:root{--primary: #0c4a6e;--primary-mid: #0369a1;--primary-light: #0ea5e9;--primary-xlight:#e0f2fe;--bg: #eef2f7;--surface: #ffffff;--surface-2: #f8fafd;--surface-3: #f0f4f9;--border: #dde4ee;--border-2: #c8d3e3;--text: #0f172a;--text-2: #334155;--text-muted: #64748b;--text-faint: #94a3b8;--critical: #dc2626;--critical-bg: #fef2f2;--critical-border:#fecaca;--high: #ea580c;--high-bg: #fff7ed;--high-border: #fed7aa;--moderate: #b45309;--moderate-bg: #fffbeb;--moderate-border:#fde68a;--low-mod: #1d4ed8;--low-mod-bg: #eff6ff;--low-mod-border:#bfdbfe;--low: #15803d;--low-bg: #f0fdf4;--low-border: #bbf7d0;--chart-1: #0369a1;--chart-2: #0891b2;--chart-3: #6366f1;--chart-4: #7c3aed;--chart-5: #0d9488;--success: #059669;--warning: #d97706;--danger: #dc2626;--info: #0369a1;--font: "Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--shadow-xs: 0 1px 2px rgba(12, 74, 110, .06);--shadow-sm: 0 1px 4px rgba(12, 74, 110, .08), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(12, 74, 110, .1), 0 1px 4px rgba(0,0,0,.05);--shadow-lg: 0 8px 24px rgba(12, 74, 110, .12), 0 2px 8px rgba(0,0,0,.06);--transition: .18s ease;--radius-sm: 8px;--radius: 12px;--radius-lg: 16px;--radius-xl: 20px}*,*: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:var(--font);background:var(--bg);color:var(--text);min-height:100vh;line-height:1.5;font-weight:400}a{color:var(--primary-mid);text-decoration:none;font-weight:500}a:hover{color:var(--primary)}h1,h2,h3,h4,h5,h6{font-family:var(--font);font-weight:700;line-height:1.2;color:var(--text);letter-spacing:-.015em}button{font-family:var(--font);font-weight:600;cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition);border:1px solid transparent}input,select,textarea{font-family:var(--font)}.landing-page{min-height:100vh;display:flex;flex-direction:column;background:#091929;font-family:var(--font);color:#dce8f5;overflow-x:hidden;position:relative}.lp-glow{position:fixed;border-radius:50%;pointer-events:none;z-index:0;filter:blur(80px)}.lp-glow--tl{top:-10%;left:-8%;width:55vw;height:55vw;background:radial-gradient(ellipse,rgba(14,165,233,.07) 0%,transparent 70%)}.lp-glow--br{bottom:-15%;right:-10%;width:50vw;height:50vw;background:radial-gradient(ellipse,rgba(99,102,241,.07) 0%,transparent 70%)}.lp-glow--mid{top:45%;left:35%;width:40vw;height:40vw;background:radial-gradient(ellipse,rgba(12,74,110,.12) 0%,transparent 70%)}.landing-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:18px;background:#091929;color:#4a7fa8}.landing-nav{height:56px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;padding:0 2.5rem;flex-shrink:0;position:relative;z-index:10;background:#091929d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.landing-nav-inner{width:100%;max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.landing-nav-brand{display:flex;align-items:center;gap:.6rem}.landing-nav-org{font-size:.67rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#4a9fd4}.landing-nav-sep{color:#ffffff2e;font-size:.85rem}.landing-nav-title{font-size:.8rem;font-weight:600;color:#ffffffa6}.landing-nav-right{display:flex;align-items:center;gap:16px}.landing-nav-version{font-size:.67rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#ffffff40}.landing-nav-btn{background:#ffffffeb;color:#0c1e35;border:none;padding:7px 18px;border-radius:6px;font-size:.78rem;font-weight:700;font-family:var(--font);cursor:pointer;transition:all .15s ease}.landing-nav-btn:hover{background:#fff;box-shadow:0 2px 12px #0000004d}.lp-hero{display:grid;grid-template-columns:1fr 400px;gap:40px;max-width:1400px;width:100%;margin:0 auto;padding:64px 2.5rem 56px;position:relative;z-index:1;align-items:start}.lp-hero-left{padding-right:32px}.lp-eyebrow{display:flex;align-items:center;gap:12px;font-size:.66rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#4a9fd4;margin-bottom:24px}.lp-eyebrow-line{display:inline-block;width:28px;height:2px;background:#4a9fd4;border-radius:2px;flex-shrink:0}.lp-headline{font-size:3rem;font-weight:800;line-height:1.08;letter-spacing:-.04em;color:#fff;margin-bottom:22px}.lp-headline-accent{color:#7dd3fc}.lp-subhead{font-size:1rem;color:#ffffff85;line-height:1.72;max-width:540px;font-weight:400;margin-bottom:40px}.lp-hero-pills{display:flex;align-items:center;gap:0;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:12px;overflow:hidden;width:fit-content}.lp-pill{padding:14px 22px;display:flex;flex-direction:column;gap:3px;border-right:1px solid rgba(255,255,255,.07)}.lp-pill:last-child{border-right:none}.lp-pill-val{font-size:1.5rem;font-weight:800;color:#fff;line-height:1;letter-spacing:-.03em}.lp-pill-lbl{font-size:.65rem;font-weight:600;color:#ffffff61;text-transform:uppercase;letter-spacing:.08em;white-space:nowrap}.lp-pill-sep{width:1px;height:28px;background:#ffffff12;align-self:center}.lp-hero-streams{margin-top:28px;border:1px solid rgba(255,255,255,.07);border-radius:12px;overflow:hidden}.lp-stream-item{display:flex;gap:16px;padding:18px 20px;border-bottom:1px solid rgba(255,255,255,.055);transition:background .15s}.lp-stream-item:last-child{border-bottom:none}.lp-stream-item:hover{background:#ffffff08}.lp-stream-num{font-size:.68rem;font-weight:800;color:#4a9fd4;letter-spacing:.06em;flex-shrink:0;width:22px;padding-top:2px;font-variant-numeric:tabular-nums}.lp-stream-name{font-size:.9rem;font-weight:700;color:#ffffffd9;margin-bottom:4px}.lp-stream-detail{font-size:.8rem;color:#fff6;line-height:1.6}.lp-hero-right{display:flex;flex-direction:column;gap:14px;position:sticky;top:72px}.access-card{background:#0d2240;border:1px solid rgba(74,159,212,.18);border-radius:16px;padding:30px 28px;box-shadow:0 8px 40px #0006,0 0 0 1px #ffffff0a}.access-eyebrow{font-size:.63rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#4a9fd4;margin-bottom:12px}.access-title{font-size:1.4rem;font-weight:800;color:#fff;margin-bottom:9px;letter-spacing:-.025em;line-height:1.2}.access-desc{font-size:.845rem;color:#ffffff7a;line-height:1.62;margin-bottom:22px}.access-btn{width:100%;background:#4a9fd4;color:#fff;border:none;padding:13px 20px;border-radius:9px;font-size:.9rem;font-weight:700;font-family:var(--font);cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:16px;letter-spacing:.005em}.access-btn-icon{font-size:1.1rem;transition:transform .15s ease}.access-btn:hover{background:#0ea5e9;box-shadow:0 4px 20px #0ea5e959;transform:translateY(-1px)}.access-btn:hover .access-btn-icon{transform:translate(3px)}.access-roles{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.access-roles-label{font-size:.61rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#ffffff47;white-space:nowrap}.access-role-chips{display:flex;gap:6px;flex-wrap:wrap}.arc{font-size:.72rem;font-weight:700;padding:3px 10px;border-radius:20px}.arc--admin{background:#dc262626;color:#fca5a5;border:1px solid rgba(220,38,38,.25)}.arc--lead{background:#4a9fd426;color:#7dd3fc;border:1px solid rgba(74,159,212,.25)}.arc--op{background:#15803d26;color:#86efac;border:1px solid rgba(21,128,61,.25)}.workflow-card{background:#ffffff0a;border:1px solid rgba(255,255,255,.07);border-radius:14px;padding:22px 24px}.workflow-eyebrow{font-size:.63rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#ffffff4d;margin-bottom:16px}.workflow-steps{display:flex;flex-direction:column;gap:0}.ws{display:flex;gap:14px;align-items:flex-start;padding:13px 0;border-bottom:1px solid rgba(255,255,255,.055)}.ws:last-child{border-bottom:none;padding-bottom:0}.ws:first-child{padding-top:0}.ws-num{font-size:.7rem;font-weight:800;color:#4a9fd4;letter-spacing:.03em;width:22px;flex-shrink:0;padding-top:1px;font-variant-numeric:tabular-nums}.ws-title{font-size:.85rem;font-weight:700;color:#ffffffd1;margin-bottom:3px}.ws-desc{font-size:.77rem;color:#ffffff61;line-height:1.5}.lp-risk-band{border-top:1px solid rgba(255,255,255,.06);padding:40px 0 44px;position:relative;z-index:1}.lp-risk-band-inner{max-width:1400px;margin:0 auto;padding:0 2.5rem}.lp-section-eyebrow{font-size:.63rem;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:#ffffff47;margin-bottom:18px}.risk-levels{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}.risk-level-card{background:var(--rl-bg);border:1px solid rgba(255,255,255,.06);border-radius:10px;padding:16px 16px 14px;transition:border-color .15s,transform .15s}.risk-level-card:hover{border-color:#ffffff24;transform:translateY(-2px)}.rl-label{font-size:.8rem;font-weight:800;margin-bottom:2px;letter-spacing:.01em}.rl-desc{font-size:.73rem;color:#ffffff61;line-height:1.4}.lp-features{padding:48px 0 56px;position:relative;z-index:1;border-top:1px solid rgba(255,255,255,.06)}.lp-features-inner{max-width:1400px;margin:0 auto;padding:0 2.5rem}.lp-section-header{margin-bottom:32px}.lp-section-header--row{display:flex;justify-content:space-between;align-items:flex-end;gap:40px}.lp-section-title{font-size:1.6rem;font-weight:800;color:#fff;letter-spacing:-.03em;line-height:1.15;margin-top:6px}.lp-section-sub{font-size:.875rem;color:#ffffff6b;line-height:1.65;max-width:420px;text-align:right}.bento-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,auto);gap:12px}.bento-p11{grid-column:1;grid-row:1 / 3}.bento-p21{grid-column:2;grid-row:1}.bento-p31{grid-column:3;grid-row:1}.bento-p22{grid-column:2;grid-row:2}.bento-p32{grid-column:3;grid-row:2 / 4}.bento-p13{grid-column:1 / 3;grid-row:3}.bento-card{border-radius:14px;padding:26px 24px;border:1px solid rgba(255,255,255,.07);transition:border-color .18s,transform .18s,box-shadow .18s;position:relative;overflow:hidden;display:flex;flex-direction:column}.bento-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;border-radius:14px 14px 0 0;opacity:0;transition:opacity .18s}.bento-card:hover{border-color:#ffffff24;transform:translateY(-3px);box-shadow:0 12px 32px #0000004d}.bento-card:hover:before{opacity:1}.bento-card--blue{background:#0369a11f}.bento-card--blue:before{background:linear-gradient(90deg,#0369a1,#0ea5e9)}.bento-card--teal{background:#0d94881a}.bento-card--teal:before{background:linear-gradient(90deg,#0d9488,#2dd4bf)}.bento-card--amber{background:#b475091a}.bento-card--amber:before{background:linear-gradient(90deg,#b45309,#fbbf24)}.bento-card--purple{background:#6d28d91f}.bento-card--purple:before{background:linear-gradient(90deg,#6d28d9,#a78bfa)}.bento-card--slate{background:#1e3a6459;border-color:#ffffff17}.bento-card--slate:before{background:linear-gradient(90deg,#1d4ed8,#60a5fa)}.bento-card--green{background:#15803d1a}.bento-card--green:before{background:linear-gradient(90deg,#15803d,#4ade80)}.bento-title{font-size:1.05rem;font-weight:700;color:#fff;margin-bottom:10px;letter-spacing:-.01em}.bento-desc{font-size:.855rem;color:#ffffff85;line-height:1.65;margin-bottom:18px}.bento-card--sm .bento-desc{margin-bottom:0}.bento-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto}.bento-tags span{font-size:.7rem;font-weight:600;padding:3px 10px;border-radius:20px;background:#ffffff14;color:#ffffff8c;border:1px solid rgba(255,255,255,.08);white-space:nowrap}.lp-categories{padding:48px 0 56px;border-top:1px solid rgba(255,255,255,.06);position:relative;z-index:1}.lp-categories-inner{max-width:1400px;margin:0 auto;padding:0 2.5rem}.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.cat-chip{border-radius:10px;padding:16px 18px;display:flex;align-items:center;background:#ffffff0a;border:1px solid rgba(255,255,255,.07);transition:all .15s ease;cursor:default}.cat-chip:hover{background:#ffffff12;border-color:#ffffff21;transform:translateY(-2px)}.cat-chip-name{font-size:.875rem;font-weight:600;color:#ffffffc7;line-height:1.3}.lp-bottom{padding:64px 0 56px;position:relative;z-index:1;border-top:1px solid rgba(255,255,255,.055)}.lp-bottom-inner{max-width:1400px;margin:0 auto;padding:0 2.5rem}.data-sources-card{background:#ffffff08;border:1px solid rgba(255,255,255,.07);border-radius:16px;padding:32px 30px}.ds-title{font-size:1.25rem;font-weight:800;color:#fff;letter-spacing:-.02em;margin:8px 0 24px}.ds-list{display:flex;flex-direction:column;gap:0}.ds-item{display:flex;gap:16px;padding:18px 0;border-bottom:1px solid rgba(255,255,255,.055)}.ds-item:last-child{border-bottom:none;padding-bottom:0}.ds-item:first-child{padding-top:0}.ds-num{font-size:.68rem;font-weight:800;color:#4a9fd4;letter-spacing:.06em;flex-shrink:0;width:22px;padding-top:2px;font-variant-numeric:tabular-nums}.ds-name{font-size:.9rem;font-weight:700;color:#ffffffe0;margin-bottom:5px}.ds-detail{font-size:.81rem;color:#fff6;line-height:1.6}.roles-stack--full{width:100%}.role-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:8px}.role-card{border-radius:12px;padding:20px 22px;border:1px solid rgba(255,255,255,.06);transition:all .15s ease}.role-card:hover{border-color:#ffffff21;transform:translate(3px)}.role-card--admin{background:#dc262612}.role-card--lead{background:#0369a114}.role-card--op{background:#15803d12}.role-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.role-badge{font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:2px 9px;border-radius:20px}.role-card--admin .role-badge{background:#dc262633;color:#fca5a5}.role-card--lead .role-badge{background:#0369a133;color:#7dd3fc}.role-card--op .role-badge{background:#15803d33;color:#86efac}.role-card-name{font-size:.9rem;font-weight:700;color:#fffc;margin-bottom:12px}.role-perms{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:4px 12px}.role-perms li{font-size:.77rem;color:#ffffff6b;padding:3px 0 3px 14px;position:relative;line-height:1.4}.role-perms li:before{content:"·";position:absolute;left:4px;color:#ffffff40}.landing-footer{padding:16px 2.5rem;color:#fff3;font-size:.73rem;font-weight:500;border-top:1px solid rgba(255,255,255,.055);display:flex;justify-content:center;align-items:center;gap:10px;flex-shrink:0;position:relative;z-index:1}.lf-sep{opacity:.4}.lf-signin{background:none;border:none;color:#4a9fd4;font-size:.73rem;font-weight:700;cursor:pointer;font-family:var(--font);transition:color .15s;padding:0}.lf-signin:hover{color:#7dd3fc}@media(max-width:1200px){.lp-hero{grid-template-columns:1fr 360px}.lp-headline{font-size:2.5rem}.cat-grid{grid-template-columns:repeat(3,1fr)}.risk-levels{grid-template-columns:repeat(5,1fr)}}@media(max-width:960px){.lp-hero{grid-template-columns:1fr;padding:44px 2rem 36px}.lp-hero-left{padding-right:0}.lp-hero-right{position:static}.lp-headline{font-size:2.1rem}.lp-hero-pills{flex-wrap:wrap;width:100%}.role-cards{grid-template-columns:1fr}.risk-levels{grid-template-columns:repeat(3,1fr)}.cat-grid{grid-template-columns:repeat(2,1fr)}.lp-section-header--row{flex-direction:column;align-items:flex-start;gap:10px}.lp-section-sub{text-align:left;max-width:100%}}@media(max-width:640px){.landing-nav{padding:0 1.25rem}.landing-nav-title{display:none}.lp-hero,.lp-risk-band-inner,.lp-features-inner,.lp-categories-inner,.lp-bottom-inner{padding-left:1.25rem;padding-right:1.25rem}.lp-headline{font-size:1.75rem}.bento-grid{grid-template-columns:1fr}.bento-p11,.bento-p21,.bento-p31,.bento-p22,.bento-p32,.bento-p13{grid-column:auto;grid-row:auto}.cat-grid,.risk-levels{grid-template-columns:1fr 1fr}.role-perms{grid-template-columns:1fr}.landing-footer{flex-direction:column;gap:6px}}@media(max-width:420px){.cat-grid{grid-template-columns:1fr}.lp-hero-pills{border-radius:10px}.lp-pill{padding:12px 16px}}.app{width:100%;min-height:100vh;overflow-x:hidden;background:var(--bg)}.main-content-area{padding:0}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:1000px}}@keyframes progressPulse{0%{transform:translate(-100%)}to{transform:translate(300%)}}@keyframes tooltipFadeIn{0%{opacity:0;transform:translate(-50%) translateY(6px) scale(.97)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:var(--bg);gap:20px}.spinner{width:44px;height:44px;border:3px solid var(--primary-xlight);border-top-color:var(--primary-mid);border-radius:50%;animation:spin .75s linear infinite}.loading-screen p{font-size:.9rem;color:var(--text-muted);font-weight:500}.main-nav{display:flex;align-items:center;justify-content:space-between;background:var(--primary);border-bottom:1px solid rgba(255,255,255,.08);padding:0 2rem;height:68px;position:sticky;top:0;z-index:100;box-shadow:0 2px 16px #0c4a6e4d}.nav-brand{display:flex;align-items:center;gap:.65rem;font-size:.925rem;font-weight:700;color:#fff;letter-spacing:-.2px;white-space:nowrap}.nav-bits-logo{height:54px;width:auto;object-fit:contain;flex-shrink:0;border-right:1px solid rgba(255,255,255,.18);padding-right:1rem;margin-right:.2rem}.nav-links{display:flex;align-items:center;gap:0;height:100%}.nav-link{position:relative;color:#ffffffad;text-decoration:none;padding:0 1rem;height:68px;display:flex;align-items:center;font-size:.865rem;font-weight:600;transition:color var(--transition);white-space:nowrap;letter-spacing:.01em}.nav-link:after{content:"";position:absolute;bottom:0;left:.75rem;right:.75rem;height:2px;background:var(--primary-light);border-radius:2px 2px 0 0;opacity:0;transform:scaleX(.4);transition:opacity var(--transition),transform var(--transition)}.nav-link:hover{color:#ffffffeb}.nav-link:hover:after{opacity:.5;transform:scaleX(1)}.nav-link.active{color:#fff}.nav-link.active:after{opacity:1;transform:scaleX(1);background:#fff}.nav-role{display:flex;align-items:center;gap:.65rem}.nav-avatar{width:30px;height:30px;border-radius:50%;background:#ffffff2e;color:#fff;font-size:.68rem;font-weight:700;display:flex;align-items:center;justify-content:center;text-transform:uppercase;letter-spacing:.5px;flex-shrink:0;border:1.5px solid rgba(255,255,255,.25)}.nav-user{font-size:.8rem;color:#ffffffbf;font-weight:500}.nav-role-badge{background:#ffffff26;color:#ffffffe6;padding:2px 9px;border-radius:20px;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.6px;border:1px solid rgba(255,255,255,.2)}.nav-logout{background:none;border:1px solid rgba(255,255,255,.18);color:#ffffffa6;padding:5px 13px;border-radius:var(--radius-sm);font-size:.78rem;font-weight:600;transition:all var(--transition)}.nav-logout:hover{background:#dc262626;border-color:#dc262680;color:#fca5a5}.role-selector{background:#ffffff1f;color:#fff;border:1px solid rgba(255,255,255,.2);padding:5px 10px;border-radius:var(--radius-sm);font-size:.78rem;font-family:var(--font);cursor:pointer}.header{background:var(--surface);border-bottom:1px solid var(--border);padding:36px 48px 28px;position:relative}.header:before{display:none}.header:after{display:none}.header-content{position:relative;z-index:1;display:flex;justify-content:space-between;align-items:flex-start;max-width:1600px;margin:0 auto;padding:0 8px}.header-left h1{color:var(--text);font-size:1.85rem;font-weight:800;margin-bottom:6px;letter-spacing:-.03em}.header-left p{color:var(--text-muted);font-size:.9rem;font-weight:400;margin-bottom:0}.header-actions{display:flex;gap:10px;align-items:center;padding-top:6px}.date-selector{background:var(--surface-2);border:1px solid var(--border);padding:9px 14px;border-radius:var(--radius-sm);color:var(--text-2);font-size:.85rem;font-weight:600;font-family:var(--font);cursor:pointer;transition:background var(--transition)}.date-selector:hover{background:var(--surface-3)}.date-selector option{background:var(--surface);color:var(--text)}.export-btn{background:var(--primary);color:#fff;border:none;padding:9px 18px;border-radius:var(--radius-sm);font-size:.85rem;font-weight:700;cursor:pointer;transition:all var(--transition);box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:7px}.export-btn:hover:not(:disabled){background:var(--primary-mid);box-shadow:0 4px 14px #0c4a6e40;transform:translateY(-1px)}.export-btn:disabled{opacity:.65;cursor:not-allowed;transform:none}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;padding:28px 48px;max-width:1600px;margin:0 auto;animation:fadeIn .4s ease both}.stat-card{background:var(--surface);padding:22px 24px;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border);transition:all var(--transition);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary-mid),var(--primary-light));opacity:0;transition:opacity var(--transition)}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px);border-color:#b8d0e8}.stat-card:hover:before{opacity:1}.stat-card-inner{display:flex;align-items:flex-start;justify-content:space-between}.stat-content{flex:1}.stat-content h3{color:var(--text-muted);font-size:.73rem;text-transform:uppercase;letter-spacing:.8px;margin-bottom:10px;font-weight:700}.stat-content .value{color:var(--primary);font-size:2.1rem;font-weight:800;margin-bottom:8px;letter-spacing:-.03em;line-height:1}.stat-content .trend{font-size:.82rem;color:var(--success);font-weight:600;display:flex;align-items:center;gap:4px}.stat-content .trend.up{color:var(--success)}.stat-content .trend.down{color:var(--danger)}.charts-section{display:grid;grid-template-columns:1fr 1.6fr;gap:20px;padding:0 48px 28px;max-width:1600px;margin:0 auto;animation:fadeIn .5s ease .08s both;overflow:hidden}.chart-card{background:var(--surface);padding:26px 28px;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border);transition:box-shadow var(--transition);overflow:hidden;min-width:0}.chart-card:hover{box-shadow:var(--shadow-md)}.chart-card h3{color:var(--text);margin-bottom:18px;font-size:.975rem;font-weight:700;letter-spacing:-.01em;display:flex;align-items:center;gap:8px}.donut-layout{display:flex;flex-direction:column;align-items:center;gap:18px;margin-top:6px}.donut-wrap{position:relative;width:220px;height:220px}.donut-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}.donut-center-num{font-size:1.5rem;font-weight:800;color:var(--primary);line-height:1}.donut-center-label{font-size:.7rem;color:var(--text-faint);margin-top:4px;text-transform:uppercase;letter-spacing:.06em;font-weight:600}.donut-legend{width:100%;display:flex;flex-direction:column;gap:7px}.donut-legend-item{display:flex;align-items:center;gap:8px;font-size:.83rem;padding:5px 8px;border-radius:6px;transition:background var(--transition)}.donut-legend-item:hover{background:var(--surface-3)}.donut-legend-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.donut-legend-name{flex:1;color:var(--text-2);font-weight:600}.donut-legend-count{color:var(--text);font-weight:700;font-size:.85rem;font-variant-numeric:tabular-nums}.donut-legend-pct{color:var(--text-faint);font-size:.76rem;min-width:38px;text-align:right;font-variant-numeric:tabular-nums}.chart-insight{margin-top:18px;padding:13px 16px;background:var(--primary-xlight);border-radius:var(--radius-sm);border-left:3px solid var(--primary-mid)}.chart-insight p{font-size:.875rem;color:var(--primary);line-height:1.55;margin:0;font-weight:500}.intelligence-section{max-width:1600px;margin:0 auto 32px;padding:0 48px}.intelligence-section h2,.risk-details-section h2,.heatmap-section h2,.markers-section h2,.patterns-section h2{font-size:1.2rem;font-weight:800;color:var(--text);margin-bottom:18px;letter-spacing:-.025em;display:flex;align-items:center;gap:10px}.intelligence-section h2:before,.risk-details-section h2:before,.heatmap-section h2:before,.markers-section h2:before,.patterns-section h2:before{content:"";display:inline-block;width:4px;height:1.1em;background:linear-gradient(180deg,var(--primary-mid),var(--primary-light));border-radius:2px;flex-shrink:0}.intelligence-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(380px,1fr));gap:20px}.intel-card{background:var(--surface);padding:28px 30px;border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:all var(--transition)}.intel-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.intel-card.priority{border-top:3px solid var(--danger);background:linear-gradient(160deg,#fff 0%,var(--critical-bg) 100%)}.intel-card.preventive{border-top:3px solid var(--warning);background:linear-gradient(160deg,#fff 0%,var(--moderate-bg) 100%)}.intel-card h3{font-size:.95rem;font-weight:700;color:var(--text);margin-bottom:14px;text-transform:uppercase;letter-spacing:.04em}.intel-number{font-size:3.2rem;font-weight:800;color:var(--primary);margin:12px 0;line-height:1;letter-spacing:-.04em;font-variant-numeric:tabular-nums}.intel-card.priority .intel-number{color:var(--danger)}.intel-card.preventive .intel-number{color:var(--warning)}.intel-card p{color:var(--text-muted);margin-bottom:18px;font-size:.9rem}.concerns-list{margin-top:18px;padding-top:16px;border-top:1px solid var(--border)}.concerns-list strong{display:block;margin-bottom:10px;color:var(--text);font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.concern-item{padding:7px 0;color:var(--text-2);font-size:.875rem;font-weight:500;border-bottom:1px solid var(--border)}.concern-item:last-child{border-bottom:none}.risk-details-section{max-width:1600px;margin:0 auto 32px;padding:0 48px}.rct-table-wrap{background:var(--surface);border-radius:var(--radius-xl);border:1px solid var(--border);box-shadow:var(--shadow-sm);overflow:hidden}.rct-table{width:100%;border-collapse:collapse;table-layout:fixed}.rct-metric-col{width:16%}.rct-risk-col{text-align:center;padding:18px 20px 16px;border-bottom:1px solid var(--border)}.rct-risk-label{display:inline-block;font-size:.82rem;font-weight:700;letter-spacing:.02em;padding:5px 13px;border-radius:20px;border:1.5px solid currentColor}.rct-metric-name{padding:15px 18px;font-size:.72rem;font-weight:700;color:var(--text-faint);text-transform:uppercase;letter-spacing:.07em;border-right:1px solid var(--border);white-space:nowrap;background:var(--surface-3)}.rct-row:not(:last-child) .rct-cell,.rct-row:not(:last-child) .rct-metric-name{border-bottom:1px solid var(--border)}.rct-row:hover .rct-cell{filter:brightness(.97)}.rct-cell{padding:15px 20px;text-align:center;vertical-align:middle;transition:filter var(--transition)}.rct-cell-value{font-size:1.3rem;font-weight:800;line-height:1;letter-spacing:-.02em;font-variant-numeric:tabular-nums}.heatmap-section{background:var(--surface);border-radius:var(--radius-lg);padding:24px 28px;max-width:1600px;margin:0 auto 32px;box-shadow:var(--shadow-sm);border:1px solid var(--border)}.heatmap-section h2{margin-bottom:6px}.section-subtitle{color:var(--text-muted);font-size:.875rem;margin-bottom:20px;font-weight:400;padding-left:14px}.heatmap-container{overflow-x:auto;margin-top:4px}.heatmap-table{width:100%;border-collapse:separate;border-spacing:5px}.heatmap-label-col{width:200px;min-width:160px;font-size:.74rem;color:var(--text-muted);font-weight:600;text-align:left;padding:4px 6px;text-transform:uppercase;letter-spacing:.05em}.heatmap-risk-header{text-align:center;padding:10px 8px;font-size:.82rem;font-weight:700;color:var(--text);min-width:140px;border-bottom:2px solid var(--border-2)}.heatmap-header-count{font-size:.68rem;font-weight:400;color:var(--text-faint);margin-top:3px;font-variant-numeric:tabular-nums}.heatmap-category-label{font-size:.8rem;color:var(--text-2);font-weight:600;padding:6px 8px;white-space:nowrap}.heatmap-cell{text-align:center;padding:14px 10px;border-radius:8px;cursor:pointer;transition:transform .12s,box-shadow .12s;position:relative;min-height:60px}.heatmap-cell:hover{transform:scale(1.05);box-shadow:0 4px 16px #0369a140;z-index:2}.heatmap-cell-count{font-size:.95rem;font-weight:800;line-height:1.2;font-variant-numeric:tabular-nums}.heatmap-cell-pct{font-size:.68rem;opacity:.8;margin-top:2px;font-variant-numeric:tabular-nums}.heatmap-cell-empty{color:#c8d5e3;font-size:.8rem}.markers-section{max-width:1600px;margin:0 auto 32px;padding:0 48px}.markers-table-wrap{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);overflow:hidden}.markers-table-header,.mt-row{display:grid;grid-template-columns:36px 1fr 72px 72px 220px 90px;align-items:center;gap:16px;padding:10px 24px}.markers-table-header{background:var(--surface-3);border-bottom:2px solid var(--border);font-size:.68rem;font-weight:700;color:var(--text-faint);text-transform:uppercase;letter-spacing:.07em}.mt-row{border-bottom:1px solid var(--border);transition:background var(--transition)}.mt-row:last-child{border-bottom:none}.mt-row:hover{background:var(--surface-3)}.mt-rank{font-size:.78rem;font-weight:700;color:var(--text-faint);text-align:center}.mt-category{font-size:.86rem;font-weight:600;color:var(--text)}.mt-stats{font-size:.88rem;font-weight:700;text-align:right;font-variant-numeric:tabular-nums}.mt-stat-high{color:var(--danger)}.mt-stat-other{color:var(--text-faint)}.mt-bar-col{display:flex;flex-direction:column;gap:4px;justify-content:center}.mt-stacked-track{position:relative;height:8px;background:var(--surface-3);border-radius:99px;overflow:hidden;display:flex;align-items:center}.mt-stacked-high{position:absolute;left:0;height:100%;background:var(--danger);border-radius:99px;transition:width .5s cubic-bezier(.4,0,.2,1);z-index:2}.mt-stacked-other{position:absolute;left:0;height:4px;background:var(--border-2);border-radius:99px;transition:width .5s cubic-bezier(.4,0,.2,1);z-index:1}.mt-delta{text-align:center}.mt-delta-badge{display:inline-block;background:var(--low-bg);color:var(--low);border:1px solid var(--low-border);border-radius:20px;padding:3px 10px;font-size:.77rem;font-weight:700;font-variant-numeric:tabular-nums}.mt-legend{padding:10px 24px;font-size:.76rem;color:var(--text-faint);font-weight:600;border-top:1px solid var(--border);display:flex;align-items:center;gap:4px}.mt-legend-dot{display:inline-block;width:8px;height:8px;border-radius:50%}.mt-dot-high{background:var(--danger)}.mt-dot-other{background:var(--border-2)}.patterns-section{max-width:1600px;margin:0 auto 40px;padding:0 48px}.patterns-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:14px}.pattern-card{background:var(--surface);padding:18px 20px;border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-xs);display:flex;gap:14px;align-items:center;transition:all var(--transition)}.pattern-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:#b8d0e8}.pattern-number{background:linear-gradient(135deg,var(--primary-mid) 0%,var(--primary-light) 100%);color:#fff;width:34px;height:34px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1rem;flex-shrink:0;box-shadow:0 2px 6px #0369a14d}.pattern-content{flex:1}.pattern-categories{display:flex;align-items:center;gap:7px;margin-bottom:7px;flex-wrap:wrap}.category-pill{background:var(--primary-xlight);color:var(--primary);padding:5px 11px;border-radius:var(--radius-sm);font-size:.8rem;font-weight:600;border:1px solid rgba(14,165,233,.25)}.plus{color:var(--text-faint);font-weight:700;font-size:1rem}.pattern-stats{color:var(--text-muted);font-size:.85rem}.pattern-stats strong{color:var(--text);font-weight:700}.filters-section{background:var(--surface);padding:18px 48px;border-top:1px solid var(--border);border-bottom:1px solid var(--border);max-width:1600px;margin:0 auto}.filters-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none}.filters-header h2{color:var(--text);margin:0;font-size:.95rem;font-weight:700;display:flex;align-items:center;gap:8px}.filters-toggle{color:var(--text-muted);font-size:1.1rem;transition:transform .28s}.filters-toggle.open{transform:rotate(180deg)}.filters-content{max-height:0;overflow:hidden;transition:max-height .3s ease,overflow 0s .3s}.filters-content.open{max-height:600px;overflow:visible;margin-top:18px;transition:max-height .3s ease,overflow 0s 0s}.filter-group{display:grid;grid-template-columns:2fr 1.5fr 1fr 1fr 1.5fr auto auto;gap:10px;align-items:center}.filter-group input:not(.searchable-select-input),.filter-group select{padding:9px 13px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:.875rem;font-family:var(--font);background:var(--surface);color:var(--text);transition:border-color var(--transition),box-shadow var(--transition)}.filter-group select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='none' stroke='%230f172a' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round' d='M2 4l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:34px}.filter-group input:not(.searchable-select-input):focus,.filter-group select:focus{outline:none;border-color:var(--primary-mid);box-shadow:0 0 0 3px #0369a11a}.filter-group input::placeholder{color:var(--text-faint)}.searchable-select{position:relative}.searchable-select-input-wrap{display:flex;align-items:center;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);overflow:hidden;transition:border-color var(--transition),box-shadow var(--transition)}.searchable-select-input-wrap:focus-within{border-color:var(--primary-mid);box-shadow:0 0 0 3px #0369a11a}.searchable-select-input{flex:1;border:none!important;outline:none!important;box-shadow:none!important;padding:9px 8px 9px 13px;font-size:.875rem;color:var(--text);background:transparent;min-width:0;font-family:var(--font)}.searchable-select-input::placeholder{color:var(--text);opacity:1}.searchable-select-clear{background:none;border:none;color:var(--text-faint);cursor:pointer;font-size:1rem;padding:0 4px;line-height:1}.searchable-select-clear:hover{color:var(--text-muted)}.searchable-select-arrow{padding:0 12px 0 4px;cursor:pointer;-webkit-user-select:none;user-select:none;display:flex;align-items:center}.searchable-select-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);z-index:100;max-height:240px;overflow-y:auto}.searchable-select-option{padding:9px 13px;font-size:.875rem;color:var(--text);cursor:pointer;transition:background var(--transition);font-family:var(--font)}.searchable-select-option:hover{background:var(--surface-3)}.searchable-select-option.selected{background:var(--primary-xlight);color:var(--primary);font-weight:600}.searchable-select-placeholder{color:var(--text-faint);font-style:italic}.searchable-select-empty{padding:9px 13px;color:var(--text-faint);font-size:.83rem}.active-filter-bar{display:flex;align-items:center;gap:8px;margin-top:10px;flex-wrap:wrap}.active-filter-label{font-size:.78rem;color:var(--text-muted);font-weight:600}.active-filter-tag{display:inline-flex;align-items:center;gap:5px;background:var(--primary-xlight);color:var(--primary);border:1px solid rgba(14,165,233,.3);border-radius:20px;padding:3px 10px 3px 11px;font-size:.78rem;font-weight:600}.active-filter-remove{background:none;border:none;color:var(--primary-mid);cursor:pointer;font-size:1rem;line-height:1;padding:0;opacity:.7}.active-filter-remove:hover{opacity:1}.btn-primary,.btn-secondary{padding:9px 20px;border-radius:var(--radius-sm);font-size:.875rem;font-weight:700;font-family:var(--font);cursor:pointer;transition:all var(--transition)}.btn-primary{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-mid) 100%);color:#fff;border:none;box-shadow:0 2px 6px #0c4a6e40}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0c4a6e4d}.btn-secondary{background:transparent;color:var(--text-muted);border:1.5px solid var(--border)}.btn-secondary:hover{background:var(--surface-3);border-color:var(--border-2)}.table-section{background:var(--surface);padding:28px 48px;max-width:1600px;margin:0 auto;animation:fadeIn .5s ease .15s both}.table-section h2{color:var(--text);margin-bottom:20px;font-size:1.1rem;font-weight:700;letter-spacing:-.015em}.table-wrapper{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-xs)}table{width:100%;border-collapse:collapse;margin-bottom:0}thead{background:var(--surface-3);position:sticky;top:0;z-index:10}th{padding:13px 16px;text-align:left;color:var(--text-muted);font-weight:700;text-transform:uppercase;font-size:.7rem;letter-spacing:.7px;border-bottom:1px solid var(--border-2)}td{padding:14px 16px;color:var(--text-2);font-size:.875rem;border-bottom:1px solid var(--border)}tbody tr{transition:background var(--transition);cursor:pointer;background:var(--surface)}tbody tr:hover{background:var(--primary-xlight)}tbody tr:nth-child(2n){background:var(--surface-2)}tbody tr:nth-child(2n):hover{background:var(--primary-xlight)}.risk-badge{padding:4px 11px;border-radius:20px;font-size:.75rem;font-weight:700;text-transform:capitalize;display:inline-block;letter-spacing:.2px}.risk-critical{background:var(--critical-bg);color:#991b1b;border:1px solid var(--critical-border)}.risk-high{background:var(--high-bg);color:#9a3412;border:1px solid var(--high-border)}.risk-moderate{background:var(--moderate-bg);color:var(--moderate);border:1px solid var(--moderate-border)}.risk-low-moderate{background:var(--low-mod-bg);color:#1e40af;border:1px solid var(--low-mod-border)}.risk-low{background:var(--low-bg);color:#166534;border:1px solid var(--low-border)}.confidence-bar{width:90px;height:5px;background:var(--border);border-radius:4px;overflow:hidden;margin-bottom:4px}.confidence-fill{height:100%;background:linear-gradient(90deg,var(--primary-mid),var(--primary-light));transition:width .4s ease;border-radius:4px}.summary-cell{max-width:420px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-muted);font-size:.87rem}.pagination{display:flex;justify-content:center;gap:10px;align-items:center;margin-top:24px;padding-bottom:16px}.pagination span{color:var(--text-muted);font-size:.875rem;font-weight:600}.pagination button{padding:8px 16px;border:1.5px solid var(--border);background:var(--surface);color:var(--primary-mid);border-radius:var(--radius-sm);cursor:pointer;font-weight:700;transition:all var(--transition);font-size:.875rem;font-family:var(--font)}.pagination button:hover:not(:disabled){background:var(--primary);color:#fff;border-color:var(--primary);transform:translateY(-1px)}.pagination button:disabled{opacity:.4;cursor:not-allowed;color:var(--text-faint)}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#0c4a6e59;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:flex-end;z-index:1000;animation:fadeIn .18s ease}.modal-content{background:var(--surface);border-radius:0;width:600px;height:100%;overflow-y:auto;box-shadow:-6px 0 28px #0c4a6e26;animation:slideInRight .28s ease}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:26px 30px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--surface);z-index:1}.modal-header h2{color:var(--text);margin:0;font-size:1.2rem;font-weight:700}.close{width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);font-size:22px;font-weight:400;color:var(--text-muted);cursor:pointer;transition:all var(--transition);background:transparent}.close:hover{background:var(--surface-3);color:var(--text)}.modal-body{padding:28px 30px}.detail-section{margin-bottom:28px}.detail-section h3{color:var(--primary-mid);margin-bottom:12px;font-size:1rem;font-weight:700;display:flex;align-items:center;gap:7px}.detail-section p,.detail-section ul{color:var(--text-muted);line-height:1.7;font-size:.9rem}.detail-section ul{list-style:none;padding-left:0}.detail-section ul li{padding:7px 0;border-bottom:1px solid var(--border)}.detail-section ul li:last-child{border-bottom:none}.email-box{background:var(--surface-2);padding:14px 16px;border-radius:var(--radius);margin-bottom:10px;border-left:3px solid var(--primary-mid);transition:background var(--transition)}.email-box:hover{background:var(--surface-3)}.email-box strong{color:var(--text);font-size:.875rem;font-weight:700;display:block;margin-bottom:6px}.email-box p{color:var(--text-2);font-size:.875rem;line-height:1.6;margin:0}.email-header-info{margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--border)}.email-subject{font-size:.95rem;color:var(--text);margin-bottom:3px;font-weight:600}.email-meta{font-size:.78rem;color:var(--text-muted)}.email-body-text{white-space:pre-line}.text-muted{color:var(--text-faint);text-align:center;font-size:.875rem;margin-top:10px}.tags-container{display:flex;flex-wrap:wrap;gap:7px;margin-top:10px}.category-tag{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-mid) 100%);color:#fff;padding:6px 13px;border-radius:var(--radius-sm);font-size:.82rem;font-weight:600;transition:all var(--transition);box-shadow:0 2px 5px #0c4a6e33}.category-tag:hover{transform:translateY(-2px);box-shadow:0 4px 10px #0c4a6e47}.indicators-list{display:flex;flex-direction:column;gap:10px;margin-top:12px}.indicator-dropdown{border-radius:var(--radius-sm);overflow:hidden}.indicator-item{display:flex;gap:10px;align-items:flex-start;background:var(--moderate-bg);padding:12px 14px;border-radius:var(--radius-sm);border-left:3px solid var(--warning);transition:background var(--transition)}.indicator-item.clickable{cursor:pointer;-webkit-user-select:none;user-select:none}.indicator-item.clickable .dropdown-arrow{margin-left:auto;font-size:.72rem;color:var(--moderate);flex-shrink:0;padding-top:4px}.indicator-item:hover{background:#fef3c7}.indicator-evidence{padding:7px 14px 10px 38px;background:#fefce8;border-left:3px solid var(--warning);display:flex;flex-direction:column;gap:6px}.indicator-evidence .nested-quote{background:var(--surface);border-left:3px solid var(--primary-mid);padding:9px 12px 9px 36px;border-radius:var(--radius-sm);font-size:.86rem}.indicator-number{background:var(--warning);color:#fff;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.82rem;flex-shrink:0}.indicator-item p{margin:0;color:#78350f;line-height:1.6;font-size:.875rem}.quotes-list{display:flex;flex-direction:column;gap:10px;margin-top:12px}.quote-item{background:var(--surface-2);padding:12px 16px 12px 44px;border-radius:var(--radius-sm);border-left:3px solid var(--primary-mid);position:relative;transition:background var(--transition)}.quote-item:hover{background:var(--surface-3)}.quote-icon{position:absolute;top:10px;left:12px;font-size:1.6rem;color:var(--primary-mid);opacity:.22;font-style:normal}.quote-item p{margin:0;color:var(--text-2);line-height:1.6;font-style:italic;font-size:.875rem}.student-detail-page{min-height:100vh;background:var(--bg)}.student-detail-header{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-mid) 100%);padding:28px 40px;color:#fff}.back-btn{background:#ffffff26;border:1px solid rgba(255,255,255,.25);color:#fff;padding:8px 18px;border-radius:var(--radius-sm);font-size:.875rem;font-weight:700;cursor:pointer;transition:all var(--transition);margin-bottom:18px;display:inline-flex;align-items:center;gap:7px;font-family:var(--font)}.back-btn:hover{background:#ffffff40;transform:translate(-2px)}.student-detail-header h1{margin:0;font-size:1.85rem;font-weight:800;letter-spacing:-.025em;color:#fff}.student-detail-content{max-width:1200px;margin:0 auto;padding:36px 40px}.student-detail-content .detail-section{background:var(--surface);padding:24px 26px;margin-bottom:20px;border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-xs)}.student-detail-content .detail-section h3{color:var(--text);margin-bottom:16px;font-size:1.05rem;font-weight:700;display:flex;align-items:center;gap:8px;padding-bottom:10px;border-bottom:2px solid var(--border)}.student-detail-content .detail-section p{color:var(--text-2);line-height:1.75;font-size:.9rem;margin-bottom:10px}.student-detail-content .detail-section p:last-child{margin-bottom:0}.student-detail-content .detail-section strong{color:var(--text);font-weight:700;margin-right:6px}.attendance-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;margin-bottom:18px;padding:14px;background:var(--primary-xlight);border-radius:var(--radius);border:1px solid rgba(14,165,233,.2)}.attendance-metric{text-align:center;padding:10px 12px;background:var(--surface);border-radius:var(--radius-sm);box-shadow:var(--shadow-xs);transition:all var(--transition)}.attendance-metric:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.metric-value{font-size:1.45rem;font-weight:800;color:var(--primary);margin-bottom:3px;font-variant-numeric:tabular-nums}.metric-label{font-size:.8rem;color:var(--text-muted);font-weight:600}.attendance-dropdown{margin-top:14px;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.dropdown-toggle{width:100%;padding:11px 14px;background:var(--surface-3);border:none;text-align:left;font-weight:600;color:var(--text);cursor:pointer;font-size:.9rem;transition:all var(--transition);display:flex;align-items:center;gap:8px;font-family:var(--font)}.dropdown-toggle:hover{background:var(--primary-xlight);color:var(--primary)}.attendance-records{padding:14px;background:var(--surface);border-top:1px solid var(--border);animation:slideDown .3s ease}.attendance-table{width:100%;border-collapse:collapse;font-size:.875rem}.attendance-table thead{background:var(--surface-3);border-bottom:2px solid var(--border)}.attendance-table th{padding:9px;text-align:left;font-weight:700;color:var(--text-muted);font-size:.72rem;text-transform:uppercase;letter-spacing:.5px}.attendance-table td{padding:9px;border-bottom:1px solid var(--border);color:var(--text-2)}.attendance-table tbody tr:hover{background:var(--surface-3)}.ratio-badge{display:inline-block;padding:3px 9px;border-radius:var(--radius-sm);font-weight:700;font-size:.8rem}.ratio-badge.high{background:var(--low-bg);color:#166534}.ratio-badge.low{background:var(--critical-bg);color:#991b1b}.scores-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:14px;margin-bottom:20px}.score-metric{background:var(--primary-xlight);padding:18px;border-radius:var(--radius);border:1px solid rgba(14,165,233,.2);text-align:center}.score-metric .metric-value{font-size:1.9rem;color:var(--primary);margin-bottom:6px}.score-metric .metric-label{font-size:.78rem;color:var(--text-muted);font-weight:700;text-transform:uppercase;letter-spacing:.5px}.scores-table-container{margin-top:18px;overflow-x:auto;border-radius:var(--radius-sm);border:1px solid var(--border)}.scores-table{width:100%;border-collapse:collapse;font-size:.875rem}.scores-table thead{background:var(--surface-3);border-bottom:2px solid var(--border)}.scores-table th{padding:11px;text-align:left;font-weight:700;color:var(--text-muted);font-size:.72rem;text-transform:uppercase;letter-spacing:.5px}.scores-table td{padding:11px;border-bottom:1px solid var(--border);color:var(--text-2)}.scores-table tbody tr:hover{background:var(--surface-3)}.grade-badge{display:inline-block;padding:3px 10px;border-radius:var(--radius-sm);font-weight:700;font-size:.8rem;text-transform:uppercase}.grade-badge.grade-A{background:var(--low-bg);color:#166534}.grade-badge.grade-B{background:var(--low-mod-bg);color:#1e40af}.grade-badge.grade-C{background:var(--moderate-bg);color:var(--moderate)}.grade-badge.grade-D,.grade-badge.grade-E,.grade-badge.grade-F{background:var(--critical-bg);color:#991b1b}.grade-badge.grade-S,.grade-badge.grade-A\+{background:#f3e8ff;color:#6b21a8}.drift-analysis-section{border-left:4px solid var(--warning)}.section-header{display:flex;justify-content:space-between;align-items:center;width:100%}.drift-content{margin-top:1.25rem}.drift-risk-card{margin-bottom:1.25rem;padding:1.25rem;border-radius:var(--radius-sm);background:var(--surface-3)}.drift-risk-badge{display:inline-block;padding:.65rem 1.25rem;border-radius:var(--radius-sm);font-weight:700;font-size:.9rem}.drift-risk-badge.high-risk{background:var(--critical-bg);color:#991b1b;border:2px solid var(--danger)}.drift-risk-badge.low-risk{background:var(--low-bg);color:#166534;border:2px solid var(--low)}.drift-metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:1rem;margin:1.25rem 0}.drift-metric-card{padding:1.1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);text-align:center;box-shadow:var(--shadow-xs)}.drift-metric-card .metric-header{font-size:.82rem;color:var(--text-muted);margin-bottom:.4rem;font-weight:600}.drift-metric-card .metric-value{font-size:1.45rem;font-weight:800;color:var(--text);margin-bottom:.4rem;font-variant-numeric:tabular-nums}.drift-metric-card .metric-value.trend-down{color:var(--danger)}.drift-metric-card .metric-value.trend-up{color:var(--success)}.drift-metric-card .metric-value.negative{color:var(--danger)}.drift-metric-card .metric-value.positive{color:var(--success)}.drift-metric-card .metric-category{font-size:.8rem;color:var(--text-muted);text-transform:capitalize;padding:.2rem .65rem;background:var(--surface-3);border-radius:4px;display:inline-block}.drift-metric-card .metric-label{font-size:.8rem;color:var(--text-muted)}.drift-signals{display:flex;flex-direction:column;gap:.65rem;margin:1.25rem 0;padding:.9rem;background:var(--surface-3);border-radius:var(--radius-sm)}.signal{display:flex;align-items:center;gap:.65rem;padding:.65rem;border-radius:var(--radius-sm);font-weight:600}.signal.alert{background:var(--critical-bg);color:#991b1b;border-left:4px solid var(--danger)}.signal.ok{background:var(--low-bg);color:#166534;border-left:4px solid var(--low)}.signal-icon{font-size:1.1rem;width:22px;text-align:center}.signal-text{flex:1;font-size:.875rem}.analysis-period{margin:1.25rem 0;padding:.9rem;background:var(--primary-xlight);border-left:4px solid var(--primary-light);border-radius:4px}.analysis-period p{margin:.4rem 0;font-size:.9rem;color:var(--primary)}.alignment-section{margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid var(--border)}.alignment-section h4{margin-bottom:.9rem;color:var(--text)}.alignment-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.9rem}.alignment-card{padding:.9rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);text-align:center}.alignment-label{font-size:.8rem;color:var(--text-muted);margin-bottom:.4rem;font-weight:600}.alignment-value{font-size:1rem;font-weight:700;padding:.4rem;border-radius:4px}.alignment-value.aligned{background:var(--low-bg);color:#166534}.alignment-value.misaligned{background:var(--moderate-bg);color:var(--moderate)}.llm-assessment-section{border-left:4px solid #8b5cf6;background:linear-gradient(135deg,#faf5ff,#f3e8ff)}.llm-content{padding:1.25rem;background:var(--surface);border-radius:var(--radius-sm);margin-top:.9rem}.llm-assessment-text{font-size:.9rem;line-height:1.65;color:var(--text-2);margin-bottom:.9rem;font-style:italic}.assessment-timestamp{font-size:.76rem;color:var(--text-faint);text-align:right}.btn-generate-reply{margin-top:10px;padding:7px 16px;background:var(--primary-mid);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.82rem;font-weight:700;cursor:pointer;transition:all var(--transition)}.btn-generate-reply:hover:not(:disabled){background:var(--primary);transform:translateY(-1px)}.btn-generate-reply:disabled{background:var(--text-faint);cursor:wait}.reply-box{margin-top:12px;padding:14px 16px;background:var(--low-bg);border-radius:var(--radius);border-left:3px solid var(--success)}.reply-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.reply-header strong{color:#065f46;font-size:.875rem}.reply-status{font-size:.72rem;font-weight:700;padding:2px 7px;border-radius:12px;text-transform:uppercase;letter-spacing:.5px}.reply-status.status-generated{background:var(--border);color:var(--text-muted)}.reply-status.status-approved{background:#d1fae5;color:#065f46}.reply-topic{font-size:.8rem;color:var(--text-muted);margin-bottom:5px;font-style:italic}.reply-categories{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:8px}.reply-category-tag{font-size:.7rem;font-weight:700;padding:2px 9px;border-radius:12px;background:var(--low-mod-bg);color:#1e40af}.reply-text{color:var(--text);font-size:.875rem;line-height:1.7;white-space:pre-wrap}.reply-actions{display:flex;gap:7px;margin-top:8px}.btn-save{padding:5px 14px;background:var(--primary-mid);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.82rem;font-weight:700;cursor:pointer;font-family:var(--font)}.btn-save:hover{background:var(--primary)}.btn-edit-reply{padding:5px 12px;background:transparent;color:var(--primary-mid);border:1px solid var(--primary-mid);border-radius:var(--radius-sm);font-size:.78rem;font-weight:700;cursor:pointer;transition:all var(--transition);font-family:var(--font)}.btn-edit-reply:hover{background:var(--primary-mid);color:#fff}.reply-edit textarea{width:100%;padding:10px 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font);font-size:.875rem;line-height:1.6;resize:vertical;margin-bottom:8px;background:var(--surface);color:var(--text)}.reply-edit textarea:focus{outline:none;border-color:var(--primary-mid);box-shadow:0 0 0 3px #0369a11a}.reply-edit-actions{display:flex;gap:7px}.btn-approve{padding:5px 14px;background:var(--success);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.82rem;font-weight:700;cursor:pointer;font-family:var(--font)}.btn-approve:hover{background:#047857}.btn-cancel{padding:5px 14px;background:var(--surface-3);color:var(--text-muted);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.82rem;font-weight:700;cursor:pointer;font-family:var(--font)}.btn-cancel:hover{background:var(--border)}.email-tabs{display:flex;gap:0;margin-bottom:14px;border-bottom:2px solid var(--border)}.email-tab{padding:9px 18px;border:none;background:none;font-size:.875rem;font-weight:700;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all var(--transition);font-family:var(--font)}.email-tab:hover{color:var(--primary-mid)}.email-tab.active{color:var(--primary-mid);border-bottom-color:var(--primary-mid)}.email-tab-content{min-height:100px}.scraped-email-box{border-left-color:#8b5cf6!important}.scraped-email-box.distress{border-left-color:var(--danger)!important}.scraped-email-box.not-distress{border-left-color:var(--text-faint)!important}.scraped-email-header{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:7px}.scraped-email-meta{display:flex;flex-direction:column;gap:2px}.scraped-email-meta strong{margin-bottom:3px}.scraped-from{font-size:.8rem;color:var(--text-muted)}.scraped-date{font-size:.76rem;color:var(--text-faint)}.scraped-email-badges{display:flex;gap:5px;flex-shrink:0}.scraped-filter-reason{font-size:.78rem;color:var(--text-muted);font-style:italic;margin:7px 0;padding:5px 9px;background:var(--surface-3);border-radius:var(--radius-sm)}.scraped-email-body{color:var(--text-2);font-size:.875rem;line-height:1.6;margin-top:7px;white-space:pre-wrap}.scraped-actions{display:flex;gap:7px;margin-bottom:12px}.btn-check-replies{padding:7px 14px;background:#7c3aed;color:#fff;border:none;border-radius:var(--radius-sm);font-size:.82rem;font-weight:700;cursor:pointer;transition:all var(--transition);font-family:var(--font)}.btn-check-replies:hover{background:#6d28d9;transform:translateY(-1px)}.distress-badge.badge-reply{background:var(--low-mod-bg);color:#1e40af}.scraped-email-box.is-reply{border-left-color:var(--primary-mid)!important;background:var(--surface-2)}.btn-view-thread{margin-top:8px;padding:5px 12px;background:transparent;color:#7c3aed;border:1px solid #7c3aed;border-radius:var(--radius-sm);font-size:.78rem;font-weight:700;cursor:pointer;transition:all var(--transition);font-family:var(--font)}.btn-view-thread:hover:not(:disabled){background:#7c3aed;color:#fff}.btn-view-thread:disabled{opacity:.6;cursor:wait}.thread-conversation{margin-top:12px;padding:14px;background:#faf5ff;border-radius:var(--radius);border:1px solid #e9d5ff}.thread-conversation h4{font-size:.875rem;font-weight:700;color:#6b21a8;margin-bottom:10px}.thread-message{padding:10px;margin-bottom:8px;border-radius:var(--radius-sm);background:var(--surface);border-left:3px solid var(--border)}.thread-message:last-child{margin-bottom:0}.thread-original{border-left-color:var(--danger)}.thread-reply{border-left-color:var(--primary-mid)}.thread-msg-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:3px}.thread-msg-header strong{font-size:.82rem;color:var(--text)}.thread-msg-date{font-size:.72rem;color:var(--text-faint)}.thread-msg-to{display:block;font-size:.76rem;color:var(--text-muted);margin-bottom:5px}.thread-msg-body{font-size:.82rem;color:var(--text-2);line-height:1.6;white-space:pre-wrap}.im-page{max-width:1200px;margin:0 auto;padding:24px;display:flex;flex-direction:column;gap:18px}.im-top-row{display:grid;grid-template-columns:1fr auto;gap:18px;align-items:start}.im-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border);overflow:hidden}.im-card-header{display:flex;align-items:center;justify-content:space-between;padding:16px 22px;cursor:pointer;-webkit-user-select:none;user-select:none}.im-card-title-row{display:flex;align-items:center;gap:10px}.im-card-icon{width:9px;height:9px;border-radius:3px;flex-shrink:0}.im-card-icon--key{background:var(--primary-mid)}.im-card-icon--stats{background:var(--primary-light)}.im-card-icon--config{background:var(--warning)}.im-card-icon--mail{background:var(--success)}.im-card-header h2{font-size:.95rem;font-weight:700;color:var(--text);margin:0}.im-card-sub{font-size:.78rem;color:var(--text-muted);margin:2px 0 0}.im-warn{color:var(--warning)}.im-chevron{font-size:.68rem;color:var(--text-faint)}.im-card-body{padding:0 22px 18px;border-top:1px solid var(--border)}.im-card-stats{min-width:290px}.im-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;padding:6px 14px 14px}.im-stat{display:flex;flex-direction:column;align-items:center;padding:10px 6px}.im-stat-val{font-size:1.5rem;font-weight:800;color:var(--text);line-height:1;font-variant-numeric:tabular-nums}.im-stat-lbl{font-size:.7rem;color:var(--text-muted);font-weight:600;margin-top:3px;text-align:center}.im-stat--alert .im-stat-val{color:var(--danger)}.cred-upload-form{display:flex;align-items:flex-end;gap:10px;flex-wrap:wrap;padding:14px 0 10px}.cred-name-input{flex:1;min-width:170px;padding:8px 11px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:.85rem;outline:none;font-family:var(--font);background:var(--surface);color:var(--text);transition:border-color var(--transition)}.cred-name-input:focus{border-color:var(--primary-mid);box-shadow:0 0 0 3px #0369a11a}.cred-file-label{display:flex;flex-direction:column;gap:3px;font-size:.72rem;font-weight:700;color:var(--text-muted);cursor:pointer}.cred-file-label span{text-transform:uppercase;letter-spacing:.4px}.cred-file-label em{font-style:normal;color:var(--text-faint);text-transform:none;letter-spacing:0;font-weight:400}.cred-file-label input[type=file]{display:none}.cred-file-chosen{display:inline-block;padding:5px 9px;border:1px dashed var(--border-2);border-radius:var(--radius-sm);font-size:.76rem;color:var(--text-muted);background:var(--surface-2);max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:pointer}.cred-file-chosen:hover{border-color:var(--primary-mid);background:var(--primary-xlight)}.cred-error{color:var(--danger);font-size:.8rem;margin-top:2px}.cred-table{width:100%;border-collapse:collapse;margin-top:7px;font-size:.85rem}.cred-table th{text-align:left;padding:7px 11px;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-faint);border-bottom:1px solid var(--border)}.cred-table td{padding:9px 11px;border-bottom:1px solid var(--surface-3);color:var(--text)}.cred-row-active{background:#f0fdf4}.cred-actions{display:flex;gap:5px}.btn-sm{padding:3px 10px;font-size:.76rem;border-radius:var(--radius-sm);cursor:pointer;font-weight:700;border:none;transition:all var(--transition);font-family:var(--font)}.btn-danger{background:var(--critical-bg);color:var(--danger);border:1px solid var(--critical-border)}.btn-danger:hover{background:#fca5a5}.cred-badge-ok{color:var(--success);font-weight:700;font-size:.8rem}.cred-badge-miss{color:var(--text-faint);font-size:.8rem}.cred-badge-active{background:var(--low-bg);color:#166534;padding:2px 8px;border-radius:20px;font-size:.7rem;font-weight:700}.cred-badge-inactive{background:var(--surface-3);color:var(--text-faint);padding:2px 8px;border-radius:20px;font-size:.7rem}.im-scrape-row{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap;padding:14px 0 7px}.im-field{display:flex;flex-direction:column;gap:4px}.im-field label{font-size:.72rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px}.im-field-grow{flex:1;min-width:190px}.im-field-small{flex:0 0 105px}.im-select,.im-input{padding:8px 11px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:.85rem;font-family:var(--font);outline:none;background:var(--surface);color:var(--text);transition:border-color var(--transition)}.im-select:focus,.im-input:focus{border-color:var(--primary-mid);box-shadow:0 0 0 3px #0369a11a}.im-scrape-btn{display:flex;align-items:center;gap:7px;padding:9px 20px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-mid) 100%);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.875rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:all var(--transition);align-self:flex-end;box-shadow:0 2px 6px #0c4a6e40;font-family:var(--font)}.im-scrape-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #0c4a6e4d}.im-scrape-btn--running,.im-scrape-btn:disabled{background:var(--text-faint);cursor:wait}.im-query-preview{font-size:.76rem;color:var(--text-faint);margin:3px 0 0;font-family:monospace}.im-query-preview span{color:var(--border-2);margin-right:3px}.im-progress-bar-wrap{display:flex;align-items:center;gap:10px;margin-top:12px}.im-progress-bar{flex:1;height:4px;background:var(--border);border-radius:4px;overflow:hidden}.im-progress-bar-inner{height:100%;width:40%;background:linear-gradient(90deg,var(--primary-mid),var(--primary-light));border-radius:4px;animation:progressPulse 1.4s ease-in-out infinite}.im-last-run{margin-top:14px;padding:12px 14px;background:var(--low-bg);border-radius:var(--radius);border:1px solid var(--low-border)}.im-last-run-title{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#166534;margin-bottom:7px}.im-last-run .im-stats-grid{padding:0;grid-template-columns:repeat(4,1fr)}.im-last-run .im-stat-val{font-size:1.2rem}.im-toggle{display:flex;align-items:center;gap:5px;font-size:.82rem;font-weight:600;color:var(--text-2);cursor:pointer}.im-toggle input{accent-color:var(--primary-mid)}.im-count{font-size:.85rem;font-weight:600;color:var(--text-faint)}.im-empty{padding:36px;text-align:center;color:var(--text-faint);font-size:.875rem}.spinner-small{width:15px;height:15px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .75s linear infinite;flex-shrink:0}.scraped-table-wrapper{overflow-x:auto}.scraped-table{width:100%;border-collapse:collapse;font-size:.83rem}.scraped-table th{text-align:left;padding:9px 11px;background:var(--surface-3);color:var(--text-muted);font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--border)}.scraped-table td{padding:9px 11px;border-bottom:1px solid var(--border);color:var(--text-2)}.scraped-table tr:hover{background:var(--surface-3)}.scraped-table tr.row-distress{border-left:3px solid var(--danger)}.student-id-cell{font-weight:700;color:var(--primary-mid)}.subject-cell{max-width:240px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.distress-badge{font-size:.76rem;font-weight:700;padding:2px 9px;border-radius:12px}.distress-badge.badge-yes{background:var(--critical-bg);color:#991b1b}.distress-badge.badge-no{background:var(--surface-3);color:var(--text-muted)}.mini-categories{display:flex;flex-wrap:wrap;gap:2px}.mini-cat-tag{font-size:.68rem;padding:1px 5px;border-radius:7px;background:var(--primary-xlight);color:var(--primary);white-space:nowrap}.status-badge{font-size:.72rem;font-weight:700;padding:2px 7px;border-radius:12px}.status-badge.status-analyzed{background:#d1fae5;color:#065f46}.status-badge.status-pending{background:var(--moderate-bg);color:var(--moderate)}.status-badge.status-skipped{background:var(--surface-3);color:var(--text-muted)}.cases-section-header{display:flex;align-items:center;justify-content:space-between;cursor:pointer;-webkit-user-select:none;user-select:none}.cases-section-header:hover h3{color:var(--primary-mid)}.cases-toggle{font-size:.82rem;color:var(--text-muted)}.cases-list{display:flex;flex-direction:column;gap:10px;margin-top:10px}.case-item{border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;background:var(--surface);transition:box-shadow var(--transition)}.case-item:hover{box-shadow:var(--shadow-md)}.case-item-resolved{border-left:4px solid var(--low)}.case-item-awaiting_reply{border-left:4px solid var(--warning)}.case-item-has_support_reply{border-left:4px solid var(--primary-mid)}.case-item-header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:5px}.case-item-meta{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.case-item-number{font-size:.76rem;font-weight:700;color:var(--text-muted)}.case-item-subject{font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.case-item-badges{display:flex;align-items:center;gap:7px;flex-shrink:0}.case-msg-count{font-size:.76rem;color:var(--text-muted);white-space:nowrap}.case-item-dates{display:flex;gap:14px;font-size:.78rem;color:var(--text-muted);margin-bottom:8px}.cases-filter-group{grid-template-columns:200px 1fr auto auto!important}.cases-table-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.cases-cache-info{display:flex;align-items:center;gap:10px;font-size:.78rem;color:var(--text-faint)}.cases-refresh-btn{padding:5px 12px!important;font-size:.8rem!important}.cases-number{font-weight:700;color:var(--primary-mid);font-size:.86rem}.cases-student-link{color:var(--primary-mid);font-weight:600;font-size:.83rem;cursor:pointer;text-decoration:none}.cases-student-link:hover{text-decoration:underline}.cases-source-badge{margin-left:8px;padding:2px 7px;border-radius:10px;font-size:.7rem;font-weight:700;background:var(--primary-xlight);color:var(--primary);vertical-align:middle}.cases-status-badge{display:inline-block;padding:3px 9px;border-radius:20px;font-size:.72rem;font-weight:700;white-space:nowrap}.status-resolved{background:var(--low-bg);color:#15803d;border:1px solid var(--low-border)}.status-awaiting{background:var(--moderate-bg);color:#b45309;border:1px solid var(--moderate-border)}.status-has-reply{background:var(--low-mod-bg);color:#1d4ed8;border:1px solid var(--low-mod-border)}.cache-info-bar{display:flex;align-items:center;justify-content:flex-end;gap:10px;margin-top:16px;font-size:.8rem;color:var(--text-muted)}.btn-refresh-cache{background:none;border:1px solid var(--border);color:var(--text-muted);padding:3px 10px;border-radius:var(--radius-sm);cursor:pointer;font-size:.8rem;font-family:var(--font);transition:all var(--transition)}.btn-refresh-cache:hover:not(:disabled){background:var(--surface-3);border-color:var(--border-2)}.btn-refresh-cache:disabled{opacity:.5;cursor:not-allowed}.login-page{display:flex;justify-content:center;align-items:center;height:100vh;background:linear-gradient(145deg,var(--primary) 0%,#0c5a84 40%,#0d7aaa 100%)}.login-card{background:var(--surface);padding:44px;border-radius:var(--radius-xl);box-shadow:0 8px 40px #0c4a6e59;text-align:center;max-width:400px;width:90%;border:1px solid rgba(255,255,255,.08)}.login-card h1{font-size:1.45rem;color:var(--text);margin-bottom:8px}.login-card p{color:var(--text-muted);margin-bottom:22px;font-size:.9rem}.btn-login{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-mid) 100%);color:#fff;border:none;padding:11px 30px;border-radius:var(--radius-sm);font-size:.95rem;cursor:pointer;font-weight:700;transition:all var(--transition);box-shadow:0 2px 8px #0c4a6e40;font-family:var(--font)}.btn-login:hover{transform:translateY(-1px);box-shadow:0 4px 14px #0c4a6e59}.main-footer{text-align:center;padding:14px 16px;color:var(--text-faint);font-size:.76rem;border-top:1px solid var(--border);margin-top:24px}.insights-section{padding:0 48px 28px;max-width:1600px;margin:0 auto;animation:fadeIn .5s ease .2s both}.insights-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:18px}.insight-card{background:var(--surface);padding:18px 22px;border-radius:var(--radius);box-shadow:var(--shadow-xs);border:1px solid var(--border);border-left:4px solid var(--primary-mid);transition:all var(--transition)}.insight-card.warning{border-left-color:var(--warning);background:linear-gradient(135deg,#fffbeb 0%,var(--surface) 100%)}.insight-card.critical{border-left-color:var(--danger);background:linear-gradient(135deg,var(--critical-bg) 0%,var(--surface) 100%)}.insight-card:hover{transform:translate(3px);box-shadow:var(--shadow-md)}.insight-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}.insight-icon{font-size:1.25em}.insight-header h4{font-size:.9rem;font-weight:700;color:var(--text);margin:0}.insight-card p{font-size:.875rem;color:var(--text-muted);line-height:1.6;margin:0}.insight-value{display:inline-block;background:var(--primary-mid);color:#fff;padding:2px 7px;border-radius:var(--radius-sm);font-weight:700;font-size:.9rem}.marker-card{background:var(--surface);padding:22px;border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-xs);display:flex;gap:14px;transition:all var(--transition);position:relative;overflow:hidden}.marker-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:#b8d0e8}.marker-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--danger) 0%,var(--warning) 50%,var(--success) 100%);opacity:0;transition:opacity var(--transition)}.marker-card:hover:before{opacity:1}.marker-rank{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-mid) 100%);color:#fff;width:38px;height:38px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.1em;flex-shrink:0;box-shadow:0 2px 7px #0c4a6e4d}.marker-content{flex:1;min-width:0}.marker-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;gap:10px}.marker-category{font-weight:700;color:var(--text);font-size:.9rem;line-height:1.4;flex:1}.marker-diff{background:var(--low-bg);color:var(--low);padding:5px 12px;border-radius:var(--radius-sm);font-weight:700;font-size:.9rem;flex-shrink:0;border:1px solid var(--low-border)}.marker-bar-container{width:100%}.marker-bar{display:flex;height:38px;border-radius:var(--radius-sm);overflow:hidden;background:var(--surface-3)}.bar-segment{display:flex;align-items:center;justify-content:center;font-size:.78em;font-weight:700;color:#fff;transition:all var(--transition);position:relative}.bar-segment.high-risk{background:linear-gradient(90deg,var(--danger) 0%,#dc2626 100%)}.bar-segment.other{background:linear-gradient(90deg,var(--text-faint) 0%,var(--text-muted) 100%)}.bar-label{white-space:nowrap;padding:0 10px;position:relative}.bar-label.outside{position:absolute;left:100%;padding-left:7px;color:var(--text);font-weight:600}.marker-explanation{max-height:0;opacity:0;overflow:hidden;transition:all .4s ease;color:var(--text-muted);font-size:.875rem;line-height:1.6;border-top:1px solid var(--border)}.marker-explanation strong{color:var(--text);font-weight:700}.prevalence-section{max-width:1600px;margin:0 auto 32px;padding:0 48px}.prevalence-section h2{font-size:1.2rem;font-weight:800;color:var(--text);margin-bottom:8px}.prevalence-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(330px,1fr));gap:18px}.prevalence-card{background:var(--surface);padding:22px;border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-xs)}.prevalence-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;padding-bottom:14px;border-bottom:2px solid var(--border)}.prevalence-header h3{margin:0;font-size:.95rem;font-weight:700}.student-count{color:var(--text-muted);font-size:.875rem;font-weight:600}.prevalence-list{display:flex;flex-direction:column;gap:10px}.prevalence-list strong{display:block;color:var(--text);font-size:.86rem;margin-bottom:7px;font-weight:700}.prevalence-item{display:flex;justify-content:space-between;align-items:flex-start;padding:8px 10px;background:var(--surface-2);border-radius:var(--radius-sm);transition:background var(--transition)}.prevalence-item:hover{background:var(--surface-3)}.prevalence-category{flex:1;color:var(--text-2);font-size:.83rem;font-weight:500;line-height:1.4}.prevalence-stats{display:flex;align-items:center;gap:7px;flex-shrink:0;margin-left:10px}.prevalence-percent{color:var(--text);font-weight:800;font-size:.875rem;min-width:40px;text-align:right;font-variant-numeric:tabular-nums}.prevalence-count{color:var(--text-faint);font-size:.8rem;font-weight:500}[data-tooltip]{position:relative;cursor:help}[data-tooltip]:hover:after{content:attr(data-tooltip);position:absolute;bottom:180%;left:50%;transform:translate(-50%) scale(1);background:#0c1c32f0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#e2eaf5;padding:10px 14px;border-radius:var(--radius-sm);font-size:.82rem;line-height:1.5;white-space:pre-wrap;width:480px;text-align:center;word-wrap:break-word;z-index:1000;box-shadow:0 8px 24px #0000002e;border:1px solid rgba(14,165,233,.2);pointer-events:none;animation:tooltipFadeIn .18s ease-in-out}[data-tooltip]:hover:before{content:"";position:absolute;bottom:174%;left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:#0c1c32f0;z-index:1000;pointer-events:none;animation:tooltipFadeIn .18s ease-in-out}@media(max-width:768px){[data-tooltip]:hover:after{max-width:200px;font-size:.78rem;padding:7px 10px}}@media(max-width:1200px){.charts-section{grid-template-columns:1fr}}@media(max-width:900px){.markers-table-header,.mt-row{grid-template-columns:28px 1fr 60px 60px 1fr 70px}}@media(max-width:768px){.header{padding:24px 20px}.stats-grid,.charts-section,.insights-section,.filters-section,.table-section,.intelligence-section,.risk-details-section,.heatmap-section,.markers-section,.patterns-section,.prevalence-section{padding-left:16px;padding-right:16px}.charts-section,.filter-group{grid-template-columns:1fr}.modal-content{width:100%}.stat-card{padding:18px}.header-actions{flex-direction:column;width:100%}.export-btn,.date-selector{width:100%;justify-content:center}.intelligence-grid,.risk-details-grid,.patterns-grid,.attendance-summary,.drift-metrics-grid,.alignment-grid,.im-top-row,.markers-table-header,.mt-row{grid-template-columns:1fr}}
