@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";*{margin:0;padding:0;box-sizing:border-box}html,body{overflow-x:hidden}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;background-color:#f4f4f4}.container{max-width:800px;margin:0 auto}.header{background-color:#000;color:#fff;padding:10px 20px;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between}.header-left{display:flex;flex-direction:column}.header-left h1{margin:0;font-size:24px}.subtitle{font-family:Inter,sans-serif;font-style:italic;font-size:16px;color:#ccc}.header-right{display:flex;align-items:center}.header-right select{margin-right:15px;padding:5px}.header-right a{color:#fff;text-decoration:none;margin-left:10px;cursor:pointer}.no-decor{color:#fff;text-decoration:none}@media (max-width: 600px){.header{flex-direction:column;align-items:flex-start}.header-right{margin-top:10px;width:100%;justify-content:space-between}.header-right select,.header-right a{margin:0}}.section{background-color:#fff;padding:1em;margin-top:1em}table{width:100%;border-collapse:collapse;margin-bottom:20px}th,td{padding:10px;text-align:left;border-bottom:1px solid #ddd}th{background-color:#f4f4f4}#astro-chart h2,h3,h4{text-align:center}#astro-chart .chart{text-align:center;margin-bottom:1em}#astro-chart .chart img{max-width:100%;height:auto}#astro-chart .planet-positions{text-align:center}#astro-chart .planet-positions ul{list-style-type:none}#astro-chart .planet-positions li{margin-bottom:.5em}.horoscope-list{list-style:none;padding:0}.horoscope-item{margin-bottom:20px}.horoscope-text{margin:0;line-height:1.6;overflow:hidden}.zodiac-symbol{float:left;font-size:40px;color:#444;margin-right:15px;line-height:1.2;margin-bottom:-4px;min-width:40px;text-align:center;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-variant:normal;font-weight:400;font-family:Segoe UI Symbol,"Apple Color Emoji","Noto Color Emoji",Symbola,Arial Unicode MS,DejaVu Sans,Lucida Sans Unicode,GNU Unifont,sans-serif}.sign-name{font-weight:700;color:#333}#register{max-width:600px;margin:1em auto 0;background-color:#fff;padding:1em 1em 12em}#register h2{text-align:center;margin-bottom:1em}form{display:flex;flex-direction:column;align-items:center}.form-group{width:100%;max-width:500px;margin-bottom:1em}label{display:block;margin-bottom:.5em;font-weight:700}input[type=text],input[type=email],input[type=date],input[type=time],select{width:100%;padding:.5em;border:1px solid #ccc;border-radius:4px;font-size:1em}.autocomplete-container{position:relative;width:100%}.suggestions{position:absolute;top:100%;left:0;right:0;border:1px solid #ccc;border-top:none;background-color:#fff;max-height:200px;overflow-y:auto;z-index:1000;display:none}.suggestions div{padding:.5em;cursor:pointer}.suggestions div:hover{background-color:#f0f0f0}button{background-color:#333;color:#fff;padding:.75em 1.5em;border:none;border-radius:4px;font-size:16px;cursor:pointer;margin-top:10px;width:100%;max-width:500px}button:hover{background-color:#555}.error{color:#ff4500;margin-bottom:.5em;font-weight:700}.success{color:green;font-weight:700}.center-txt{text-align:center}#button-link{display:inline-block;background-color:#333;color:#fff;padding:.75em 1.5em;text-decoration:none;border-radius:4px;text-align:center;width:100%;max-width:500px}#button-link:hover{background-color:#555}#site-footer{padding-top:4em;padding-bottom:2em;background:linear-gradient(to bottom,#fff,#fafafa);color:#888;font-size:.8em;text-align:center;border-top:1px solid #f0f0f0;margin-top:20px}#site-footer p{margin:.5em 0;line-height:1.6}#site-footer p:first-of-type{font-weight:700;color:#666}#site-footer a{color:#888;text-decoration:none}#site-footer a:hover{color:#444;text-decoration:underline}#register-link{padding:1em;margin-top:1em}@media (max-width: 600px){.container{padding:0 .5em}#register button{width:100%}}@media (max-width: 480px){.zodiac-symbol{font-size:36px;margin-right:10px;min-width:36px;line-height:1.25;margin-bottom:0}.horoscope-text{font-size:.95em}}.landing-page{min-height:100vh;background:linear-gradient(135deg,#f8f9fa,#e8eaf6,#f3e5f5);overflow-x:hidden}.hero-section{min-height:90vh;display:flex;align-items:center;justify-content:center;padding:2rem 1rem;position:relative;overflow:hidden}.hero-content{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;position:relative;z-index:1}.stars-background{position:absolute;top:0;left:0;right:0;bottom:0;background-image:radial-gradient(2px 2px at 20% 30%,rgba(107,91,149,.3),transparent),radial-gradient(2px 2px at 60% 70%,rgba(107,91,149,.3),transparent),radial-gradient(1px 1px at 50% 50%,rgba(107,91,149,.3),transparent),radial-gradient(1px 1px at 80% 10%,rgba(107,91,149,.3),transparent),radial-gradient(2px 2px at 90% 60%,rgba(107,91,149,.3),transparent),radial-gradient(1px 1px at 33% 80%,rgba(107,91,149,.3),transparent);background-size:200% 200%;animation:twinkle 8s ease-in-out infinite;pointer-events:none}@keyframes twinkle{0%,to{opacity:.5}50%{opacity:1}}.hero-text{text-align:left}.hero-title{font-size:3.5rem;font-weight:700;line-height:1.2;margin-bottom:1.5rem;color:#2d2d2d}.gradient-text{background:linear-gradient(135deg,#6b5b95,#8e7cc3,#b8a4d9);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:inline-block}.hero-subtitle{font-size:1.25rem;line-height:1.8;color:#5a5a5a;margin-bottom:2.5rem;max-width:500px}.cta-button{display:inline-flex;align-items:center;gap:.75rem;padding:1rem 2.5rem;font-size:1.125rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#6b5b95,#8e7cc3);border:none;border-radius:50px;text-decoration:none;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #6b5b954d}.cta-button:hover{transform:translateY(-2px);box-shadow:0 6px 25px #6b5b9566;background:linear-gradient(135deg,#7c6ca5,#9f8dd3)}.cta-button:active{transform:translateY(0)}.cta-icon{font-size:1.5rem;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.hero-visual{display:flex;justify-content:center;align-items:center}.astro-illustration{width:100%;max-width:400px;height:auto;filter:drop-shadow(0 10px 30px rgba(107,91,149,.2));animation:float 6s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.features-section{padding:5rem 1rem;background:#fff}.features-container{max-width:1200px;margin:0 auto}.section-title{font-size:2.5rem;font-weight:700;text-align:center;color:#2d2d2d;margin-bottom:3rem}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;margin-top:3rem}.feature-card{background:#fafafa;padding:2.5rem 2rem;border-radius:20px;text-align:center;transition:all .3s ease;border:2px solid transparent}.feature-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px #6b5b9526;border-color:#e8d5ff;background:#fff}.feature-icon{font-size:3rem;margin-bottom:1.25rem;display:inline-block;animation:bounce 2s ease-in-out infinite}.feature-card:nth-child(1) .feature-icon{animation-delay:0s}.feature-card:nth-child(2) .feature-icon{animation-delay:.3s}.feature-card:nth-child(3) .feature-icon{animation-delay:.6s}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.feature-title{font-size:1.5rem;font-weight:600;color:#2d2d2d;margin-bottom:1rem}.feature-description{font-size:1rem;line-height:1.7;color:#666}.cta-section{padding:5rem 1rem;background:linear-gradient(135deg,#6b5b95,#8e7cc3);text-align:center}.cta-container{max-width:800px;margin:0 auto}.cta-title{font-size:2.5rem;font-weight:700;color:#fff;margin-bottom:1.5rem}.cta-text{font-size:1.25rem;line-height:1.7;color:#ffffffe6;margin-bottom:2.5rem}.cta-button-large{padding:1.25rem 3rem;font-size:1.25rem;background:#fff;color:#6b5b95;box-shadow:0 4px 20px #0003}.cta-button-large:hover{background:#f8f9fa;color:#6b5b95;box-shadow:0 6px 30px #0000004d}.landing-footer{padding:2rem 1rem;text-align:center;background:#f8f9fa;color:#5a5a5a;font-size:.95rem}.card-page,.register-page,.login-page{min-height:100vh;background:linear-gradient(135deg,#f8f9fa,#e8eaf6,#f3e5f5);padding:2rem 1rem;display:flex;justify-content:center}.login-container{max-width:900px;width:100%;background:#fff;border-radius:20px;padding:3rem 2.5rem;box-shadow:0 10px 40px #6b5b9526;display:flex;flex-direction:column;min-height:80vh}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{font-size:2rem;font-weight:700;line-height:1.2;margin-bottom:1rem;color:#2d2d2d}.login-subtitle{font-size:1rem;color:#666;line-height:1.6}.login-content{margin-bottom:2rem}.login-visual{display:flex;align-items:center;justify-content:center;margin-bottom:2rem}.login-illustration{width:200px;height:200px;animation:rotateGlow 20s linear infinite}@keyframes rotateGlow{0%{transform:rotate(0);filter:drop-shadow(0 0 10px rgba(107,91,149,.3))}50%{filter:drop-shadow(0 0 20px rgba(107,91,149,.5))}to{transform:rotate(360deg);filter:drop-shadow(0 0 10px rgba(107,91,149,.3))}}.login-form{width:100%}.login-form .form-group{margin-bottom:1.5rem}.login-form label{display:block;margin-bottom:.5rem;font-weight:500;color:#2d2d2d;font-size:.95rem}.login-form input{width:100%;padding:.875rem 1rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:all .3s ease;background:#fafafa}.login-form input:focus{outline:none;border-color:#6b5b95;background:#fff;box-shadow:0 0 0 3px #6b5b951a}.btn-login{width:100%;padding:.875rem 2rem;font-size:1rem;font-weight:600;border:none;border-radius:50px;cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;min-height:44px;background:linear-gradient(135deg,#6b5b95,#8e7cc3);color:#fff;box-shadow:0 4px 15px #6b5b954d;margin-top:.5rem}.btn-login:hover{transform:translateY(-2px);box-shadow:0 6px 25px #6b5b9566;background:linear-gradient(135deg,#7c6ca5,#9f8dd3)}.btn-login:active{transform:translateY(0)}.btn-login .btn-icon{font-size:1.25rem}.card-page-footer,.register-prompt{text-align:center;padding-top:2rem;padding-bottom:2rem;margin-top:auto;border-top:1px solid #e0e0e0}.card-page-footer p,.register-prompt p{font-size:.95rem;color:#666}.card-page-footer-link,.register-link{color:#6b5b95;font-weight:600;text-decoration:none;transition:all .3s ease}.card-page-footer-link:hover,.register-link:hover{color:#8e7cc3;text-decoration:underline}.register-container{max-width:900px;width:100%;background:#fff;border-radius:20px;padding:3rem 2.5rem;box-shadow:0 10px 40px #6b5b9526;display:flex;flex-direction:column;min-height:80vh}.register-header{text-align:center;margin-bottom:2.5rem}.register-header h1{font-size:2.5rem;font-weight:700;line-height:1.2;margin-bottom:1rem;color:#2d2d2d}.register-subtitle{font-size:1.125rem;color:#666;line-height:1.6}.step-indicator{display:flex;align-items:center;justify-content:space-between;margin-bottom:3rem;padding:0 1rem}.step{display:flex;flex-direction:column;align-items:center;gap:.5rem;flex:0 0 auto;position:relative}.step-number{width:48px;height:48px;border-radius:50%;background:#e0e0e0;color:#999;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1.25rem;transition:all .3s ease}.step.active .step-number{background:linear-gradient(135deg,#6b5b95,#8e7cc3);color:#fff;box-shadow:0 4px 15px #6b5b954d}.step.completed .step-number{background:#4caf50;color:#fff}.step-label{font-size:.875rem;font-weight:500;color:#999;transition:all .3s ease}.step.active .step-label{color:#6b5b95;font-weight:600}.step.completed .step-label{color:#4caf50}.step-line{flex:1;height:2px;background:#e0e0e0;margin:0 .5rem 2rem}.step-content{margin-bottom:2rem;animation:fadeIn .4s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.step-title{font-size:1.75rem;font-weight:600;color:#2d2d2d;margin-bottom:.75rem;text-align:center}.step-description{font-size:1rem;color:#666;text-align:center;margin-bottom:2rem;line-height:1.6}.language-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:2rem}.language-card{position:relative;padding:1.25rem 1rem;background:#fafafa;border:2px solid #e0e0e0;border-radius:12px;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;min-height:70px}.language-card:hover{border-color:#b8a4d9;background:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #6b5b951a}.language-card.selected{border-color:#6b5b95;background:linear-gradient(135deg,#6b5b950d,#b8a4d90d);box-shadow:0 4px 15px #6b5b9533}.language-name{font-size:1.125rem;font-weight:500;color:#2d2d2d;text-align:center}.check-icon{position:relative;top:auto;right:auto;width:24px;height:24px;background:#6b5b95;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;flex-shrink:0}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.5rem}.full-width-field{margin-bottom:1.5rem;width:100%}.full-width-field .form-group{margin-bottom:0;width:100%;max-width:none}.full-width-field .autocomplete-container,.full-width-field input{width:100%}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#2d2d2d;font-size:.95rem}.form-group input{width:100%;padding:.875rem 1rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:all .3s ease;background:#fafafa}.form-group input:focus{outline:none;border-color:#6b5b95;background:#fff;box-shadow:0 0 0 3px #6b5b951a}.form-group small{display:block;margin-top:.5rem;font-size:.875rem;color:#666}.email-input{animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;max-height:0;margin:0}to{opacity:1;max-height:200px;margin-bottom:1.5rem}}.communication-grid{display:flex;flex-direction:column;align-items:center;gap:1rem;margin-bottom:2rem;max-width:500px;margin-left:auto;margin-right:auto}.communication-card{position:relative;padding:1rem 1.5rem;background:#fafafa;border:2px solid #e0e0e0;border-radius:12px;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:row;align-items:center;justify-content:flex-start;gap:1rem;min-height:60px;width:100%}.communication-card:hover{border-color:#b8a4d9;background:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #6b5b951a}.communication-card.selected{border-color:#6b5b95;background:linear-gradient(135deg,#6b5b950d,#b8a4d90d);box-shadow:0 4px 15px #6b5b9533}.comm-icon{width:40px;height:40px;object-fit:contain}.comm-name{font-size:1.125rem;font-weight:500;color:#2d2d2d;text-align:left;flex:1}.comm-card-icon{font-size:2.5rem;margin-bottom:.75rem}.communication-card h3{font-size:1.25rem;font-weight:600;color:#2d2d2d;margin-bottom:.5rem}.communication-card p{font-size:.9rem;color:#666;margin-bottom:1rem;line-height:1.4}.btn-comm-select{width:100%;padding:.75rem 1.5rem;font-size:.95rem;font-weight:600;border:none;border-radius:50px;cursor:pointer;transition:all .3s ease;background:linear-gradient(135deg,#6b5b95,#8e7cc3);color:#fff;box-shadow:0 4px 15px #6b5b954d}.btn-comm-select:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6b5b9566}.telegram-link-section{display:flex;flex-direction:column;align-items:center;gap:1rem;width:100%}.btn-telegram-link{width:100%;padding:.75rem 1.5rem;font-size:.95rem;font-weight:600;border:none;border-radius:50px;cursor:pointer;transition:all .3s ease;background:linear-gradient(135deg,#08c,#0ae);color:#fff;box-shadow:0 4px 15px #0088cc4d;text-decoration:none;text-align:center;display:inline-block}.btn-telegram-link:hover{transform:translateY(-2px);box-shadow:0 6px 20px #08c6;color:#fff}.whatsapp-link-section{display:flex;flex-direction:column;align-items:center;gap:1rem;width:100%}.btn-whatsapp-link{width:100%;padding:.75rem 1.5rem;font-size:.95rem;font-weight:600;border:none;border-radius:50px;cursor:pointer;transition:all .3s ease;background:linear-gradient(135deg,#25d366,#128c7e);color:#fff;box-shadow:0 4px 15px #25d3664d;text-decoration:none;text-align:center;display:inline-block}.btn-whatsapp-link:hover{transform:translateY(-2px);box-shadow:0 6px 20px #25d36666;color:#fff}.whatsapp-instruction{font-size:.85rem;color:#666;font-style:italic;margin:0}.comm-provider-icon-img{width:32px;height:32px;object-fit:contain;flex-shrink:0}.comm-detail-icon-img{width:48px;height:48px;object-fit:contain}.current-provider-icon-img{width:20px;height:20px;object-fit:contain}.waiting-indicator{display:flex;flex-direction:column;align-items:center;gap:.5rem}.waiting-text{font-size:.85rem;color:#666}.comm-setup-container{max-width:500px}.comm-provider-options{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem;animation:fadeIn .4s ease}.comm-provider-option{display:flex;align-items:center;gap:1rem;padding:1.25rem 1.5rem;background:#fff;border:2px solid #e0e0e0;border-radius:16px;cursor:pointer;transition:all .3s ease}.comm-provider-option:hover{border-color:#b8a4d9;background:linear-gradient(135deg,#6b5b9508,#b8a4d908);transform:translateY(-2px);box-shadow:0 6px 20px #6b5b951f}.comm-provider-option:active{transform:translateY(0)}.comm-provider-icon{font-size:2rem;flex-shrink:0}.comm-provider-name{font-size:1.125rem;font-weight:600;color:#2d2d2d}.comm-provider-details{display:flex;flex-direction:column;align-items:center;text-align:center;padding:2rem;background:#fff;border:2px solid #6b5b95;border-radius:20px;margin-bottom:2rem;animation:fadeIn .4s ease;box-shadow:0 8px 30px #6b5b9526}.comm-detail-header{display:flex;flex-direction:column;align-items:center;gap:.75rem;margin-bottom:1rem}.comm-detail-icon{font-size:3rem}.comm-detail-header h3{font-size:1.5rem;font-weight:700;color:#2d2d2d;margin:0}.comm-detail-description{font-size:1rem;color:#666;line-height:1.6;margin:0 0 1.5rem}.btn-comm-confirm{width:100%;max-width:280px;padding:.875rem 2rem;font-size:1rem;font-weight:600;border:none;border-radius:50px;cursor:pointer;transition:all .3s ease;background:linear-gradient(135deg,#6b5b95,#8e7cc3);color:#fff;box-shadow:0 4px 15px #6b5b954d;margin-bottom:1rem}.btn-comm-confirm:hover{transform:translateY(-2px);box-shadow:0 6px 25px #6b5b9566;background:linear-gradient(135deg,#7c6ca5,#9f8dd3)}.btn-comm-back{background:transparent;border:none;color:#6b5b95;font-size:.95rem;font-weight:500;cursor:pointer;padding:.5rem 1rem;transition:all .3s ease}.btn-comm-back:hover{color:#8e7cc3;text-decoration:underline}.comm-provider-details .telegram-link-section{width:100%;max-width:280px;margin-bottom:1rem}.comm-provider-details .btn-telegram-link{width:100%}@media (max-width: 480px){.comm-setup-container{padding:1.5rem 1rem}.comm-provider-option{padding:1rem 1.25rem}.comm-provider-icon{font-size:1.75rem}.comm-provider-name{font-size:1rem}.comm-provider-details{padding:1.5rem 1rem}.comm-detail-icon{font-size:2.5rem}.comm-detail-header h3{font-size:1.25rem}}.comm-selector-embedded{width:100%}.comm-selector-embedded .comm-provider-options{margin-bottom:0}.comm-selector-embedded .comm-provider-option{padding:.875rem 1rem;border-radius:10px}.comm-selector-embedded .comm-provider-option.current{border-color:#d5c2f0;background:linear-gradient(135deg,#6b5b950d,#b8a4d90d);cursor:default}.comm-selector-embedded .comm-provider-icon{font-size:1.5rem}.comm-selector-embedded .comm-provider-name{font-size:1rem}.comm-selector-embedded .comm-provider-details{padding:1.25rem;border-radius:12px}.comm-selector-embedded .comm-detail-icon{font-size:2rem}.comm-selector-embedded .comm-detail-header h3{font-size:1.125rem}.comm-selector-embedded .comm-detail-description{font-size:.9rem;margin-bottom:1rem}.comm-selector-embedded .btn-comm-confirm{max-width:100%;padding:.75rem 1.5rem;font-size:.9rem}.comm-selector-embedded .btn-telegram-link{font-size:.9rem;padding:.75rem 1.5rem}.provider-current-tag{margin-left:auto;color:#6b5b95;font-weight:600}.current-provider-badge{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:linear-gradient(135deg,#6b5b9514,#b8a4d914);border-radius:10px;margin-bottom:.75rem}.current-provider-icon{font-size:1.25rem}.current-provider-name{font-size:.9rem;color:#5a5a5a}.button-group{display:flex;gap:1rem;justify-content:flex-end;align-items:center;margin-top:2rem}.button-group:has(.btn-submit):not(:has(.btn-back)){justify-content:center}.btn-back,.btn-next,.btn-submit{padding:.875rem 2rem;font-size:1rem;font-weight:600;border:none;border-radius:50px;cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;gap:.5rem;min-height:44px}.btn-back{background:#f5f5f5;color:#666;border:2px solid #e0e0e0}.btn-back:hover{background:#e0e0e0;color:#2d2d2d}.btn-next,.btn-submit{background:linear-gradient(135deg,#6b5b95,#8e7cc3);color:#fff;box-shadow:0 4px 15px #6b5b954d;justify-content:center;min-width:180px}.btn-next:hover,.btn-submit:hover{transform:translateY(-2px);box-shadow:0 6px 25px #6b5b9566;background:linear-gradient(135deg,#7c6ca5,#9f8dd3)}.btn-next:active,.btn-submit:active{transform:translateY(0)}.btn-icon{font-size:1.25rem;animation:pulse 2s ease-in-out infinite}.error-message{background:#ffebee;color:#c62828;padding:1rem 1.25rem;border-radius:8px;margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem;border-left:4px solid #c62828;animation:shake .4s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.error-icon{font-size:1.25rem}.success-card{text-align:center;padding:2rem;animation:fadeIn .6s ease}.success-icon{font-size:4rem;margin-bottom:1.5rem;display:inline-block;animation:bounce 1s ease infinite}.success-card h2{font-size:2rem;color:#2d2d2d;margin-bottom:1rem}.success-card p{font-size:1.125rem;color:#666;margin-bottom:2rem;line-height:1.6}.card-page-footer,.login-prompt{text-align:center;padding-top:2rem;padding-bottom:2rem;margin-top:auto;border-top:1px solid #e0e0e0}.card-page-footer p,.login-prompt p{font-size:.95rem;color:#666}.card-page-footer-link,.login-link{color:#6b5b95;font-weight:600;text-decoration:none;transition:all .3s ease}.card-page-footer-link:hover,.login-link:hover{color:#8e7cc3;text-decoration:underline}@media (max-width: 768px){.hero-content{grid-template-columns:1fr;gap:2rem;text-align:center}.hero-text{text-align:center}.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.125rem;max-width:100%}.astro-illustration{max-width:300px}.section-title,.cta-title{font-size:2rem}.cta-text{font-size:1.125rem}.features-grid{grid-template-columns:1fr;gap:1.5rem}.feature-card,.register-container{padding:2rem 1.5rem}.register-header h1{font-size:2rem}.register-subtitle{font-size:1rem}.login-container{padding:2rem 1.5rem}.login-header h1{font-size:1.75rem}.login-subtitle{font-size:.95rem}.login-illustration{width:150px;height:150px}.step-indicator{padding:0}.step-number{width:40px;height:40px;font-size:1rem}.step-label{font-size:.75rem}.step-line{margin:0 .25rem}.step-title{font-size:1.5rem}.language-grid,.communication-grid{grid-template-columns:repeat(2,1fr)}.register-container .form-grid{grid-template-columns:1fr;gap:1.5rem}.button-group{flex-direction:column}.btn-back{order:2}.btn-next,.btn-submit{order:1}}@media (max-width: 480px){.hero-section{min-height:auto;padding:3rem 1rem}.hero-title{font-size:2rem}.hero-subtitle{font-size:1rem;margin-bottom:2rem}.cta-button{padding:.875rem 2rem;font-size:1rem}.astro-illustration{max-width:250px}.section-title{font-size:1.75rem}.feature-icon{font-size:2.5rem}.feature-title{font-size:1.25rem}.feature-description{font-size:.95rem}.cta-section{padding:3rem 1rem}.cta-title{font-size:1.75rem}.cta-text{font-size:1rem}.cta-button-large{padding:1rem 2rem;font-size:1rem}.register-page{padding:1rem .5rem}.register-container{padding:1.5rem 1rem;border-radius:15px}.register-header h1{font-size:1.75rem}.register-subtitle{font-size:.95rem}.login-page{padding:1rem .5rem}.login-container{padding:1.5rem 1rem;border-radius:15px}.login-header h1{font-size:1.5rem}.login-subtitle{font-size:.875rem}.login-illustration{width:120px;height:120px}.step-indicator{margin-bottom:2rem}.step-title{font-size:1.25rem}.step-description{font-size:.95rem}.language-grid,.communication-grid{gap:.75rem}.language-card,.communication-card{padding:1.25rem .75rem;min-height:100px}.language-flag,.comm-icon{font-size:2rem}.btn-back,.btn-next,.btn-submit{padding:.75rem 1.5rem;font-size:.95rem}}@media (min-width: 1440px){.hero-title{font-size:4rem}.hero-subtitle{font-size:1.375rem}.section-title,.cta-title{font-size:3rem}}@media (prefers-reduced-motion: reduce){.astro-illustration,.stars-background,.cta-icon,.feature-icon,.login-illustration{animation:none}.cta-button:hover,.feature-card:hover{transform:none}.step-content,.error-message,.success-card,.email-input{animation:none}.btn-next:hover,.btn-submit:hover,.btn-login:hover,.language-card:hover,.communication-card:hover{transform:none}}.home-page{min-height:100vh;background:linear-gradient(135deg,#f8f9fa,#e8eaf6,#f3e5f5);padding:0}.home-container{max-width:1000px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column}.home-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;background:linear-gradient(135deg,#6b5b95,#8e7cc3);color:#fff;flex-wrap:wrap;gap:1rem}.home-header-left h1{margin:0;font-size:1.75rem;font-weight:700}.home-title-link{color:#fff;text-decoration:none;transition:opacity .3s ease}.home-title-link:hover{opacity:.9}.home-subtitle{font-family:Inter,sans-serif;font-style:italic;font-size:1rem;color:#ffffffd9;margin:.25rem 0 0}.home-header-right{display:flex;align-items:center;gap:1rem}.language-select{padding:.5rem .75rem;border:1px solid rgba(255,255,255,.3);border-radius:8px;background:#ffffff26;color:#fff;font-size:.9rem;cursor:pointer}.language-select option{color:#333;background:#fff}.header-link{color:#fff;text-decoration:none;font-size:.95rem;padding:.5rem 1rem;border-radius:8px;transition:background .3s ease}.header-link:hover{background:#ffffff26}.logout-btn{background:#fff3;color:#fff;border:none;padding:.5rem 1rem;border-radius:8px;font-size:.95rem;cursor:pointer;transition:background .3s ease}.logout-btn:hover{background:#ffffff4d}.chat-interface{flex:1;padding:2rem;display:flex;flex-direction:column;gap:2rem}.chat-greeting{display:flex;align-items:center;gap:1.5rem;padding:2rem;background:#fff;border-radius:20px;box-shadow:0 4px 20px #6b5b951a}.ai-avatar{width:80px;height:80px;flex-shrink:0;animation:float 6s ease-in-out infinite}.ai-avatar svg{width:100%;height:100%;filter:drop-shadow(0 4px 10px rgba(107,91,149,.3))}.greeting-text h2{font-size:1.75rem;margin-bottom:.5rem}.greeting-text p{color:#666;font-size:1rem;margin:0}.chat-message{display:flex;gap:1rem;padding:1.5rem;background:#fff;border-radius:16px;box-shadow:0 4px 15px #6b5b9514;animation:slideIn .5s ease}.chat-message.featured{background:linear-gradient(135deg,#faf8ff,#f3e5f5);border:2px solid #e8d5ff}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message-icon{font-size:2rem;flex-shrink:0}.message-content{flex:1}.message-header{font-weight:600;color:#6b5b95;margin-bottom:.5rem;font-size:1.1rem}.message-content p{color:#444;line-height:1.7;margin:0}.chat-section{display:flex;flex-direction:column;gap:1rem}.chat-bubble{display:flex;gap:.75rem;padding:1rem 1.25rem;border-radius:12px;animation:slideIn .3s ease}.chat-bubble.user-bubble{background:linear-gradient(135deg,#6b5b95,#8e7cc3);margin-left:20%}.chat-bubble.user-bubble .bubble-content p{color:#fff}.chat-bubble.ai-bubble{background:linear-gradient(135deg,#faf8ff,#f3e5f5);border:1px solid #e8d5ff;margin-right:20%}.chat-bubble.ai-bubble .bubble-content p{color:#444}.bubble-icon{font-size:1.25rem;flex-shrink:0}.bubble-content{flex:1}.bubble-content p{margin:0;line-height:1.5;white-space:pre-wrap}.typing-indicator{display:inline-block;animation:typingPulse 1s ease-in-out infinite}@keyframes typingPulse{0%,to{opacity:.4}50%{opacity:1}}.chat-send-btn:disabled{background:#888;cursor:not-allowed;opacity:.7}.waiting-dots{display:flex;justify-content:center;align-items:center;gap:6px;padding:8px 0}.waiting-dots .dot{width:8px;height:8px;background:linear-gradient(135deg,#6b5b95,#8e7cc3);border-radius:50%;animation:dotWave 1.4s ease-in-out infinite}.waiting-dots .dot:nth-child(1){animation-delay:0s}.waiting-dots .dot:nth-child(2){animation-delay:.2s}.waiting-dots .dot:nth-child(3){animation-delay:.4s}@keyframes dotWave{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-8px);opacity:1}}.chat-bubble.error-bubble{background:linear-gradient(135deg,#fff5f5,#ffe6e6);border:1px solid #ffcccc;margin-right:20%}.chat-bubble.error-bubble .bubble-content p{color:#c44}.chat-bubble.chart-bubble{background:#fff;border:2px solid #e8d5ff}.chat-chart-image{max-width:100%;height:auto;border-radius:12px;margin-top:.5rem}.category-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}.category-card{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 4px 15px #6b5b9514;transition:all .3s ease;border:2px solid transparent}.category-card:hover{transform:translateY(-3px);box-shadow:0 8px 25px #6b5b9526;border-color:#e8d5ff}.category-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.category-icon{font-size:1.5rem}.category-title{font-weight:600;color:#6b5b95;font-size:1.1rem}.category-text{color:#555;line-height:1.6;font-size:.95rem;margin:0 0 1rem}.category-score{margin-top:auto;padding-top:1rem;border-top:1px solid #f0f0f0}.score-container{display:flex;align-items:center;gap:1rem}.score-bar-bg{flex:1;height:8px;background:#e8eaf6;border-radius:4px;overflow:hidden}.score-bar-fill{height:100%;background:linear-gradient(90deg,#6b5b95,#8e7cc3);border-radius:4px;transition:width 1s ease}.score-value{font-size:.85rem;font-weight:600;color:#6b5b95;min-width:40px;text-align:right}.chart-section{background:#fff;border-radius:20px;padding:2rem;box-shadow:0 4px 20px #6b5b951a}.chart-title{text-align:center;color:#2d2d2d;margin-bottom:1.5rem;font-size:1.5rem}.chart-container{display:flex;justify-content:center;overflow:hidden;border-radius:12px}.chart-image{max-width:100%;height:auto;border-radius:12px}.home-footer{text-align:center;padding:2rem;color:#666;font-size:.9rem;border-top:1px solid #e0e0e0;background:#fff}.loading-state,.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;gap:1rem}.loading-spinner{font-size:4rem;animation:pulse 1.5s ease-in-out infinite}.error-icon{font-size:4rem}.loading-state p,.error-state p{color:#666;font-size:1.1rem}.home-page.chat-layout{display:flex;flex-direction:column;height:100vh;height:100dvh;overflow:hidden}.home-page.chat-layout .home-container{flex:1;display:flex;flex-direction:column;overflow:hidden}.chat-content-wrapper{max-width:900px;width:100%;margin:0 auto}.chat-header{display:flex;justify-content:center;align-items:center;padding:.6rem 1.5rem;background:linear-gradient(135deg,#6b5b95,#8e7cc3);color:#fff;flex-shrink:0}.chat-header-inner{display:flex;justify-content:space-between;align-items:center;width:100%;max-width:900px}.chat-header-logo{color:#fff;text-decoration:none;font-size:1.2rem;font-weight:700;transition:opacity .3s ease}.chat-header-logo:hover{opacity:.9}.chat-header-actions{display:flex;flex-direction:row;align-items:center;gap:0}.chat-header-link{color:#fff;text-decoration:none;font-size:.8rem;line-height:1;padding:.5rem 1rem;transition:all .3s ease;background:#ffffff1f;cursor:pointer}.chat-header-link:first-child{border-radius:16px 0 0 16px}.chat-header-link:last-child{border-radius:0 16px 16px 0;border-left:1px solid rgba(255,255,255,.15)}.chat-header-link:hover{background:#ffffff40}.chat-response-area{flex:1;overflow-y:auto;overflow-x:hidden;padding:1.5rem;display:flex;flex-direction:column;align-items:center;gap:1.5rem;scroll-behavior:smooth}.chat-response-area>*{max-width:900px;width:100%}.chat-starter{display:flex;align-items:center;gap:1.25rem;padding:1.5rem;background:#fff;border-radius:16px;box-shadow:0 4px 20px #6b5b951a}.chat-starter-avatar{width:60px;height:60px;flex-shrink:0;animation:float 6s ease-in-out infinite}.chat-starter-avatar svg{width:100%;height:100%;filter:drop-shadow(0 4px 10px rgba(107,91,149,.3))}.chat-starter-content h2{font-size:1.5rem;margin:0 0 .25rem}.chat-starter-date{color:#666;font-size:.95rem;margin:0}.chat-input-container{flex-shrink:0;background:#fff;border-top:1px solid #e8eaf6;padding:.75rem 1.5rem .25rem;display:flex;flex-direction:column;align-items:center}.chat-input-form{display:flex;flex-direction:row;align-items:stretch;background:#fff;border-radius:26px;border:2px solid #d5c2f0;transition:all .3s ease;max-width:900px;width:100%;box-sizing:border-box;overflow:hidden}.chat-input-form:focus-within{border-color:#8e7cc3;box-shadow:0 0 0 3px #6b5b951f}.chat-input{flex:1 1 auto;order:1;border:none;background:transparent;padding:.7rem 1rem;font-size:.95rem;color:#2d2d2d;outline:none;min-width:0}.chat-input::placeholder{color:#aaa}.char-count{display:flex;align-items:center;padding:0 .5rem;font-size:.75rem;color:#999;order:2}.chat-send-btn{order:3;width:50px;height:auto;border-radius:0;border:none;margin:-2px -2px -2px 0;background:linear-gradient(135deg,#6b5b95,#8e7cc3);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.chat-send-btn:hover{background:linear-gradient(135deg,#7c6ba5,#9f8dd3)}.chat-send-btn:active{background:linear-gradient(135deg,#5c4b85,#7e6cb3)}.send-icon{font-size:1.2rem;font-weight:700}.chat-footer{text-align:center;padding:.4rem 0 .2rem;color:#ccc;font-size:.65rem;letter-spacing:.02em;max-width:900px;width:100%}.command-link{color:#6b5b95;cursor:pointer;text-decoration:none;font-family:SF Mono,Monaco,Consolas,monospace;background:#6b5b951a;padding:2px 6px;border-radius:4px;transition:all .2s ease;white-space:nowrap}.command-link:hover{background:#6b5b9533;text-decoration:underline}.command-menu{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem;padding-top:.75rem;border-top:1px solid rgba(107,91,149,.15)}.command-button{display:flex;flex-direction:column;align-items:flex-start;gap:.15rem;padding:.5rem .85rem;background:#6b5b9514;border:1px solid rgba(107,91,149,.2);border-radius:12px;font-size:.85rem;cursor:pointer;transition:all .2s ease;min-width:140px;max-width:200px;text-align:left}.command-button:hover{background:#6b5b9526;border-color:#6b5b95;transform:translateY(-1px);box-shadow:0 2px 8px #6b5b9526}.command-button:active{transform:translateY(0);box-shadow:none}.command-name{font-family:SF Mono,Monaco,Consolas,monospace;font-weight:600;color:#6b5b95;font-size:.85rem}.command-label{font-size:.75rem;color:#666;line-height:1.3}.start-bubble .bubble-content{max-width:100%}@media (max-width: 768px){.home-header{padding:1rem;flex-direction:column;text-align:center}.home-header-left{order:1}.home-header-right{order:2;flex-wrap:wrap;justify-content:center}.chat-interface{padding:1rem;gap:1.5rem}.chat-greeting{flex-direction:column;text-align:center;padding:1.5rem}.ai-avatar{width:60px;height:60px}.greeting-text h2{font-size:1.4rem}.category-grid{grid-template-columns:1fr}.chat-message{padding:1.25rem}.message-icon{font-size:1.5rem}.chat-response-area{padding:1rem;gap:1rem}.chat-starter{flex-direction:column;text-align:center;padding:1.25rem}.chat-starter-avatar{width:50px;height:50px}.chat-starter-content h2{font-size:1.35rem}.chat-input-container{padding:.5rem 1rem .25rem}}@media (max-width: 480px){.home-header-left h1{font-size:1.4rem}.home-header-right{gap:.5rem}.header-link,.logout-btn{padding:.4rem .75rem;font-size:.85rem}.language-select{padding:.4rem .5rem;font-size:.85rem}.greeting-text h2{font-size:1.25rem}.category-card{padding:1rem}.chat-header{padding:.5rem 1rem}.chat-header-logo{font-size:1rem}.chat-header-link,.chat-header-logout{font-size:.7rem;padding:.4rem .75rem}.chat-response-area{padding:.75rem;gap:.75rem}.chat-starter{padding:1rem}.chat-starter-avatar{width:45px;height:45px}.chat-starter-content h2{font-size:1.2rem}.chat-starter-date{font-size:.85rem}.chat-input-container{padding:.5rem .75rem .25rem}.chat-input{font-size:.9rem;padding:.6rem .75rem}.chat-send-btn{width:44px}.send-icon{font-size:1.1rem}}.chat-message,.category-card,.chart-section{animation:fadeSlideIn .3s ease-out}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.settings-page{min-height:100vh;background:linear-gradient(135deg,#f8f9fa,#e8eaf6,#f3e5f5);display:flex;flex-direction:column}.settings-content{flex:1;display:flex;flex-direction:column;align-items:center;padding:2rem 1rem;overflow-y:auto}.settings-title{text-align:center;margin-bottom:2rem;max-width:600px}.settings-title h1{font-size:2rem;font-weight:700;line-height:1.3;margin-bottom:.5rem;color:#2d2d2d}.settings-subtitle{font-size:1rem;color:#666;line-height:1.6}.settings-form{width:100%;max-width:900px;display:flex;flex-direction:column;gap:1rem}.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.settings-section{background:#fff;border-radius:16px;padding:1.5rem;border:1px solid #e8e8e8;transition:all .3s ease;box-shadow:0 2px 8px #6b5b950f;display:flex;flex-direction:column}.settings-section:hover{border-color:#d5c2f0;box-shadow:0 4px 16px #6b5b951f}.section-label{font-size:1rem;font-weight:600;color:#6b5b95;margin-bottom:1.25rem;display:flex;align-items:center;gap:.5rem}.section-icon{font-size:1.25rem}.settings-form .form-group{margin-bottom:1rem}.settings-form .form-group:last-child{margin-bottom:0}.settings-form label{display:block;margin-bottom:.5rem;font-weight:500;color:#2d2d2d;font-size:.9rem}.settings-form input,.settings-form select{width:100%;padding:.75rem 1rem;border:2px solid #e0e0e0;border-radius:10px;font-size:.95rem;transition:all .3s ease;background:#fafafa}.settings-form input:focus,.settings-form select:focus{outline:none;border-color:#6b5b95;background:#fff;box-shadow:0 0 0 3px #6b5b951a}.settings-select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b5b95' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem;background-color:#fafafa}.success-message{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);color:#2e7d32;padding:1rem 1.25rem;border-radius:10px;margin-bottom:.5rem;display:flex;align-items:center;gap:.75rem;border-left:4px solid #4caf50;animation:slideIn .4s ease}.success-icon{width:24px;height:24px;background:#4caf50;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem;flex-shrink:0}@keyframes slideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.settings-actions{display:flex;justify-content:center;margin-top:.5rem}.settings-actions .btn-submit{min-width:200px}.settings-content .loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:1rem}.settings-content .loading-spinner{font-size:3rem;animation:spin 2s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.settings-content .loading-state p{color:#666;font-size:1rem}@media (max-width: 768px){.settings-content{padding:1.5rem 1rem}.settings-title h1{font-size:1.6rem}.settings-grid{grid-template-columns:1fr}.settings-section{padding:1.25rem}}@media (max-width: 480px){.settings-content{padding:1rem .75rem}.settings-title h1{font-size:1.4rem}.section-label{font-size:.95rem}.settings-actions .btn-submit{width:100%}}@supports (-webkit-touch-callout: none){@media (max-width: 768px){.settings-form input[type=date],.settings-form input[type=time]{max-width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;min-width:0;box-sizing:border-box}.settings-form .form-group:not(:has(.autocomplete-container)){overflow:hidden}.settings-form .autocomplete-container{overflow:visible}.settings-form .suggestions{position:absolute;z-index:9999}.register-container .form-grid{overflow:hidden}.register-container .form-grid input[type=date],.register-container .form-grid input[type=time]{width:100%;max-width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;min-width:0;box-sizing:border-box}.register-container .form-group:not(:has(.autocomplete-container)){overflow:hidden;max-width:100%;width:100%}.register-container .autocomplete-container{overflow:visible}.register-container .suggestions{position:absolute;z-index:9999}}}.settings-section-danger{border-color:#ffcdd2;background:linear-gradient(135deg,#fff5f5,#ffebee)}.settings-section-danger:hover{border-color:#ef9a9a;box-shadow:0 4px 16px #f443361f}.settings-section-full{grid-column:1 / -1}.section-label-danger{color:#c62828}.account-email{font-size:1rem;font-weight:500;color:#2d2d2d;padding:.5rem 0;margin-bottom:.5rem;border-bottom:1px solid #ffcdd2}.danger-text{font-size:.9rem;color:#666;line-height:1.5;margin-bottom:1rem}.btn-danger{width:100%;padding:.75rem 1.5rem;font-size:.95rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;background:#e53935;color:#fff;box-shadow:0 2px 8px #e5393540}.btn-danger:hover{background:#c62828;box-shadow:0 4px 12px #e5393559;transform:translateY(-1px)}.delete-confirm{display:flex;flex-direction:column;gap:1rem}.confirm-text{font-size:.95rem;font-weight:500;color:#c62828;text-align:center;padding:.75rem;background:#c6282814;border-radius:8px}.confirm-buttons{display:flex;gap:.75rem}.btn-cancel{flex:1;padding:.75rem 1rem;font-size:.9rem;font-weight:500;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .3s ease;background:#f5f5f5;color:#666}.btn-cancel:hover{background:#e0e0e0;color:#2d2d2d}.btn-cancel:disabled{opacity:.5;cursor:not-allowed}.btn-danger-confirm{flex:1;padding:.75rem 1rem;font-size:.9rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;background:#c62828;color:#fff}.btn-danger-confirm:hover{background:#b71c1c}.btn-danger-confirm:disabled{opacity:.6;cursor:not-allowed}
