*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --white:#fff;--bg:#F5F6F9;--red:#D12E00;--red-s:rgba(209,46,0,.07);--red-b:rgba(209,46,0,.14);
  --orange:#F07430;--navy:#12224A;--ink:#0B0F1E;--ink2:#404767;--muted:#8890AA;--muted2:#BFC4D6;
  --border:#E4E7F0;--green:#0B9E72;--green-s:rgba(11,158,114,.07);--amber:#C97700;
  --amber-s:rgba(201,119,0,.07);--blue:#2255D4;--blue-s:rgba(34,85,212,.07);
}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--ink);overflow-x:hidden}
::-webkit-scrollbar{width:4px}::-webkit-scrollbar-thumb{background:var(--muted2);border-radius:2px}

.dafety-app{display:flex;height:100vh}

/* SIDEBAR */
.sb{width:210px;background:var(--white);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0}
.sb-logo{padding:18px 16px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px}
.sb-logo-text{font-family:'Josefin Sans',sans-serif;font-size:20px;font-weight:700;color:var(--ink);letter-spacing:-0.5px}
.sb-logo-text span{color:var(--red)}
.sb-ver{margin-left:auto;font-size:9px;font-weight:700;letter-spacing:.6px;font-family:'JetBrains Mono',monospace;color:var(--red);background:var(--red-s);border:1px solid var(--red-b);padding:2px 6px;border-radius:3px}
.sb-sect{padding:14px 14px 4px;font-size:9px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--muted);font-family:'JetBrains Mono',monospace}
.sb-link{display:flex;align-items:center;gap:9px;padding:8px 14px;margin:1px 8px;border-radius:7px;cursor:pointer;font-size:12.5px;font-weight:500;color:var(--ink2);transition:all .15s;text-decoration:none;position:relative;border:none;background:none;width:calc(100% - 16px);text-align:left}
.sb-link:hover{background:var(--bg);color:var(--ink)}
.sb-link.on{background:var(--red-s);color:var(--red);font-weight:600}
.sb-link.on::before{content:'';position:absolute;left:-8px;top:50%;transform:translateY(-50%);width:3px;height:14px;background:var(--red);border-radius:0 2px 2px 0}
.sb-dash-link{font-weight:600 !important;color:var(--ink) !important;font-size:13px !important}
.sb-ico{width:16px;text-align:center;font-size:13px;opacity:.65;flex-shrink:0}
.sb-link.on .sb-ico,.sb-link:hover .sb-ico{opacity:1}
.sb-pill{margin-left:auto;font-size:9px;font-weight:700;padding:1px 6px;border-radius:3px;font-family:'JetBrains Mono',monospace}
.spr{background:var(--red);color:#fff}.spg{background:var(--green-s);color:var(--green);border:1px solid rgba(11,158,114,.2)}
.sb-foot{margin-top:auto;padding:14px;border-top:1px solid var(--border);display:flex;align-items:center;gap:9px}
.sb-ava{width:28px;height:28px;border-radius:7px;background:linear-gradient(135deg,var(--red),var(--orange));display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;color:#fff;font-family:'JetBrains Mono',monospace;flex-shrink:0}

/* MAIN */
.main-area{flex:1;display:flex;flex-direction:column;overflow:hidden}
.topbar{height:50px;background:var(--white);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:12px;flex-shrink:0}
.tb-bc{display:flex;align-items:center;gap:5px;font-size:12.5px;color:var(--muted)}
.tb-bc .sep{color:var(--muted2)}.tb-bc .cur{color:var(--ink);font-weight:600}
.tb-r{margin-left:auto;display:flex;align-items:center;gap:8px}
.tb-live{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:600;color:var(--green);font-family:'JetBrains Mono',monospace}
.ldot{width:6px;height:6px;border-radius:50%;background:var(--green);animation:ping 2s infinite}
@keyframes ping{0%,100%{box-shadow:0 0 0 0 rgba(11,158,114,.4)}50%{box-shadow:0 0 0 5px transparent}}
.tb-btn{height:30px;padding:0 13px;border-radius:6px;font-size:11.5px;font-weight:600;cursor:pointer;font-family:'Inter',sans-serif;transition:all .15s;border:none;display:inline-flex;align-items:center;text-decoration:none;line-height:1}
.tb-ghost{background:var(--bg);color:var(--ink2);border:1px solid var(--border)}.tb-ghost:hover{color:var(--ink)}
.tb-primary{background:var(--red);color:#fff;box-shadow:0 2px 8px rgba(209,46,0,.2)}.tb-primary:hover{background:#aa2500}

/* Alerts dropdown */
.alerts-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:340px;background:var(--white);border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 30px rgba(0,0,0,.12);z-index:50;animation:up .15s ease;overflow:hidden}

/* DEMO BAR */
.dbar{background:var(--white);border-bottom:1px solid var(--border);padding:7px 24px;display:flex;align-items:center;gap:6px;flex-shrink:0}
.dlabel{font-size:9px;font-weight:700;letter-spacing:1px;color:var(--muted);text-transform:uppercase;font-family:'JetBrains Mono',monospace;margin-right:3px;white-space:nowrap}
.dtab{padding:4px 12px;border-radius:5px;font-size:11px;font-weight:600;cursor:pointer;border:1px solid var(--border);background:transparent;color:var(--muted);font-family:'Inter',sans-serif;transition:all .14s;white-space:nowrap}
.dtab:hover{border-color:var(--muted2);color:var(--ink2)}.dtab.on{background:var(--navy);color:#fff;border-color:var(--navy)}

.scroll{flex:1;overflow-y:auto;padding:26px 26px 48px}
.screen{display:none}.screen.on{display:block;animation:up .2s ease forwards}
@keyframes up{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}

/* DASHBOARD */
.pg-hd{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:22px}
.pg-title{font-family:'Outfit',sans-serif;font-weight:800;font-size:24px;letter-spacing:-.3px;color:var(--ink)}
.pg-sub{font-size:12px;color:var(--muted);margin-top:3px}
.run-btn{background:var(--red);color:#fff;border:none;border-radius:8px;padding:9px 18px;font-size:12.5px;font-weight:700;cursor:pointer;font-family:'Inter',sans-serif;display:flex;align-items:center;gap:6px;box-shadow:0 3px 12px rgba(209,46,0,.22);transition:all .15s}
.run-btn:hover{background:#aa2500;transform:translateY(-1px)}

/* KPI strip */
.kpi-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}
.kpi{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:18px 20px;position:relative;overflow:hidden;transition:box-shadow .2s,transform .2s}
.kpi:hover{box-shadow:0 4px 18px rgba(0,0,0,.06);transform:translateY(-1px)}
.kpi-top{position:absolute;top:0;left:0;right:0;height:3px;border-radius:12px 12px 0 0}
.kpi-lbl{font-size:9.5px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--muted);margin-bottom:10px;font-family:'JetBrains Mono',monospace}
.kpi-num{font-family:'Outfit',sans-serif;font-weight:800;font-size:40px;letter-spacing:-.5px;line-height:1;color:var(--ink)}
.kpi-foot{display:flex;align-items:center;gap:5px;margin-top:8px}
.kpi-delta{font-size:10.5px;font-weight:700;font-family:'JetBrains Mono',monospace}
.kpi-sub2{font-size:11px;color:var(--muted)}
.up{color:var(--green)}.warn{color:var(--amber)}
.spark{position:absolute;bottom:14px;right:14px}

/* Grid layouts */
.row2{display:grid;grid-template-columns:1.4fr 1fr;gap:14px;margin-bottom:14px}
.row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}

/* Card */
.card{background:var(--white);border:1px solid var(--border);border-radius:12px;overflow:hidden}
.ch{padding:13px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.ch-t{font-size:12.5px;font-weight:700;color:var(--ink);display:flex;align-items:center;gap:6px}
.ch-r{font-size:10.5px;font-weight:600;color:var(--red);cursor:pointer;font-family:'JetBrains Mono',monospace}
.cb{padding:14px 16px}

/* Badges */
.badge{font-size:9.5px;font-weight:700;padding:2px 7px;border-radius:3px;font-family:'JetBrains Mono',monospace;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;flex-shrink:0}
.br{background:var(--red-s);color:var(--red);border:1px solid var(--red-b)}
.ba{background:var(--amber-s);color:var(--amber);border:1px solid rgba(201,119,0,.15)}
.bi{background:var(--blue-s);color:var(--blue);border:1px solid rgba(34,85,212,.12)}
.bg2{background:var(--green-s);color:var(--green);border:1px solid rgba(11,158,114,.15)}

/* Incidents */
.irow{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--border);cursor:pointer;transition:padding .12s}
.irow:last-child{border-bottom:none;padding-bottom:0}.irow:hover{padding-left:4px}
.ibar{width:3px;height:34px;border-radius:2px;flex-shrink:0}
.itext{flex:1;min-width:0}
.ititle{font-size:12.5px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.imeta{font-size:10.5px;color:var(--muted);margin-top:1px;font-family:'JetBrains Mono',monospace}

/* Bar chart */
.barchart{display:flex;align-items:flex-end;gap:5px;height:92px;padding-bottom:2px}
.bc{flex:1;border-radius:3px 3px 0 0;transition:opacity .2s;cursor:pointer}.bc:hover{opacity:.75}
.bc-ax{display:flex;justify-content:space-between;margin-top:6px}
.bc-ax span{font-size:8.5px;color:var(--muted);font-family:'JetBrains Mono',monospace}

/* Donut */
.donut-wrap{display:flex;align-items:center;gap:18px}
.legend{flex:1;display:flex;flex-direction:column;gap:9px}
.leg{display:flex;align-items:center;justify-content:space-between}
.leg-l{display:flex;align-items:center;gap:7px;font-size:11.5px;color:var(--ink2)}
.leg-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}
.leg-val{font-size:12px;font-weight:700;color:var(--ink);font-family:'JetBrains Mono',monospace}

/* Category bars */
.cat{margin-bottom:11px}.cat:last-child{margin-bottom:0}
.cat-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:4px}
.cat-name{font-size:11.5px;font-weight:500;color:var(--ink2)}
.cat-pct{font-size:11px;font-weight:700;color:var(--ink);font-family:'JetBrains Mono',monospace}
.cat-bar{height:5px;background:var(--bg);border-radius:3px;overflow:hidden}
.cat-fill{height:100%;border-radius:3px;transition:width .7s ease}

/* Heatmap */
.hm-months{display:grid;grid-template-columns:repeat(12,1fr);gap:2px;margin-bottom:2px}
.hm-months span{font-size:8px;color:var(--muted);text-align:center;font-family:'JetBrains Mono',monospace}
.hm{display:grid;grid-template-columns:repeat(12,1fr);gap:2px;contain:layout style}
.hmc{aspect-ratio:1;border-radius:2px;cursor:pointer;transition:transform .08s}.hmc:hover{transform:scale(1.2)}
.hm-tooltip{position:absolute;transform:translateX(-50%) translateY(-100%);background:var(--navy);color:#fff;padding:4px 10px;border-radius:5px;font-size:10px;font-weight:600;white-space:nowrap;pointer-events:none;font-family:'JetBrains Mono',monospace;z-index:10;box-shadow:0 3px 10px rgba(0,0,0,.18)}
.hm-leg{display:flex;align-items:center;gap:5px;margin-top:8px;justify-content:flex-end}
.hm-leg span{font-size:8.5px;color:var(--muted);font-family:'JetBrains Mono',monospace}
.hm-sw{width:9px;height:9px;border-radius:2px}

/* Stat tiles */
.st{background:var(--bg);border-radius:8px;padding:13px 14px;text-align:center}
.stn{font-family:'Outfit',sans-serif;font-weight:800;font-size:26px;letter-spacing:-.5px;line-height:1}
.stl{font-size:9.5px;color:var(--muted);margin-top:4px;font-family:'JetBrains Mono',monospace;text-transform:uppercase;letter-spacing:.4px}

/* FLOW */
.stepper{display:flex;align-items:center;background:var(--white);border:1px solid var(--border);border-radius:10px;padding:13px 22px;margin-bottom:28px}
.stp{display:flex;align-items:center}
.stp-c{width:26px;height:26px;border-radius:50%;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;font-family:'JetBrains Mono',monospace;flex-shrink:0;transition:all .2s}
.stp-c.done{background:var(--navy);color:#fff}.stp-c.act{background:var(--red);color:#fff;box-shadow:0 0 0 3px rgba(209,46,0,.15)}.stp-c.todo{background:var(--bg);color:var(--muted);border:1.5px solid var(--border)}
.stp-l{font-size:11.5px;font-weight:600;margin-left:8px}
.stp-l.done{color:var(--muted)}.stp-l.act{color:var(--red)}.stp-l.todo{color:var(--muted)}
.stp-line{flex:1;height:1.5px;margin:0 10px;max-width:50px}
.stp-line.done{background:var(--navy);opacity:.25}.stp-line.todo{background:var(--border)}

.flow-outer{max-width:840px;margin:0 auto}
.flow-hd{text-align:center;margin-bottom:32px}
.flow-eye{font-size:9.5px;font-weight:700;letter-spacing:1.4px;text-transform:uppercase;color:var(--muted);margin-bottom:9px;font-family:'JetBrains Mono',monospace}
.flow-eye b{color:var(--red)}
.flow-title{font-family:'Outfit',sans-serif;font-weight:800;font-size:30px;letter-spacing:-.3px;color:var(--ink);margin-bottom:7px}
.flow-sub{font-size:13.5px;color:var(--ink2);line-height:1.7}

/* Option cards */
.og{display:grid;grid-template-columns:repeat(3,1fr);gap:11px;margin-bottom:11px}
.og2{grid-template-columns:repeat(2,1fr);max-width:540px;margin:0 auto}
.oc{background:var(--white);border:2px solid var(--border);border-radius:11px;padding:20px 16px;cursor:pointer;transition:all .18s;text-align:center;position:relative}
.oc:hover{border-color:var(--muted2);box-shadow:0 4px 14px rgba(0,0,0,.06);transform:translateY(-2px)}
.oc.sel{border-color:var(--red);background:var(--red-s);box-shadow:0 0 0 1px rgba(209,46,0,.08),0 6px 18px rgba(209,46,0,.07);transform:translateY(-2px)}
.oc-check{position:absolute;top:9px;right:9px;width:16px;height:16px;border-radius:50%;background:var(--red);display:none;align-items:center;justify-content:center;font-size:8px;color:#fff;font-weight:900}
.oc.sel .oc-check{display:flex}
.oi{width:42px;height:42px;border-radius:10px;background:var(--bg);border:1px solid var(--border);margin:0 auto 11px;display:flex;align-items:center;justify-content:center;font-size:18px;transition:all .2s}
.oc.sel .oi{background:rgba(209,46,0,.07);border-color:var(--red-b)}
.oc h4{font-size:13px;font-weight:700;color:var(--ink);margin-bottom:5px}
.oc p{font-size:11px;color:var(--muted);line-height:1.6}

/* Query tabs */
.qtabs{display:flex;background:var(--bg);border:1px solid var(--border);border-radius:7px;padding:3px;max-width:fit-content;margin:0 auto 26px}
.qtab{padding:5px 14px;border-radius:5px;font-size:11.5px;font-weight:600;cursor:pointer;color:var(--muted);background:none;border:none;font-family:'Inter',sans-serif;transition:all .14s}
.qtab:hover{color:var(--ink2)}.qtab.on{background:var(--white);color:var(--ink);box-shadow:0 1px 4px rgba(0,0,0,.08)}

/* Flow footer */
.ffoot{display:flex;align-items:center;justify-content:space-between;margin-top:32px;padding-top:20px;border-top:1px solid var(--border)}
.btn-back{background:transparent;border:1.5px solid var(--border);color:var(--ink2);border-radius:7px;padding:9px 18px;font-size:12.5px;font-weight:600;cursor:pointer;font-family:'Inter',sans-serif;transition:all .15s;display:flex;align-items:center;gap:6px}
.btn-back:hover{border-color:var(--muted2);color:var(--ink)}
.btn-next{background:var(--red);color:#fff;border:none;border-radius:7px;padding:9px 22px;font-size:12.5px;font-weight:700;cursor:pointer;font-family:'Inter',sans-serif;transition:all .15s;display:flex;align-items:center;gap:7px;box-shadow:0 3px 10px rgba(209,46,0,.2)}
.btn-next:hover{background:#aa2500}

/* CASE SUMMARY */
.alert-box{background:rgba(209,46,0,.05);border:1.5px solid var(--red-b);border-radius:10px;padding:14px 18px;margin-bottom:18px;display:flex;gap:12px;align-items:flex-start;position:relative;overflow:hidden}
.alert-box::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--red)}
.alert-ic{width:32px;height:32px;background:var(--red-s);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.alert-title{font-size:12.5px;font-weight:700;color:var(--red);margin-bottom:3px}
.alert-body{font-size:11.5px;color:var(--ink2);line-height:1.6}

.meta-strip{display:grid;grid-template-columns:repeat(6,1fr);background:var(--white);border:1px solid var(--border);border-radius:11px;overflow:hidden;margin-bottom:16px}
.ms{padding:14px 12px;border-right:1px solid var(--border);text-align:center;transition:background .12s;cursor:default}
.ms:last-child{border-right:none}.ms:hover{background:var(--bg)}
.ms-lbl{font-size:8.5px;font-weight:700;letter-spacing:.7px;text-transform:uppercase;color:var(--muted);margin-bottom:7px;font-family:'JetBrains Mono',monospace}
.ms-val{font-family:'Outfit',sans-serif;font-weight:800;font-size:19px;letter-spacing:-.3px;line-height:1;color:var(--ink)}
.ms-sub{font-size:9.5px;color:var(--muted);margin-top:3px}

/* Timeline */
.timeline{padding-left:18px;position:relative}
.timeline::before{content:'';position:absolute;left:5px;top:2px;bottom:2px;width:1.5px;background:var(--border)}
.tl-ev{position:relative;margin-bottom:16px}.tl-ev:last-child{margin-bottom:0}
.tl-dot{position:absolute;left:-18px;top:3px;width:11px;height:11px;border-radius:50%;border:2px solid var(--white);box-shadow:0 0 0 1.5px var(--border)}
.tl-date{font-size:9.5px;font-weight:700;color:var(--muted);font-family:'JetBrains Mono',monospace;margin-bottom:2px}
.tl-ttl{font-size:12.5px;font-weight:600;color:var(--ink);margin-bottom:1px}
.tl-body{font-size:11.5px;color:var(--muted);line-height:1.55}

/* Detail card */
.dcard{background:var(--white);border:1px solid var(--border);border-radius:9px;overflow:hidden;margin-bottom:11px}
.dcard-h{padding:10px 16px;background:var(--bg);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px}
.dcard-title{font-size:11.5px;font-weight:700;color:var(--ink)}
.dcard-b{padding:13px 16px;font-size:12.5px;color:var(--ink2);line-height:1.75}
.dcard-b ul{margin-left:16px;margin-top:7px;display:flex;flex-direction:column;gap:4px}
.dcard-b li{font-size:11.5px;color:var(--muted)}

/* INCIDENT DETAILS */
.prod-hd{background:var(--white);border:1px solid var(--border);border-radius:11px;padding:20px 22px;margin-bottom:16px;display:flex;gap:20px}
.ph-left{flex:1}
.ph-title{font-family:'Outfit',sans-serif;font-weight:800;font-size:20px;letter-spacing:-.3px;color:var(--ink);margin-bottom:8px}
.ph-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:6px}
.ph-id{font-size:10.5px;color:var(--muted);font-family:'JetBrains Mono',monospace}
.ph-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:16px;padding-top:14px;border-top:1px solid var(--border)}
.ph-stat{text-align:center}
.ph-stat-n{font-family:'Outfit',sans-serif;font-weight:800;font-size:26px;letter-spacing:-.5px;line-height:1;color:var(--ink)}
.ph-stat-l{font-size:9.5px;color:var(--muted);margin-top:3px;font-family:'JetBrains Mono',monospace;text-transform:uppercase;letter-spacing:.4px}
.ph-actions{display:flex;flex-direction:column;gap:7px;flex-shrink:0}
.act-btn{display:flex;align-items:center;gap:7px;padding:7px 13px;border-radius:7px;font-size:11.5px;font-weight:600;cursor:pointer;border:1.5px solid var(--border);background:var(--white);color:var(--ink2);font-family:'Inter',sans-serif;transition:all .14s;white-space:nowrap}
.act-btn:hover{border-color:var(--muted2);color:var(--ink)}.act-btn.danger{border-color:var(--red-b);color:var(--red)}.act-btn.danger:hover{background:var(--red-s)}

/* Data table */
.dtable{background:var(--white);border:1px solid var(--border);border-radius:10px;overflow:hidden}
.dt-hd{display:grid;padding:9px 16px;background:var(--bg);border-bottom:1px solid var(--border)}
.dt4{grid-template-columns:2.5fr 1fr 1fr 1.2fr}
.dt-hcell{font-size:8.5px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--muted);font-family:'JetBrains Mono',monospace}
.dt-row{display:grid;padding:12px 16px;border-bottom:1px solid var(--border);align-items:center;transition:background .12s;cursor:pointer}
.dt-row:last-child{border-bottom:none}.dt-row:hover{background:var(--bg)}
.dt-cell{font-size:12px;color:var(--ink2)}.dt-cell.bold{font-weight:600;color:var(--ink)}.dt-cell.mono{font-family:'JetBrains Mono',monospace;font-size:10.5px;color:var(--muted)}
@keyframes draw{to{stroke-dashoffset:0}}

/* LOGIN SCREEN */
.login-overlay{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,#F5F6F9 0%,#ECEEF4 50%,#E4E7F0 100%);transition:opacity .5s ease,visibility .5s ease}
.login-overlay.hidden{opacity:0;visibility:hidden;pointer-events:none}
.login-wrap{width:100%;max-width:400px;padding:0 20px}
.login-flow-dots{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:28px}
.login-flow-step{display:flex;flex-direction:column;align-items:center;gap:4px}
.lf-dot{width:10px;height:10px;border-radius:50%;border:2px solid var(--muted2);background:transparent;transition:all .3s}
.lf-dot.active{background:var(--red);border-color:var(--red)}
.lf-dot.done{background:var(--green);border-color:var(--green)}
.lf-line{width:36px;height:2px;background:var(--border);margin:0 6px}
.lf-label{font-size:9px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--muted);font-family:'JetBrains Mono',monospace}
.login-card{background:var(--white);border:1px solid var(--border);border-radius:14px;padding:40px 36px 34px;box-shadow:0 16px 48px rgba(11,15,30,.05),0 1px 3px rgba(11,15,30,.03)}
.login-logo-area{text-align:center;margin-bottom:10px;display:flex;justify-content:center}
.login-tagline{text-align:center;font-size:12px;color:var(--muted);margin-bottom:28px}
.login-field{margin-bottom:16px}
.login-field label{display:block;font-size:11px;font-weight:600;color:var(--ink2);margin-bottom:5px;letter-spacing:.02em}
.login-field input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;font-size:13px;font-family:'Inter',sans-serif;color:var(--ink);background:var(--bg);outline:none;transition:border-color .2s,box-shadow .2s}
.login-field input:focus{border-color:var(--red);box-shadow:0 0 0 3px rgba(209,46,0,.06)}
.login-field input::placeholder{color:var(--muted2)}
.login-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.login-row label{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--ink2);cursor:pointer}
.login-row input[type="checkbox"]{width:14px;height:14px;accent-color:var(--red)}
.login-row a{font-size:12px;color:var(--red);text-decoration:none;font-weight:500}
.login-submit{width:100%;padding:11px;background:var(--red);color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:700;font-family:'Inter',sans-serif;cursor:pointer;transition:all .2s;letter-spacing:.02em}
.login-submit:hover{background:#aa2500;transform:translateY(-1px);box-shadow:0 4px 16px rgba(209,46,0,.22)}
.login-submit:active{transform:translateY(0)}
.login-divider{display:flex;align-items:center;gap:12px;margin:20px 0;color:var(--muted);font-size:11px}
.login-divider::before,.login-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.demo-login-btn{width:100%;padding:11px;border:1.5px solid var(--border);border-radius:8px;background:var(--white);font-size:13px;font-weight:600;color:var(--ink2);cursor:pointer;transition:all .2s;font-family:'Inter',sans-serif;display:flex;align-items:center;justify-content:center;gap:8px}
.demo-login-btn:hover{border-color:var(--red);color:var(--red);background:var(--red-s)}
.login-footer{text-align:center;margin-top:22px;font-size:12px;color:var(--muted)}
.login-footer a{color:var(--red);text-decoration:none;font-weight:600}

/* AGENT TAB BAR */
.agent-tab-bar{display:flex;align-items:center;gap:0;padding:0 24px;background:var(--white);border-bottom:1px solid var(--border);flex-shrink:0}
.atab{padding:9px 16px;font-size:11.5px;font-weight:600;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;transition:all .2s;font-family:'Inter',sans-serif;background:none;border-top:none;border-left:none;border-right:none}
.atab:hover{color:var(--ink2)}
.atab.on{color:var(--red);border-bottom:2px solid var(--red)}
.atab .new-pill{font-size:8px;font-weight:800;background:var(--red);color:#fff;padding:1px 5px;border-radius:3px;text-transform:uppercase;margin-left:6px;letter-spacing:.3px}

/* Agent chat UI */
.agent-panel{display:none;flex:1;overflow:hidden}
.agent-panel.on{display:flex}
.agent-sidebar{width:240px;background:var(--white);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:18px 14px}
.agent-hist-title{font-size:9px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--muted);font-family:'JetBrains Mono',monospace;margin-bottom:12px}
.agent-hist-item{padding:9px 10px;border-radius:7px;margin-bottom:3px;cursor:pointer;transition:all .15s;border:none;background:transparent;width:100%;text-align:left}
.agent-hist-item:hover{background:var(--bg)}
.agent-hist-item.active{background:var(--red-s)}
.ah-name{font-size:12px;font-weight:600;color:var(--ink);margin-bottom:2px}
.ah-time{font-size:9.5px;color:var(--muted);font-family:'JetBrains Mono',monospace}
.agent-new-btn{margin-top:auto;padding:9px;border:1px dashed var(--muted2);border-radius:7px;background:transparent;font-size:12px;font-weight:500;color:var(--muted);cursor:pointer;transition:all .15s;font-family:'Inter',sans-serif}
.agent-new-btn:hover{background:var(--bg);border-color:var(--red);color:var(--red)}
.conv-menu{position:absolute;right:6px;top:100%;background:var(--white);border:1px solid var(--border);border-radius:8px;box-shadow:0 6px 20px rgba(0,0,0,.1);z-index:20;min-width:140px;padding:4px;animation:up .12s ease}
.conv-menu button{display:flex;align-items:center;gap:7px;width:100%;padding:7px 11px;border:none;background:none;font-size:12px;font-weight:500;color:var(--ink2);cursor:pointer;border-radius:5px;font-family:'Inter',sans-serif;transition:background .12s,color .12s;text-align:left}
.conv-menu button:hover{background:var(--bg);color:var(--ink)}
.agent-chat-main{flex:1;display:flex;flex-direction:column}
.agent-messages{flex:1;overflow-y:auto;padding:28px;display:flex;flex-direction:column;gap:18px}
.msg-row{display:flex;gap:10px;max-width:680px}
.msg-row.agent{align-self:flex-start}
.msg-row.user{align-self:flex-end;flex-direction:row-reverse}
.msg-ava{width:30px;height:30px;border-radius:7px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:12px}
.msg-row.agent .msg-ava{background:linear-gradient(135deg,var(--red),var(--orange));color:#fff}
.msg-row.user .msg-ava{background:var(--navy);color:#fff;font-size:10px;font-weight:700;font-family:'JetBrains Mono',monospace}
.msg-bub{padding:12px 16px;border-radius:10px;font-size:13px;line-height:1.6;color:var(--ink);white-space:pre-wrap}
.msg-row.agent .msg-bub{background:var(--white);border:1px solid var(--border);border-top-left-radius:3px}
.msg-row.user .msg-bub{background:var(--navy);color:#fff;border-top-right-radius:3px}
.msg-tag{display:inline-block;font-size:9px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;padding:2px 7px;border-radius:3px;margin-bottom:7px;font-family:'JetBrains Mono',monospace}
.msg-tag.step{background:var(--red-s);color:var(--red);border:1px solid var(--red-b)}
.msg-tag.found{background:var(--green-s);color:var(--green);border:1px solid rgba(11,158,114,.2)}
.msg-sources{margin-top:8px;display:flex;flex-wrap:wrap;gap:5px}
.msg-src{font-size:9px;font-weight:500;padding:2px 7px;background:var(--bg);border:1px solid var(--border);border-radius:3px;color:var(--ink2);font-family:'JetBrains Mono',monospace}
.typing-dots{display:flex;gap:4px;padding:6px 0}
.typing-dots span{width:5px;height:5px;border-radius:50%;background:var(--muted);animation:typedot 1.4s infinite}
.typing-dots span:nth-child(2){animation-delay:.2s}
.typing-dots span:nth-child(3){animation-delay:.4s}
@keyframes typedot{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}
.agent-input-bar{padding:14px 28px 20px;border-top:1px solid var(--border);background:var(--white)}
.agent-input-wrap{display:flex;align-items:center;gap:8px;background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:5px 5px 5px 14px;transition:border-color .2s}
.agent-input-wrap:focus-within{border-color:var(--red)}
.agent-input{flex:1;border:none;background:transparent;font-size:13px;color:var(--ink);outline:none;font-family:'Inter',sans-serif;padding:7px 0}
.agent-input::placeholder{color:var(--muted2)}
.agent-send{width:34px;height:34px;border-radius:8px;background:var(--red);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;transition:all .15s}
.agent-send:hover{background:#aa2500}
.agent-hint{font-size:10px;color:var(--muted);margin-top:6px;text-align:center}

/* Agent markdown formatting */
.msg-bub h1,.msg-bub h2,.msg-bub h3{font-family:'Outfit',sans-serif;color:var(--ink);margin:10px 0 6px;line-height:1.3}
.msg-bub h1{font-size:16px;font-weight:800}.msg-bub h2{font-size:14px;font-weight:700}.msg-bub h3{font-size:13px;font-weight:700}
.msg-bub p{margin:0 0 8px;line-height:1.65}.msg-bub p:last-child{margin-bottom:0}
.msg-bub ul,.msg-bub ol{margin:4px 0 10px 18px;display:flex;flex-direction:column;gap:3px}
.msg-bub li{font-size:12.5px;line-height:1.55;color:var(--ink2)}
.msg-bub strong{font-weight:700;color:var(--ink)}
.msg-bub em{font-style:italic;color:var(--ink2)}
.msg-bub code{font-family:'JetBrains Mono',monospace;font-size:11px;background:var(--bg);padding:1px 5px;border-radius:3px;border:1px solid var(--border);color:var(--red)}
.msg-bub pre{background:var(--bg);border:1px solid var(--border);border-radius:7px;padding:10px 12px;margin:8px 0;overflow-x:auto}
.msg-bub pre code{background:none;border:none;padding:0;font-size:11px;color:var(--ink)}
.msg-bub blockquote{border-left:3px solid var(--red);padding:4px 12px;margin:6px 0;color:var(--ink2);font-style:italic;background:var(--red-s);border-radius:0 5px 5px 0}
.msg-row.user .msg-bub strong{color:#fff}
.msg-row.user .msg-bub li{color:rgba(255,255,255,.8)}
.msg-row.user .msg-bub code{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.2);color:#fff}

/* Made with Emergent - minimal */
#emergent-badge{opacity:0.02 !important;transition:opacity .2s !important}
#emergent-badge:hover{opacity:0.02 !important}

/* Tableau panel */
.tableau-panel{display:none;flex:1;overflow-y:auto;padding:28px}
.tableau-panel.on{display:block}

/* Loading spinner */
.loading-overlay{position:fixed;inset:0;background:rgba(245,246,249,.85);display:flex;align-items:center;justify-content:center;z-index:100}
.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--red);border-radius:50%;animation:spin .6s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
