@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";
@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2c55a0e60120577a-s.0bjc5tiuqdqro.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.0m6w47a4e5dy9.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/ad66f9afd8947f86-s.11u06r12fd6v_.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/5476f68d60460930-s.0wxq9webf.ew4.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.067x_6k0k23tk.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/1bffadaabf893a1e-s.16ipb6fqu393i.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.0q-301v4kxxnr.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter Fallback;src:local(Arial);ascent-override:90.44%;descent-override:22.52%;line-gap-override:0.0%;size-adjust:107.12%}.inter_c15e96cb-module__0bjUvq__className{font-family:Inter,Inter Fallback;font-style:normal}.inter_c15e96cb-module__0bjUvq__variable{--font-inter:"Inter", "Inter Fallback"}
:root{--color-bg-darkest:#060910;--color-bg-dark:#0a0e1a;--color-bg-base:#0f1629;--color-bg-elevated:#1a1f36;--color-bg-surface:#232946;--color-bg-hover:#2a3158;--color-primary:#3b82f6;--color-primary-hover:#2563eb;--color-primary-glow:#3b82f640;--color-primary-subtle:#3b82f61a;--color-accent:#8b5cf6;--color-accent-hover:#7c3aed;--color-accent-glow:#8b5cf640;--color-success:#10b981;--color-success-bg:#10b9811a;--color-warning:#f59e0b;--color-warning-bg:#f59e0b1a;--color-error:#ef4444;--color-error-bg:#ef44441a;--color-text-primary:#e2e8f0;--color-text-secondary:#94a3b8;--color-text-muted:#64748b;--color-text-inverse:#0a0e1a;--color-border:#ffffff14;--color-border-hover:#ffffff26;--color-border-active:#3b82f666;--gradient-primary:linear-gradient(135deg, #3b82f6 0%, #8b5cf6 100%);--gradient-bg:linear-gradient(180deg, #0a0e1a 0%, #0f1629 50%, #1a1f36 100%);--gradient-card:linear-gradient(135deg, #1a1f36cc 0%, #0f162999 100%);--gradient-glow:radial-gradient(600px circle at var(--mouse-x,50%) var(--mouse-y,50%), #3b82f60f, transparent 40%);--gradient-hero:linear-gradient(135deg, #0a0e1a 0%, #1a1040 50%, #0f1629 100%);--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", "Consolas", monospace;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--text-5xl:3rem;--text-6xl:3.75rem;--leading-tight:1.2;--leading-normal:1.5;--leading-relaxed:1.7;--tracking-tight:-.025em;--tracking-normal:0;--tracking-wide:.025em;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--space-24:6rem;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-2xl:20px;--radius-full:9999px;--shadow-sm:0 2px 8px #0003;--shadow-md:0 4px 16px #0000004d;--shadow-lg:0 8px 32px #0006;--shadow-xl:0 16px 48px #00000080;--shadow-glow-primary:0 0 20px #3b82f64d;--shadow-glow-accent:0 0 20px #8b5cf64d;--glass-bg:#0f1629b3;--glass-bg-heavy:#0a0e1ad9;--glass-blur:blur(16px);--glass-border:1px solid #ffffff14;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.4s ease;--transition-spring:.5s cubic-bezier(.34, 1.56, .64, 1);--z-dropdown:100;--z-sticky:200;--z-modal-backdrop:300;--z-modal:400;--z-toast:500;--z-tooltip:600;--sidebar-width:260px;--sidebar-collapsed:72px;--header-height:64px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-text-primary);background:var(--color-bg-darkest);min-height:100vh;overflow-x:hidden}body:before{content:"";background:var(--gradient-bg);z-index:-2;position:fixed;inset:0}body:after{content:"";opacity:.015;z-index:-1;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");position:fixed;inset:0}a{color:var(--color-primary);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-primary-hover)}img{max-width:100%;display:block}input,textarea,button,select{font-family:inherit;font-size:inherit;color:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{border-radius:var(--radius-full);background:#ffffff1a}::-webkit-scrollbar-thumb:hover{background:#fff3}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:var(--leading-tight);letter-spacing:var(--tracking-tight);color:var(--color-text-primary)}h1{font-size:var(--text-4xl)}h2{font-size:var(--text-3xl)}h3{font-size:var(--text-2xl)}h4{font-size:var(--text-xl)}h5{font-size:var(--text-lg)}h6{font-size:var(--text-base);font-weight:600}p{color:var(--color-text-secondary);line-height:var(--leading-relaxed)}code{font-family:var(--font-mono);background:var(--color-bg-surface);border-radius:var(--radius-sm);color:var(--color-primary);padding:.15em .4em;font-size:.9em}pre{font-family:var(--font-mono);background:var(--color-bg-dark);border:var(--glass-border);border-radius:var(--radius-lg);padding:var(--space-4);font-size:var(--text-sm);overflow-x:auto}pre code{color:var(--color-text-primary);background:0 0;padding:0}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-weight:500;font-size:var(--text-sm);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;border:none;display:inline-flex;position:relative;overflow:hidden}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover:not(:disabled){box-shadow:var(--shadow-glow-primary);transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:var(--color-bg-surface);color:var(--color-text-primary);border:var(--glass-border)}.btn-secondary:hover:not(:disabled){background:var(--color-bg-hover);border-color:var(--color-border-hover)}.btn-ghost{color:var(--color-text-secondary);background:0 0}.btn-ghost:hover:not(:disabled){color:var(--color-text-primary);background:#ffffff0d}.btn-danger{background:var(--color-error);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626;box-shadow:0 0 20px #ef44444d}.btn-lg{padding:var(--space-3) var(--space-6);font-size:var(--text-base);border-radius:var(--radius-lg)}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--text-xs)}.btn-icon{border-radius:var(--radius-md);width:36px;height:36px;padding:0}.glass-card{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border:var(--glass-border);border-radius:var(--radius-xl);transition:all var(--transition-base)}.glass-card:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-md)}.glass-card-interactive{cursor:pointer}.glass-card-interactive:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.gradient-border{position:relative}.gradient-border:before{content:"";border-radius:inherit;background:var(--gradient-primary);-webkit-mask-composite:xor;opacity:0;transition:opacity var(--transition-base);padding:1px;position:absolute;inset:0;-webkit-mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);-webkit-mask-position:0 0,0 0;-webkit-mask-size:auto,auto;-webkit-mask-repeat:repeat,repeat;-webkit-mask-clip:content-box,border-box;-webkit-mask-origin:content-box,border-box;-webkit-mask-composite:xor;mask-composite:exclude;-webkit-mask-source-type:auto,auto;mask-mode:match-source,match-source}.gradient-border:hover:before{opacity:1}.input{width:100%;padding:var(--space-3) var(--space-4);background:var(--color-bg-dark);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);transition:all var(--transition-fast);outline:none;font-size:16px}.input::placeholder{color:var(--color-text-muted)}.input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-subtle)}.input:hover:not(:focus){border-color:var(--color-border-hover)}textarea.input{resize:vertical;min-height:100px}.input-group{gap:var(--space-2);flex-direction:column;display:flex}.input-label{font-size:var(--text-sm);color:var(--color-text-secondary);font-weight:500}.badge{align-items:center;gap:var(--space-1);padding:2px var(--space-2);font-size:var(--text-xs);border-radius:var(--radius-full);white-space:nowrap;font-weight:600;display:inline-flex}.badge-primary{background:var(--color-primary-subtle);color:var(--color-primary)}.badge-accent{color:var(--color-accent);background:#8b5cf61a}.badge-success{background:var(--color-success-bg);color:var(--color-success)}.badge-warning{background:var(--color-warning-bg);color:var(--color-warning)}.badge-error{background:var(--color-error-bg);color:var(--color-error)}.tabs{gap:var(--space-1);border-bottom:1px solid var(--color-border);scrollbar-width:none;padding-bottom:0;display:flex;overflow-x:auto}.tabs::-webkit-scrollbar{display:none}.tab{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;font-weight:500;display:flex}.tab:hover{color:var(--color-text-secondary)}.tab-active{color:var(--color-primary);border-bottom-color:var(--color-primary)}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg, var(--color-bg-surface) 25%, var(--color-bg-hover) 50%, var(--color-bg-surface) 75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s ease-in-out infinite shimmer}.skeleton-text{height:1em;margin-bottom:var(--space-2)}.skeleton-title{width:60%;height:1.5em;margin-bottom:var(--space-3)}.skeleton-card{border-radius:var(--radius-xl);height:200px}@keyframes spin{to{transform:rotate(360deg)}}.spinner{border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:24px;height:24px;animation:.6s linear infinite spin}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.pulse{animation:2s ease-in-out infinite pulse}.toast-container{bottom:var(--space-6);right:var(--space-6);z-index:var(--z-toast);gap:var(--space-3);flex-direction:column;display:flex;position:fixed}.toast{background:var(--glass-bg-heavy);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:var(--glass-border);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4);align-items:center;gap:var(--space-3);box-shadow:var(--shadow-lg);min-width:300px;max-width:420px;display:flex}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-modal-backdrop);padding:var(--space-4);background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--color-bg-elevated);border:var(--glass-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:520px;max-height:85vh;z-index:var(--z-modal);overflow-y:auto}.modal-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.modal-body{padding:var(--space-6)}.modal-footer{justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border);display:flex}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--glass-bg-heavy);height:100vh;-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-right:var(--glass-border);z-index:var(--z-sticky);transition:width var(--transition-base);flex-direction:column;display:flex;position:fixed;top:0;left:0;overflow:hidden}.sidebar-logo{padding:var(--space-5) var(--space-5);align-items:center;gap:var(--space-3);border-bottom:1px solid var(--color-border);display:flex}.sidebar-logo h2{font-size:var(--text-xl);background:var(--gradient-primary);-webkit-text-fill-color:transparent;letter-spacing:-.03em;-webkit-background-clip:text;background-clip:text;font-weight:800}.sidebar-nav{padding:var(--space-4) var(--space-3);gap:var(--space-1);flex-direction:column;flex:1;display:flex;overflow-y:auto}.sidebar-link{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-3);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);text-align:left;background:0 0;border:none;width:100%;font-weight:500;display:flex}.sidebar-link:hover{color:var(--color-text-primary);background:#ffffff0d}.sidebar-link-active{background:var(--color-primary-subtle);color:var(--color-primary)}.sidebar-section-title{font-size:var(--text-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:var(--tracking-wide);padding:var(--space-4) var(--space-3) var(--space-2);font-weight:600}.sidebar-user{padding:var(--space-4) var(--space-3);border-top:1px solid var(--color-border);align-items:center;gap:var(--space-3);display:flex}.sidebar-user-avatar{border-radius:var(--radius-full);background:var(--gradient-primary);width:36px;height:36px;font-weight:700;font-size:var(--text-sm);color:#fff;flex-shrink:0;justify-content:center;align-items:center;display:flex}.main-content{margin-left:var(--sidebar-width);flex:1;min-height:100vh}.page-header{padding:var(--space-6) var(--space-8);border-bottom:1px solid var(--color-border);background:var(--glass-bg-heavy);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);z-index:var(--z-sticky);position:sticky;top:0}.page-content{padding:var(--space-6) var(--space-8)}.drop-zone{border:2px dashed var(--color-border);border-radius:var(--radius-xl);padding:var(--space-12) var(--space-8);justify-content:center;align-items:center;gap:var(--space-4);text-align:center;transition:all var(--transition-base);cursor:pointer;flex-direction:column;display:flex;position:relative;overflow:hidden}.drop-zone:before{content:"";background:var(--gradient-primary);opacity:0;transition:opacity var(--transition-base);position:absolute;inset:0}.drop-zone:hover,.drop-zone-active{border-color:var(--color-primary);background:var(--color-primary-subtle)}.drop-zone:hover:before,.drop-zone-active:before{opacity:.03}.drop-zone-icon{border-radius:var(--radius-lg);background:var(--color-primary-subtle);width:56px;height:56px;color:var(--color-primary);justify-content:center;align-items:center;display:flex}.flashcard-container{perspective:1200px;width:100%;max-width:600px;height:360px;margin:0 auto}.flashcard{width:100%;height:100%;transform-style:preserve-3d;cursor:pointer;transition:transform .6s cubic-bezier(.4,0,.2,1);position:relative}.flashcard-flipped{transform:rotateY(180deg)}.flashcard-face{backface-visibility:hidden;padding:var(--space-8);background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:var(--glass-border);border-radius:var(--radius-xl);text-align:center;font-size:var(--text-lg);line-height:var(--leading-relaxed);flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.flashcard-front{background:linear-gradient(135deg,#0f1629e6,#1a1f36e6)}.flashcard-back{background:linear-gradient(135deg,#3b82f61a,#8b5cf61a);border-color:#3b82f633;transform:rotateY(180deg)}.flashcard-label{font-size:var(--text-xs)!important;text-transform:uppercase!important;letter-spacing:var(--tracking-wide)!important;color:var(--color-text-muted)!important;align-self:flex-start!important;margin:0!important;font-weight:600!important;position:absolute!important;top:16px!important;left:16px!important}.flashcard-controls{gap:var(--space-3);margin-top:var(--space-6);justify-content:center;display:flex}.flashcard-btn{padding:var(--space-3) var(--space-5);border-radius:var(--radius-lg);font-weight:600;font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-base);border:none}.flashcard-btn-again{background:var(--color-error-bg);color:var(--color-error)}.flashcard-btn-hard{background:var(--color-warning-bg);color:var(--color-warning)}.flashcard-btn-good{background:var(--color-success-bg);color:var(--color-success)}.flashcard-btn-easy{background:var(--color-primary-subtle);color:var(--color-primary)}.flashcard-btn:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.chat-container{flex-direction:column;height:100%;max-height:calc(100vh - 200px);display:flex}.chat-messages{padding:var(--space-4);gap:var(--space-4);flex-direction:column;flex:1;display:flex;overflow-y:auto}.chat-message{gap:var(--space-3);max-width:85%;display:flex}.chat-message-user{flex-direction:row-reverse;align-self:flex-end}.chat-message-avatar{border-radius:var(--radius-full);width:32px;height:32px;font-size:var(--text-xs);flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.chat-message-user .chat-message-avatar{background:var(--gradient-primary);color:#fff}.chat-message-ai .chat-message-avatar{background:var(--color-accent-glow);color:var(--color-accent)}.chat-message-bubble{padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);font-size:var(--text-sm);line-height:var(--leading-relaxed)}.chat-message-user .chat-message-bubble{background:var(--color-primary);color:#fff;border-bottom-right-radius:var(--radius-sm)}.chat-message-ai .chat-message-bubble{background:var(--color-bg-surface);border:var(--glass-border);border-bottom-left-radius:var(--radius-sm)}.chat-input-bar{gap:var(--space-3);padding:var(--space-4);border-top:1px solid var(--color-border);background:var(--glass-bg-heavy);display:flex}.chat-input{padding:var(--space-3) var(--space-4);background:var(--color-bg-dark);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-primary);font-size:var(--text-sm);resize:none;min-height:44px;max-height:120px;transition:border-color var(--transition-fast);outline:none;flex:1}.chat-input:focus{border-color:var(--color-primary)}.quiz-option{align-items:flex-start;gap:var(--space-3);padding:var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);text-align:left;width:100%;font-size:var(--text-sm);color:var(--color-text-primary);background:0 0;display:flex}.quiz-option:hover{border-color:var(--color-border-hover);background:#ffffff08}.quiz-option-selected{border-color:var(--color-primary);background:var(--color-primary-subtle)}.quiz-option-correct{border-color:var(--color-success);background:var(--color-success-bg)}.quiz-option-wrong{border-color:var(--color-error);background:var(--color-error-bg)}.quiz-option-indicator{border-radius:var(--radius-full);border:2px solid var(--color-border);width:22px;height:22px;transition:all var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;margin-top:1px;display:flex}.quiz-option-selected .quiz-option-indicator{border-color:var(--color-primary);background:var(--color-primary)}.progress-bar{background:var(--color-bg-surface);border-radius:var(--radius-full);width:100%;height:6px;overflow:hidden}.progress-bar-fill{background:var(--gradient-primary);border-radius:var(--radius-full);height:100%;transition:width var(--transition-slow)}.stats-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.stat-card{padding:var(--space-5)}.stat-value{font-size:var(--text-3xl);letter-spacing:var(--tracking-tight);background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:800}.stat-label{font-size:var(--text-sm);color:var(--color-text-muted);margin-top:var(--space-1)}@keyframes processingGlow{0%,to{box-shadow:0 0 20px #3b82f61a}50%{box-shadow:0 0 40px #3b82f633}}.processing-card{animation:2s ease-in-out infinite processingGlow}@keyframes dotBounce{0%,80%,to{transform:translateY(0)}40%{transform:translateY(-6px)}}.typing-dots{align-items:center;gap:4px;display:flex}.typing-dot{background:var(--color-text-muted);border-radius:50%;width:6px;height:6px;animation:1.4s ease-in-out infinite both dotBounce}.typing-dot:first-child{animation-delay:-.32s}.typing-dot:nth-child(2){animation-delay:-.16s}.typing-dot:nth-child(3){animation-delay:0}@media (max-width:1024px){.sidebar{transform:translate(-100%)}.sidebar-open{transform:translate(0)}.main-content{margin-left:0}.page-content,.page-header{padding:var(--space-4)}}@media (max-width:768px){h1{font-size:var(--text-3xl)}h2{font-size:var(--text-2xl)}h3{font-size:var(--text-xl)}.stats-grid{grid-template-columns:repeat(2,1fr)}.flashcard-container{height:280px}.chat-message{max-width:95%}}@media (max-width:480px){.stats-grid{grid-template-columns:1fr}.flashcard-container{height:240px}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.text-center{text-align:center}.text-sm{font-size:var(--text-sm)}.text-muted{color:var(--color-text-muted)}.text-secondary{color:var(--color-text-secondary)}.w-full{width:100%}.relative{position:relative}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.animate-fade-in{animation:.4s forwards fadeIn}.animate-slide-in{animation:.4s forwards slideInRight}.animate-scale-in{animation:.3s forwards scaleIn}.stagger-children>*{opacity:0;animation:.4s forwards fadeIn}.stagger-children>:first-child{animation-delay:0s}.stagger-children>:nth-child(2){animation-delay:50ms}.stagger-children>:nth-child(3){animation-delay:.1s}.stagger-children>:nth-child(4){animation-delay:.15s}.stagger-children>:nth-child(5){animation-delay:.2s}.stagger-children>:nth-child(6){animation-delay:.25s}.stagger-children>:nth-child(7){animation-delay:.3s}.stagger-children>:nth-child(8){animation-delay:.35s}
