@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=JetBrains+Mono:wght@400;500;600&display=swap";body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}html,body,#root{height:100%}.event-important-symbol{position:absolute;top:2px;right:2px;color:var(--warning);font-size:.6rem;line-height:1;z-index:2}.calendar-day.today .event-important-symbol{color:#fffc}.calendar-tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--card-bg);color:var(--text);padding:8px 12px;border-radius:8px;box-shadow:var(--shadow-lg);width:max-content;max-width:220px;z-index:200;pointer-events:none;border:1px solid var(--border);font-size:.75rem;animation:tooltipFadeIn .15s ease}@keyframes tooltipFadeIn{0%{opacity:0;transform:translate(-50%) translateY(4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.calendar-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border-width:5px;border-style:solid;border-color:var(--card-bg) transparent transparent transparent}.tooltip-item{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:3px;text-align:left;display:flex;align-items:center;gap:6px;font-weight:500}.tooltip-item:before{content:"";width:5px;height:5px;border-radius:50%;background:var(--primary);flex-shrink:0}.tooltip-item:last-child{margin-bottom:0}:root{--primary: #6366F1;--primary-light: #EEF2FF;--primary-dark: #4F46E5;--primary-50: #EEF2FF;--primary-100: #E0E7FF;--primary-200: #C7D2FE;--primary-500: #6366F1;--primary-600: #4F46E5;--primary-700: #4338CA;--primary-gradient: linear-gradient(135deg, #6366F1 0%, #8B5CF6 50%, #A78BFA 100%);--primary-gradient-hover: linear-gradient(135deg, #4F46E5 0%, #7C3AED 50%, #8B5CF6 100%);--primary-gradient-subtle: linear-gradient(135deg, rgba(99,102,241,.08) 0%, rgba(139,92,246,.08) 100%);--accent-blue: #8B5CF6;--accent-blue-light: #EDE9FE;--success: #10B981;--success-light: #D1FAE5;--success-dark: #059669;--danger: #EF4444;--danger-light: #FEE2E2;--danger-dark: #DC2626;--warning: #F59E0B;--warning-light: #FEF3C7;--warning-dark: #D97706;--info: #3B82F6;--info-light: #DBEAFE;--mark-review: #F97316;--mark-review-hover: #EA580C;--accent-cyan: #22D3EE;--accent-emerald: #34D399;--bg-main: #F5F7FA;--bg-gradient-start: #F5F7FA;--bg-gradient-end: #EEF1F6;--card-bg: #FFFFFF;--card-bg-hover: #FAFBFC;--surface-elevated: #FFFFFF;--glass-bg: rgba(255, 255, 255, .95);--glass-border: rgba(0, 0, 0, .06);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 12px rgba(0, 0, 0, .06);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .08);--shadow-xl: 0 16px 40px rgba(0, 0, 0, .1);--shadow-2xl: 0 24px 50px rgba(0, 0, 0, .14);--shadow-primary: 0 4px 14px rgba(99, 102, 241, .25);--shadow-primary-lg: 0 8px 28px rgba(99, 102, 241, .3);--shadow-glow: 0 0 16px rgba(99, 102, 241, .12);--shadow-inner-glow: inset 0 1px 0 rgba(255, 255, 255, .06);--card-shadow: 0 1px 4px rgba(0, 0, 0, .05);--card-shadow-hover: 0 8px 24px rgba(0, 0, 0, .1);--soft-shadow: var(--shadow-md);--text: #1A202C;--text-black: #000000;--text-secondary: #4A5568;--text-muted: #A0AEC0;--text-on-primary: #FFFFFF;--border: #E2E8F0;--border-light: #EDF2F7;--border-focus: #6366F1;--radius: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 9999px;--sidebar-bg: #312E81;--sidebar-text: rgba(255, 255, 255, .6);--sidebar-text-active: #FFFFFF;--sidebar-active-bg: rgba(255, 255, 255, .12);--sidebar-item-hover: rgba(255, 255, 255, .06);--sidebar-border: rgba(255, 255, 255, .08);--sidebar-width: 78px;--sidebar-collapsed-width: 78px;--btn-primary: #6366F1;--btn-secondary: #EEF2FF;--badge-subject-bg: #EEF2FF;--badge-subject-text: #6366F1;--badge-upcoming-bg: #FEF3C7;--badge-upcoming-text: #D97706;--badge-live-bg: #FEE2E2;--badge-live-text: #EF4444;--badge-completed-bg: #D1FAE5;--badge-completed-text: #059669;--notice-upcoming-bg: #EFF6FF;--notice-upcoming-text: #2563EB;--notice-urgent-bg: #FEE2E2;--notice-urgent-text: #EF4444;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .35s cubic-bezier(.4, 0, .2, 1);--transition-spring: .5s cubic-bezier(.34, 1.56, .64, 1);--transition-bounce: .6s cubic-bezier(.68, -.55, .265, 1.55)}[data-theme=dark]{--primary: #818CF8;--primary-light: rgba(129, 140, 248, .12);--primary-dark: #6366F1;--primary-50: rgba(129, 140, 248, .06);--primary-100: rgba(129, 140, 248, .1);--primary-200: rgba(129, 140, 248, .18);--primary-500: #818CF8;--primary-600: #6366F1;--primary-gradient: linear-gradient(135deg, #818CF8 0%, #A78BFA 50%, #C4B5FD 100%);--primary-gradient-hover: linear-gradient(135deg, #6366F1 0%, #8B5CF6 50%, #A78BFA 100%);--primary-gradient-subtle: linear-gradient(135deg, rgba(129,140,248,.06) 0%, rgba(167,139,250,.06) 100%);--accent-blue: #A78BFA;--accent-blue-light: rgba(167, 139, 250, .12);--success: #34D399;--success-light: rgba(52, 211, 153, .12);--danger: #F87171;--danger-light: rgba(248, 113, 113, .12);--warning: #FBBF24;--warning-light: rgba(251, 191, 36, .12);--info: #60A5FA;--info-light: rgba(96, 165, 250, .12);--mark-review: #FB923C;--mark-review-hover: #F97316;--accent-color: #A78BFA;--bg-main: #0B0F1A;--bg-gradient-start: #0F1629;--bg-gradient-end: #0B0F1A;--card-bg: rgba(17, 24, 45, .8);--card-bg-hover: rgba(26, 35, 60, .9);--surface-elevated: rgba(22, 30, 52, .9);--glass-bg: rgba(17, 24, 45, .6);--glass-border: rgba(255, 255, 255, .06);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .3);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4), 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 8px rgba(0, 0, 0, .4), 0 0 0 1px rgba(255,255,255,.03);--shadow-lg: 0 10px 30px rgba(0, 0, 0, .5), 0 0 0 1px rgba(255,255,255,.03);--shadow-xl: 0 20px 50px rgba(0, 0, 0, .6);--shadow-2xl: 0 30px 70px rgba(0, 0, 0, .7);--shadow-primary: 0 4px 20px rgba(129, 140, 248, .2), 0 0 0 1px rgba(129,140,248,.1);--shadow-primary-lg: 0 8px 35px rgba(129, 140, 248, .25), 0 0 0 1px rgba(129,140,248,.12);--shadow-glow: 0 0 30px rgba(129, 140, 248, .12);--shadow-inner-glow: inset 0 1px 0 rgba(255, 255, 255, .04);--card-shadow: 0 1px 3px rgba(0, 0, 0, .3), 0 0 0 1px rgba(255,255,255,.04);--card-shadow-hover: 0 12px 35px rgba(0, 0, 0, .5), 0 0 0 1px rgba(129,140,248,.1);--text: #E2E8F0;--text-black: #FFFFFF;--text-secondary: #94A3B8;--text-muted: #64748B;--border: rgba(255, 255, 255, .06);--border-light: rgba(255, 255, 255, .03);--border-focus: #818CF8;--sidebar-bg: rgba(20, 16, 56, .95);--sidebar-text: rgba(255, 255, 255, .5);--sidebar-text-active: #FFFFFF;--sidebar-active-bg: rgba(129, 140, 248, .15);--sidebar-item-hover: rgba(255, 255, 255, .05);--sidebar-border: rgba(255, 255, 255, .04);--btn-primary: #818CF8;--btn-secondary: rgba(129, 140, 248, .12);--badge-subject-bg: rgba(129, 140, 248, .12);--badge-subject-text: #818CF8;--badge-upcoming-bg: rgba(251, 191, 36, .12);--badge-upcoming-text: #FBBF24;--badge-live-bg: rgba(248, 113, 113, .12);--badge-live-text: #F87171;--badge-completed-bg: rgba(52, 211, 153, .12);--badge-completed-text: #34D399;--notice-upcoming-bg: rgba(96, 165, 250, .1);--notice-upcoming-text: #60A5FA;--notice-urgent-bg: rgba(248, 113, 113, .1);--notice-urgent-text: #F87171;--palette-current: rgba(129, 140, 248, .3);--palette-answered: rgba(52, 211, 153, .3);--palette-marked: rgba(251, 146, 60, .3);--palette-not-answered: rgba(248, 113, 113, .3);--palette-not-visited: rgba(100, 116, 139, .3);--option-bg: rgba(22, 30, 52, .8);--option-selected-bg: rgba(129, 140, 248, .12);--option-hover-bg: rgba(255, 255, 255, .03)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-main);color:var(--text);min-height:100vh;line-height:1.6;transition:background var(--transition-slow),color var(--transition-slow)}::selection{background:var(--primary-200);color:var(--primary-700)}[data-theme=dark] ::selection{background:#818cf84d;color:#e0e7ff}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.app-layout{display:flex;min-height:100vh;background:var(--bg-main)}.app-sidebar{width:240px;background:var(--sidebar-bg);display:flex;flex-direction:column;padding:16px 0;height:100vh;position:fixed;left:0;top:0;z-index:100;overflow:visible;box-shadow:2px 0 12px #0000001f}.app-sidebar.collapsed{align-items:center}.sidebar-logo{display:flex;align-items:center;justify-content:center;padding:4px 16px;margin-bottom:20px;min-height:48px;width:100%}.app-sidebar.collapsed .sidebar-logo{padding:4px;justify-content:center}.sidebar-collapse-btn{position:absolute;top:28px;right:-16px;width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:2px solid var(--card-bg);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:110;box-shadow:0 2px 12px #6366f159;transition:all var(--transition-base)}.sidebar-collapse-btn:hover{background:linear-gradient(135deg,#8b5cf6,#a78bfa);box-shadow:0 4px 20px #6366f180;transform:scale(1.08)}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:2px;width:100%;padding:0 10px;overflow-y:auto;overflow-x:hidden}.app-sidebar.collapsed .sidebar-nav{padding:0 6px}.nav-item{display:flex;flex-direction:row;align-items:center;gap:12px;padding:11px 14px;border-radius:10px;color:var(--sidebar-text);transition:all var(--transition-base);cursor:pointer;text-decoration:none;font-weight:500;position:relative;border:none;background:none;width:100%}.nav-item:hover{background:var(--sidebar-item-hover);color:#ffffffd9}.nav-item.active{background:var(--sidebar-active-bg);color:var(--sidebar-text-active);font-weight:600}.nav-item.active:before{content:"";position:absolute;left:-10px;top:50%;transform:translateY(-50%);width:3px;height:24px;background:#8b5cf6;border-radius:0 3px 3px 0}.nav-icon{display:flex;align-items:center;justify-content:center;width:22px;height:22px;flex-shrink:0}.nav-item svg{width:20px;height:20px;flex-shrink:0}.nav-label{font-size:.88rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-item.collapsed{flex-direction:column;justify-content:center;align-items:center;padding:10px 4px;gap:4px;text-align:center;min-height:58px}.nav-item.collapsed .nav-icon{width:22px;height:22px}.nav-label-small{font-size:.58rem;font-weight:400;letter-spacing:.02em;line-height:1;opacity:.7;white-space:nowrap}.nav-item.active .nav-label-small{opacity:1;font-weight:600}.nav-item.collapsed.active:before{left:-6px}.nav-divider{height:1px;background:var(--sidebar-border);margin:8px 12px}.sidebar-footer{display:flex;flex-direction:column;gap:4px;padding-top:12px;border-top:1px solid var(--sidebar-border);margin-top:auto;width:100%;padding-left:10px;padding-right:10px}.app-sidebar.collapsed .sidebar-footer{padding-left:6px;padding-right:6px}.user-profile-section{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:10px;transition:all var(--transition-base)}.user-profile-section:hover{background:var(--sidebar-item-hover)}.user-profile-section.collapsed{justify-content:center;padding:8px 4px;gap:0}.user-avatar{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.75rem;flex-shrink:0}.user-info{flex:1;overflow:hidden;display:flex;flex-direction:column}.user-name{font-size:.8rem;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:.7rem;color:var(--sidebar-text)}.logout-btn{color:var(--sidebar-text)!important}.logout-btn:hover{background:#ef444426!important;color:#f87171!important}.app-main{flex:1;margin-left:240px;display:flex;flex-direction:column;overflow-x:hidden;transition:margin-left var(--transition-slow);min-height:100vh}.app-layout.sidebar-collapsed .app-main{margin-left:78px}.app-header{height:64px;display:flex;justify-content:space-between;align-items:center;padding:0 28px;background:var(--card-bg);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50;box-shadow:var(--shadow-xs)}[data-theme=dark] .app-header{background:#0f1324e6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.04)}.app-content{padding:24px 28px;max-width:1440px;margin:0 auto;width:100%}.header-left{display:flex;align-items:center;gap:16px}.header-right{display:flex;align-items:center;gap:12px}.header-page-title h1{font-size:1.2rem;font-weight:700;color:var(--text);letter-spacing:-.01em;margin:0}.header-action-btn{width:38px;height:38px;border-radius:10px;border:1px solid var(--border);background:var(--card-bg);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);position:relative}.header-action-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-50)}.header-notification-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 5px;background:var(--danger);color:#fff;border-radius:9px;font-size:.65rem;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid var(--card-bg);line-height:1}.notification-wrapper{position:relative}.notification-dropdown{position:absolute;top:calc(100% + 10px);right:0;width:360px;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);z-index:200;overflow:hidden}[data-theme=dark] .notification-dropdown{background:#11182df2;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.notif-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px 12px;border-bottom:1px solid var(--border-light)}.notif-header h3{font-size:.95rem;font-weight:700;color:var(--text);margin:0}.notif-mark-all{display:flex;align-items:center;gap:4px;font-size:.72rem;font-weight:600;color:var(--primary);background:none;border:none;cursor:pointer;padding:4px 8px;border-radius:6px;transition:all var(--transition-base)}.notif-mark-all:hover{background:var(--primary-50)}.notif-list{max-height:320px;overflow-y:auto}.notif-item{display:flex;align-items:flex-start;gap:12px;padding:14px 20px;cursor:pointer;transition:all var(--transition-base);position:relative;border-bottom:1px solid var(--border-light)}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--border-light)}.notif-item.unread{background:var(--primary-50)}.notif-item.unread:hover{background:var(--primary-100)}.notif-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.notif-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.notif-title{font-size:.82rem;font-weight:600;color:var(--text);line-height:1.3}.notif-desc{font-size:.75rem;color:var(--text-muted);line-height:1.4}.notif-time{font-size:.68rem;color:var(--text-muted);margin-top:2px}.notif-unread-dot{width:8px;height:8px;border-radius:50%;background:var(--primary);flex-shrink:0;margin-top:6px}.notif-empty{padding:32px 20px;text-align:center;font-size:.85rem;color:var(--text-muted)}.header-user-profile{display:flex;align-items:center;gap:10px;padding:4px 12px 4px 4px;border-radius:var(--radius);cursor:pointer;transition:all var(--transition-base);border:1px solid transparent}.header-user-profile:hover{background:var(--bg-main);border-color:var(--border)}.header-user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.85rem}.header-user-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}.header-user-name{font-size:.88rem;font-weight:600;color:var(--text);white-space:nowrap}.header-user-chevron{color:var(--text-muted);transition:transform var(--transition-base)}.profile-dropdown-wrapper{position:relative}.profile-dropdown{position:absolute;top:calc(100% + 10px);right:0;width:260px;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);z-index:200;overflow:hidden;backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%)}[data-theme=dark] .profile-dropdown{background:#11182deb;border:1px solid rgba(255,255,255,.06)}.profile-dropdown-header{display:flex;align-items:center;gap:12px;padding:16px 18px}.profile-dropdown-name{font-size:.9rem;font-weight:700;color:var(--text);line-height:1.3}.profile-dropdown-email{font-size:.72rem;color:var(--text-muted);margin-top:1px}.profile-dropdown-divider{height:1px;background:var(--border-light);margin:0 12px}.profile-dropdown-item{display:flex;align-items:center;gap:10px;width:100%;padding:11px 18px;border:none;background:none;color:var(--text-secondary);font-size:.84rem;font-weight:500;font-family:Inter,sans-serif;cursor:pointer;transition:all var(--transition-base);text-align:left}.profile-dropdown-item:hover{background:var(--primary-50);color:var(--primary)}.profile-dropdown-item svg{flex-shrink:0}.profile-dropdown-logout:hover{background:var(--danger-light);color:var(--danger)}.sidebar-toggle-btn{width:38px;height:38px;border-radius:10px!important;display:none;align-items:center;justify-content:center;transition:all var(--transition-base)!important;background:none;border:none;cursor:pointer;color:var(--text-secondary)}.sidebar-toggle-btn:hover{background:var(--primary-50)!important;color:var(--primary)!important}.theme-toggle{width:38px;height:38px;border-radius:10px;border:1px solid var(--border);background:var(--card-bg);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base)}.theme-toggle:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-50)}.metric-grid{display:flex;gap:16px;margin-top:-40px;margin-bottom:28px;padding:0 8px;position:relative;z-index:2}.metric-grid::-webkit-scrollbar{height:0}.metric-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:22px 28px;transition:all .4s cubic-bezier(.34,1.56,.64,1);display:flex;align-items:center;gap:16px;position:relative;overflow:hidden;box-shadow:var(--shadow-md);flex:1;min-width:200px}.metric-card:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:3px;background:linear-gradient(90deg,transparent,#8B5CF6,#6366F1,transparent);transition:left .6s ease;opacity:0}.metric-card:hover:before{left:100%;opacity:1}.metric-card:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 50%,rgba(99,102,241,.04) 0%,transparent 70%);opacity:0;transition:opacity .4s ease;pointer-events:none}.metric-card:hover:after{opacity:1}.metric-card.clickable{cursor:pointer}.metric-card.clickable:hover{border-color:var(--primary-200);box-shadow:0 8px 24px #6366f11f,0 0 0 1px #6366f114;transform:translateY(-4px)}.metric-card.active{border-color:var(--primary);box-shadow:0 0 0 1.5px var(--primary),0 4px 16px #6366f126}.btn-start{padding:11px 20px;border-radius:10px;border:none;background:var(--primary-gradient);color:#fff;font-weight:600;font-size:.85rem;cursor:pointer;transition:all .35s cubic-bezier(.34,1.56,.64,1);font-family:Inter,sans-serif;letter-spacing:.01em;box-shadow:var(--shadow-primary);display:flex;align-items:center;justify-content:center;gap:6px;position:relative;overflow:hidden}.btn-start:after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.15) 50%,transparent 70%);transform:translate(-100%);transition:transform .5s ease}.btn-start:hover:after{transform:translate(100%)}.btn-start:hover{background:var(--primary-gradient-hover);box-shadow:var(--shadow-primary-lg);transform:translateY(-2px)}.btn-start:active{transform:translateY(0);box-shadow:var(--shadow-primary)}.btn-start.disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.btn-start.disabled:hover{transform:none;box-shadow:none}.btn-start.disabled:hover:after{transform:translate(-100%)}.btn-upcoming{padding:11px 20px;border-radius:10px;border:1px solid rgba(245,158,11,.15);background:var(--badge-upcoming-bg);color:var(--badge-upcoming-text);font-weight:600;font-size:.85rem;cursor:not-allowed;font-family:Inter,sans-serif;display:flex;align-items:center;justify-content:center;gap:6px;transition:all var(--transition-base);position:relative}.btn-view-summary{margin-top:auto;transition:all .35s cubic-bezier(.34,1.56,.64,1)!important}.btn-view-summary:hover{background:var(--primary-50)!important;box-shadow:0 4px 16px #6366f126,var(--shadow-glow)!important;transform:translateY(-1px)}.dashboard{animation:fadeIn .4s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.welcome-banner{background:linear-gradient(135deg,#4c1d95,#6d28d9 35%,#7c3aed 65%,#8b5cf6);border-radius:var(--radius-lg);padding:36px 40px 64px;margin-bottom:0;color:#fff;position:relative;overflow:hidden}.welcome-banner:before{content:"";position:absolute;top:0;left:-100%;width:200%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.03) 25%,rgba(255,255,255,.08) 50%,rgba(255,255,255,.03) 75%,transparent 100%);animation:bannerShimmer 8s ease-in-out infinite}@keyframes bannerShimmer{0%{transform:translate(-50%)}to{transform:translate(50%)}}.welcome-banner:after{content:"";position:absolute;top:-40%;right:-8%;width:300px;height:300px;background:radial-gradient(circle,rgba(167,139,250,.25) 0%,rgba(139,92,246,.1) 40%,transparent 70%);border-radius:50%;animation:orbFloat 6s ease-in-out infinite}@keyframes orbFloat{0%,to{transform:translate(0) scale(1)}50%{transform:translate(-10px,8px) scale(1.05)}}.welcome-banner-decor{position:absolute;bottom:-30%;left:10%;width:250px;height:250px;background:radial-gradient(circle,rgba(196,181,253,.12) 0%,transparent 60%);border-radius:50%;animation:orbFloat 8s ease-in-out infinite reverse}.welcome-banner-dots{position:absolute;top:12px;right:20px;display:grid;grid-template-columns:repeat(5,6px);gap:8px;opacity:.15}.welcome-banner-dots span{width:6px;height:6px;border-radius:50%;background:#fff}.welcome-banner h2{font-size:1.35rem;font-weight:700;margin-bottom:10px;position:relative;z-index:1}.welcome-banner p{font-size:.88rem;opacity:.8;line-height:1.6;position:relative;z-index:1;max-width:650px}.welcome-banner .welcome-emoji{font-size:1.15rem}.section-title{font-size:1.1rem;font-weight:700;color:var(--text);margin-bottom:16px;display:flex;align-items:center;gap:10px;letter-spacing:-.01em}.live-dot{width:8px;height:8px;background:var(--danger);border-radius:50%;animation:livePulse 2s ease-in-out infinite;box-shadow:0 0 8px #ef444466}@keyframes livePulse{0%,to{opacity:1;box-shadow:0 0 #ef444466}50%{opacity:.8;box-shadow:0 0 0 8px #ef444400}}.upcoming-dot,.missed-dot{width:8px;height:8px;border-radius:50%}.assessment-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;margin-bottom:24px}.assessment-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;transition:all .4s cubic-bezier(.34,1.56,.64,1);display:flex;flex-direction:column;position:relative;overflow:hidden;gap:4px;box-shadow:var(--card-shadow),var(--shadow-inner-glow)}.assessment-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary),var(--accent-blue),var(--primary));background-size:200% 100%;opacity:0;transition:opacity .4s ease;animation:gradientSlide 3s linear infinite}@keyframes gradientSlide{0%{background-position:0% 50%}to{background-position:200% 50%}}.assessment-card:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 50%,rgba(99,102,241,.05) 0%,transparent 70%);opacity:0;transition:opacity .4s ease;pointer-events:none}.assessment-card:hover:before{opacity:1}.assessment-card:hover:after{opacity:1}.assessment-card:hover{box-shadow:0 12px 36px #6366f11a,0 0 0 1px #6366f10f,var(--shadow-inner-glow);transform:translateY(-5px);border-color:var(--primary-200)}.card-badge-container{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:10px}.badge{padding:5px 12px;border-radius:var(--radius-full);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.badge--subject{background-color:var(--badge-subject-bg);color:var(--badge-subject-text);border:1px solid rgba(99,102,241,.08)}.badge--status{font-weight:700;display:flex;align-items:center;gap:5px}.badge--live{background-color:var(--badge-live-bg);color:var(--badge-live-text);animation:livePulse 2s ease-in-out infinite;border:1px solid rgba(239,68,68,.1)}.badge--upcoming{background-color:var(--badge-upcoming-bg);color:var(--badge-upcoming-text);border:1px solid rgba(245,158,11,.1)}.badge--completed{background-color:var(--badge-completed-bg);color:var(--badge-completed-text);border:1px solid rgba(16,185,129,.1)}.badge--missed{background-color:var(--notice-urgent-bg);color:var(--notice-urgent-text);border:1px solid rgba(239,68,68,.1);gap:4px}.card-title{font-size:1.05rem;font-weight:700;color:var(--text);margin:0;line-height:1.35;letter-spacing:-.015em;flex:1}.card-instructor{font-size:.82rem;color:var(--text-muted);margin-bottom:12px}.card-meta{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.meta-item{display:flex;align-items:center;gap:5px;padding:4px 10px;border-radius:8px;background:var(--bg-main);border:1px solid var(--border-light);font-size:.78rem;font-weight:500;color:var(--text-secondary);transition:all var(--transition-base)}.meta-item svg{color:var(--text-muted);flex-shrink:0}.assessment-card:hover .meta-item{border-color:var(--primary-100);background:var(--card-bg);box-shadow:0 1px 4px #6366f10f}.expiry-notice{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--border-light);border-radius:10px;color:var(--text-secondary);font-size:.78rem;font-weight:500;margin-bottom:14px;border:1px solid var(--border);border-left:3px solid var(--text-muted);position:relative}.expiry-notice--urgent{background:var(--notice-urgent-bg);color:var(--notice-urgent-text);border-color:#f8717126;border-left-color:var(--danger)}.expiry-notice--upcoming{background:var(--notice-upcoming-bg);color:var(--notice-upcoming-text);border-color:#60a5fa26;border-left-color:var(--info)}.score-notice{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--badge-completed-bg);border-radius:10px;color:var(--success);font-size:.82rem;font-weight:600;margin-bottom:14px;border:1px solid rgba(16,185,129,.15)}.card-actions{display:flex;flex-direction:column;gap:8px;margin-top:auto}.btn-outline{width:100%;padding:11px 20px;border-radius:10px;border:1.5px solid var(--primary);background:transparent;color:var(--primary);font-weight:600;font-size:.85rem;cursor:pointer;transition:all .35s cubic-bezier(.34,1.56,.64,1);font-family:Inter,sans-serif;position:relative;overflow:hidden}.btn-outline:before{content:"";position:absolute;inset:0;background:var(--primary);opacity:0;transition:opacity .3s ease;z-index:0}.btn-outline:hover{background:var(--primary-50);box-shadow:0 4px 16px #6366f126,var(--shadow-glow);transform:translateY(-1px);border-color:var(--primary)}.btn-outline:active{transform:translateY(0)}.btn-missed{padding:11px 20px;border-radius:10px;border:1px solid rgba(239,68,68,.12);background:var(--notice-urgent-bg);color:var(--notice-urgent-text);font-weight:600;font-size:.85rem;cursor:not-allowed;font-family:Inter,sans-serif;display:flex;align-items:center;justify-content:center;gap:6px;transition:all var(--transition-base);opacity:.75}.card--expired{border-left:3px solid var(--danger);position:relative}.card--expired .expired-overlay{position:absolute;inset:0;border-radius:inherit;pointer-events:none;z-index:0;background:repeating-linear-gradient(135deg,transparent,transparent 10px,rgba(239,68,68,.015) 10px,rgba(239,68,68,.015) 20px)}[data-theme=dark] .card--expired .expired-overlay{background:repeating-linear-gradient(135deg,transparent,transparent 10px,rgba(248,113,113,.02) 10px,rgba(248,113,113,.02) 20px)}.card--expired:before{background:linear-gradient(90deg,var(--danger),#F97316,var(--danger));background-size:200% 100%;animation:gradientSlide 3s linear infinite}.card--expired:hover{border-color:#ef44444d;box-shadow:0 10px 30px #ef444414,0 0 0 1px #ef44440f;border-left-color:var(--danger)}.card--expired .card-badge-container,.card--expired .card-title,.card--expired .card-meta,.card--expired .expired-info-bar,.card--expired .btn-missed{position:relative;z-index:1}.card--expired .card-meta{opacity:.6}.expired-info-bar{display:flex;align-items:center;gap:16px;padding:10px 14px;background:var(--notice-urgent-bg);border:1px solid rgba(239,68,68,.12);border-radius:10px;margin-bottom:14px;font-size:.78rem;font-weight:500;color:var(--notice-urgent-text);position:relative;z-index:1}.expired-date,.expired-duration{display:flex;align-items:center;gap:5px}.expired-date{flex:1}.expired-duration{opacity:.7}[data-theme=dark] .expired-info-bar{background:#f871710f;border-color:#f871711a}.live-dot,.upcoming-dot,.completed-dot,.missed-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}.live-dot{background-color:var(--danger);animation:livePulse 2s ease-in-out infinite}.schedule-page{animation:fadeIn .4s ease;display:flex;flex-direction:column;gap:24px}.schedule-hero-banner{background:linear-gradient(135deg,#1e3a8a,#2563eb 35%,#6366f1 65%,#8b5cf6);border-radius:var(--radius-lg);padding:32px 36px 40px;color:#fff;position:relative;overflow:hidden;box-shadow:0 8px 40px #2563eb47,0 0 0 1px #ffffff0f inset;animation:schedBannerGlow 4s ease-in-out infinite alternate}@keyframes schedBannerGlow{0%{box-shadow:0 8px 40px #2563eb38,0 0 0 1px #ffffff0f inset}to{box-shadow:0 12px 50px #6366f152,0 0 0 1px #ffffff17 inset}}.schedule-hero-banner:before{content:"";position:absolute;top:0;left:-100%;width:200%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.03) 25%,rgba(255,255,255,.07) 50%,rgba(255,255,255,.03) 75%,transparent 100%);animation:bannerShimmer 8s ease-in-out infinite}.schedule-banner-orb{position:absolute;border-radius:50%;pointer-events:none}.schedule-banner-orb--1{top:-40%;right:-6%;width:280px;height:280px;background:radial-gradient(circle,rgba(147,197,253,.22) 0%,rgba(99,102,241,.08) 45%,transparent 70%);animation:orbFloat 6s ease-in-out infinite}.schedule-banner-orb--2{bottom:-30%;left:8%;width:220px;height:220px;background:radial-gradient(circle,rgba(196,181,253,.14) 0%,transparent 60%);animation:orbFloat 9s ease-in-out infinite reverse}.schedule-banner-dots{position:absolute;top:14px;right:22px;display:grid;grid-template-columns:repeat(5,6px);gap:8px;opacity:.15}.schedule-banner-dots span{width:6px;height:6px;border-radius:50%;background:#fff}.schedule-banner-body{display:flex;align-items:center;gap:18px;position:relative;z-index:1}.schedule-banner-icon-wrap{width:52px;height:52px;border-radius:14px;background:#ffffff26;border:1px solid rgba(255,255,255,.25);display:flex;align-items:center;justify-content:center;flex-shrink:0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.schedule-banner-title{font-size:1.3rem;font-weight:700;margin-bottom:6px;color:#fff}.schedule-banner-subtitle{font-size:.86rem;opacity:.78;line-height:1.55;max-width:580px;color:#fff}.schedule-content-grid{display:grid;grid-template-columns:1fr 380px;gap:20px;align-items:start}.schedule-calendar-col,.schedule-events-col{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--card-shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.schedule-panel-header{display:flex;align-items:center;gap:8px;margin-bottom:16px}.schedule-panel-icon{width:30px;height:30px;border-radius:8px;background:var(--primary-50);color:var(--primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.schedule-panel-title{font-size:.92rem;font-weight:700;color:var(--text);flex:1}.schedule-total-badge{min-width:24px;height:24px;border-radius:100px;background:var(--primary-100);color:var(--primary);font-size:.72rem;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 7px}.schedule-filter-tabs{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:14px}.sched-tab{display:flex;align-items:center;gap:5px;padding:5px 10px;border-radius:8px;border:1px solid transparent;background:var(--border-light);color:var(--text-muted);font-size:.75rem;font-weight:600;cursor:pointer;transition:all var(--transition-base)}.sched-tab:hover{background:var(--primary-50);color:var(--primary);border-color:var(--primary-200)}.sched-tab--active{background:var(--primary);color:#fff;border-color:var(--primary)}.sched-tab--active:hover{background:var(--primary-dark);color:#fff;border-color:var(--primary-dark)}.sched-tab-count{background:#ffffff40;border-radius:100px;padding:0 5px;font-size:.68rem;min-width:18px;text-align:center}.sched-tab:not(.sched-tab--active) .sched-tab-count{background:var(--border);color:var(--text-muted)}.schedule-events-list{display:flex;flex-direction:column;gap:8px;max-height:480px;overflow-y:auto;scrollbar-width:thin}.sched-event-card{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;border-radius:var(--radius);border:1px solid var(--border-light);background:var(--bg-main);transition:all var(--transition-base);cursor:default}.sched-event-card:hover{border-color:var(--primary-200);background:var(--primary-50);box-shadow:var(--shadow-sm);transform:translate(2px)}.sched-event-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:5px}.sched-event-dot--pulse{animation:livePulse 2s ease-in-out infinite;box-shadow:0 0 0 0 currentColor}.sched-event-body{flex:1;min-width:0}.sched-event-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:6px}.sched-event-title{font-size:.83rem;font-weight:600;color:var(--text);line-height:1.35;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sched-event-badge{font-size:.62rem;font-weight:700;padding:2px 7px;border-radius:100px;letter-spacing:.04em;white-space:nowrap;flex-shrink:0}.sched-event-meta{display:flex;align-items:center;flex-wrap:wrap;gap:4px;font-size:.72rem;color:var(--text-muted)}.sched-meta-item{display:flex;align-items:center;gap:3px}.sched-meta-sep{opacity:.4}.sched-meta-time{color:var(--primary);font-weight:600}.schedule-skeleton-box{height:340px;border-radius:var(--radius);background:linear-gradient(90deg,var(--border-light) 25%,var(--border) 50%,var(--border-light) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite}.sched-event-skeleton{height:62px;border-radius:var(--radius);background:linear-gradient(90deg,var(--border-light) 25%,var(--border) 50%,var(--border-light) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.sched-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;gap:8px}.sched-empty-icon{color:var(--text-muted);opacity:.45;margin-bottom:4px}.sched-empty-title{font-size:.9rem;font-weight:600;color:var(--text-secondary)}.sched-empty-sub{font-size:.78rem;color:var(--text-muted)}.notif-close-btn{width:24px;height:24px;border-radius:6px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base)}.notif-close-btn:hover{background:var(--border-light);color:var(--text)}.notif-loading-spinner{width:20px;height:20px;border:2px solid var(--border);border-top:2px solid var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 8px}@keyframes spin{to{transform:rotate(360deg)}}.app-header{backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);background:#ffffffd9!important;border-bottom:1px solid rgba(255,255,255,.2)}[data-theme=dark] .app-header{background:#0f1324bf!important;backdrop-filter:blur(24px) saturate(150%);-webkit-backdrop-filter:blur(24px) saturate(150%);border-bottom:1px solid rgba(255,255,255,.04)}.metric-card{backdrop-filter:blur(12px) saturate(150%);-webkit-backdrop-filter:blur(12px) saturate(150%);background:#ffffffe0;border:1px solid rgba(255,255,255,.4);box-shadow:0 4px 16px #0000000a,0 0 0 1px #fff3 inset}[data-theme=dark] .metric-card{background:#11182db3;border:1px solid rgba(255,255,255,.06);box-shadow:0 4px 16px #0000004d,0 0 0 1px #ffffff08 inset}.assessment-card{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#ffffffeb;border:1px solid rgba(255,255,255,.3);box-shadow:0 2px 12px #0000000a,0 0 0 1px #ffffff26 inset}[data-theme=dark] .assessment-card{background:#11182da6;border:1px solid rgba(255,255,255,.05)}.notification-dropdown{backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);background:#ffffffeb!important;border:1px solid rgba(255,255,255,.3);box-shadow:0 16px 48px #0000001f,0 0 0 1px #fff3 inset}[data-theme=dark] .notification-dropdown{background:#11182de0!important;border:1px solid rgba(255,255,255,.06);box-shadow:0 16px 48px #00000080,0 0 0 1px #ffffff0a inset}.welcome-banner{box-shadow:0 8px 40px #7c3aed40,0 0 0 1px #ffffff0f inset;animation:bannerGlow 4s ease-in-out infinite alternate}@keyframes bannerGlow{0%{box-shadow:0 8px 40px #7c3aed33,0 0 0 1px #ffffff0f inset}to{box-shadow:0 12px 50px #8b5cf64d,0 0 0 1px #ffffff14 inset}}[data-theme=dark] .welcome-banner{box-shadow:0 8px 48px #7c3aed33,0 0 0 1px #ffffff0a inset}.app-sidebar{backdrop-filter:blur(16px) saturate(140%);-webkit-backdrop-filter:blur(16px) saturate(140%)}.header-action-btn{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#ffffffb3;border:1px solid rgba(255,255,255,.3)}[data-theme=dark] .header-action-btn{background:#1e284699;border:1px solid rgba(255,255,255,.06)}.header-action-btn:hover{background:var(--primary-50);border-color:var(--primary-200);box-shadow:0 2px 12px #6366f126}.theme-toggle{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffffb3;border:1px solid rgba(255,255,255,.3)}[data-theme=dark] .theme-toggle{background:#1e284699;border:1px solid rgba(255,255,255,.06)}.header-user-profile{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fff6;border:1px solid rgba(255,255,255,.3)}.header-user-profile:hover{background:#fff9;border-color:#6366f126;box-shadow:0 2px 12px #6366f114}[data-theme=dark] .header-user-profile{background:#1e284666;border-color:#ffffff0a}@media(max-width:768px){.app-sidebar{display:none}.app-main{margin-left:0!important}.app-content{padding:16px}.app-header{padding:0 16px}.sidebar-toggle-btn{display:flex}.sidebar-collapse-btn{display:none}.metric-grid{flex-wrap:nowrap;overflow-x:auto;padding:0 4px}.metric-card{min-width:160px;flex:0 0 auto;padding:16px 18px}.assessment-grid{grid-template-columns:1fr}.welcome-banner{padding:24px 20px 52px}.welcome-banner h2{font-size:1.1rem}.notification-dropdown{width:300px;right:-20px}.header-user-name{display:none}}@media(max-width:1100px){.schedule-calendar-wrapper{max-width:100%}.schedule-content-grid{grid-template-columns:1fr}.schedule-events-list{max-height:360px}}@media(max-width:768px){.schedule-hero-banner{padding:24px 20px 32px}.schedule-banner-title{font-size:1.1rem}.schedule-banner-body{gap:12px}.schedule-banner-icon-wrap{width:42px;height:42px}.schedule-filter-tabs{gap:3px}.sched-tab{padding:4px 8px;font-size:.7rem}}@media(max-width:1024px){.metric-grid{flex-wrap:wrap}.metric-card{min-width:180px}}.topic-boxes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;margin-bottom:20px}.topic-box{background:var(--card-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--radius);padding:16px;cursor:pointer;transition:all var(--transition-base)}.topic-box:hover{border-color:var(--primary-200);box-shadow:var(--shadow-md);transform:translateY(-1px)}.topic-box.active{border-color:var(--primary);background:var(--primary-50);box-shadow:var(--shadow-primary)}.topic-box.missed{border-left:3px solid var(--danger)}.topic-header{display:flex;justify-content:space-between;align-items:center}.topic-name{font-weight:600;font-size:.88rem;color:var(--text)}.topic-count{font-size:.78rem;color:var(--text-muted);font-weight:500}.topic-details-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px;padding-top:8px;border-top:1px solid var(--border-light)}.topic-detail-item{display:flex;align-items:center;gap:4px;font-size:.73rem;color:var(--text-muted);font-weight:500}.topic-detail-item svg{color:var(--text-muted);flex-shrink:0}.topic-tests-preview{margin-top:10px;padding-top:10px;border-top:1px solid var(--border-light);display:flex;flex-direction:column;gap:6px}.topic-test-row{display:flex;justify-content:space-between;align-items:center;gap:8px}.topic-test-name{font-size:.78rem;font-weight:600;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.topic-test-detail{font-size:.7rem;color:var(--text-muted);white-space:nowrap;flex-shrink:0}.topic-test-more{font-size:.7rem;color:var(--primary);font-weight:600;margin-top:2px}.expanded-content{background:var(--card-bg);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:var(--radius);padding:24px;margin-bottom:20px;animation:slideDown .3s ease;box-shadow:var(--shadow-md)}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.expanded-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.expanded-header h3{font-size:1.1rem;font-weight:700;color:var(--text)}.btn-close{background:var(--border-light);border:1px solid var(--border);border-radius:10px;padding:6px;cursor:pointer;color:var(--text-secondary);display:flex;transition:all var(--transition-base)}.btn-close:hover{background:var(--danger-light);color:var(--danger);border-color:#ef444433}.calendar-view{background:var(--card-bg);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:var(--radius);padding:20px;position:relative;box-shadow:var(--card-shadow)}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.calendar-header h3{font-size:.95rem;font-weight:700;color:var(--text)}.calendar-nav{width:32px;height:32px;border-radius:8px;border:1px solid var(--border);background:var(--card-bg);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base)}.calendar-nav:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-50)}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:4px}.weekday{text-align:center;font-size:.7rem;font-weight:600;color:var(--text-muted);padding:6px 0;text-transform:uppercase;letter-spacing:.05em}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.calendar-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:10px;cursor:pointer;transition:all var(--transition-fast);position:relative;font-size:.82rem}.calendar-day:hover:not(.empty){background:var(--border-light)}.calendar-day.today{background:var(--primary-gradient);color:#fff;font-weight:700;box-shadow:var(--shadow-primary)}.calendar-day.today:hover{background:var(--primary-gradient-hover)}.calendar-day.has-events{font-weight:600}.calendar-day.has-events:after{content:"";width:4px;height:4px;background:var(--primary);border-radius:50%;position:absolute;bottom:4px}.calendar-day.today.has-events:after{background:#fff}.day-number{font-size:.82rem;line-height:1}.event-important-symbol{position:absolute;top:2px;right:2px;color:var(--warning);font-size:.6rem}.calendar-day.today .event-important-symbol{color:#fff}.calendar-popup-overlay{position:fixed;inset:0;background:#0009;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .2s ease;isolation:isolate}.calendar-popup-modal{background:var(--card-bg);border-radius:var(--radius-xl);padding:28px;max-width:480px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 25px 60px #0000004d;border:1px solid var(--border);animation:popupSlideIn .25s ease}@keyframes popupSlideIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.popup-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.popup-header h3{font-size:1.1rem;font-weight:700;color:var(--text)}.popup-close-btn{width:32px;height:32px;border-radius:10px;border:none;background:var(--border-light);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base)}.popup-close-btn:hover{background:var(--danger-light);color:var(--danger)}.popup-content{display:flex;flex-direction:column;gap:14px}.popup-assessment-card{background:var(--bg-main);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.popup-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.subject-tag{padding:3px 10px;border-radius:var(--radius-full);font-size:.7rem;font-weight:600;background:var(--badge-subject-bg);color:var(--badge-subject-text)}.status-badge{padding:3px 10px;border-radius:var(--radius-full);font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.popup-assessment-card h4{font-size:.95rem;font-weight:700;color:var(--text);margin-bottom:4px}.popup-instructor{font-size:.78rem;color:var(--text-muted);margin-bottom:10px}.popup-details{display:flex;flex-direction:column;gap:4px}.popup-timing,.popup-duration{display:flex;align-items:center;gap:6px;font-size:.78rem;color:var(--text-secondary);margin:0}.popup-score{font-size:.78rem;font-weight:600;color:var(--success);margin:0}.detail-icon{display:flex;color:var(--text-muted)}.activity-feed{background:var(--card-bg);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--card-shadow)}.feed-title{font-size:.95rem;font-weight:700;color:var(--text);margin-bottom:16px}.activity-list{display:flex;flex-direction:column;gap:12px}.activity-item{display:flex;gap:12px;animation:fadeIn .3s ease backwards}.activity-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.activity-content{flex:1;min-width:0}.activity-header{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.activity-title{font-size:.82rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.activity-time{font-size:.7rem;color:var(--text-muted);white-space:nowrap;flex-shrink:0}.activity-description{font-size:.75rem;color:var(--text-muted);margin-top:2px;line-height:1.4}.activity-empty{text-align:center;padding:32px 0;color:var(--text-muted)}.empty-icon{display:block;margin-bottom:8px;opacity:.5}.assessment-search-bar{position:relative;display:flex;align-items:center;margin-bottom:20px}.assessment-search-icon{position:absolute;left:14px;display:flex;align-items:center;color:var(--text-muted);pointer-events:none}.assessment-search-input{width:100%;padding:10px 40px;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:.9rem;font-family:inherit;outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.assessment-search-input::placeholder{color:var(--text-muted)}.assessment-search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-100)}.assessment-search-clear{position:absolute;right:12px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--text-muted);padding:4px;border-radius:50%;transition:color var(--transition-fast),background var(--transition-fast)}.assessment-search-clear:hover{color:var(--text);background:var(--border-light)}.empty-state{background:var(--card-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px dashed var(--border);border-radius:var(--radius);padding:48px 24px;text-align:center}.empty-state p{color:var(--text-muted);font-size:.9rem}.login-page-v2{height:100vh;display:flex;background:var(--bg-main);overflow:hidden;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;min-height:0}.login-page-v2>*{overflow-y:auto;overflow-x:hidden}.login-showcase{flex:1.15;background:linear-gradient(145deg,#1e0a3c,#2d1066,#4c1d95,#6d28d9,#7c3aed);display:flex;align-items:flex-start;justify-content:center;position:relative;overflow-y:auto;overflow-x:hidden;scrollbar-width:none}.showcase-bg-layer{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 20% 80%,rgba(139,92,246,.3) 0%,transparent 60%),radial-gradient(ellipse 60% 50% at 80% 20%,rgba(99,102,241,.25) 0%,transparent 50%);animation:bgPulse 8s ease-in-out infinite alternate}@keyframes bgPulse{0%{opacity:.7}to{opacity:1}}.showcase-mesh-1,.showcase-mesh-2,.showcase-mesh-3{position:absolute;border-radius:50%;pointer-events:none;filter:blur(60px)}.showcase-mesh-1{top:-15%;right:-10%;width:500px;height:500px;background:radial-gradient(circle,rgba(167,139,250,.4) 0%,rgba(139,92,246,.15) 40%,transparent 70%);animation:meshFloat1 12s ease-in-out infinite}.showcase-mesh-2{bottom:-20%;left:-5%;width:450px;height:450px;background:radial-gradient(circle,rgba(99,102,241,.35) 0%,rgba(79,70,229,.1) 50%,transparent 70%);animation:meshFloat2 15s ease-in-out infinite}.showcase-mesh-3{top:40%;left:30%;width:300px;height:300px;background:radial-gradient(circle,rgba(196,181,253,.2) 0%,transparent 60%);animation:meshFloat3 10s ease-in-out infinite}@keyframes meshFloat1{0%,to{transform:translate(0) scale(1)}33%{transform:translate(-20px,15px) scale(1.08)}66%{transform:translate(10px,-10px) scale(.95)}}@keyframes meshFloat2{0%,to{transform:translate(0) scale(1)}50%{transform:translate(25px,-20px) scale(1.1)}}@keyframes meshFloat3{0%,to{transform:translate(0) scale(1) rotate(0)}50%{transform:translate(-15px,10px) scale(1.15) rotate(5deg)}}.showcase-particles{position:absolute;inset:0;pointer-events:none}.particle{position:absolute;border-radius:50%;background:#ffffff26;animation:particleDrift linear infinite}@keyframes particleDrift{0%{transform:translateY(0) translate(0) scale(1);opacity:0}10%{opacity:.6}90%{opacity:.6}to{transform:translateY(-100vh) translate(40px) scale(.3);opacity:0}}.showcase-grid-pattern{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:40px 40px;pointer-events:none;mask-image:radial-gradient(ellipse 70% 70% at center,black,transparent);-webkit-mask-image:radial-gradient(ellipse 70% 70% at center,black,transparent)}.showcase-shimmer{position:absolute;top:0;left:-100%;width:200%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.02) 25%,rgba(255,255,255,.06) 50%,rgba(255,255,255,.02) 75%,transparent 100%);animation:showcaseShimmer 10s ease-in-out infinite;pointer-events:none}@keyframes showcaseShimmer{0%{transform:translate(-50%)}to{transform:translate(50%)}}.showcase-content{position:relative;z-index:2;padding:24px 44px;max-width:540px;color:#fff;margin:auto 0}.showcase-logo-group{display:flex;align-items:center;gap:10px;margin-bottom:18px}.showcase-logo{width:36px;height:36px;filter:brightness(10) drop-shadow(0 0 8px rgba(255,255,255,.3))}.showcase-logo-text{font-size:1.15rem;font-weight:800;letter-spacing:-.03em;background:linear-gradient(135deg,#fff,#c4b5fd);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.showcase-headline{font-size:clamp(1.8rem,2.2vw,2.5rem);font-weight:900;line-height:1.1;letter-spacing:-.04em;margin-bottom:14px;color:#fff}.showcase-headline-accent{color:#ffffffb3}.showcase-headline-glow{background:linear-gradient(135deg,#c4b5fd,#a78bfa,#818cf8 60%,#22d3ee);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 0 20px rgba(167,139,250,.3))}.showcase-tagline{font-size:.9rem;line-height:1.6;color:#fff9;margin-bottom:18px;max-width:440px}.showcase-features{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}.showcase-feature{display:flex;align-items:center;gap:12px;padding:11px 16px;background:#ffffff0f;border:1px solid rgba(255,255,255,.08);border-radius:12px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:all .3s ease}.showcase-feature:hover{background:#ffffff1a;border-color:#ffffff26;transform:translate(6px);box-shadow:0 4px 20px #00000026}.feature-icon{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,#8b5cf666,#6366f14d);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#c4b5fd;box-shadow:0 0 16px #8b5cf626}.feature-text{display:flex;flex-direction:column;gap:2px}.feature-title{font-size:.82rem;font-weight:700;color:#fff;letter-spacing:-.01em}.feature-desc{font-size:.72rem;color:#ffffff80;line-height:1.3}.showcase-stats{display:flex;align-items:center;gap:20px;padding:14px 20px;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:14px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.showcase-stat{display:flex;flex-direction:column;align-items:center;gap:2px;flex:1}.stat-number{font-size:1.15rem;font-weight:800;color:#fff;letter-spacing:-.03em}.showcase-stats .stat-label{font-size:.72rem;color:#ffffff73;font-weight:500;text-transform:uppercase;letter-spacing:.06em}.showcase-stat-divider{width:1px;height:32px;background:#ffffff1a}.login-form-panel{flex:.85;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:24px 36px;position:relative;overflow-y:auto;overflow-x:hidden;background:var(--bg-main);min-width:440px;scrollbar-width:none}.form-panel-orb{position:absolute;border-radius:50%;pointer-events:none;filter:blur(80px)}.form-panel-orb--1{top:-10%;right:-15%;width:350px;height:350px;background:radial-gradient(circle,rgba(99,102,241,.08) 0%,transparent 70%);animation:formOrbFloat 10s ease-in-out infinite}.form-panel-orb--2{bottom:-10%;left:-10%;width:300px;height:300px;background:radial-gradient(circle,rgba(139,92,246,.06) 0%,transparent 70%);animation:formOrbFloat 12s ease-in-out infinite reverse}[data-theme=dark] .form-panel-orb--1{background:radial-gradient(circle,rgba(129,140,248,.08) 0%,transparent 70%)}[data-theme=dark] .form-panel-orb--2{background:radial-gradient(circle,rgba(167,139,250,.06) 0%,transparent 70%)}@keyframes formOrbFloat{0%,to{transform:translate(0) scale(1)}50%{transform:translate(-10px,8px) scale(1.05)}}.login-v2-theme-toggle{position:absolute;top:24px;right:28px;z-index:10}.login-v2-card{width:100%;max-width:400px;padding:28px 32px 24px;border-radius:var(--radius-xl);border:1px solid var(--border);position:relative;z-index:2;flex-shrink:0;margin:auto 0;backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);background:#ffffffeb;box-shadow:0 24px 60px #00000014,0 8px 24px #6366f10a,0 0 0 1px #fff6 inset}[data-theme=dark] .login-v2-card{background:#11182dbf;border-color:#ffffff0f;box-shadow:0 24px 60px #00000080,0 8px 24px #0003,0 0 0 1px #ffffff0a inset}.login-v2-header{text-align:center;margin-bottom:20px}.login-v2-mobile-logo{display:none;align-items:center;justify-content:center;gap:10px;margin-bottom:20px}.login-v2-mobile-logo img{width:36px;height:36px}.login-v2-mobile-logo span{font-size:1.15rem;font-weight:800;letter-spacing:-.02em;background:var(--primary-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-v2-title{font-size:1.35rem;font-weight:800;color:var(--text);letter-spacing:-.03em;margin-bottom:4px;line-height:1.2}.login-v2-subtitle{color:var(--text-muted);font-size:.85rem;line-height:1.5}.login-v2-form{display:flex;flex-direction:column;gap:14px}.login-v2-field{display:flex;flex-direction:column;gap:5px;position:relative}.login-v2-field label{font-size:.82rem;font-weight:600;color:var(--text-secondary);display:flex;align-items:center;gap:6px;transition:color var(--transition-base)}.login-v2-field label svg{color:var(--text-muted);transition:color var(--transition-base)}.login-v2-field.focused label{color:var(--primary)}.login-v2-field.focused label svg{color:var(--primary)}.login-v2-field input{width:100%;padding:12px 16px;border:1.5px solid var(--border);border-radius:12px;font-size:.9rem;font-family:Inter,sans-serif;color:var(--text);background:var(--bg-main);transition:all var(--transition-base);outline:none}.login-v2-field input:focus{border-color:var(--primary);box-shadow:0 0 0 3.5px var(--primary-100),0 0 16px #6366f114;background:var(--card-bg)}.login-v2-field input::placeholder{color:var(--text-muted);font-weight:400}.login-v2-field.has-value input{border-color:var(--primary-200)}.login-v2-password-wrapper{position:relative;display:flex;align-items:center}.login-v2-password-wrapper input{padding-right:48px}.login-v2-eye-btn{position:absolute;right:14px;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);border-radius:8px}.login-v2-eye-btn:hover{color:var(--primary);background:var(--primary-50)}.login-v2-error{display:flex;align-items:center;gap:8px;background:var(--danger-light);color:var(--danger);padding:11px 16px;border-radius:12px;font-size:.82rem;font-weight:500;border:1px solid rgba(239,68,68,.15);overflow:hidden}.login-v2-error svg{flex-shrink:0}.login-v2-submit{width:100%;padding:13px;border-radius:12px;border:none;background:linear-gradient(135deg,#6366f1,#7c3aed,#8b5cf6);color:#fff;font-weight:700;font-size:.92rem;cursor:pointer;transition:all .35s cubic-bezier(.4,0,.2,1);font-family:Inter,sans-serif;letter-spacing:.01em;box-shadow:0 4px 16px #6366f14d,0 0 #6366f100;position:relative;overflow:hidden;margin-top:2px}.login-v2-submit:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.15) 0%,transparent 50%,rgba(255,255,255,.05) 100%);opacity:0;transition:opacity .3s ease}.login-v2-submit:hover:not(:disabled):before{opacity:1}.login-v2-submit:hover:not(:disabled){box-shadow:0 8px 28px #6366f166,0 0 0 2px #6366f126;transform:translateY(-2px)}.login-v2-submit:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #6366f14d}.login-v2-submit:disabled{opacity:.7;cursor:not-allowed}.login-v2-submit-content{display:flex;align-items:center;justify-content:center;gap:8px}.login-v2-submit-content svg{transition:transform .3s ease}.login-v2-submit:hover:not(:disabled) .login-v2-submit-content svg{transform:translate(4px)}.login-v2-spinner-wrapper{display:flex;align-items:center;justify-content:center;gap:10px}.login-v2-spinner{width:18px;height:18px;border:2.5px solid rgba(255,255,255,.25);border-top:2.5px solid white;border-radius:50%;animation:loginSpin .7s linear infinite;display:inline-block}@keyframes loginSpin{to{transform:rotate(360deg)}}.login-v2-divider{display:flex;align-items:center;width:100%;margin:16px 0 14px;gap:0}.login-v2-divider-line{flex:1;height:1px;background:var(--border)}.login-v2-divider-text{padding:0 16px;color:var(--text-muted);font-size:.78rem;font-weight:500;white-space:nowrap;text-transform:uppercase;letter-spacing:.06em}.login-v2-google{display:flex;justify-content:center;width:100%}.login-v2-footer{text-align:center;font-size:.72rem;color:var(--text-muted);margin-top:14px;line-height:1.5}.login-v2-footer a{color:var(--primary);text-decoration:none;font-weight:500;transition:color var(--transition-base)}.login-v2-footer a:hover{text-decoration:underline}.login-v2-copyright{position:relative;bottom:auto;margin-top:12px;flex-shrink:0;font-size:.72rem;color:var(--text-muted);letter-spacing:.02em;padding-bottom:8px}@media(max-width:1024px){.login-showcase{flex:1}.login-form-panel{flex:1;min-width:400px}.showcase-content{padding:40px 36px}.showcase-headline{font-size:2rem}.showcase-features{gap:10px}}@media(max-width:768px){.login-page-v2{flex-direction:column}.login-showcase{display:none}.login-form-panel{flex:1;min-width:0;padding:24px 20px;justify-content:center}.login-v2-mobile-logo{display:flex}.login-v2-card{max-width:100%;padding:28px 24px 24px}.login-v2-title{font-size:1.3rem}.login-v2-copyright{position:relative;bottom:auto;margin-top:20px}}@media(max-width:400px){.login-form-panel{padding:16px 14px}.login-v2-card{padding:24px 18px 20px;border-radius:var(--radius-lg)}.login-v2-field input{padding:12px 14px}.login-v2-submit{padding:13px}}.calendar-view,.activity-feed{backdrop-filter:blur(12px) saturate(150%);-webkit-backdrop-filter:blur(12px) saturate(150%);background:#ffffffe0;border:1px solid rgba(255,255,255,.35);box-shadow:0 4px 20px #0000000a,0 0 0 1px #ffffff26 inset}[data-theme=dark] .calendar-view,[data-theme=dark] .activity-feed{background:#11182da6;border:1px solid rgba(255,255,255,.05);box-shadow:0 4px 20px #0000004d,0 0 0 1px #ffffff08 inset}.topic-box{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#ffffffd9;box-shadow:0 2px 8px #00000008,0 0 0 1px #ffffff1a inset}[data-theme=dark] .topic-box{background:#11182d99}.expanded-content{backdrop-filter:blur(16px) saturate(160%);-webkit-backdrop-filter:blur(16px) saturate(160%);background:#ffffffe6;box-shadow:0 8px 30px #0000000f,0 0 0 1px #fff3 inset}[data-theme=dark] .expanded-content{background:#11182dbf;box-shadow:0 8px 30px #0006,0 0 0 1px #ffffff0a inset}.calendar-popup-modal{background:var(--card-bg);box-shadow:0 25px 60px #00000026,0 0 0 1px #ffffff40 inset}.fullscreen-content,.success-content,.summary-card{backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);background:#ffffffeb;box-shadow:0 24px 60px #0000001f,0 0 0 1px #ffffff40 inset}[data-theme=dark] .calendar-popup-modal{background:var(--card-bg);box-shadow:0 25px 60px #00000080,0 0 0 1px #ffffff0a inset}[data-theme=dark] .fullscreen-content,[data-theme=dark] .success-content,[data-theme=dark] .summary-card{background:#11182dd9;box-shadow:0 24px 60px #0009,0 0 0 1px #ffffff0a inset}.exam-container{min-height:100vh}.exam-header{height:64px;display:flex;justify-content:space-between;align-items:center;padding:0 28px;background:var(--card-bg);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50;box-shadow:var(--shadow-xs)}.exam-header-enhanced{backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);background:#ffffffe0;border-bottom:1px solid rgba(255,255,255,.2)}[data-theme=dark] .exam-header-enhanced{background:#0f1324d9;border-bottom:1px solid rgba(255,255,255,.04)}.exam-header .header-right{display:flex;align-items:center;gap:16px}.student-info{display:flex;align-items:center;gap:10px}.student-info .avatar{width:36px;height:36px;border-radius:50%;object-fit:cover}.tab-switch-badge{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:8px;background:var(--danger-light);color:var(--danger);font-size:.78rem;font-weight:700;border:1px solid rgba(239,68,68,.2);animation:tabBadgePulse 2s ease-in-out infinite}@keyframes tabBadgePulse{0%,to{box-shadow:0 0 #ef444433}50%{box-shadow:0 0 0 6px #ef444400}}.tab-switch-warning{position:sticky;top:64px;z-index:45;display:flex;align-items:center;justify-content:space-between;padding:10px 28px;background:linear-gradient(135deg,#fef3c7,#fbbf24);border-bottom:2px solid #F59E0B;color:#92400e;font-size:.84rem;font-weight:600}[data-theme=dark] .tab-switch-warning{background:linear-gradient(135deg,#d9770626,#fbbf241a);border-bottom-color:#f59e0b4d;color:#fcd34d}.tab-warning-content{display:flex;align-items:center;gap:10px}.tab-warning-close{background:none;border:none;cursor:pointer;color:inherit;padding:4px;border-radius:4px;transition:background .2s}.tab-warning-close:hover{background:#0000001a}.timer{display:flex;align-items:center;gap:6px;font-family:JetBrains Mono,monospace;font-weight:600;background:var(--border-light);color:var(--text);padding:8px 16px;border-radius:10px;font-size:.95rem;transition:all var(--transition-base);border:1px solid var(--border)}.timer-warning{background:#fef3c7;color:#d97706;border-color:#d9770633}.timer-critical{background:var(--danger-light);color:var(--danger);border-color:#ef444426;animation:timerCriticalPulse 1s ease-in-out infinite}@keyframes timerCriticalPulse{0%,to{box-shadow:0 0 #ef44444d}50%{box-shadow:0 0 0 8px #ef444400}}.timer.pulse{animation:timerPulse .5s ease 3}@keyframes timerPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05);box-shadow:0 0 16px #ef44444d}}.time-display{font-family:JetBrains Mono,monospace}.progress-submit-row{display:flex;align-items:center;gap:16px;padding:12px 28px;background:var(--card-bg);border-bottom:1px solid var(--border-light)}.progress-container{flex:1;display:flex;align-items:center;gap:12px}.progress-bar{flex:1;height:6px;background:var(--border-light);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:var(--primary-gradient);border-radius:3px;transition:width .4s ease}.progress-text{font-size:.78rem;font-weight:600;color:var(--text-secondary);white-space:nowrap}.main-content{display:grid;grid-template-columns:1fr 300px;gap:24px;padding:24px 28px;max-width:1400px;margin:0 auto}.question-section{display:flex;flex-direction:column;gap:20px}.question-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:28px;box-shadow:var(--card-shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:all .3s ease}.question-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--border-light)}.question-no{font-size:.82rem;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.05em}.marks{font-size:.78rem;font-weight:600;color:var(--text-muted);background:var(--border-light);padding:4px 12px;border-radius:var(--radius-full)}.question-text{font-size:1.05rem;font-weight:500;color:var(--text);line-height:1.7}.options{display:flex;flex-direction:column;gap:10px}.option-card{display:flex;align-items:center;gap:14px;padding:14px 18px;border:1.5px solid var(--border);border-radius:12px;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);font-size:.92rem;color:var(--text);background:var(--card-bg);position:relative;overflow:hidden}.option-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:transparent;transition:background .3s}.option-card:hover{border-color:var(--primary-200);background:var(--primary-50);transform:translate(4px)}.option-card:hover:before{background:var(--primary-200)}.option-card.selected{border-color:var(--primary);background:var(--primary-50);box-shadow:0 0 0 3px var(--primary-100),var(--shadow-glow);transform:translate(4px)}.option-card.selected:before{background:var(--primary)}.option-card input[type=radio]{width:18px;height:18px;accent-color:var(--primary);cursor:pointer;flex-shrink:0}.option-card span{line-height:1.5}.navigation-buttons{display:flex;gap:10px;flex-wrap:wrap}.navigation-buttons button{padding:10px 18px;border-radius:10px;font-weight:600;font-size:.85rem;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);font-family:Inter,sans-serif;border:1px solid var(--border);background:var(--card-bg);color:var(--text-secondary)}.navigation-buttons button:hover:not(:disabled){background:var(--border-light);color:var(--text);transform:translateY(-1px)}.navigation-buttons button:disabled{opacity:.4;cursor:not-allowed}.btn-next,.btn-submit-final{background:var(--primary-gradient)!important;color:#fff!important;border:none!important;box-shadow:var(--shadow-primary)!important}.btn-next:hover,.btn-submit-final:hover{box-shadow:var(--shadow-primary-lg)!important;transform:translateY(-2px)!important}.btn-mark{border-color:var(--mark-review)!important;color:var(--mark-review)!important}.btn-mark:hover{background:#f9731614!important}.sidebar{display:flex;flex-direction:column;gap:16px}.sidebar h3{font-size:.95rem;font-weight:700;color:var(--text)}.palette-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:6px}.palette-btn{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:10px;font-size:.78rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);border:1.5px solid var(--border);background:var(--card-bg);color:var(--text-secondary)}.palette-btn:hover{transform:scale(1.08)}.palette-btn.current{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:var(--shadow-primary)}.palette-btn.answered{background:var(--success);color:#fff;border-color:var(--success)}.palette-btn.marked{background:var(--mark-review);color:#fff;border-color:var(--mark-review)}.palette-btn.not-answered{background:var(--danger-light);color:var(--danger);border-color:var(--danger)}.palette-btn.not-visited{background:var(--border-light);color:var(--text-muted);border-color:var(--border)}.summary{display:flex;flex-direction:column;gap:8px;padding:14px;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius)}.summary-item{display:flex;align-items:center;gap:8px;font-size:.78rem;color:var(--text-secondary);font-weight:500}.dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}.dot.current{background:var(--primary)}.dot.answered{background:var(--success)}.dot.marked{background:var(--mark-review)}.dot.not-answered{background:var(--danger)}.dot.not-visited{background:var(--text-muted)}.legend{padding:14px;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);display:flex;flex-direction:column;gap:6px;font-size:.75rem;color:var(--text-secondary)}.legend h4{font-size:.82rem;font-weight:700;color:var(--text);margin-bottom:4px}.legend div{display:flex;align-items:center;gap:8px}.btn-submit{padding:12px 24px;background:var(--primary-gradient);color:#fff;border:none;border-radius:12px;font-weight:700;font-size:.9rem;cursor:pointer;transition:all var(--transition-base);font-family:Inter,sans-serif;box-shadow:var(--shadow-primary)}.btn-submit:hover:not(:disabled){background:var(--primary-gradient-hover);box-shadow:var(--shadow-primary-lg);transform:translateY(-1px)}.btn-submit:disabled{opacity:.5;cursor:not-allowed}.btn-submit-small{padding:8px 18px;font-size:.82rem}.fullscreen-modal{position:fixed;inset:0;background:#0009;backdrop-filter:blur(12px) saturate(120%);-webkit-backdrop-filter:blur(12px) saturate(120%);display:flex;align-items:center;justify-content:center;z-index:1000}.fullscreen-content{background:var(--card-bg);border-radius:var(--radius-xl);padding:36px;max-width:640px;width:90%;max-height:85vh;overflow-y:auto;box-shadow:0 24px 60px #0003;border:1px solid var(--border);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}[data-theme=dark] .fullscreen-content{background:#11182deb;box-shadow:0 24px 60px #00000080}.confirmation-header{text-align:center;margin-bottom:28px}.confirmation-header h2{font-size:1.3rem;font-weight:800;color:var(--text);margin-bottom:6px;letter-spacing:-.02em}.confirmation-header p{color:var(--text-muted);font-size:.88rem}.confirmation-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:28px}.stat-item{text-align:center;padding:14px 8px;border-radius:var(--radius);background:var(--border-light);border:1px solid var(--border);transition:all .3s ease}.stat-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-item .stat-value{display:block;font-size:1.5rem;font-weight:800;color:var(--text)}.stat-item .stat-label{display:block;font-size:.7rem;color:var(--text-muted);margin-top:4px;font-weight:500}.stat-item.answered{border-left:3px solid var(--success)}.stat-item.marked{border-left:3px solid var(--mark-review)}.stat-item.not-answered{border-left:3px solid var(--danger)}.stat-item.not-visited{border-left:3px solid var(--text-muted)}.confirmation-palette{margin-bottom:20px}.confirmation-palette h3{font-size:.95rem;font-weight:700;color:var(--text);margin-bottom:14px}.palette-grid-large{display:grid;grid-template-columns:repeat(8,1fr);gap:8px}.palette-item{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:10px;font-size:.82rem;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.34,1.56,.64,1)}.palette-item:hover{transform:scale(1.1)}.palette-item.answered{background:var(--success);color:#fff}.palette-item.marked{background:var(--mark-review);color:#fff}.palette-item.not-answered{background:var(--danger-light);color:var(--danger);border:1px solid var(--danger)}.palette-item.not-visited{background:var(--border-light);color:var(--text-muted);border:1px solid var(--border)}.confirmation-legend{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:24px;justify-content:center}.legend-item{display:flex;align-items:center;gap:6px;font-size:.75rem;color:var(--text-secondary)}.confirmation-actions{display:flex;gap:12px;justify-content:center}.btn-back-to-test{padding:12px 24px;border-radius:12px;border:1px solid var(--border);background:var(--card-bg);color:var(--text-secondary);font-weight:600;font-size:.88rem;cursor:pointer;transition:all .3s ease;font-family:Inter,sans-serif}.btn-back-to-test:hover{background:var(--border-light);color:var(--text);transform:translateY(-1px)}.btn-confirm-submit{padding:12px 28px;border-radius:12px;border:none;background:var(--primary-gradient);color:#fff;font-weight:700;font-size:.88rem;cursor:pointer;transition:all .3s ease;font-family:Inter,sans-serif;box-shadow:var(--shadow-primary)}.btn-confirm-submit:hover{background:var(--primary-gradient-hover);box-shadow:var(--shadow-primary-lg);transform:translateY(-1px)}.fullscreen-prompt-overlay{position:fixed;inset:0;z-index:2000;background:#000000b3;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);display:flex;align-items:center;justify-content:center}.fullscreen-prompt-card{background:var(--card-bg);border-radius:var(--radius-xl);padding:40px;text-align:center;max-width:420px;width:90%;box-shadow:0 24px 60px #0000004d;border:1px solid var(--border)}.fullscreen-prompt-icon{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;box-shadow:0 8px 24px #6366f14d}.fullscreen-prompt-card h3{font-size:1.2rem;font-weight:800;color:var(--text);margin:0 0 8px;letter-spacing:-.02em}.fullscreen-prompt-card p{color:var(--text-muted);font-size:.88rem;line-height:1.6;margin:0 0 24px}.success-modal{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;z-index:1000}.success-content-enhanced{background:var(--card-bg);border-radius:var(--radius-xl);padding:48px 40px;text-align:center;max-width:480px;width:90%;box-shadow:0 24px 80px #0003;border:1px solid var(--border);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);overflow:hidden;position:relative}[data-theme=dark] .success-content-enhanced{background:#11182deb;box-shadow:0 24px 80px #00000080}.success-content-enhanced:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at center,rgba(16,185,129,.06) 0%,transparent 50%);pointer-events:none}.success-check-circle{width:88px;height:88px;border-radius:50%;background:linear-gradient(135deg,#d1fae5,#a7f3d0);display:flex;align-items:center;justify-content:center;margin:0 auto 24px;color:#059669;box-shadow:0 8px 24px #10b98133}[data-theme=dark] .success-check-circle{background:linear-gradient(135deg,#10b98133,#05966926)}.success-content-enhanced h2{font-size:1.4rem;font-weight:800;color:var(--text);margin:0 0 20px;letter-spacing:-.02em}.success-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}.success-stat{padding:14px 10px;border-radius:var(--radius);background:var(--border-light);border:1px solid var(--border);text-align:center}.success-stat-value{display:block;font-size:1.2rem;font-weight:800;color:var(--primary);line-height:1.2}.success-stat-label{display:block;font-size:.7rem;color:var(--text-muted);margin-top:4px;font-weight:500}.success-stat-warn{border-color:var(--danger)}.success-stat-warn .success-stat-value{color:var(--danger)}.success-progress-bar{height:4px;border-radius:2px;background:var(--border-light);overflow:hidden;margin-top:16px}.success-progress-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,#6366f1,#8b5cf6)}.redirect-text{color:var(--text-muted)!important;font-size:.82rem!important;margin-top:4px!important;margin-bottom:0!important}.loading-spinner{width:28px;height:28px;border:3px solid var(--border);border-top:3px solid var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin:16px auto 0}.rules-page{min-height:100vh;background:var(--bg-main);padding:32px}.rules-container{max-width:1100px;margin:0 auto}.rules-split-layout{display:grid;grid-template-columns:2fr 1fr;gap:24px}.profile-page{animation:fadeIn .4s ease}.profile-cover-banner{height:180px;border-radius:var(--radius-lg);overflow:hidden;position:relative;margin-bottom:-60px}.cover-gradient{width:100%;height:100%;background:linear-gradient(135deg,#ff6b35,#f7c948,#e8553d,#cc2d4a,#7b2d8e);position:relative}.cover-gradient:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 40%,rgba(255,255,255,.15) 0%,transparent 50%),radial-gradient(circle at 20% 80%,rgba(0,0,0,.1) 0%,transparent 40%)}.profile-header-section{display:grid;grid-template-columns:260px 1fr;gap:24px;position:relative;z-index:2}.profile-info-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px 24px;text-align:center;box-shadow:var(--card-shadow);position:relative}.profile-info-card .profile-avatar-section{display:flex;justify-content:center;margin-bottom:16px}.profile-info-card .avatar-upload-wrapper{position:relative;cursor:pointer;border-radius:50%;overflow:hidden;width:90px;height:90px}.profile-info-card .profile-avatar-large{width:90px;height:90px;border-radius:50%;object-fit:cover;display:block}.profile-avatar-placeholder{width:90px;height:90px;border-radius:50%;background:var(--bg-main);border:2px solid var(--border);display:flex;align-items:center;justify-content:center}.profile-info-card .avatar-upload-overlay{position:absolute;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-base);border-radius:50%}.avatar-upload-wrapper:hover .avatar-upload-overlay{opacity:1}.hidden-input{display:none}.profile-name{font-size:1.15rem;font-weight:700;color:var(--text);margin-bottom:12px;letter-spacing:-.01em}.profile-divider{height:1px;background:var(--border);margin:16px 0}.profile-personal-info{text-align:left}.profile-personal-info h4{font-size:.88rem;font-weight:700;color:var(--text);margin-bottom:14px;display:flex;align-items:center;gap:8px}.edit-link{font-size:.78rem;color:#6366f1;cursor:pointer;font-weight:500}.edit-link:hover{text-decoration:underline}.info-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border-light)}.info-row:last-child{border-bottom:none}.info-label{font-size:.82rem;color:var(--text-muted);font-weight:500}.info-value{font-size:.82rem;color:var(--text);font-weight:600;text-overflow:ellipsis;overflow:hidden;max-width:120px;white-space:nowrap}.profile-right-section{display:flex;flex-direction:column;gap:20px;padding-top:68px}.profile-info-pills{display:flex;gap:16px;flex-wrap:wrap}.info-pill{display:flex;align-items:center;gap:10px;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:10px 18px;box-shadow:var(--card-shadow)}.pill-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.pill-content{display:flex;flex-direction:column}.pill-label{font-size:.7rem;color:var(--text-muted);font-weight:500}.pill-value{font-size:.82rem;font-weight:600;color:var(--text)}.profile-tabs{display:flex;gap:4px;background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:4px;overflow-x:auto}.profile-tab{padding:10px 20px;border-radius:10px;border:none;background:transparent;color:var(--text-secondary);font-size:.82rem;font-weight:500;cursor:pointer;transition:all var(--transition-base);font-family:Inter,sans-serif;white-space:nowrap}.profile-tab:hover{background:var(--border-light);color:var(--text)}.profile-tab.active{background:var(--primary);color:#fff;font-weight:600;box-shadow:var(--shadow-primary)}.profile-tab-content{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--card-shadow)}.tab-panel h3{font-size:1.05rem;font-weight:700;color:var(--text);margin-bottom:20px}.profile-details-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.profile-detail-item{display:flex;flex-direction:column;gap:4px;padding:14px;background:var(--bg-main);border-radius:10px;border:1px solid var(--border-light)}.detail-label{font-size:.75rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.detail-value{font-size:.95rem;font-weight:700;color:var(--text)}.overview-section{animation:fadeIn .3s ease .1s backwards}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.settings-section{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;box-shadow:var(--card-shadow)}.settings-section h3{font-size:1.1rem;font-weight:700;color:var(--text);margin-bottom:20px}.setting-item{display:flex;justify-content:space-between;align-items:center;padding:14px 0;border-bottom:1px solid var(--border-light)}.setting-item:last-of-type{border-bottom:none}.setting-info h4{font-size:.9rem;font-weight:600;color:var(--text);margin-bottom:2px}.setting-info p{font-size:.78rem;color:var(--text-muted)}.toggle-switch{position:relative;display:inline-block;width:44px;height:24px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background:var(--border);border-radius:12px;transition:all var(--transition-base)}.toggle-slider:before{content:"";position:absolute;height:18px;width:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:all var(--transition-base);box-shadow:0 1px 3px #00000026}.toggle-switch input:checked+.toggle-slider{background:var(--primary)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(20px)}.accent-color-picker{padding:16px 0}.accent-color-picker h4{font-size:.88rem;font-weight:600;color:var(--text);margin-bottom:12px}.color-options{display:flex;gap:10px}.color-option{width:36px;height:36px;border-radius:10px;border:2px solid var(--border);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);background:none;position:relative}.color-option.selected{border-color:var(--option-color);box-shadow:0 0 0 2px var(--option-color)}.color-swatch{width:20px;height:20px;border-radius:6px;display:block}.color-check{position:absolute;color:#fff;font-size:.7rem}.color-name{font-size:.75rem;color:var(--text-muted);margin-top:8px}.analytics-page{animation:fadeIn .4s ease}.analytics-content-grid{display:grid;grid-template-columns:2fr 1fr;gap:24px}.summary-modal{position:fixed;inset:0;background:#0009;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .2s ease}.summary-card{background:var(--card-bg);border-radius:var(--radius-xl);padding:32px;max-width:520px;width:90%;max-height:85vh;overflow-y:auto;box-shadow:0 25px 60px #0003;position:relative;border:1px solid var(--border)}.btn-close-modal{position:absolute;top:16px;right:16px;width:32px;height:32px;border-radius:10px;border:none;background:var(--border-light);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);z-index:2}.btn-close-modal:hover{background:var(--danger-light);color:var(--danger)}.summary-detail-header{text-align:center;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid var(--border-light)}.summary-detail-badges{display:flex;justify-content:center;gap:8px;margin-bottom:14px}.summary-detail-title{font-size:1.25rem;font-weight:800;color:var(--text);margin:0 0 6px;letter-spacing:-.02em}.summary-detail-instructor{font-size:.82rem;color:var(--text-muted);margin:0}.summary-detail-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:24px}.summary-info-item{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--bg-main);border:1px solid var(--border-light);border-radius:var(--radius)}.summary-info-icon{width:32px;height:32px;border-radius:8px;background:var(--primary-50);color:var(--primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.summary-info-label{display:block;font-size:.68rem;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.05em}.summary-info-value{display:block;font-size:.88rem;font-weight:700;color:var(--text);margin-top:1px}.summary-score-section{display:flex;align-items:center;gap:24px;padding:20px;background:var(--bg-main);border:1px solid var(--border-light);border-radius:var(--radius-lg);margin-bottom:20px}.summary-score-ring{position:relative;flex-shrink:0;width:100px;height:100px}.summary-score-text{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}.summary-score-value{font-size:1.3rem;font-weight:800;color:var(--text)}.summary-score-details{flex:1}.summary-grade-badge{display:inline-flex;align-items:center;gap:6px;padding:5px 14px;border-radius:var(--radius-full);font-size:.78rem;font-weight:700;margin-bottom:8px}.grade-excellent{background:var(--success-light);color:var(--success)}.grade-good{background:var(--primary-50);color:var(--primary)}.grade-average{background:var(--warning-light);color:var(--warning)}.grade-low{background:var(--danger-light);color:var(--danger)}.summary-grade-message{font-size:.82rem;color:var(--text-secondary);line-height:1.5;margin:0 0 8px}.summary-marks-detail{font-size:.82rem;color:var(--text-muted)}.summary-marks-detail strong{color:var(--text);font-weight:700}.summary-recommendations{background:var(--bg-main);border-radius:var(--radius);padding:20px;margin-bottom:20px;border:1px solid var(--border)}.summary-recommendations h4{font-size:.88rem;font-weight:700;color:var(--text);margin-bottom:12px;display:flex;align-items:center;gap:8px}.summary-recommendations ul{list-style:none;padding:0;display:flex;flex-direction:column;gap:8px}.summary-recommendations li{font-size:.82rem;color:var(--text-secondary);padding-left:20px;position:relative;line-height:1.5}.summary-recommendations li:before{content:"";position:absolute;left:0;top:7px;width:6px;height:6px;border-radius:50%;background:var(--primary)}.btn-close-summary{width:100%;padding:12px;border-radius:12px;border:1px solid var(--border);background:var(--card-bg);color:var(--text-secondary);font-weight:600;font-size:.88rem;cursor:pointer;transition:all var(--transition-base);font-family:Inter,sans-serif}.btn-close-summary:hover{background:var(--border-light);color:var(--text)}.fab-container{position:fixed;bottom:24px;right:24px;z-index:90;display:flex;flex-direction:column-reverse;align-items:center;gap:12px}.fab-main{width:50px;height:50px;border-radius:14px;border:none;background:var(--primary-gradient);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-primary-lg);transition:all var(--transition-base)}.fab-main:hover{transform:scale(1.05)}.fab-icon{transition:transform var(--transition-base);display:flex}.fab-container.open .fab-icon{transform:rotate(45deg)}.fab-actions{display:flex;flex-direction:column-reverse;gap:8px;opacity:0;pointer-events:none;transform:translateY(8px);transition:all var(--transition-base)}.fab-container.open .fab-actions{opacity:1;pointer-events:all;transform:translateY(0)}.fab-action{display:flex;align-items:center;gap:10px;padding:10px 16px;background:var(--card-bg);border:1px solid var(--border);border-radius:12px;cursor:pointer;white-space:nowrap;box-shadow:var(--shadow-lg);transition:all var(--transition-base);color:var(--text);font-weight:500;font-size:.85rem}.fab-action:hover{box-shadow:var(--shadow-xl);transform:translate(-4px)}.fab-action-icon{display:flex;color:var(--action-color, var(--primary))}.fab-action-label{font-size:.82rem}.fab-overlay{position:fixed;inset:0;z-index:-1}.breadcrumb{margin-bottom:16px}.breadcrumb-list{display:flex;align-items:center;gap:4px;list-style:none;padding:0;margin:0}.breadcrumb-link{display:flex;align-items:center;gap:4px;color:var(--text-muted);text-decoration:none;font-size:.82rem;transition:color var(--transition-base)}.breadcrumb-link:hover{color:var(--primary)}.breadcrumb-separator{color:var(--text-muted);margin:0 4px}.breadcrumb-current{color:var(--text);font-size:.82rem;font-weight:600}.home-icon{display:flex}.skeleton{background:linear-gradient(90deg,var(--border-light) 25%,var(--border) 37%,var(--border-light) 63%);background-size:400% 100%;animation:shimmer 1.8s ease-in-out infinite;border-radius:10px}@keyframes shimmer{0%{background-position:100% 50%}to{background-position:0 50%}}.skeleton-text{display:flex;flex-direction:column;gap:10px}.skeleton-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:22px;display:flex;flex-direction:column;gap:14px}.skeleton-card-header{display:flex;justify-content:space-between}.skeleton-card-details{display:flex;flex-direction:column;gap:8px;margin-top:8px}.dashboard-skeleton{display:flex;flex-direction:column;gap:24px}.skeleton-header{display:flex;justify-content:space-between;align-items:center}.skeleton-header-right{display:flex;align-items:center;gap:12px}.skeleton-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.skeleton-stats{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:20px;display:flex;align-items:center;gap:14px}.skeleton-stats-content{display:flex;flex-direction:column;gap:8px}.skeleton-section-title{margin-top:4px}.skeleton-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.skeleton-button{margin-top:8px}.profile-skeleton{display:flex;flex-direction:column;gap:24px}.skeleton-profile-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;display:flex;align-items:center;gap:24px}.skeleton-profile-info{display:flex;flex-direction:column;gap:10px}.animated-counter{font-variant-numeric:tabular-nums}.progress-ring-container{position:relative;display:flex;align-items:center;justify-content:center}.progress-ring{transform:rotate(-90deg)}.progress-ring-content{position:absolute;display:flex;flex-direction:column;align-items:center;justify-content:center}.toast-container{position:fixed;top:20px;right:20px;z-index:2000;display:flex;flex-direction:column;gap:8px}.toast{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;padding:12px 16px;box-shadow:var(--shadow-xl);display:flex;align-items:center;gap:10px;animation:slideInRight .3s ease;font-size:.85rem;color:var(--text)}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.reports-page{animation:fadeIn .4s ease}.reports-page .metric-grid{margin-top:8px}.reports-content{margin-top:20px}.rtable-wrapper{background:var(--card-bg);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--card-shadow);overflow:hidden}.rtable-controls{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 20px;border-bottom:1px solid var(--border-light);flex-wrap:wrap}.rtable-controls-left{display:flex;align-items:center;gap:12px;flex:1;min-width:200px}.rtable-controls-right{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.rtable-search{position:relative;flex:1;max-width:320px}.rtable-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.rtable-search-input{width:100%;padding:9px 36px 9px 38px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-main);color:var(--text);font-size:.82rem;font-family:Inter,sans-serif;transition:all var(--transition-fast);outline:none}.rtable-search-input::placeholder{color:var(--text-muted)}.rtable-search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a}.rtable-search-clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px;display:flex;border-radius:50%;transition:color var(--transition-fast)}.rtable-search-clear:hover{color:var(--text)}.rtable-filter-group{display:flex;align-items:center;gap:8px;color:var(--text-muted)}.rtable-filter-pills{display:flex;gap:4px;background:var(--bg-main);border-radius:var(--radius);padding:3px;border:1px solid var(--border-light)}.rtable-filter-pill{padding:5px 12px;border:none;border-radius:8px;background:transparent;color:var(--text-muted);font-size:.75rem;font-weight:600;font-family:Inter,sans-serif;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.rtable-filter-pill:hover{color:var(--text);background:var(--card-bg-hover)}.rtable-filter-pill.active{background:var(--primary);color:#fff;box-shadow:0 2px 6px #6366f140}.rtable-rows-select{display:flex;align-items:center;gap:6px;font-size:.78rem;color:var(--text-muted);font-weight:500}.rtable-rows-select select{padding:5px 8px;border:1px solid var(--border);border-radius:8px;background:var(--bg-main);color:var(--text);font-size:.78rem;font-family:Inter,sans-serif;cursor:pointer;outline:none;transition:border-color var(--transition-fast)}.rtable-rows-select select:focus{border-color:var(--primary)}.rtable-scroll{overflow-x:auto}.rtable{width:100%;border-collapse:collapse;text-align:left}.rtable-th{padding:12px 18px;font-size:.72rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border);background:var(--bg-main);white-space:nowrap;-webkit-user-select:none;user-select:none}.rtable-th.sortable{cursor:pointer;transition:color var(--transition-fast)}.rtable-th.sortable:hover{color:var(--primary)}.rtable-th span{display:inline-flex;align-items:center;gap:6px}.rtable-th-action{text-align:center;width:120px}.sort-icon-idle{opacity:.35;transition:opacity var(--transition-fast)}.rtable-th:hover .sort-icon-idle{opacity:.7}.sort-icon-active{color:var(--primary)}.rtable-row{transition:background var(--transition-fast)}.rtable-row:hover{background:var(--card-bg-hover)}.rtable-row.row-locked{opacity:.6}.rtable-td{padding:14px 18px;font-size:.84rem;color:var(--text-secondary);border-bottom:1px solid var(--border-light);vertical-align:middle}.rtable-td-action{text-align:center}.rtable-topic-cell{display:flex;align-items:center;gap:12px}.rtable-topic-icon{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.rtable-topic-icon.generated{background:var(--primary-gradient-subtle);color:var(--primary)}.rtable-topic-icon.pending{background:var(--warning-light);color:var(--warning)}.rtable-topic-icon.locked{background:var(--border-light);color:var(--text-muted)}.rtable-topic-text{font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:260px}.rtable-date{font-size:.8rem;color:var(--text-muted);font-weight:500}.rtable-questions{font-weight:600;font-size:.84rem;color:var(--text-secondary)}.rtable-status-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border-radius:20px;font-size:.72rem;font-weight:700;letter-spacing:.02em}.rtable-status-badge.status-generated{background:var(--success-light);color:var(--success-dark)}.rtable-status-badge.status-pending{background:var(--warning-light);color:var(--warning-dark)}.rtable-status-badge.status-locked{background:var(--border-light);color:var(--text-muted)}.rtable-action-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 16px;border:none;border-radius:8px;font-size:.78rem;font-weight:700;font-family:Inter,sans-serif;cursor:pointer;transition:all var(--transition-fast)}.rtable-action-btn.view{background:var(--primary-gradient-subtle);color:var(--primary)}.rtable-action-btn.view:hover{background:var(--primary);color:#fff;box-shadow:var(--shadow-primary);transform:translateY(-1px)}.rtable-action-btn.generate{background:linear-gradient(135deg,var(--primary),var(--accent-blue));color:#fff;box-shadow:0 2px 8px #6366f140}.rtable-action-btn.generate:hover{box-shadow:0 4px 14px #6366f166;transform:translateY(-1px)}.rtable-locked-info{display:inline-flex;align-items:center;gap:4px;font-size:.72rem;color:var(--text-muted);font-weight:500}.rtable-empty{padding:48px 20px;text-align:center;color:var(--text-muted)}.rtable-empty p{margin-top:10px;font-size:.85rem}.rtable-pagination{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-top:1px solid var(--border-light);flex-wrap:wrap;gap:12px}.rtable-page-info{font-size:.78rem;color:var(--text-muted);font-weight:500}.rtable-page-controls{display:flex;align-items:center;gap:4px}.rtable-page-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border:1px solid var(--border);border-radius:8px;background:transparent;color:var(--text-secondary);font-size:.76rem;font-weight:600;font-family:Inter,sans-serif;cursor:pointer;transition:all var(--transition-fast)}.rtable-page-btn:hover:not(:disabled){background:var(--card-bg-hover);border-color:var(--primary-200);color:var(--primary)}.rtable-page-btn:disabled{opacity:.4;cursor:not-allowed}.rtable-page-num{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border:1px solid transparent;border-radius:8px;background:transparent;color:var(--text-muted);font-size:.78rem;font-weight:600;font-family:Inter,sans-serif;cursor:pointer;transition:all var(--transition-fast)}.rtable-page-num:hover{background:var(--card-bg-hover);color:var(--text)}.rtable-page-num.active{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 2px 6px #6366f140}@media(max-width:1024px){.rtable-controls{flex-direction:column;align-items:stretch}.rtable-controls-left{min-width:unset}.rtable-search{max-width:100%}.rtable-controls-right{justify-content:space-between}}@media(max-width:768px){.rtable-controls{padding:12px 14px}.rtable-filter-pills{overflow-x:auto}.rtable-td,.rtable-th{padding:10px 12px}.rtable-topic-text{max-width:140px}.rtable-pagination{flex-direction:column;align-items:center;text-align:center}}@media(max-width:640px){.rtable-topic-icon{display:none}}.ai-report-page{animation:fadeIn .4s ease;max-width:900px;margin:-8px auto 0;padding:0 20px 60px}.report-topbar{display:flex;justify-content:space-between;align-items:center;padding:8px 0;margin-bottom:4px}.btn-report-back{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:10px;border:1px solid var(--border);background:var(--card-bg);color:var(--text-secondary);font-weight:600;font-size:.85rem;cursor:pointer;transition:all var(--transition-base);font-family:Inter,sans-serif}.btn-report-back:hover{background:var(--border-light);color:var(--text);transform:translate(-2px)}.btn-report-print{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:10px;border:1px solid var(--border);background:var(--card-bg);color:var(--text-secondary);font-weight:500;font-size:.82rem;cursor:pointer;transition:all var(--transition-base);font-family:Inter,sans-serif}.btn-report-print:hover{background:var(--border-light);color:var(--text)}.report-hero{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-xl);padding:36px 32px;margin-bottom:24px;position:relative;overflow:hidden;box-shadow:var(--card-shadow)}.report-hero:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--primary-gradient)}.report-hero-content{position:relative;z-index:2}.report-hero-decoration{position:absolute;right:24px;top:50%;transform:translateY(-50%);color:var(--primary-100);opacity:.3;z-index:1}[data-theme=dark] .report-hero-decoration{opacity:.08}.report-hero-badge{display:inline-flex;align-items:center;gap:6px;padding:5px 14px;border-radius:var(--radius-full);background:var(--primary-gradient-subtle);color:var(--primary);font-size:.78rem;font-weight:700;letter-spacing:.03em;margin-bottom:14px}.report-hero-title{font-size:1.5rem;font-weight:800;color:var(--text);margin:0 0 6px;letter-spacing:-.02em;line-height:1.3}.report-hero-meta{font-size:.82rem;color:var(--text-muted);margin:0}.report-section{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;margin-bottom:20px;box-shadow:var(--card-shadow);transition:box-shadow var(--transition-base)}.report-section:hover{box-shadow:var(--card-shadow-hover)}.report-section-header{display:flex;align-items:center;gap:12px;margin-bottom:20px;flex-wrap:wrap}.report-section-header h2{font-size:1.08rem;font-weight:700;color:var(--text);margin:0;flex:1}.report-section-icon{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.summary-icon{background:var(--primary-gradient-subtle);color:var(--primary)}.strength-icon{background:var(--success-light);color:var(--success)}.weakness-icon{background:var(--warning-light);color:var(--warning-dark)}.question-icon{background:var(--info-light);color:var(--info)}.roadmap-icon{background:linear-gradient(135deg,#6366f11a,#8b5cf61a);color:var(--primary)}.tips-icon{background:#fbbf241f;color:var(--warning)}.report-summary-text{font-size:.95rem;color:var(--text-secondary);line-height:1.8;margin:0;padding:16px 20px;background:var(--bg-main);border-radius:var(--radius);border-left:3px solid var(--primary)}.report-two-col{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}.insight-cards{display:flex;flex-direction:column;gap:12px}.insight-card{padding:16px 18px;border-radius:var(--radius);border:1px solid var(--border-light);transition:all var(--transition-base)}.insight-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.insight-card h4{font-size:.9rem;font-weight:700;margin:0 0 6px}.insight-card p{font-size:.82rem;color:var(--text-secondary);line-height:1.6;margin:0}.strength-card{background:var(--success-light);border-color:transparent}.strength-card h4{color:var(--success-dark)}[data-theme=dark] .strength-card{background:#10b98114;border-color:#10b98126}[data-theme=dark] .strength-card h4{color:var(--success)}.weakness-card{background:var(--warning-light);border-color:transparent}.weakness-card h4{color:var(--warning-dark)}[data-theme=dark] .weakness-card{background:#f59e0b14;border-color:#f59e0b26}[data-theme=dark] .weakness-card h4{color:var(--warning)}.no-data-text{font-size:.85rem;color:var(--text-muted);font-style:italic;text-align:center;padding:20px}.question-toggle-actions{display:flex;gap:8px}.btn-toggle-all{padding:5px 12px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--text-muted);font-size:.72rem;font-weight:600;cursor:pointer;transition:all var(--transition-base);font-family:Inter,sans-serif}.btn-toggle-all:hover{background:var(--border-light);color:var(--text)}.question-analysis-list{display:flex;flex-direction:column;gap:8px}.question-analysis-item{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:border-color var(--transition-base)}.question-analysis-item:hover{border-color:var(--primary-200)}.question-analysis-item.correct{border-left:3px solid var(--success)}.question-analysis-item.incorrect{border-left:3px solid var(--danger)}.question-analysis-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:transparent;border:none;cursor:pointer;font-family:Inter,sans-serif;transition:background var(--transition-base);text-align:left;color:var(--text)}.question-analysis-header:hover{background:var(--bg-main)}.qa-left{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.qa-status-dot{display:flex;align-items:center;justify-content:center;flex-shrink:0}.qa-status-dot.correct{color:var(--success)}.qa-status-dot.incorrect{color:var(--danger)}.qa-status-dot.unanswered{color:var(--text-muted)}.qa-question-label{font-weight:800;font-size:.82rem;color:var(--primary);flex-shrink:0}.qa-question-preview{font-size:.82rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.qa-chevron{color:var(--text-muted);flex-shrink:0;margin-left:12px}.question-analysis-body{padding:0 16px 16px;overflow:hidden}.qa-full-question{font-size:.88rem;color:var(--text);line-height:1.6;padding:12px 16px;background:var(--bg-main);border-radius:var(--radius);margin-bottom:14px}.qa-full-question strong{color:var(--text-muted);font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;display:block;margin-bottom:4px}.qa-answers-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}.qa-answer-box{padding:12px 14px;border-radius:10px;border:1px solid var(--border)}.qa-answer-box.correct{background:var(--success-light);border-color:#10b98133}.qa-answer-box.wrong{background:var(--danger-light);border-color:#ef444433}.qa-answer-label{display:block;font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:4px}.qa-answer-value{display:block;font-size:.85rem;font-weight:600;color:var(--text);line-height:1.4}.qa-explanation{padding:14px 16px;background:var(--bg-main);border-radius:var(--radius);margin-bottom:10px;border:1px solid var(--border-light)}.qa-explanation-header{display:flex;align-items:center;gap:8px;color:var(--primary);margin-bottom:8px}.qa-explanation-header strong{font-size:.82rem}.qa-explanation p{font-size:.85rem;color:var(--text-secondary);line-height:1.7;margin:0}.qa-takeaway{display:flex;align-items:flex-start;gap:8px;padding:10px 14px;background:var(--primary-gradient-subtle);border-radius:8px;font-size:.82rem;color:var(--text-secondary);line-height:1.5}.qa-takeaway svg{color:var(--primary);flex-shrink:0;margin-top:2px}.improvement-cards{display:flex;flex-direction:column;gap:16px}.improvement-card{padding:22px 24px;border:1px solid var(--border);border-radius:var(--radius);background:var(--card-bg);transition:all var(--transition-base)}.improvement-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.improvement-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;gap:12px}.improvement-card-header h3{font-size:1rem;font-weight:700;color:var(--text);margin:0}.priority-badge{padding:4px 12px;border-radius:var(--radius-full);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;border:1px solid;flex-shrink:0}.improvement-gap{font-size:.85rem;color:var(--text-secondary);line-height:1.6;margin:0 0 16px;padding:10px 14px;background:var(--bg-main);border-radius:8px;border-left:3px solid var(--warning)}.improvement-actions,.improvement-resources{margin-bottom:12px}.improvement-actions:last-child,.improvement-resources:last-child{margin-bottom:0}.improvement-actions h4,.improvement-resources h4{font-size:.82rem;font-weight:700;color:var(--text);margin:0 0 8px;display:flex;align-items:center;gap:6px}.improvement-actions ul,.improvement-resources ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.improvement-actions li,.improvement-resources li{font-size:.82rem;color:var(--text-secondary);padding-left:18px;position:relative;line-height:1.6}.improvement-actions li:before{content:"";position:absolute;left:0;top:8px;width:6px;height:6px;border-radius:50%;background:var(--primary)}.improvement-resources li:before{content:"→";position:absolute;left:0;top:0;color:var(--primary);font-weight:600}.study-tips-list{display:flex;flex-direction:column;gap:10px}.study-tip-item{display:flex;align-items:flex-start;gap:14px;padding:14px 18px;background:var(--bg-main);border-radius:var(--radius);border:1px solid var(--border-light);transition:all var(--transition-base)}.study-tip-item:hover{border-color:var(--primary-200);transform:translate(4px)}.tip-number{width:28px;height:28px;border-radius:50%;background:var(--primary-gradient);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:800;flex-shrink:0}.study-tip-item p{font-size:.85rem;color:var(--text-secondary);line-height:1.6;margin:0;padding-top:3px}.report-bottom-actions{display:flex;justify-content:space-between;align-items:center;padding-top:12px;gap:12px}.btn-report-action{display:flex;align-items:center;gap:8px;padding:12px 24px;border-radius:12px;border:none;background:var(--primary-gradient);color:#fff;font-weight:700;font-size:.88rem;cursor:pointer;transition:all var(--transition-base);font-family:Inter,sans-serif;box-shadow:var(--shadow-primary)}.btn-report-action:hover:not(:disabled){background:var(--primary-gradient-hover);box-shadow:var(--shadow-primary-lg);transform:translateY(-1px)}.btn-report-action:disabled{opacity:.5;cursor:not-allowed}.btn-report-secondary{display:flex;align-items:center;gap:8px;padding:12px 24px;border-radius:12px;border:1px solid var(--border);background:var(--card-bg);color:var(--text-secondary);font-weight:600;font-size:.88rem;cursor:pointer;transition:all var(--transition-base);font-family:Inter,sans-serif}.btn-report-secondary:hover{background:var(--border-light);color:var(--text)}.report-generating,.report-error{display:flex;align-items:center;justify-content:center;min-height:60vh}.generating-card,.error-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-xl);padding:48px 40px;text-align:center;max-width:480px;width:100%;box-shadow:var(--shadow-lg)}.generating-icon{width:80px;height:80px;border-radius:50%;background:var(--primary-gradient-subtle);color:var(--primary);display:flex;align-items:center;justify-content:center;margin:0 auto 24px}.generating-card h2,.error-card h2{font-size:1.25rem;font-weight:800;color:var(--text);margin:0 0 8px}.generating-card p,.error-card p{font-size:.88rem;color:var(--text-muted);margin:0 0 24px}.generating-progress{height:4px;border-radius:2px;background:var(--border-light);overflow:hidden;margin-bottom:12px}.generating-progress-fill{height:100%;border-radius:2px;background:var(--primary-gradient)}.generating-note{font-size:.78rem!important;color:var(--text-muted)!important;margin:0!important}.error-card svg{color:var(--danger);margin-bottom:16px}@media print{.report-topbar,.report-bottom-actions,.btn-toggle-all,.qa-chevron{display:none!important}.ai-report-page{max-width:100%;padding:0}.report-section{break-inside:avoid;box-shadow:none;border:1px solid #ddd}.question-analysis-body{display:block!important;height:auto!important;opacity:1!important}.report-hero{box-shadow:none}}@media(max-width:1200px){.analytics-content-grid,.rules-split-layout{grid-template-columns:1fr}}@media(max-width:1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}.main-content{grid-template-columns:1fr}.sidebar{display:none}.profile-header-section{grid-template-columns:1fr}.profile-right-section{padding-top:20px}.profile-cover-banner{margin-bottom:0}}@media(max-width:768px){.assessment-grid{grid-template-columns:1fr}.confirmation-stats{grid-template-columns:repeat(2,1fr)}.palette-grid-large{grid-template-columns:repeat(6,1fr)}.progress-submit-row{padding:10px 16px}.main-content{padding:16px}.login-glass-card{padding:24px 20px 28px}.login-banner{padding:28px 20px 32px}.login-banner-title{font-size:1.25rem}.rules-page{padding:16px}.fullscreen-content{padding:24px}.profile-info-pills{flex-direction:column}.stats-grid{grid-template-columns:1fr 1fr}.exam-header{padding:0 16px;gap:8px}.timer{padding:6px 10px;font-size:.85rem}.profile-details-grid,.report-two-col,.qa-answers-row{grid-template-columns:1fr}.report-hero-title{font-size:1.2rem}.report-bottom-actions{flex-direction:column}}@media(max-width:480px){.navigation-buttons{flex-wrap:wrap}.navigation-buttons button{flex:1;min-width:100px;font-size:.78rem;padding:8px 12px}.confirmation-actions{flex-direction:column}.topic-boxes-grid{grid-template-columns:1fr 1fr}.improvement-card-header{flex-direction:column;align-items:flex-start}.report-section{padding:20px 16px}}[data-glass=true] .card-bg,[data-glass=true] .assessment-card,[data-glass=true] .metric-card{backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}[data-theme=dark][data-glass=true] .assessment-card,[data-theme=dark][data-glass=true] .metric-card{background:#141b32b3}.diagram-icon{background:linear-gradient(135deg,var(--info),var(--primary))!important}.question-dot-grid{display:flex;flex-wrap:wrap;gap:8px;padding:20px 0;justify-content:center}.question-dot{display:flex;flex-direction:column;align-items:center;gap:4px;width:52px;height:52px;border-radius:12px;justify-content:center;font-size:.7rem;font-weight:600;cursor:default;transition:transform .2s ease,box-shadow .2s ease;border:1.5px solid transparent}.question-dot:hover{transform:translateY(-2px)}.question-dot .dot-label{font-size:.65rem;font-weight:700;letter-spacing:.02em}.question-dot.correct{background:var(--success-light);color:var(--success);border-color:var(--success)}.question-dot.correct:hover{box-shadow:0 4px 12px #10b98140}.question-dot.incorrect{background:var(--danger-light);color:var(--danger);border-color:var(--danger)}.question-dot.incorrect:hover{box-shadow:0 4px 12px #ef444440}.question-dot.unanswered{background:var(--warning-light);color:var(--warning);border-color:var(--warning)}.dot-grid-legend{display:flex;justify-content:center;gap:24px;padding:8px 0 20px}.legend-item{display:flex;align-items:center;gap:8px;font-size:.8rem;color:var(--text-secondary);font-weight:500}.legend-dot{width:10px;height:10px;border-radius:50%}.legend-dot.correct{background:var(--success)}.legend-dot.incorrect{background:var(--danger)}.topic-breakdown{padding:16px 0 4px;border-top:1px solid var(--border-light);margin-top:8px}.topic-breakdown-title{font-size:.9rem;font-weight:700;color:var(--text);display:flex;align-items:center;gap:8px;margin-bottom:16px}.topic-bars{display:flex;flex-direction:column;gap:14px}.topic-bar-row{display:grid;grid-template-columns:140px 1fr 90px;align-items:center;gap:12px}.topic-bar-label{font-size:.82rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topic-bar-track{height:10px;background:var(--border-light);border-radius:8px;overflow:hidden;position:relative}.topic-bar-fill{height:100%;border-radius:8px;position:absolute;left:0;top:0}.topic-bar-fill.strength{background:linear-gradient(90deg,var(--success),#34D399)}.topic-bar-fill.weakness{background:linear-gradient(90deg,var(--danger),#F87171)}.topic-bar-tag{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:3px 10px;border-radius:20px;text-align:center}.topic-bar-tag.strength{background:var(--success-light);color:var(--success)}.topic-bar-tag.weakness{background:var(--danger-light);color:var(--danger)}@media(max-width:600px){.topic-bar-row{grid-template-columns:1fr;gap:4px}.topic-bar-label{font-size:.78rem}.question-dot{width:44px;height:44px;border-radius:10px}.question-dot .dot-label{font-size:.6rem}}@media print{.app-sidebar,.fab-container,.theme-toggle,.sidebar-toggle-btn{display:none!important}.app-main{margin-left:0!important}body{background:#fff}.question-dot-grid{gap:4px}.question-dot{width:40px;height:40px}}
