:root,[data-theme=light]{--bg-primary:#f5f5f7;--bg-secondary:#fff;--card-bg:#fff;--text-primary:#111827;--text-secondary:#6b7280;--accent:#7c3aed;--button-primary:#2563eb;--button-primary-hover:#1d4ed8;--border-color:#e5e7eb}[data-theme=dark]{--bg-primary:#121212;--bg-secondary:#1b1b1b;--card-bg:#202020;--text-primary:#f5f5f5;--text-secondary:#bdbdbd;--accent:#9b5cff;--button-primary:#7c3aed;--button-primary-hover:#6d28d9;--border-color:#333}[data-theme=sakura]{--bg-primary:#fedfe1;--bg-secondary:#fff1f3;--card-bg:#fff;--text-primary:#2a2a2a;--text-secondary:#666;--accent:#ff7aa2;--button-primary:#ff5c8a;--button-primary-hover:#ff4778;--border-color:#f5b7c8}[data-theme=peach]{--bg-primary:#ffe5cf;--bg-secondary:#fff1e6;--card-bg:#fff;--text-primary:#2a2a2a;--text-secondary:#555;--accent:#ffb38a;--button-primary:#ff9e6d;--button-primary-hover:#ff8c57;--border-color:#ffd6bd}[data-theme=lavender]{--bg-primary:#e8e0f7;--bg-secondary:#f6f2ff;--card-bg:#f6f2ff;--text-primary:#2d2438;--text-secondary:#7a669d;--accent:#9b7ede;--button-primary:#b497f0;--button-primary-hover:#8d6fe0;--border-color:#d9c8ff;--bg:#e8e0f7;--text:#2d2438;--text-h:#2d2438}[data-theme=sora]{--bg-primary:#d8ecf4;--bg-secondary:#f5fbfe;--card-bg:#f5fbfe;--text-primary:#1e2f3a;--text-secondary:#26708c;--accent:#6fafd1;--button-primary:#8ec5e6;--button-primary-hover:#5da8d4;--border-color:#b9ecfb;--bg:#d8ecf4;--text:#1e2f3a;--text-h:#1e2f3a}[data-theme=matcha]{--bg-primary:#e4f8ba;--bg-secondary:#f1ffd8;--card-bg:#fff;--text-primary:#243018;--text-secondary:#4b5a3d;--accent:#7fbf4d;--button-primary:#6ea83f;--button-primary-hover:#5f9336;--border-color:#cce7a2}[data-theme=butter]{--bg-primary:#fdfbd4;--bg-secondary:#fffde8;--card-bg:#fff;--text-primary:#2f2b1f;--text-secondary:#6d6650;--accent:#e0b84f;--button-primary:#d6aa37;--button-primary-hover:#bf952f;--border-color:#f0e4a0}[data-theme=amber]{--bg-primary:#1f1205;--bg-secondary:#2b1907;--card-bg:#321d08;--text-primary:#fff2d2;--text-secondary:#f3b45c;--accent:#ffb020;--button-primary:#ff9f0a;--button-primary-hover:#f97316;--border-color:#6b3d0c}:root{--color-danger:#ef4444;--font-family:"Inter", system-ui, -apple-system, sans-serif;--font-size-base:16px;--font-size-sm:.875rem;--font-size-lg:1.125rem;--font-size-xl:1.5rem;--border-radius:12px;--radius-sm:12px;--radius-md:18px;--radius-lg:24px;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--shadow-soft:0 20px 60px #00000014;--shadow-card:0 12px 32px #0000000f;--transition-speed:.18s}*{box-sizing:border-box;margin:0;padding:0}html,body{background-color:var(--bg-primary);color:var(--text-primary);font-family:var(--font-family);font-size:var(--font-size-base);-webkit-font-smoothing:antialiased;max-width:100vw;min-height:100vh;overflow-x:hidden}a{color:var(--accent);transition:color var(--transition-speed) ease;text-decoration:none}a:hover{color:var(--button-primary-hover)}button{cursor:pointer;font-family:var(--font-family);border-radius:var(--radius-md);transition:all var(--transition-speed) ease;border:none}.btn-primary{background-color:var(--button-primary);color:#fff;font-weight:600;font-size:var(--font-size-base);padding:.75rem 1.5rem}.btn-primary:hover{background-color:var(--button-primary-hover);box-shadow:var(--shadow-md)}.btn-secondary{color:var(--text-primary);border:1px solid var(--border-color);background-color:#0000;padding:.5rem 1rem;font-weight:500}.btn-secondary:hover{background-color:var(--bg-secondary)}input{background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);font-family:var(--font-family);font-size:var(--font-size-base);transition:all var(--transition-speed) ease;padding:1rem 1.25rem}input:focus{border-color:var(--button-primary);box-shadow:0 0 0 3px var(--bg-secondary);outline:none}.card{background-color:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:2.5rem}.error-text{color:var(--color-danger);font-size:var(--font-size-sm);margin-top:.5rem}.layout-login{justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.login-container{width:100%;max-width:400px}.login-header{text-align:center;margin-bottom:2rem}.login-logo{object-fit:contain;filter:drop-shadow(0 4px 12px #00000026);border-radius:20px;width:88px;height:88px;margin-bottom:1rem}@keyframes tokkiPremiumPulse{0%,to{filter:drop-shadow(0 8px 18px #9b7ede2e);transform:scale(1)}50%{filter:drop-shadow(0 12px 28px #9b7ede52);transform:scale(1.045)}}.tokki-logo-pulse{transform-origin:50%;will-change:transform, filter;animation:3s ease-in-out infinite tokkiPremiumPulse}@media (prefers-reduced-motion:reduce){.tokki-logo-pulse{animation:none}}.login-header h1{letter-spacing:-.02em;margin-bottom:.25rem;font-size:1.75rem;font-weight:700}.login-subtitle{color:var(--color-text-secondary);letter-spacing:.04em;opacity:.85;font-size:.95rem;font-weight:500}.login-header p{color:var(--color-text-secondary)}.login-card-premium{-webkit-backdrop-filter:blur(18px);border:1px solid var(--color-border);border-radius:20px;padding:2.5rem 2rem;box-shadow:0 8px 32px #0000001f,0 1px 3px #00000014}.form-group{margin-bottom:1.5rem}.form-group label{font-weight:500;font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:.5rem;display:block}.login-btn-wrapper{margin-top:2rem}.login-btn-wrapper button{width:100%}.layout-dashboard{flex-direction:column;min-height:100vh;display:flex}.navbar{background-color:var(--color-bg-surface);border-bottom:1px solid var(--color-border);z-index:10;background-color:color-mix(in srgb, var(--card-bg) 80%, transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid color-mix(in srgb, var(--border-color) 40%, transparent);justify-content:space-between;align-items:center;height:64px;padding:0 2rem;display:flex;position:sticky;top:0}.navbar-brand{font-weight:700;font-size:var(--font-size-lg);color:var(--color-text-primary)}.navbar-user{align-items:center;gap:1rem;display:flex}.user-name{color:var(--text-primary);margin-right:.5rem;font-weight:600}.navbar-profile-link{color:inherit;cursor:pointer;border-radius:999px;align-items:center;gap:.5rem;padding:.25rem .5rem;text-decoration:none;transition:all .2s;display:flex}.navbar-profile-link:hover{background:color-mix(in srgb, var(--accent) 10%, transparent)}.navbar-profile-link:hover .user-name{color:var(--accent)}.nav-pill{color:var(--text-secondary);font-weight:600;font-size:var(--font-size-sm);transition:all var(--transition-speed) ease;background-color:#0000;border-radius:999px;justify-content:center;align-items:center;padding:.5rem 1rem;display:inline-flex}.nav-pill:hover{background-color:color-mix(in srgb, var(--text-primary) 8%, transparent);color:var(--text-primary)}.nav-pill.active{background-color:var(--accent);color:#fff;box-shadow:0 4px 12px color-mix(in srgb, var(--accent) 30%, transparent)}.nav-pill-danger{color:var(--color-danger)}.nav-pill-danger:hover{background-color:color-mix(in srgb, var(--color-danger) 10%, transparent);color:var(--color-danger)}.main-content{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:2rem}.dashboard-header{margin-bottom:2rem}.dashboard-header h1{font-size:var(--font-size-xl);margin-bottom:.5rem}.dashboard-header p{color:var(--color-text-secondary)}.hidden{display:none!important}.dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-bottom:2rem;display:grid}.stat-item{border-bottom:1px solid var(--color-border);flex-direction:column;gap:.25rem;padding:1rem 0;display:flex}.stat-item:last-child{border-bottom:none}.stat-label{color:var(--color-text-secondary);font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.05em;font-weight:500}.stat-value{color:var(--color-text-primary);font-size:1.5rem;font-weight:700}.badge{font-size:var(--font-size-sm);background-color:var(--bg-secondary);color:var(--text-primary);border-radius:999px;padding:.35rem .85rem;font-weight:600;display:inline-block}.badge-warning{color:#fbbf24;background-color:#f59e0b33}.history-list{flex-direction:column;gap:1rem;display:flex}.history-item{background-color:var(--bg-secondary);border-radius:var(--radius-md);transition:all var(--transition-speed) ease;border:1px solid #0000;justify-content:space-between;align-items:center;padding:1.25rem;display:flex}.history-item:hover{border-color:var(--border-color);background-color:var(--card-bg);box-shadow:var(--shadow-sm)}.history-item-left{flex-direction:column;display:flex}.history-title{font-weight:600}.history-date{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.history-score{font-size:1.125rem;font-weight:700}.loading-state{text-align:center;color:var(--color-text-secondary);font-size:var(--font-size-lg);padding:4rem}.exam-option{border:1px solid var(--border-color);cursor:pointer;transition:all var(--transition-speed) ease;background-color:var(--card-bg);border-radius:18px;align-items:center;margin-bottom:.75rem;padding:18px 22px;display:flex}.exam-option:hover:not([disabled]){border-color:var(--accent);background-color:color-mix(in srgb, var(--accent) 5%, var(--card-bg));box-shadow:var(--shadow-sm);transform:translateY(-1px)}.exam-option.selected{border-color:var(--accent);background-color:color-mix(in srgb, var(--accent) 10%, transparent);box-shadow:0 0 0 1px var(--accent)}.exam-option.selected .opt-bubble{background-color:var(--accent);color:#fff}.opt-bubble{background-color:var(--bg-secondary);width:32px;height:32px;color:var(--text-primary);transition:all var(--transition-speed) ease;border:1px solid var(--border-color);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-right:1rem;font-weight:700;display:flex}.opt-text{color:var(--text-primary);font-size:1rem;line-height:1.5}.premium-topbar{z-index:50;background-color:color-mix(in srgb, var(--bg-primary) 80%, transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid color-mix(in srgb, var(--border-color) 40%, transparent);justify-content:space-between;align-items:center;padding:1rem 2rem;display:flex;position:sticky;top:0}.premium-topbar-left{flex-direction:column;display:flex}.premium-topbar-title{font-size:var(--font-size-lg);color:var(--text-primary);margin:0;font-weight:700}.premium-topbar-subtitle{font-size:var(--font-size-sm);color:var(--text-secondary)}.premium-topbar-right{align-items:center;gap:1rem;display:flex}.table-responsive{width:100%;overflow-x:auto}.data-table{border-collapse:collapse;text-align:left;width:100%}.data-table th,.data-table td{border-bottom:1px solid var(--color-border);padding:1rem}.data-table th{color:var(--color-text-secondary);text-transform:uppercase;font-weight:600;font-size:var(--font-size-sm);letter-spacing:.05em;background-color:var(--color-bg-base)}.data-table tr:hover{background-color:#ffffff05}.data-table td{color:var(--color-text-primary);vertical-align:middle}.filters-bar{flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;display:flex}.filters-bar select,.filters-bar input{border-radius:var(--border-radius);border:1px solid var(--color-border);background-color:var(--color-bg-base);color:var(--color-text-primary);padding:.5rem}.search-bar-container{margin-bottom:1.25rem}.search-bar-pill{background:color-mix(in srgb, var(--card-bg) 70%, transparent);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-color);transition:all var(--transition-speed) ease;border-radius:9999px;align-items:center;gap:.75rem;padding:.6rem 1.25rem;display:flex;box-shadow:0 2px 8px #0000000f}.search-bar-pill:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 15%, transparent), 0 4px 16px #0000001a}.search-bar-icon{opacity:.5;transition:opacity var(--transition-speed) ease;flex-shrink:0;font-size:1rem}.search-bar-pill:focus-within .search-bar-icon{opacity:1}.search-bar-input{color:var(--text-primary);font-size:.95rem;font-family:var(--font-family);background:0 0;border:none;outline:none;flex:1;min-width:0}.search-bar-input::placeholder{color:var(--text-secondary);opacity:.6}.search-bar-clear{background:color-mix(in srgb, var(--text-secondary) 15%, transparent);width:28px;height:28px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-speed) ease;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.75rem;line-height:1;display:flex}.search-bar-clear:hover{background:color-mix(in srgb, var(--color-danger) 20%, transparent);color:var(--color-danger);transform:scale(1.1)}.search-result-count{font-size:var(--font-size-sm);color:var(--text-secondary);margin-top:.5rem;padding-left:1.25rem;font-weight:500;animation:.2s fadeIn}.training-section{margin-bottom:2rem}.training-cats-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.5rem;margin-bottom:1.5rem;display:grid}.training-category-title{font-size:2rem}.training-mode-card{padding:2rem}.question-media-wrapper{border:1px solid var(--border-color);background:var(--bg-secondary);border-radius:18px;width:100%;max-height:420px;margin-bottom:24px;position:relative;overflow:hidden}.question-media-skeleton{background:linear-gradient(110deg, var(--bg-secondary) 0%, color-mix(in srgb, var(--border-color) 30%, var(--bg-secondary)) 40%, var(--bg-secondary) 60%);z-index:1;background-size:200% 100%;border-radius:18px;transition:opacity .35s;animation:1.6s ease-in-out infinite skeletonShimmer;position:absolute;inset:0}.question-media-skeleton.loaded{opacity:0;pointer-events:none}@keyframes skeletonShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-line{background:linear-gradient(110deg, var(--bg-secondary) 0%, color-mix(in srgb, var(--border-color) 30%, var(--bg-secondary)) 40%, var(--bg-secondary) 60%);border-radius:var(--radius-md,8px);background-size:200% 100%;min-height:1rem;animation:1.6s ease-in-out infinite skeletonShimmer}.skeleton-circle{background:linear-gradient(110deg, var(--bg-secondary) 0%, color-mix(in srgb, var(--border-color) 30%, var(--bg-secondary)) 40%, var(--bg-secondary) 60%);background-size:200% 100%;border-radius:50%;animation:1.6s ease-in-out infinite skeletonShimmer}.question-media{object-fit:contain;background:var(--bg-secondary);opacity:0;border-radius:18px;width:100%;max-height:420px;transition:opacity .4s;display:block}.question-media.loaded{opacity:1}.question-media.error,.question-media-wrapper.media-error{display:none}.training-cat-card{border:1px solid var(--border-color);cursor:pointer;min-height:180px;transition:all var(--transition-speed) ease;background-color:var(--card-bg);box-shadow:var(--shadow-sm);border-radius:26px;flex-direction:column;padding:28px;display:flex}.training-cat-card:hover{border-color:var(--accent);box-shadow:var(--shadow-card);transform:translateY(-2px)}.training-cat-card.selected{border-color:var(--accent);background-color:var(--bg-secondary);box-shadow:0 0 0 3px var(--border-color)}.training-cat-name{font-weight:700;font-size:var(--font-size-lg);color:var(--text-primary);margin-bottom:.25rem}.training-cat-count{font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:1rem}.premium-cta-pill{background-color:color-mix(in srgb, var(--accent) 15%, transparent);color:var(--accent);font-weight:600;font-size:var(--font-size-sm);transition:all var(--transition-speed) ease;border-radius:9999px;justify-content:center;align-self:flex-start;align-items:center;margin-top:auto;padding:.6rem 1.25rem;display:inline-flex}.training-cat-card:hover .premium-cta-pill{background-color:var(--accent);color:#fff;box-shadow:0 4px 12px color-mix(in srgb, var(--accent) 30%, transparent)}.training-controls{border-top:1px solid var(--color-border);padding-top:1.5rem}.training-mode-selector{grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1.25rem;display:grid}.training-mode-option{border:2px solid var(--color-border);border-radius:var(--border-radius);cursor:pointer;transition:all var(--transition-speed) ease;text-align:center;background-color:#0000;flex-direction:column;align-items:center;padding:1rem;display:flex}.training-mode-option:hover{border-color:var(--color-brand-primary-hover)}.training-mode-option.selected{border-color:var(--color-brand-primary);background-color:#3b82f61a}.training-mode-icon{margin-bottom:.25rem;font-size:1.75rem}.training-mode-label{font-weight:700;font-size:var(--font-size-base);color:var(--color-text-primary)}.training-mode-desc{color:var(--color-text-secondary);margin-top:.25rem;font-size:.75rem}.training-count-row{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.training-count-row input[type=number]{text-align:center;width:80px}.training-layout{background-color:var(--color-bg-base);flex-direction:column;min-height:100vh;display:flex}.training-header{background-color:var(--color-bg-surface);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:1rem 2rem;display:flex}.training-progress{background-color:var(--card-bg);border-bottom:1px solid var(--border-color);font-size:var(--font-size-sm);flex-wrap:wrap;gap:1.5rem;padding:1rem 2rem;font-weight:600;display:flex}.tp-item{color:var(--color-text-secondary)}.tp-mastered{color:#34d399}.tp-pending{color:#fbbf24}.tp-errors{color:#ef4444}.training-main{flex:1;width:100%;max-width:800px;margin:0 auto;padding:2rem 1rem}.training-options{flex-direction:column;gap:1rem;display:flex}.training-complete-icon{margin-bottom:1rem;font-size:3.5rem}.training-stats-grid{grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1rem;display:grid}.training-stat{text-align:center}.training-stat-value{color:var(--color-text-primary);font-size:1.75rem;font-weight:700}.training-stat-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:.25rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.theme-toggle-pill{background-color:color-mix(in srgb, var(--accent) 10%, transparent);color:var(--accent);border:1px solid color-mix(in srgb, var(--accent) 50%, transparent);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-speed) ease;border-radius:9999px;justify-content:center;align-items:center;padding:.5rem 1rem;font-weight:600;display:flex}.theme-toggle-pill:hover{border-color:var(--accent);background-color:color-mix(in srgb, var(--accent) 20%, transparent);box-shadow:0 4px 14px color-mix(in srgb, var(--accent) 25%, transparent)}.theme-toggle-fixed{z-index:100;position:fixed;top:1.5rem;right:1.5rem}.navbar-avatar{object-fit:cover;border:2px solid color-mix(in srgb, var(--accent) 40%, transparent);border-radius:50%;flex-shrink:0;width:36px;height:36px;transition:box-shadow .2s,transform .2s}.navbar-avatar:hover{box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 20%, transparent);transform:scale(1.05)}.navbar-avatar--initials{background:linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent) 60%, #ff8c42));color:#fff;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;font-size:.9rem;font-weight:700;display:inline-flex}.avatar-modal-overlay{z-index:200;-webkit-backdrop-filter:blur(8px);background:#00000073;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.avatar-modal-card{background:var(--card-bg,#fff);text-align:center;border-radius:24px;width:90%;max-width:380px;padding:2rem 2.25rem;animation:.3s slideUp;box-shadow:0 24px 48px #0003}.avatar-modal-card h2{color:var(--text-primary);margin:0 0 .25rem;font-size:1.25rem;font-weight:700}.avatar-modal-card .subtitle{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.85rem}.avatar-preview-circle{object-fit:cover;border:3px solid color-mix(in srgb, var(--accent) 40%, transparent);background:color-mix(in srgb, var(--accent) 8%, transparent);border-radius:50%;width:128px;height:128px;margin:0 auto 1.25rem;display:block}.avatar-preview-initials{color:#fff;background:linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent) 60%, #ff8c42));border:3px solid color-mix(in srgb, var(--accent) 40%, transparent);border-radius:50%;justify-content:center;align-items:center;width:128px;height:128px;margin:0 auto 1.25rem;font-size:3rem;font-weight:800;display:flex}.avatar-file-label{cursor:pointer;background:color-mix(in srgb, var(--accent) 12%, transparent);color:var(--accent);border:1px solid color-mix(in srgb, var(--accent) 30%, transparent);border-radius:12px;align-items:center;gap:.5rem;padding:.6rem 1.25rem;font-size:.85rem;font-weight:600;transition:all .2s;display:inline-flex}.avatar-file-label:hover{background:color-mix(in srgb, var(--accent) 20%, transparent);transform:translateY(-1px)}.avatar-modal-actions{justify-content:center;gap:.75rem;margin-top:1.5rem;display:flex}.avatar-modal-actions button{cursor:pointer;border:none;border-radius:12px;padding:.55rem 1.25rem;font-size:.85rem;font-weight:600;transition:all .2s}.avatar-btn-cancel{background:color-mix(in srgb, var(--text-secondary) 10%, transparent);color:var(--text-secondary)}.avatar-btn-cancel:hover{background:color-mix(in srgb, var(--text-secondary) 18%, transparent)}.avatar-btn-remove{color:#ef4444;background:#ef44441f}.avatar-btn-remove:hover{background:#ef444438}.avatar-btn-save{background:var(--accent);color:#fff}.avatar-btn-save:hover{filter:brightness(1.1);transform:translateY(-1px)}.avatar-btn-save:disabled{opacity:.5;cursor:not-allowed;transform:none}.avatar-error{color:#ef4444;min-height:1.2em;margin-top:.5rem;font-size:.8rem}.dashboard-avatar-wrapper{cursor:pointer;display:inline-block;position:relative}.dashboard-avatar{object-fit:cover;border:3px solid color-mix(in srgb, var(--accent) 30%, transparent);border-radius:50%;width:64px;height:64px;transition:box-shadow .2s}.dashboard-avatar-wrapper:hover .dashboard-avatar{box-shadow:0 0 0 4px color-mix(in srgb, var(--accent) 15%, transparent)}.dashboard-avatar-initials{color:#fff;background:linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent) 60%, #ff8c42));border:3px solid color-mix(in srgb, var(--accent) 30%, transparent);border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;font-size:1.5rem;font-weight:800;transition:box-shadow .2s;display:flex}.dashboard-avatar-edit-badge{background:var(--accent);color:#fff;border:2px solid var(--card-bg,#fff);border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:.7rem;display:flex;position:absolute;bottom:-2px;right:-2px;box-shadow:0 2px 6px #0003}.music-card{border-radius:16px;flex-direction:column;gap:.75rem;margin-bottom:.75rem;padding:1.25rem 1.5rem;transition:box-shadow .2s,transform .15s;display:flex}.music-card:hover{transform:translateY(-1px);box-shadow:0 6px 20px #00000014}.music-card-header{align-items:center;gap:1rem;display:flex}.music-card-platform{flex-shrink:0}.music-icon{border-radius:12px;justify-content:center;align-items:center;width:42px;height:42px;font-size:1.1rem;font-weight:700;display:inline-flex}.music-icon--spotify{color:#fff;background:linear-gradient(135deg,#1db954,#1aa34a)}.music-icon--youtube{color:#fff;background:linear-gradient(135deg,red,#c00)}.music-icon--other{background:linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent) 70%, #6366f1));color:#fff}.music-card-info{flex:1;min-width:0}.music-card-title{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;margin-bottom:.25rem;font-size:.95rem;font-weight:700;overflow:hidden}.music-card-meta{color:var(--text-secondary);align-items:center;gap:.4rem;font-size:.78rem;display:flex}.music-card-badge{background:color-mix(in srgb, var(--text-secondary) 10%, transparent);border-radius:6px;padding:.1rem .5rem;font-size:.7rem;font-weight:600}.music-avatar-mini{background:linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent) 60%, #ff8c42));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:.6rem;font-weight:700;display:inline-flex}.music-card-actions{border-top:1px solid color-mix(in srgb, var(--border-color) 50%, transparent);align-items:center;gap:.5rem;padding-top:.5rem;display:flex}.music-like-btn{border:1px solid color-mix(in srgb, var(--border-color) 60%, transparent);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:10px;align-items:center;gap:.35rem;padding:.35rem .75rem;font-size:.82rem;font-weight:600;transition:all .2s;display:inline-flex}.music-like-btn:hover{color:#ef4444;background:#ef444414;border-color:#ef44444d}.music-like-btn--active{color:#ef4444;background:#ef44441a;border-color:#ef44444d}.music-open-btn{background:color-mix(in srgb, var(--accent) 10%, transparent);color:var(--accent);border:1px solid color-mix(in srgb, var(--accent) 25%, transparent);border-radius:10px;align-items:center;padding:.35rem .85rem;font-size:.82rem;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}.music-open-btn:hover{background:color-mix(in srgb, var(--accent) 18%, transparent);transform:translateY(-1px)}.music-delete-btn{color:var(--text-secondary);cursor:pointer;opacity:.5;background:0 0;border:none;border-radius:8px;margin-left:auto;padding:.3rem .6rem;font-size:.85rem;transition:all .2s}.music-delete-btn:hover{color:#ef4444;opacity:1;background:#ef44441f}.notif-bell-wrapper{display:inline-flex;position:relative}.notif-bell-btn{cursor:pointer;background:0 0;border:none;border-radius:10px;padding:.4rem;font-size:1.2rem;line-height:1;transition:background .2s,transform .15s;position:relative}.notif-bell-btn:hover{background:color-mix(in srgb, var(--text-secondary) 10%, transparent);transform:scale(1.08)}.notif-badge{color:#fff;border:2px solid var(--bg-primary,#fff);background:#ef4444;border-radius:9px;justify-content:center;align-items:center;min-width:17px;height:17px;padding:0 4px;font-size:.6rem;font-weight:800;animation:.3s notifPop;display:flex;position:absolute;top:0;right:-2px}@keyframes notifPop{0%{transform:scale(0)}50%{transform:scale(1.3)}to{transform:scale(1)}}.notif-dropdown{background:var(--card-bg,#fff);border:1px solid var(--border-color);z-index:1000;border-radius:16px;width:340px;max-height:420px;animation:.2s notifSlideIn;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 12px 40px #0000001f}@keyframes notifSlideIn{0%{opacity:0;transform:translateY(-8px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.notif-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:.85rem 1rem;display:flex}.notif-header-title{color:var(--text-primary);font-size:.9rem;font-weight:700}.notif-read-all-btn{color:var(--accent);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:.25rem .5rem;font-size:.75rem;font-weight:600;transition:background .15s}.notif-read-all-btn:hover{background:color-mix(in srgb, var(--accent) 10%, transparent)}.notif-list{max-height:340px;overflow-y:auto}.notif-list::-webkit-scrollbar{width:4px}.notif-list::-webkit-scrollbar-thumb{background:color-mix(in srgb, var(--text-secondary) 25%, transparent);border-radius:2px}.notif-item{border-bottom:1px solid color-mix(in srgb, var(--border-color) 40%, transparent);cursor:pointer;gap:.7rem;padding:.75rem 1rem;transition:background .15s;display:flex}.notif-item:hover{background:color-mix(in srgb, var(--text-secondary) 5%, transparent)}.notif-item:last-child{border-bottom:none}.notif-item--unread{background:color-mix(in srgb, var(--accent) 6%, transparent);border-left:3px solid var(--accent)}.notif-item--unread:hover{background:color-mix(in srgb, var(--accent) 10%, transparent)}.notif-item-icon{background:color-mix(in srgb, var(--accent) 8%, transparent);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.2rem;display:flex}.notif-item-content{flex:1;min-width:0}.notif-item-title{color:var(--text-primary);margin-bottom:.15rem;font-size:.82rem;font-weight:600}.notif-item-msg{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:.75rem;overflow:hidden}.notif-item-time{color:color-mix(in srgb, var(--text-secondary) 60%, transparent);margin-top:.2rem;font-size:.65rem}.notif-empty{text-align:center;color:var(--text-secondary);padding:2rem 1rem;font-size:.85rem}.notif-empty p{margin-top:.5rem}.music-card .music-comment-composer{border:1px solid var(--border-color)!important;background:var(--card-bg)!important;box-shadow:var(--shadow-card)!important;border-radius:999px!important;align-items:center!important;gap:10px!important;margin-top:14px!important;padding:8px!important;display:flex!important}.music-card .music-comment-input{resize:none!important;min-height:38px!important;color:var(--text-primary)!important;font:inherit!important;background:0 0!important;border:0!important;outline:none!important;flex:1!important;padding:10px 14px!important;line-height:1.3!important}.music-card .music-comment-submit{background:var(--button-primary)!important;color:#fff!important;cursor:pointer!important;white-space:nowrap!important;border:0!important;border-radius:999px!important;padding:10px 18px!important;font-weight:800!important}.music-card .music-comment-avatar,.music-card .music-comment-avatar img{object-fit:cover!important;border-radius:50%!important;width:34px!important;min-width:34px!important;max-width:34px!important;height:34px!important;max-height:34px!important;overflow:hidden!important}.music-card .music-comment-item{align-items:flex-start!important;gap:10px!important;margin-top:12px!important;display:flex!important}.music-comments-list{flex-direction:column;gap:.75rem;max-height:300px;margin-bottom:1rem;padding-right:.5rem;display:flex;overflow-y:auto}.music-comments-list::-webkit-scrollbar{width:4px}.music-comments-list::-webkit-scrollbar-track{background:0 0}.music-comments-list::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.music-comment-content{flex:1}.music-comment-meta{align-items:center;gap:.5rem;margin-bottom:.25rem;display:flex}.music-comment-meta strong{color:var(--text-primary);font-weight:600}.music-comment-meta span{color:var(--text-secondary);font-size:12px}.music-comment-content p{color:var(--text-primary);white-space:pre-wrap;word-break:break-word;margin:0;line-height:1.4}.music-comment-actions{text-align:right;margin-top:.25rem}.music-comment-delete{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:0;font-size:12px}.music-comment-delete:hover{color:var(--color-danger);text-decoration:underline}@keyframes highlightComment{0%{background-color:#aa3bff1a}to{background-color:#0000}}.music-comment-highlight{border-radius:8px;animation:3s ease-out forwards highlightComment}.music-toggle-comments{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;gap:.25rem;padding:.25rem .5rem;font-size:14px;transition:background .2s;display:flex}.music-toggle-comments:hover{background:var(--bg-secondary);color:var(--text-primary)}.premium-topbar{background:color-mix(in srgb, var(--card-bg,#fff) 85%, transparent);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border-color,var(--border));z-index:50;grid-template-columns:1fr auto 1fr;align-items:center;min-height:86px;margin-bottom:1.5rem;padding:0 28px;display:grid;position:sticky;top:0}.premium-topbar-left{align-items:center;gap:1rem;display:flex}.premium-topbar-center{justify-content:center;align-items:center;display:flex}.premium-topbar-title{font-family:var(--heading);color:var(--text-h);margin:0;font-size:1.15rem;font-weight:700}.premium-topbar-subtitle{background:var(--accent-bg);color:var(--accent);text-transform:uppercase;letter-spacing:.5px;border-radius:999px;padding:.35rem .85rem;font-size:.75rem;font-weight:700}.premium-topbar-right{justify-content:flex-end;align-items:center;gap:1rem;display:flex}.premium-cta-pill{color:var(--text-secondary);border:1px solid var(--border-color,var(--border));cursor:pointer;background:0 0;border-radius:999px;padding:.4rem 1.2rem;font-size:.85rem;font-weight:600;text-decoration:none;transition:all .2s}.premium-cta-pill:hover{background:var(--code-bg);color:var(--text-h);border-color:var(--text-secondary)}.stats-pill-container{flex-wrap:nowrap;justify-content:center;gap:8px;margin-bottom:0;padding:0;display:flex}.stat-pill{background:var(--code-bg);color:var(--text-h);border:1px solid #0000;border-radius:999px;align-items:center;gap:.4rem;padding:.4rem 1rem;font-size:.9rem;font-weight:600;transition:transform .2s,box-shadow .2s;display:inline-flex;box-shadow:0 1px 2px #0000000d}.stat-pill:hover{transform:translateY(-2px);box-shadow:0 4px 6px #0000000d}.stat-pill.stat-correct{color:#10b981;background:#34d3991a;border-color:#34d39933}.stat-pill.stat-error{color:#ef4444;background:#ef44441a;border-color:#ef444433}.stat-pill.stat-warning{color:#f59e0b;background:#f59e0b1a;border-color:#f59e0b33}.premium-question-card{background:var(--card-bg,var(--bg));border:1px solid var(--border-color,var(--border));border-radius:20px;max-width:760px;margin:0 auto 2rem;padding:2.5rem;animation:.4s cubic-bezier(.16,1,.3,1) forwards slideFadeIn;box-shadow:0 12px 36px #0000000f,0 2px 8px #00000008}@keyframes slideFadeIn{0%{opacity:0;transform:translateY(12px)scale(.99)}to{opacity:1;transform:translateY(0)scale(1)}}.premium-question-text{font-family:var(--heading);color:var(--text-h);max-width:100%;margin-bottom:2rem;font-size:1.35rem;font-weight:700;line-height:1.5}@media (width<=800px){.premium-topbar{flex-direction:column;gap:1rem;min-height:auto;padding:1rem;display:flex}.premium-topbar-left,.premium-topbar-right{justify-content:center;width:100%}.stats-pill-container{flex-wrap:wrap;gap:.5rem}.stat-pill{padding:.3rem .8rem;font-size:.85rem}.premium-question-card{box-sizing:border-box;border-radius:16px;width:100%;margin:0 auto 2rem;padding:1.5rem}.premium-question-text{font-size:1.15rem}}.streak-widget-hero{background:var(--card-bg,#fff);border:1px solid var(--border-color,var(--border));border-radius:20px;flex:1;align-items:center;gap:1.5rem;min-width:300px;max-width:450px;padding:1.5rem 2rem;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 4px 20px #0000000f,0 1px 3px #00000005}.streak-widget-hero:hover{transform:translateY(-2px);box-shadow:0 8px 30px #00000014}.streak-hero-left{flex-shrink:0}.streak-heart-hero{justify-content:center;align-items:center;width:72px;height:72px;display:flex}.streak-hero-right{flex-direction:column;justify-content:center;display:flex}.streak-hero-days{font-family:var(--heading);color:var(--text-h);margin:0 0 .25rem;font-size:1.75rem;font-weight:800;line-height:1.1}.streak-hero-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.2rem;font-size:.85rem;font-weight:700;display:block}.streak-hero-subtext{color:var(--text-secondary);margin:0;font-size:.85rem}@media (width<=600px){.dashboard-hero-layout{flex-direction:column!important;align-items:stretch!important}.streak-widget-hero{gap:1rem;max-width:100%;padding:1.25rem}.streak-hero-days{font-size:1.5rem}.streak-heart-hero{width:64px;height:64px}}.training-brain-icon{object-fit:contain;opacity:.85;width:22px;height:auto;display:block}.report-question-btn{color:var(--text-secondary);cursor:pointer;opacity:.6;background:0 0;border:none;margin:1.25rem auto 0;padding:.5rem .75rem;font-size:.8rem;transition:opacity .2s,color .2s;display:block}.report-question-btn:hover{opacity:1;color:var(--accent,#7c3aed)}.report-modal-overlay{z-index:9999;background:#00000073;justify-content:center;align-items:center;padding:1rem;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.report-modal{background:var(--card-bg,#fff);border:1px solid var(--border-color,#e5e7eb);border-radius:16px;width:100%;max-width:460px;animation:.25s slideFadeIn;overflow:hidden;box-shadow:0 8px 32px #0000001f}.report-modal-header{border-bottom:1px solid var(--border-color,#e5e7eb);justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.report-modal-header h3{color:var(--text-h,#111);margin:0;font-size:1.1rem}.report-modal-close{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;padding:0;font-size:1.5rem;line-height:1}.report-modal-body{padding:1.25rem 1.5rem}.report-modal-label{color:var(--text-h,#111);margin-bottom:.5rem;font-size:.85rem;font-weight:600;display:block}.report-modal-select{border:1px solid var(--border-color,#e5e7eb);background:var(--bg-secondary,#f9fafb);width:100%;color:var(--text-primary,#111);appearance:auto;border-radius:10px;padding:.65rem .85rem;font-family:inherit;font-size:.9rem}.report-modal-select:focus{border-color:var(--accent,#7c3aed);outline:none}.report-modal-textarea{border:1px solid var(--border-color,#e5e7eb);background:var(--bg-secondary,#f9fafb);width:100%;color:var(--text-primary,#111);resize:vertical;box-sizing:border-box;border-radius:10px;min-height:60px;padding:.65rem .85rem;font-family:inherit;font-size:.9rem}.report-modal-textarea:focus{border-color:var(--accent,#7c3aed);outline:none}.report-modal-footer{justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem 1.25rem;display:flex}.report-modal-btn-cancel{border:1px solid var(--border-color,#e5e7eb);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:10px;padding:.55rem 1.25rem;font-family:inherit;font-size:.85rem;transition:background .15s}.report-modal-btn-cancel:hover{background:var(--bg-secondary,#f3f4f6)}.report-modal-btn-submit{background:var(--button-primary,#7c3aed);color:#fff;cursor:pointer;border:none;border-radius:10px;padding:.55rem 1.25rem;font-family:inherit;font-size:.85rem;font-weight:600;transition:background .15s}.report-modal-btn-submit:hover{background:var(--button-primary-hover,#6d28d9)}.report-modal-btn-submit:disabled{opacity:.6;cursor:not-allowed}.reports-filters{flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem;display:flex}.report-filter-select,.report-filter-input{border:1px solid var(--border-color,#e5e7eb);background:var(--card-bg,#fff);color:var(--text-primary,#111);border-radius:10px;min-width:180px;padding:.55rem .85rem;font-family:inherit;font-size:.85rem}.report-filter-input{flex:1;min-width:220px}.report-filter-select:focus,.report-filter-input:focus{border-color:var(--accent,#7c3aed);outline:none}.reports-table-container{border:1px solid var(--border-color,#e5e7eb);background:var(--card-bg,#fff);border-radius:12px;overflow-x:auto}.reports-table{border-collapse:collapse;width:100%;font-size:.85rem}.reports-table thead th{text-align:left;border-bottom:1px solid var(--border-color,#e5e7eb);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;padding:.85rem 1rem;font-size:.8rem;font-weight:600}.reports-table tbody td{border-bottom:1px solid var(--border-color,#e5e7eb);color:var(--text-primary);vertical-align:top;padding:.75rem 1rem}.reports-table tbody tr:last-child td{border-bottom:none}.report-status-badge{white-space:nowrap;border-radius:999px;padding:.2rem .6rem;font-size:.75rem;font-weight:600;display:inline-block}.report-actions-cell{gap:.35rem;display:flex}.report-action-btn{border:1px solid var(--border-color,#e5e7eb);cursor:pointer;background:0 0;border-radius:8px;padding:.3rem .45rem;font-size:.85rem;line-height:1;transition:background .15s}.report-action-btn:hover{background:var(--bg-secondary,#f3f4f6)}@media (width<=768px){.reports-filters{flex-direction:column}.report-filter-select,.report-filter-input{min-width:100%}}.report-section{margin-bottom:1.5rem}.report-section-title{margin-bottom:.75rem;padding:0;font-size:1rem;font-weight:600}.report-question-card{background:var(--card-bg,var(--color-bg-surface));border:1px solid var(--border-color,#e5e7eb);border-radius:12px;margin-bottom:.75rem;padding:1rem 1.25rem;transition:border-color .2s}.report-question-failed{border-left:3px solid #ef4444}.report-question-passed{border-left:3px solid #34d399}.report-q-body{color:var(--text-primary);margin-bottom:.6rem;font-size:.92rem;font-weight:500;line-height:1.5}.report-q-answers{flex-direction:column;gap:.3rem;margin-bottom:.5rem;display:flex}.report-answer-wrong{color:#ef4444;background:#ef444414;border-radius:6px;padding:.25rem .6rem;font-size:.82rem;display:inline-block}.report-answer-correct{color:#34d399;background:#34d39914;border-radius:6px;padding:.25rem .6rem;font-size:.82rem;display:inline-block}.report-q-explanation{color:var(--color-text-secondary);background:var(--bg-secondary,#00000008);border-radius:8px;margin-top:.4rem;padding:.5rem .75rem;font-size:.8rem;font-style:italic;line-height:1.45}details>summary{-webkit-user-select:none;user-select:none;list-style:none}details>summary::-webkit-details-marker{display:none}details>summary:after{content:" ▸";font-size:.8rem}details[open]>summary:after{content:" ▾"}@media (width<=640px){.report-q-answers{gap:.4rem}.report-question-card{padding:.85rem 1rem}}.form-label-row{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.form-label-row label{margin-bottom:0}.latex-insert-btn{border:1px solid color-mix(in srgb, var(--accent) 40%, transparent);background:color-mix(in srgb, var(--accent) 8%, transparent);color:var(--accent);cursor:pointer;transition:all var(--transition-speed) ease;white-space:nowrap;font-size:.75rem;font-weight:600;line-height:1;font-family:var(--font-family);border-radius:8px;justify-content:center;align-items:center;padding:.2rem .6rem;display:inline-flex}.latex-insert-btn:hover{background:color-mix(in srgb, var(--accent) 20%, transparent);border-color:var(--accent);box-shadow:0 2px 8px color-mix(in srgb, var(--accent) 20%, transparent);transform:translateY(-1px)}.latex-modal-overlay{z-index:300;-webkit-backdrop-filter:blur(8px);background:#00000080;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.latex-modal-card{background:var(--card-bg,#1a1a2e);border:1px solid var(--border-color);border-radius:24px;width:92%;max-width:480px;padding:1.75rem 2rem;animation:.3s slideUp;box-shadow:0 24px 48px #0000004d}.latex-modal-header{justify-content:space-between;align-items:center;margin-bottom:.25rem;display:flex}.latex-modal-title{color:var(--text-primary);margin:0;font-size:1.15rem;font-weight:700}.latex-modal-close-btn{background:color-mix(in srgb, var(--text-secondary) 12%, transparent);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-speed) ease;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:.85rem;display:flex}.latex-modal-close-btn:hover{background:color-mix(in srgb, var(--color-danger) 20%, transparent);color:var(--color-danger)}.latex-modal-subtitle{color:var(--text-secondary);margin-bottom:1.25rem;font-size:.85rem}.latex-symbols-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.5rem;margin-bottom:1.25rem;display:grid}.latex-symbol-btn{border:1px solid var(--border-color);background:var(--bg-secondary,#ffffff0a);cursor:pointer;transition:all var(--transition-speed) ease;border-radius:14px;flex-direction:column;justify-content:center;align-items:center;gap:.15rem;padding:.6rem .4rem;display:flex}.latex-symbol-btn:hover{border-color:var(--accent);background:color-mix(in srgb, var(--accent) 10%, transparent);box-shadow:0 4px 12px color-mix(in srgb, var(--accent) 15%, transparent);transform:translateY(-2px)}.latex-symbol-label{color:var(--text-primary);font-size:1.25rem;font-weight:700;line-height:1}.latex-symbol-desc{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;font-size:.6rem}.latex-modal-custom{margin-bottom:1rem}.latex-custom-label{font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:.4rem;font-weight:500;display:block}.latex-custom-row{gap:.5rem;display:flex}.latex-custom-input{border:1px solid var(--border-color);background:var(--bg-secondary,#ffffff0a);color:var(--text-primary);border-radius:10px;flex:1;padding:.5rem .75rem;font-family:Courier New,monospace;font-size:.85rem}.latex-custom-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb, var(--accent) 15%, transparent);outline:none}.latex-custom-btn{white-space:nowrap;border-radius:10px;padding:.5rem 1rem;font-size:.85rem}.latex-modal-preview-row{font-size:var(--font-size-sm);color:var(--text-secondary);border-top:1px solid color-mix(in srgb, var(--border-color) 40%, transparent);align-items:center;gap:.5rem;padding-top:.75rem;display:flex}.latex-preview-field{color:var(--accent);background:color-mix(in srgb, var(--accent) 8%, transparent);border-radius:6px;padding:.15rem .5rem;font-family:Courier New,monospace;font-size:.75rem}.katex{font-size:1.05em}.latex-error{color:var(--color-danger);background:color-mix(in srgb, var(--color-danger) 10%, transparent);border-radius:4px;padding:.1rem .3rem;font-size:.85em}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.generative-exam-banner{margin-bottom:2rem}.genexam-hero{border-radius:var(--radius-lg);text-align:center;background:color-mix(in srgb, var(--accent) 22%, #ffffff8c);-webkit-backdrop-filter:blur(18px);border:1px solid color-mix(in srgb, var(--accent) 35%, #fff6);flex-direction:column;justify-content:center;align-items:center;padding:3rem 2.5rem;text-decoration:none;transition:transform .3s cubic-bezier(.4,0,.2,1),box-shadow .3s;display:flex;position:relative;overflow:hidden;box-shadow:0 12px 40px #00000014,inset 0 1px #ffffff40}.genexam-hero:hover{transform:translateY(-3px);box-shadow:0 20px 50px #0000001f,inset 0 1px #ffffff4d}.genexam-hero-orb{background:color-mix(in srgb, var(--accent) 18%, #ffffff26);pointer-events:none;border-radius:50%;position:absolute}.genexam-hero-orb--top{width:160px;height:160px;top:-50px;right:-50px}.genexam-hero-orb--bottom{width:110px;height:110px;bottom:-30px;left:-20px}.genexam-hero-title{color:var(--text-primary);z-index:1;letter-spacing:-.02em;margin-bottom:.5rem;font-size:2.2rem;font-weight:800;position:relative}.genexam-hero-subtitle{color:var(--text-secondary);z-index:1;margin-bottom:2rem;font-size:1.1rem;position:relative}.genexam-hero-btn{-webkit-backdrop-filter:blur(10px);color:var(--accent);z-index:1;background:#ffffffd1;border:1px solid #ffffff80;border-radius:9999px;align-items:center;gap:10px;padding:.85rem 2.5rem;font-size:1.1rem;font-weight:800;transition:transform .25s cubic-bezier(.4,0,.2,1),box-shadow .25s;display:inline-flex;position:relative;box-shadow:0 4px 16px #0000001a}.genexam-hero:hover .genexam-hero-btn{transform:translateY(-2px);box-shadow:0 12px 30px #0000001f}.genexam-hero-content{z-index:1;justify-content:center;align-items:center;gap:2rem;width:100%;display:flex;position:relative}.genexam-hero-lottie{opacity:.95;flex-shrink:0;width:160px;height:160px}.genexam-hero-copy{text-align:left;flex-direction:column;align-items:flex-start;display:flex}.genexam-hero-copy .genexam-hero-title{text-align:left}.genexam-hero-copy .genexam-hero-subtitle{text-align:left;margin-bottom:1.5rem}@media (width<=640px){.genexam-hero-content{text-align:center;flex-direction:column}.genexam-hero-lottie{width:96px;height:96px}.genexam-hero-copy{text-align:center;align-items:center}.genexam-hero-copy .genexam-hero-title,.genexam-hero-copy .genexam-hero-subtitle{text-align:center}}.generative-exam-page{background:var(--bg-primary);flex-direction:column;min-height:100vh;font-family:Inter,system-ui,sans-serif;display:flex;position:relative}.genexam-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);z-index:50;justify-content:space-between;align-items:center;padding:1rem 1.5rem;display:flex;position:sticky;top:0;box-shadow:0 4px 20px #00000008}.genexam-header-right{align-items:center;gap:.75rem;display:flex}.genexam-exit{color:var(--text-secondary);cursor:pointer;border:1px solid var(--border-color);z-index:51;background:0 0;border-radius:99px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:1rem;font-weight:600;transition:all .2s;display:flex;position:relative}.genexam-exit:hover{color:#ef4444;background:#ef44441a;border-color:#ef444466}.genexam-meta{text-align:center;flex-direction:column;display:flex}.genexam-meta strong{color:var(--text-primary);font-size:1.1rem;font-weight:700}.genexam-meta span{color:var(--text-secondary);margin-top:.1rem;font-size:.85rem;font-weight:500}.genexam-timer{color:var(--accent);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;padding:.4rem 1rem;font-family:ui-monospace,Consolas,monospace;font-size:1.25rem;font-weight:700}.genexam-progress{background:var(--bg-card);width:100%;height:6px}.genexam-progress-bar{background:linear-gradient(90deg, var(--color-primary), #d8b4fe);border-radius:0 4px 4px 0;height:100%;transition:width .4s cubic-bezier(.4,0,.2,1)}.genexam-main{box-sizing:border-box;flex:1;width:100%;max-width:900px;margin:0 auto;padding:3rem 1.5rem 8rem}.genexam-card{background:var(--bg-card);box-shadow:0 20px 40px -15px #0000000d, 0 0 0 1px var(--bg-body);border-radius:28px;margin-bottom:2rem;padding:2.5rem;position:relative}.genexam-badge{color:var(--color-primary);text-transform:uppercase;letter-spacing:.5px;background:#aa3bff1a;border-radius:99px;margin-bottom:1.25rem;padding:.35rem .8rem;font-size:.8rem;font-weight:700;display:inline-block}.genexam-question-text{color:var(--text-primary);font-size:1.35rem;font-weight:500;line-height:1.6}.genexam-options-container{flex-direction:column;gap:1rem;display:flex}.genexam-option{text-align:left;border:2px solid var(--border-color);background:var(--card-bg);cursor:pointer;color:var(--text-primary);border-radius:18px;align-items:center;gap:1.25rem;width:100%;padding:1.25rem 1.5rem;font-family:inherit;font-size:1.1rem;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;box-shadow:0 8px 22px #0000000f}.genexam-option:hover{border-color:var(--accent);transform:translateY(-1px);box-shadow:0 12px 28px #0000001a}.genexam-option.selected{border-color:var(--button-primary);background:color-mix(in srgb, var(--button-primary) 16%, var(--card-bg));box-shadow:0 0 0 3px color-mix(in srgb, var(--button-primary) 22%, transparent)}.genexam-option-letter{color:var(--accent);background:var(--bg-primary);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.2rem;font-weight:800;transition:all .2s;display:flex}.genexam-option.selected .genexam-option-letter{background:var(--button-primary);color:#fff}.genexam-option-text{flex:1}.genexam-footer{background:var(--bg-secondary);border-top:1px solid var(--border-color);z-index:50;padding:1.25rem;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -10px 20px #0000000d}.genexam-footer-content{justify-content:space-between;align-items:center;max-width:900px;margin:0 auto;display:flex}.genexam-footer-count{color:var(--text-secondary);font-size:.95rem;font-weight:500}.genexam-btn-nav{cursor:pointer;background:var(--button-primary);color:#fff;border:2px solid var(--button-primary-hover);border-radius:14px;padding:.8rem 1.5rem;font-size:1.05rem;font-weight:700;transition:all .2s}.genexam-btn-nav:hover:not(:disabled){background:var(--button-primary-hover);border-color:var(--button-primary);transform:translateY(-2px);box-shadow:0 8px 15px -5px #0003}.genexam-btn-nav:disabled{background:var(--bg-primary);color:var(--text-secondary);border-color:var(--border-color);cursor:not-allowed;box-shadow:none;opacity:.5;transform:none}.genexam-btn-finish{color:#fff;background:#ef4444;border-color:#b91c1c}.genexam-btn-finish:hover:not(:disabled){background:#f87171;border-color:#ef4444;box-shadow:0 8px 15px -5px #ef444466}.genexam-modal.hidden{display:none!important}.genexam-modal{z-index:9999;-webkit-backdrop-filter:blur(8px);background:#1e143759;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.genexam-modal-content{background:var(--bg-card);text-align:center;border-radius:24px;width:90%;max-width:400px;padding:2.5rem;animation:.3s cubic-bezier(.34,1.56,.64,1) modalIn;box-shadow:0 25px 50px -12px #00000040}@keyframes modalIn{0%{opacity:0;transform:translateY(20px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.genexam-modal h3{color:var(--text-primary);margin-bottom:.5rem;font-size:1.5rem}.genexam-modal p{color:var(--text-secondary);margin-bottom:2rem;line-height:1.5}.genexam-modal-actions{justify-content:center;gap:1rem;display:flex}.genexam-modal-actions button{cursor:pointer;border:none;border-radius:12px;flex:1;padding:.8rem;font-weight:600}.genexam-btn-cancel{background:var(--bg-body);color:var(--text-primary)}.genexam-btn-confirm{background:var(--color-primary);color:#fff}.profile-hero{background:var(--card-bg);border:1px solid var(--border-color);border-radius:28px;align-items:center;gap:1.75rem;margin-bottom:2rem;padding:2.5rem 2rem;display:flex;position:relative;overflow:hidden;box-shadow:0 12px 40px -12px #00000014}.profile-hero:before{content:"";background:linear-gradient(90deg, var(--accent), color-mix(in srgb, var(--accent) 60%, #ff8c42));border-radius:28px 28px 0 0;height:4px;position:absolute;top:0;left:0;right:0}.profile-hero-avatar-wrapper{flex-shrink:0}.profile-avatar-large{object-fit:cover;border:3px solid var(--accent);width:100px;height:100px;box-shadow:0 8px 24px color-mix(in srgb, var(--accent) 25%, transparent);border-radius:50%}.profile-avatar-initials-large{color:#fff;background:linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent) 60%, #ff8c42));width:100px;height:100px;box-shadow:0 8px 24px color-mix(in srgb, var(--accent) 25%, transparent);border-radius:50%;justify-content:center;align-items:center;font-size:2.5rem;font-weight:800;display:flex}.profile-hero-info{flex:1;min-width:0}.profile-hero-name{letter-spacing:-.02em;color:var(--text-primary);margin:0 0 .4rem;font-size:1.75rem;font-weight:800}.profile-you-badge{color:var(--accent);font-size:.85rem;font-weight:600}.profile-hero-meta{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.profile-role-badge{background:color-mix(in srgb, var(--accent) 12%, transparent);color:var(--accent);border-radius:999px;padding:.25rem .75rem;font-size:.8rem;font-weight:600;display:inline-block}.profile-joined{color:var(--text-secondary);font-size:.85rem}.profile-streak-badge{color:#ef4444;background:linear-gradient(135deg,#ef44441f,#f973161f);border-radius:999px;align-items:center;margin-top:.5rem;padding:.3rem .85rem;font-size:.85rem;font-weight:700;display:inline-flex}.profile-section{margin-bottom:2rem}.profile-section-title{color:var(--text-primary);align-items:center;gap:.5rem;margin-bottom:1rem;font-size:1.25rem;font-weight:700;display:flex}.profile-medal-count{color:var(--text-secondary);background:color-mix(in srgb, var(--text-secondary) 10%, transparent);border-radius:999px;margin-left:.5rem;padding:.2rem .6rem;font-size:.85rem;font-weight:600}.profile-stats-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem;display:grid}.profile-stat-card{background:var(--card-bg);border:1px solid var(--border-color);text-align:center;border-radius:18px;padding:1.25rem;transition:all .2s;box-shadow:0 4px 12px #0000000a}.profile-stat-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000014}.profile-stat-value{color:var(--text-primary);font-size:1.75rem;font-weight:800;line-height:1.2}.profile-stat-label{color:var(--text-secondary);margin-top:.3rem;font-size:.8rem;font-weight:600}.medals-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:18px;display:grid}.medal-master-section{justify-content:center;margin-bottom:1.5rem;display:flex}.medal-card{border:1px solid var(--border-color);background:var(--card-bg);text-align:center;cursor:pointer;border-radius:22px;padding:20px 18px;transition:transform .25s,box-shadow .25s,border-color .25s;animation:.5s backwards medalReveal;position:relative;box-shadow:0 10px 28px #0000000f}.medal-card:hover{border-color:var(--accent);box-shadow:0 18px 42px #00000024, 0 0 0 4px color-mix(in srgb, var(--accent) 14%, transparent);transform:translateY(-6px)scale(1.025)}.medal-img{object-fit:contain;filter:drop-shadow(0 2px 2px #00000040)drop-shadow(0 8px 18px #00000029);width:92px;height:92px;margin-bottom:10px;transition:transform .25s,filter .25s,opacity .25s}.medal-name{color:var(--text-primary);margin-bottom:4px;font-size:.9rem;font-weight:700}.medal-date{color:var(--text-secondary);font-size:.75rem;font-weight:500}.medal-date-locked{color:color-mix(in srgb, var(--text-secondary) 60%, transparent);font-style:italic}.medal-card.locked .medal-img{filter:grayscale()brightness(.23)contrast(1.35)blur(1.2px)drop-shadow(0 2px 2px #00000073);opacity:.3}.medal-card.locked{opacity:.7}.medal-card.locked:after{content:"";pointer-events:none;background:#00000047;border-radius:18px;position:absolute;inset:12px}.medal-card.locked:hover{transform:translateY(-3px)scale(1.01)}.medal-card.locked:hover .medal-img{filter:grayscale()brightness(.3)contrast(1.25)blur(.5px)drop-shadow(0 2px 2px #00000073);transform:scale(1.03)}.medal-lock{opacity:.6;z-index:2;font-size:1rem;position:absolute;top:12px;right:12px}.medal-card.unlocked .medal-img{filter:drop-shadow(0 2px 2px #00000047) drop-shadow(0 10px 22px #0000002e) drop-shadow(0 0 18px color-mix(in srgb, var(--accent) 45%, transparent))}.medal-card.unlocked:hover .medal-img{filter:drop-shadow(0 2px 2px #00000047) drop-shadow(0 10px 22px #0000002e) drop-shadow(0 0 28px color-mix(in srgb, var(--accent) 65%, transparent));transform:rotate(-3deg)scale(1.08)}.medal-card.unlocked{border-color:color-mix(in srgb, var(--accent) 25%, var(--border-color))}.medal-card.medal-master{border-width:2px;min-width:220px;max-width:260px;padding:24px 20px;transform:scale(1.04)}.medal-card.medal-master .medal-img{width:110px;height:110px}.medal-card.medal-master:hover{transform:translateY(-6px)scale(1.06);box-shadow:0 20px 50px #fbbf2433,0 0 0 4px #fbbf2433}.medal-card.medal-master.locked{border-color:color-mix(in srgb, #fbbf24 25%, var(--border-color));background:linear-gradient(145deg, var(--card-bg), color-mix(in srgb, #fbbf24 3%, var(--card-bg)))}.medal-card.medal-master.unlocked{background:linear-gradient(145deg, var(--card-bg), color-mix(in srgb, #fbbf24 8%, var(--card-bg)));border-color:#fbbf24;box-shadow:0 16px 44px #fbbf2433,0 0 0 2px #fbbf2426}.medal-card.medal-master.unlocked .medal-img{filter:drop-shadow(0 0 28px #fbbf248c)}.medal-card.medal-master.unlocked:hover .medal-img{filter:drop-shadow(0 0 36px #fbbf24b3);transform:rotate(-3deg)scale(1.1)}.medal-card.medal-master .medal-name{color:#fbbf24;font-size:1.05rem;font-weight:800}@keyframes medalReveal{0%{opacity:0;transform:translateY(12px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.medals-grid .medal-card:first-child{animation-delay:50ms}.medals-grid .medal-card:nth-child(2){animation-delay:.1s}.medals-grid .medal-card:nth-child(3){animation-delay:.15s}.medals-grid .medal-card:nth-child(4){animation-delay:.2s}.medals-grid .medal-card:nth-child(5){animation-delay:.25s}.medals-grid .medal-card:nth-child(6){animation-delay:.3s}.medals-grid .medal-card:nth-child(7){animation-delay:.35s}.medals-grid .medal-card:nth-child(8){animation-delay:.4s}.medals-grid .medal-card:nth-child(9){animation-delay:.45s}.medal-modal-backdrop{z-index:9999;-webkit-backdrop-filter:blur(10px);opacity:0;visibility:hidden;background:#0000008c;justify-content:center;align-items:center;transition:opacity .3s,visibility .3s;display:flex;position:fixed;inset:0}.medal-modal-backdrop.active{opacity:1;visibility:visible}.medal-modal{background:var(--card-bg);text-align:center;border:1px solid var(--border-color);border-radius:28px;width:90%;max-width:380px;padding:2.5rem 2rem;animation:.35s cubic-bezier(.34,1.56,.64,1) both medalModalIn;position:relative;box-shadow:0 30px 60px -12px #00000059}@keyframes medalModalIn{0%{opacity:0;transform:translateY(30px)scale(.92)}to{opacity:1;transform:translateY(0)scale(1)}}.medal-modal-close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.5rem;transition:all .2s;display:flex;position:absolute;top:14px;right:16px}.medal-modal-close:hover{background:color-mix(in srgb, var(--text-secondary) 12%, transparent);color:var(--text-primary)}.medal-modal-img{object-fit:contain;filter:drop-shadow(0 4px 4px #00000040)drop-shadow(0 18px 36px #00000038);width:min(280px,65vw);height:min(280px,65vw);margin-bottom:1.25rem}.medal-modal.unlocked .medal-modal-img{filter:drop-shadow(0 4px 4px #00000040) drop-shadow(0 18px 36px #00000038) drop-shadow(0 0 24px color-mix(in srgb, var(--accent) 50%, transparent))}.medal-modal.locked .medal-modal-img{filter:grayscale()brightness(.22)contrast(1.35)blur(1px);opacity:.35}.medal-modal h2{color:var(--text-primary);margin:0 0 .4rem;font-size:1.35rem;font-weight:800}.medal-modal .medal-modal-status{color:var(--text-secondary);font-size:.9rem;font-weight:500}.medal-modal .medal-modal-status.obtained{color:var(--accent);font-weight:700}.medal-modal.master-modal h2{color:#fbbf24}.medal-modal.master-modal.unlocked .medal-modal-img{filter:drop-shadow(0 4px 4px #00000040)drop-shadow(0 18px 36px #00000038)drop-shadow(0 0 32px #fbbf2480)}.medal-toast{background:var(--card-bg);z-index:9999;border:1px solid #fbbf24;border-radius:18px;align-items:center;gap:1rem;max-width:90vw;padding:1rem 1.5rem;animation:.5s cubic-bezier(.34,1.56,.64,1) forwards toastSlideIn;display:flex;position:fixed;bottom:2rem;left:50%;transform:translate(-50%)translateY(120px);box-shadow:0 20px 50px #0003,0 0 30px #fbbf2426}.medal-toast-img{object-fit:contain;filter:drop-shadow(0 0 8px #fbbf2466);width:48px;height:48px}.medal-toast-text{color:var(--text-primary);font-size:.95rem;font-weight:700}.medal-toast-sub{color:var(--text-secondary);font-size:.8rem;font-weight:500}@keyframes toastSlideIn{0%{opacity:0;transform:translate(-50%)translateY(120px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@keyframes toastSlideOut{0%{opacity:1;transform:translate(-50%)translateY(0)}to{opacity:0;transform:translate(-50%)translateY(120px)}}@media (width<=640px){.profile-hero{text-align:center;flex-direction:column;padding:2rem 1.5rem}.profile-hero-meta{justify-content:center}.profile-hero-name{font-size:1.4rem}.profile-avatar-large,.profile-avatar-initials-large{width:80px;height:80px}.profile-avatar-initials-large{font-size:2rem}.medals-grid{grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:12px}.medal-img{width:72px;height:72px}.medal-card{padding:14px 12px}.profile-stats-grid{grid-template-columns:repeat(2,1fr)}}.genexam-question,.training-question,.question-card{-webkit-user-select:none;user-select:none}img{-webkit-user-drag:none}@media (width<=1024px){.navbar{padding:0 1rem}}@media (width<=768px){.navbar{flex-wrap:wrap;gap:1rem;height:auto;padding:1rem}.navbar-nav{-webkit-overflow-scrolling:touch;scrollbar-width:none;justify-content:flex-start;width:100%;padding-bottom:.5rem;overflow-x:auto}.navbar-nav::-webkit-scrollbar{display:none}.navbar-user .user-name{display:none}.main-content{padding:1rem}.dashboard-hero-layout{flex-direction:column!important;align-items:stretch!important}.streak-widget-hero{min-width:100%;max-width:100%}.generative-exam-banner{width:100%}.genexam-hero{padding:2rem 1.5rem}.genexam-hero-title{font-size:1.75rem}.genexam-hero-subtitle{font-size:.95rem}.training-cats-grid,.dashboard-grid{grid-template-columns:1fr}}@media (width<=480px){.premium-topbar{flex-direction:column;align-items:flex-start;gap:.75rem;height:auto;padding:1rem}.premium-topbar-left{justify-content:space-between;width:100%}.premium-topbar-right{justify-content:flex-end;width:100%}.premium-topbar-title{font-size:1rem}.card{padding:1.5rem}.dashboard-header h1{font-size:1.25rem}.training-category-title{font-size:1.35rem}.training-mode-card{padding:1.25rem}.training-mode-card h3{font-size:1.2rem!important}}
