/* pages.css — Document Intelligence + Case Diary + Login */

/* login / sign-up page — split layout (brand panel + form) */
.auth-page{min-height:100vh;display:grid;grid-template-columns:1.05fr 1fr;background:var(--bg)}
.auth-aside{position:relative;display:flex;flex-direction:column;justify-content:space-between;gap:30px;padding:40px 44px;color:#fff;background:linear-gradient(150deg,var(--brand),var(--brand-ink))}
.auth-aside-brand{display:flex;align-items:center;gap:10px;font-size:16px;font-weight:700;color:#fff}
.auth-aside-brand .auth-logo{background:rgba(255,255,255,.16)}
.auth-aside-h{font-size:clamp(1.5rem,2.6vw,2.1rem);font-weight:700;letter-spacing:-.02em;line-height:1.15;margin:0 0 22px;max-width:14ch}
.auth-points{list-style:none;display:flex;flex-direction:column;gap:14px;font-size:14px;line-height:1.45}
.auth-points li{display:flex;align-items:flex-start;gap:11px;color:rgba(255,255,255,.92)}
.auth-points b{font-weight:700;color:#fff}
.ap-ic{flex-shrink:0;width:24px;height:24px;border-radius:7px;background:rgba(255,255,255,.16);display:flex;align-items:center;justify-content:center;margin-top:1px}
.auth-aside-foot{font-size:11.5px;color:rgba(255,255,255,.7)}
.auth-main{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px}
.auth-back{position:absolute;top:20px;left:22px;display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--ink-3);transition:var(--tr)}
.auth-back:hover{color:var(--ink)}
.auth-card{width:100%;max-width:392px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-1);padding:32px 30px 26px;animation:fadeUp .5s both}
.auth-brand{display:flex;align-items:center;gap:9px;font-size:15px;font-weight:700;color:var(--ink);margin-bottom:22px}
.auth-brand-sm{display:none}
.auth-logo{width:28px;height:28px;flex-shrink:0;border-radius:8px;background:var(--brand);color:#fff;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:800}
.auth-h1{font-size:23px;font-weight:700;letter-spacing:-.02em;color:var(--ink);margin:0 0 6px}
.auth-sub{font-size:13.5px;line-height:1.55;color:var(--ink-2);margin:0 0 20px}
.auth-seg{display:flex;background:var(--surface-2);border:1px solid var(--border);border-radius:99px;padding:3px;margin-bottom:20px}
.auth-seg-b{flex:1;font-size:12.5px;font-weight:500;color:var(--ink-2);padding:7px 0;border-radius:99px;transition:var(--tr)}
.auth-seg-b.on{background:var(--surface);color:var(--brand-ink);box-shadow:var(--sh-1);font-weight:600}
.auth-field{display:block;margin-bottom:14px}
.auth-label{display:block;font-size:11px;color:var(--ink-3);margin-bottom:6px;letter-spacing:.02em}
.auth-input{width:100%;box-sizing:border-box;padding:11px 13px;font-size:14px;color:var(--ink);background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-sm);outline:none;transition:var(--tr)}
.auth-input:focus{border-color:var(--brand);background:var(--surface);box-shadow:0 0 0 3px var(--brand-soft)}
.auth-input:disabled{opacity:.6}
.auth-pw{position:relative}
.auth-pw .auth-input{padding-right:56px}
.auth-pw-tog{position:absolute;top:50%;right:8px;transform:translateY(-50%);font-size:11px;font-weight:600;color:var(--ink-3);padding:5px 8px;border-radius:6px;transition:var(--tr)}
.auth-pw-tog:hover{color:var(--brand-ink);background:var(--brand-soft)}
.auth-err{display:flex;align-items:center;gap:7px;font-size:12.5px;color:var(--warn);background:var(--warn-soft,rgba(190,120,0,.08));border:1px solid var(--warn-line,rgba(190,120,0,.2));border-radius:var(--r-sm);padding:9px 11px;margin-bottom:14px}
.auth-submit{width:100%;justify-content:center;margin-top:4px}
.auth-switch{text-align:center;font-size:12.5px;color:var(--ink-3);margin-top:18px}
.auth-switch button{color:var(--brand-ink);font-weight:600}
.auth-switch button:hover{text-decoration:underline}
.auth-legal{max-width:392px;text-align:center;font-size:11px;color:var(--ink-3);margin-top:18px;line-height:1.5}
@media (max-width:820px){
  .auth-page{grid-template-columns:1fr}
  .auth-aside{display:none}
  .auth-brand-sm{display:flex;justify-content:center}
}

/* export menu in the document result bar */
.doc-export{position:relative}
.exp-menu{position:absolute;top:calc(100% + 6px);right:0;z-index:60;min-width:208px;background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r-md);box-shadow:var(--sh-pop);padding:6px;animation:pop .14s both}
.exp-item{display:flex;align-items:center;gap:9px;width:100%;text-align:left;padding:9px 10px;border-radius:var(--r-xs);font-size:13.5px;color:var(--ink);transition:var(--tr)}
.exp-item:hover{background:var(--surface-2)}
.exp-hint{margin-left:auto;font-size:10.5px;color:var(--ink-3)}

/* signed-out gate on Document Intelligence */
.gate-card{display:flex;align-items:center;gap:16px;flex-wrap:wrap;background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r-md);box-shadow:var(--sh-1);padding:18px 20px;margin:4px 0 8px}
.gate-ico{width:46px;height:46px;flex-shrink:0;border-radius:13px;background:var(--brand-soft);color:var(--brand);display:flex;align-items:center;justify-content:center}
.gate-tx{flex:1;min-width:200px;display:flex;flex-direction:column;gap:3px}
.gate-tx b{font-size:14.5px;color:var(--ink)}
.gate-tx span{font-size:12.5px;color:var(--ink-2);line-height:1.5}
.gate-tx a{color:var(--brand-ink);font-weight:600}
.gate-cta{flex-shrink:0;white-space:nowrap}


/* document workspace tabs (mirrors the Ask page; research.css isn't loaded here) */
.qtabs{display:flex;align-items:flex-end;gap:5px;padding:8px 14px 0;border-bottom:1px solid var(--border);background:var(--bg);overflow-x:auto;flex-shrink:0;scrollbar-width:thin}
.qtabs::-webkit-scrollbar{height:0}
.qtab{display:flex;align-items:center;gap:8px;max-width:230px;flex-shrink:0;padding:8px 9px 8px 13px;border:1px solid var(--border);border-bottom:none;border-radius:var(--r-sm) var(--r-sm) 0 0;background:var(--surface-2);color:var(--ink-2);font-size:12.5px;font-weight:500;cursor:pointer;transition:var(--tr);position:relative;top:1px}
.qtab:hover{background:var(--surface);color:var(--ink)}
.qtab.on{background:var(--surface);color:var(--ink);font-weight:600;border-color:var(--border);box-shadow:0 -2px 6px rgba(30,28,40,.04)}
.qtab-t{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.qtab-x{width:18px;height:18px;border-radius:5px;display:flex;align-items:center;justify-content:center;color:var(--ink-3);flex-shrink:0;transition:var(--tr)}
.qtab-x:hover{background:var(--surface-3);color:var(--ink)}
.qtab-new{flex-shrink:0;width:30px;height:30px;border-radius:var(--r-sm);color:var(--ink-2);display:flex;align-items:center;justify-content:center;transition:var(--tr)}
.qtab-new:hover{background:var(--surface-2);color:var(--brand)}

/* shared empty/hero reuse: .ask-h1, .ask-lede, .trust-row from research.css are not loaded here,
   so redeclare the few needed. */
.ask-h1{font-size:clamp(2rem,3.4vw,2.9rem);font-weight:700;letter-spacing:-.03em;line-height:1.05;color:var(--ink)}
.ask-h1 span{color:var(--ink-3)}
.ask-lede{margin:16px 0 28px;font-size:16px;line-height:1.6;color:var(--ink-2);max-width:560px}
.trust-row{display:flex;gap:22px;flex-wrap:wrap;margin-top:30px;padding-top:22px;border-top:1px solid var(--border)}
.trust{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--ink-2);font-weight:500}
.trust svg{width:15px;height:15px;color:var(--ok)}
.result-foot{font-size:11px;color:var(--ink-3);border-top:1px solid var(--border);padding-top:16px;margin-top:8px;line-height:1.6}

.result-bar{flex-shrink:0;display:flex;align-items:center;gap:10px;padding:11px 22px;border-bottom:1px solid var(--border);background:color-mix(in oklch,var(--surface),transparent 18%);backdrop-filter:blur(8px)}
.rb-back{display:flex;align-items:center;gap:6px;white-space:nowrap;font-size:13px;font-weight:600;color:var(--ink-2);padding:7px 11px;border-radius:var(--r-sm);transition:var(--tr)}
.rb-back:hover{background:var(--surface-2);color:var(--ink)}
.rb-back svg{transform:rotate(45deg)}
.rb-spacer{flex:1}

/* ============ Document Intelligence ============ */
/* New-document / loading stage: fills the pane and never scrolls — the empty
   state is short and self-contained, so it's vertically centred instead. */
.doc-stage{flex:1;min-height:0;overflow:hidden;display:flex;flex-direction:column;justify-content:center;padding:20px 0}
.doc-stage .doc-empty{padding-top:0;padding-bottom:0}
.doc-empty{max-width:700px;margin:0 auto;padding:clamp(40px,8vh,96px) 28px 70px;animation:fadeUp .5s both}
.dropzone{display:flex;flex-direction:column;align-items:center;gap:8px;width:100%;background:var(--surface);border:2px dashed var(--border-2);border-radius:var(--r-lg);padding:46px 24px;transition:var(--tr);text-align:center}
.dropzone:hover,.dropzone.drag{border-color:var(--brand);background:var(--brand-soft)}
.dropzone.drag{box-shadow:0 0 0 4px var(--brand-soft)}
.doc-err{display:flex;align-items:center;gap:7px;justify-content:center;margin-top:16px;font-size:12.5px;color:var(--warn)}
.dz-ico{width:58px;height:58px;border-radius:16px;background:var(--brand-soft);color:var(--brand);display:flex;align-items:center;justify-content:center;margin-bottom:6px}
.dropzone b{font-size:16px;color:var(--ink)}
.dropzone .mono{font-size:11.5px;color:var(--ink-3)}

.doc-split{max-width:none;margin:0;padding:26px 32px 56px;display:grid;grid-template-columns:340px 1fr;gap:28px;align-items:start}
@media(max-width:900px){.doc-split{grid-template-columns:1fr}}
.doc-panel{position:sticky;top:20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px;box-shadow:var(--sh-1);max-height:calc(100vh - 40px);overflow:auto}
/* one card per uploaded document when several are loaded */
.doc-setcount{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);margin:0 0 12px}
.doccard.multi{border:1px solid var(--border);border-radius:var(--r-md);padding:14px;margin-bottom:12px;background:var(--surface-2)}
.doccard.multi .doc-file{padding-bottom:12px}
.doc-file{display:flex;gap:11px;align-items:center;padding-bottom:16px;border-bottom:1px solid var(--border)}
.doccard-x{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--ink-3);border-radius:6px;cursor:pointer;transition:var(--tr)}
.doccard-x:hover:not(:disabled){background:var(--danger-soft,rgba(220,38,38,.1));color:var(--danger,#dc2626)}
.doccard-x:disabled{opacity:.4;cursor:default}
.docadd{display:flex;align-items:center;justify-content:center;gap:7px;width:100%;margin-top:14px;padding:10px;font-size:12.5px;font-weight:600;color:var(--brand-ink,var(--brand));background:var(--brand-soft);border:1px dashed var(--brand-line,var(--brand));border-radius:var(--r-md);cursor:pointer;transition:var(--tr)}
.docadd:hover:not(:disabled){background:var(--brand);color:#fff}
.docadd:disabled{opacity:.6;cursor:default}
.docadd .qtab-spin{width:13px;height:13px}
.doc-file-ic{width:38px;height:38px;border-radius:10px;background:var(--brand-soft);color:var(--brand);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.doc-file-ic svg{width:19px;height:19px}
.doc-file-n{font-size:13px;font-weight:600;color:var(--ink);line-height:1.3;overflow-wrap:break-word;word-break:break-word;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.doc-file-m{font-size:10.5px;color:var(--ink-3);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-variant-numeric:tabular-nums}
.doc-sec-l{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);margin:18px 0 9px}
.doc-facts{display:flex;flex-direction:column;gap:2px}
/* Stacked (label above value): legal facts often have long labels AND long
   values, which a side-by-side row can't fit in the narrow panel — forcing the
   value into a one-character-wide vertical column. Stacking always reads. */
.doc-fact{display:flex;flex-direction:column;gap:2px;padding:8px 0;border-bottom:1px solid var(--surface-2)}
.df-k{color:var(--ink-3);font-size:10.5px;letter-spacing:.02em;overflow-wrap:break-word;word-break:break-word}
.df-v{color:var(--ink);font-weight:500;font-size:12.5px;min-width:0;overflow-wrap:break-word;word-break:break-word}
.doc-clauses{display:flex;flex-direction:column;gap:3px}
.doc-clause{display:flex;align-items:center;gap:10px;padding:7px 9px;border-radius:var(--r-xs);transition:var(--tr);cursor:pointer}
.doc-clause:hover{background:var(--surface-2)}
.dc-id{font-size:10.5px;color:var(--brand);background:var(--brand-soft);padding:2px 6px;border-radius:5px;font-weight:600;flex-shrink:0}
.dc-t{font-size:12.5px;color:var(--ink);flex:1;min-width:0;overflow-wrap:break-word;word-break:break-word}
.dc-p{font-size:10.5px;color:var(--ink-3)}

.doc-main{min-width:0;display:flex;flex-direction:column;gap:18px}
.doc-summary{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px;box-shadow:var(--sh-1)}
.ds-head{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.ds-date{font-size:11px;color:var(--ink-3)}
.ds-text{font-size:15px;line-height:1.65;color:var(--ink-2)}
/* multi-document summary: one block per document */
.ds-docs{display:flex;flex-direction:column;gap:14px}
.ds-doc{padding-bottom:14px;border-bottom:1px solid var(--border)}
.ds-doc:last-child{padding-bottom:0;border-bottom:none}
.ds-doc-h{display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin-bottom:7px}
.ds-doc-n{font-size:13px;font-weight:600;color:var(--ink);min-width:0;overflow-wrap:anywhere}
.ds-doc .ds-text{font-size:13.5px}
.pill.ghost{background:var(--surface-2);color:var(--ink-2);border:1px solid var(--border)}
.ds-parties{display:flex;gap:9px;flex-wrap:wrap;margin-top:14px;padding-top:14px;border-top:1px solid var(--border)}
.party{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:500;color:var(--ink);background:var(--surface-2);border:1px solid var(--border);padding:5px 10px;border-radius:99px}
.party svg{color:var(--brand)}

.qa-thread{display:flex;flex-direction:column;gap:20px}
.qa{animation:fadeUp .35s both}
.qa-q{display:flex;gap:11px;align-items:flex-start;margin-bottom:11px}
.qa-av{width:24px;height:24px;border-radius:7px;background:var(--ink);color:var(--bg);font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.qa-q p{font-size:15px;font-weight:600;color:var(--ink);line-height:1.45;padding-top:2px}
.qa-a{margin-left:35px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:15px 18px;box-shadow:var(--sh-1)}
/* Legal-analysis drafts read like an opinion: a brand accent rail + roomier set. */
.qa-a.ana{border-left:3px solid var(--brand);padding-left:17px}
.qa-a.err{border-color:var(--bad-line,var(--border));background:var(--bad-soft,var(--surface))}
.qa-a>p{font-size:14.5px;line-height:1.68;color:var(--ink-2)}
.qa-a strong{color:var(--ink);font-weight:600}
/* answer toolbar — label chip + copy */
.qa-a-hd{display:flex;align-items:center;gap:8px;margin:-2px 0 12px;padding-bottom:10px;border-bottom:1px solid var(--border)}
.qa-a-tag{display:inline-flex;align-items:center;gap:5px;font-size:10.5px;font-weight:600;letter-spacing:.02em;padding:3px 9px;border-radius:99px}
.qa-a-tag.ana{color:var(--brand-ink);background:var(--brand-soft);border:1px solid var(--brand-line)}
.qa-a-tag.doc{color:var(--ink-2);background:var(--surface-2);border:1px solid var(--border)}
.qa-copy{margin-left:auto;display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--border);background:var(--surface);color:var(--ink-3);border-radius:8px;cursor:pointer;transition:var(--tr)}
.qa-copy:hover{color:var(--brand-ink);border-color:var(--brand-line);background:var(--brand-soft)}
/* rendered markdown in an answer */
.qa-md{font-size:14.5px;line-height:1.68;color:var(--ink-2)}
.qa-md>*:first-child{margin-top:0}
.qa-md>*:last-child{margin-bottom:0}
.qa-md-p{margin:0 0 10px}
.qa-md strong{color:var(--ink);font-weight:600}
.qa-md em{font-style:italic}
.qa-md code{font-family:var(--mono,monospace);font-size:12.5px;background:var(--surface-2);border:1px solid var(--border);border-radius:5px;padding:1px 5px}
.qa-md-h{font-weight:700;color:var(--ink);line-height:1.35;margin:18px 0 8px}
.qa-md-h1{font-size:16.5px}
.qa-md-h2{font-size:14.5px;padding-bottom:5px;border-bottom:1px solid var(--border)}
.qa-md-h3{font-size:13.5px}
.qa-md-h4{font-size:11px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.06em}
.qa-md-ul,.qa-md-ol{margin:0 0 11px;padding-left:20px;display:flex;flex-direction:column;gap:6px}
.qa-md-ul{list-style:disc}
.qa-md-ol{list-style:decimal}
.qa-md-ul li,.qa-md-ol li{line-height:1.62;padding-left:3px}
.qa-md-ul li::marker{color:var(--brand)}
.qa-md-ol li::marker{color:var(--brand-ink);font-weight:600}
.qa-md-q{margin:0 0 11px;padding:8px 13px;border-left:3px solid var(--brand-line);background:var(--surface-2);border-radius:0 6px 6px 0;color:var(--ink-2);font-style:italic}
.qa-md-hr{border:none;border-top:1px solid var(--border);margin:16px 0}
/* Legal-document text formatting — justified prose + automatic hyphenation, to
   match the Ask analysis (see research.css). Only paragraphs and quoted blocks
   are justified; headings and list markers stay flush-left. */
.qa-md-p,.qa-md-q{text-align:justify;text-justify:inter-word;hyphens:auto;-webkit-hyphens:auto}
/* clickable case citations inside an answer */
.doc-citelink{display:inline;font:inherit;color:var(--brand-ink);background:var(--brand-soft);border:1px solid var(--brand-line);border-radius:5px;padding:0 4px;line-height:1.4;cursor:pointer;transition:var(--tr)}
.doc-citelink:hover{background:var(--brand);color:#fff}
/* authority drawer — same details/look as the Ask page (research.css isn't loaded here) */
@keyframes slideIn{from{transform:translateX(40px);opacity:.4}to{transform:none;opacity:1}}
.drawer-scrim{position:fixed;inset:0;background:rgba(20,18,30,.42);backdrop-filter:blur(2px);z-index:120;display:flex;justify-content:flex-end;animation:fadeIn .18s both}
.drawer{width:min(480px,94vw);height:100%;background:var(--surface);border-left:1px solid var(--border-2);box-shadow:var(--sh-pop);overflow-y:auto;padding:22px 26px 40px;animation:slideIn .26s cubic-bezier(.4,0,.2,1) both}
.dr-top{display:flex;align-items:center;gap:10px;margin-bottom:18px}
.dr-court{font-size:12.5px;color:var(--ink-2);font-weight:500}
.dr-x{margin-left:auto;width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--ink-2);transition:var(--tr)}
.dr-x:hover{background:var(--surface-2);color:var(--ink)}
.dr-title{font-size:21px;font-weight:700;letter-spacing:-.02em;line-height:1.22;color:var(--ink);overflow-wrap:break-word}
.dr-cite{font-size:13px;color:var(--ink-2);margin-top:6px;overflow-wrap:anywhere}
.goodlaw{display:flex;align-items:center;gap:12px;border-radius:var(--r-md);padding:13px 15px;margin:18px 0;border:1px solid}
.goodlaw.ok{background:var(--ok-soft);border-color:var(--ok-line)}
.goodlaw.warn{background:var(--warn-soft);border-color:var(--warn-line)}
.goodlaw.bad{background:var(--bad-soft);border-color:var(--bad-line)}
.gl-ico{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}
.goodlaw.ok .gl-ico{background:var(--ok)}
.goodlaw.warn .gl-ico{background:var(--warn)}
.goodlaw.bad .gl-ico{background:var(--bad)}
.gl-tx{display:flex;flex-direction:column;gap:1px}
.gl-tx b{font-size:14.5px;color:var(--ink)}
.gl-tx span{font-size:12px;color:var(--ink-2);line-height:1.4}
.authrow{display:flex;align-items:center;gap:10px;border-radius:var(--r-md);padding:11px 14px;margin:14px 0;border:1px solid var(--border)}
.authrow.binding{background:var(--brand-soft);border-color:var(--brand-line)}
.authrow-lvl{font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;flex-shrink:0;color:var(--ink)}
.authrow.binding .authrow-lvl{color:var(--brand-ink)}
.authrow-why{font-size:12.5px;color:var(--ink-2);line-height:1.4}
.dr-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px 18px;padding:16px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.dr-f{display:flex;flex-direction:column;gap:3px}
.dr-fl{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3)}
.dr-f span:last-child{font-size:13.5px;color:var(--ink);font-weight:500}
.dr-sec{margin-top:18px}
.dr-sl{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);margin-bottom:7px}
.dr-sec p{font-size:14px;line-height:1.6;color:var(--ink-2)}
.dr-quote{margin:0;padding:11px 14px;border-left:3px solid var(--brand-line);background:var(--brand-soft);border-radius:0 var(--r-sm) var(--r-sm) 0;font-size:14px;line-height:1.6;color:var(--ink);font-style:italic}
.dr-chips{display:flex;flex-wrap:wrap;gap:7px}
.dr-chip{font-size:11.5px;color:var(--ink-2);background:var(--surface-2);border:1px solid var(--border);padding:3px 9px;border-radius:99px}
.src-chip{display:inline-flex;align-items:center;gap:5px;cursor:pointer;text-decoration:none;transition:var(--tr)}
.src-chip:hover{color:var(--brand-ink);background:var(--brand-soft);border-color:var(--brand-line)}
.dr-actions{display:flex;gap:10px;margin-top:24px}
.dr-actions .btn{flex:1}
.dr-verified{display:flex;align-items:center;justify-content:center;gap:7px;font-size:11px;color:var(--ok);margin-top:16px}
.qa-cites{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:13px;padding-top:12px;border-top:1px solid var(--border)}
.qa-cite{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--brand-ink);background:var(--brand-soft);border:1px solid var(--brand-line);padding:3px 9px;border-radius:99px}
.qa-grounded{display:flex;align-items:center;gap:5px;font-size:10.5px;color:var(--ok);margin-left:auto}
.qa-applied{display:flex;align-items:center;gap:5px;font-size:10.5px;color:var(--warn);margin-left:auto}
.qa-law{display:flex;align-items:center;gap:7px;flex-wrap:wrap;margin-top:11px}
.qa-lawchip{display:inline-flex;align-items:center;gap:5px;font-size:11px;color:var(--ink-2);background:var(--surface-2);border:1px solid var(--border);padding:3px 9px;border-radius:99px;cursor:pointer;transition:var(--tr);text-decoration:none}
.qa-lawchip:hover{color:var(--brand-ink);background:var(--brand-soft);border-color:var(--brand-line)}
.qa-hint{font-size:12.5px;color:var(--ink-3);text-align:center;padding:8px 0 4px}
.qa-reask{display:inline-flex;align-items:center;gap:6px;margin-top:11px;font-size:11.5px;color:var(--brand-ink);background:var(--brand-soft);border:1px solid var(--brand-line);padding:6px 11px;border-radius:99px;transition:var(--tr)}
.qa-reask:hover:not(:disabled){background:var(--brand);color:#fff}
.qa-reask:disabled{opacity:.5;cursor:default}
.qa-pending{display:flex;align-items:flex-start;gap:11px;font-size:12.5px;color:var(--ink-3)}
.qa-pending .qtab-spin{margin-top:1px;flex:none}
.qa-pending-tx{display:flex;flex-direction:column;gap:3px;min-width:0}
.qa-pending-tx b{font-size:13px;font-weight:600;color:var(--ink-2)}
.qa-pending-tx span{font-size:11.5px;color:var(--ink-3);line-height:1.5}
.tx-caret{display:inline-block;width:7px;height:14px;margin-left:2px;vertical-align:-2px;background:var(--brand);border-radius:1px;animation:txblink 1s step-end infinite}
@keyframes txblink{50%{opacity:0}}
.qtab-spin{display:inline-block;width:14px;height:14px;flex-shrink:0;border-radius:50%;border:2px solid var(--brand-soft);border-top-color:var(--brand);animation:docrot .7s linear infinite}
@keyframes docrot{to{transform:rotate(360deg)}}

.doc-modes{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:10px}
.doc-modeseg{display:inline-flex;background:var(--surface-2);border:1px solid var(--border);border-radius:99px;padding:3px}
.dm-pill{font-size:12.5px;font-weight:500;color:var(--ink-2);padding:6px 14px;border-radius:99px;transition:var(--tr)}
.dm-pill.on{background:var(--surface);color:var(--brand-ink);box-shadow:var(--sh-1)}
.doc-side{font-size:12px;color:var(--ink-2);background:var(--surface);border:1px solid var(--border);border-radius:99px;padding:6px 12px;cursor:pointer;max-width:240px}
.doc-lenses{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:11px}
.doc-lens{font-size:12.5px;color:var(--brand-ink);background:var(--brand-soft);border:1px solid var(--brand-line);padding:7px 13px;border-radius:99px;transition:var(--tr)}
.doc-lens:hover:not(:disabled){background:var(--brand);color:#fff}
.doc-lens:disabled{opacity:.5;cursor:default}
.doc-ask{display:flex;gap:10px;background:var(--surface);border:1.5px solid var(--border-2);border-radius:var(--r-md);padding:9px 9px 9px 16px;box-shadow:var(--sh-1);transition:var(--tr)}
.doc-ask:focus-within{border-color:var(--brand);box-shadow:var(--sh-1),0 0 0 4px var(--brand-soft)}
.doc-ask-in{flex:1;border:none;outline:none;background:none;font-size:14.5px}
.doc-ask-in::placeholder{color:var(--ink-3)}

/* merged single-column document workspace (replaces the two-column doc-split) */
.doc-merged{max-width:940px;margin:0 auto;padding:26px 32px 56px;display:flex;flex-direction:column;gap:18px}
@media(max-width:700px){.doc-merged{padding:18px 14px 44px}}
.doc-merged .doccard{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px;box-shadow:var(--sh-1)}
.doc-setcount{font-size:11px;color:var(--ink-3);letter-spacing:.04em;margin-bottom:-6px}
.doc-cardsum{font-size:14px;line-height:1.6;margin-top:6px}
/* acting-for row */
.doc-actingfor{display:flex;align-items:center;gap:10px;margin-bottom:2px}
.af-l{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3)}
/* the five options (Chat + four lenses) */
.doc-opts{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:11px}
.doc-opt{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600;color:var(--ink-2);background:var(--surface-2);border:1px solid var(--border);padding:7px 13px;border-radius:99px;cursor:pointer;transition:var(--tr)}
.doc-opt:hover:not(:disabled){border-color:var(--brand-line);color:var(--brand-ink)}
.doc-opt.on{background:var(--brand);color:#fff;border-color:var(--brand)}
.doc-opt:disabled{opacity:.5;cursor:default}
.doc-opt svg{flex-shrink:0}

/* document-reading progress — a real % readout that never looks frozen */
.docprog-wrap{max-width:440px;margin:24px auto 0}
.docprog{display:flex;flex-direction:column;gap:9px}
.docprog-track{height:7px;border-radius:99px;background:var(--surface-2);overflow:hidden}
.docprog-fill{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--brand-line),var(--brand));transition:width .25s ease}
.docprog-meta{display:flex;justify-content:space-between;gap:12px;font-size:11.5px;color:var(--ink-3)}
.docprog-meta b{color:var(--brand-ink);font-weight:700;font-variant-numeric:tabular-nums}

/* collapsible "Clauses detected" — minimised by default to keep the card compact */
.doc-clausesec{margin-top:16px}
.doc-cltoggle{display:flex;align-items:center;gap:7px;width:100%;margin:0;padding:0;background:none;border:none;cursor:pointer;color:var(--ink-3)}
.doc-cltoggle:hover{color:var(--brand-ink)}
.doc-clcount{font-size:10px;font-weight:700;color:var(--brand);background:var(--brand-soft);border-radius:99px;padding:1px 7px}
.doc-clausesec .doc-clauses{margin-top:10px}

/* dedicated, full-width space for the answer/output (neater, roomier) */
.doc-merged .qa-q{margin-left:0}
.doc-merged .qa-a{margin-left:0;padding:18px 22px;border-radius:var(--r-lg)}
.doc-merged .qa-md{font-size:14.5px;line-height:1.72}
.doc-merged .qa-md-p{margin:0 0 12px}

/* ============ Case Diary ============ */
.diary-split{max-width:1240px;margin:0 auto;padding:26px 28px 56px;display:grid;grid-template-columns:320px 1fr;gap:26px;align-items:start}
@media(max-width:920px){.diary-split{grid-template-columns:1fr}}
.matters{display:flex;flex-direction:column;gap:9px}
.matters-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.matters-head h3{font-size:18px;font-weight:700;letter-spacing:-.01em;color:var(--ink);display:flex;align-items:center;gap:8px}
.matters-head h3 .mono{font-size:12px;color:var(--ink-3);background:var(--surface-3);padding:2px 8px;border-radius:99px;font-weight:500}
.matter{text-align:left;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:14px 15px;transition:var(--tr);position:relative}
.matter:hover{border-color:var(--border-2);box-shadow:var(--sh-1)}
.matter.on{border-color:var(--brand-line);box-shadow:0 0 0 3px var(--brand-soft);background:color-mix(in oklch,var(--brand-soft),var(--surface) 55%)}
.matter-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:6px}
.matter-title{font-size:14.5px;font-weight:600;color:var(--ink);letter-spacing:-.01em;line-height:1.3}
.matter-st{flex-shrink:0;margin-top:1px;font-size:9.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:2px 7px;border-radius:99px}
.matter-st.act{color:var(--ink-2);background:var(--surface-3)}
.matter-st.urg{color:var(--bad);background:var(--bad-soft);border:1px solid var(--bad-line)}
.matter-meta{font-size:11px;color:var(--ink-3);margin-bottom:9px}
.matter-next{font-size:11.5px;color:var(--ink-2);display:flex;align-items:center;gap:6px;line-height:1.4}
.matter-next svg{color:var(--brand);flex-shrink:0}
.matter-next b{color:var(--ink);font-weight:600}

.matter-detail{min-width:0}
.md-head{padding-bottom:18px;border-bottom:1px solid var(--border)}
.md-meta{display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin-bottom:12px}
.md-title{font-size:clamp(1.5rem,2.4vw,2rem);font-weight:700;letter-spacing:-.02em;color:var(--ink)}
.md-sub{font-size:13.5px;color:var(--ink-2);margin-top:6px}
.md-next{display:flex;align-items:center;gap:15px;background:var(--brand-soft);border:1px solid var(--brand-line);border-radius:var(--r-md);padding:14px 16px;margin:20px 0}
.mn-date{display:flex;flex-direction:column;align-items:center;justify-content:center;width:52px;height:52px;border-radius:12px;background:var(--brand);color:#fff;flex-shrink:0}
.mn-d{font-size:20px;font-weight:700;line-height:1}
.mn-mo{font-size:9.5px;letter-spacing:.04em;margin-top:2px;text-transform:uppercase}
.mn-w{font-size:14.5px;font-weight:600;color:var(--ink)}
.mn-f{font-size:11.5px;color:var(--brand-ink);margin-top:2px}

.md-cols{display:grid;grid-template-columns:1.1fr 1fr;gap:28px;margin-top:8px}
@media(max-width:720px){.md-cols{grid-template-columns:1fr}}
.md-col-h{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);font-family:var(--mono);margin-bottom:13px}
.timeline{display:flex;flex-direction:column}
.tl-item{display:flex;gap:13px;padding-bottom:18px;position:relative}
.tl-item:not(:last-child)::before{content:"";position:absolute;left:5px;top:14px;bottom:-4px;width:1.5px;background:var(--border)}
.tl-dot{width:11px;height:11px;border-radius:50%;border:2px solid var(--border-2);background:var(--surface);flex-shrink:0;margin-top:3px;z-index:1}
.tl-item.up .tl-dot{border-color:var(--brand);background:var(--brand)}
.tl-item.done .tl-dot{border-color:var(--ok-line);background:var(--ok)}
.tl-t{font-size:13.5px;font-weight:500;color:var(--ink);line-height:1.4}
.tl-item.done .tl-t{color:var(--ink-2)}
.tl-d{font-size:11px;color:var(--ink-3);margin-top:2px}

.tasks{display:flex;flex-direction:column;gap:7px}
.task{display:flex;align-items:center;gap:10px;font-size:13.5px;color:var(--ink);cursor:pointer;padding:5px 0}
.tk-box{width:18px;height:18px;border-radius:6px;border:1.5px solid var(--border-2);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;transition:var(--tr)}
.task.done .tk-box{background:var(--ok);border-color:var(--ok)}
.task.done{color:var(--ink-3);text-decoration:line-through}

.saved-list{display:flex;flex-direction:column;gap:9px}
.saved{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:13px 14px;transition:var(--tr)}
.saved:hover{border-color:var(--brand-line);background:var(--brand-soft);transform:translateX(3px)}
.saved-ic{width:34px;height:34px;border-radius:9px;background:var(--brand-soft);color:var(--brand);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.saved-ic svg{width:17px;height:17px}
.saved-ic.add{background:var(--surface-2);color:var(--ink-3)}
.saved-t{font-size:13.5px;font-weight:600;color:var(--ink);line-height:1.35}
.saved-m{font-size:10.5px;color:var(--ink-3);margin-top:2px}
.saved.add{border-style:dashed}

/* ===== responsive hardening (Documents + Diary) ===== */
.doc-split>*,.diary-split>*,.md-cols>*{min-width:0}
.doc-panel,.matters{overscroll-behavior:contain}
.qa-q p,.qa-a,.matter-title,.md-title,.saved-t{overflow-wrap:anywhere}
@media(max-width:680px){
  .doc-split{padding:18px 14px 44px}
  .diary-split{padding:18px 14px 44px}
  .doc-panel{position:static}            /* don't pin the side panel when stacked */
  .result-bar{flex-wrap:wrap}
}
@media(max-width:520px){
  .md-next{flex-wrap:wrap}
  .md-next .btn{margin-left:0!important}
  .doc-ask{flex-wrap:wrap}
  .doc-ask .btn{flex:1}
}

/* ── on-point precedents (Document Intelligence) ─────────────────────────── */
.doc-precedents{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px 20px;box-shadow:var(--sh-1);margin-top:16px}
.dp-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.dp-title{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:var(--ink)}
.dp-sub{font-size:10.5px;font-weight:500;color:var(--ink-3)}
.dp-find{padding:6px 12px}
.dp-hint{font-size:12px;color:var(--ink-3);margin:10px 0 0;line-height:1.55}
.dp-issue{font-size:12.5px;color:var(--ink-2);margin:10px 0 0;line-height:1.5}
.dp-issue b{color:var(--ink);font-weight:600}
.dp-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,400px),1fr));gap:14px;margin-top:14px}
.dp-card{text-align:left;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);padding:14px 15px;display:flex;flex-direction:column;gap:8px;cursor:pointer;transition:var(--tr)}
.dp-card:hover{border-color:var(--brand-line);box-shadow:var(--sh-2);transform:translateY(-2px)}
.dp-card-top{display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.dp-bench{font-size:9.5px;font-weight:600;color:var(--ink-2);background:var(--surface);border:1px solid var(--border-2);padding:1px 6px;border-radius:5px}
.dp-dot{width:8px;height:8px;border-radius:50%;flex:none;background:var(--ok)}
.dp-dot.warn{background:var(--warn)}
.dp-dot.bad{background:var(--bad)}
.dp-status{font-size:10px;font-weight:600}
.dp-status.ok{color:var(--ok)}.dp-status.warn{color:var(--warn)}.dp-status.bad{color:var(--bad)}
.dp-court{font-size:10.5px;color:var(--ink-3);margin-left:auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dp-card-title{font-size:13.5px;font-weight:600;color:var(--ink);line-height:1.4;overflow-wrap:anywhere}
.dp-card-cite{font-size:10.5px;color:var(--brand-ink)}
.dp-block{display:flex;flex-direction:column;gap:2px}
.dp-lbl{font-size:9px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3)}
.dp-text{font-size:12px;color:var(--ink-2);line-height:1.5;overflow-wrap:break-word;word-break:break-word}
.dp-quote{margin:0;font-size:12px;font-style:italic;color:var(--ink-2);line-height:1.5;padding-left:9px;border-left:2px solid var(--brand-line);overflow-wrap:break-word;word-break:break-word}
.dp-clamp2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.dp-clamp3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.dp-clamp4{display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}
.dp-disp{display:inline-block;font-size:10.5px;font-weight:600;color:var(--ok);background:var(--ok-soft);border:1px solid var(--ok-line);border-radius:5px;padding:2px 8px}
.dp-chips{display:flex;flex-wrap:wrap;gap:5px}
.dp-chip{font-size:10px;color:var(--ink-2);background:var(--surface);border:1px solid var(--border-2);border-radius:5px;padding:1px 7px}
.dp-card-meta{display:flex;align-items:center;gap:6px;font-size:10.5px;color:var(--ink-3);margin-top:2px;flex-wrap:wrap}
.dp-open{margin-left:auto;display:inline-flex;align-items:center;gap:3px;color:var(--brand-ink);font-weight:600}

/* ── grounded-analysis answer: verified references + document flags ───────── */
.qa-flags{margin:12px 0 0;border:1px solid var(--warn-line);background:var(--warn-soft);border-radius:var(--r-md);padding:10px 12px}
.qa-flags-h{display:flex;align-items:center;gap:6px;font-size:10px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--warn);margin-bottom:6px}
.qa-flag{font-size:12.5px;color:var(--ink-2);line-height:1.5;padding:3px 0;border-top:1px dashed var(--warn-line)}
.qa-flag:first-of-type{border-top:none}
.doc-reflink{display:inline;border:none;background:none;padding:0 1px;margin:0;font:inherit;font-weight:700;font-size:.8em;vertical-align:.3em;color:var(--brand-ink);cursor:pointer;line-height:0}
.doc-reflink:hover{text-decoration:underline}
.qa-note{display:flex;align-items:center;gap:6px;margin:10px 0 0;font-size:11.5px;color:var(--ink-3)}
.qa-refs{margin:14px 0 0}
.qa-refs-h{display:flex;align-items:center;gap:6px;font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);margin-bottom:8px}
.qa-reflist{display:flex;flex-direction:column;gap:10px}
.qa-ref{text-align:left;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:12px 14px;display:flex;flex-direction:column;gap:6px;cursor:pointer;transition:var(--tr)}
.qa-ref:hover{border-color:var(--brand-line);box-shadow:var(--sh-2);transform:translateY(-1px)}
.qa-ref-top{display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.qa-ref-n{flex:none;display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;font-size:10.5px;font-weight:700;color:#fff;background:var(--brand)}
.qa-ref-title{font-size:13.5px;font-weight:600;color:var(--ink);line-height:1.4;overflow-wrap:break-word;word-break:break-word}
.qa-ref-cite{font-weight:500;color:var(--brand-ink)}
.qa-ref-why{font-size:12.5px;color:var(--ink);line-height:1.55;overflow-wrap:break-word;word-break:break-word}
.qa-ref-why b{font-weight:600}
.qa-ref-hold{font-size:12px;color:var(--ink-2);line-height:1.5}
.qa-ref-hold .dp-lbl{display:inline;margin-right:5px}
.qa-ref-meta{display:flex;align-items:center;gap:6px;font-size:10.5px;color:var(--ink-3);flex-wrap:wrap}
