/* ═══════════════════════════════════════════════════
   CASE PORTAL v3 — app.css (includes MFA auth styles)
   ═══════════════════════════════════════════════════ */

*{box-sizing:border-box;margin:0;padding:0;}
:root{
  --navy:#0f2340;--navy2:#1a3356;--navy3:#24446b;
  --gold:#c8a84b;--gold2:#e0bf72;--gold3:#f5e4b0;
  --bg:#f7f5f0;--card:#fff;--border:#e2ddd4;
  --text:#1a1a1a;--muted:#6b6560;--light:#f0ece4;
  --blue:#1a5fa8;--blue-l:#e8f1fb;
  --red:#a83220;--red-l:#faeae8;
  --green:#2a6b3a;--green-l:#e8f4ec;
  --amber:#8a5c10;--amber-l:#fef3e2;
  --purple:#4a2d8a;--purple-l:#eeebfd;
  --teal:#0f6e6e;--teal-l:#e0f4f4;
  --pink:#8a2d5a;--pink-l:#fdeef5;
  --gray:#4a4a4a;--gray-l:#f0f0ee;
  --r:8px;--rl:12px;
}
html,body{height:100%;font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;}

/* ─── ALL AUTH SCREENS ──────────────────────────────── */
#login-screen,
#mfa-verify-screen,
#mfa-enroll-screen{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:var(--navy);padding:20px;
}
.login-card{
  background:var(--card);border-radius:16px;padding:36px;width:100%;max-width:400px;
  border:1px solid var(--border);text-align:center;
  box-shadow:0 8px 40px rgba(0,0,0,.25);
}
.login-seal{
  width:64px;height:64px;border-radius:50%;background:var(--navy);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 20px;font-size:28px;color:var(--gold2);
}
.login-title{font-family:'Lora',serif;font-size:20px;font-weight:600;color:var(--navy);margin-bottom:4px;}
.login-case{font-size:13px;font-weight:600;color:var(--gold);letter-spacing:.04em;margin-bottom:4px;}
.login-court{font-size:11px;color:var(--muted);margin-bottom:24px;line-height:1.5;}
.login-lbl{display:block;font-size:10px;font-weight:600;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;margin-bottom:5px;text-align:left;}
.login-input{
  width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--r);
  font-family:'DM Sans',sans-serif;font-size:14px;color:var(--text);margin-bottom:12px;
  transition:border .12s;background:var(--card);
}
.login-input:focus{outline:none;border-color:#85a8d4;box-shadow:0 0 0 3px rgba(26,95,168,.1);}

/* Password field with show/hide toggle */
.pass-wrap{position:relative;margin-bottom:12px;}
.pass-wrap .login-input{margin-bottom:0;padding-right:40px;}
.pass-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--muted);font-size:16px;padding:4px;}
.pass-toggle:hover{color:var(--navy);}

.login-error{font-size:12px;color:var(--red);min-height:18px;margin-bottom:10px;text-align:left;line-height:1.4;}
.login-btn{
  width:100%;padding:11px;background:var(--navy);color:var(--gold2);border:none;
  border-radius:var(--r);font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;
  cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;
  transition:background .12s;margin-bottom:8px;
}
.login-btn:hover{background:var(--navy2);}
.login-btn:disabled{opacity:.6;cursor:default;}
.login-btn-ghost{
  width:100%;padding:9px;background:transparent;color:var(--muted);
  border:1px solid var(--border);border-radius:var(--r);
  font-family:'DM Sans',sans-serif;font-size:12.5px;font-weight:500;
  cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;
  transition:all .12s;margin-top:4px;
}
.login-btn-ghost:hover{background:var(--light);color:var(--text);}
.login-note{font-size:11px;color:var(--muted);margin-top:20px;line-height:1.6;}
.mfa-sent-to{font-size:12px;color:var(--muted);background:var(--light);border-radius:var(--r);padding:8px 10px;margin-bottom:12px;text-align:left;}

/* MFA security badge on top bar */
.user-pill{display:flex;align-items:center;gap:5px;padding:4px 10px;background:rgba(255,255,255,.1);border-radius:20px;font-size:11px;color:rgba(255,255,255,.7);border:1px solid rgba(255,255,255,.15);}

/* ─── APP SHELL ─────────────────────────────────────── */
#app{height:100vh;display:flex;flex-direction:column;}
.shell{display:grid;grid-template-rows:52px 1fr;height:100vh;overflow:hidden;}
.topbar{background:var(--navy);display:flex;align-items:center;gap:10px;padding:0 16px;flex-shrink:0;flex-wrap:wrap;}
.case-badge{font-family:'Lora',serif;color:var(--gold2);font-size:13px;font-weight:600;letter-spacing:.02em;}
.court{color:rgba(255,255,255,.42);font-size:11px;border-left:1px solid rgba(255,255,255,.15);padding-left:12px;}
.sp{flex:1;}
.tbtn{color:rgba(255,255,255,.6);background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:6px;padding:5px 10px;font-size:12px;cursor:pointer;display:flex;align-items:center;gap:5px;font-family:'DM Sans',sans-serif;transition:all .12s;}
.tbtn:hover{background:rgba(255,255,255,.15);}
.body{display:grid;grid-template-columns:210px 1fr;overflow:hidden;}

/* ─── SIDEBAR ───────────────────────────────────────── */
.sb{background:var(--card);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;}
.sb-inner{flex:1;overflow-y:auto;}
.sb-sec{padding:10px 0;}
.sb-sec+.sb-sec{border-top:1px solid var(--border);}
.sb-lbl{font-size:9.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);padding:0 14px 5px;}
.si{display:flex;align-items:center;gap:8px;padding:7px 14px;cursor:pointer;border-left:2.5px solid transparent;color:var(--muted);font-size:12.5px;transition:all .12s;}
.si:hover{background:var(--light);color:var(--text);}
.si.on{border-left-color:var(--gold);background:var(--light);color:var(--navy);font-weight:500;}
.si i{font-size:15px;flex-shrink:0;}
.sct{margin-left:auto;font-size:10px;background:var(--light);color:var(--muted);padding:1px 6px;border-radius:10px;font-weight:600;}
.si.on .sct{background:var(--gold3);color:var(--amber);}
.add-ev-btn{margin:12px;padding:11px 0;background-color:#c8a84b;color:#0f2340;border-radius:var(--r);font-size:13px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;border:none;font-family:'DM Sans',sans-serif;user-select:none;transition:background .12s;}
.add-ev-btn:hover{background-color:#b8942e;}
.add-ev-btn i,.add-ev-btn span{color:#0f2340;}
.sb-docket{border-top:1px solid var(--border);padding:10px 12px;}
.docket-btn{display:flex;align-items:center;gap:8px;padding:9px 10px;background:#f0f7ff;border:1px solid #c0d4f0;border-radius:var(--r);cursor:pointer;text-decoration:none;transition:all .12s;}
.docket-btn:hover{background:#dceeff;border-color:#85b7eb;}
.docket-icon{width:28px;height:28px;border-radius:6px;background:var(--navy);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.docket-icon i{font-size:14px;color:var(--gold2);}
.docket-text{flex:1;}
.docket-title{font-size:12px;font-weight:600;color:var(--navy);}
.docket-sub{font-size:10px;color:var(--muted);}
.docket-ext{font-size:13px;color:var(--blue);flex-shrink:0;}
.docket-hint{font-size:10px;color:var(--muted);margin-top:6px;line-height:1.5;padding:0 2px;}
.docket-hint strong{color:var(--navy);}

/* ─── MAIN ──────────────────────────────────────────── */
.main{display:flex;flex-direction:column;overflow:hidden;background:var(--bg);}
.toolbar{display:flex;align-items:center;gap:10px;padding:10px 16px;border-bottom:1px solid var(--border);background:var(--card);flex-shrink:0;flex-wrap:wrap;min-height:52px;}
.toolbar h2{font-family:'Lora',serif;font-size:15px;font-weight:600;color:var(--navy);flex:1;min-width:120px;}
.chips{display:flex;gap:6px;flex-wrap:wrap;}
.chip{font-size:11px;padding:4px 11px;border-radius:20px;border:1px solid var(--border);cursor:pointer;color:var(--muted);background:var(--card);font-family:'DM Sans',sans-serif;transition:all .12s;display:flex;align-items:center;gap:5px;}
.chip:hover{border-color:#aaa;}
.chip.on{background:var(--navy);color:var(--gold2);border-color:var(--navy);font-weight:500;}
.chip.on.f-custody{background:var(--blue);border-color:var(--blue);color:#fff;}
.chip.on.f-financial{background:var(--amber);border-color:var(--amber);color:#fff;}
.chip.on.f-conduct{background:var(--red);border-color:var(--red);color:#fff;}
.chip-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;}
.chip-dot.c{background:var(--blue);}
.chip-dot.f{background:var(--amber);}
.chip-dot.co{background:var(--red);}
.chip.on .chip-dot{background:#fff;}
.chip-count{font-size:10px;opacity:.75;}
.vbtns{display:flex;border:1px solid var(--border);border-radius:6px;overflow:hidden;}
.vb{padding:5px 9px;cursor:pointer;color:var(--muted);background:var(--card);border:none;font-size:14px;transition:all .12s;}
.vb.on{background:var(--light);color:var(--navy);}
.panel{display:flex;flex:1;overflow:hidden;}
.ev-list,.tl-list{flex:1;overflow-y:auto;padding:12px 16px;}
.empty-state{padding:48px 24px;text-align:center;color:var(--muted);}
.empty-state i{font-size:32px;display:block;margin-bottom:10px;opacity:.3;}
.empty-state p{font-size:13px;line-height:1.6;}
.mh{font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin:16px 0 8px;padding-bottom:4px;border-bottom:1px solid var(--border);}
.mh:first-child{margin-top:0;}
.ec{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--r);margin-bottom:6px;cursor:pointer;background:var(--card);transition:all .12s;}
.ec:hover{border-color:#bbb;box-shadow:0 1px 6px rgba(0,0,0,.06);}
.ec.sel{border-color:var(--navy3);box-shadow:0 0 0 1px var(--navy3);background:#f8fafd;}
.ei{width:34px;height:34px;border-radius:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:15px;}
.i-doc{background:var(--blue-l);color:var(--blue);}
.i-vid{background:var(--red-l);color:var(--red);}
.i-img{background:var(--green-l);color:var(--green);}
.i-msg{background:var(--amber-l);color:var(--amber);}
.i-voice{background:var(--purple-l);color:var(--purple);}
.i-police{background:var(--teal-l);color:var(--teal);}
.i-witness{background:var(--pink-l);color:var(--pink);}
.i-other{background:var(--gray-l);color:var(--gray);}
.eb{flex:1;min-width:0;}
.et{font-size:12.5px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.es{font-size:11px;color:var(--muted);margin-top:1px;}
.tag{display:inline-block;font-size:9.5px;font-weight:600;padding:1px 6px;border-radius:4px;margin-left:5px;letter-spacing:.03em;vertical-align:1px;}
.tc{background:var(--blue-l);color:var(--blue);}
.tf{background:var(--amber-l);color:var(--amber);}
.tco{background:var(--red-l);color:var(--red);}
.ed{font-size:10.5px;color:var(--muted);flex-shrink:0;}
.tli{display:flex;gap:12px;}
.tls{display:flex;flex-direction:column;align-items:center;width:20px;flex-shrink:0;}
.tld{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:4px;border:2px solid var(--card);}
.tld.doc{background:var(--blue);box-shadow:0 0 0 1px var(--blue);}
.tld.vid{background:var(--red);box-shadow:0 0 0 1px var(--red);}
.tld.img{background:var(--green);box-shadow:0 0 0 1px var(--green);}
.tld.msg{background:var(--amber);box-shadow:0 0 0 1px var(--amber);}
.tld.voice{background:var(--purple);box-shadow:0 0 0 1px var(--purple);}
.tld.police{background:var(--teal);box-shadow:0 0 0 1px var(--teal);}
.tld.witness{background:var(--pink);box-shadow:0 0 0 1px var(--pink);}
.tld.other{background:var(--gray);box-shadow:0 0 0 1px var(--gray);}
.tlln{flex:1;width:1.5px;background:var(--border);margin:3px 0;}
.tlc{flex:1;padding-bottom:14px;}
.tlt{font-size:10px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px;}
.tlk{border:1px solid var(--border);border-radius:var(--r);padding:9px 11px;background:var(--card);cursor:pointer;transition:all .12s;}
.tlk:hover{border-color:#bbb;}
.tlk.sel{border-color:var(--navy3);background:#f8fafd;}
.tlkt{font-size:12px;font-weight:500;}
.tlks{font-size:11px;color:var(--muted);margin-top:2px;}

/* Incident timeline */
.inc-view{flex:1;overflow-y:auto;padding:16px 20px;}
.itl-wrap{max-width:700px;margin:0 auto;}
.filter-bar{display:flex;align-items:center;gap:8px;margin-bottom:14px;padding:8px 12px;background:var(--card);border:1px solid var(--border);border-radius:var(--r);flex-wrap:wrap;}
.filter-bar-lbl{font-size:11px;color:var(--muted);font-weight:500;}
.filter-bar-val{font-size:11.5px;font-weight:600;color:var(--navy);}
.filter-bar-count{font-size:11px;color:var(--muted);margin-left:auto;}
.filter-bar-clear{font-size:11px;color:var(--muted);background:none;border:none;cursor:pointer;text-decoration:underline;font-family:'DM Sans',sans-serif;}
.itl-add-btn{display:flex;align-items:center;gap:8px;padding:9px 14px;background:var(--navy);color:var(--gold2);border:none;border-radius:var(--r);font-size:12.5px;font-weight:600;cursor:pointer;font-family:'DM Sans',sans-serif;margin-bottom:16px;transition:background .12s;}
.itl-add-btn:hover{background:var(--navy2);}
.itl-empty{text-align:center;padding:48px 24px;color:var(--muted);}
.itl-empty i{font-size:36px;display:block;margin-bottom:10px;opacity:.25;}
.itl-empty p{font-size:13px;line-height:1.7;}
.incident{display:flex;gap:0;margin-bottom:0;}
.inc-spine{display:flex;flex-direction:column;align-items:center;width:40px;flex-shrink:0;padding-top:6px;}
.inc-dot{width:14px;height:14px;border-radius:50%;flex-shrink:0;border:3px solid var(--bg);z-index:1;}
.inc-dot.issue-Custody{background:var(--blue);box-shadow:0 0 0 2px var(--blue);}
.inc-dot.issue-Financial{background:var(--amber);box-shadow:0 0 0 2px var(--amber);}
.inc-dot.issue-Conduct{background:var(--red);box-shadow:0 0 0 2px var(--red);}
.inc-line{flex:1;width:2px;background:var(--border);margin:5px 0;}
.inc-body{flex:1;padding-bottom:18px;}
.inc-card{background:var(--card);border:1px solid var(--border);border-radius:var(--rl);overflow:hidden;transition:all .15s;}
.inc-card:hover{box-shadow:0 2px 12px rgba(0,0,0,.08);}
.inc-card.open{box-shadow:0 2px 16px rgba(0,0,0,.1);}
.inc-card.issue-Custody{border-left:3px solid var(--blue);}
.inc-card.issue-Financial{border-left:3px solid var(--amber);}
.inc-card.issue-Conduct{border-left:3px solid var(--red);}
.inc-header{padding:12px 14px;cursor:pointer;display:flex;align-items:flex-start;gap:10px;}
.inc-date-col{flex-shrink:0;text-align:center;width:44px;}
.inc-day{font-family:'Lora',serif;font-size:22px;font-weight:600;color:var(--navy);line-height:1;}
.inc-month{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-top:2px;}
.inc-year{font-size:9px;color:var(--muted);}
.inc-meta{flex:1;min-width:0;}
.inc-title{font-size:13.5px;font-weight:600;color:var(--navy);line-height:1.3;margin-bottom:4px;}
.inc-summary{font-size:12px;color:var(--muted);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.inc-footer{display:flex;align-items:center;gap:8px;margin-top:6px;}
.inc-badge{font-size:10px;font-weight:600;padding:2px 8px;border-radius:10px;}
.inc-ev-count{font-size:10.5px;color:var(--muted);display:flex;align-items:center;gap:3px;}
.inc-chevron{margin-left:auto;color:var(--muted);font-size:16px;flex-shrink:0;transition:transform .2s;}
.inc-card.open .inc-chevron{transform:rotate(180deg);}
.inc-expand{display:none;border-top:1px solid var(--border);}
.inc-card.open .inc-expand{display:block;}
.inc-full-desc{padding:12px 14px;font-size:12.5px;color:var(--text);line-height:1.7;background:#fafaf8;border-bottom:1px solid var(--border);}
.inc-full-desc-lbl{font-size:10px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:5px;}
.inc-ev-section{padding:12px 14px;}
.inc-ev-lbl{font-size:10px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;display:flex;align-items:center;justify-content:space-between;}
.inc-ev-add{font-size:11px;color:var(--blue);cursor:pointer;font-weight:500;background:none;border:none;font-family:'DM Sans',sans-serif;}
.inc-ev-add:hover{text-decoration:underline;}
.inc-ev-item{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--light);border-radius:var(--r);border:1px solid var(--border);margin-bottom:6px;}
.inc-ev-thumb{width:28px;height:28px;border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;}
.inc-ev-name{flex:1;font-size:12px;font-weight:500;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.inc-ev-type{font-size:10px;color:var(--muted);}
.inc-ev-open{color:var(--blue);font-size:15px;cursor:pointer;flex-shrink:0;text-decoration:none;transition:color .12s;}
.inc-ev-open:hover{color:var(--navy);}
.inc-no-ev{font-size:12px;color:var(--muted);text-align:center;padding:14px;background:var(--light);border-radius:var(--r);border:1px dashed var(--border);}
.inc-actions{display:flex;gap:8px;margin-top:10px;}
.inc-act-btn{padding:5px 10px;border-radius:6px;font-size:11px;font-weight:500;cursor:pointer;border:1px solid var(--border);background:var(--card);color:var(--muted);font-family:'DM Sans',sans-serif;display:flex;align-items:center;gap:4px;transition:all .12s;}
.inc-act-btn:hover{background:var(--light);}
.inc-act-btn.del{color:var(--red);border-color:#f0c0b8;}
.inc-act-btn.del:hover{background:var(--red-l);}

/* Preview pane */
.pv{width:255px;flex-shrink:0;border-left:1px solid var(--border);display:flex;flex-direction:column;background:var(--card);overflow-y:auto;}
.pvh{padding:13px;border-bottom:1px solid var(--border);}
.pvh h3{font-family:'Lora',serif;font-size:13px;font-weight:600;color:var(--navy);line-height:1.4;}
.pvh p{font-size:11px;color:var(--muted);margin-top:3px;}
.pvt{margin:12px;height:96px;border-radius:var(--r);border:1px solid var(--border);background:var(--light);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;color:var(--muted);font-size:11px;}
.pvt i{font-size:26px;}
.pvex{margin:0 12px 10px;display:flex;align-items:center;gap:6px;padding:7px 10px;background:var(--navy);border-radius:var(--r);color:var(--gold2);font-size:11px;font-weight:600;letter-spacing:.04em;}
.mr{display:flex;justify-content:space-between;align-items:center;padding:5px 0;border-bottom:1px solid var(--border);font-size:11.5px;}
.mr:last-child{border-bottom:none;}
.mk{color:var(--muted);}
.mv{font-weight:500;color:var(--text);}
.mg{margin:0 12px 10px;}
.pvdesc{margin:0 12px 12px;padding:8px 10px;background:var(--light);border-radius:var(--r);font-size:11.5px;color:var(--text);line-height:1.5;border:1px solid var(--border);}
.pvdesc-lbl{font-size:10px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px;}
.drbtn{display:flex;align-items:center;justify-content:center;gap:6px;margin:6px 12px 8px;padding:8px;background:#e8f0fe;color:#1a73e8;border:1px solid #c0d4f0;border-radius:var(--r);font-size:12px;font-weight:500;cursor:pointer;text-decoration:none;transition:all .12s;}
.drbtn:hover{background:#d0e4fa;}
.del-btn{display:flex;align-items:center;justify-content:center;gap:5px;margin:0 12px 14px;padding:7px;background:var(--red-l);color:var(--red);border:1px solid #f0c0b8;border-radius:var(--r);font-size:12px;font-weight:500;cursor:pointer;width:calc(100% - 24px);font-family:'DM Sans',sans-serif;transition:all .12s;}
.del-btn:hover{background:#f5d0c8;}
.nosel{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--muted);padding:24px;text-align:center;}
.nosel i{font-size:26px;opacity:.35;}
.nosel p{font-size:12px;line-height:1.6;}

/* Summary bar */
.sumbar{display:flex;gap:1px;background:var(--border);border-top:1px solid var(--border);overflow-x:auto;flex-shrink:0;}
.smi{flex:1;min-width:48px;background:var(--card);padding:7px 6px;text-align:center;}
.smn{font-size:14px;font-weight:600;color:var(--navy);font-family:'Lora',serif;}
.sml{font-size:9px;color:var(--muted);margin-top:1px;}

/* Modals */
.overlay{display:none;position:fixed;inset:0;background:rgba(15,35,64,.5);z-index:200;align-items:flex-start;justify-content:center;padding:32px 16px;overflow-y:auto;}
.overlay.on{display:flex;}
.modal{background:var(--card);border-radius:var(--rl);width:100%;max-width:560px;border:1px solid var(--border);margin:auto;}
.mhdr{background:var(--navy);padding:14px 18px;display:flex;align-items:center;gap:10px;border-radius:var(--rl) var(--rl) 0 0;}
.mhdr h2{font-family:'Lora',serif;color:var(--gold2);font-size:15px;font-weight:600;flex:1;margin:0;}
.mclose{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:6px;background:rgba(255,255,255,.15);border:1.5px solid rgba(255,255,255,.4);color:#fff;cursor:pointer;font-size:16px;transition:all .15s;}
.mclose:hover{background:#c0392b;border-color:#c0392b;}
.mbody{padding:18px;}
.fl{display:block;font-size:10px;font-weight:600;color:var(--muted);letter-spacing:.04em;text-transform:uppercase;margin-bottom:4px;}
.fi,.fta{width:100%;padding:7px 9px;border:1px solid var(--border);border-radius:var(--r);font-family:'DM Sans',sans-serif;font-size:12.5px;color:var(--text);background:var(--card);transition:border .12s;margin-bottom:12px;}
.fi:focus,.fta:focus{outline:none;border-color:#85a8d4;}
.fta{resize:vertical;min-height:60px;margin-bottom:0;}
.char-hint{font-size:10px;color:var(--muted);text-align:right;margin-top:2px;margin-bottom:12px;}
.req{color:var(--red);font-size:10px;margin-left:3px;}
.tagrow{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:14px;}
.tgb{padding:5px 12px;border-radius:20px;border:1px solid var(--border);font-size:12px;cursor:pointer;background:var(--card);color:var(--muted);font-family:'DM Sans',sans-serif;transition:all .12s;}
.tgb.on.cu{background:var(--blue-l);border-color:#85b7eb;color:var(--blue);font-weight:500;}
.tgb.on.fi2{background:var(--amber-l);border-color:#e0b060;color:var(--amber);font-weight:500;}
.tgb.on.co{background:var(--red-l);border-color:#e0a090;color:var(--red);font-weight:500;}
.btnrow{display:flex;gap:8px;justify-content:flex-end;margin-top:16px;}
.btn{padding:8px 16px;border-radius:var(--r);font-family:'DM Sans',sans-serif;font-size:12.5px;font-weight:500;cursor:pointer;border:1px solid var(--border);background:var(--card);color:var(--muted);transition:all .12s;}
.btn:hover{background:var(--light);}
.btn.pri{background:var(--navy);color:var(--gold2);border-color:var(--navy);display:flex;align-items:center;gap:5px;}
.btn.pri:hover{background:var(--navy2);}
.type-lbl{font-size:10px;font-weight:600;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;margin-bottom:8px;}
.type-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:16px;}
.type-card{border:1.5px solid var(--border);border-radius:var(--r);padding:10px 6px;text-align:center;cursor:pointer;transition:all .12s;background:var(--card);}
.type-card:hover{border-color:#aaa;background:var(--light);}
.type-card.sel.t-doc{border:2px solid var(--blue);background:var(--blue-l);}
.type-card.sel.t-vid{border:2px solid var(--red);background:var(--red-l);}
.type-card.sel.t-img{border:2px solid var(--green);background:var(--green-l);}
.type-card.sel.t-msg{border:2px solid var(--amber);background:var(--amber-l);}
.type-card.sel.t-voice{border:2px solid var(--purple);background:var(--purple-l);}
.type-card.sel.t-police{border:2px solid var(--teal);background:var(--teal-l);}
.type-card.sel.t-witness{border:2px solid var(--pink);background:var(--pink-l);}
.type-card.sel.t-other{border:2px solid var(--gray);background:var(--gray-l);}
.tc-icon{width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;margin:0 auto 6px;font-size:16px;}
.tc-lbl{font-size:10.5px;font-weight:600;color:var(--navy);line-height:1.3;}
.other-box{background:#f8f8f6;border:1.5px solid var(--border);border-radius:var(--r);padding:14px;margin-bottom:14px;display:none;}
.other-box.on{display:block;}
.other-box-head{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:600;color:var(--gray);margin-bottom:10px;text-transform:uppercase;letter-spacing:.05em;}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px;}
.upmethods{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:14px;}
.upm{border:1px solid var(--border);border-radius:var(--r);padding:12px 8px;text-align:center;cursor:pointer;transition:all .12s;background:var(--card);}
.upm:hover{border-color:#aaa;background:var(--light);}
.upm.gdrive:hover{background:#e8f0fe;border-color:#85b7eb;}
.upm-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;margin:0 auto 6px;font-size:18px;}
.upm h3{font-size:11.5px;font-weight:600;color:var(--navy);}
.upm p{font-size:10px;color:var(--muted);margin-top:2px;line-height:1.4;}
.dropz{border:2px dashed var(--border);border-radius:var(--r);padding:20px;text-align:center;cursor:pointer;transition:all .15s;margin-bottom:14px;}
.dropz.over{border-color:#1a73e8;background:#e8f0fe;}
.dropz i{font-size:26px;color:var(--muted);display:block;margin-bottom:5px;}
.dropz h3{font-size:13px;font-weight:500;margin-bottom:2px;}
.dropz p{font-size:11px;color:var(--muted);}
.browse{color:#1a73e8;font-weight:500;text-decoration:underline;}
.sfrow{display:flex;align-items:center;gap:9px;padding:8px 10px;background:var(--light);border-radius:var(--r);margin-bottom:8px;border:1px solid var(--border);}
.sfthumb{width:30px;height:30px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;}
.sfname{flex:1;font-size:12px;font-weight:500;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sfsize{font-size:11px;color:var(--muted);}
.sfrm{color:var(--muted);cursor:pointer;font-size:15px;background:none;border:none;padding:2px;}
.sfrm:hover{color:var(--red);}
.ai-box{background:#f0f4ff;border:1px solid #c0d4f0;border-radius:var(--r);padding:12px 14px;margin-bottom:14px;display:none;}
.ai-box.on{display:block;}
.ai-row{display:flex;align-items:center;gap:8px;margin-bottom:8px;}
.ai-dot{width:8px;height:8px;border-radius:50%;background:#1a73e8;animation:pulse 1.2s infinite;flex-shrink:0;}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:.3;}}
.ai-lbl{font-size:11px;color:#1a73e8;font-weight:600;}
.ai-edit-btn{font-size:11px;color:var(--muted);cursor:pointer;margin-left:auto;text-decoration:underline;background:none;border:none;font-family:'DM Sans',sans-serif;}
.ai-name-display{font-size:13px;font-weight:500;color:var(--navy);margin-bottom:4px;}
.ev-picker-list{max-height:200px;overflow-y:auto;border:1px solid var(--border);border-radius:var(--r);margin-bottom:12px;}
.ev-pick-item{display:flex;align-items:center;gap:8px;padding:8px 10px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .1s;}
.ev-pick-item:last-child{border-bottom:none;}
.ev-pick-item:hover{background:var(--light);}
.ev-pick-item.sel{background:var(--blue-l);}
.ev-pick-check{width:16px;height:16px;border-radius:4px;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:11px;}
.ev-pick-item.sel .ev-pick-check{background:var(--blue);border-color:var(--blue);color:#fff;}
.ev-pick-name{font-size:12px;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.ev-pick-meta{font-size:10.5px;color:var(--muted);}
.spinner{display:inline-block;width:13px;height:13px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
.toast{position:fixed;bottom:20px;right:20px;background:var(--navy);color:#fff;padding:10px 16px;border-radius:var(--r);font-size:12.5px;display:flex;align-items:center;gap:8px;transform:translateY(80px);transition:transform .3s;z-index:999;box-shadow:0 4px 16px rgba(0,0,0,.2);}
.toast.on{transform:translateY(0);}
.toast i{color:var(--gold2);}
input[type=file]{display:none;}

/* Helper: show/hide password */
.pass-wrap .login-input{padding-right:44px;}

@media(max-width:640px){
  .body{grid-template-columns:1fr;}
  .sb{display:none;}
  .pv{display:none;}
  .type-grid{grid-template-columns:repeat(2,1fr);}
  .upmethods{grid-template-columns:1fr 1fr;}
  .fgrid{grid-column:1fr;}
  .court{display:none;}
  .inc-view{padding:12px;}
}
