
/* ═══════ AI INTAKE ═══════ */
.intake-overlay{position:fixed;top:var(--header-h);left:0;right:0;bottom:var(--footer-h);z-index:90;background:var(--cream);display:none;flex-direction:column}
.intake-overlay.open{display:flex}
.intake-body{flex:1;overflow-y:auto;display:flex;gap:0;min-height:0}
.intake-list-pane{width:var(--sf-list-w,300px);flex-shrink:0;border-right:1px solid var(--border);background:#fff;display:flex;flex-direction:column;overflow-y:auto;transition:width .2s ease}
.intake-detail-pane{flex:1;overflow-y:auto;padding:24px;min-width:0}
/* Drag-to-resize handles between columns. A thin grab strip; its divider line
   shows on hover/drag. Width persists (see restoreColWidths). */
.sf-col-resizer{flex:0 0 8px;align-self:stretch;min-height:48px;cursor:col-resize;position:relative;background:transparent;z-index:6}
.sf-col-resizer::before{content:"";position:absolute;top:0;bottom:0;left:50%;transform:translateX(-50%);width:1px;background:transparent;transition:width .12s,background .12s}
.sf-col-resizer:hover::before,.sf-col-resizer.dragging::before{width:3px;background:var(--gold)}
body.sf-resizing,body.sf-resizing *{cursor:col-resize!important;user-select:none!important}
body.sf-resizing .intake-list-pane{transition:none}
.intake-body.list-collapsed .sf-col-resizer[data-resize="list"]{display:none}
.intake-detail-cols:not(.split) .sf-col-resizer[data-resize="case"]{display:none}
@media(max-width:760px){.sf-col-resizer{display:none}}
/* Split layout — dock the case/info section to a sticky left column so a long
   tab list scrolls beside an always-visible drag source. */
.intake-detail-cols{display:block}
.intake-detail-cols.split{display:flex;gap:6px;align-items:flex-start}
.intake-detail-cols.split .intake-col-left{width:var(--sf-case-w,320px);flex-shrink:0;position:sticky;top:0;max-height:calc(100vh - var(--header-h) - var(--footer-h) - 48px);overflow-y:auto;padding-right:6px}
.intake-detail-cols.split .intake-col-right{flex:1;min-width:0}
/* In split mode the case panel is a quick, temporary dock: no fold control,
   and drop the divider line above the documents so it reads clean. */
.intake-fold-left{display:none}
.intake-detail-cols.split #intakeDocsSection{border-top:none;margin-top:0;padding-top:0}
.intake-split-toggle{flex-shrink:0;background:none;border:none;cursor:pointer;color:var(--ink-faint);padding:3px;border-radius:6px;display:inline-flex;align-items:center;transition:color .12s,background .12s}
.intake-split-toggle:hover{color:var(--gold);background:var(--gold-faint)}
.intake-split-toggle.active{color:var(--gold);background:var(--gold-faint)}
.intake-list-head{padding:16px 16px 8px;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-faint);display:flex;align-items:center;justify-content:space-between;gap:8px}
.intake-fold-btn{display:flex;align-items:center;justify-content:center;width:26px;height:26px;flex-shrink:0;border:none;background:none;border-radius:7px;color:var(--ink-faint);cursor:pointer;transition:background .12s,color .12s}
.intake-fold-btn:hover{background:var(--cream);color:var(--ink)}
/* Folded state: collapse the list pane and reveal a slim rail to reopen it */
.intake-unfold-btn{display:none;flex-direction:column;align-items:center;gap:8px;width:38px;flex-shrink:0;padding:16px 0;border:none;border-right:1px solid var(--border);background:#fff;color:var(--ink-faint);cursor:pointer;transition:background .12s,color .12s}
.intake-unfold-btn:hover{background:var(--cream);color:var(--gold)}
.intake-unfold-label{writing-mode:vertical-rl;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase}
.intake-body.list-collapsed .intake-list-pane{width:0;min-width:0;border-right:none;overflow:hidden;opacity:0}
.intake-body.list-collapsed .intake-unfold-btn{display:flex}
.intake-client-row-wrap{position:relative}
.intake-client-actions{position:absolute;top:0;bottom:0;right:10px;display:none;align-items:center;gap:3px}
.intake-client-row-wrap:hover .intake-client-actions{display:flex}
.intake-client-act{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;border:none;background:#fff;border-radius:6px;color:var(--ink-faint);cursor:pointer;padding:0;box-shadow:0 1px 3px rgba(26,25,22,.16);transition:color .12s,background .12s}
.intake-client-act:hover{color:var(--ink);background:var(--cream)}
.intake-client-act.del:hover{color:var(--red)}
.intake-client-row{display:flex;align-items:center;gap:11px;padding:11px 16px;cursor:grab;border:none;background:none;width:100%;text-align:left;font-family:'DM Sans',sans-serif;border-left:3px solid transparent;transition:background .12s,border-color .12s}
.intake-client-row:hover{background:var(--gold-faint);border-left-color:var(--client-color,var(--gold))}
.intake-client-row.active{background:var(--gold-faint);border-left-color:var(--client-color,var(--gold))}
.intake-client-row.client-dragging{opacity:.4;cursor:grabbing}
.intake-client-row.client-drag-over{box-shadow:inset 0 3px 0 -1px var(--gold)}
.intake-client-row.client-drag-over-below{box-shadow:inset 0 -3px 0 -1px var(--gold)}
.intake-avatar{width:38px;height:38px;border-radius:50%;flex-shrink:0;object-fit:cover;background:var(--gold-faint);display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--gold);font-size:14px;overflow:hidden;box-shadow:0 0 0 1px rgba(26,25,22,.04) inset}
.intake-avatar img{width:100%;height:100%;object-fit:cover}
.intake-client-row-info{min-width:0;flex:1}
.intake-client-row-name{font-size:14px;color:var(--ink);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.intake-client-row-sub{font-size:12px;color:var(--ink-faint)}
/* Case sub-rows under each client in the list */
.intake-case-list{padding:0 0 6px}
.intake-case-row{display:flex;align-items:center;gap:8px;padding:6px 16px 6px 49px;cursor:pointer;border:none;background:none;width:100%;text-align:left;font-family:'DM Sans',sans-serif;font-size:12.5px;color:var(--ink-muted);border-left:3px solid transparent;transition:background .12s}
.intake-case-row:hover{background:var(--gold-faint)}
.intake-case-row.active{background:var(--gold-faint);border-left-color:var(--gold);color:var(--ink)}
.intake-case-row::before{content:"";width:4px;height:4px;border-radius:50%;background:var(--gold);flex-shrink:0;opacity:.5}
.intake-case-row-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.intake-case-row-none{padding:4px 16px 6px 49px;font-size:11.5px;color:var(--ink-faint);font-style:italic}
/* New client button */
.intake-new-client-btn{display:flex;align-items:center;justify-content:center;gap:7px;margin:8px 14px 16px;padding:10px 14px;border-radius:9px;border:1.5px dashed var(--border-strong);background:transparent;color:var(--ink-muted);font-family:'DM Sans',sans-serif;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}
.intake-new-client-btn:hover{border-color:var(--gold);color:var(--gold);background:var(--gold-faint)}
/* Left-column footer — brand, Settings, legal (replaces the old top header/footer) */
.intake-pane-footer{margin-top:auto;padding:14px 14px 16px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:4px}
.intake-pane-brand{display:inline-flex;align-items:center;gap:4px;background:none;border:none;cursor:pointer;padding:0;font-family:'DM Sans',sans-serif;font-size:11px;font-weight:500;color:var(--ink-faint);transition:color .12s;-webkit-tap-highlight-color:transparent}
.intake-pane-brand:hover{color:var(--gold)}
.intake-pane-brand svg{flex-shrink:0}
.intake-pane-link{display:flex;align-items:center;gap:9px;background:none;border:none;cursor:pointer;padding:8px 8px;border-radius:8px;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:500;color:var(--ink-muted);transition:background .12s,color .12s;-webkit-tap-highlight-color:transparent}
.intake-pane-link:hover{background:var(--cream);color:var(--ink)}
.intake-pane-link svg{flex-shrink:0;color:var(--ink-faint)}
.intake-pane-legal{display:flex;align-items:center;flex-wrap:wrap;gap:7px;padding:6px 8px 0;font-size:11px;color:var(--ink-faint)}
.intake-pane-legal a{color:var(--ink-faint);text-decoration:none;transition:color .12s}
.intake-pane-legal a:hover{color:var(--gold)}
.intake-empty{padding:40px 24px;text-align:center;color:var(--ink-faint);font-size:13px}
/* Welcome / empty-state hero shown in the right column when no client is selected */
.intake-welcome{max-width:540px;margin:0 auto;padding:44px 24px 48px;text-align:center;display:flex;flex-direction:column;align-items:center}
.intake-welcome-logo{width:128px;height:128px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 36% 30%,var(--gold-faint),#fff 72%);box-shadow:0 14px 38px rgba(184,150,90,.22),inset 0 0 0 1px rgba(184,150,90,.16);margin-bottom:24px;animation:welcomeFloat 5.5s ease-in-out infinite}
@keyframes welcomeFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
.intake-welcome-logo svg{filter:drop-shadow(0 3px 6px rgba(184,150,90,.32))}
.intake-welcome-title{font-family:'Playfair Display',serif;font-size:40px;font-weight:600;color:var(--ink);margin:0 0 8px;letter-spacing:.4px}
.intake-welcome-tagline{font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;color:var(--gold);margin:0 0 18px;text-transform:uppercase;letter-spacing:.16em}
.intake-welcome-intro{font-size:14.5px;color:var(--ink-muted);line-height:1.75;margin:0 0 30px;max-width:450px}
.intake-welcome-features{display:flex;flex-direction:column;gap:11px;width:100%;max-width:430px;margin-bottom:30px;text-align:left}
.intake-welcome-feature{display:flex;align-items:flex-start;gap:13px;padding:14px 16px;background:#fff;border:1px solid var(--border);border-radius:12px;transition:border-color .15s,box-shadow .15s,transform .15s}
.intake-welcome-feature:hover{border-color:rgba(184,150,90,.38);box-shadow:0 5px 16px rgba(26,25,22,.06);transform:translateY(-1px)}
.iwf-icon{flex-shrink:0;width:38px;height:38px;border-radius:10px;background:var(--gold-faint);color:var(--gold);display:flex;align-items:center;justify-content:center}
.iwf-icon.teal{background:var(--teal-light);color:var(--teal)}
.iwf-text{display:flex;flex-direction:column;gap:3px;min-width:0}
.iwf-text b{font-size:14px;font-weight:600;color:var(--ink)}
.iwf-text span{font-size:12.5px;color:var(--ink-faint);line-height:1.55}
.intake-welcome-cta{padding:12px 24px;font-size:14px}
/* ── Auto-playing feature demos on the welcome screen ── */
.intake-welcome-feature{flex-direction:column;align-items:stretch;gap:11px}
.iwf-anim{position:relative;width:100%;height:88px;border-radius:10px;overflow:hidden;background:linear-gradient(180deg,#faf6ee,#fff);border:1px solid var(--border)}
.iwf-scene{position:absolute;inset:0}
/* Card 1 — Organize by case: tagged documents drop into a folder */
.org-folder{position:absolute;left:50%;margin-left:-27px;bottom:13px;width:54px;height:34px;border-radius:5px;background:var(--gold-light);box-shadow:0 3px 9px rgba(184,150,90,.3)}
.org-folder::before{content:"";position:absolute;top:-7px;left:6px;width:23px;height:9px;border-radius:4px 4px 0 0;background:var(--gold-light)}
.org-folder::after{content:"";position:absolute;left:0;right:0;top:0;height:5px;border-radius:5px 5px 0 0;background:rgba(255,255,255,.35)}
.org-doc{position:absolute;left:50%;margin-left:-13px;top:7px;width:26px;height:31px;border-radius:3px;background:#fff;border:1px solid var(--border);border-left:3px solid var(--teal);box-shadow:0 2px 5px rgba(0,0,0,.08);opacity:0;animation:orgDrop 3.3s cubic-bezier(.5,.05,.5,1) infinite}
.org-doc::after{content:"";position:absolute;left:4px;right:5px;top:6px;height:2px;background:var(--border);box-shadow:0 5px 0 var(--border),0 10px 0 var(--border)}
.org-doc.d2{border-left-color:var(--gold);animation-delay:1.1s}
.org-doc.d3{border-left-color:var(--red);animation-delay:2.2s}
@keyframes orgDrop{0%{opacity:0;transform:translateY(-18px) rotate(-5deg)}13%{opacity:1}42%{opacity:1;transform:translateY(20px) rotate(0)}55%{opacity:0;transform:translateY(27px) scale(.82)}100%{opacity:0;transform:translateY(27px) scale(.82)}}
/* Card 2 — Translate: 中文 → English */
.iwf-scene.tr{display:flex;align-items:center;justify-content:center;gap:13px}
.tr-cn{font-family:Georgia,serif;font-size:24px;font-weight:600;color:var(--ink);animation:trCn 3s ease-in-out infinite}
.tr-arrow{color:var(--gold);font-size:19px;animation:trArrow 3s ease-in-out infinite}
.tr-en{font-family:'Playfair Display',serif;font-size:19px;font-weight:600;color:var(--teal);animation:trEn 3s ease-in-out infinite}
@keyframes trCn{0%,28%{opacity:1}55%,100%{opacity:.32}}
@keyframes trArrow{0%,18%{opacity:.4;transform:translateX(0)}42%{opacity:1;transform:translateX(4px)}62%,100%{opacity:.4;transform:translateX(0)}}
@keyframes trEn{0%,28%{opacity:0;transform:translateX(-5px)}55%{opacity:1;transform:translateX(0)}100%{opacity:1;transform:translateX(0)}}
/* Card 3 — Assemble & export: pages stack, then a PDF pops out */
.ex-page{position:absolute;left:50%;top:16px;width:34px;height:44px;margin-left:-17px;background:#fff;border:1px solid var(--border);border-radius:4px;box-shadow:0 2px 6px rgba(0,0,0,.09);opacity:0;animation:exStack 3.2s ease-in-out infinite}
.ex-page::after{content:"";position:absolute;left:5px;right:6px;top:7px;height:2px;background:var(--border);box-shadow:0 5px 0 var(--border),0 10px 0 var(--border),0 15px 0 var(--border)}
.ex-page.p1{--ex-x:-7px;--ex-y:2px;animation-delay:0s}
.ex-page.p2{--ex-x:0px;--ex-y:0px;animation-delay:.16s}
.ex-page.p3{--ex-x:7px;--ex-y:-2px;animation-delay:.32s}
@keyframes exStack{0%{opacity:0;transform:translate(-48px,-4px) rotate(-13deg)}18%{opacity:1}45%,100%{opacity:1;transform:translate(var(--ex-x,0),var(--ex-y,0)) rotate(0)}}
.ex-badge{position:absolute;left:50%;bottom:11px;margin-left:-19px;width:38px;height:17px;border-radius:4px;background:var(--red);color:#fff;font-size:9px;font-weight:700;letter-spacing:.06em;display:flex;align-items:center;justify-content:center;opacity:0;animation:exBadge 3.2s ease-in-out infinite}
@keyframes exBadge{0%,56%{opacity:0;transform:translateY(7px)}72%{opacity:1;transform:translateY(0)}94%,100%{opacity:1;transform:translateY(0)}}
@media (prefers-reduced-motion: reduce){.iwf-anim *{animation:none!important;opacity:1!important;transform:none!important}}
/* Drop / analyze card */
.intake-drop{border:1.5px dashed var(--border-strong);border-radius:14px;background:#fff;padding:20px;margin-bottom:22px;transition:all .15s}
.intake-drop.drag-over{border-color:var(--gold);background:var(--gold-faint)}
.intake-drop-title{font-family:'Playfair Display',serif;font-size:17px;color:var(--ink);margin-bottom:4px}
.intake-drop-sub{font-size:13px;color:var(--ink-muted);margin-bottom:14px}
.intake-textarea{width:100%;min-height:84px;border:1px solid var(--border);border-radius:10px;padding:11px 13px;font-family:'DM Sans',sans-serif;font-size:13.5px;color:var(--ink);resize:vertical;background:var(--cream)}
.intake-textarea:focus{outline:none;border-color:var(--gold)}
.intake-drop-actions{display:flex;gap:10px;align-items:center;margin-top:12px;flex-wrap:wrap}
.intake-btn{display:inline-flex;align-items:center;gap:7px;padding:9px 16px;border-radius:9px;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:500;cursor:pointer;border:none;transition:all .15s}
.intake-btn.primary{background:var(--ink);color:#fff}
.intake-btn.primary:hover{background:#000}
.intake-btn.primary:disabled{opacity:.5;cursor:default}
.intake-btn.ghost{background:transparent;color:var(--ink-muted);border:1px solid var(--border)}
.intake-btn.ghost:hover{background:var(--cream)}
.intake-file-label{display:inline-flex;align-items:center;gap:7px;padding:9px 16px;border-radius:9px;border:1px solid var(--border);background:#fff;cursor:pointer;font-size:13px;color:var(--ink-muted)}
.intake-file-label:hover{border-color:var(--gold)}
.intake-file-label input{display:none}
.intake-file-name{font-size:12.5px;color:var(--teal)}
.intake-spinner{width:15px;height:15px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
/* Profile detail */
/* Right-column sections: basic info card, then cases & documents groups */
.intake-info-card{background:#fff;border:1px solid var(--border);border-radius:14px;padding:18px 20px;box-shadow:var(--shadow);margin-bottom:8px}
.intake-group{padding-top:22px;margin-top:22px;border-top:1px solid var(--border)}
.intake-profile-head{display:flex;gap:18px;align-items:flex-start}
.intake-photo{width:84px;height:84px;border-radius:14px;flex-shrink:0;background:var(--gold-faint);display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:600;color:var(--gold);overflow:hidden;position:relative;cursor:pointer}
.intake-photo img{width:100%;height:100%;object-fit:cover}
.intake-photo-edit{position:absolute;inset:0;background:rgba(0,0,0,.45);color:#fff;font-size:11px;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s}
.intake-photo:hover .intake-photo-edit{opacity:1}
.intake-photo input{display:none}
.intake-profile-fields{flex:1;min-width:0}
.intake-field-name{font-family:'Playfair Display',serif;font-size:24px;color:var(--ink);border:none;background:none;width:100%;padding:2px 0;font-weight:600}
.intake-field-name:focus{outline:none;border-bottom:1px solid var(--gold)}
.intake-field-row{display:flex;gap:8px;align-items:center;margin-top:8px;font-size:13px;color:var(--ink-muted)}
.intake-age-input{width:64px;border:1px solid var(--border);border-radius:7px;padding:5px 8px;font-family:'DM Sans',sans-serif;font-size:13px;color:var(--ink)}
.intake-age-input:focus{outline:none;border-color:var(--gold)}
/* Client basic-info grid: read-only text by default; click a field to edit it */
.intake-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:3px 8px;margin-top:14px}
.intake-info-field{display:flex;flex-direction:column;gap:2px;min-width:0;border-radius:9px;padding:6px 10px;transition:background .12s,box-shadow .12s}
.intake-info-field:hover{background:var(--cream)}
.intake-info-field.editing{background:#fff;box-shadow:0 0 0 1px var(--gold),0 0 0 4px var(--gold-faint)}
.intake-info-field-wide{grid-column:1 / -1}
.intake-info-label{font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-faint)}
.intake-info-view{font-size:14px;color:var(--ink);cursor:pointer;min-height:20px;line-height:1.45;white-space:pre-wrap;word-break:break-word}
.intake-info-view.empty{color:var(--ink-faint)}
.intake-info-input{display:none;border:none;border-radius:0;padding:0;font-family:'DM Sans',sans-serif;font-size:14px;color:var(--ink);background:none;width:100%}
.intake-info-input:focus{outline:none}
.intake-info-input::placeholder{color:var(--ink-faint)}
.intake-info-field.editing .intake-info-view{display:none}
.intake-info-field.editing .intake-info-input{display:block}
select.intake-info-input{cursor:pointer;margin-left:-1px}
textarea.intake-info-input{resize:vertical;min-height:40px;line-height:1.45}
@media(max-width:560px){.intake-info-grid{grid-template-columns:1fr}}
.intake-section-label{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-faint);margin:26px 0 12px;display:flex;align-items:center;justify-content:space-between}
/* Documents header pinned to the top of the scrolling case pane, so the tab
   tools (New tab / Asylum setup / New template / Preview) stay reachable when
   the tab list is long — no scrolling back up. Sits above tab content (z:1) but
   below the colour popover (z:100) and modals. */
.intake-section-label.intake-docs-head{position:sticky;top:0;z-index:10;margin:0 0 10px;padding:14px 0 10px;background:var(--cream);border-bottom:1px solid var(--border)}
/* Collapsible section header (Client info / Cases) */
.intake-section-label .intake-section-title{display:flex;align-items:center;gap:7px;cursor:pointer;user-select:none}
.intake-section-caret{width:16px;height:16px;flex-shrink:0;transition:transform .2s;color:var(--ink-faint)}
.intake-section-title.collapsed .intake-section-caret{transform:rotate(-90deg)}
.intake-section-body.collapsed{display:none}
/* Client name shown in the header only while Client info is folded */
.intake-section-name{font-size:13px;font-weight:500;color:var(--ink);text-transform:none;letter-spacing:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-left:10px;display:none}
.intake-section-title.collapsed + .intake-section-name{display:block}
.intake-case{border:1px solid var(--border);border-radius:13px;background:#fff;padding:16px 18px;margin-bottom:14px}
.intake-case-title{font-family:'Playfair Display',serif;font-size:17px;color:var(--ink);border:none;background:none;width:100%;font-weight:600;padding:1px 0}
.intake-case-title:focus{outline:none;border-bottom:1px solid var(--gold)}
.intake-case-desc{width:100%;border:none;background:none;font-family:'DM Sans',sans-serif;font-size:13.5px;color:var(--ink-muted);resize:vertical;min-height:42px;margin-top:6px;line-height:1.5}
.intake-case-desc:focus{outline:none}
.intake-case-head{display:flex;align-items:flex-start;gap:8px}
.intake-case-del{background:none;border:none;cursor:pointer;color:var(--ink-faint);padding:4px;border-radius:6px;flex-shrink:0}
.intake-case-del:hover{color:var(--red);background:var(--cream)}
.intake-case-docs{margin-top:14px;border-top:1px solid var(--border);padding-top:12px;border-radius:0 0 8px 8px;transition:background .12s,box-shadow .12s}
.intake-case-docs.drag-over{background:var(--gold-faint);box-shadow:inset 0 0 0 2px var(--gold)}
.intake-doc-row{display:flex;align-items:center;gap:10px;padding:7px 9px;border-radius:8px;cursor:pointer;transition:background .12s}
.intake-doc-row:hover{background:var(--cream)}
.intake-doc-icon{width:26px;height:26px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:#fff;flex-shrink:0}
.intake-doc-icon.pdf{background:#C84B3A}.intake-doc-icon.doc{background:#3A5FB8}.intake-doc-icon.img{background:#2D7A47}.intake-doc-icon.txt{background:#5C5A55}
.intake-doc-name{font-size:13px;color:var(--ink);flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.intake-doc-badge{font-size:10px;padding:2px 7px;border-radius:9px;background:var(--teal-light);color:var(--teal);flex-shrink:0}
.intake-doc-grid-label{color:var(--ink-faint);font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;margin-bottom:11px}
.intake-doc-empty{color:var(--ink-faint);font-size:12.5px;padding:2px 0}
.intake-doc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(94px,1fr));gap:8px}
.intake-doc-tile{position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px;padding:11px 7px 9px;border-radius:9px;cursor:grab;transition:background .12s,opacity .12s}
.intake-doc-tile:hover{background:var(--cream)}
.intake-doc-tile:active{cursor:grabbing}
.intake-doc-tile-dragging{opacity:.4}
.intake-doc-tile .intake-doc-icon{width:38px;height:38px;border-radius:8px;font-size:10px}
.intake-doc-tile-name{font-size:12px;font-weight:500;color:var(--ink);width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.intake-doc-tile-time{font-size:10.5px;color:var(--ink-faint);line-height:1.3}
.intake-doc-tile-dot{position:absolute;top:7px;right:9px;width:8px;height:8px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 2px #fff}
.intake-doc-tile-del{position:absolute;top:4px;left:5px;width:19px;height:19px;padding:0;border:none;border-radius:50%;background:rgba(26,25,22,.5);color:#fff;cursor:pointer;display:none;align-items:center;justify-content:center;transition:background .12s}
.intake-doc-tile:hover .intake-doc-tile-del{display:inline-flex}
.intake-doc-tile-del:hover{background:var(--red)}
.intake-case-actions{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}
.intake-case-link{font-size:12.5px;color:var(--gold);font-weight:500;background:none;border:none;cursor:pointer;display:inline-flex;align-items:center;gap:5px;padding:4px 0}
.intake-case-link:hover{text-decoration:underline}
/* Inline Documents module embedded in the right column */
.intake-docs-tools{display:flex;gap:14px;flex-shrink:0}
#intakeDocsSlot{margin-top:2px}
#intakeDocsSlot .cat-group{margin-bottom:14px}
.intake-upload-mini{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;color:var(--ink-muted);border:1px dashed var(--border-strong);border-radius:8px;padding:6px 12px;cursor:pointer}
.intake-upload-mini:hover{border-color:var(--gold);color:var(--gold)}
.intake-upload-mini input{display:none}
.intake-saving{font-size:11px;color:var(--ink-faint);font-style:italic}
/* Draft review */
.intake-draft{border:1px solid var(--gold);border-radius:13px;background:var(--gold-faint);padding:18px 20px;margin-bottom:22px}
.intake-draft-title{font-family:'Playfair Display',serif;font-size:16px;color:var(--ink);margin-bottom:3px}
.intake-draft-sub{font-size:12.5px;color:var(--ink-muted);margin-bottom:14px}
/* Documents-page filter banner */
.doc-filter-banner{display:none;align-items:center;gap:12px;background:var(--ink);color:#fff;border-radius:11px;padding:12px 16px;margin-bottom:16px}
.doc-filter-banner.show{display:flex}
/* On narrow screens the floating hamburger (fixed, top/right 16px, 42px) overlaps
   the content's top-right; reserve space so the clear button stays clickable. */
@media(max-width:932px){.doc-filter-banner{padding-right:62px}}
.doc-filter-banner-text{flex:1;font-size:13.5px;min-width:0}
.doc-filter-banner-text b{color:var(--gold-light)}
.doc-filter-clear{background:rgba(255,255,255,.12);border:none;color:#fff;border-radius:7px;padding:7px 13px;font-size:12.5px;cursor:pointer;font-family:'DM Sans',sans-serif;flex-shrink:0}
.doc-filter-clear:hover{background:rgba(255,255,255,.22)}
.doc-filter-back{display:inline-flex;align-items:center;gap:6px;background:var(--gold);border:none;color:var(--ink);border-radius:7px;padding:7px 13px;font-size:12.5px;font-weight:500;cursor:pointer;font-family:'DM Sans',sans-serif;flex-shrink:0}
.doc-filter-back:hover{background:var(--gold-light)}
.doc-filter-back svg{flex-shrink:0}
.doc-source-chip{font-size:10px;padding:2px 7px;border-radius:9px;background:var(--teal-light);color:var(--teal);margin-left:6px}
@media(max-width:640px){
  .intake-body{flex-direction:column}
  .intake-list-pane{width:100%;border-right:none;border-bottom:1px solid var(--border);max-height:38vh;transition:max-height .2s ease}
  .intake-detail-pane{padding:16px 14px}
  /* Mobile fold: collapse vertically and show a full-width reopen bar */
  .intake-body.list-collapsed .intake-list-pane{width:100%;max-height:0;border-bottom:none;opacity:0}
  .intake-body.list-collapsed .intake-unfold-btn{flex-direction:row;justify-content:center;width:100%;padding:10px 0;border-right:none;border-bottom:1px solid var(--border)}
  .intake-unfold-btn .intake-unfold-label{writing-mode:horizontal-tb}
  .intake-body.list-collapsed .intake-unfold-btn svg{transform:rotate(90deg)}
}
