
:root {
  --ink:    #1c1a17;
  --ink2:   #3a3630;
  --muted:  #8a8070;
  --paper:  #faf8f3;
  --bg:     #f4f1eb;
  --faint:  #ede9e0;
  --faint2: #e8e4da;
  --line:   #ddd9ce;
  --green:  #2d6a4f;
  --green-l:#d4ede0;
  --amber:  #8a6a20;
  --amber-bg:#fdf4e3;
  --red:    #a03030;
  --red-line:#d08080;
  --red-bg: #fdf0f0;
  --urg:    #c0392b;
  --r: 14px;
  --shadow-sm: 0 1px 4px rgba(0,0,0,.06);
  --shadow-md: 0 4px 16px rgba(0,0,0,.1);
  --shadow-lg: 0 8px 32px rgba(0,0,0,.14);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Jost',sans-serif;background:var(--bg);color:var(--ink);min-height:100vh;position:relative}
body::before{content:'';position:fixed;inset:0;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='.03'/%3E%3C/svg%3E");pointer-events:none;z-index:0;}

/* ── TOPBAR ──────────────────────────────────────────────── */
.topbar {
  background: #0f0e0c;
  position: sticky; top: 0; z-index: 100;
  border-bottom: 1px solid #2a2520;
}
.topbar-main {
  padding: .9rem 1.25rem .75rem;
  display: flex; align-items: center;
  justify-content: space-between; gap: .75rem;
}
.firm-name {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.45rem; font-weight: 600;
  color: #f0ece4; line-height: 1.1; letter-spacing: .015em;
}
.firm-name .ampersand { color: #c8b878; font-style: italic; }
.firm-sub { font-size: .62rem; letter-spacing: .16em; text-transform: uppercase; margin-top: .2rem; font-family: 'Jost', sans-serif; font-weight: 500; }
.firm-sub .docket-tag { color: #c8b878; animation: goldglow 4s ease-in-out infinite; }
@keyframes goldglow { 0%,100%{opacity:.8} 50%{opacity:1;text-shadow:0 0 8px rgba(200,184,120,.6)} }
.topbar-right { display: flex; flex-direction: column; align-items: flex-end; gap: .1rem; flex-shrink: 0; }
.topbar-day { font-family: 'Jost', sans-serif; font-size: .75rem; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: #c8b878; animation: goldglow 4s ease-in-out infinite; }
.topbar-date { font-family: 'Jost', sans-serif; font-size: .65rem; color: #4a4840; letter-spacing: .04em; margin-top: .12rem; }
.topbar-gold-rule { height: 1px; background: linear-gradient(90deg,transparent 0%,#3a3428 20%,#c8b878 50%,#3a3428 80%,transparent 100%); background-size: 200% 100%; animation: rulesweep 5s ease-in-out infinite; opacity: .7; }
@keyframes rulesweep { 0%{background-position:200% center} 100%{background-position:-200% center} }
.top-save { display:none; background:transparent; border:1px solid rgba(168,204,184,.3); color:#6aaa88; padding:.18rem .6rem; border-radius:20px; font-size:.65rem; font-family:'Jost',sans-serif; cursor:pointer; margin-top:.25rem; }
.top-save.pending,.top-save.saving { display:inline-block; }
@media(max-width:480px){ .topbar-main{padding:.75rem 1rem .65rem} .firm-name{font-size:1.22rem} }

/* ── TABS NAV ────────────────────────────────────────────── */
.tabs-nav {
  background: var(--paper);
  border-bottom: 1px solid var(--line);
  padding: .6rem 1rem;
  position: sticky;
  top: 62px;
  left: 0; right: 0;
  z-index: 90;
  display: flex; gap: .35rem;
  overflow-x: auto; scrollbar-width: none;
  transition: transform .3s ease, opacity .3s ease;
  will-change: transform;
}
.tabs-nav.hidden {
  transform: translateY(-200%);
  opacity: 0;
  pointer-events: none;
}
.tabs-nav::-webkit-scrollbar { display: none; }
.tab-btn {
  flex-shrink: 0; height: 36px;
  padding: 0 1.1rem;
  border-radius: 20px;
  font-size: .78rem; font-weight: 500;
  font-family: 'Jost', sans-serif;
  letter-spacing: .03em;
  cursor: pointer; transition: all .18s;
  border: 1.5px solid var(--line);
  background: transparent; color: var(--muted);
  white-space: nowrap;
}
.tab-btn:hover { border-color: var(--ink2); color: var(--ink); }
.tab-btn.active { background: var(--ink); border-color: var(--ink); color: #f0ece4; font-weight: 600; }

/* ── DATE NAV ────────────────────────────────────────────── */

.date-nav-btn:hover { border-color: var(--ink2); color: var(--ink); }
.date-nav-btn:disabled { opacity: .35; cursor: default; }
.date-nav-label {
  font-size: .8rem; font-weight: 600;
  font-family: 'Jost', sans-serif;
  color: var(--ink); letter-spacing: .02em;
  text-align: center;
}
.date-nav-sub { font-size: .65rem; color: var(--muted); font-weight: 400; }
.date-nav-readonly { font-size: .62rem; color: var(--red); font-weight: 600; letter-spacing: .06em; text-transform: uppercase; margin-top: .15rem; }

/* ── PAGE WRAP ───────────────────────────────────────────── */
.page { max-width: 780px; margin: 0 auto; padding: 1.25rem 1rem 0; position: relative; z-index: 1;
}
.tab-content { display: none; }
.tab-content.active { display: block; }

/* ── SYNC BAR ────────────────────────────────────────────── */
.sync-bar { display:flex; align-items:center; gap:.4rem; font-size:.72rem; color:var(--muted); padding:.3rem 0; margin-bottom:.3rem; opacity:0; transition:opacity .3s; }
.sync-bar.on { opacity:1; }
.sync-bar.err { color:var(--red); }
.sync-bar.ok { color:var(--green); }
.sdot { width:6px; height:6px; border-radius:50%; background:currentColor; }
.sync-bar.loading .sdot { animation:sdotpulse 1s ease-in-out infinite; }
@keyframes sdotpulse{0%,100%{opacity:.3}50%{opacity:1}}

/* ── DATE MISMATCH BANNER ────────────────────────────────── */
#dateMismatchBanner { display:none; background:#fdf4e3; border:1.5px solid #e8c870; border-radius:10px; padding:.7rem 1rem; margin-bottom:1rem; font-size:.82rem; color:#7a4f10; line-height:1.5; position:relative; }

/* ── HERO ────────────────────────────────────────────────── */
.hero { margin-bottom: 1.25rem; }
.hero-head { display:flex; align-items:baseline; justify-content:space-between; gap:1rem; margin-bottom:.85rem; flex-wrap:wrap; }
.docket-eyebrow { font-family:'Cormorant Garamond',serif; font-size:2.2rem; font-weight:500; color:var(--ink); line-height:1.1; }
.docket-eyebrow em { font-style:italic; color:var(--muted); font-size:1.4rem; margin-left:.3rem; }
#docketDateBadge { font-size:.78rem; color:var(--muted); font-weight:400; white-space:nowrap; }
.hero-stats { display:flex; gap:.6rem; flex-wrap:wrap; margin-bottom:.75rem; }
.dstat { flex:1; min-width:70px; background:var(--paper); border:1px solid var(--line); border-radius:10px; padding:.6rem .5rem; text-align:center; border-top:2.5px solid; box-shadow:var(--shadow-sm); }
.dstat.pend { border-top-color:#b8860b; }
.dstat.att  { border-top-color:#2c5f8a; }
.dstat.args { border-top-color:#6a3d8f; }
.dstat.comp { border-top-color:var(--green); }
.dstat.urg  { border-top-color:var(--urg); }
.dstat-n { display:block; font-family:'Cormorant Garamond',serif; font-size:2rem; font-weight:600; line-height:1; }
.dstat-n.a  { color:#b8860b; }
.dstat-n.bl { color:#2c5f8a; }
.dstat-n.p  { color:#6a3d8f; }
.dstat-n.g  { color:var(--green); }
.dstat-n.r  { color:var(--urg); }
@keyframes breathe { 0%{transform:scale(1)}50%{transform:scale(1.08)}100%{transform:scale(1)} }
.dstat-n.animate { animation:breathe 3s ease-in-out; }
.dstat-l { font-size:.6rem; text-transform:uppercase; letter-spacing:.1em; color:var(--muted); margin-top:.55rem; }
#heroSub { font-size:.78rem; color:var(--muted); margin-bottom:.5rem; }
.progress-bar { height:4px; border-radius:2px; background:var(--faint2); display:flex; overflow:hidden; margin-bottom:.4rem; }
.pb-seg { transition:flex .3s; }
.pb-pending   { background:#b8860b; }
.pb-attended  { background:#2c5f8a; }
.pb-arguments { background:#6a3d8f; }
.pb-completed { background:var(--green); }
.progress-legend { display:flex; gap:.85rem; flex-wrap:wrap; }
.pl-item { display:flex; align-items:center; gap:.3rem; font-size:.68rem; color:var(--muted); }
.pl-dot { width:7px; height:7px; border-radius:50%; flex-shrink:0; }

/* ── FILTERS ─────────────────────────────────────────────── */
.filters { margin-bottom: 1.25rem; display:flex; flex-direction:column; gap:.5rem; }
.f-status-row { display:flex; gap:.3rem; overflow-x:auto; -webkit-overflow-scrolling:touch; padding-bottom:2px; scrollbar-width:none; }
.f-status-row::-webkit-scrollbar { display:none; }
.pill { flex-shrink:0; background:var(--paper); border:1.5px solid var(--line); border-radius:20px; padding:0 .9rem; height:38px; font-size:.78rem; font-weight:500; font-family:'Jost',sans-serif; color:var(--muted); cursor:pointer; white-space:nowrap; display:inline-flex; align-items:center; transition:all .15s; }
.pill:hover { border-color:var(--ink2); color:var(--ink); }
.pill.on { background:var(--ink); border-color:var(--ink); color:#f0ece3; }
.f-select-row { display:flex; gap:.4rem; }
.sel-pill { flex:1; min-width:0; background:var(--paper); border:1.5px solid var(--line); border-radius:20px; padding:0 .9rem; height:38px; font-size:.78rem; font-family:'Jost',sans-serif; color:var(--muted); outline:none; cursor:pointer; }
.court-multi-wrap { position:relative; flex:1; min-width:0; }
.court-multi-btn { width:100%; height:38px; background:var(--paper); border:1.5px solid var(--line); border-radius:20px; padding:0 .9rem; font-size:.78rem; font-family:'Jost',sans-serif; color:var(--muted); cursor:pointer; display:flex; align-items:center; justify-content:space-between; gap:.4rem; white-space:nowrap; overflow:hidden; }
.court-multi-btn.active { border-color:var(--ink); color:var(--ink); font-weight:500; }
.court-multi-btn .caret { font-size:.6rem; opacity:.5; flex-shrink:0; }
.court-multi-dropdown { display:none; position:absolute; top:calc(100% + 4px); left:0; right:0; background:var(--paper); border:1.5px solid var(--line); border-radius:12px; box-shadow:var(--shadow-md); z-index:200; max-height:260px; overflow-y:auto; }
.court-multi-dropdown.open { display:block; }
.court-multi-opt { display:flex; align-items:center; gap:.6rem; padding:.7rem 1rem; font-size:.82rem; font-family:'Jost',sans-serif; color:var(--ink2); cursor:pointer; border-bottom:1px solid var(--faint); user-select:none; }
.court-multi-opt:last-of-type { border-bottom:none; }
.court-multi-opt:hover { background:var(--faint2); }
.court-multi-opt input[type=checkbox] { width:17px; height:17px; accent-color:var(--green); flex-shrink:0; }
.court-multi-clear { padding:.55rem 1rem; font-size:.76rem; color:var(--red); border-top:1.5px solid var(--line); cursor:pointer; font-family:'Jost',sans-serif; text-align:center; font-weight:500; }

/* ── COURT GROUPS ────────────────────────────────────────── */
.court-group { margin-bottom: 1.1rem; border-radius: var(--r); overflow:hidden; border: 1.5px solid var(--line); box-shadow: var(--shadow-sm); transition: border-color .2s; }
.court-group.all-done { border-color: #a8d8b8; }
.court-group.has-urgent { border-color: #e08080; }
.court-label { display:flex; align-items:center; gap:.6rem; padding:.6rem .9rem; color:#fff; font-size:.7rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; }
.court-color-dot { width:6px; height:6px; border-radius:50%; background:rgba(255,255,255,.4); flex-shrink:0; }
.court-case-count { margin-left:auto; font-size:.65rem; font-weight:500; opacity:.75; white-space:nowrap; }
:root { --court-0:#2d5a3d; --court-1:#3d2d5a; --court-2:#5a3d2d; --court-3:#2d455a; --court-4:#5a2d2d; --court-5:#2d5a5a; --court-6:#4a3d20; --court-7:#3d4a20; }

/* ── CASE CARDS ──────────────────────────────────────────── */
.case-card { background:var(--paper); border-top:1px solid var(--faint2); transition:background .15s; }
.case-card:last-child { border-radius:0 0 calc(var(--r) - 2px) calc(var(--r) - 2px); }
.case-card.urgent { background:#fdf5f5; border-left:3px solid var(--urg); }
.case-card.attended { background:#dff2e8; }
.case-card.completed { background:#d4ede0; }
.case-summary { display:flex; align-items:flex-start; padding:.8rem .9rem; cursor:pointer; gap:.6rem; }
.case-summary:hover { background:rgba(0,0,0,.02); }
.case-summary-l { flex:1; min-width:0; }
.case-parties { font-family:'Cormorant Garamond',serif; font-size:1.12rem; font-weight:500; color:var(--ink); line-height:1.3; margin-bottom:.3rem; }
.case-card.attended .case-parties, .case-card.completed .case-parties { color:#1a4a2e; font-weight:600; }
.case-meta { display:flex; align-items:center; gap:.4rem; flex-wrap:wrap; }
.case-num-lbl { font-size:.7rem; color:var(--muted); }
.case-stage-lbl { font-size:.68rem; color:var(--amber); background:var(--amber-bg); border:1px solid #e8c870; border-radius:4px; padding:.05rem .38rem; font-weight:500; letter-spacing:.04em; text-transform:uppercase; }
.serial-badge { font-size:.72rem; font-family:'Jost',sans-serif; font-weight:600; color:var(--ink2); background:var(--faint2); border:1px solid var(--line); border-radius:6px; padding:.08rem .45rem; letter-spacing:.02em; }
.serial-add { font-size:.68rem; color:var(--muted); border:1px dashed var(--line); border-radius:6px; padding:.08rem .45rem; cursor:pointer; }
.serial-add:hover { border-color:var(--ink2); color:var(--ink); }
.cc-adv-pill { display:inline-flex; align-items:center; gap:.2rem; font-size:.7rem; font-family:'Jost',sans-serif; background:rgba(30,77,62,.09); color:#1e4d3e; border:1px solid rgba(30,77,62,.18); border-radius:20px; padding:.15rem .5rem; }
.cc-note-pill { display:inline-flex; align-items:flex-start; gap:.2rem; font-size:.7rem; font-family:'Jost',sans-serif; background:rgba(90,60,20,.07); color:#5a3c14; border:1px solid rgba(90,60,20,.14); border-radius:10px; padding:.25rem .55rem; white-space:normal; line-height:1.4; margin-top:.2rem; }
.case-summary-r { display:flex; align-items:center; gap:.4rem; flex-shrink:0; }
.status-badge { font-size:.65rem; font-weight:600; letter-spacing:.06em; text-transform:uppercase; border:1.5px solid; border-radius:20px; padding:.2rem .6rem; white-space:nowrap; }
.sb-pending   { color:#8a6a20; border-color:#d4a840; }
.sb-attended  { color:#2c5f8a; border-color:#6a9abf; }
.sb-arguments { color:#6a3d8f; border-color:#9a6dbf; }
.sb-completed { color:var(--green); border-color:#5aaa7a; }
.expand-icon { font-size:.65rem; color:var(--muted); transition:transform .2s; }
.case-card.open .expand-icon { transform:rotate(180deg); }

/* ── EXPANDED CARD ───────────────────────────────────────── */
.case-details { display:none; padding:.5rem .9rem .9rem; border-top:1px solid var(--faint2); }
.case-card.open .case-details { display:block; }
.detail-section { margin-bottom:.85rem; }
.detail-lbl { font-size:.62rem; font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); margin-bottom:.4rem; }
.status-btns { display:flex; gap:.35rem; flex-wrap:wrap; }
.stbtn { height:32px; padding:0 .85rem; border-radius:20px; font-size:.74rem; font-family:'Jost',sans-serif; font-weight:500; cursor:pointer; border:1.5px solid var(--line); background:transparent; color:var(--muted); transition:all .15s; }
.stbtn:hover { border-color:var(--ink2); color:var(--ink); }
.stbtn.on-pending   { background:#fff8e8; border-color:#d4a840; color:#8a6a20; font-weight:600; }
.stbtn.on-attended  { background:#e8f0f8; border-color:#6a9abf; color:#2c5f8a; font-weight:600; }
.stbtn.on-arguments { background:#f4eef8; border-color:#9a6dbf; color:#6a3d8f; font-weight:600; }
.status-ts { font-size:.7rem; color:var(--muted); margin-top:.35rem; }
.adv-btns { display:flex; gap:.3rem; flex-wrap:wrap; }
.advbtn { height:30px; padding:0 .75rem; border-radius:20px; font-size:.72rem; font-family:'Jost',sans-serif; cursor:pointer; border:1.5px solid var(--line); background:transparent; color:var(--muted); display:flex; align-items:center; gap:.3rem; transition:all .15s; }
.advbtn.on { border-color:var(--green); background:rgba(45,106,79,.08); color:#1a4a2e; font-weight:600; }
.adot { width:6px; height:6px; border-radius:50%; background:var(--muted); flex-shrink:0; }
.advbtn.on .adot { background:var(--green); }
.note-in { width:100%; background:var(--bg); border:1px solid var(--line); border-radius:8px; padding:.5rem .7rem; font-family:'Jost',sans-serif; font-size:.8rem; color:var(--ink); outline:none; transition:border-color .15s; }
.note-in:focus { border-color:var(--ink2); }
.note-in::placeholder { color:var(--muted); }

/* Serial number section */
.serial-section { display:flex; gap:.5rem; flex-wrap:wrap; align-items:flex-end; }
.serial-field { display:flex; flex-direction:column; gap:.25rem; flex:1; min-width:80px; }
.serial-field label { font-size:.62rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); }
.serial-field input, .serial-field select { height:34px; background:var(--bg); border:1px solid var(--line); border-radius:8px; padding:0 .7rem; font-family:'Jost',sans-serif; font-size:.8rem; color:var(--ink); outline:none; }
.serial-field input:focus, .serial-field select:focus { border-color:var(--ink2); }

.detail-actions { display:flex; gap:.5rem; justify-content:flex-end; flex-wrap:wrap; padding-top:.35rem; border-top:1px solid var(--faint2); }
.da-btn { background:transparent; border:none; font-size:.75rem; color:var(--muted); cursor:pointer; padding:.3rem .5rem; border-radius:6px; font-family:'Jost',sans-serif; transition:all .15s; }
.da-btn:hover { background:var(--faint2); color:var(--ink); }
.da-btn.del:hover { color:var(--red); }
.da-btn.urg-on { color:var(--urg); }

.urg-lbl { color:var(--urg); }
.empty { text-align:center; padding:3rem 1rem; }
.empty .ei { font-size:2.5rem; margin-bottom:.75rem; }
.empty h3 { font-family:'Cormorant Garamond',serif; font-size:1.4rem; color:var(--ink2); margin-bottom:.35rem; }
.empty p { font-size:.82rem; color:var(--muted); }

/* ── IMPORT CARD ──────────────────────────────────────────── */
.import-card { background:var(--paper); border:1px solid var(--faint); border-radius:var(--r); overflow:hidden; box-shadow:var(--shadow-sm); }
.import-card-top { background:var(--faint2); padding:1.75rem 1.5rem 1.5rem; text-align:center; border-bottom:1px solid var(--line); }
.import-card-icon { font-size:2rem; margin-bottom:.6rem; line-height:1; }
.import-card-title { font-family:'Cormorant Garamond',serif; font-size:1.6rem; font-weight:500; color:var(--ink); margin-bottom:.3rem; }
.import-card-sub { font-size:.75rem; color:var(--muted); margin-bottom:.85rem; }
.import-fmt { display:inline-flex; align-items:center; gap:.5rem; background:var(--paper); border:1px solid var(--line); border-radius:8px; padding:.35rem .75rem; }
.fmt-label { font-size:.6rem; font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:var(--amber); }
.fmt-code { font-size:.72rem; color:var(--muted); font-family:'Jost',sans-serif; }

/* Import date selector */
.import-date-row { display:flex; gap:.4rem; padding:.85rem 1.25rem .4rem; background:var(--paper); }
.import-date-opt { flex:1; padding:.5rem .4rem; border:1.5px solid var(--line); border-radius:10px; text-align:center; cursor:pointer; transition:all .15s; background:transparent; }
.import-date-opt:hover { border-color:var(--ink2); }
.import-date-opt.selected { border-color:var(--green); background:rgba(45,106,79,.06); }
.import-date-opt .ido-label { font-size:.68rem; font-weight:600; color:var(--ink2); letter-spacing:.04em; }
.import-date-opt .ido-date { font-size:.63rem; color:var(--muted); margin-top:.15rem; }
.import-date-opt.selected .ido-label { color:var(--green); }

.paste-area { display:block; width:100%; background:var(--bg); border:none; border-top:1px solid var(--faint); padding:1rem 1.25rem; font-family:'Jost',sans-serif; font-size:.82rem; color:var(--ink); outline:none; resize:none; min-height:100px; transition:background .15s; }
.paste-area:focus { background:var(--paper); }
.paste-area::placeholder { color:var(--muted); line-height:1.7; }
.import-btn { display:block; width:100%; background:var(--green); color:#f0ece4; border:none; padding:.95rem 1rem; font-size:.85rem; font-family:'Jost',sans-serif; font-weight:600; letter-spacing:.06em; text-transform:uppercase; cursor:pointer; border-top:1px solid rgba(255,255,255,.08); transition:opacity .15s; }
.import-btn:hover { opacity:.88; }

/* ── BOTTOM ACTIONS ──────────────────────────────────────── */
.bottom-actions { max-width:780px; margin:1rem auto 0; padding:1rem 1rem 0; border-top:1px solid var(--line); position:relative; z-index:1; }
.bottom-actions-title { font-size:.62rem; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); margin-bottom:.6rem; font-family:'Jost',sans-serif; }
.f-action-row { display:flex; gap:.4rem; }
.fa-btn { flex:1; height:40px; border-radius:20px; font-size:.78rem; font-family:'Jost',sans-serif; font-weight:500; cursor:pointer; border:1.5px solid var(--line); background:var(--paper); color:var(--ink2); white-space:nowrap; transition:all .15s; }
.fa-btn:hover { background:var(--faint2); }
.fa-btn.danger { color:var(--red); border-color:#d08080; }
.fa-btn.danger:hover { background:var(--red-bg); }
.fa-btn.primary { background:var(--ink); border-color:var(--ink); color:#f0ece3; font-weight:600; }
.fa-btn.primary:hover { opacity:.85; }

/* ── MISC WORK TAB ───────────────────────────────────────── */
.tab-hero { margin-bottom:1.25rem; }
.tab-hero-title { font-family:'Cormorant Garamond',serif; font-size:2rem; font-weight:500; color:var(--ink); }
.tab-hero-title em { font-style:italic; color:var(--muted); font-size:1.3rem; margin-left:.3rem; }
.tab-hero-sub { font-size:.78rem; color:var(--muted); margin-top:.25rem; }
.misc-stats, .filing-stats { display:flex; gap:.5rem; margin:1rem 0; }
.mstat { flex:1; background:var(--paper); border:1px solid var(--line); border-radius:10px; padding:.55rem .5rem; text-align:center; }
.mstat-n { font-family:'Cormorant Garamond',serif; font-size:1.6rem; font-weight:600; display:block; color:var(--ink); }
.mstat-l { font-size:.6rem; text-transform:uppercase; letter-spacing:.1em; color:var(--muted); }

.misc-card { background:var(--paper); border:1.5px solid var(--line); border-radius:var(--r); margin-bottom:.75rem; overflow:hidden; box-shadow:var(--shadow-sm); transition:border-color .2s; }
.misc-card.urgent-task { border-color:#e08080; }
.misc-card.done-task { border-color:#a8d8b8; background:#f0f8f4; }
.misc-summary { display:flex; align-items:flex-start; padding:.75rem .9rem; cursor:pointer; gap:.6rem; }
.misc-summary:hover { background:rgba(0,0,0,.02); }
.misc-summary-l { flex:1; min-width:0; }
.misc-title { font-family:'Cormorant Garamond',serif; font-size:1.08rem; font-weight:500; color:var(--ink); margin-bottom:.25rem; }
.misc-meta { display:flex; gap:.35rem; flex-wrap:wrap; align-items:center; }
.misc-badge { font-size:.65rem; border-radius:4px; padding:.05rem .4rem; font-weight:500; letter-spacing:.04em; text-transform:uppercase; }
.mb-pending  { background:#fff8e8; color:#8a6a20; border:1px solid #e8c870; }
.mb-progress { background:#e8f0f8; color:#2c5f8a; border:1px solid #6a9abf; }
.mb-done     { background:#d4ede0; color:#1a4a2e; border:1px solid #a8d8b8; }
.mb-urgent   { background:#fdf0f0; color:var(--urg); border:1px solid #e08080; }
.misc-details { display:none; padding:.4rem .9rem .85rem; border-top:1px solid var(--faint2); }
.misc-card.open .misc-details { display:block; }
.misc-card.open .expand-icon { transform:rotate(180deg); }

/* ── FRESH FILINGS TAB ───────────────────────────────────── */
.filing-card { background:var(--paper); border:1.5px solid var(--line); border-radius:var(--r); margin-bottom:.75rem; overflow:hidden; box-shadow:var(--shadow-sm); transition:border-color .2s; }
.filing-card.overdue { border-color:#e08080; background:#fdf8f8; }
.filing-card.filed { border-color:#a8d8b8; background:#f0f8f4; }
.filing-summary { display:flex; align-items:flex-start; padding:.75rem .9rem; cursor:pointer; gap:.6rem; }
.filing-summary:hover { background:rgba(0,0,0,.02); }
.filing-summary-l { flex:1; min-width:0; }
.filing-title { font-family:'Cormorant Garamond',serif; font-size:1.08rem; font-weight:500; color:var(--ink); margin-bottom:.25rem; }
.filing-meta { display:flex; gap:.35rem; flex-wrap:wrap; align-items:center; }
.deadline-badge { font-size:.68rem; font-family:'Jost',sans-serif; font-weight:600; border-radius:6px; padding:.1rem .5rem; }
.db-ok       { background:#e8f0f8; color:#2c5f8a; border:1px solid #6a9abf; }
.db-soon     { background:#fff8e8; color:#8a6a20; border:1px solid #e8c870; }
.db-overdue  { background:#fdf0f0; color:var(--urg); border:1px solid #e08080; }
.filing-details { display:none; padding:.4rem .9rem .85rem; border-top:1px solid var(--faint2); }
.filing-card.open .filing-details { display:block; }
.filing-card.open .expand-icon { transform:rotate(180deg); }
.status-select { height:34px; background:var(--bg); border:1px solid var(--line); border-radius:8px; padding:0 .7rem; font-family:'Jost',sans-serif; font-size:.8rem; color:var(--ink); outline:none; width:100%; }

/* ── MODALS ──────────────────────────────────────────────── */
.overlay { display:none; position:fixed; inset:0; background:rgba(10,8,6,.6); backdrop-filter:blur(4px); z-index:300; align-items:center; justify-content:center; padding:1rem; }
.overlay.on { display:flex; }
@keyframes rise { from{opacity:0;transform:translateY(16px)} to{opacity:1;transform:translateY(0)} }
.modal { background:var(--paper); border:1px solid var(--line); border-radius:var(--r); width:96%; max-width:480px; max-height:90vh; display:flex; flex-direction:column; box-shadow:var(--shadow-lg); animation:rise .2s ease; overflow:hidden; }
.modal-hdr { display:flex; align-items:center; justify-content:space-between; padding:.85rem 1.25rem; border-bottom:1px solid var(--line); flex-shrink:0; background:var(--ink); }
.modal-title { font-family:'Cormorant Garamond',serif; font-size:1.15rem; color:#f0ece4; }
.modal-body { overflow-y:auto; padding:1.25rem; flex:1; display:flex; flex-direction:column; gap:.85rem; }
.modal-close { background:transparent; border:1px solid rgba(255,255,255,.12); color:#6a6458; width:28px; height:28px; border-radius:50%; cursor:pointer; font-size:.9rem; display:flex; align-items:center; justify-content:center; transition:all .15s; }
.modal-close:hover { color:#f0ece4; }
.field-group { display:flex; flex-direction:column; gap:.3rem; }
.field-group label { font-size:.62rem; font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); }
.field-group input, .field-group select, .field-group textarea { background:var(--bg); border:1px solid var(--line); border-radius:8px; padding:.5rem .75rem; font-family:'Jost',sans-serif; font-size:.85rem; color:var(--ink); outline:none; transition:border-color .15s; width:100%; }
.field-group input:focus, .field-group select:focus, .field-group textarea:focus { border-color:var(--ink2); }
.field-group textarea { resize:vertical; min-height:70px; }
.field-row { display:flex; gap:.6rem; }
.field-row .field-group { flex:1; }
.modal-footer { display:flex; gap:.5rem; justify-content:flex-end; padding:.85rem 1.25rem; border-top:1px solid var(--line); flex-shrink:0; }
.btn-ghost { background:transparent; border:1.5px solid var(--line); border-radius:20px; padding:.35rem .9rem; font-size:.78rem; font-family:'Jost',sans-serif; color:var(--ink2); cursor:pointer; transition:all .15s; }
.btn-ghost:hover { border-color:var(--ink2); }
.btn-solid-m { background:var(--ink); border:1.5px solid var(--ink); border-radius:20px; padding:.35rem .9rem; font-size:.78rem; font-family:'Jost',sans-serif; color:#f0ece4; cursor:pointer; font-weight:600; transition:opacity .15s; }
.btn-solid-m:hover { opacity:.85; }

/* EOD Modal */
.eod-modal { background:var(--paper); border:1px solid var(--line); border-radius:var(--r); width:96%; max-width:820px; max-height:92vh; display:flex; flex-direction:column; box-shadow:var(--shadow-lg); animation:rise .2s ease; overflow:hidden; }
.eod-modal-hdr { display:flex; align-items:center; justify-content:space-between; padding:.85rem 1.25rem; border-bottom:1px solid var(--line); flex-shrink:0; background:var(--ink); }
.eod-modal-title { font-family:'Cormorant Garamond',serif; font-size:1.15rem; font-weight:500; color:#f0ece4; }
.eod-modal-body { overflow-y:auto; padding:1.4rem; flex:1; }
.eod-modal-hdr .btn-ghost { background:transparent; border:1px solid rgba(255,255,255,.2); color:#c8b878; font-size:.74rem; padding:.3rem .85rem; border-radius:20px; cursor:pointer; font-family:'Jost',sans-serif; font-weight:500; transition:all .15s; }
.eod-modal-hdr .btn-ghost:hover { border-color:#c8b878; background:rgba(200,184,120,.1); }
.eod-modal-hdr .mc { background:transparent; border:1px solid rgba(255,255,255,.12); color:#6a6458; font-size:.74rem; padding:.3rem .85rem; border-radius:20px; cursor:pointer; font-family:'Jost',sans-serif; transition:all .15s; }
.eod-modal-hdr .mc:hover { color:#f0ece4; border-color:rgba(255,255,255,.25); }

/* PW overlay */
.pw-box { background:var(--paper); border-radius:var(--r); padding:1.75rem; width:90%; max-width:340px; box-shadow:var(--shadow-lg); animation:rise .2s ease; text-align:center; }
.pw-title { font-family:'Cormorant Garamond',serif; font-size:1.3rem; color:var(--ink); margin-bottom:.25rem; }
.pw-desc { font-size:.78rem; color:var(--muted); margin-bottom:1rem; }
.pw-in { width:100%; border:1.5px solid var(--line); border-radius:8px; padding:.55rem .75rem; font-family:'Jost',sans-serif; font-size:1rem; text-align:center; letter-spacing:.1em; outline:none; background:var(--bg); color:var(--ink); transition:border-color .15s; margin-bottom:.5rem; }
.pw-in:focus { border-color:var(--ink2); }
.pw-in.err { border-color:var(--red); animation:shake .3s; }
@keyframes shake { 0%,100%{transform:translateX(0)} 25%{transform:translateX(-6px)} 75%{transform:translateX(6px)} }
.pw-err { font-size:.74rem; color:var(--red); min-height:1.1em; margin-bottom:.5rem; }
.pw-btn { width:100%; background:var(--ink); color:#f0ece4; border:none; border-radius:8px; padding:.65rem; font-size:.85rem; font-family:'Jost',sans-serif; font-weight:600; cursor:pointer; }

/* ── TEAM ────────────────────────────────────────────────── */
.team-bar-bottom { max-width:780px; margin:.75rem auto 0; padding:0 1rem; position:relative; z-index:1; }
.team-wrap { background:var(--paper); border:1px solid var(--line); border-radius:var(--r); padding:.85rem 1rem; }
.team-lbl { font-size:.62rem; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); margin-bottom:.6rem; }
.chips { display:flex; gap:.35rem; flex-wrap:wrap; margin-bottom:.5rem; }
.chip { display:flex; align-items:center; gap:.3rem; background:var(--faint2); border:1px solid var(--line); border-radius:20px; padding:.2rem .65rem; font-size:.75rem; color:var(--ink2); }
.chip-dot { width:6px; height:6px; border-radius:50%; background:var(--green); flex-shrink:0; }
.chip .x { cursor:pointer; color:var(--muted); font-size:.85rem; margin-left:.15rem; }
.chip .x:hover { color:var(--red); }
.col-in { background:transparent; border:none; border-bottom:1px dashed var(--line); padding:.2rem 0; font-family:'Jost',sans-serif; font-size:.78rem; color:var(--ink); outline:none; width:100%; }
.col-in::placeholder { color:var(--muted); }

/* ── FOOTER ──────────────────────────────────────────────── */
.footer { margin:3rem 0 0; padding:1.25rem 1rem 3rem; position:relative; z-index:1; }
.footer-inner { max-width:780px; margin:0 auto; background:var(--faint2); border:1px solid var(--line); border-radius:10px; padding:.75rem 1.25rem; display:flex; align-items:center; justify-content:center; flex-wrap:wrap; gap:.3rem .6rem; }
.footer-seg { font-family:Consolas,'Courier New',monospace; font-size:.65rem; color:var(--muted); letter-spacing:.06em; white-space:nowrap; }
.footer-seg.brand { color:var(--ink2); font-weight:500; }
.footer-seg.divider { color:var(--line); }

.docket-date-badge{display:flex;align-items:center;gap:.5rem;flex-shrink:0}
.date-nav-prev,.date-nav-next{background:transparent;border:1.5px solid var(--line);border-radius:50%;width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-size:.65rem;color:var(--muted);transition:all .15s;user-select:none}
.date-nav-prev:hover,.date-nav-next:hover{border-color:var(--ink2);color:var(--ink)}
.date-nav-label-click{font-size:.82rem;color:var(--muted);cursor:pointer;padding:.2rem .5rem;border-radius:6px;transition:background .15s;white-space:nowrap}
.date-nav-label-click:hover{background:var(--faint2)}
.import-date-row{display:flex;gap:.4rem;padding:.85rem 1.25rem .4rem}
.import-date-opt{flex:1;padding:.55rem .4rem;border:1.5px solid var(--line);border-radius:10px;text-align:center;cursor:pointer;transition:all .15s}
.import-date-opt:hover{border-color:var(--ink2)}
.import-date-opt.selected{border-color:var(--green);background:rgba(45,106,79,.06)}
.import-date-opt .ido-label{font-size:.72rem;font-weight:600;color:var(--ink2);letter-spacing:.03em}
.import-date-opt .ido-date{font-size:.63rem;color:var(--muted);margin-top:.15rem}
.import-date-opt.selected .ido-label{color:var(--green)}


/* ── HERO DATE NAV ── */
.hero-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:.75rem; flex-wrap:wrap; gap:.5rem; }
.hero-head-left { flex:1; min-width:0; }
.hero-date-nav { display:flex; align-items:center; gap:.4rem; flex-shrink:0; position:relative; }
.hero-nav-btn {
  background: transparent;
  border: 1.5px solid var(--line);
  border-radius: 50%;
  width: 30px; height: 30px;
  display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer; font-size: .65rem; color: var(--muted);
  transition: all .15s; user-select: none;
}
.hero-nav-btn:hover { border-color: var(--ink2); color: var(--ink); background: var(--faint2); }
.hero-date-label {
  display: flex; align-items: center; gap: .35rem;
  font-size: .82rem; color: var(--muted); cursor: pointer;
  padding: .25rem .65rem; border-radius: 8px;
  border: 1.5px solid var(--line); transition: all .15s;
  white-space: nowrap; user-select: none;
}
.hero-date-label:hover { border-color: var(--ink2); color: var(--ink); background: var(--faint2); }
.hero-cal-icon { font-size: .85rem; opacity: .55; }

.hero-today-btn {
  font-size: .7rem; font-weight: 600; letter-spacing: .04em;
  color: var(--amber); border: 1.5px solid var(--amber);
  background: transparent; border-radius: 20px;
  padding: .2rem .65rem; cursor: pointer; transition: all .15s;
  white-space: nowrap; font-family: 'Jost', sans-serif;
}
.hero-today-btn:hover { background: var(--amber); color: #fff; }

/* detail-actions save button */
.detail-actions {
  display:flex; align-items:center; justify-content:space-between;
  gap:.5rem; flex-wrap:wrap; padding-top:.4rem;
  border-top:1px solid var(--faint2);
}
.da-left { display:flex; align-items:center; gap:.4rem; flex: 0 0 auto; }
.da-right { display:flex; align-items:center; gap:.3rem; flex: 0 0 auto; flex-wrap:nowrap; }
@media (max-width: 520px) {
  .detail-actions { justify-content:space-between; }
  .da-btn { font-size:.71rem; padding:.22rem .45rem; }
  .da-btn.da-save { padding:.28rem .75rem; }
  .nature-select { font-size:.71rem; padding:.2rem .35rem; }
}
.da-btn.da-save {
  font-weight: 600;
  color: var(--paper);
  background: #2d6a4f;
  border-color: #2d6a4f;
  padding: .3rem .9rem;
  letter-spacing: .03em;
  transition: all .2s;
}
.da-btn.da-save:hover { background: #1e4d35; border-color: #1e4d35; }


/* ── MISC COMPLETED SECTION ── */
.misc-completed-section { margin-top: 1.5rem; }
.misc-completed-header {
  display: flex; align-items: center; justify-content: space-between;
  font-size: .7rem; font-weight: 700; letter-spacing: .1em;
  text-transform: uppercase; color: var(--muted);
  padding: .5rem .25rem; border-top: 1.5px solid var(--line);
  cursor: pointer; user-select: none;
}
.misc-completed-header:hover { color: var(--ink2); }
.misc-comp-toggle { font-size: .8rem; }
.misc-completed-body { margin-top: .5rem; }
.done-task { opacity: .75; }
.done-task .misc-title { text-decoration: line-through; color: var(--muted); }
.misc-title-done { text-decoration: line-through; color: var(--muted) !important; }
.misc-completed-stamp {
  font-size: .7rem; color: #2d6a4f; font-style: italic;
  margin-top: .15rem; margin-bottom: .15rem;
}
.done-task { border-left-color: #2d6a4f !important; background: #f0f7f4 !important; }


/* stronger overdue red for filings */
.filing-card.overdue {
  border-left: 3px solid #c0392b !important;
  background: #fff5f5 !important;
}
.filing-card.overdue .filing-title { color: #c0392b; }
.filing-card.filed { opacity: .75; border-left-color: #2d6a4f !important; background: #f0f7f4 !important; }
.filing-card.filed .filing-title { text-decoration: line-through; color: var(--muted); }


.btn-confirm {
  padding: .5rem 1.25rem; border-radius: 8px; border: none;
  background: #2d6a4f; color: #fff; font-size: .9rem;
  font-weight: 600; cursor: pointer; transition: background .15s;
}
.btn-confirm:hover { background: #235840; }
.btn-danger {
  background: #c0392b; color: #fff;
  border: none; border-radius: 6px;
  padding: .5rem 1.4rem; font-size: .85rem;
  font-weight: 600; cursor: pointer;
  font-family: 'Jost', sans-serif;
  transition: background .15s;
}
.btn-danger:hover { background: #a93226; }
.btn-secondary {
  background: transparent; color: var(--ink2);
  border: 1.5px solid var(--line); border-radius: 6px;
  padding: .5rem 1.4rem; font-size: .85rem;
  font-weight: 500; cursor: pointer;
  font-family: 'Jost', sans-serif;
  transition: all .15s;
}
.btn-secondary:hover { border-color: var(--ink2); color: var(--ink); }


/* ── NATURE SELECT ── */
.nature-select {
  font-size: .72rem; font-weight: 500;
  padding: .22rem .5rem;
  border-radius: 6px; border: 1.5px solid var(--line);
  background: var(--paper); color: var(--muted);
  cursor: pointer; font-family: 'Jost', sans-serif;
  outline: none; transition: all .15s;
  appearance: auto;
}
.nature-select:hover, .nature-select:focus { border-color: var(--ink2); color: var(--ink); }
.nature-select-imp { border-color: #b8860b !important; color: #b8860b !important; background: #fdf8ec !important; font-weight: 600 !important; }
.nature-select-very-imp { border-color: #c0392b !important; color: #c0392b !important; background: #fdf0ee !important; font-weight: 600 !important; }

/* ── NATURE DOT (collapsed card) ── */
.nature-dot {
  display: inline-block;
  font-size: .55rem;
  vertical-align: middle;
  margin-left: .25rem;
  line-height: 1;
}
.nd-imp { color: #b8860b; }
.nd-very-imp { color: #c0392b; }


/* ── DON'T ATTEND ── */
.da-card{opacity:.6;position:relative;overflow:hidden;}
.da-card::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(-45deg,transparent,transparent 9px,rgba(120,100,90,.08) 9px,rgba(120,100,90,.08) 11px);pointer-events:none;z-index:1;}
.da-stamp{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(-18deg);z-index:2;pointer-events:none;}
.da-stamp span{display:block;font-family:'Jost',sans-serif;font-size:.62rem;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:rgba(170,35,35,0.4);border:2px solid rgba(170,35,35,0.3);padding:.18rem .55rem;border-radius:3px;white-space:nowrap;}
.da-skip{color:#c0392b!important;border-color:#e0a090!important;}
.da-skip:hover{background:#fdf0ee!important;}
.da-restore{color:#2d6a4f!important;border-color:#a0c8b8!important;}
.da-restore:hover{background:#eaf3ee!important;}
.da-section{margin-top:1.5rem;border-top:2px dashed var(--line);padding-top:.75rem;opacity:.85;}
.da-section-hdr{font-family:'Jost',sans-serif;font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:.75rem;padding:.35rem .6rem;background:var(--faint2);border-radius:6px;display:inline-block;}
.da-court-group .court-label{opacity:.55;filter:grayscale(55%);}


/* ── TOPBAR LOGO ── */
.topbar-logo {
  width: 36px; height: 36px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
  filter: drop-shadow(0 1px 4px rgba(0,0,0,.35));
}
.firm-left { display: flex; align-items: center; gap: .6rem; }



/* ════════════════════════════════════════
   LOGIN OVERLAY
   ════════════════════════════════════════ */
#loginOverlay {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #0f0e0c;
  background-image:
    radial-gradient(ellipse at 30% 20%, rgba(184,151,42,0.08) 0%, transparent 60%),
    radial-gradient(ellipse at 70% 80%, rgba(184,151,42,0.05) 0%, transparent 60%);
}
#loginOverlay.hidden {
  display: none;
}
.login-card {
  width: 100%;
  max-width: 380px;
  margin: 1rem;
  background: #1a1814;
  border: 1px solid rgba(184,151,42,0.25);
  border-radius: 16px;
  padding: 2.5rem 2rem 2rem;
  text-align: center;
  box-shadow:
    0 0 0 1px rgba(184,151,42,0.08),
    0 24px 60px rgba(0,0,0,0.6),
    0 8px 20px rgba(0,0,0,0.4);
}
.login-logo-wrap {
  display: flex;
  justify-content: center;
  margin-bottom: 1.25rem;
}
.login-logo {
  width: 88px;
  height: 88px;
  border-radius: 50%;
  object-fit: cover;
  border: 2px solid rgba(184,151,42,0.35);
  box-shadow: 0 4px 20px rgba(0,0,0,0.5), 0 0 0 4px rgba(184,151,42,0.08);
}
.login-firm {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.25rem;
  font-weight: 600;
  color: #f0ece4;
  letter-spacing: .02em;
  line-height: 1.2;
}
.login-amp {
  color: #c8a84b;
  font-style: italic;
}
.login-sub {
  font-family: 'Jost', sans-serif;
  font-size: .65rem;
  font-weight: 400;
  color: #6b6560;
  text-transform: uppercase;
  letter-spacing: .1em;
  margin-top: .35rem;
}
.login-divider {
  width: 48px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(184,151,42,0.5), transparent);
  margin: 1.25rem auto;
}
.login-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.6rem;
  font-weight: 600;
  color: #c8a84b;
  letter-spacing: .04em;
  margin-bottom: .3rem;
}
.login-hint {
  font-family: 'Jost', sans-serif;
  font-size: .75rem;
  color: #5a5550;
  margin-bottom: 1.5rem;
}
.login-field-wrap {
  display: flex;
  gap: .5rem;
  margin-bottom: .75rem;
}
.login-input {
  flex: 1;
  background: #0f0e0c;
  border: 1px solid rgba(184,151,42,0.2);
  border-radius: 8px;
  color: #f0ece4;
  font-family: 'Jost', sans-serif;
  font-size: .9rem;
  padding: .65rem 1rem;
  outline: none;
  transition: border-color .2s;
  letter-spacing: .1em;
}
.login-input::placeholder { color: #3a3530; letter-spacing: .05em; }
.login-input:focus { border-color: rgba(184,151,42,0.5); }
.login-input.error { border-color: rgba(192,57,43,0.6); animation: loginShake .35s ease; }
.login-btn {
  background: linear-gradient(135deg, #c8a84b, #a8882b);
  border: none;
  border-radius: 8px;
  color: #0f0e0c;
  font-family: 'Jost', sans-serif;
  font-size: .85rem;
  font-weight: 700;
  letter-spacing: .06em;
  padding: .65rem 1.25rem;
  cursor: pointer;
  transition: opacity .15s, transform .1s;
  white-space: nowrap;
}
.login-btn:hover { opacity: .9; }
.login-btn:active { transform: scale(.97); }
.login-error {
  font-family: 'Jost', sans-serif;
  font-size: .75rem;
  color: #c0392b;
  min-height: 1rem;
  margin-bottom: .5rem;
  transition: opacity .2s;
}
.login-footer {
  font-family: 'Jost', sans-serif;
  font-size: .62rem;
  color: #2e2c28;
  text-transform: uppercase;
  letter-spacing: .1em;
  margin-top: 1.25rem;
}
@keyframes loginShake {
  0%,100% { transform: translateX(0); }
  20%      { transform: translateX(-6px); }
  40%      { transform: translateX(6px); }
  60%      { transform: translateX(-4px); }
  80%      { transform: translateX(4px); }
}
@media (max-width: 420px) {
  .login-card { padding: 2rem 1.25rem 1.5rem; }
  .login-logo { width: 72px; height: 72px; }
}
