.auth-modal-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.auth-modal{background:var(--bg-secondary);border-radius:12px;max-width:480px;width:100%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 20px 60px #00000080}.auth-modal-close{position:absolute;top:1rem;right:1rem;background:transparent;border:none;color:var(--text-secondary);font-size:2rem;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s;z-index:10}.auth-modal-close:hover{background:#ffffff1a;color:var(--text-primary)}.auth-modal-tabs{display:flex;border-bottom:1px solid rgba(255,255,255,.1);padding:0 2rem}.auth-tab{flex:1;padding:1.5rem 1rem;background:transparent;border:none;color:var(--text-secondary);font-size:1rem;font-weight:600;cursor:pointer;position:relative;transition:color .2s}.auth-tab:hover{color:var(--text-primary)}.auth-tab.active{color:var(--text-accent)}.auth-tab.active:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--text-accent)}.auth-modal-content{padding:2rem}.auth-form{max-width:100%}.auth-form h2{margin-bottom:1.5rem;text-align:center;color:var(--text-primary)}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:var(--text-secondary);font-size:.9rem;font-weight:500}.form-group input{width:100%;padding:.875rem 1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.2);border-radius:6px;color:var(--text-primary);font-size:1rem;transition:all .2s}.form-group input:focus{outline:none;border-color:var(--text-accent);background:#ffffff14}.form-group input:disabled{opacity:.6;cursor:not-allowed}.form-group input::placeholder{color:#fff6}.password-strength{margin-top:.5rem;display:flex;align-items:center;gap:.5rem}.password-strength-bar{height:4px;border-radius:2px;transition:all .3s;flex:1}.password-strength-label{font-size:.75rem;color:var(--text-secondary);min-width:80px;text-align:right}.auth-submit-btn{width:100%;padding:1rem;background:var(--text-accent);color:#000;border:none;border-radius:6px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s;margin-bottom:1rem}.auth-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #64ffda4d}.auth-submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-divider{display:flex;align-items:center;margin:1.5rem 0;color:var(--text-secondary);font-size:.875rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#ffffff1a}.auth-divider span{padding:0 1rem}.google-signin-btn{width:100%;padding:1rem;background:#fff;color:#444;border:1px solid #ddd;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.75rem}.google-signin-btn:hover:not(:disabled){background:#f8f8f8;box-shadow:0 2px 8px #0000001a}.google-signin-btn:disabled{opacity:.6;cursor:not-allowed}.auth-error{background:#ff64641a;border:1px solid rgba(255,100,100,.3);border-radius:6px;padding:.875rem;margin-bottom:1rem;color:#ff6464e6;font-size:.9rem;text-align:center}.auth-footer{margin-top:1.5rem;text-align:center;color:var(--text-secondary);font-size:.9rem}.auth-link{background:none;border:none;color:var(--text-accent);text-decoration:underline;cursor:pointer;font-size:inherit;padding:0}.auth-link:hover:not(:disabled){opacity:.8}.auth-link:disabled{opacity:.5;cursor:not-allowed}.auth-terms{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.1);text-align:center;font-size:.8rem;color:var(--text-secondary);line-height:1.6}.auth-terms a{color:var(--text-accent);text-decoration:none}.auth-terms a:hover{text-decoration:underline}.verification-success{text-align:center;padding:2rem 0}.success-icon{font-size:4rem;margin-bottom:1rem}.verification-success h2{margin-bottom:1rem}.verification-success p{color:var(--text-secondary);margin-bottom:1rem;line-height:1.6}.verification-instructions{background:#64ffda0d;border-left:3px solid var(--text-accent);padding:1rem;border-radius:4px;margin:1.5rem 0}@media(max-width:600px){.auth-modal{max-width:100%;margin:0;border-radius:0;max-height:100vh}.auth-modal-content{padding:1.5rem}.auth-modal-tabs{padding:0 1.5rem}}.theme-toggle{background:transparent;border:1px solid var(--border-color, #333);color:var(--text-primary);cursor:pointer;padding:.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .3s ease;margin-right:1rem;min-width:36px;min-height:36px;width:36px;height:36px}.theme-toggle:hover{background:var(--hover-bg, rgba(255, 255, 255, .1));transform:rotate(15deg)}.theme-toggle svg{width:20px;height:20px}@media(max-width:768px){.theme-toggle{margin-right:.5rem}}.main-nav{position:fixed;top:0;left:0;right:0;z-index:1000;background:var(--nav-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border-color, rgba(255, 255, 255, .05))}.nav-container{max-width:1400px;margin:0 auto;padding:1rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:2rem;position:relative}.nav-logo{display:flex;flex-direction:column;text-decoration:none;gap:.2rem;z-index:1001}.logo-text{font-size:1.2rem;font-weight:600;color:var(--text-primary);letter-spacing:-.02em}.logo-subtitle{font-size:.7rem;color:var(--text-secondary);letter-spacing:.05em}.nav-links{display:flex;gap:2rem;align-items:center;flex:1;justify-content:center}.nav-links a{color:var(--text-secondary);text-decoration:none;font-size:.9rem;font-weight:500;transition:color .2s;white-space:nowrap}.nav-links a:hover,.nav-links a.active{color:var(--text-primary)}.nav-cta{background:var(--text-primary);color:var(--bg-color);padding:.6rem 1.5rem;border-radius:4px;text-decoration:none;font-weight:600;font-size:.9rem;transition:transform .2s;z-index:1001}.nav-cta:hover{transform:translateY(-1px)}.profile-badge{display:flex;align-items:center;gap:.5rem;background:#64ffda1a;border:1px solid var(--text-accent);padding:.4rem .8rem;border-radius:20px;font-size:.85rem;color:var(--text-accent);cursor:pointer;transition:all .2s;z-index:1001;text-decoration:none}.profile-badge:hover{background:#64ffda26;transform:translateY(-1px)}.profile-icon{font-size:1rem}.profile-count{font-weight:600;font-size:.9rem;color:var(--text-accent)}.nav-auth-section,.nav-toggles-desktop{display:flex;align-items:center;gap:1rem}@media(max-width:1024px){.nav-toggles-desktop{display:none}}.nav-auth-btn{padding:.75rem 1.5rem;border-radius:6px;font-weight:700;font-size:.95rem;cursor:pointer;transition:all .2s;text-decoration:none;display:inline-block;white-space:nowrap;letter-spacing:.05em}.login-btn{background:transparent;color:var(--text-primary);border:2px solid var(--text-accent)}.login-btn:hover{background:var(--text-accent);color:#000;transform:translateY(-2px);box-shadow:0 4px 12px #64ffda4d}.nav-links a,.nav-auth-btn,.user-menu-button,.profile-badge{will-change:transform,color,background-color,box-shadow}.register-btn{background:var(--text-accent);color:#000;border:2px solid var(--text-accent)}.register-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #64ffda66}.user-menu-container{position:relative}.user-menu-button{display:flex;align-items:center;gap:.75rem;padding:.5rem 1rem;background:#64ffda1a;border:2px solid var(--text-accent);border-radius:8px;cursor:pointer;transition:all .2s;color:var(--text-primary);font-weight:600}.user-menu-button:hover{background:#64ffda26;transform:translateY(-2px);box-shadow:0 4px 12px #64ffda33}.user-avatar{width:36px;height:36px;border-radius:50%;overflow:hidden;display:flex;align-items:center;justify-content:center;background:var(--text-accent);color:#000;font-weight:700;border:2px solid var(--text-accent)}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-avatar-fallback{font-size:1rem}.user-name{color:var(--text-primary);font-weight:600;font-size:.95rem}.user-menu-arrow{color:var(--text-accent);font-size:.875rem;transition:transform .2s}.user-menu-button:hover .user-menu-arrow{transform:translateY(2px)}.user-menu-overlay{position:fixed;inset:0;z-index:999}.user-menu-dropdown{position:absolute;top:calc(100% + .75rem);right:0;min-width:280px;background:var(--bg-secondary);border:2px solid var(--text-accent);border-radius:12px;box-shadow:0 8px 32px #64ffda26;z-index:1000;overflow:hidden}.user-menu-header{padding:1.25rem;background:#64ffda0d;border-bottom:1px solid rgba(100,255,218,.2)}.user-menu-name{color:var(--text-primary);font-weight:700;margin-bottom:.35rem;font-size:1.05rem}.user-menu-email{color:var(--text-secondary);font-size:.875rem}.email-verification-badge{margin-top:.75rem;padding:.5rem .75rem;background:#ffa50026;border-left:3px solid #ffa500;border-radius:4px;font-size:.8rem;color:#ffb84d;font-weight:600}.user-menu-divider{height:1px;background:#64ffda26}.user-menu-item{display:flex;align-items:center;gap:.875rem;width:100%;padding:1rem 1.25rem;background:transparent;border:none;color:var(--text-primary);text-decoration:none;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s}.user-menu-item:hover{background:#64ffda14;color:var(--text-accent);padding-left:1.5rem}.user-menu-icon{font-size:1.2rem;transition:transform .2s}.user-menu-item:hover .user-menu-icon{transform:scale(1.1)}.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:.5rem;z-index:1001;transition:transform .3s}.hamburger-line{width:25px;height:2px;background:var(--text-primary);transition:all .3s ease;border-radius:2px}.hamburger.active .hamburger-line:nth-child(1){transform:translateY(7px) rotate(45deg)}.hamburger.active .hamburger-line:nth-child(2){opacity:0}.hamburger.active .hamburger-line:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.nav-overlay{display:none}@media(max-width:1024px){.hamburger{display:flex}.nav-links{position:fixed;top:0;right:-100%;width:280px;height:100vh;background:var(--nav-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);flex-direction:column;justify-content:flex-start;align-items:flex-start;padding:6rem 2rem 2rem;gap:2rem;transition:right .3s ease-in-out;border-left:1px solid rgba(255,255,255,.1);box-shadow:-5px 0 20px #00000080}.nav-links.mobile-open{right:0}.nav-links a{font-size:1.1rem;padding:.5rem 0;width:100%;border-bottom:1px solid rgba(255,255,255,.05)}.nav-overlay{display:block;position:fixed;top:0;left:0;width:100%;height:100vh;background:#000000b3;z-index:999;animation:fadeIn .3s ease}.nav-cta{display:none}.mobile-nav-controls{display:flex;align-items:center;gap:1.5rem;margin-top:1rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.1);width:100%;justify-content:center}}@media(max-width:768px){.nav-container{padding:1rem 1.5rem}.logo-text{font-size:1.1rem}.logo-subtitle{font-size:.65rem}.nav-links{width:260px}}.language-toggle-container{display:flex;align-items:center;gap:.2rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:4px;padding:2px}.lang-btn{background:transparent;border:none;color:var(--text-secondary);font-size:.75rem;font-weight:700;padding:.3rem .5rem;cursor:pointer;border-radius:3px;transition:all .2s;opacity:.5}.lang-btn.active{background:var(--text-accent);color:#000;opacity:1}.lang-btn:hover:not(.active){opacity:.8;background:#ffffff1a}.lang-divider{color:#fff3;font-size:.8rem;-webkit-user-select:none;user-select:none}.main-footer{background:var(--bg-secondary);border-top:1px solid var(--border-color, #333);padding:3rem 0 1rem;margin-top:auto;width:100%}.footer-container{max-width:1200px;margin:0 auto;padding:0 2rem;display:grid;grid-template-columns:2fr 1fr 1fr;gap:3rem}.footer-col h3{margin-bottom:1rem;color:var(--text-primary)}.footer-col h4{margin-bottom:1rem;color:var(--text-accent);text-transform:uppercase;font-size:.85rem;letter-spacing:1px}.footer-desc{color:var(--text-secondary);font-size:.9rem;line-height:1.6;max-width:300px}.footer-col a{display:block;color:var(--text-secondary);text-decoration:none;margin-bottom:.75rem;font-size:.95rem;transition:color .2s}.footer-col a:hover{color:var(--text-primary)}.footer-bottom{max-width:1200px;margin:3rem auto 0;padding:1.5rem 2rem 0;border-top:1px solid rgba(255,255,255,.05);display:flex;justify-content:space-between;align-items:center;color:var(--text-secondary);font-size:.85rem}@media(max-width:768px){.footer-bottom{flex-direction:column;gap:1.5rem;text-align:center}}@media(max-width:768px){.footer-container{grid-template-columns:1fr;gap:2rem;text-align:center}.footer-desc{margin:0 auto}}.layout{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding-top:80px;width:100%}.page-loader{position:fixed;inset:0;background:#050505f2;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999;opacity:0;animation:fadeIn .2s ease forwards}@keyframes fadeIn{to{opacity:1}}.loader-content{display:flex;flex-direction:column;align-items:center;gap:1.5rem}.loader-rings{position:relative;width:80px;height:80px}.loader-ring{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border:2px solid transparent;border-top-color:var(--text-accent, #64ffda);border-radius:50%;animation:spin 1.5s linear infinite}.loader-ring:nth-child(1){width:60px;height:60px;animation-duration:1.5s;opacity:.8}.loader-ring:nth-child(2){width:45px;height:45px;animation-duration:2s;animation-direction:reverse;opacity:.6}.loader-ring:nth-child(3){width:30px;height:30px;animation-duration:2.5s;opacity:.4}@keyframes spin{0%{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}.loader-text{margin:0;color:var(--text-secondary, #999);font-size:.875rem;letter-spacing:.05em;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}.page-loader.exiting{animation:fadeOut .3s ease forwards}@keyframes fadeOut{to{opacity:0}}.app-container{width:100vw;height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden;background:radial-gradient(circle at center,var(--bg-secondary) 0%,var(--bg-color) 70%)}.app-header{position:absolute;top:2rem;left:0;width:100%;text-align:center;z-index:50;pointer-events:none}.app-header h1{margin:0;font-size:1.5rem;letter-spacing:.2rem;text-transform:uppercase;font-weight:300;color:var(--text-primary)}.subtitle{margin:.5rem 0 0;font-size:.9rem;color:var(--text-secondary);font-weight:300;letter-spacing:.05rem}.compass-wrapper{position:relative;z-index:10}.controls{position:absolute;bottom:2rem;z-index:50}@media(max-width:768px){.app-header{top:1rem}.app-header h1{font-size:1.2rem}.controls{bottom:8rem}}.paywall-overlay{position:fixed;inset:0;background:#000000d9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.paywall-modal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;max-width:500px;width:100%;padding:32px;position:relative;box-shadow:0 20px 60px #00000080;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.paywall-close{position:absolute;top:16px;right:16px;background:none;border:none;font-size:28px;color:var(--text-secondary);cursor:pointer;transition:color .2s;padding:4px 8px}.paywall-close:hover{color:var(--text-primary)}.paywall-icon{font-size:48px;text-align:center;margin-bottom:16px}.paywall-title{font-size:24px;font-weight:700;text-align:center;margin-bottom:12px;color:var(--text-primary)}.paywall-description{text-align:center;color:var(--text-secondary);margin-bottom:24px;font-size:16px;line-height:1.5}.paywall-feature-box{background:var(--accent-primary);background:linear-gradient(135deg,#ff6b351a,#ff6b350d);border:1px solid rgba(255,107,53,.3);border-radius:8px;padding:12px 16px;margin-bottom:24px;text-align:center}.paywall-feature-box p{margin:0;color:var(--text-primary);font-size:14px}.paywall-pricing{text-align:center;margin-bottom:24px;padding:20px;background:#ffffff05;border-radius:8px}.paywall-price{display:flex;align-items:baseline;justify-content:center;gap:4px;margin-bottom:8px}.price-amount{font-size:40px;font-weight:700;color:var(--accent-primary)}.price-period{font-size:16px;color:var(--text-secondary)}.price-yearly{font-size:13px;color:var(--text-tertiary);margin:0}.paywall-features{margin-bottom:28px}.features-title{font-size:14px;font-weight:600;color:var(--text-secondary);margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.paywall-features ul{list-style:none;padding:0;margin:0}.paywall-features li{padding:8px 0;color:var(--text-primary);font-size:14px;display:flex;align-items:center;gap:8px}.paywall-actions{display:flex;gap:12px;flex-direction:column}.paywall-btn{padding:14px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;border:none;width:100%}.paywall-btn.primary{background:var(--accent-primary);color:#fff}.paywall-btn.primary:hover{background:#e6642d;transform:translateY(-1px);box-shadow:0 4px 12px #ff6b354d}.paywall-btn.secondary{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary)}.paywall-btn.secondary:hover{background:#ffffff0d;border-color:var(--text-secondary)}@media(max-width:600px){.paywall-modal{padding:24px}.paywall-title{font-size:20px}.price-amount{font-size:32px}}.floating-chat-button{position:fixed;bottom:24px;right:24px;width:64px;height:64px;border-radius:50%;background:var(--gradient-primary);border:none;font-size:28px;cursor:pointer;box-shadow:0 8px 24px #00f0ff4d;z-index:999;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.floating-chat-button:hover{transform:scale(1.1);box-shadow:0 12px 32px #00f0ff80}.floating-chat-button:not(.active){animation:pulse 2s infinite}@keyframes pulse{0%,to{box-shadow:0 8px 24px #00f0ff4d}50%{box-shadow:0 8px 32px #00f0ff99}}.floating-chat-button.active{background:var(--text-color);color:var(--bg-color)}.name-modal-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease}.name-modal{background:var(--card-bg);border:1px solid var(--primary-color);border-radius:24px;padding:3rem;max-width:500px;width:90%;box-shadow:0 20px 60px #00000080;animation:slideUp .4s ease}.name-modal h2{font-size:1.8rem;margin-bottom:1rem;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.name-modal p{color:var(--text-secondary);margin-bottom:2rem}.name-modal form{display:flex;flex-direction:column;gap:1rem}.name-modal input{background:#ffffff0d;border:1px solid rgba(0,240,255,.3);border-radius:12px;padding:1rem;font-size:1.1rem;color:var(--text-color);font-family:inherit;transition:all .3s ease}.name-modal input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 20px #00f0ff33}.name-modal button{background:var(--gradient-primary);border:none;border-radius:12px;padding:1rem 2rem;font-size:1.1rem;font-weight:700;color:#000;cursor:pointer;transition:all .3s ease}.name-modal button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #00f0ff66}.name-modal button:disabled{opacity:.5;cursor:not-allowed}.floating-chat-window{position:fixed;bottom:100px;right:24px;width:420px;height:600px;background:var(--card-bg);border:1px solid var(--primary-color);border-radius:24px;box-shadow:0 20px 60px #00000080;display:flex;flex-direction:column;z-index:998;animation:slideUp .3s ease;overflow:hidden}.chat-header{background:linear-gradient(135deg,#00f0ff26,#ff00801a);border-bottom:1px solid rgba(0,240,255,.2);padding:1.25rem;display:flex;justify-content:space-between;align-items:center}.chat-header-info{display:flex;align-items:center;gap:1rem}.ai-avatar{font-size:2rem}.chat-header h3{font-size:1.2rem;margin:0;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.ai-subtitle{font-size:.85rem;color:var(--text-secondary)}.close-chat{background:none;border:none;font-size:2rem;color:var(--text-secondary);cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s ease}.close-chat:hover{background:#ffffff1a;color:var(--text-color)}.chat-messages{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.chat-message{display:flex;animation:messageSlide .3s ease}.chat-message.user{justify-content:flex-end}.chat-message.assistant{justify-content:flex-start}.message-bubble{max-width:80%;padding:.875rem 1.125rem;border-radius:16px;line-height:1.5;word-wrap:break-word}.chat-message.user .message-bubble{background:var(--gradient-primary);color:#000;font-weight:500;border-bottom-right-radius:4px}.chat-message.assistant .message-bubble{background:#00f0ff1a;border:1px solid rgba(0,240,255,.2);color:var(--text-color);border-bottom-left-radius:4px}.message-bubble.loading{padding:1rem 1.5rem}.message-bubble.loading .dot{animation:dotPulse 1.4s infinite;font-size:1.5rem;margin:0 .2rem}.message-bubble.loading .dot:nth-child(2){animation-delay:.2s}.message-bubble.loading .dot:nth-child(3){animation-delay:.4s}@keyframes dotPulse{0%,60%,to{opacity:.3}30%{opacity:1}}.chat-error{background:#ff00001a;border:1px solid rgba(255,0,0,.3);border-radius:12px;padding:.75rem 1rem;color:#ff6b6b;font-size:.9rem;text-align:center}.chat-input{border-top:1px solid rgba(0,240,255,.2);padding:1rem;display:flex;gap:.75rem;background:var(--card-bg)}.chat-input input{flex:1;background:#ffffff0d;border:1px solid rgba(0,240,255,.3);border-radius:12px;padding:.875rem 1rem;color:var(--text-color);font-size:.95rem;font-family:inherit;transition:all .3s ease}.chat-input input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 12px #00f0ff33}.chat-input button{background:var(--gradient-primary);border:none;border-radius:12px;padding:0 1.5rem;font-size:1.5rem;font-weight:700;color:#000;cursor:pointer;transition:all .2s ease;min-width:56px}.chat-input button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 16px #00f0ff66}.chat-input button:disabled{opacity:.5;cursor:not-allowed}.usage-indicator{padding:.5rem 1rem;text-align:center;font-size:.85rem;color:var(--text-secondary);border-top:1px solid rgba(0,240,255,.1)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes messageSlide{0%{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}@media(max-width:768px){.floating-chat-window{right:0;bottom:0;left:0;width:100%;height:calc(100vh - 70px);border-radius:24px 24px 0 0}.floating-chat-button{bottom:16px;right:16px;width:56px;height:56px;font-size:24px}.name-modal{padding:2rem;width:95%}.name-modal h2{font-size:1.5rem}}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track{background:#0003;border-radius:3px}.chat-messages::-webkit-scrollbar-thumb{background:#00f0ff4d;border-radius:3px}.chat-messages::-webkit-scrollbar-thumb:hover{background:#00f0ff80}*{box-sizing:border-box}html{overflow-x:hidden;width:100%}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-color);color:var(--text-primary);overflow-x:hidden;width:100%}:root{--bg-color: #050505;--bg-secondary: #0a0a0a;--text-primary: #f5f5f5;--text-secondary: #999;--text-accent: #64ffda;--card-bg: #111;--card-border: #333;--nav-bg: rgba(5, 5, 5, .85);--shadow-color: rgba(0, 0, 0, .5);--input-bg: rgba(255, 255, 255, .05);--hover-bg: rgba(255, 255, 255, .1)}[data-theme=light]{--bg-color: #f8f9fa;--bg-secondary: #ffffff;--text-primary: #1a1a1a;--text-secondary: #555;--text-accent: #00796b;--card-bg: #ffffff;--card-border: #e0e0e0;--nav-bg: rgba(255, 255, 255, .9);--shadow-color: rgba(0, 0, 0, .1);--input-bg: #f0f0f0;--hover-bg: rgba(0, 0, 0, .05)}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{width:100%;overflow-x:hidden}button,a,input[type=checkbox]{min-height:44px;min-width:44px}@media(max-width:768px){body{font-size:16px}h1{font-size:clamp(1.75rem,5vw,3rem)}h2{font-size:clamp(1.5rem,4vw,2.5rem)}h3{font-size:clamp(1.25rem,3vw,1.75rem)}button{padding:.75rem 1.5rem}a{padding:.5rem;margin:-.5rem}}@media(min-width:769px)and (max-width:1024px){.container,.library-container,.ai-container,.courses-container{max-width:90%;padding:3rem 2rem}}
