@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Outfit:wght@300;400;500;600;700;800&display=swap";
:root{--color-bg-base:#0a0a12;--color-bg-surface:#10101e;--color-bg-card:#141428;--color-bg-card-hover:#1a1a35;--color-bg-sidebar:#0d0d1f;--color-accent-purple:#7c5cfc;--color-accent-purple-dim:#4e38a4;--color-accent-blue:#3b8ef3;--color-accent-cyan:#22d3ee;--color-accent-green:#22c55e;--color-accent-orange:#f97316;--color-accent-pink:#e879f9;--gradient-brand:linear-gradient(135deg,#7c5cfc 0%,#3b8ef3 100%);--gradient-success:linear-gradient(135deg,#22c55e 0%,#22d3ee 100%);--gradient-warm:linear-gradient(135deg,#f97316 0%,#e879f9 100%);--gradient-card:linear-gradient(145deg,#141428 0%,#1a1a35 100%);--gradient-hero:linear-gradient(145deg,#0a0a12 0%,#150f3d 50%,#0a0a12 100%);--color-text-primary:#f0efff;--color-text-secondary:#9898c8;--color-text-muted:#5c5c8a;--color-text-accent:#7c5cfc;--color-border:#7c5cfc26;--color-border-subtle:#ffffff0d;--color-border-hover:#7c5cfc66;--glow-purple:0 0 20px #7c5cfc40;--glow-blue:0 0 20px #3b8ef340;--glow-green:0 0 20px #22c55e40;--shadow-card:0 4px 24px #0006;--shadow-elevated:0 8px 40px #0009;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--font-body:"Inter",sans-serif;--font-display:"Outfit",sans-serif;--sidebar-width:240px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-body);background-color:var(--color-bg-base);color:var(--color-text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;line-height:1.6}a{color:inherit;text-decoration:none}img,svg{max-width:100%;display:block}button{cursor:pointer;font-family:inherit}input,textarea,select{font-family:inherit}.text-display{font-family:var(--font-display);letter-spacing:-.02em;font-weight:700}.text-h1{font-size:clamp(2rem,5vw,3.5rem);font-weight:800}.text-h2{font-size:clamp(1.5rem,3vw,2.25rem);font-weight:700}.text-h3{font-size:1.25rem;font-weight:600}.text-h4{font-size:1rem;font-weight:600}.text-body{font-size:.9375rem}.text-sm{font-size:.8125rem}.text-xs{font-size:.6875rem}.text-gradient{background:var(--gradient-brand);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.app-shell{min-height:100vh;display:flex}.main-content{margin-left:var(--sidebar-width);background:var(--color-bg-base);flex:1;min-height:100vh}.page-container{max-width:75vw;min-height:100vh;padding:2rem}.card{background:var(--gradient-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem;transition:border-color .2s,box-shadow .2s,transform .2s}.card:hover{border-color:var(--color-border-hover);box-shadow:var(--glow-purple)}.card-glass{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);background:#14142899;padding:1.5rem}.card-glow{position:relative}.card-glow:before{content:"";border-radius:calc(var(--radius-lg) + 1px);background:var(--gradient-brand);opacity:0;z-index:-1;transition:opacity .3s;position:absolute;inset:-1px}.card-glow:hover:before{opacity:.4}.btn{border-radius:var(--radius-md);white-space:nowrap;border:none;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:600;transition:all .2s;display:inline-flex}.btn-primary{background:var(--gradient-brand);color:#fff;box-shadow:0 4px 16px #7c5cfc4d}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 24px #7c5cfc73}.btn-primary:active{transform:translateY(0)}.btn-secondary{color:var(--color-accent-purple);border:1px solid var(--color-border);background:#7c5cfc1f}.btn-secondary:hover{border-color:var(--color-border-hover);background:#7c5cfc33}.btn-ghost{color:var(--color-text-secondary);border:1px solid var(--color-border-subtle);background:0 0}.btn-ghost:hover{background:var(--color-bg-card);color:var(--color-text-primary)}.btn-danger{color:#ef4444;background:#ef44441a;border:1px solid #ef444433}.btn-danger:hover{background:#ef444433}.btn-lg{border-radius:var(--radius-lg);padding:.875rem 2rem;font-size:1rem}.btn-sm{padding:.375rem .875rem;font-size:.8125rem}.btn-icon{border-radius:var(--radius-sm);aspect-ratio:1;justify-content:center;padding:.5rem}.btn-full{justify-content:center;width:100%}.input-group{flex-direction:column;gap:.375rem;display:flex}.input-label{color:var(--color-text-secondary);letter-spacing:.04em;text-transform:uppercase;font-size:.8125rem;font-weight:600}.input{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;color:var(--color-text-primary);outline:none;padding:.75rem 1rem;font-size:.9375rem;transition:border-color .2s,box-shadow .2s}.input::placeholder{color:var(--color-text-muted)}.input:focus{border-color:var(--color-accent-purple);box-shadow:0 0 0 3px #7c5cfc26}.input-icon-wrapper{position:relative}.input-icon-wrapper .input{padding-left:2.75rem}.input-icon{color:var(--color-text-muted);pointer-events:none;position:absolute;top:50%;left:.875rem;transform:translateY(-50%)}.badge{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.06em;align-items:center;gap:.25rem;padding:.2rem .6rem;font-size:.6875rem;font-weight:700;display:inline-flex}.badge-purple{color:var(--color-accent-purple);background:#7c5cfc26;border:1px solid #7c5cfc4d}.badge-green{color:var(--color-accent-green);background:#22c55e26;border:1px solid #22c55e4d}.badge-orange{color:var(--color-accent-orange);background:#f9731626;border:1px solid #f973164d}.badge-blue{color:var(--color-accent-blue);background:#3b8ef326;border:1px solid #3b8ef34d}.circular-progress{justify-content:center;align-items:center;display:inline-flex;position:relative}.circular-progress svg{transform:rotate(-90deg)}.circular-progress-label{text-align:center;position:absolute}.circular-progress-value{font-family:var(--font-display);color:var(--color-text-primary);font-size:1.5rem;font-weight:700;line-height:1}.circular-progress-sublabel{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;margin-top:2px;font-size:.6875rem;font-weight:600}.kpi-card{background:var(--gradient-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);flex-direction:column;gap:.5rem;padding:1.25rem 1.5rem;display:flex}.kpi-label{text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);font-size:.6875rem;font-weight:700}.kpi-value{font-family:var(--font-display);color:var(--color-text-primary);font-size:2rem;font-weight:800;line-height:1.1}.kpi-change{align-items:center;gap:4px;font-size:.75rem;font-weight:600;display:flex}.kpi-change.positive{color:var(--color-accent-green)}.kpi-change.negative{color:#ef4444}.progress-bar-container{border-radius:var(--radius-full);background:#ffffff0f;width:100%;height:4px;overflow:hidden}.progress-bar-fill{border-radius:var(--radius-full);background:var(--gradient-brand);height:100%;transition:width .8s cubic-bezier(.4,0,.2,1)}.sidebar{width:var(--sidebar-width);background:var(--color-bg-sidebar);border-right:1px solid var(--color-border-subtle);z-index:100;flex-direction:column;padding:1.5rem 0;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-logo{border-bottom:1px solid var(--color-border-subtle);align-items:center;gap:.75rem;padding:0 1.25rem 1.5rem;display:flex}.sidebar-logo-icon{background:var(--gradient-brand);border-radius:var(--radius-sm);color:#fff;width:36px;height:36px;box-shadow:var(--glow-purple);justify-content:center;align-items:center;font-size:1rem;display:flex}.sidebar-logo-text{font-family:var(--font-display);color:var(--color-text-primary);font-size:1.125rem;font-weight:700}.sidebar-nav{flex-direction:column;flex:1;gap:.25rem;padding:1rem .75rem;display:flex}.sidebar-nav-item{border-radius:var(--radius-md);color:var(--color-text-muted);border:1px solid #0000;align-items:center;gap:.75rem;padding:.625rem .875rem;font-size:.875rem;font-weight:500;transition:all .15s;display:flex}.sidebar-nav-item:hover{color:var(--color-text-secondary);background:#7c5cfc14}.sidebar-nav-item.active{color:var(--color-accent-purple);background:#7c5cfc26;border-color:#7c5cfc33;font-weight:600}.sidebar-user{border-top:1px solid var(--color-border-subtle);align-items:center;gap:.75rem;padding:1rem 1.25rem;display:flex}.sidebar-avatar{border-radius:var(--radius-full);background:var(--gradient-brand);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.875rem;font-weight:700;display:flex}.sidebar-user-info{min-width:0}.sidebar-user-name{color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.8125rem;font-weight:600;overflow:hidden}.sidebar-user-tier{color:var(--color-accent-purple);font-size:.6875rem;font-weight:600}.exam-card{background:var(--color-bg-card);border:2px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;text-align:center;padding:1.25rem;transition:all .2s}.exam-card:hover{border-color:var(--color-accent-purple);background:var(--color-bg-card-hover);transform:translateY(-2px)}.exam-card.selected{border-color:var(--color-accent-purple);box-shadow:var(--glow-purple);background:#7c5cfc1a}.exam-card-icon{margin-bottom:.5rem;font-size:2rem}.exam-card-name{font-family:var(--font-display);color:var(--color-text-primary);margin-bottom:.25rem;font-size:1rem;font-weight:700}.exam-card-desc{color:var(--color-text-muted);font-size:.75rem}.tier-card{background:var(--color-bg-card);border:2px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;padding:1rem;transition:all .2s}.tier-card:hover{border-color:var(--color-border-hover)}.tier-card.selected{border-color:var(--color-accent-purple);background:#7c5cfc14}.tier-name{margin-bottom:.25rem;font-size:.9375rem;font-weight:700}.tier-desc{color:var(--color-text-muted);font-size:.75rem;line-height:1.5}.stepper{justify-content:center;align-items:center;gap:0;margin-bottom:2.5rem;display:flex}.step{flex-direction:column;align-items:center;gap:.375rem;display:flex;position:relative}.step-circle{border-radius:var(--radius-full);border:2px solid var(--color-border);background:var(--color-bg-card);width:36px;height:36px;color:var(--color-text-muted);z-index:1;justify-content:center;align-items:center;font-size:.875rem;font-weight:700;transition:all .3s;display:flex}.step.active .step-circle{border-color:var(--color-accent-purple);background:var(--color-accent-purple);color:#fff;box-shadow:var(--glow-purple)}.step.completed .step-circle{border-color:var(--color-accent-green);background:var(--color-accent-green);color:#fff}.step-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;font-size:.6875rem;font-weight:600}.step.active .step-label{color:var(--color-accent-purple)}.step-connector{background:var(--color-border);flex-shrink:0;width:60px;height:2px;margin:0 -1px 1.375rem}.step-connector.completed{background:var(--gradient-brand)}.chat-container{flex-direction:column;height:calc(100vh - 140px);display:flex}.chat-messages{scrollbar-width:thin;scrollbar-color:var(--color-border)transparent;flex-direction:column;flex:1;gap:1rem;padding:1.5rem;display:flex;overflow-y:auto}.chat-messages::-webkit-scrollbar{width:4px}.chat-messages::-webkit-scrollbar-track{background:0 0}.chat-messages::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}.chat-bubble{border-radius:var(--radius-lg);max-width:72%;padding:.875rem 1.125rem;font-size:.9375rem;line-height:1.65}.chat-bubble-user{background:var(--gradient-brand);color:#fff;border-bottom-right-radius:var(--radius-sm);align-self:flex-end}.chat-bubble-ai{background:var(--color-bg-card);border:1px solid var(--color-border);color:var(--color-text-primary);border-bottom-left-radius:var(--radius-sm);align-self:flex-start}.chat-input-bar{border-top:1px solid var(--color-border-subtle);background:var(--color-bg-surface);align-items:center;gap:.75rem;padding:1rem 1.5rem;display:flex}.chat-input{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);color:var(--color-text-primary);outline:none;flex:1;padding:.75rem 1.25rem;font-size:.9375rem;transition:border-color .2s}.chat-input:focus{border-color:var(--color-accent-purple)}.chat-input::placeholder{color:var(--color-text-muted)}.chat-send-btn{border-radius:var(--radius-full);background:var(--gradient-brand);color:#fff;border:none;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;transition:all .2s;display:flex;box-shadow:0 4px 12px #7c5cfc4d}.chat-send-btn:hover{box-shadow:var(--glow-purple);transform:scale(1.05)}.mission-item:hover{border-color:var(--color-border-hover)}.mission-item:hover .mission-checkbox{border-color:var(--color-accent-purple)}.mission-item.completed .mission-checkbox{border-color:var(--color-accent-green);background:var(--color-accent-green)}.mission-content{flex:1;min-width:0}.mission-title{color:var(--color-text-primary);margin-bottom:.125rem;font-size:.875rem;font-weight:600}.mission-coin-reward{color:#f59e0b;align-items:center;gap:4px;font-size:.75rem;font-weight:700;display:flex}.resource-card{background:var(--gradient-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;flex-direction:column;transition:all .25s;display:flex;overflow:hidden}.resource-card:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-elevated);transform:translateY(-4px)}.resource-card-thumb{height:140px;position:relative;overflow:hidden}.resource-card-body{flex-direction:column;flex:1;gap:.5rem;padding:1rem;display:flex}.resource-card-title{color:var(--color-text-primary);font-size:.9375rem;font-weight:700;line-height:1.4}.resource-card-meta{color:var(--color-text-muted);font-size:.75rem}.insight-banner{border-radius:var(--radius-lg);background:linear-gradient(135deg,#7c5cfc1f,#3b8ef314);border:1px solid #7c5cfc40;align-items:center;gap:1rem;margin-bottom:1.5rem;padding:1rem 1.5rem;display:flex}.insight-banner-icon{border-radius:var(--radius-md);background:var(--gradient-brand);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.insight-banner-content{flex:1;min-width:0}.insight-banner-text{color:var(--color-text-secondary);font-size:.875rem}.live-badge{color:#ef4444;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.08em;background:#ef444426;align-items:center;gap:4px;padding:.125rem .4rem;font-size:.6rem;font-weight:800;display:inline-flex}.live-badge:before{content:"";background:#ef4444;border-radius:50%;width:5px;height:5px;animation:1.5s infinite pulse-dot}@keyframes pulse-dot{0%{opacity:1}50%{opacity:.5}to{opacity:1}}.coin-display{border-radius:var(--radius-full);color:#f59e0b;background:#f59e0b1a;border:1px solid #f59e0b40;align-items:center;gap:.375rem;padding:.375rem .75rem;font-size:.875rem;font-weight:700;display:inline-flex}.auth-shell{background:var(--gradient-hero);justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.auth-card{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:448px;box-shadow:var(--shadow-elevated);padding:2.5rem}.auth-logo{justify-content:center;align-items:center;gap:.75rem;margin-bottom:2rem;display:flex}.auth-logo-icon{border-radius:var(--radius-md);background:var(--gradient-brand);color:#fff;width:44px;height:44px;box-shadow:var(--glow-purple);justify-content:center;align-items:center;font-size:1.25rem;display:flex}.auth-divider{align-items:center;gap:1rem;margin:1.5rem 0;display:flex}.auth-divider-line{background:var(--color-border-subtle);flex:1;height:1px}.auth-divider-text{color:var(--color-text-muted);font-size:.75rem;font-weight:500}.onboarding-shell{background:var(--gradient-hero);flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.onboarding-card{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:680px;box-shadow:var(--shadow-elevated);padding:2.5rem}*{scrollbar-width:thin;scrollbar-color:var(--color-border)transparent}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.animate-slide-left{animation:.4s both slideInLeft}.skeleton{background:linear-gradient(90deg,var(--color-bg-card)25%,var(--color-bg-card-hover)50%,var(--color-bg-card)75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s infinite shimmer}.glow-purple{box-shadow:var(--glow-purple)}.glow-blue{box-shadow:var(--glow-blue)}.glow-green{box-shadow:var(--glow-green)}.grid-2{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:1rem;display:grid}.grid-4{grid-template-columns:repeat(4,1fr);gap:1rem;display:grid}@media (max-width:900px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}}@media (max-width:600px){.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}.main-content{margin-left:0}.page-container{padding:1rem}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.w-full{width:100%}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.insight-banner{background:var(--gradient-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);align-items:center;gap:1.25rem;margin-bottom:1.5rem;padding:1.25rem 1.5rem;display:flex}.insight-banner-icon{border-radius:var(--radius-md);width:48px;height:48px;color:var(--color-accent-purple);background:#7c5cfc26;flex-shrink:0;justify-content:center;align-items:center;display:flex}.insight-banner-content{flex:1}.insight-banner-label{text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);align-items:center;gap:.5rem;margin-bottom:.25rem;font-size:.75rem;font-weight:700;display:flex}.insight-banner-text{color:var(--color-text-primary);font-size:.9375rem;font-weight:500}.live-badge{color:#ef4444;border-radius:var(--radius-sm);background:#ef444426;border:1px solid #ef44444d;padding:.15rem .4rem;font-size:.625rem;animation:2s infinite pulse-dot}.coin-display{color:#f59e0b;border-radius:var(--radius-md);background:#f59e0b1a;border:1px solid #f59e0b33;align-items:center;gap:.375rem;padding:.375rem .75rem;font-size:.875rem;font-weight:700;display:flex}.mission-item{background:var(--color-bg-card);border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);align-items:flex-start;gap:1rem;padding:1rem;transition:all .2s;display:flex}.mission-item:hover{border-color:var(--color-border-hover);background:var(--color-bg-card-hover)}.mission-item.completed{opacity:.7}.mission-item.completed .mission-title{color:var(--color-text-muted);text-decoration:line-through}.mission-checkbox{border:2px solid var(--color-border);cursor:pointer;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;margin-top:2px;transition:all .2s;display:flex}.mission-item.completed .mission-checkbox{background:var(--color-accent-green);border-color:var(--color-accent-green)}.mission-content{flex:1}.mission-title{color:var(--color-text-primary);margin-bottom:.25rem;font-size:.9375rem;font-weight:600;transition:color .2s}.mission-meta{color:var(--color-text-muted);align-items:center;gap:1rem;font-size:.8125rem;display:flex}.mission-coin-reward{color:#f59e0b;font-weight:700}.library-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);flex-direction:column;height:100%;padding:1.25rem;transition:all .2s;display:flex}.library-card:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-card);transform:translateY(-2px)}.mission-card{background:var(--gradient-card);border:1px solid var(--color-border);border-left:3px solid var(--color-accent-purple);border-radius:var(--radius-lg);padding:1.125rem 1.25rem;transition:border-color .2s,box-shadow .2s}.mission-card:hover{border-color:var(--color-border-hover);box-shadow:var(--glow-purple)}.mission-card-completed{opacity:.75}.mission-card-header{-webkit-user-select:none;user-select:none;align-items:center;gap:.75rem;display:flex}.mission-card-title{color:var(--color-text-primary);font-size:.9375rem;font-weight:600;line-height:1.4}.mission-card-body{border-top:1px solid var(--color-border-subtle);margin-top:1rem;padding-top:1rem}.mission-day-badge{border-radius:var(--radius-md);text-align:center;border:1px solid;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:.6875rem;font-weight:700;line-height:1.2;display:inline-flex}.mission-day-number{display:block}.coin-display{color:#f59e0b;align-items:center;gap:.375rem;font-size:.8125rem;font-weight:700;display:inline-flex}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-fade-in{animation:.4s forwards fadeIn}.timeline-flow{flex-direction:column;gap:0;display:flex;position:relative}.timeline-phase{position:relative}.timeline-connector{border-left:2px dashed var(--color-border);width:2px;height:16px;position:absolute;top:-16px;left:17px}.timeline-phase-header{background:var(--gradient-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;align-items:flex-start;gap:1rem;padding:1.25rem;transition:border-color .2s,box-shadow .2s;display:flex}.timeline-phase-header:hover{border-color:var(--color-border-hover);box-shadow:var(--glow-purple)}.timeline-phase-dot{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;margin-top:2px;display:flex}.timeline-chapters{border-left:2px solid var(--color-border);flex-direction:column;gap:.375rem;margin-left:17px;padding:.75rem 0 .75rem 1.5rem;display:flex}.timeline-chapter-card{background:var(--color-bg-card);border:1px solid var(--color-border-subtle);border-left:3px solid var(--color-accent-blue);border-radius:var(--radius-md);padding:.75rem 1rem;transition:border-color .15s,background .15s}.timeline-chapter-card:hover{border-color:var(--color-border-hover);background:var(--color-bg-card-hover)}.timetable-grid{grid-template-columns:repeat(7,1fr);gap:.5rem;display:grid;overflow-x:auto}@media (max-width:1200px){.timetable-grid{grid-template-columns:repeat(7,minmax(140px,1fr))}}.timetable-day{background:var(--gradient-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);min-width:0;overflow:hidden}.timetable-day-header{text-align:center;border-bottom:2px solid var(--color-border);background:#ffffff05;padding:.75rem}.timetable-slot:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0000004d}.spin{animation:1s linear infinite spin}.mobile-menu-btn,.mobile-close-btn,.sidebar-overlay{display:none}@media (max-width:768px){.app-shell{flex-direction:column}.main-content{min-width:100vw;margin-left:0;padding-top:60px}.page-container{max-width:100vw;padding:1.25rem}.mobile-menu-btn{z-index:90;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);cursor:pointer;padding:8px;display:flex;position:fixed;top:12px;left:16px}.mobile-close-btn{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;display:flex}.sidebar{z-index:1000;transition:transform .3s cubic-bezier(.4,0,.2,1);transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:95;background:#0009;display:block;position:fixed;inset:0}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr!important}.chat-container{height:calc(100vh - 120px)}.insight-banner{flex-direction:column;align-items:flex-start;gap:.5rem}}
