:root{--bg:#f3f4f6;--paper:#fff;--text:#111827;--muted:#6b7280;--line:#e5e7eb;--me:#2563eb;--meText:#fff;--dji:#fff;--djiBorder:#d1d5db;--note:#fff7ed;--noteBorder:#fed7aa;--shadow:0 20px 50px #1118271f}*{box-sizing:border-box}body{background:radial-gradient(circle at top left, #2563eb1f, transparent 28rem), var(--bg);color:var(--text);margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.45}.page{max-width:900px;margin:0 auto;padding:28px 16px 56px}.case-header{border:1px solid var(--line);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffd1;border-radius:24px;margin-bottom:18px;padding:22px}.eyebrow{letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:8px;font-size:12px;font-weight:800}h1{margin:0 0 8px;font-size:clamp(26px,4vw,42px);line-height:1.05}.summary{color:#374151;max-width:72ch;margin:0;font-size:16px}.resource-links{flex-wrap:wrap;gap:10px;margin-top:18px;display:flex}.resource-link{color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe;border-radius:999px;align-items:center;gap:8px;padding:9px 12px;font-size:13px;font-weight:800;text-decoration:none;display:inline-flex}.resource-link:hover{background:#dbeafe;border-color:#93c5fd}.legend{color:var(--muted);flex-wrap:wrap;gap:10px;margin-top:16px;font-size:13px;display:flex}.pill{border:1px solid var(--line);background:#f9fafb;border-radius:999px;align-items:center;gap:7px;padding:6px 10px;font-weight:650;display:inline-flex}.chat-shell{background:var(--paper);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:28px;overflow:hidden}.chat-topbar{z-index:2;border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe0;justify-content:space-between;align-items:center;gap:12px;padding:14px 18px;display:flex;position:sticky;top:0}.chat-title{font-weight:850}.chat-subtitle{color:var(--muted);font-size:13px}.chat-actions{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}button,.link-button{border:1px solid var(--line);color:#111827;font:inherit;cursor:pointer;background:#fff;border-radius:999px;padding:7px 11px;font-size:13px;font-weight:750;text-decoration:none}button:hover,.link-button:hover{background:#f9fafb;border-color:#cbd5e1}.chat-window{padding:20px 16px 28px}.date-separator{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;align-items:center;gap:12px;margin:22px 0;font-size:13px;font-weight:800;display:flex}.date-separator:before,.date-separator:after{content:"";background:var(--line);flex:1;height:1px}.narrator{background:var(--note);border:1px solid var(--noteBorder);color:#7c2d12;border-radius:16px;max-width:720px;margin:14px auto;padding:12px 14px;font-size:14px}.message-row{margin:9px 0;padding-inline:6px;display:flex}.message-row.dji{justify-content:flex-start}.message-row.me{justify-content:flex-end}.bubble-wrap{flex-direction:column;min-width:0;max-width:min(68%,620px);display:flex}.message-row.dji .bubble-wrap{align-items:flex-start}.message-row.me .bubble-wrap{align-items:flex-end}.speaker{color:var(--muted);align-items:center;gap:7px;margin:0 8px 5px;font-size:12px;font-weight:850;display:flex}.message-row.me .speaker{justify-content:flex-end}.source-icon{border:1px solid var(--line);background:#f3f4f6;border-radius:999px;justify-content:center;align-items:center;width:20px;height:20px;font-size:12px;line-height:1;display:inline-flex}.bubble{overflow-wrap:anywhere;word-break:normal;border-radius:16px;width:fit-content;max-width:100%;padding:8px 10px;display:block;position:relative;box-shadow:0 1px 2px #0000000d}.message-row.dji .bubble{background:var(--dji);border:1px solid var(--djiBorder);border-top-left-radius:8px}.message-row.me .bubble{background:var(--me);color:var(--meText);border-top-right-radius:8px}.bubble-text{white-space:pre-wrap;margin:0;font-size:14.5px}.source-button{opacity:.9;border-radius:999px;align-items:center;margin-left:7px;padding:2px 6px;font-size:10px;line-height:1.15;display:inline-flex;transform:translateY(-1px)}.message-row.me .source-button{color:#eff6ff;background:#ffffff24;border-color:#ffffff59}.message-row.me .source-button:hover{background:#ffffff38}dialog{border:0;border-radius:24px;width:min(880px,100vw - 24px);padding:0;overflow:hidden;box-shadow:0 30px 90px #00000052}dialog::backdrop{background:#0f172a9e}.modal-head{border-bottom:1px solid var(--line);background:#fff;justify-content:space-between;align-items:center;gap:12px;padding:16px 18px;display:flex}.modal-title{font-weight:850}.modal-subtitle{color:var(--muted);margin-top:2px;font-size:13px}.modal-body{background:#f9fafb;max-height:76vh;padding:18px;overflow:auto}.source-card{border:1px solid var(--line);background:#fff;border-radius:18px;margin-bottom:14px;padding:16px}.source-card h3{margin:0 0 8px;font-size:15px}.source-card p{color:#374151;margin:0 0 8px}.screenshot-placeholder{text-align:center;color:#334155;background:linear-gradient(135deg,#f8fafc,#e0f2fe);border:1px solid #cbd5e1;border-radius:18px;place-items:center;min-height:360px;padding:20px;display:grid}.source-image{border:1px solid var(--line);border-radius:14px;max-width:100%;display:block}pre{white-space:pre-wrap;word-break:break-word;color:#e5e7eb;background:#0f172a;border-radius:14px;padding:14px;font-size:13px;overflow:auto}.field-list{gap:8px;margin-top:10px;font-size:14px;display:grid}.field{border-bottom:1px solid #f3f4f6;grid-template-columns:110px 1fr;gap:10px;padding-bottom:7px;display:grid}.field strong{color:var(--muted)}.rendered-email{white-space:pre-wrap}@media print{:root{--text:#000;--muted:#1f2937;--line:#9ca3af;--me:#fff;--meText:#000;--dji:#fff;--djiBorder:#6b7280;--note:#fff;--noteBorder:#9a3412}body{color:#000;-webkit-print-color-adjust:exact;print-color-adjust:exact;background:#fff}.page{max-width:100%;padding:0}.case-header,.chat-shell{box-shadow:none;border-color:#6b7280}.case-header,.chat-shell,.bubble,.narrator,.pill{background:#fff}.summary,.legend,.eyebrow,.chat-subtitle,.speaker,.narrator{color:#431407;border-color:#9a3412}.message-row.me .bubble,.message-row.dji .bubble{color:#000;background:#fff;border:1px solid #374151}.source-icon{color:#000;background:#fff;border-color:#6b7280}.date-separator{color:#111827}.date-separator:before,.date-separator:after{background:#6b7280}.chat-topbar,.source-button,.chat-actions{display:none}.message-row{break-inside:avoid}}@media (width<=640px){.bubble-wrap{max-width:86%}.chat-window{padding-inline:8px}.chat-topbar{flex-direction:column;align-items:flex-start}.field{grid-template-columns:1fr}}
