@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--gray-25: #F8FAFC;--gray-50: #F1F5F9;--gray-100: #E2E8F0;--gray-200: #CBD5E1;--gray-300: #94A3B8;--gray-400: #64748B;--gray-500: #475569;--gray-600: #334155;--gray-700: #1E293B;--gray-800: #0F172A;--gray-900: #020617;--gray-950: #010409;--primary-25: #F0FDFA;--primary-50: #F0FDFA;--primary-100: #CCFBF1;--primary-200: #99F6E4;--primary-300: #5EEAD4;--primary-400: #2DD4BF;--primary-500: #14B8A6;--primary-600: #0D9488;--primary-700: #0F766E;--primary-800: #115E59;--primary-900: #134E4A;--success-50: #ECFDF5;--success-100: #D1FADF;--success-500: #12B76A;--success-600: #039855;--success-700: #027A48;--success-900: #054F31;--warning-25: #FFFCF5;--warning-50: #FFFAEB;--warning-100: #FEF0C7;--warning-500: #F79009;--warning-600: #DC6803;--warning-700: #B54708;--warning-900: #7A2E0E;--error-50: #FEF3F2;--error-500: #F04438;--error-600: #D92D20;--error-700: #B42318;--bg-primary: #FFFFFF;--bg-secondary: #FDFCFA;--bg-tertiary: var(--gray-50);--bg-inset: var(--gray-50);--card-bg: var(--bg-primary);--text-primary: var(--gray-900);--text-secondary: var(--gray-600);--text-tertiary: var(--gray-500);--text-placeholder: var(--gray-400);--text-white: #FFFFFF;--text-brand: var(--primary-600);--border-primary: var(--gray-200);--border-secondary: var(--gray-300);--border-brand: var(--primary-300);--border-color: var(--border-primary);--shadow-xs: 0px 1px 2px rgba(16, 24, 40, .05);--shadow-sm: 0px 1px 3px rgba(16, 24, 40, .1), 0px 1px 2px rgba(16, 24, 40, .06);--shadow-md: 0px 4px 8px -2px rgba(16, 24, 40, .1), 0px 2px 4px -2px rgba(16, 24, 40, .06);--shadow-lg: 0px 12px 16px -4px rgba(16, 24, 40, .08), 0px 4px 6px -2px rgba(16, 24, 40, .03);--shadow-xl: 0px 20px 24px -4px rgba(16, 24, 40, .08), 0px 8px 8px -4px rgba(16, 24, 40, .03);--shadow-2xl: 0px 24px 48px -12px rgba(16, 24, 40, .18);--shadow-focus: 0px 0px 0px 4px rgba(13, 148, 136, .24);--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 20px;--radius-full: 9999px;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-8: 32px;--sp-10: 40px;--sp-12: 48px;--sp-16: 64px;--sp-20: 80px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-smooth: .3s cubic-bezier(.4, 0, .2, 1);--sidebar-width: 260px;--header-height: 64px}[data-theme=dark]{color-scheme:dark;--gray-25: #0B1120;--gray-50: #111827;--gray-100: #1F2937;--gray-200: #334155;--gray-300: #475569;--gray-400: #64748B;--gray-500: #94A3B8;--gray-600: #CBD5E1;--gray-700: #E2E8F0;--gray-800: #F1F5F9;--gray-900: #F8FAFC;--gray-950: #FFFFFF;--primary-25: rgba(20, 184, 166, .1);--primary-50: rgba(20, 184, 166, .14);--primary-100: rgba(20, 184, 166, .2);--primary-200: rgba(45, 212, 191, .32);--primary-300: #5EEAD4;--primary-400: #2DD4BF;--primary-500: #14B8A6;--primary-600: #2DD4BF;--primary-700: #5EEAD4;--primary-800: #99F6E4;--primary-900: #CCFBF1;--success-50: rgba(18, 183, 106, .14);--success-100: rgba(18, 183, 106, .22);--success-500: #32D583;--success-600: #6CE9A6;--success-700: #A6F4C5;--success-900: #D1FADF;--warning-25: rgba(247, 144, 9, .1);--warning-50: rgba(247, 144, 9, .14);--warning-100: rgba(247, 144, 9, .22);--warning-500: #FDB022;--warning-600: #FEC84B;--warning-700: #FEDF89;--warning-900: #FEF0C7;--error-50: rgba(240, 68, 56, .14);--error-500: #F97066;--error-600: #FDA29B;--error-700: #FECDCA;--bg-primary: #111827;--bg-secondary: #0B1120;--bg-tertiary: #1F2937;--bg-inset: #0F172A;--card-bg: #111827;--text-primary: #F8FAFC;--text-secondary: #CBD5E1;--text-tertiary: #94A3B8;--text-placeholder: #64748B;--text-brand: #5EEAD4;--border-primary: rgba(148, 163, 184, .2);--border-secondary: rgba(148, 163, 184, .3);--border-brand: rgba(94, 234, 212, .46);--border-color: var(--border-primary);--shadow-xs: 0px 1px 2px rgba(0, 0, 0, .35);--shadow-sm: 0px 1px 3px rgba(0, 0, 0, .45), 0px 1px 2px rgba(0, 0, 0, .35);--shadow-md: 0px 8px 18px rgba(0, 0, 0, .35);--shadow-lg: 0px 16px 30px rgba(0, 0, 0, .4);--shadow-xl: 0px 24px 44px rgba(0, 0, 0, .45);--shadow-2xl: 0px 32px 64px rgba(0, 0, 0, .55);--shadow-focus: 0px 0px 0px 4px rgba(45, 212, 191, .22)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--text-primary);background:var(--bg-secondary);line-height:1.5;min-height:100vh}html,body,#root{background:var(--bg-secondary)}h1,h2,h3,h4,h5,h6{color:var(--text-primary);font-weight:600;line-height:1.25;letter-spacing:-.02em}h1{font-size:1.875rem;font-weight:700}h2{font-size:1.5rem}h3{font-size:1.125rem}h4{font-size:1rem}p{color:var(--text-secondary);line-height:1.6}a{color:var(--text-brand);text-decoration:none}a:hover{color:var(--primary-700)}.app-shell{display:flex;min-height:100vh}.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-width);background:var(--bg-primary);border-right:1px solid var(--border-primary);display:flex;flex-direction:column;z-index:40;transition:transform var(--transition-smooth)}.sidebar-brand{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-6);border-bottom:1px solid var(--border-primary);height:var(--header-height)}.sidebar-brand-icon{width:32px;height:32px;background:var(--primary-600);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:14px}.sidebar-brand-text{font-size:1.125rem;font-weight:700;color:var(--text-primary);letter-spacing:-.03em}.sidebar-brand-badge{font-size:.625rem;font-weight:600;color:var(--primary-600);background:var(--primary-50);padding:2px 6px;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em;margin-left:auto}.sidebar-nav{flex:1;padding:var(--sp-4);overflow-y:auto}.sidebar-section-label{font-size:.6875rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em;padding:var(--sp-4) var(--sp-3) var(--sp-2)}.sidebar-link{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-2) var(--sp-3);border-radius:var(--radius-md);color:var(--text-secondary);font-weight:500;font-size:.875rem;text-decoration:none;transition:all var(--transition-fast);cursor:pointer;border:none;background:none;width:100%;text-align:left}.sidebar-link:hover{background:var(--bg-secondary);color:var(--text-primary)}.sidebar-link.active{background:var(--primary-50);color:var(--primary-700);font-weight:600}.sidebar-link .link-icon{width:20px;height:20px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.sidebar-link .link-badge{margin-left:auto;font-size:.75rem;font-weight:600;background:var(--error-50);color:var(--error-600);padding:1px 8px;border-radius:var(--radius-full)}.sidebar-footer{padding:var(--sp-4);border-top:1px solid var(--border-primary)}.sidebar-user{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-2) var(--sp-3);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.sidebar-user:hover{background:var(--bg-secondary)}.sidebar-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:var(--primary-100);color:var(--primary-700);font-weight:600;font-size:.875rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-size:.875rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:.75rem;color:var(--text-tertiary)}.main-content{margin-left:var(--sidebar-width);flex:1;min-height:100vh;display:flex;flex-direction:column}.page-header{position:sticky;top:0;z-index:30;background:color-mix(in srgb,var(--bg-secondary) 84%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-primary);padding:var(--sp-5) var(--sp-8);display:flex;align-items:center;justify-content:space-between;min-height:var(--header-height)}.page-header-breadcrumb{font-size:.8125rem;color:var(--text-tertiary);display:flex;align-items:center;gap:var(--sp-2)}.page-header-breadcrumb span{color:var(--text-primary);font-weight:500}.page-header-title{font-size:1.25rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.page-header-right{display:flex;align-items:center;gap:var(--sp-3)}.page-body{flex:1;padding:var(--sp-8)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);font-family:inherit;font-weight:600;font-size:.875rem;border-radius:var(--radius-full);padding:10px 20px;cursor:pointer;transition:all var(--transition-fast);border:1px solid transparent;text-decoration:none;white-space:nowrap;line-height:1.25}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:focus-visible{outline:none;box-shadow:var(--shadow-focus)}.btn-primary{background:var(--primary-600);color:#fff;border-color:var(--primary-600);box-shadow:var(--shadow-xs)}.btn-primary:hover:not(:disabled){background:var(--primary-700);border-color:var(--primary-700)}.btn-secondary{background:var(--bg-primary);color:var(--text-secondary);border-color:var(--border-secondary);box-shadow:var(--shadow-xs)}.btn-secondary:hover:not(:disabled){background:var(--bg-secondary);color:var(--text-primary)}.btn-ghost{background:transparent;color:var(--text-secondary);border:none;padding:8px 12px}.btn-ghost:hover:not(:disabled){background:var(--bg-secondary);color:var(--text-primary)}.btn-danger{background:var(--error-600);color:#fff;border-color:var(--error-600)}.btn-success{background:var(--success-600);color:#fff;border-color:var(--success-600)}.btn-success:hover:not(:disabled){background:var(--success-700)}.btn-sm{padding:6px 12px;font-size:.8125rem}.btn-lg{padding:12px 20px;font-size:1rem}.btn-icon{padding:8px;min-width:36px;min-height:36px}.card{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-base),transform var(--transition-base)}.card-hover:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.card-header{padding:var(--sp-5) var(--sp-6);border-bottom:1px solid var(--border-primary);display:flex;align-items:center;justify-content:space-between}.card-footer{padding:var(--sp-4) var(--sp-6);border-top:1px solid var(--border-primary);display:flex;align-items:center;justify-content:flex-end;gap:var(--sp-3)}.stripe-payment-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1200;display:flex;align-items:center;justify-content:center;padding:clamp(12px,2vw,24px);background:#0f172ab8;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.stripe-payment-dialog{width:min(100%,560px);max-height:calc(100dvh - 32px);display:flex;flex-direction:column;overflow:hidden;border-radius:var(--radius-xl)}.stripe-payment-header{flex-shrink:0;display:flex;align-items:flex-start;justify-content:space-between;gap:var(--sp-4)}.stripe-payment-body{overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.payment-result-page{min-height:100%;display:grid;place-items:center;padding:clamp(20px,4vw,48px);background:radial-gradient(circle at top left,rgba(20,184,166,.12),transparent 36%),radial-gradient(circle at bottom right,rgba(99,102,241,.12),transparent 32%),var(--bg-secondary)}.payment-result-card{width:min(100%,560px);padding:clamp(24px,5vw,48px);border:1px solid var(--border-primary);border-radius:var(--radius-xl);background:var(--bg-primary);box-shadow:var(--shadow-xl);text-align:center}.payment-result-icon{width:76px;height:76px;margin:0 auto var(--sp-5);display:grid;place-items:center;border-radius:999px}.payment-result-card-success .payment-result-icon{color:var(--success-700);background:var(--success-50)}.payment-result-card-failed .payment-result-icon{color:var(--error-600);background:var(--error-50)}.payment-result-kicker{margin-bottom:var(--sp-2);font-size:.75rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.payment-result-card-success .payment-result-kicker{color:var(--success-700)}.payment-result-card-failed .payment-result-kicker{color:var(--error-600)}.payment-result-card h1{margin:0 0 var(--sp-3);font-size:clamp(1.75rem,4vw,2.5rem);line-height:1.1;color:var(--text-primary)}.payment-result-message{max-width:420px;margin:0 auto var(--sp-7);color:var(--text-secondary);line-height:1.6}.payment-result-details{display:grid;gap:var(--sp-3);margin-bottom:var(--sp-7);padding:var(--sp-4);border:1px solid var(--border-primary);border-radius:var(--radius-lg);background:var(--bg-secondary);text-align:left}.payment-result-details>div{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-4)}.payment-result-details span{color:var(--text-secondary);font-size:.875rem}.payment-result-details strong{color:var(--text-primary);font-size:.875rem;text-align:right;overflow-wrap:anywhere}.payment-result-actions{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3)}@media (max-width: 640px){.stripe-payment-overlay{align-items:flex-end;padding:var(--sp-2)}.stripe-payment-dialog{width:100%;max-height:calc(100dvh - 16px);border-radius:var(--radius-lg)}.stripe-payment-header,.stripe-payment-body{padding:var(--sp-4)}.payment-result-page{align-items:stretch;padding:var(--sp-4)}.payment-result-card{align-self:center;border-radius:var(--radius-lg)}.payment-result-details>div{align-items:flex-start;flex-direction:column;gap:4px}.payment-result-details strong{text-align:left}.payment-result-actions{grid-template-columns:1fr}}.stat-card{display:flex;flex-direction:column;gap:var(--sp-1)}.stat-card .stat-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.25rem;margin-bottom:var(--sp-2)}.stat-card .stat-value{font-size:1.875rem;font-weight:700;color:var(--text-primary);letter-spacing:-.03em;line-height:1.15}.stat-card .stat-label{font-size:.875rem;color:var(--text-secondary);font-weight:500}.stat-card .stat-change{font-size:.8125rem;font-weight:600;display:inline-flex;align-items:center;gap:4px;margin-top:var(--sp-2)}.stat-change.positive{color:var(--success-600)}.stat-change.negative{color:var(--error-600)}table{width:100%;border-collapse:collapse}thead th{text-align:left;font-size:.75rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--border-primary);background:var(--bg-secondary);white-space:nowrap}tbody td{padding:var(--sp-4);font-size:.875rem;color:var(--text-primary);border-bottom:1px solid var(--border-primary);vertical-align:middle}tbody tr{transition:background var(--transition-fast)}tbody tr:hover{background:var(--bg-secondary)}tbody tr:last-child td{border-bottom:none}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;white-space:nowrap;line-height:1.4}.badge-gray{background:var(--gray-100);color:var(--gray-700)}.badge-error{background:var(--error-50);color:var(--error-700)}.input{display:block;width:100%;padding:10px 14px;font-family:inherit;font-size:.875rem;color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--border-secondary);border-radius:var(--radius-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none;line-height:1.5}.input::placeholder{color:var(--text-placeholder)}.input:focus{border-color:var(--primary-300);box-shadow:var(--shadow-focus)}.input-lg{padding:12px 16px;font-size:1rem}textarea.input{resize:vertical;min-height:80px}.form-label{display:block;font-size:.875rem;font-weight:500;color:var(--text-secondary);margin-bottom:var(--sp-1)}.form-hint{font-size:.8125rem;color:var(--text-tertiary)}.form-error{font-size:.8125rem;color:var(--error-600)}.tabs{display:flex;gap:0;border-bottom:1px solid var(--border-primary);margin-bottom:var(--sp-6)}.tab{padding:var(--sp-3) var(--sp-4);font-size:.875rem;font-weight:500;color:var(--text-tertiary);cursor:pointer;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all var(--transition-fast);font-family:inherit}.tab:hover{color:var(--text-secondary)}.tab.active{color:var(--primary-700);border-bottom-color:var(--primary-600);font-weight:600}.progress-bar{width:100%;height:8px;background:var(--gray-100);border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;background:var(--primary-500);border-radius:var(--radius-full);transition:width var(--transition-smooth)}.progress-fill.success{background:var(--success-500)}.progress-fill.warning{background:var(--warning-500)}.avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-full);font-weight:600;flex-shrink:0}.avatar-sm{width:28px;height:28px;font-size:.6875rem}.avatar-md{width:36px;height:36px;font-size:.8125rem}.avatar-lg{width:48px;height:48px;font-size:1.125rem}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--sp-16) var(--sp-8);text-align:center}.empty-state-icon{width:48px;height:48px;background:var(--gray-100);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--gray-400);margin-bottom:var(--sp-4)}.empty-state h3{margin-bottom:var(--sp-2)}.empty-state p{max-width:360px;margin-bottom:var(--sp-5)}.toast-container{position:fixed;bottom:var(--sp-8);right:var(--sp-8);z-index:100;display:flex;flex-direction:column;gap:var(--sp-3)}.toast{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-5);background:var(--gray-900);color:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);font-size:.875rem;font-weight:500;animation:toast-in .3s ease;min-width:320px}@keyframes toast-in{0%{opacity:0;transform:translateY(12px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.skeleton{background:linear-gradient(90deg,var(--gray-100) 25%,var(--gray-200) 50%,var(--gray-100) 75%);background-size:400% 100%;animation:skeleton-shimmer 1.5s ease infinite;border-radius:var(--radius-md)}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{height:14px;width:70%;margin-bottom:8px}.skeleton-title{height:20px;width:50%;margin-bottom:12px}.skeleton-block{height:80px;width:100%;margin-bottom:12px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.flex-1{flex:1}.flex-wrap{flex-wrap:wrap}.gap-1{gap:var(--sp-1)}.gap-2{gap:var(--sp-2)}.gap-3{gap:var(--sp-3)}.gap-4{gap:var(--sp-4)}.gap-6{gap:var(--sp-6)}.gap-8{gap:var(--sp-8)}.grid{display:grid}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.text-xs{font-size:.75rem}.text-lg{font-size:1.125rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-brand{color:var(--text-brand)}.text-success{color:var(--success-600)}.text-error{color:var(--error-600)}.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--sp-6)}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--sp-6)}.auth-page{display:flex;min-height:100vh;background:var(--bg-primary)}.auth-hero-side{flex:0 0 480px;background:linear-gradient(160deg,var(--primary-900) 0%,var(--primary-700) 50%,var(--primary-600) 100%);color:#fff;display:flex;align-items:center;justify-content:center;padding:var(--sp-12);position:relative;overflow:hidden}.auth-hero-side:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 20% 80%,rgba(13,148,136,.25) 0%,transparent 60%),radial-gradient(ellipse at 80% 20%,rgba(45,212,191,.2) 0%,transparent 50%);pointer-events:none}.auth-hero-side:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");pointer-events:none}.auth-hero-content{position:relative;z-index:1;max-width:360px}.auth-hero-logo{width:52px;height:52px;background:#ffffff26;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.2);border-radius:14px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.125rem;letter-spacing:-.02em;margin-bottom:var(--sp-6)}.auth-hero-title{font-size:2rem;font-weight:800;letter-spacing:-.03em;color:#fff;margin-bottom:var(--sp-3)}.auth-hero-subtitle{font-size:1rem;line-height:1.6;color:#ffffffb3;margin-bottom:var(--sp-10)}.auth-hero-features{display:flex;flex-direction:column;gap:var(--sp-5)}.auth-hero-feature{display:flex;align-items:flex-start;gap:var(--sp-4)}.auth-hero-feature-icon{width:36px;height:36px;min-width:36px;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#ffffffd9}.auth-hero-feature-title{font-size:.875rem;font-weight:600;color:#fff;margin-bottom:2px}.auth-hero-feature-desc{font-size:.8125rem;color:#ffffff8c;line-height:1.4}.auth-hero-footer{margin-top:var(--sp-12);padding-top:var(--sp-6);border-top:1px solid rgba(255,255,255,.12);font-size:.8125rem;color:#fff6}.auth-form-side{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--sp-8);overflow-y:auto}.auth-form-container{width:100%;max-width:400px}.auth-form-header{text-align:center;margin-bottom:var(--sp-8)}.auth-mobile-logo{display:none;width:44px;height:44px;background:var(--primary-600);border-radius:12px;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:1rem;margin:0 auto var(--sp-5)}.auth-form-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em;margin-bottom:var(--sp-2)}.auth-form-desc{font-size:.9375rem;color:var(--text-secondary)}.auth-error{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);background:var(--error-50);color:var(--error-700);border-radius:var(--radius-md);border:1px solid rgba(240,68,56,.12);font-size:.875rem;font-weight:500;margin-bottom:var(--sp-6);animation:authShake .4s ease}@keyframes authShake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.auth-form{display:flex;flex-direction:column;gap:var(--sp-5)}.auth-field{display:flex;flex-direction:column;gap:var(--sp-2)}.auth-label{font-size:.8125rem;font-weight:600;color:var(--text-primary)}.auth-input-wrap{position:relative;display:flex;align-items:center}.auth-input-icon{position:absolute;left:14px;color:var(--gray-400);pointer-events:none;transition:color .2s}.auth-input-wrap:focus-within .auth-input-icon{color:var(--primary-500)}.auth-input{width:100%;padding:11px 14px 11px 44px;font-size:.9375rem;font-family:inherit;border:1.5px solid var(--gray-200);border-radius:var(--radius-md);background:#fff;color:var(--text-primary);outline:none;transition:border-color .2s,box-shadow .2s}.auth-input::placeholder{color:var(--gray-400)}.auth-input:focus{border-color:var(--primary-400);box-shadow:0 0 0 3px #0d94881f}.auth-hint{font-size:.75rem;color:var(--text-tertiary);line-height:1.4;margin-top:2px}.auth-role-picker{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3)}.auth-role-option{display:flex;flex-direction:column;align-items:center;gap:var(--sp-2);padding:var(--sp-4) var(--sp-3);border:1.5px solid var(--gray-200);border-radius:var(--radius-lg);background:#fff;cursor:pointer;font-family:inherit;transition:all .2s;text-align:center;color:var(--text-secondary)}.auth-role-option:hover{border-color:var(--gray-300);background:var(--gray-25)}.auth-role-option.active{border-color:var(--primary-500);background:var(--primary-25);color:var(--primary-700);box-shadow:0 0 0 3px #0d948814}.auth-role-option.active svg{color:var(--primary-600)}.auth-role-label{font-size:.875rem;font-weight:600}.auth-role-desc{font-size:.6875rem;color:var(--text-tertiary);line-height:1.3}.auth-role-option.active .auth-role-desc{color:var(--primary-500)}.auth-submit{display:flex;align-items:center;justify-content:center;gap:var(--sp-2);width:100%;padding:12px 20px;font-size:.9375rem;font-weight:600;font-family:inherit;background:var(--primary-600);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .2s;margin-top:var(--sp-2)}.auth-submit:hover:not(:disabled){background:var(--primary-700);transform:translateY(-1px);box-shadow:var(--shadow-md)}.auth-submit:active:not(:disabled){transform:translateY(0)}.auth-submit:disabled{opacity:.65;cursor:not-allowed}.auth-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:authSpin .6s linear infinite}@keyframes authSpin{to{transform:rotate(360deg)}}.auth-form-footer{text-align:center;margin-top:var(--sp-8)}.auth-form-footer p{font-size:.8125rem;color:var(--text-tertiary);margin-bottom:var(--sp-2)}.auth-form-hint{font-size:.75rem!important;color:var(--text-tertiary);margin-top:var(--sp-2)}.auth-link{color:var(--primary-600);font-weight:500;text-decoration:none;transition:color .15s}.auth-link:hover{color:var(--primary-700);text-decoration:underline}@media (max-width: 920px){.auth-hero-side{display:none}.auth-mobile-logo{display:inline-flex}.auth-form-side{padding:var(--sp-6)}}@media (max-width: 480px){.auth-form-container{max-width:100%}.auth-role-picker{grid-template-columns:1fr}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.session-layout{display:grid;grid-template-columns:260px 1fr 300px;grid-template-rows:auto 1fr auto;height:calc(100vh - var(--header-height));max-height:calc(100vh - var(--header-height));margin:calc(-1 * var(--sp-8))}.session-toolbar{grid-column:1 / -1;display:flex;align-items:center;justify-content:space-between;gap:var(--sp-4);padding:var(--sp-4) var(--sp-6);background:var(--bg-primary);border-bottom:1px solid var(--border-primary)}.session-toolbar-left{display:flex;align-items:center;gap:var(--sp-4)}.session-live-dot{width:8px;height:8px;background:var(--error-500);border-radius:var(--radius-full);animation:pulse-live 2s ease infinite}@keyframes pulse-live{0%,to{opacity:1;box-shadow:0 0 #f0443880}50%{opacity:.8;box-shadow:0 0 0 6px #f0443800}}.session-steps-sidebar{grid-row:2;background:var(--bg-primary);border-right:1px solid var(--border-primary);overflow-y:auto;padding:var(--sp-4)}.session-step-item{display:flex;align-items:flex-start;gap:var(--sp-3);padding:var(--sp-3) var(--sp-3);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast);margin-bottom:var(--sp-1)}.session-step-item:hover{background:var(--bg-secondary)}.session-step-number{width:28px;height:28px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0;background:var(--gray-100);color:var(--gray-500)}.session-step-title{font-size:.8125rem;font-weight:500;color:var(--text-secondary);line-height:1.4}.session-center{grid-row:2;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--sp-12);overflow-y:auto;background:var(--bg-secondary)}.session-prompt-card{max-width:640px;width:100%}.session-prompt-card h2{font-size:1.5rem;margin-bottom:var(--sp-6)}.session-prompt-text{font-size:1.125rem;line-height:1.8;color:var(--text-primary)}.session-roster-panel{grid-row:2;background:var(--bg-primary);border-left:1px solid var(--border-primary);overflow-y:auto;display:flex;flex-direction:column}.session-roster-header{padding:var(--sp-4) var(--sp-5);border-bottom:1px solid var(--border-primary);display:flex;align-items:center;justify-content:space-between}.session-roster-list{flex:1;padding:var(--sp-3);overflow-y:auto}.session-student-row{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-2) var(--sp-3);border-radius:var(--radius-md);transition:background var(--transition-fast)}.session-student-row:hover{background:var(--bg-secondary)}.session-student-status{width:8px;height:8px;border-radius:var(--radius-full);flex-shrink:0}.status-online{background:var(--success-500)}.status-offline{background:var(--gray-300)}.status-submitted{background:var(--primary-500)}.session-footer{grid-column:1 / -1;display:flex;align-items:center;justify-content:center;gap:var(--sp-8);padding:var(--sp-4) var(--sp-6);background:var(--bg-primary);border-top:1px solid var(--border-primary)}.submission-counter{display:flex;align-items:center;gap:var(--sp-4)}.submission-counter-value{font-size:1.5rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.submission-counter-label{font-size:.8125rem;color:var(--text-tertiary)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1018288c;display:flex;align-items:center;justify-content:center;z-index:60;animation:overlay-in .2s ease}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-2xl);max-width:520px;width:100%;margin:var(--sp-4);animation:modal-in .2s ease}@keyframes modal-in{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{padding:var(--sp-6);display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border-primary)}.modal-footer{padding:var(--sp-4) var(--sp-6);border-top:1px solid var(--border-primary);display:flex;align-items:center;justify-content:flex-end;gap:var(--sp-3)}.divider{height:1px;background:var(--border-primary);margin:var(--sp-6) 0}@media (max-width: 1024px){.stat-grid,.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}.session-layout{grid-template-columns:1fr}.session-steps-sidebar,.session-roster-panel{display:none}}@media (max-width: 768px){.sidebar{transform:translate(-100%)}.main-content{margin-left:0}.page-body,.page-header{padding:var(--sp-4)}.stat-grid,.grid-2,.card-grid{grid-template-columns:1fr}}.ob-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,var(--primary-900) 0%,#1e1b4b 30%,var(--primary-800) 60%,var(--primary-700) 100%);position:relative;overflow:hidden;padding:var(--sp-6)}.ob-bg-orb{position:absolute;border-radius:50%;filter:blur(100px);pointer-events:none;animation:ob-orb-float 20s ease-in-out infinite}.ob-bg-orb-1{width:600px;height:600px;background:#6366f126;top:-200px;right:-150px;animation-delay:0s}.ob-bg-orb-2{width:500px;height:500px;background:#818cf81a;bottom:-200px;left:-100px;animation-delay:-7s}.ob-bg-orb-3{width:350px;height:350px;background:#a5b4fc14;top:40%;left:50%;animation-delay:-14s}@keyframes ob-orb-float{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-50px) scale(1.05)}66%{transform:translate(-20px,40px) scale(.95)}}.ob-confetti-canvas{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;pointer-events:none}.ob-container{position:relative;z-index:10;width:100%;max-width:620px;display:flex;flex-direction:column;align-items:center;gap:var(--sp-6)}.ob-stepper{display:flex;align-items:center;gap:0;margin-bottom:var(--sp-2)}.ob-step-indicator{display:flex;align-items:center;gap:var(--sp-2)}.ob-step-dot{width:32px;height:32px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:#ffffff4d;background:#ffffff14;border:2px solid rgba(255,255,255,.12);transition:all .4s cubic-bezier(.4,0,.2,1);flex-shrink:0}.ob-step-indicator.active .ob-step-dot{background:var(--primary-500);border-color:var(--primary-400);color:#fff;box-shadow:0 0 0 4px #6366f140,0 0 20px #6366f14d;animation:ob-dot-pulse 2s ease infinite}.ob-step-indicator.completed .ob-step-dot{background:var(--success-500);border-color:var(--success-500);color:#fff;box-shadow:none}@keyframes ob-dot-pulse{0%,to{box-shadow:0 0 0 4px #6366f140,0 0 20px #6366f14d}50%{box-shadow:0 0 0 8px #6366f11a,0 0 30px #6366f126}}.ob-step-label{font-size:.75rem;font-weight:600;color:#ffffff40;transition:color .3s;white-space:nowrap}.ob-step-indicator.active .ob-step-label{color:#ffffffe6}.ob-step-indicator.completed .ob-step-label{color:#ffffff80}.ob-step-line{width:40px;height:2px;background:#ffffff1a;margin:0 var(--sp-2);border-radius:var(--radius-full);transition:background .4s;flex-shrink:0}.ob-step-line.filled{background:var(--success-500)}.ob-card{width:100%;background:#fffffff7;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-2xl);box-shadow:0 25px 50px -12px #00000040,0 0 0 1px #ffffff0d inset;overflow:hidden}.ob-card-inner{padding:var(--sp-10) var(--sp-8)}.ob-slide-in-right{animation:ob-slide-right .45s cubic-bezier(.4,0,.2,1)}.ob-slide-in-left{animation:ob-slide-left .45s cubic-bezier(.4,0,.2,1)}@keyframes ob-slide-right{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}@keyframes ob-slide-left{0%{opacity:0;transform:translate(-40px)}to{opacity:1;transform:translate(0)}}.ob-step-content{display:flex;flex-direction:column;align-items:center;text-align:center}.ob-step-icon{width:72px;height:72px;background:var(--primary-50);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;color:var(--primary-600);margin-bottom:var(--sp-5);animation:ob-icon-bounce .6s ease}@keyframes ob-icon-bounce{0%{transform:scale(.5);opacity:0}60%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.ob-title{font-size:1.625rem;font-weight:800;color:var(--text-primary);letter-spacing:-.03em;margin-bottom:var(--sp-2);line-height:1.2}.ob-subtitle{font-size:.9375rem;color:var(--text-secondary);line-height:1.6;max-width:420px;margin-bottom:var(--sp-8)}.ob-welcome .ob-welcome-icon{width:80px;height:80px;background:linear-gradient(135deg,var(--primary-500),var(--primary-700));border-radius:24px;display:flex;align-items:center;justify-content:center;color:#fff;margin-bottom:var(--sp-6);animation:ob-icon-bounce .7s ease;box-shadow:0 12px 32px -4px #6366f166}.ob-welcome-features{display:flex;flex-direction:column;gap:var(--sp-4);margin-bottom:var(--sp-8);width:100%;max-width:340px}.ob-welcome-feature{display:flex;align-items:center;gap:var(--sp-4);text-align:left;font-size:.9375rem;color:var(--text-secondary);font-weight:500}.ob-feature-badge{width:28px;height:28px;min-width:28px;border-radius:var(--radius-full);background:var(--primary-50);color:var(--primary-700);font-size:.75rem;font-weight:800;display:flex;align-items:center;justify-content:center}.ob-form{width:100%;display:flex;flex-direction:column;gap:var(--sp-5);text-align:left}.ob-field{display:flex;flex-direction:column;gap:var(--sp-2);position:relative}.ob-label{font-size:.8125rem;font-weight:600;color:var(--text-primary)}.ob-optional{font-weight:400;color:var(--text-tertiary)}.ob-input{width:100%;padding:11px 14px;font-size:.9375rem;font-family:inherit;border:1.5px solid var(--gray-200);border-radius:var(--radius-md);background:#fff;color:var(--text-primary);outline:none;transition:border-color .2s,box-shadow .2s}.ob-input::placeholder{color:var(--gray-400)}.ob-input:focus{border-color:var(--primary-400);box-shadow:0 0 0 3px #4f46e51f}.ob-textarea{width:100%;padding:11px 14px;font-size:.9375rem;font-family:inherit;border:1.5px solid var(--gray-200);border-radius:var(--radius-md);background:#fff;color:var(--text-primary);outline:none;resize:vertical;min-height:80px;transition:border-color .2s,box-shadow .2s;line-height:1.5}.ob-textarea::placeholder{color:var(--gray-400)}.ob-textarea:focus{border-color:var(--primary-400);box-shadow:0 0 0 3px #4f46e51f}.ob-char-count{font-size:.6875rem;color:var(--text-tertiary);text-align:right}.ob-avatar-upload{display:flex;align-items:center;gap:var(--sp-4);padding:var(--sp-4);background:var(--gray-50);border-radius:var(--radius-lg);border:1px solid var(--border-primary)}.ob-avatar-circle{width:56px;height:56px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--primary-500),var(--primary-700));color:#fff;font-weight:700;font-size:1.125rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.ob-avatar-info{display:flex;flex-direction:column;gap:2px;min-width:0}.ob-avatar-info strong{font-size:.9375rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ob-avatar-info span{font-size:.8125rem;color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ob-tag-grid{display:flex;flex-wrap:wrap;gap:var(--sp-2)}.ob-tag{display:inline-flex;align-items:center;gap:4px;padding:6px 14px;border-radius:var(--radius-full);border:1.5px solid var(--gray-200);background:#fff;color:var(--text-secondary);font-size:.8125rem;font-weight:500;font-family:inherit;cursor:pointer;transition:all .2s;white-space:nowrap}.ob-tag:hover{border-color:var(--primary-200);background:var(--primary-25);color:var(--primary-700)}.ob-tag.active{border-color:var(--primary-500);background:var(--primary-50);color:var(--primary-700);font-weight:600;box-shadow:0 0 0 2px #6366f11a}.ob-actions{display:flex;align-items:center;justify-content:space-between;width:100%;margin-top:var(--sp-8);gap:var(--sp-4)}.ob-btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);padding:12px 28px;font-size:.9375rem;font-weight:600;font-family:inherit;background:var(--primary-600);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .2s;white-space:nowrap}.ob-btn-primary:hover:not(:disabled){background:var(--primary-700);transform:translateY(-1px);box-shadow:0 8px 24px -4px #4f46e559}.ob-btn-primary:active:not(:disabled){transform:translateY(0)}.ob-btn-primary:disabled{opacity:.65;cursor:not-allowed}.ob-btn-ghost{display:inline-flex;align-items:center;gap:var(--sp-2);padding:12px 20px;font-size:.9375rem;font-weight:500;font-family:inherit;background:transparent;color:var(--text-tertiary);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .15s}.ob-btn-ghost:hover{color:var(--text-primary);background:var(--gray-50)}.ob-skip{background:none;border:none;font-family:inherit;font-size:.8125rem;font-weight:500;color:#fff6;cursor:pointer;padding:var(--sp-2) var(--sp-4);border-radius:var(--radius-md);transition:all .2s}.ob-skip:hover:not(:disabled){color:#ffffffb3;background:#ffffff0f}.ob-skip:disabled{opacity:.5;cursor:not-allowed}.ob-celebration .ob-celebration-icon{color:var(--success-500);margin-bottom:var(--sp-4);animation:ob-celebrate-icon .8s cubic-bezier(.4,0,.2,1)}@keyframes ob-celebrate-icon{0%{transform:scale(0) rotate(-30deg);opacity:0}50%{transform:scale(1.15) rotate(5deg)}to{transform:scale(1) rotate(0);opacity:1}}.ob-celebration-actions{margin-top:var(--sp-4)}@media (max-width: 640px){.ob-card-inner{padding:var(--sp-8) var(--sp-5)}.ob-stepper{transform:scale(.85);transform-origin:center}.ob-step-label{display:none}.ob-title{font-size:1.375rem}.ob-actions{flex-direction:column-reverse}.ob-actions .ob-btn-primary,.ob-actions .ob-btn-ghost{width:100%;justify-content:center}.ob-tag-grid{gap:var(--sp-1)}.ob-tag{font-size:.75rem;padding:5px 10px}}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--sp-6);padding:var(--sp-6) var(--sp-8);border-bottom:1px solid var(--border-primary, var(--gray-200));background:#fff;flex-wrap:wrap}.page-header-left{display:flex;flex-direction:column;gap:var(--sp-1)}.page-header-right{display:flex;align-items:center;gap:var(--sp-3);flex-wrap:wrap}.page-header-breadcrumb{font-size:.8125rem;color:var(--text-tertiary);display:flex;align-items:center;gap:var(--sp-1)}.page-header-title{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.page-body{padding:var(--sp-8)}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--sp-4)}.stat-card{display:flex;flex-direction:column;gap:var(--sp-2)}.stat-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.25rem;margin-bottom:var(--sp-1)}.stat-value{font-size:1.75rem;font-weight:800;color:var(--text-primary);line-height:1}.stat-label{font-size:.8125rem;color:var(--text-tertiary);font-weight:500}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;white-space:nowrap}.badge-dot{width:6px;height:6px;border-radius:var(--radius-full);background:currentColor}.badge-primary{background:var(--primary-50);color:var(--primary-700)}.badge-success{background:var(--success-50);color:var(--success-700)}.badge-warning{background:var(--warning-50);color:var(--warning-600)}.badge-gray{background:var(--gray-100);color:var(--gray-600)}.badge-danger{background:var(--error-50);color:var(--error-700)}.table-container{overflow-x:auto}.table-container table{width:100%;border-collapse:collapse;font-size:.875rem}.table-container thead{border-bottom:1px solid var(--border-primary, var(--gray-200))}.table-container th{padding:var(--sp-3) var(--sp-4);text-align:left;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-tertiary)}.table-container td{padding:var(--sp-3) var(--sp-4);color:var(--text-primary);border-bottom:1px solid var(--gray-100)}.table-container tbody tr:hover{background:var(--gray-25)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--sp-6)}.modal{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:520px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-5) var(--sp-6);border-bottom:1px solid var(--border-primary, var(--gray-200))}.modal-header h3{margin:0;font-size:1.125rem;font-weight:700}.modal-body{padding:var(--sp-6)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--sp-3);padding:var(--sp-4) var(--sp-6);border-top:1px solid var(--border-primary, var(--gray-200))}.empty-state{text-align:center;padding:var(--sp-12) var(--sp-6)}.empty-state-icon{font-size:3rem;margin-bottom:var(--sp-4)}.empty-state h3{font-size:1.125rem;font-weight:700;margin-bottom:var(--sp-2)}.empty-state p{font-size:.875rem;color:var(--text-tertiary);max-width:400px;margin:0 auto var(--sp-6);line-height:1.6}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--sp-5)}.card-hover{transition:border-color .15s,box-shadow .15s}.card-hover:hover{border-color:var(--primary-200);box-shadow:0 4px 12px #4f46e514}.card-footer{padding:var(--sp-4) var(--sp-5);border-top:1px solid var(--border-primary, var(--gray-200))}.btn-danger{background:var(--error-600);color:#fff}.btn-danger:hover:not(:disabled){background:var(--error-700)}.btn-icon{padding:6px;font-size:1.125rem;line-height:1}.form-hint{font-size:.75rem;color:var(--text-tertiary);margin-top:var(--sp-1)}.progress-bar{height:6px;background:var(--gray-100);border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-500),var(--primary-600));border-radius:var(--radius-full);transition:width .4s ease}.session-layout{display:grid;grid-template-columns:220px 1fr 300px;grid-template-rows:auto 1fr auto;grid-template-areas:"toolbar toolbar toolbar" "steps   center  roster" "footer  footer  footer";height:calc(100vh + -0px);overflow:hidden}.session-toolbar{grid-area:toolbar;display:flex;align-items:center;justify-content:space-between;padding:var(--sp-3) var(--sp-5);border-bottom:1px solid var(--border-primary, var(--gray-200));background:#fff;gap:var(--sp-3);flex-wrap:wrap}.session-toolbar-left{display:flex;align-items:center;gap:var(--sp-3)}.session-live-dot{width:8px;height:8px;border-radius:var(--radius-full);background:var(--error-500);animation:live-pulse 1.5s ease-in-out infinite}@keyframes live-pulse{0%,to{opacity:1;box-shadow:0 0 #f0443866}50%{opacity:.7;box-shadow:0 0 0 6px #f0443800}}.session-steps-sidebar{grid-area:steps;border-right:1px solid var(--border-primary, var(--gray-200));padding:var(--sp-4) var(--sp-3);overflow-y:auto;background:var(--gray-25)}.session-step-item{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-2) var(--sp-3);border-radius:var(--radius-md);cursor:pointer;transition:all .15s;margin-bottom:var(--sp-1)}.session-step-item:hover{background:var(--gray-100)}.session-step-item.active{background:var(--primary-50)}.session-step-item.active .session-step-number{background:var(--primary-600);color:#fff}.session-step-item.completed .session-step-number{background:var(--success-50);color:var(--success-600)}.session-step-number{width:28px;height:28px;border-radius:var(--radius-full);background:var(--gray-100);color:var(--text-tertiary);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0;transition:all .15s}.session-step-title{font-size:.8125rem;font-weight:500;color:var(--text-secondary)}.session-step-item.active .session-step-title{color:var(--primary-700);font-weight:600}.session-center{grid-area:center;display:flex;align-items:center;justify-content:center;padding:var(--sp-8);overflow-y:auto;background:var(--gray-25)}.session-prompt-card{max-width:560px;width:100%}.session-prompt-text{font-size:1.125rem;line-height:1.7;color:var(--text-secondary)}.session-roster-panel{grid-area:roster;border-left:1px solid var(--border-primary, var(--gray-200));display:flex;flex-direction:column;background:#fff}.session-roster-header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-4) var(--sp-4);border-bottom:1px solid var(--border-primary, var(--gray-200))}.session-roster-header h4{margin:0}.session-roster-list{flex:1;overflow-y:auto;padding:var(--sp-3)}.session-student-row{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-2) var(--sp-3);border-radius:var(--radius-md)}.session-footer{grid-area:footer;display:flex;align-items:center;gap:var(--sp-5);padding:var(--sp-3) var(--sp-6);border-top:1px solid var(--border-primary, var(--gray-200));background:#fff}.submission-counter{display:flex;align-items:center;gap:var(--sp-3)}.submission-counter-value{font-size:1.5rem;font-weight:800;color:var(--primary-600);line-height:1}.submission-counter-label{font-size:.75rem;color:var(--text-tertiary);font-weight:500}.student-session-layout{max-width:720px;margin:0 auto;padding:var(--sp-8);display:flex;flex-direction:column;gap:var(--sp-6)}.student-prompt-card{padding:var(--sp-8);text-align:center}.student-prompt-card h2{margin-bottom:var(--sp-4)}.student-editor{width:100%;min-height:200px;padding:var(--sp-4);font-size:1rem;font-family:inherit;line-height:1.7;border:1px solid var(--gray-300);border-radius:var(--radius-md);background:#fff;color:var(--text-primary);outline:none;resize:vertical;transition:border-color .15s,box-shadow .15s}.student-editor:focus{border-color:var(--primary-400);box-shadow:0 0 0 3px #4f46e51a}.student-editor::placeholder{color:var(--gray-400)}.student-char-count{font-size:.75rem;color:var(--text-tertiary);text-align:right;margin-top:var(--sp-1)}.student-session-ended{text-align:center;padding:var(--sp-12) 0}@media (max-width: 900px){.session-layout{grid-template-columns:1fr;grid-template-rows:auto auto 1fr auto auto;grid-template-areas:"toolbar" "center" "roster" "footer"}.session-steps-sidebar{display:none}}.card{background:var(--bg-primary, #fff);border:1px solid var(--border-primary, var(--gray-200));border-radius:var(--radius-xl);box-shadow:0 1px 2px #1018280d}.card-padding{padding:var(--sp-6)}.card-header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-5) var(--sp-6);border-bottom:1px solid var(--border-primary, var(--gray-200));gap:var(--sp-4)}.card-body{padding:var(--sp-6)}.tabs{display:flex;gap:var(--sp-1);margin-bottom:var(--sp-5);border-bottom:1px solid var(--border-primary, var(--gray-200))}.tab{display:inline-flex;align-items:center;padding:var(--sp-3) var(--sp-4);font-size:.875rem;font-weight:500;font-family:inherit;color:var(--text-tertiary);border:none;background:transparent;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s;white-space:nowrap}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--primary-600);border-bottom-color:var(--primary-600);font-weight:600}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);padding:10px 18px;font-size:.875rem;font-weight:600;font-family:inherit;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .15s;white-space:nowrap;text-decoration:none;line-height:1}.btn-primary{background:var(--primary-600);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-700)}.btn-primary:disabled{opacity:.55;cursor:not-allowed}.btn-secondary{background:#fff;color:var(--gray-700);border:1px solid var(--gray-300)}.btn-secondary:hover{background:var(--gray-50);border-color:var(--gray-400)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--gray-50);color:var(--text-primary)}.btn-sm{padding:6px 14px;font-size:.8125rem}.form-group{display:flex;flex-direction:column;gap:var(--sp-1)}.form-label{font-size:.8125rem;font-weight:600;color:var(--text-primary)}.input{width:100%;padding:10px 14px;font-size:.875rem;font-family:inherit;border:1px solid var(--gray-300);border-radius:var(--radius-md);background:#fff;color:var(--text-primary);outline:none;transition:border-color .15s,box-shadow .15s}.input::placeholder{color:var(--gray-400)}.input:focus{border-color:var(--primary-400);box-shadow:0 0 0 3px #4f46e51a}textarea.input{resize:vertical;min-height:80px;line-height:1.5}.form-error{font-size:.75rem;color:var(--error-600);font-weight:500;margin-top:2px}.text-sm{font-size:.8125rem}.text-secondary{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}.w-full{width:100%}.skeleton{background:linear-gradient(90deg,var(--gray-100) 25%,var(--gray-200) 50%,var(--gray-100) 75%);background-size:200% 100%;animation:skeleton-wave 1.5s ease-in-out infinite;border-radius:var(--radius-md)}.skeleton-title{height:24px}.skeleton-block{width:100%}@keyframes skeleton-wave{0%{background-position:200% 0}to{background-position:-200% 0}}.prof-layout{display:grid;grid-template-columns:300px 1fr;gap:var(--sp-6);align-items:start}.prof-sidebar{position:sticky;top:calc(var(--header-height) + var(--sp-8))}.prof-identity-card{overflow:hidden}.prof-cover{height:100px;background:linear-gradient(135deg,var(--primary-600) 0%,var(--primary-800) 100%);position:relative}.prof-cover-pattern{position:absolute;top:0;right:0;bottom:0;left:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.06'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}.prof-identity{display:flex;flex-direction:column;align-items:center;margin-top:-40px;padding:0 var(--sp-6) var(--sp-5)}.prof-avatar-lg{width:80px;height:80px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--primary-500),var(--primary-700));color:#fff;font-weight:700;font-size:1.5rem;display:flex;align-items:center;justify-content:center;border:4px solid var(--bg-primary);box-shadow:var(--shadow-md);position:relative;flex-shrink:0}.prof-avatar-img{width:100%;height:100%;border-radius:var(--radius-full);object-fit:cover}.prof-avatar-edit{position:absolute;bottom:-2px;right:-2px;width:28px;height:28px;border-radius:var(--radius-full);background:var(--bg-primary);border:2px solid var(--border-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);transition:all .15s;padding:0}.prof-avatar-edit:hover{background:var(--primary-50);color:var(--primary-600);border-color:var(--primary-300)}.prof-name{margin-top:var(--sp-3);font-size:1.125rem;font-weight:700;color:var(--text-primary);text-align:center}.prof-role-badge{display:inline-flex;align-items:center;padding:2px 12px;border-radius:var(--radius-full);background:var(--primary-50);color:var(--primary-700);font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-top:var(--sp-2)}.prof-email{font-size:.8125rem;color:var(--text-tertiary);margin-top:var(--sp-1);word-break:break-all;text-align:center}.prof-meta{padding:var(--sp-4) var(--sp-6);border-top:1px solid var(--border-primary);display:flex;flex-direction:column;gap:var(--sp-3)}.prof-meta-row{display:flex;align-items:center;gap:var(--sp-2);font-size:.8125rem;color:var(--text-secondary)}.prof-meta-row svg{color:var(--text-tertiary);flex-shrink:0}.prof-content{min-width:0}.prof-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-5) var(--sp-6)}.prof-span-2{grid-column:1 / -1}.prof-section-title{font-size:.8125rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;margin:0}.prof-divider{height:1px;background:var(--border-primary)}.prof-value{font-size:.9375rem;color:var(--text-primary);padding:10px 0;line-height:1.5;min-height:42px;display:flex;align-items:center;flex-wrap:wrap;gap:var(--sp-2)}.prof-value-readonly{color:var(--text-secondary);gap:var(--sp-2)}.prof-value-readonly svg{color:var(--text-tertiary);flex-shrink:0}.prof-tags{display:flex;flex-wrap:wrap;gap:var(--sp-1)}.prof-tag{display:inline-flex;align-items:center;padding:3px 10px;border-radius:var(--radius-full);background:var(--primary-50);color:var(--primary-700);font-size:.75rem;font-weight:600}.prof-link{color:var(--primary-600);text-decoration:none;font-weight:500}.prof-link:hover{text-decoration:underline}.prof-alert{padding:var(--sp-3) var(--sp-4);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;margin-bottom:var(--sp-5)}.prof-alert-success{background:var(--success-50);color:var(--success-700);border:1px solid rgba(18,183,106,.15)}.prof-alert-error{background:var(--error-50);color:var(--error-700);border:1px solid rgba(240,68,56,.15)}.prof-pw-form{display:flex;flex-direction:column;gap:var(--sp-5);max-width:480px}.prof-pw-wrap{position:relative;display:flex;align-items:center}.prof-pw-wrap .input{padding-right:44px}.prof-pw-toggle{position:absolute;right:12px;background:none;border:none;cursor:pointer;color:var(--text-tertiary);padding:4px;display:flex;align-items:center;transition:color .15s}.prof-pw-toggle:hover{color:var(--text-primary)}.prof-pw-strength{display:flex;align-items:center;gap:var(--sp-3);margin-top:var(--sp-2)}.prof-pw-strength-bar{flex:1;height:4px;background:var(--gray-100);border-radius:var(--radius-full);overflow:hidden}.prof-pw-strength-fill{height:100%;border-radius:var(--radius-full);transition:width .3s ease,background .3s ease}.prof-pw-strength-label{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.prof-match-ok{display:inline-flex;align-items:center;gap:4px;font-size:.8125rem;color:var(--success-600);font-weight:500;margin-top:2px}.prof-pw-rules{margin-top:var(--sp-8);padding-top:var(--sp-6);border-top:1px solid var(--border-primary)}.prof-pw-rules h4{font-size:.8125rem;font-weight:600;color:var(--text-secondary);margin-bottom:var(--sp-3)}.prof-pw-rules ul{list-style:none;display:flex;flex-direction:column;gap:var(--sp-2)}.prof-pw-rules li{font-size:.8125rem;color:var(--text-tertiary);display:flex;align-items:center;gap:var(--sp-2)}.prof-pw-rules li:before{content:"";width:6px;height:6px;border-radius:var(--radius-full);background:var(--gray-300);flex-shrink:0;transition:background .2s}.prof-pw-rules li.met{color:var(--success-600)}.prof-pw-rules li.met:before{background:var(--success-500)}.prof-pw-actions{padding-top:var(--sp-2)}@media (max-width: 900px){.prof-layout{grid-template-columns:1fr}.prof-sidebar{position:static}}@media (max-width: 640px){.prof-form-grid{grid-template-columns:1fr}.prof-span-2{grid-column:1}}.ls-shell{display:flex;flex-direction:column;height:100vh;overflow:hidden;background:var(--gray-50)}.ls-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:var(--sp-3)}.ls-loading-spinner{width:24px;height:24px;border:3px solid var(--gray-200);border-top-color:var(--primary-600);border-radius:50%;animation:spin .8s linear infinite}.ls-loading p{font-size:.875rem;color:var(--text-tertiary)}.ls-topbar{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-3) var(--sp-5);background:#fff;border-bottom:1px solid var(--gray-200);gap:var(--sp-3);flex-wrap:wrap;flex-shrink:0;z-index:10}.ls-topbar-left,.ls-topbar-right{display:flex;align-items:center;gap:var(--sp-3)}.ls-back-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-md);color:var(--text-secondary);transition:all .15s}.ls-back-btn:hover{background:var(--gray-100);color:var(--text-primary)}.ls-topbar-divider{width:1px;height:20px;background:var(--gray-200);flex-shrink:0}.ls-live-badge{display:flex;align-items:center;gap:6px;padding:3px 10px 3px 8px;background:var(--error-50);border-radius:var(--radius-full);font-size:.6875rem;font-weight:800;color:var(--error-600);letter-spacing:.08em;text-transform:uppercase}.ls-live-dot{width:7px;height:7px;border-radius:50%;background:var(--error-500);animation:ls-pulse 1.5s ease-in-out infinite}@keyframes ls-pulse{0%,to{opacity:1;box-shadow:0 0 #f0443866}50%{opacity:.6;box-shadow:0 0 0 6px #f0443800}}.ls-session-meta{display:flex;align-items:center;gap:6px;font-size:.8125rem}.ls-meta-class{font-weight:600;color:var(--text-primary)}.ls-meta-sep{color:var(--gray-300)}.ls-meta-lesson{color:var(--text-secondary)}.ls-timer{display:flex;align-items:center;gap:5px;padding:4px 10px;background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius-md);font-size:.8125rem;font-weight:600;color:var(--text-secondary);font-variant-numeric:tabular-nums}.ls-counter-badge{display:flex;align-items:baseline;gap:2px;padding:4px 12px;background:var(--primary-50);border:1px solid var(--primary-100);border-radius:var(--radius-md);font-size:.8125rem;font-weight:600}.ls-counter-num{color:var(--primary-700);font-size:.9375rem;font-weight:800}.ls-counter-sep{color:var(--primary-300)}.ls-counter-total{color:var(--primary-500)}.ls-counter-label{color:var(--primary-400);font-size:.6875rem;margin-left:4px;font-weight:500}.ls-body{display:flex;flex:1;min-height:0;overflow:hidden}.ls-main{flex:1;display:flex;flex-direction:column;overflow-y:auto;padding:var(--sp-6);gap:var(--sp-5)}.ls-phase-nav{display:flex;align-items:center;gap:var(--sp-1);padding:var(--sp-1);background:#fff;border-radius:var(--radius-lg);border:1px solid var(--gray-200);box-shadow:var(--shadow-xs)}.ls-phase-pill{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--radius-md);border:none;background:transparent;font-size:.8125rem;font-weight:500;color:var(--text-tertiary);cursor:pointer;transition:all .15s;white-space:nowrap}.ls-phase-pill:hover:not(:disabled){background:var(--gray-50);color:var(--text-secondary)}.ls-phase-pill.active{background:var(--gray-900);color:#fff;box-shadow:var(--shadow-sm)}.ls-phase-pill.completed{color:var(--text-secondary)}.ls-phase-dot{width:6px;height:6px;border-radius:50%;background:var(--gray-300);flex-shrink:0;transition:all .15s}.ls-phase-pill.active .ls-phase-dot{background:#fff!important}.ls-phase-pill.completed .ls-phase-dot{background:var(--success-500)}.ls-phase-label{line-height:1}.ls-content-area{flex:1;display:flex;align-items:flex-start;justify-content:center}.ls-content-card{width:100%;max-width:720px;background:#fff;border-radius:var(--radius-xl);border:1px solid var(--gray-200);box-shadow:var(--shadow-sm);overflow:hidden}.ls-content-phase-header{display:flex;align-items:center;gap:var(--sp-4);padding:var(--sp-6) var(--sp-6) var(--sp-4)}.ls-content-phase-icon{font-size:2rem;line-height:1}.ls-content-phase-step{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);margin-bottom:2px}.ls-content-phase-title{font-size:1.375rem;font-weight:700;color:var(--text-primary);margin:0}.ls-content-instruction{display:flex;align-items:flex-start;gap:var(--sp-3);margin:0 var(--sp-6);padding:var(--sp-3) var(--sp-4);background:var(--primary-25);border-radius:var(--radius-md);border-left:3px solid var(--primary-400);font-size:.8125rem;color:var(--primary-700);line-height:1.5}.ls-content-instruction svg{flex-shrink:0;margin-top:1px}.ls-prompt-block{margin:var(--sp-5) var(--sp-6);padding:var(--sp-5);background:var(--gray-25);border-radius:var(--radius-lg);border:1px solid var(--gray-200)}.ls-prompt-label{display:flex;align-items:center;gap:6px;font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);margin-bottom:var(--sp-3)}.ls-prompt-text{font-size:1.0625rem;line-height:1.8;color:var(--text-primary);margin:0;white-space:pre-wrap}.ls-progress-section{padding:var(--sp-4) var(--sp-6) var(--sp-5)}.ls-progress-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-2)}.ls-progress-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary)}.ls-progress-count{font-size:.8125rem;font-weight:600;color:var(--primary-600)}.ls-progress-track{height:8px;background:var(--gray-100);border-radius:var(--radius-full);overflow:hidden}.ls-progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-500),var(--primary-600));border-radius:var(--radius-full);transition:width .5s ease;min-width:0}.ls-step-controls{display:flex;align-items:center;justify-content:center;gap:var(--sp-6);padding:var(--sp-2) 0}.ls-step-indicator{display:flex;gap:6px}.ls-step-dot{width:8px;height:8px;border-radius:50%;background:var(--gray-200);transition:all .2s}.ls-step-dot.active{background:var(--primary-600);transform:scale(1.3)}.ls-step-dot.done{background:var(--success-400)}.ls-keyboard-hint{text-align:center;font-size:.75rem;color:var(--gray-400)}.ls-keyboard-hint kbd{display:inline-block;padding:1px 5px;margin:0 2px;background:var(--gray-100);border:1px solid var(--gray-300);border-radius:3px;font-size:.6875rem;font-family:inherit}.ls-panel{width:320px;flex-shrink:0;display:flex;flex-direction:column;background:#fff;border-left:1px solid var(--gray-200);overflow:hidden}.ls-panel-header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-4) var(--sp-5);border-bottom:1px solid var(--gray-200)}.ls-panel-header h4{margin:0;font-size:.9375rem;font-weight:700}.ls-roster-summary{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--gray-200);border-bottom:1px solid var(--gray-200)}.ls-roster-stat{display:flex;flex-direction:column;align-items:center;padding:var(--sp-3);background:#fff;gap:2px}.ls-roster-stat-num{font-size:1.25rem;font-weight:800;line-height:1}.ls-roster-stat.submitted .ls-roster-stat-num{color:var(--success-600)}.ls-roster-stat.waiting .ls-roster-stat-num{color:var(--gray-400)}.ls-roster-stat-label{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary)}.ls-roster-list{flex:1;overflow-y:auto;padding:var(--sp-3)}.ls-roster-empty{text-align:center;padding:var(--sp-8) var(--sp-4);color:var(--text-tertiary)}.ls-roster-empty span{font-size:2rem;display:block;margin-bottom:var(--sp-2)}.ls-roster-empty p{font-size:.8125rem;line-height:1.5;margin:0}.ls-student-card{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-2) var(--sp-3);border-radius:var(--radius-md);margin-bottom:2px;transition:background .1s}.ls-student-card:hover{background:var(--gray-50)}.ls-student-avatar{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.625rem;font-weight:700;flex-shrink:0}.ls-student-info{flex:1;min-width:0;display:flex;flex-direction:column}.ls-student-name{font-size:.8125rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ls-student-status{font-size:.6875rem}.ls-student-status.submitted{color:var(--success-600);font-weight:500}.ls-student-status.waiting{color:var(--gray-400)}.ls-feedback-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;border-radius:var(--radius-md);background:transparent;color:var(--text-tertiary);cursor:pointer;transition:all .15s;flex-shrink:0}.ls-feedback-btn:hover{background:var(--primary-50);color:var(--primary-600)}@media (max-width: 900px){.ls-body{flex-direction:column}.ls-panel{width:100%;border-left:none;border-top:1px solid var(--gray-200);max-height:280px}.ls-phase-nav{overflow-x:auto;-webkit-overflow-scrolling:touch}}@media (max-width: 600px){.ls-phase-pill .ls-phase-label,.ls-session-meta,.ls-counter-label{display:none}}.ls-script-block{margin-bottom:var(--sp-6);padding:var(--sp-4);background:var(--warning-25);border:1px solid var(--warning-100);border-radius:var(--radius-md)}.ls-script-label{display:flex;align-items:center;gap:var(--sp-2);font-size:.75rem;font-weight:700;color:var(--warning-700);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--sp-2)}.ls-script-content{font-size:1rem;line-height:1.6;color:var(--warning-900);font-style:italic;white-space:pre-wrap}.ls-online-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.ls-online-dot.online{background:var(--success-500);box-shadow:0 0 0 2px var(--success-100)}.ls-online-dot.offline{background:var(--gray-300)}.ls-student-card.waiting{border-left:3px solid var(--gray-200)}.ls-student-card.submitted{border-left:3px solid var(--success-500)}.theme-toggle{margin-top:var(--sp-2)}.theme-toggle .link-icon{color:var(--primary-600)}.card,.auth-card,.modal-card,.dialog-card,.stripe-payment-dialog,.modal,.session-roster-panel,.session-footer,.session-toolbar,.ls-topbar,.ls-phase-nav,.ls-content-card,.ls-panel,.ls-student-card{background:var(--card-bg, var(--bg-primary));color:var(--text-primary)}.input,.auth-input,.ob-input,.ob-textarea,.profile-input,.profile-textarea,select.input,textarea.input{background:var(--bg-primary);color:var(--text-primary);border-color:var(--border-secondary)}.auth-role-option,.ob-tag,.keypad-btn{background:var(--bg-primary);color:var(--text-secondary);border-color:var(--border-secondary)}.auth-role-option:hover,.ob-tag:hover,.keypad-btn:hover{background:var(--bg-tertiary)}.btn-secondary{background:var(--bg-primary);color:var(--text-secondary);border-color:var(--border-secondary)}.btn-secondary:hover:not(:disabled){background:var(--bg-tertiary);color:var(--text-primary)}.page-header,.sidebar,.sidebar-footer{background-color:color-mix(in srgb,var(--bg-primary) 92%,transparent)}.table-container tbody tr:hover,tbody tr:hover{background:var(--bg-tertiary)}[data-theme=dark] .sidebar-brand-icon,[data-theme=dark] .btn-primary,[data-theme=dark] .btn-danger,[data-theme=dark] .btn-success{color:#06111a}[data-theme=dark] .sidebar-brand-icon{background:var(--primary-400)}[data-theme=dark] .sidebar-link.active,[data-theme=dark] .auth-role-option.active{background:var(--primary-50);color:var(--primary-700)}[data-theme=dark] .badge-gray{background:#94a3b829;color:var(--text-secondary)}[data-theme=dark] .badge-primary,[data-theme=dark] .badge-success,[data-theme=dark] .badge-warning,[data-theme=dark] .badge-error{border:1px solid currentColor}[data-theme=dark] .empty-state,[data-theme=dark] .page-body{color:var(--text-primary)}.billing-page,.marketplace-page{max-width:1440px;width:100%}.billing-page-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(360px,.82fr);gap:var(--sp-8);align-items:start}.billing-hero{display:flex;justify-content:space-between;gap:var(--sp-6);align-items:center;margin-bottom:var(--sp-8);background:linear-gradient(135deg,var(--primary-50),transparent 55%),var(--card-bg);border-color:var(--border-brand)}.billing-hero h2{margin:var(--sp-3) 0 var(--sp-2);font-size:clamp(1.4rem,3vw,2rem)}.billing-hero p{max-width:780px;margin:0}.billing-hero-price{min-width:180px;padding:var(--sp-5);border-radius:var(--radius-xl);background:var(--bg-inset);border:1px solid var(--border-primary);text-align:center}.billing-hero-price span{display:block;font-size:1.75rem;font-weight:800;color:var(--text-primary)}.billing-hero-price small{color:var(--text-tertiary);font-weight:600}.billing-card-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--sp-4);margin-bottom:var(--sp-5)}.billing-card-heading h3{margin:var(--sp-1) 0 0;font-size:1.25rem}.billing-status-meter{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-4);border-radius:var(--radius-lg);background:var(--bg-inset);border:1px solid var(--border-primary);margin-bottom:var(--sp-5)}.billing-status-meter div{width:12px;height:12px;border-radius:var(--radius-full);background:var(--warning-500)}.billing-status-meter div.active{background:var(--success-500)}.billing-status-meter span{font-weight:700;color:var(--text-primary)}.billing-detail-list,.billing-access-table{display:flex;flex-direction:column;gap:var(--sp-3)}.billing-detail-row,.billing-access-table div{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--sp-4);padding-bottom:var(--sp-3);border-bottom:1px solid var(--border-primary)}.billing-detail-row:last-child,.billing-access-table div:last-child{border-bottom:none;padding-bottom:0}.billing-detail-row span,.billing-access-table span{color:var(--text-tertiary);font-size:.875rem}.billing-detail-row strong,.billing-access-table strong{color:var(--text-primary);text-align:right;max-width:60%}.billing-plan-card{overflow:hidden;border-color:var(--border-brand)}.billing-plan-header{padding:var(--sp-8);background:var(--primary-50);border-bottom:1px solid var(--border-brand)}.billing-plan-header h3{margin:var(--sp-3) 0 var(--sp-2);font-size:1.35rem}.billing-plan-header p{margin:0}.billing-plan-body{padding:var(--sp-8);display:flex;flex-direction:column;gap:var(--sp-6)}.billing-primary-action{min-height:48px;border-radius:var(--radius-lg)}.billing-action-stack{display:flex;flex-direction:column;gap:var(--sp-3)}.billing-fine-print{margin:0;text-align:center}.marketplace-access-banner{display:flex;justify-content:space-between;align-items:center;gap:var(--sp-5);margin-bottom:var(--sp-6);border-color:var(--border-brand);background:var(--primary-50)}.marketplace-access-banner.is-unlocked{background:var(--success-50);border-color:var(--success-100)}.marketplace-access-banner h3{margin:var(--sp-2) 0 var(--sp-1);font-size:1.25rem}.marketplace-access-banner p{margin:0;max-width:720px}@media (max-width: 900px){.billing-page-grid,.billing-hero{grid-template-columns:1fr;flex-direction:column;align-items:stretch}.marketplace-access-banner{flex-direction:column;align-items:stretch}.billing-detail-row,.billing-access-table div{flex-direction:column;gap:var(--sp-1)}.billing-detail-row strong,.billing-access-table strong{max-width:none;text-align:left}}@media (max-width: 640px){.page-body,.billing-plan-header,.billing-plan-body{padding:var(--sp-5)}}
