@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 var(--transition-base);font-family:Inter,sans-serif;letter-spacing:.01em;box-shadow:var(--shadow-primary)}.btn-start:hover{background:var(--primary-gradient-hover);box-shadow:var(--shadow-primary-lg);transform:translateY(-1px)}.btn-start:active{transform:translateY(0)}.btn-start.disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.btn-start.disabled:hover{transform:none;box-shadow:none}.btn-upcoming{padding:11px 20px;border-radius:10px;border:1px solid var(--border);background:var(--border-light);color:var(--text-muted);font-weight:600;font-size:.85rem;cursor:not-allowed;font-family:Inter,sans-serif}.btn-view-summary{margin-top:auto;transition:all var(--transition-base)!important}.btn-view-summary:hover{background:var(--primary-50)!important;box-shadow:var(--shadow-glow)!important}.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);padding:22px;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)}.assessment-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#6366f1,#8b5cf6,#a78bfa,#8b5cf6,#6366f1);background-size:200% 100%;opacity:0;transition:opacity .3s ease;animation:gradientSlide 3s linear infinite}@keyframes gradientSlide{0%{background-position:0% 50%}to{background-position:200% 50%}}.assessment-card:hover:before{opacity:1}.assessment-card:hover{box-shadow:0 10px 30px #6366f11a,0 0 0 1px #6366f10f;transform:translateY(-4px);border-color:var(--primary-200)}.card-badge-container{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.badge{padding:4px 12px;border-radius:var(--radius-full);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.badge--subject{background-color:var(--badge-subject-bg);color:var(--badge-subject-text)}.badge--status{font-weight:700;display:flex;align-items:center;gap:6px}.badge--live{background-color:var(--badge-live-bg);color:var(--badge-live-text);animation:livePulse 2s ease-in-out infinite}.badge--upcoming{background-color:var(--badge-upcoming-bg);color:var(--badge-upcoming-text)}.badge--completed{background-color:var(--badge-completed-bg);color:var(--badge-completed-text)}.card-title{font-size:1rem;font-weight:700;color:var(--text);margin-bottom:6px;line-height:1.4;letter-spacing:-.01em}.card-instructor{font-size:.82rem;color:var(--text-muted);margin-bottom:12px}.card-meta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:16px;color:var(--text-secondary);font-size:.82rem}.meta-item{display:flex;align-items:center;gap:5px}.meta-item svg{color:var(--text-muted)}.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)}.expiry-notice--urgent{background:var(--notice-urgent-bg);color:var(--notice-urgent-text);border-color:#f8717126}.expiry-notice--upcoming{background:var(--notice-upcoming-bg);color:var(--notice-upcoming-text);border-color:#60a5fa26}.dashboard-widgets{display:grid;grid-template-columns:1.4fr 1fr;gap:20px;margin-top:4px}.widget-column{display:flex;flex-direction:column;gap:16px}.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}.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:1200px){.dashboard-widgets{grid-template-columns:1fr}}@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}.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}.performance-graph{background:var(--card-bg);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:var(--radius);padding:24px;box-shadow:var(--card-shadow)}.graph-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.graph-header h3{font-size:1.05rem;font-weight:700;color:var(--text)}.graph-stats{display:flex;gap:16px}.graph-stat{display:flex;flex-direction:column;align-items:center}.graph-stat .stat-value{font-size:1.1rem;font-weight:700;color:var(--primary)}.graph-stat .stat-label{font-size:.72rem;color:var(--text-muted)}.graph-container{display:flex;gap:12px;height:200px}.graph-y-axis{display:flex;flex-direction:column;justify-content:space-between;font-size:.7rem;color:var(--text-muted);padding:0 8px 24px 0;min-width:32px}.graph-area{flex:1;position:relative}.graph-grid{position:absolute;inset:0 0 24px}.grid-line{position:absolute;left:0;right:0;height:1px;background:var(--border-light)}.graph-bars{display:flex;align-items:flex-end;gap:8px;height:calc(100% - 24px);padding:0 4px}.bar-container{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;height:100%;justify-content:flex-end}.bar{width:100%;max-width:40px;border-radius:8px 8px 0 0;background:var(--primary-gradient);position:relative;transition:height .8s cubic-bezier(.4,0,.2,1);min-height:4px;box-shadow:0 -4px 12px #6366f126}.bar-placeholder{animation:growBar .8s ease forwards}@keyframes growBar{0%{height:0}}.bar-tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--text);color:var(--card-bg);padding:6px 10px;border-radius:8px;font-size:.72rem;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity var(--transition-fast);z-index:10;box-shadow:var(--shadow-lg)}.bar:hover .bar-tooltip{opacity:1}.tooltip-date{display:block;font-size:.65rem;opacity:.7}.bar-label{font-size:.7rem;color:var(--text-muted);font-weight:500}.graph-empty-message{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-muted);font-size:.88rem}.graph-message{text-align:center;padding-top:12px}.graph-message p{font-size:.78rem;color:var(--text-muted)}.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:#00000080;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.calendar-popup-modal{background:var(--card-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-xl);padding:28px;max-width:480px;width:90%;max-height:80vh;overflow-y:auto;box-shadow:var(--shadow-2xl);border:1px solid var(--border)}.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}.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{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-main);position:relative;overflow:hidden;padding:20px}.login-bg-decoration{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}.math-symbol{position:absolute;font-size:2rem;color:var(--primary);opacity:.05;font-weight:700;-webkit-user-select:none;user-select:none;animation:floatSymbol 20s ease-in-out infinite}@keyframes floatSymbol{0%,to{transform:translateY(0) rotate(0)}25%{transform:translateY(-15px) rotate(5deg)}50%{transform:translateY(-5px) rotate(-3deg)}75%{transform:translateY(-20px) rotate(3deg)}}.symbol-1{top:10%;left:8%;font-size:3rem;animation-delay:0s}.symbol-2{top:20%;right:12%;font-size:2.5rem;animation-delay:2s}.symbol-3{top:35%;left:15%;font-size:2rem;animation-delay:4s}.symbol-4{bottom:30%;right:20%;font-size:3.5rem;animation-delay:1s}.symbol-5{bottom:15%;left:20%;font-size:2rem;animation-delay:3s}.symbol-6{top:50%;right:8%;font-size:2.5rem;animation-delay:5s}.symbol-7{top:60%;left:5%;font-size:2rem;animation-delay:2.5s}.symbol-8{bottom:40%;right:30%;font-size:3rem;animation-delay:1.5s}.symbol-9{top:5%;left:40%;font-size:2rem;animation-delay:3.5s}.symbol-10{bottom:10%;right:40%;font-size:2.5rem;animation-delay:4.5s}.symbol-11{top:75%;left:30%;font-size:2rem;animation-delay:.5s}.symbol-12{top:15%;left:60%;font-size:2.5rem;animation-delay:2.5s}.symbol-13{bottom:25%;left:45%;font-size:3rem;animation-delay:3.5s}.symbol-14{top:45%;right:35%;font-size:2rem;animation-delay:1s}.login-container{width:100%;max-width:420px;background:var(--card-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-xl);padding:40px 36px;box-shadow:var(--shadow-2xl);border:1px solid var(--border);position:relative;z-index:1;animation:scaleIn .4s cubic-bezier(.34,1.56,.64,1)}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.login-theme-toggle{position:absolute;top:20px;right:20px}.login-header{text-align:center;margin-bottom:8px}.login-logo-img{margin-bottom:12px;filter:drop-shadow(0 2px 8px rgba(99,102,241,.15))}.login-header p{color:var(--text-muted);font-size:.88rem;margin:0}.login-title{text-align:center;margin-bottom:28px}.login-title h2{font-size:1.4rem;font-weight:800;color:var(--text);letter-spacing:-.02em}.login-form{display:flex;flex-direction:column;gap:18px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:.82rem;font-weight:600;color:var(--text-secondary)}.form-group input{width:100%;padding:13px 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}.form-group input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-100),var(--shadow-glow);background:var(--card-bg)}.form-group input::placeholder{color:var(--text-muted)}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper input{padding-right:44px}.password-toggle-btn{position:absolute;right:12px;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;display:flex;transition:color var(--transition-base)}.password-toggle-btn:hover{color:var(--text-secondary)}.login-error{background:var(--danger-light);color:var(--danger);padding:10px 14px;border-radius:10px;font-size:.82rem;font-weight:500;border:1px solid rgba(239,68,68,.15)}.btn-login{width:100%;padding:14px;border-radius:12px;border:none;background:var(--primary-gradient);color:#fff;font-weight:700;font-size:.95rem;cursor:pointer;transition:all var(--transition-base);font-family:Inter,sans-serif;letter-spacing:.01em;box-shadow:var(--shadow-primary)}.btn-login:hover:not(:disabled){background:var(--primary-gradient-hover);box-shadow:var(--shadow-primary-lg);transform:translateY(-2px)}.btn-login:active{transform:translateY(0)}.btn-login:disabled{opacity:.7;cursor:not-allowed}.login-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin .8s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.google-login-container{margin-top:20px}.divider{display:flex;align-items:center;gap:12px;margin-bottom:16px}.divider span:first-child,.divider span:last-child{flex:1;height:1px;background:var(--border)}.performance-graph,.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] .performance-graph,[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}.login-container{backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);background:#ffffffe6;box-shadow:0 24px 60px #0000001a,0 0 0 1px #ffffff4d inset}[data-theme=dark] .login-container{background:#11182dbf;box-shadow:0 24px 60px #00000080,0 0 0 1px #ffffff0d inset}.calendar-popup-modal,.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,[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:#00000080;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.summary-card{background:var(--card-bg);border-radius:var(--radius-xl);padding:36px;max-width:480px;width:90%;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-2xl);position:relative;border:1px solid var(--border);animation:scaleIn .3s cubic-bezier(.34,1.56,.64,1)}.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)}.btn-close-modal:hover{background:var(--danger-light);color:var(--danger)}.summary-illustration{text-align:center;margin-bottom:20px}.illustration-icon{width:72px;height:72px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center}.illustration-icon.excellent{background:var(--success-light);color:var(--success)}.illustration-icon.good{background:var(--primary-50);color:var(--primary)}.illustration-icon.average{background:var(--warning-light);color:var(--warning)}.illustration-icon.low{background:var(--danger-light);color:var(--danger)}.summary-header{text-align:center;margin-bottom:16px}.summary-header h2{font-size:1.25rem;font-weight:800;color:var(--text);margin-bottom:4px;letter-spacing:-.02em}.summary-title{font-size:.88rem;color:var(--text-secondary)}.summary-feedback{text-align:center;margin-bottom:20px}.summary-feedback p{font-size:.88rem;color:var(--text-secondary)}.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}.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}}@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-container{padding:32px 24px}.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{grid-template-columns:1fr}}@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}}[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}@media print{.app-sidebar,.fab-container,.theme-toggle,.sidebar-toggle-btn{display:none!important}.app-main{margin-left:0!important}body{background:#fff}}
