@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--bg-primary:#0a0a0f;--bg-secondary:#12121a;--bg-tertiary:#1a1a28;--bg-card:#14141f;--bg-glass:#141423cc;--bg-glass-hover:#1e1e32d9;--text-primary:#e8e8f0;--text-secondary:#9898b0;--text-muted:#5e5e78;--accent-primary:#6c5ce7;--accent-secondary:#a29bfe;--accent-tertiary:#fd79a8;--accent-glow:#6c5ce74d;--user-bubble:#2d2d48;--tutor-bubble:linear-gradient(135deg, #1e1e36 0%, #252544 100%);--tutor-border:#6c5ce740;--success:#00cec9;--warning:#fdcb6e;--danger:#e17055;--border-subtle:#ffffff0f;--border-light:#ffffff1a;--radius-sm:8px;--radius-md:12px;--radius-lg:20px;--radius-xl:24px;--shadow-soft:0 4px 24px #0000004d;--shadow-glow:0 0 40px #6c5ce726;--transition-fast:.15s ease;--transition-normal:.25s ease;--transition-smooth:.35s cubic-bezier(.4, 0, .2, 1);--max-width:1200px;--nav-height:64px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6}a{color:inherit;text-decoration:none}img{max-width:100%}.hidden{display:none!important}.text-gradient{background:linear-gradient(135deg, var(--accent-primary), var(--accent-tertiary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.navbar{z-index:100;background:var(--bg-glass);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border-bottom:1px solid var(--border-subtle);height:var(--nav-height);position:sticky;top:0}.nav-inner{max-width:var(--max-width);justify-content:space-between;align-items:center;height:100%;margin:0 auto;padding:0 24px;display:flex}.nav-brand{letter-spacing:-.3px;align-items:center;gap:10px;font-size:18px;font-weight:700;display:flex}.nav-logo{background:linear-gradient(135deg, var(--accent-primary), var(--accent-tertiary));border-radius:var(--radius-sm);justify-content:center;align-items:center;width:34px;height:34px;font-size:18px;display:flex}.nav-logo-img{object-fit:contain;border-radius:var(--radius-sm);flex-shrink:0;width:34px;height:34px}.nav-brand-text-group{flex-direction:column;line-height:1.1;display:flex}.nav-brand-byline{color:var(--text-muted);letter-spacing:.2px;text-transform:none;font-size:10px;font-weight:400}.brand-banner{border-bottom:1px solid var(--border-subtle);background:#6c5ce70f;justify-content:center;align-items:center;gap:14px;padding:14px 24px;display:flex}.brand-banner-icon{object-fit:contain;border-radius:8px;width:42px;height:42px}.brand-banner-text{flex-direction:column;line-height:1.2;display:flex}.brand-banner-name{letter-spacing:.3px;color:var(--text-primary);font-size:14px;font-weight:700}.brand-banner-tagline{color:var(--text-muted);font-size:11px;font-style:italic}.footer-logo-img{object-fit:contain;border-radius:6px;flex-shrink:0;width:30px;height:30px}.footer-brand-info{flex-direction:column;line-height:1.2;display:flex}.footer-byline{color:var(--text-muted);font-size:11px;font-style:italic;font-weight:400}.about-hero-visual{justify-content:center;margin-bottom:28px;display:flex}.about-hero-img-wrap{border-radius:var(--radius-lg);border:1px solid var(--border-subtle);background:#1a1a2e;width:328px;height:250px;position:relative;overflow:hidden;box-shadow:0 4px 24px #6c5ce726,0 0 60px #6c5ce70f}.about-hero-logo{object-fit:contain;width:100%;height:100%;display:block}.nav-links{align-items:center;gap:4px;display:flex}.nav-link{border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition-fast);padding:8px 16px;font-size:14px;font-weight:500}.nav-link:hover{color:var(--text-primary);background:#ffffff0a}.nav-link.active{color:var(--text-primary);background:#6c5ce71a}.nav-link-cta{background:var(--accent-primary)!important;color:#fff!important}.nav-link-cta:hover{background:#7c6cf7!important}.nav-link-signin{border:1px solid var(--border-light);color:var(--text-primary)!important}.nav-right{align-items:center;gap:12px;display:flex}.nav-user{align-items:center;gap:10px;display:flex}.nav-avatar{border:2px solid var(--accent-primary);border-radius:50%;width:32px;height:32px}.nav-user-name{color:var(--text-secondary);font-size:13px;font-weight:500}.nav-signout{border-radius:var(--radius-sm);color:var(--danger);cursor:pointer;transition:all var(--transition-fast);background:#e170551a;border:1px solid #e1705533;padding:6px 14px;font-family:inherit;font-size:12px;font-weight:500}.nav-signout:hover{background:#e1705533}.nav-hamburger{cursor:pointer;background:0 0;border:none;flex-direction:column;gap:5px;padding:4px;display:none}.nav-hamburger span{background:var(--text-secondary);width:22px;height:2px;transition:all var(--transition-fast);border-radius:2px;display:block}.nav-hamburger.open span:first-child{transform:rotate(45deg)translate(5px,5px)}.nav-hamburger.open span:nth-child(2){opacity:0}.nav-hamburger.open span:nth-child(3){transform:rotate(-45deg)translate(5px,-5px)}@media (width<=768px){.nav-hamburger{display:flex}.nav-links{top:var(--nav-height);background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);flex-direction:column;gap:4px;padding:16px;display:none;position:absolute;left:0;right:0}.nav-links.open{display:flex}.nav-user-name{display:none}}.btn-primary{background:linear-gradient(135deg, var(--accent-primary), #8b5cf6);color:#fff;border-radius:var(--radius-xl);cursor:pointer;transition:all var(--transition-smooth);letter-spacing:.3px;border:none;justify-content:center;align-items:center;padding:12px 28px;font-family:inherit;font-size:15px;font-weight:600;display:inline-flex;box-shadow:0 4px 20px #6c5ce759}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 30px #6c5ce780}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-lg{padding:16px 40px;font-size:16px}.landing-page{overflow-x:hidden}.hero{max-width:var(--max-width);grid-template-columns:1fr 1fr;align-items:center;gap:60px;margin:0 auto;padding:80px 24px 60px;display:grid;position:relative}.hero-bg-glow{pointer-events:none;background:radial-gradient(#6c5ce71f 0%,#0000 70%);width:600px;height:400px;position:absolute;top:-100px;left:50%;transform:translate(-50%)}.hero-content{z-index:1}.hero-badge{color:var(--accent-secondary);background:#6c5ce71f;border:1px solid #6c5ce733;border-radius:20px;margin-bottom:24px;padding:6px 16px;font-size:13px;font-weight:500;display:inline-block}.hero-title{letter-spacing:-1.5px;margin-bottom:20px;font-size:52px;font-weight:800;line-height:1.1}.hero-gradient{background:linear-gradient(135deg, var(--accent-primary), var(--accent-tertiary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero-subtitle{color:var(--text-secondary);text-align:justify;max-width:480px;margin-bottom:32px;font-size:17px;line-height:1.7}.hero-actions{align-items:center;gap:16px;display:flex}.hero-visual{z-index:1}.hero-mockup{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft), var(--shadow-glow);overflow:hidden}.mockup-header{background:var(--bg-tertiary);border-bottom:1px solid var(--border-subtle);align-items:center;gap:12px;padding:12px 16px;display:flex}.mockup-dots{gap:6px;display:flex}.mockup-dots span{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:50%;width:10px;height:10px}.mockup-dots span:first-child{background:var(--danger);border-color:var(--danger)}.mockup-dots span:nth-child(2){background:var(--warning);border-color:var(--warning)}.mockup-dots span:nth-child(3){background:var(--success);border-color:var(--success)}.mockup-title{color:var(--text-muted);font-size:12px;font-weight:500}.mockup-body{flex-direction:column;gap:12px;min-height:260px;padding:20px 16px;display:flex}.mockup-msg{border-radius:var(--radius-md);max-width:85%;padding:10px 14px;font-size:13px;line-height:1.5;animation:.8s ease-out backwards mockupFadeIn}.mockup-msg:first-child{animation-delay:.5s}.mockup-msg:nth-child(2){animation-delay:1.5s}.mockup-msg:nth-child(3){animation-delay:2.5s}@keyframes mockupFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.mockup-msg.tutor{background:var(--tutor-bubble);border:1px solid var(--tutor-border);align-self:flex-start}.mockup-msg.student{background:var(--user-bubble);align-self:flex-end}.mockup-label{text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);margin-bottom:3px;font-size:10px;font-weight:600;display:block}.mockup-typing{align-self:flex-start;align-items:center;gap:4px;padding:10px 14px;animation:.8s ease-out 3.5s backwards mockupFadeIn;display:flex}@media (width<=768px){.hero{grid-template-columns:1fr;gap:40px;padding:40px 24px}.hero-title{font-size:36px}.hero-visual{order:-1}}.section-header{text-align:center;margin-bottom:48px}.section-title{letter-spacing:-.8px;margin-bottom:12px;font-size:36px;font-weight:700}.section-subtitle{color:var(--text-secondary);font-size:16px}.features-section{max-width:var(--max-width);margin:0 auto;padding:80px 24px}.features-grid{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}.feature-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:all var(--transition-smooth);padding:28px 24px}.feature-card:hover{border-color:#6c5ce740;transform:translateY(-4px);box-shadow:0 8px 30px #0003}.feature-icon{margin-bottom:16px;font-size:32px}.feature-title{margin-bottom:8px;font-size:17px;font-weight:600}.feature-desc{color:var(--text-secondary);font-size:14px;line-height:1.6}@media (width<=768px){.features-grid{grid-template-columns:1fr}.section-title{font-size:28px}}.how-section{max-width:var(--max-width);margin:0 auto;padding:80px 24px}.steps-grid{grid-template-columns:repeat(3,1fr);gap:24px;display:grid}.step-card{text-align:center;padding:32px 24px}.step-number{background:linear-gradient(135deg, var(--accent-primary), var(--accent-tertiary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:16px;font-size:48px;font-weight:800}.step-title{margin-bottom:8px;font-size:18px;font-weight:600}.step-desc{color:var(--text-secondary);font-size:14px;line-height:1.6}@media (width<=768px){.steps-grid{grid-template-columns:1fr}}.cta-section{max-width:var(--max-width);margin:0 auto;padding:40px 24px 80px}.cta-card{text-align:center;border-radius:var(--radius-xl);background:linear-gradient(135deg,#6c5ce71a 0%,#fd79a80d 100%);border:1px solid #6c5ce726;padding:64px 32px}.cta-title{margin-bottom:12px;font-size:32px;font-weight:700}.cta-subtitle{color:var(--text-secondary);margin-bottom:28px;font-size:16px}.cta-actions{justify-content:center;display:flex}.footer{border-top:1px solid var(--border-subtle);margin-top:40px;padding:32px 24px}.footer-inner{max-width:var(--max-width);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin:0 auto;display:flex}.footer-brand{align-items:center;gap:8px;font-size:15px;font-weight:600;display:flex}.footer-logo{font-size:20px}.footer-links{gap:24px;display:flex}.footer-links a{color:var(--text-secondary);transition:color var(--transition-fast);font-size:13px}.footer-links a:hover{color:var(--text-primary)}.footer-copy{color:var(--text-muted);font-size:12px}@media (width<=600px){.footer-inner{text-align:center;flex-direction:column}}.static-page{min-height:calc(100vh - var(--nav-height));flex-direction:column;display:flex}.static-page-inner{max-width:var(--max-width);flex:1;margin:0 auto;padding:60px 24px}.page-hero{text-align:center;margin-bottom:48px}.page-hero-title{letter-spacing:-1px;margin-bottom:12px;font-size:40px;font-weight:700}.page-hero-subtitle{color:var(--text-secondary);max-width:520px;margin:0 auto;font-size:16px}.content-grid{grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:60px;display:grid}.content-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:all var(--transition-smooth);padding:28px 24px}.content-card:hover{border-color:#6c5ce733}.content-icon{margin-bottom:14px;font-size:28px}.content-card h2{margin-bottom:10px;font-size:18px;font-weight:600}.content-card p{color:var(--text-secondary);font-size:14px;line-height:1.7}@media (width<=768px){.content-grid{grid-template-columns:1fr}.page-hero-title{font-size:30px}}.about-values{margin-top:20px}.about-values .section-title{text-align:center;margin-bottom:36px}.values-list{flex-direction:column;gap:16px;max-width:700px;margin:0 auto;display:flex}.value-item{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);transition:border-color var(--transition-fast);align-items:flex-start;gap:20px;padding:20px 24px;display:flex}.value-item:hover{border-color:#6c5ce733}.value-number{color:var(--accent-primary);flex-shrink:0;font-size:24px;font-weight:800}.value-item h3{margin-bottom:4px;font-size:16px;font-weight:600}.value-item p{color:var(--text-secondary);font-size:13px}.contact-layout{grid-template-columns:1.3fr 1fr;gap:24px;display:grid}.contact-form-card,.contact-info-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:32px 28px}.contact-form-card h2,.contact-info-card h2{margin-bottom:24px;font-size:20px;font-weight:600}.contact-form{flex-direction:column;gap:18px;display:flex}.form-group label{color:var(--text-secondary);margin-bottom:6px;font-size:13px;font-weight:500;display:block}.form-group input,.form-group textarea{background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);width:100%;color:var(--text-primary);transition:border-color var(--transition-fast);resize:vertical;outline:none;padding:12px 16px;font-family:inherit;font-size:14px}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-muted)}.form-group input:focus,.form-group textarea:focus{border-color:#6c5ce766}.btn-submit{align-self:flex-start}.form-success{text-align:center;padding:40px 0}.success-icon{margin-bottom:16px;font-size:48px}.form-success h3{margin-bottom:8px;font-size:22px}.form-success p{color:var(--text-secondary);font-size:14px}.info-items{flex-direction:column;gap:20px;display:flex}.info-item{align-items:flex-start;gap:14px;display:flex}.info-icon{flex-shrink:0;margin-top:2px;font-size:24px}.info-item h4{margin-bottom:2px;font-size:14px;font-weight:600}.info-item p{color:var(--text-secondary);font-size:13px}@media (width<=768px){.contact-layout{grid-template-columns:1fr}}.tutor-page{height:calc(100vh - var(--nav-height));flex-direction:column;width:100%;max-width:900px;margin:0 auto;display:flex}.tutor-header{border-bottom:1px solid var(--border-subtle);background:var(--bg-glass);justify-content:space-between;align-items:center;padding:12px 24px;display:flex}.tutor-header-left{align-items:center;gap:12px;display:flex}.tutor-avatar{background:linear-gradient(135deg, var(--accent-primary), var(--accent-tertiary));border-radius:var(--radius-sm);justify-content:center;align-items:center;width:38px;height:38px;font-size:20px;display:flex}.tutor-name{font-size:15px;font-weight:600}.tutor-status{color:var(--text-muted);align-items:center;gap:6px;font-size:12px;display:flex}.tutor-user-name{color:var(--text-secondary);font-size:13px;font-weight:500}.tutor-welcome{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:20px;padding:40px 24px;display:flex}.tutor-welcome-icon{font-size:56px;animation:3s ease-in-out infinite float}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.tutor-welcome h2{font-size:26px;font-weight:700}.tutor-welcome p{color:var(--text-secondary);max-width:420px;font-size:14px}.chat-area{scroll-behavior:smooth;flex-direction:column;flex:1;gap:8px;padding:24px;display:none;overflow-y:auto}.chat-area.active{display:flex}.chat-area::-webkit-scrollbar{width:6px}.chat-area::-webkit-scrollbar-track{background:0 0}.chat-area::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}.message{border-radius:var(--radius-lg);max-width:80%;animation:messageIn .3s var(--transition-smooth);word-wrap:break-word;padding:12px 18px;font-size:14px;line-height:1.6}@keyframes messageIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.message.user{background:var(--user-bubble);border-bottom-right-radius:6px;align-self:flex-end}.message.gemini{background:var(--tutor-bubble);border:1px solid var(--tutor-border);border-bottom-left-radius:6px;align-self:flex-start}.message-label{text-transform:uppercase;letter-spacing:.8px;margin-bottom:4px;font-size:11px;font-weight:600;display:block}.message.user .message-label{color:var(--accent-secondary);text-align:right}.message.gemini .message-label{color:var(--accent-tertiary)}.message-text{white-space:pre-wrap}.message.system{max-width:90%;color:var(--text-secondary);text-align:center;border-radius:var(--radius-md);background:#6c5ce71a;border:1px solid #6c5ce726;align-self:center;font-size:12px}.video-container{padding:0 24px 16px;display:none}.video-container.active{display:block}.video-wrapper{border-radius:var(--radius-md);background:var(--bg-tertiary);border:1px solid var(--border-subtle);max-height:200px;position:relative;overflow:hidden}.video-wrapper video{object-fit:cover;width:100%;max-height:200px;display:block}.video-label{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;background:#0009;border-radius:6px;padding:4px 10px;font-size:11px;font-weight:500;position:absolute;bottom:8px;left:8px}.control-bar{background:var(--bg-glass);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid var(--border-subtle);flex-direction:column;gap:12px;padding:16px 24px;display:none}.control-bar.active{display:flex}.input-row{align-items:center;gap:8px;display:flex}.text-input{background:var(--bg-tertiary);border-radius:var(--radius-lg);color:var(--text-primary);transition:border-color var(--transition-fast);border:1px solid #ffffff14;outline:none;flex:1;padding:12px 18px;font-family:inherit;font-size:14px}.text-input::placeholder{color:var(--text-muted)}.text-input:focus{border-color:#6c5ce766}.btn-send{background:var(--accent-primary);color:#fff;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);border:none;flex-shrink:0;justify-content:center;align-items:center;padding:12px 16px;display:flex}.btn-send:hover{background:#7c6cf7}.btn-send svg{width:20px;height:20px}.media-controls{justify-content:center;align-items:center;gap:8px;display:flex}.btn-media{background:var(--bg-tertiary);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:1px solid #ffffff14;align-items:center;gap:6px;padding:8px 16px;font-family:inherit;font-size:13px;display:flex}.btn-media:hover{background:var(--bg-glass-hover);border-color:var(--border-light);color:var(--text-primary)}.btn-media.active{color:var(--accent-secondary);background:#6c5ce726;border-color:#6c5ce759}.btn-media .icon{font-size:16px}.btn-disconnect{border-radius:var(--radius-md);color:var(--danger);cursor:pointer;transition:all var(--transition-fast);background:#e170551a;border:1px solid #e1705533;align-items:center;gap:6px;margin-left:auto;padding:8px 16px;font-family:inherit;font-size:13px;display:flex}.btn-disconnect:hover{background:#e1705533}.session-end{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:20px;padding:40px;display:none}.session-end.active{display:flex}.session-end-title{color:var(--text-secondary);font-size:22px;font-weight:600}.status-dot{background:var(--text-muted);width:8px;height:8px;transition:background var(--transition-normal);border-radius:50%}.status-dot.connected{background:var(--success);box-shadow:0 0 8px #00cec980}.status-dot.connecting{background:var(--warning);animation:1.5s infinite pulse}.status-dot.error{background:var(--danger)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;opacity:0;visibility:hidden;width:100vw;height:100vh;transition:all var(--transition-fast);background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;top:0;left:0}.modal-overlay.active{opacity:1;visibility:visible}.modal-dialog{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);width:90%;max-width:420px;transition:all var(--transition-smooth);padding:32px;transform:translateY(20px)scale(.95);box-shadow:0 10px 40px #0000004d}.modal-overlay.active .modal-dialog{transform:translateY(0)scale(1)}.modal-header{margin-bottom:16px}.modal-title{color:var(--text-primary);margin:0;font-size:22px;font-weight:600}.modal-body{color:var(--text-secondary);margin-bottom:32px;font-size:15px;line-height:1.6}.modal-body p{margin:0}.modal-footer{justify-content:flex-end;gap:12px;display:flex}.modal-footer button{padding:10px 20px}.typing-indicator{background:var(--tutor-bubble);border:1px solid var(--tutor-border);border-radius:var(--radius-lg);border-bottom-left-radius:6px;align-self:flex-start;align-items:center;gap:4px;padding:12px 18px;display:none}.typing-indicator.active{display:flex}.typing-dot{background:var(--text-muted);border-radius:50%;width:6px;height:6px;animation:1.4s infinite typingBounce}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes typingBounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-6px)}}.audio-indicator{align-items:center;gap:3px;margin-right:8px;display:none}.audio-indicator.active{display:flex}.audio-bar{background:var(--accent-primary);border-radius:2px;width:3px;height:12px;animation:.8s ease-in-out infinite audioWave}.audio-bar:nth-child(2){height:18px;animation-delay:.1s}.audio-bar:nth-child(3){height:8px;animation-delay:.2s}.audio-bar:nth-child(4){height:16px;animation-delay:.3s}@keyframes audioWave{0%,to{transform:scaleY(.5)}50%{transform:scaleY(1.2)}}@media (width<=600px){.tutor-header{padding:10px 16px}.chat-area{padding:16px}.message{max-width:90%;padding:10px 14px}.control-bar{padding:12px 16px}.media-controls{flex-wrap:wrap}}.courses-page{max-width:var(--max-width);margin:0 auto;padding:40px 24px 60px}.courses-header{text-align:center;margin-bottom:40px}.courses-header h1{letter-spacing:-.5px;margin-bottom:8px;font-size:36px;font-weight:700}.courses-subtitle{color:var(--text-secondary);font-size:16px}.courses-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px;display:grid}.courses-loading,.courses-empty,.courses-error{text-align:center;color:var(--text-secondary);grid-column:1/-1;padding:60px 20px}.spinner{border:3px solid var(--border-subtle);border-top:3px solid var(--accent-primary);border-radius:50%;width:36px;height:36px;margin:0 auto 16px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.course-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:all var(--transition-smooth);flex-direction:column;gap:12px;padding:24px;display:flex}.course-card:hover{border-color:#6c5ce74d;transform:translateY(-2px);box-shadow:0 8px 30px #00000026}.course-card-header{justify-content:space-between;align-items:center;display:flex}.course-icon{font-size:32px}.course-meta{align-items:center;gap:8px;display:flex}.chapter-count{color:var(--text-muted);background:var(--bg-tertiary);border-radius:20px;padding:4px 10px;font-size:12px}.progress-badge{border-radius:20px;padding:4px 10px;font-size:11px;font-weight:600}.progress-badge.in-progress{color:var(--warning);background:#fdcb6e26}.progress-badge.completed{color:var(--success);background:#00cec926}.course-title{font-size:20px;font-weight:600}.course-description{color:var(--text-secondary);flex:1;font-size:14px;line-height:1.6}.course-score{color:var(--accent-secondary);font-size:13px;font-weight:500}.btn-course-view{align-self:flex-start;margin-top:4px}.btn-back{color:var(--text-secondary);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;align-items:center;gap:4px;margin-bottom:20px;padding:8px 0;font-family:inherit;font-size:14px;display:inline-flex}.btn-back:hover{color:var(--accent-secondary)}.course-detail{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);margin-bottom:32px;padding:32px}.course-detail-header{align-items:flex-start;gap:20px;margin-bottom:24px;display:flex}.course-detail-icon{flex-shrink:0;font-size:48px}.course-detail-title{margin-bottom:8px;font-size:28px;font-weight:700}.course-detail-desc{color:var(--text-secondary);margin-bottom:12px;font-size:15px;line-height:1.6}.course-detail-meta{color:var(--text-muted);gap:16px;font-size:13px;display:flex}.btn-start-course{padding:14px 28px;font-size:16px}.chapters-section{margin-bottom:40px}.chapters-heading{margin-bottom:20px;font-size:22px;font-weight:600}.chapters-empty{color:var(--text-muted);font-size:14px}.chapters-list{flex-direction:column;gap:12px;display:flex}.chapter-item{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);transition:all var(--transition-fast);align-items:center;gap:16px;padding:16px 20px;display:flex}.chapter-item:hover{border-color:#6c5ce733}.chapter-item.completed{border-left:3px solid var(--success)}.chapter-item.in-progress{border-left:3px solid var(--warning)}.chapter-number{background:var(--bg-tertiary);width:32px;height:32px;color:var(--text-secondary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:600;display:flex}.chapter-info{flex:1;min-width:0}.chapter-title{margin-bottom:2px;font-size:15px;font-weight:600}.chapter-desc{color:var(--text-secondary);font-size:13px}.chapter-score{color:var(--accent-secondary);margin-top:4px;font-size:12px;font-weight:500}.chapter-progress{color:var(--warning);margin-top:4px;font-size:12px;font-weight:500}.btn-sm{flex-shrink:0;padding:6px 16px;font-size:13px}.btn-secondary{background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;padding:12px 24px;font-family:inherit;font-size:14px;font-weight:500;text-decoration:none;display:inline-flex}.btn-secondary:hover{background:var(--bg-glass-hover);border-color:var(--border-light)}.btn-test{border:1px solid var(--accent-primary);border-radius:var(--radius-xl);color:var(--accent-primary);cursor:pointer;transition:all var(--transition-smooth);letter-spacing:.3px;background:#6c5ce71a;justify-content:center;align-items:center;padding:11px 27px;font-family:inherit;font-size:15px;font-weight:600;text-decoration:none;display:inline-flex;box-shadow:0 4px 20px #6c5ce726}.btn-test:hover{background:var(--accent-primary);color:#fff;transform:translateY(-2px);box-shadow:0 8px 30px #6c5ce759}.btn-test:active{transform:translateY(0)}.session-end-buttons{align-items:center;gap:12px;display:flex}.tutor-breadcrumb{color:var(--text-muted);margin-top:2px;font-size:12px}.tutor-breadcrumb a{color:var(--text-secondary);transition:color var(--transition-fast);text-decoration:none}.tutor-breadcrumb a:hover{color:var(--accent-secondary)}.message.system.tool-call{color:var(--text-primary);background:#00cec91a;border-color:#00cec933;font-size:13px}.markdown-body{font-family:inherit;line-height:1.6}.markdown-body p:first-child{margin-top:0}.markdown-body p:last-child{margin-bottom:0}.markdown-body pre{color:#d4d4d4;background:#1e1e1e;border-radius:8px;margin:12px 0;padding:16px;position:relative;overflow-x:auto;box-shadow:inset 0 2px 4px #0003}.markdown-body pre.hljs{padding:16px}.markdown-body code{font-family:Fira Code,Courier New,monospace;font-size:13px}.copy-btn{color:#d4d4d4;cursor:pointer;transition:all var(--transition-fast);z-index:10;background:#ffffff1a;border:1px solid #fff3;border-radius:4px;justify-content:center;align-items:center;padding:4px;display:flex;position:absolute;top:8px;right:8px}.copy-btn:hover{color:#fff;background:#ffffff40}.message.system.tool-call strong{color:var(--success)}@media (width<=768px){.courses-grid{grid-template-columns:1fr}.course-detail-header{flex-direction:column;gap:12px}.course-detail-title{font-size:22px}.chapter-item{flex-wrap:wrap}}pre code.hljs{padding:1em;display:block;overflow-x:auto}code.hljs{padding:3px 5px}.hljs{color:#c9d1d9;background:#0d1117}.hljs-doctag,.hljs-keyword,.hljs-meta .hljs-keyword,.hljs-template-tag,.hljs-template-variable,.hljs-type,.hljs-variable.language_{color:#ff7b72}.hljs-title,.hljs-title.class_,.hljs-title.class_.inherited__,.hljs-title.function_{color:#d2a8ff}.hljs-attr,.hljs-attribute,.hljs-literal,.hljs-meta,.hljs-number,.hljs-operator,.hljs-variable,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-id{color:#79c0ff}.hljs-regexp,.hljs-string,.hljs-meta .hljs-string{color:#a5d6ff}.hljs-built_in,.hljs-symbol{color:#ffa657}.hljs-comment,.hljs-code,.hljs-formula{color:#8b949e}.hljs-name,.hljs-quote,.hljs-selector-tag,.hljs-selector-pseudo{color:#7ee787}.hljs-subst{color:#c9d1d9}.hljs-section{color:#1f6feb;font-weight:700}.hljs-bullet{color:#f2cc60}.hljs-emphasis{color:#c9d1d9;font-style:italic}.hljs-strong{color:#c9d1d9;font-weight:700}.hljs-addition{color:#aff5b4;background-color:#033a16}.hljs-deletion{color:#ffdcd7;background-color:#67060c}
