:root{--bg-primary: #0a0a1a;--bg-secondary: #0f0f2a;--bg-tertiary: #161638;--bg-card: rgba(255, 255, 255, .04);--bg-card-hover: rgba(255, 255, 255, .07);--bg-glass: rgba(255, 255, 255, .06);--bg-glass-strong: rgba(255, 255, 255, .1);--bg-input: rgba(255, 255, 255, .05);--bg-sidebar: rgba(10, 10, 30, .95);--primary: #7c3aed;--primary-light: #a78bfa;--primary-dark: #5b21b6;--primary-glow: rgba(124, 58, 237, .3);--secondary: #06b6d4;--secondary-light: #22d3ee;--secondary-dark: #0891b2;--secondary-glow: rgba(6, 182, 212, .3);--accent: #10b981;--accent-light: #34d399;--accent-glow: rgba(16, 185, 129, .3);--warning: #f59e0b;--warning-light: #fbbf24;--warning-glow: rgba(245, 158, 11, .3);--danger: #ef4444;--danger-light: #f87171;--danger-glow: rgba(239, 68, 68, .3);--pink: #ec4899;--pink-light: #f472b6;--orange: #f97316;--gradient-primary: linear-gradient(135deg, #7c3aed, #06b6d4);--gradient-accent: linear-gradient(135deg, #10b981, #06b6d4);--gradient-warm: linear-gradient(135deg, #f59e0b, #ef4444);--gradient-cool: linear-gradient(135deg, #7c3aed, #ec4899);--gradient-card: linear-gradient(135deg, rgba(124, 58, 237, .1), rgba(6, 182, 212, .05));--gradient-sidebar: linear-gradient(180deg, #0a0a1a 0%, #0f0f2a 100%);--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-tertiary: #64748b;--text-muted: #475569;--text-inverse: #0a0a1a;--border: rgba(255, 255, 255, .08);--border-light: rgba(255, 255, 255, .12);--border-focus: rgba(124, 58, 237, .5);--font-heading: "Space Grotesk", system-ui, sans-serif;--font-body: "Inter", system-ui, sans-serif;--font-mono: "JetBrains Mono", monospace;--text-xs: .75rem;--text-sm: .8125rem;--text-base: .9375rem;--text-lg: 1.0625rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--text-5xl: 3rem;--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;--radius-sm: .375rem;--radius-md: .625rem;--radius-lg: .875rem;--radius-xl: 1.25rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .5);--shadow-xl: 0 16px 50px rgba(0, 0, 0, .6);--shadow-glow-primary: 0 0 20px rgba(124, 58, 237, .3);--shadow-glow-secondary: 0 0 20px rgba(6, 182, 212, .3);--shadow-glow-accent: 0 0 20px rgba(16, 185, 129, .3);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--transition-spring: .5s cubic-bezier(.34, 1.56, .64, 1);--sidebar-width: 260px;--sidebar-collapsed: 72px;--header-height: 64px;--z-sidebar: 40;--z-header: 30;--z-modal: 50;--z-toast: 60;--z-tooltip: 70}[data-theme=light]{--bg-primary: #f8fafc;--bg-secondary: #f1f5f9;--bg-tertiary: #e2e8f0;--bg-card: rgba(255, 255, 255, .8);--bg-card-hover: rgba(255, 255, 255, .95);--bg-glass: rgba(255, 255, 255, .7);--bg-glass-strong: rgba(255, 255, 255, .85);--bg-input: rgba(0, 0, 0, .04);--bg-sidebar: rgba(255, 255, 255, .95);--text-primary: #0f172a;--text-secondary: #475569;--text-tertiary: #94a3b8;--text-muted: #cbd5e1;--border: rgba(0, 0, 0, .08);--border-light: rgba(0, 0, 0, .12);--gradient-sidebar: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);--gradient-card: linear-gradient(135deg, rgba(124, 58, 237, .05), rgba(6, 182, 212, .03));--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .12);--shadow-xl: 0 16px 50px rgba(0, 0, 0, .15)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;overflow-x:hidden}#root{min-height:100vh}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--text-tertiary);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:700;line-height:1.2;letter-spacing:-.02em;color:var(--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)}p{color:var(--text-secondary);line-height:1.7}a{color:var(--primary-light);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary)}.app-layout{display:flex;min-height:100vh;background:var(--bg-primary)}.main-content{flex:1;margin-left:var(--sidebar-width);min-height:100vh;display:flex;flex-direction:column;transition:margin-left var(--transition-base)}.page-content{flex:1;padding:var(--space-8);padding-top:calc(var(--header-height) + var(--space-8));max-width:1400px;width:100%;margin:0 auto}.glass-card{background:var(--bg-card);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-6);transition:all var(--transition-base);position:relative;overflow:hidden}.glass-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent)}.glass-card:hover{background:var(--bg-card-hover);border-color:var(--border-light);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-family:var(--font-body);font-size:var(--text-sm);font-weight:600;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;position:relative;overflow:hidden}.btn:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(rgba(255,255,255,.1),transparent);opacity:0;transition:opacity var(--transition-fast)}.btn:hover:after{opacity:1}.btn:active{transform:scale(.97)}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-glow-primary)}.btn-primary:hover{box-shadow:0 0 30px #7c3aed80;transform:translateY(-1px)}.btn-secondary{background:var(--bg-glass-strong);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:#ffffff26;border-color:var(--border-light)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-glass);color:var(--text-primary)}.btn-danger{background:var(--danger);color:#fff}.btn-success{background:var(--accent);color:#fff}.btn-sm{padding:var(--space-2) var(--space-4);font-size:var(--text-xs)}.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--text-base)}.btn-icon{padding:var(--space-2);width:36px;height:36px;border-radius:var(--radius-md)}.input{width:100%;padding:var(--space-3) var(--space-4);background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-body);font-size:var(--text-sm);transition:all var(--transition-base);outline:none}.input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow);background:var(--bg-glass)}.input::placeholder{color:var(--text-tertiary)}.textarea{resize:vertical;min-height:100px;line-height:1.6}.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.label{display:block;font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-2)}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-size:var(--text-xs);font-weight:600;border-radius:var(--radius-full);background:var(--bg-glass);color:var(--text-secondary);border:1px solid var(--border)}.badge-primary{background:#7c3aed26;color:var(--primary-light);border-color:#7c3aed4d}.badge-secondary{background:#06b6d426;color:var(--secondary-light);border-color:#06b6d44d}.badge-accent{background:#10b98126;color:var(--accent-light);border-color:#10b9814d}.badge-warning{background:#f59e0b26;color:var(--warning-light);border-color:#f59e0b4d}.badge-danger{background:#ef444426;color:var(--danger-light);border-color:#ef44444d}.stat-card{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-6);position:relative;overflow:hidden;transition:all var(--transition-base)}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--border-light)}.stat-card .stat-icon{width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-4);font-size:1.5rem}.stat-card .stat-value{font-family:var(--font-heading);font-size:var(--text-3xl);font-weight:700;color:var(--text-primary);line-height:1;margin-bottom:var(--space-1)}.stat-card .stat-label{font-size:var(--text-sm);color:var(--text-secondary)}.stat-card .stat-change{font-size:var(--text-xs);font-weight:600;display:flex;align-items:center;gap:var(--space-1);margin-top:var(--space-2)}.stat-change.positive{color:var(--accent)}.stat-change.negative{color:var(--danger)}.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-width);height:100vh;background:var(--gradient-sidebar);border-right:1px solid var(--border);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:var(--z-sidebar);display:flex;flex-direction:column;transition:width var(--transition-base);overflow-y:auto;overflow-x:hidden}.sidebar-logo{padding:var(--space-6);display:flex;align-items:center;gap:var(--space-3);border-bottom:1px solid var(--border)}.sidebar-logo .logo-icon{width:40px;height:40px;border-radius:var(--radius-lg);background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.25rem;flex-shrink:0;box-shadow:var(--shadow-glow-primary)}.sidebar-logo .logo-text{font-family:var(--font-heading);font-size:var(--text-lg);font-weight:700;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-logo .logo-badge{font-size:var(--text-xs);background:#7c3aed33;color:var(--primary-light);padding:2px 6px;border-radius:var(--radius-sm);font-weight:600}.sidebar-nav{flex:1;padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-1)}.sidebar-section{margin-top:var(--space-4);margin-bottom:var(--space-2)}.sidebar-section-title{font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);padding:0 var(--space-3)}.nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-3);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast);text-decoration:none;position:relative}.nav-item:hover{background:var(--bg-glass);color:var(--text-primary)}.nav-item.active{background:#7c3aed1f;color:var(--primary-light)}.nav-item.active:before{content:"";position:absolute;left:-16px;top:50%;transform:translateY(-50%);width:3px;height:20px;background:var(--primary);border-radius:0 var(--radius-sm) var(--radius-sm) 0}.nav-item .nav-icon{width:20px;height:20px;flex-shrink:0}.nav-item .nav-badge{margin-left:auto;background:var(--primary);color:#fff;font-size:.65rem;padding:2px 6px;border-radius:var(--radius-full);font-weight:700;min-width:18px;text-align:center}.sidebar-footer{padding:var(--space-4);border-top:1px solid var(--border)}.sidebar-user{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.sidebar-user:hover{background:var(--bg-glass)}.sidebar-user .user-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:var(--text-sm);flex-shrink:0}.sidebar-user .user-info{flex:1;min-width:0}.sidebar-user .user-name{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user .user-level{font-size:var(--text-xs);color:var(--primary-light);display:flex;align-items:center;gap:var(--space-1)}.header{position:fixed;top:0;left:var(--sidebar-width);right:0;height:var(--header-height);background:#0a0a1acc;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);z-index:var(--z-header);display:flex;align-items:center;padding:0 var(--space-8);gap:var(--space-4);transition:left var(--transition-base)}[data-theme=light] .header{background:#f8fafccc}.header-search{flex:1;max-width:400px;position:relative}.header-search .search-icon{position:absolute;left:var(--space-3);top:50%;transform:translateY(-50%);color:var(--text-tertiary);width:16px;height:16px}.header-search input{width:100%;padding:var(--space-2) var(--space-4) var(--space-2) 36px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-full);color:var(--text-primary);font-size:var(--text-sm);outline:none;transition:all var(--transition-base)}.header-search input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.header-search .search-shortcut{position:absolute;right:var(--space-3);top:50%;transform:translateY(-50%);font-size:var(--text-xs);color:var(--text-tertiary);background:var(--bg-glass);padding:2px 6px;border-radius:var(--radius-sm);border:1px solid var(--border);font-family:var(--font-mono)}.header-actions{display:flex;align-items:center;gap:var(--space-2);margin-left:auto}.header-actions .action-btn{width:36px;height:36px;border-radius:var(--radius-md);border:none;background:transparent;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);position:relative}.header-actions .action-btn:hover{background:var(--bg-glass);color:var(--text-primary)}.header-actions .action-btn .notification-dot{position:absolute;top:6px;right:6px;width:8px;height:8px;background:var(--danger);border-radius:50%;border:2px solid var(--bg-primary)}.streak-display{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:#f59e0b1a;border:1px solid rgba(245,158,11,.2);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:600;color:var(--warning-light)}.streak-display .streak-flame{animation:flicker 1s ease-in-out infinite alternate}.page-header{margin-bottom:var(--space-8)}.page-header h1{font-size:var(--text-3xl);margin-bottom:var(--space-2)}.page-header .page-subtitle{font-size:var(--text-base);color:var(--text-secondary)}.page-header .page-actions{display:flex;gap:var(--space-3);margin-top:var(--space-4)}.grid{display:grid;gap:var(--space-6)}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.grid-auto{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.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)}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.text-center{text-align:center}.text-right{text-align:right}.text-primary-color{color:var(--primary-light)}.text-accent-color{color:var(--accent-light)}.text-warning-color{color:var(--warning-light)}.text-muted{color:var(--text-secondary)}.font-mono{font-family:var(--font-mono)}.font-heading{font-family:var(--font-heading)}.font-bold{font-weight:700}.font-semibold{font-weight:600}.progress-bar{height:6px;background:var(--bg-glass);border-radius:var(--radius-full);overflow:hidden;position:relative}.progress-bar .progress-fill{height:100%;border-radius:var(--radius-full);background:var(--gradient-primary);transition:width var(--transition-slow);position:relative}.progress-bar .progress-fill:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);animation:shimmer 2s infinite}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:var(--space-4);animation:fadeIn .2s ease-out}.modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-2xl);width:100%;max-width:560px;max-height:85vh;overflow-y:auto;animation:slideUp .3s var(--transition-spring)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-6);border-bottom:1px solid var(--border)}.modal-header h3{font-size:var(--text-xl)}.modal-body{padding:var(--space-6)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--border)}.toast-container{position:fixed;bottom:var(--space-6);right:var(--space-6);z-index:var(--z-toast);display:flex;flex-direction:column;gap:var(--space-3)}.toast{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);min-width:300px;animation:slideInRight .4s var(--transition-spring)}.toast.toast-success{border-left:3px solid var(--accent)}.toast.toast-error{border-left:3px solid var(--danger)}.toast.toast-warning{border-left:3px solid var(--warning)}.toast.toast-info{border-left:3px solid var(--secondary)}.tabs{display:flex;gap:var(--space-1);padding:var(--space-1);background:var(--bg-glass);border-radius:var(--radius-lg);border:1px solid var(--border);width:fit-content}.tab{padding:var(--space-2) var(--space-5);font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:none;background:none;font-family:var(--font-body)}.tab:hover{color:var(--text-primary)}.tab.active{background:var(--primary);color:#fff;box-shadow:var(--shadow-sm)}.flashcard-container{perspective:1000px;width:100%;max-width:500px;height:320px;margin:0 auto}.flashcard{width:100%;height:100%;position:relative;transform-style:preserve-3d;transition:transform .6s cubic-bezier(.4,0,.2,1);cursor:pointer}.flashcard.flipped{transform:rotateY(180deg)}.flashcard-front,.flashcard-back{position:absolute;top:0;right:0;bottom:0;left:0;backface-visibility:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-8);border-radius:var(--radius-2xl);text-align:center;border:1px solid var(--border)}.flashcard-front{background:var(--gradient-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.flashcard-back{background:linear-gradient(135deg,#10b9811a,#06b6d40d);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);transform:rotateY(180deg)}.timer-ring{position:relative;display:flex;align-items:center;justify-content:center}.timer-ring svg{transform:rotate(-90deg)}.timer-ring .timer-circle-bg{fill:none;stroke:var(--bg-glass);stroke-width:6}.timer-ring .timer-circle-progress{fill:none;stroke:url(#timer-gradient);stroke-width:6;stroke-linecap:round;transition:stroke-dashoffset 1s linear}.timer-ring .timer-display{position:absolute;text-align:center}.timer-ring .timer-display .timer-time{font-family:var(--font-heading);font-size:var(--text-4xl);font-weight:700;color:var(--text-primary);letter-spacing:.02em}.timer-ring .timer-display .timer-label{font-size:var(--text-sm);color:var(--text-secondary);margin-top:var(--space-1)}.knowledge-graph{width:100%;height:500px;background:var(--bg-card);border-radius:var(--radius-xl);border:1px solid var(--border);position:relative;overflow:hidden}.knowledge-graph canvas{width:100%;height:100%}.chat-container{display:flex;flex-direction:column;height:calc(100vh - var(--header-height) - 120px);background:var(--bg-card);border-radius:var(--radius-xl);border:1px solid var(--border);overflow:hidden}.chat-messages{flex:1;overflow-y:auto;padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-4)}.chat-message{display:flex;gap:var(--space-3);max-width:80%;animation:fadeIn .3s ease-out}.chat-message.user{align-self:flex-end;flex-direction:row-reverse}.chat-message .message-avatar{width:32px;height:32px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:var(--text-sm);flex-shrink:0}.chat-message.ai .message-avatar{background:var(--gradient-primary);color:#fff}.chat-message.user .message-avatar{background:var(--accent);color:#fff}.chat-message .message-content{padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);font-size:var(--text-sm);line-height:1.6}.chat-message.ai .message-content{background:var(--bg-glass);border:1px solid var(--border);color:var(--text-primary)}.chat-message.user .message-content{background:var(--primary);color:#fff}.chat-input-area{padding:var(--space-4);border-top:1px solid var(--border);display:flex;gap:var(--space-3)}.chat-input-area input{flex:1}.heatmap-grid{display:grid;grid-template-columns:repeat(52,1fr);gap:3px}.heatmap-cell{width:12px;height:12px;border-radius:2px;background:var(--bg-glass);transition:all var(--transition-fast);cursor:pointer}.heatmap-cell:hover{transform:scale(1.5);box-shadow:var(--shadow-sm)}.heatmap-cell.level-1{background:#7c3aed33}.heatmap-cell.level-2{background:#7c3aed66}.heatmap-cell.level-3{background:#7c3aed99}.heatmap-cell.level-4{background:#7c3aedcc}.xp-bar-container{padding:var(--space-3);background:var(--bg-glass);border-radius:var(--radius-lg);border:1px solid var(--border)}.xp-bar{height:8px;background:#7c3aed33;border-radius:var(--radius-full);overflow:hidden}.xp-bar .xp-fill{height:100%;background:var(--gradient-primary);border-radius:var(--radius-full);transition:width var(--transition-slow);position:relative}.xp-bar .xp-fill:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s infinite}.xp-info{display:flex;justify-content:space-between;font-size:var(--text-xs);color:var(--text-secondary);margin-top:var(--space-2)}.empty-state{text-align:center;padding:var(--space-16) var(--space-8);color:var(--text-secondary)}.empty-state .empty-icon{font-size:3rem;margin-bottom:var(--space-4);opacity:.5}.empty-state h3{margin-bottom:var(--space-2);color:var(--text-primary)}.empty-state p{margin-bottom:var(--space-6);max-width:400px;margin-left:auto;margin-right:auto}.skeleton{background:linear-gradient(90deg,var(--bg-glass) 25%,var(--bg-glass-strong) 50%,var(--bg-glass) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-md)}.tooltip{position:relative}.tooltip:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%);padding:var(--space-2) var(--space-3);background:var(--bg-secondary);color:var(--text-primary);font-size:var(--text-xs);border-radius:var(--radius-sm);border:1px solid var(--border);white-space:nowrap;opacity:0;pointer-events:none;transition:all var(--transition-fast);margin-bottom:4px}.tooltip:hover:after{opacity:1}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(100px)}to{opacity:1;transform:translate(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-100px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes flicker{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes glow{0%,to{box-shadow:0 0 5px var(--primary-glow)}50%{box-shadow:0 0 20px var(--primary-glow),0 0 40px #7c3aed1a}}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{opacity:1;transform:scale(1.05)}70%{transform:scale(.95)}to{transform:scale(1)}}@keyframes countUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes ripple{0%{transform:scale(0);opacity:.5}to{transform:scale(4);opacity:0}}@keyframes typingDots{0%,60%,to{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-5px)}}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@media (max-width: 1024px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}.page-content{padding:var(--space-6);padding-top:calc(var(--header-height) + var(--space-6))}}@media (max-width: 768px){.sidebar{transform:translate(-100%);width:280px}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.header{left:0;padding:0 var(--space-4)}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.page-content{padding:var(--space-4);padding-top:calc(var(--header-height) + var(--space-4))}.flashcard-container{height:260px}.chat-message{max-width:90%}}@media (max-width: 480px){.page-header h1,.stat-card .stat-value{font-size:var(--text-2xl)}.header-search{display:none}}.particles{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;overflow:hidden}.particle{position:absolute;width:2px;height:2px;background:var(--primary);border-radius:50%;opacity:.3;animation:float 6s ease-in-out infinite}.typing-indicator{display:flex;gap:4px;padding:var(--space-3) var(--space-4)}.typing-indicator span{width:8px;height:8px;border-radius:50%;background:var(--text-tertiary);animation:typingDots 1.4s ease-in-out infinite}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}.subject-math{--subject-color: #7c3aed}.subject-science{--subject-color: #06b6d4}.subject-english{--subject-color: #10b981}.subject-history{--subject-color: #f59e0b}.subject-cs{--subject-color: #ec4899}.subject-physics{--subject-color: #f97316}.subject-chemistry{--subject-color: #8b5cf6}.subject-biology{--subject-color: #14b8a6}.welcome-banner{background:var(--gradient-card);border:1px solid var(--border);border-radius:var(--radius-2xl);padding:var(--space-8);position:relative;overflow:hidden}.welcome-banner:before{content:"";position:absolute;top:-50%;right:-20%;width:400px;height:400px;background:radial-gradient(circle,rgba(124,58,237,.15) 0%,transparent 70%);border-radius:50%}.welcome-banner:after{content:"";position:absolute;bottom:-30%;left:-10%;width:300px;height:300px;background:radial-gradient(circle,rgba(6,182,212,.1) 0%,transparent 70%);border-radius:50%}.welcome-banner .welcome-content{position:relative;z-index:1}.quick-actions{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:var(--space-3)}.quick-action-btn{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-5) var(--space-4);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-base);font-family:var(--font-body);font-size:var(--text-sm)}.quick-action-btn:hover{background:var(--bg-card-hover);color:var(--text-primary);transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--border-light)}.quick-action-btn .action-icon{width:40px;height:40px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center}.activity-feed{display:flex;flex-direction:column;gap:var(--space-3)}.activity-item{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-md);transition:background var(--transition-fast)}.activity-item:hover{background:var(--bg-glass)}.activity-item .activity-dot{width:8px;height:8px;border-radius:50%;margin-top:6px;flex-shrink:0}.activity-item .activity-text{font-size:var(--text-sm);color:var(--text-secondary)}.activity-item .activity-time{font-size:var(--text-xs);color:var(--text-tertiary);margin-left:auto;white-space:nowrap}.note-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-5);cursor:pointer;transition:all var(--transition-base);position:relative}.note-card:hover{background:var(--bg-card-hover);transform:translateY(-2px);box-shadow:var(--shadow-md)}.note-card .note-color-bar{position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--radius-xl) var(--radius-xl) 0 0}.note-card .note-title{font-weight:600;font-size:var(--text-base);margin-bottom:var(--space-2);color:var(--text-primary)}.note-card .note-preview{font-size:var(--text-sm);color:var(--text-secondary);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:var(--space-3)}.note-card .note-meta{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs);color:var(--text-tertiary)}.settings-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-6);margin-bottom:var(--space-6)}.settings-section h3{font-size:var(--text-lg);margin-bottom:var(--space-4);padding-bottom:var(--space-4);border-bottom:1px solid var(--border)}.setting-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) 0;border-bottom:1px solid var(--border)}.setting-row:last-child{border-bottom:none}.setting-info{flex:1}.setting-info .setting-label{font-weight:500;color:var(--text-primary);margin-bottom:var(--space-1)}.setting-info .setting-desc{font-size:var(--text-sm);color:var(--text-secondary)}.toggle{position:relative;width:44px;height:24px;flex-shrink:0}.toggle input{opacity:0;width:0;height:0}.toggle .toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--bg-glass-strong);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-base);border:1px solid var(--border)}.toggle .toggle-slider:before{content:"";position:absolute;height:18px;width:18px;left:2px;bottom:2px;background:#fff;border-radius:50%;transition:all var(--transition-base)}.toggle input:checked+.toggle-slider{background:var(--primary);border-color:var(--primary)}.toggle input:checked+.toggle-slider:before{transform:translate(20px)}.achievement-badge{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-4);text-align:center}.achievement-badge .badge-icon{width:64px;height:64px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:1.5rem;position:relative}.achievement-badge .badge-icon.unlocked{animation:glow 2s ease-in-out infinite}.achievement-badge .badge-icon.locked{filter:grayscale(1);opacity:.4}.achievement-badge .badge-name{font-size:var(--text-sm);font-weight:600;color:var(--text-primary)}.achievement-badge .badge-desc{font-size:var(--text-xs);color:var(--text-tertiary)}.page-enter{animation:fadeIn .3s ease-out,slideUp .3s ease-out}
