:root{
  --bg:#f6f5f1;
  --paper:#ffffff;
  --ink:#1a1a1a;
  --ink-soft:#2b2b2b;
  --muted:#6b6b6b;
  --line:#e5e3dc;
  --line-strong:#c9c6bd;
  --brand:#0a7d42;
  --brand-soft:#e8f3ec;
  --accent:#b45309;
  --code-bg:#f1efea;

  /* dark mockup palette (matches app's dark mode) */
  --d-bg:#0b0f14;
  --d-panel:#121821;
  --d-panel-2:#0f141c;
  --d-line:#1f2937;
  --d-line-2:#2a3545;
  --d-text:#e5e7eb;
  --d-muted:#94a3b8;
  --d-brand:#10b981;
  --d-amber:#f59e0b;
  --d-blue:#3b82f6;
  --d-yellow:#eab308;
  --d-orange:#f97316;
  --d-purple:#a855f7;
  --d-emerald:#10b981;
  --d-red:#ef4444;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:'Instrument Sans',ui-sans-serif,system-ui,sans-serif;font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased}
code,kbd{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:0.88em;background:var(--code-bg);padding:1px 6px;border-radius:4px}
.kbd{border:1px solid var(--line-strong);background:#fff;box-shadow:0 1px 0 var(--line-strong);padding:0 6px;border-radius:4px;font-size:0.82em}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}

.shell{display:grid;grid-template-columns:260px 1fr;max-width:1280px;margin:0 auto;gap:0;background:var(--paper);min-height:100vh;border-left:1px solid var(--line);border-right:1px solid var(--line)}
.toc{position:sticky;top:0;align-self:start;height:100vh;overflow:auto;padding:28px 18px 28px 24px;border-right:1px solid var(--line);background:#fbfaf6}
.toc-brand{display:flex;gap:10px;align-items:center;margin-bottom:14px;color:inherit;text-decoration:none;border-radius:6px;padding:2px;transition:background .15s}
.toc-brand:hover{background:#f0ede5;text-decoration:none}
.toc-download{display:inline-flex;align-items:center;gap:6px;margin-bottom:16px;padding:7px 11px;font-size:12px;font-weight:600;color:var(--ink-soft);background:#fff;border:1px solid var(--line);border-radius:6px;cursor:pointer;transition:background .15s,border-color .15s}
.toc-download:hover{background:#f0ede5;border-color:#d6d1c1}
.toc-download svg{flex-shrink:0}
.toc-brand .logo{width:32px;height:32px;background:var(--brand);color:#fff;border-radius:7px;display:grid;place-items:center}
.toc-brand .logo svg{width:18px;height:18px}
.toc-brand .name{font-weight:700;letter-spacing:-0.01em}
.toc-brand .sub{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:0.08em}
.toc .doc-title{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:0.1em;margin:18px 4px 6px}
.toc a{display:block;padding:5px 10px;border-radius:5px;color:var(--ink-soft);font-size:13.5px}
.toc a:hover{background:#f0ede5;text-decoration:none}
.toc a.sub{padding-left:22px;color:var(--muted);font-size:12.5px}
.toc .version{margin-top:28px;font-size:11px;color:var(--muted);padding-top:16px;border-top:1px solid var(--line)}

.main{padding:56px 56px 120px;min-width:0;overflow-wrap:break-word}
.eyebrow{font-size:11px;letter-spacing:0.15em;text-transform:uppercase;color:var(--brand);font-weight:600;margin-bottom:8px}
h1.doc{font-size:36px;line-height:1.15;letter-spacing:-0.02em;margin:0 0 14px;font-weight:700}
.lede{font-size:17px;color:var(--ink-soft);max-width:62ch}
section{margin-top:46px;scroll-margin-top:20px}
.sec-head{display:flex;align-items:baseline;gap:14px;margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid var(--line)}
.sec-head .num{font-size:13px;font-weight:600;color:var(--brand);letter-spacing:0.04em}
.sec-head h2{margin:0;font-size:26px;letter-spacing:-0.015em;font-weight:700}
h3{font-size:18px;margin:28px 0 8px;letter-spacing:-0.01em}
h4{font-size:14.5px;margin:20px 0 6px;letter-spacing:-0.005em}
p{margin:10px 0}
ol.steps{padding-left:22px}
ol.steps li{margin:5px 0}
ul{padding-left:22px}
ul li{margin:4px 0}

.callout{border-left:3px solid var(--brand);background:var(--brand-soft);padding:12px 16px;margin:16px 0;border-radius:0 6px 6px 0;font-size:14px}
.callout.warn{border-left-color:var(--accent);background:#fdf4e6}
.callout.note{border-left-color:#2563eb;background:#eef4ff}

figure.shot{margin:18px 0 6px;padding:0}
figure.shot figcaption{font-size:12.5px;color:var(--muted);margin-top:8px;text-align:center}

/* mockup canvas look — dark panel with subtle frame */
.mock{background:var(--d-bg);border:1px solid var(--line-strong);border-radius:10px;overflow:hidden;color:var(--d-text);font-size:13px;line-height:1.45;box-shadow:0 1px 0 var(--line),0 20px 40px -28px rgba(0,0,0,0.25)}
.mock-chrome{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#0a0f17;border-bottom:1px solid var(--d-line)}
.mock-chrome .dot{width:10px;height:10px;border-radius:50%;background:#374151}
.mock-chrome .url{margin-left:12px;font-size:11.5px;color:#64748b;font-family:ui-monospace,Menlo,Consolas,monospace}
.mock-topbar{display:flex;align-items:center;gap:22px;padding:12px 18px;border-bottom:1px solid var(--d-line);background:#0e141d}
.mock-topbar .brand{display:flex;align-items:center;gap:8px;font-weight:700;color:#fff}
.mock-topbar .brand .sq{width:22px;height:22px;background:var(--d-brand);border-radius:5px;display:grid;place-items:center;color:#0b0f14;font-size:12px;font-weight:900}
.mock-topbar nav{display:flex;gap:18px;color:var(--d-muted);font-size:13px}
.mock-topbar nav .on{color:var(--d-text);position:relative}
.mock-topbar nav .on:after{content:"";position:absolute;left:0;right:0;bottom:-14px;height:2px;background:var(--d-brand);border-radius:2px}
.mock-topbar .spacer{flex:1}
.mock-topbar .pill{font-size:11px;padding:3px 10px;border:1px solid var(--d-line-2);border-radius:999px;color:var(--d-muted)}
.mock-topbar .avatar{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,#10b981,#3b82f6)}

.mock-body{padding:18px}
.mock-h{font-size:20px;font-weight:700;margin:0 0 4px;letter-spacing:-0.01em;color:#fff}
.mock-sub{color:var(--d-muted);font-size:12.5px;margin-bottom:14px}

.kpi-row{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:14px}
.kpi{background:var(--d-panel);border:1px solid var(--d-line);border-radius:8px;padding:12px 14px}
.kpi .l{font-size:11px;color:var(--d-muted);text-transform:uppercase;letter-spacing:0.05em}
.kpi .v{font-size:22px;font-weight:700;color:#fff;margin-top:2px}
.kpi .d{font-size:11px;color:var(--d-emerald);margin-top:2px}
.kpi.red .d{color:var(--d-red)}

.grid-2{display:grid;grid-template-columns:1.35fr 1fr;gap:12px}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.grid-6{display:grid;grid-template-columns:repeat(6,1fr);gap:10px}

.card{background:var(--d-panel);border:1px solid var(--d-line);border-radius:8px;padding:14px}
.card h4{margin:0 0 10px;font-size:13px;color:#fff;letter-spacing:0}
.row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--d-line);font-size:12.5px}
.row:last-child{border-bottom:none}
.tag{display:inline-block;font-size:10.5px;padding:2px 8px;border-radius:999px;font-weight:600;letter-spacing:0.03em}
.tag.amber{background:rgba(245,158,11,.15);color:#fbbf24}
.tag.blue{background:rgba(59,130,246,.15);color:#60a5fa}
.tag.yellow{background:rgba(234,179,8,.15);color:#facc15}
.tag.orange{background:rgba(249,115,22,.15);color:#fb923c}
.tag.purple{background:rgba(168,85,247,.15);color:#c084fc}
.tag.emerald{background:rgba(16,185,129,.15);color:#34d399}
.tag.red{background:rgba(239,68,68,.15);color:#f87171}
.tag.gray{background:rgba(148,163,184,.15);color:#cbd5e1}

.stage-card{background:var(--d-panel);border:1px solid var(--d-line);border-radius:8px;padding:14px;position:relative;overflow:hidden}
.stage-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px}
.stage-card.amber:before{background:var(--d-amber)}
.stage-card.blue:before{background:var(--d-blue)}
.stage-card.yellow:before{background:var(--d-yellow)}
.stage-card.orange:before{background:var(--d-orange)}
.stage-card.purple:before{background:var(--d-purple)}
.stage-card.emerald:before{background:var(--d-emerald)}
.stage-card .name{font-size:12px;color:var(--d-muted);text-transform:uppercase;letter-spacing:0.06em}
.stage-card .big{font-size:28px;font-weight:700;color:#fff;line-height:1}
.stage-card .small{font-size:11px;color:var(--d-muted);margin-top:6px}

table.mtable{width:100%;border-collapse:collapse;font-size:12.5px}
table.mtable th,table.mtable td{text-align:left;padding:8px 10px;border-bottom:1px solid var(--d-line)}
table.mtable th{font-weight:600;color:var(--d-muted);font-size:11px;text-transform:uppercase;letter-spacing:0.05em;background:#0d121b}
table.mtable tbody tr:hover{background:#0f1722}

.btn{display:inline-flex;align-items:center;gap:6px;font-size:12px;padding:6px 12px;border-radius:6px;border:1px solid var(--d-line-2);color:var(--d-text);background:var(--d-panel)}
.btn.primary{background:var(--d-brand);color:#042116;border-color:transparent;font-weight:600}
.btn.warn{background:#7c2d12;color:#fed7aa;border-color:transparent}
.btn.ghost{background:transparent}

/* permission matrix */
table.matrix{width:100%;border-collapse:collapse;font-size:12px;margin-top:10px}
table.matrix th,table.matrix td{border:1px solid var(--line);padding:7px 8px;text-align:center}
table.matrix th{background:#faf8f2;color:var(--ink-soft);font-weight:600;font-size:11px}
table.matrix td.role{text-align:left;font-weight:600;background:#fbfaf6;color:var(--ink)}
table.matrix td.y{color:var(--brand);font-weight:700}
table.matrix td.n{color:#c9c6bd}

.faq .q{border-top:1px solid var(--line);padding:14px 0}
.faq .q h4{margin:0 0 4px;font-size:14.5px;color:var(--ink)}
.faq .q p{margin:0;color:var(--ink-soft);font-size:14px}

dl.glossary{display:grid;grid-template-columns:180px 1fr;gap:6px 18px;margin:12px 0}
dl.glossary dt{font-weight:600;color:var(--ink);grid-column:1}
dl.glossary dd{margin:0;color:var(--ink-soft);grid-column:2}

/* Filament-style light panel for admin shots */
.fila{background:#f8f8f7;border:1px solid var(--line-strong);border-radius:10px;overflow:hidden;color:#1f2937;box-shadow:0 1px 0 var(--line),0 20px 40px -28px rgba(0,0,0,0.25)}
.fila-top{display:flex;align-items:center;gap:10px;padding:10px 14px;background:#fff;border-bottom:1px solid #e5e7eb}
.fila-top .logo{width:22px;height:22px;background:#f59e0b;border-radius:6px;display:grid;place-items:center;color:#fff;font-weight:800;font-size:11px}
.fila-top .t{font-weight:700}
.fila-layout{display:grid;grid-template-columns:220px 1fr}
.fila-side{background:#fff;border-right:1px solid #e5e7eb;padding:14px 10px;font-size:13px;min-height:420px}
.fila-side .g{font-size:10px;text-transform:uppercase;color:#9ca3af;letter-spacing:0.08em;padding:10px 8px 4px}
.fila-side a{display:block;padding:6px 10px;border-radius:6px;color:#374151}
.fila-side a.on{background:#fef3c7;color:#7c2d12;font-weight:600}
.fila-main{padding:18px 22px;background:#f8f8f7}
.fila-h{font-size:18px;font-weight:700;color:#111827;margin:0 0 2px}
.fila-sub{font-size:12px;color:#6b7280;margin-bottom:14px}
.fila-table{background:#fff;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}
.fila-toolbar{display:flex;gap:8px;align-items:center;padding:10px;border-bottom:1px solid #e5e7eb;background:#fff}
.fila-toolbar input{flex:1;padding:6px 10px;border:1px solid #e5e7eb;border-radius:6px;font-size:13px;background:#f9fafb}
.fila-toolbar .btn{background:#f59e0b;color:#fff;border:none;font-weight:600;padding:6px 12px;border-radius:6px;font-size:12px}
.fila-table table{width:100%;border-collapse:collapse;font-size:13px}
.fila-table th{text-align:left;padding:10px 12px;background:#fafafa;color:#6b7280;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:0.04em;border-bottom:1px solid #e5e7eb}
.fila-table td{padding:11px 12px;border-bottom:1px solid #f3f4f6}
.fila-table tr:last-child td{border-bottom:none}
.chip{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600;background:#fef3c7;color:#92400e}
.chip.green{background:#dcfce7;color:#14532d}
.chip.gray{background:#f3f4f6;color:#374151}
.chip.red{background:#fee2e2;color:#991b1b}
.chip.blue{background:#dbeafe;color:#1e3a8a}

.fila-form{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:18px 22px}
.fila-form .fgrid{display:grid;grid-template-columns:1fr 1fr;gap:14px 18px}
.fila-form label{font-size:12px;font-weight:600;color:#374151;display:block;margin-bottom:4px}
.fila-form .inp{padding:7px 10px;border:1px solid #d1d5db;border-radius:6px;font-size:13px;background:#fff;color:#111827}
.fila-form .full{grid-column:1/-1}
.fila-form .fft{display:flex;gap:10px;justify-content:flex-end;margin-top:18px;padding-top:14px;border-top:1px solid #f3f4f6}

.print-break{page-break-before:always}

@media print{
  body{background:#fff}
  .shell{display:block;max-width:none;border:none}
  .toc{display:none}
  .main{padding:0}
  section{margin-top:24px}
  figure.shot{break-inside:avoid}
  .mock,.fila{break-inside:avoid;box-shadow:none}
  a{color:var(--ink)}
  h1.doc{font-size:28px}
}
