/* FurnFlow documentation — shared styles for the multi-page docs site (/docs/). */

/* Self-hosted Inter (variable, latin) — no third-party Google Fonts request. */
@font-face {
  font-family: "Inter";
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("/fonts/inter-latin.woff2") format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: "Inter";
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("/fonts/inter-latin-ext.woff2") format("woff2");
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

:root{
  --bg:#F6F8FC; --surface:#FFFFFF; --surface-2:#F8FAFC; --ink:#0B1124; --ink-2:#1E293B;
  --muted:#475569; --muted-2:#64748B; --line:#E2E8F0; --line-2:#EEF2F7;
  --brand:#2563EB; --brand-d:#1D4ED8; --brand-soft:#EEF2FF; --accent:#4F46E5; --violet:#7C3AED;
  --good:#16A34A; --good-soft:#DCFCE7; --warn:#F59E0B; --warn-soft:#FEF3C7;
  --bad:#DC2626; --bad-soft:#FEE2E2; --info:#0EA5E9; --info-soft:#E0F2FE;
  --radius:14px; --radius-sm:9px; --shadow:0 8px 24px rgba(15,23,42,.08);
  --shadow-lg:0 24px 60px rgba(15,23,42,.14); --grad:linear-gradient(135deg,var(--brand),var(--accent) 55%,var(--violet));
  --side-w:300px; --top-h:60px; --max:880px;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:80px}
body{margin:0;font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;background:var(--bg);color:var(--ink);line-height:1.64;font-size:15.5px;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{line-height:1.22;letter-spacing:-.02em;color:var(--ink);margin:0}
strong{color:var(--ink-2);font-weight:700}
code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.85em;background:#0f172a;color:#e2e8f0;padding:.1em .42em;border-radius:6px;white-space:nowrap}
kbd{font-family:ui-monospace,Menlo,monospace;font-size:.8em;background:#1e293b;color:#f8fafc;border-radius:6px;padding:2px 7px;border:1px solid #334155}

/* Top bar */
.topbar{position:sticky;top:0;z-index:50;height:var(--top-h);display:flex;align-items:center;gap:14px;padding:0 20px;
  background:rgba(255,255,255,.85);backdrop-filter:saturate(180%) blur(12px);-webkit-backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:16px;color:var(--ink);white-space:nowrap}
.brand img{width:30px;height:30px;border-radius:8px;display:block}
.brand .tag{font-weight:600;font-size:11px;color:#fff;background:var(--grad);padding:3px 8px;border-radius:99px;letter-spacing:.04em}
.topbar .search{flex:1;max-width:440px;margin-left:8px;position:relative}
.topbar .search input{width:100%;border:1px solid var(--line);border-radius:10px;padding:9px 12px 9px 34px;font:inherit;font-size:14px;background:var(--surface-2)}
.topbar .search input:focus{outline:none;border-color:var(--brand);background:#fff;box-shadow:0 0 0 3px var(--brand-soft)}
.topbar .search::before{content:"⌕";position:absolute;left:11px;top:50%;transform:translatey(-50%);color:var(--muted-2);font-size:16px}
.topbar .search .results{position:absolute;top:46px;left:0;right:0;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-lg);padding:6px;display:none;max-height:60vh;overflow:auto;z-index:60}
.topbar .search .results.open{display:block}
.topbar .search .results a{display:block;padding:8px 12px;border-radius:8px;color:var(--ink);font-size:13.5px}
.topbar .search .results a:hover,.topbar .search .results a.hl{background:var(--brand-soft);text-decoration:none}
.topbar .search .results .grp{font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--muted-2);padding:8px 12px 2px}
.topbar .search .results .empty{padding:12px;color:var(--muted-2);font-size:13px}
.topbar .spacer{flex:1}
.topbar .open-app{background:var(--grad);color:#fff;font-weight:600;font-size:13.5px;padding:9px 16px;border-radius:10px;white-space:nowrap}
.topbar .open-app:hover{text-decoration:none;filter:brightness(1.05)}
.menu-btn{display:none;width:40px;height:40px;border:1px solid var(--line);background:var(--surface-2);border-radius:9px;font-size:18px;align-items:center;justify-content:center;cursor:pointer;color:var(--ink)}

/* Layout */
/* minmax(0,1fr) (not bare 1fr) prevents the content track from blowing out to
   the grid item's min-content — without it, wide children like tables with
   min-width:480px push .main wider than the viewport on phones. */
.layout{display:grid;grid-template-columns:var(--side-w) minmax(0,1fr);align-items:start}
.sidebar{position:sticky;top:var(--top-h);height:calc(100vh - var(--top-h));overflow-y:auto;border-right:1px solid var(--line);padding:18px 12px 70px;background:var(--surface)}
.sidebar .grp{font-size:11px;font-weight:800;letter-spacing:.07em;text-transform:uppercase;color:var(--muted-2);margin:16px 10px 4px}
.sidebar .grp:first-child{margin-top:0}
.sidebar a.pg{display:block;color:var(--muted);font-size:13.8px;font-weight:600;padding:6px 10px;border-radius:8px}
.sidebar a.pg:hover{color:var(--ink);background:var(--surface-2);text-decoration:none}
.sidebar a.pg.active{color:var(--brand);background:var(--brand-soft)}
.sidebar .sub{margin:2px 0 4px 10px;border-left:2px solid var(--line);padding-left:8px;display:flex;flex-direction:column}
.sidebar .sub a{color:var(--muted);font-size:12.8px;font-weight:500;padding:4px 8px;border-radius:6px}
.sidebar .sub a:hover{color:var(--ink);background:var(--surface-2);text-decoration:none}
.sidebar .sub a.active{color:var(--brand);font-weight:600}

.main{min-width:0;padding:30px clamp(20px,5vw,60px) 110px;max-width:calc(var(--max) + 120px);margin:0 auto}
.content{max-width:var(--max)}
.crumbs{font-size:12.5px;color:var(--muted-2);margin-bottom:12px}
.crumbs a{color:var(--muted)}
.eyebrow{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--brand);background:var(--brand-soft);padding:5px 11px;border-radius:99px;margin-bottom:14px}
.main h1{font-size:clamp(28px,4.2vw,40px);margin-bottom:8px}
.main h2{font-size:clamp(21px,2.8vw,27px);scroll-margin-top:80px;margin-top:38px;padding-top:18px;border-top:1px solid var(--line-2);display:flex;align-items:center;gap:10px}
.main h2:first-of-type{border-top:0;padding-top:0;margin-top:26px}
.main h3{font-size:17.5px;margin:24px 0 8px}
.main h4{font-size:12px;margin:18px 0 6px;color:var(--muted-2);text-transform:uppercase;letter-spacing:.05em;font-weight:800}
.main p{margin:10px 0}
.lead{font-size:18px;color:var(--muted);margin:6px 0 16px;line-height:1.55}
.main ul,.main ol{margin:10px 0;padding-left:22px}
.main li{margin:5px 0}
.main li::marker{color:var(--muted-2)}

.where{display:inline-flex;flex-wrap:wrap;align-items:center;gap:6px;font-size:13px;font-weight:600;background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:7px 12px;margin:6px 0 14px;color:var(--ink-2)}
.where .crumb{color:var(--muted)}
.where .sep{color:var(--muted-2)}
.where b{color:var(--brand)}

.callout{display:flex;gap:12px;border:1px solid var(--line);border-left-width:4px;border-radius:10px;padding:13px 16px;margin:16px 0;background:var(--surface);font-size:14.2px}
.callout .ci{font-size:18px;line-height:1.4;flex-shrink:0}
.callout.note{border-left-color:var(--info);background:var(--info-soft)}
.callout.tip{border-left-color:var(--good);background:var(--good-soft)}
.callout.warn{border-left-color:var(--warn);background:var(--warn-soft)}
.callout.role{border-left-color:var(--violet);background:#F5F3FF}
.callout p{margin:0}.callout p+p{margin-top:6px}

.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin:16px 0}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px}
.card .h{font-weight:700;font-size:14.5px;margin-bottom:4px;display:flex;align-items:center;gap:8px}
.card p{font-size:13.5px;color:var(--muted);margin:0}
.card a{font-weight:600}

/* Hub: page grid */
.hub-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:14px;margin:18px 0}
.hub-card{display:block;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;transition:border-color .15s,transform .15s,box-shadow .15s}
.hub-card:hover{border-color:var(--brand);transform:translateY(-3px);box-shadow:var(--shadow);text-decoration:none}
.hub-card .ic{font-size:22px}
.hub-card .t{font-weight:800;font-size:16px;margin:8px 0 4px;color:var(--ink)}
.hub-card .d{font-size:13.3px;color:var(--muted)}
.hub-card .links{margin-top:8px;font-size:12.5px;color:var(--muted-2)}

.flow{display:flex;flex-wrap:wrap;align-items:stretch;gap:0;margin:18px 0;border:1px solid var(--line);border-radius:var(--radius);padding:18px 14px;background:var(--surface)}
.flow-step{flex:1 1 130px;min-width:118px;text-align:center;position:relative;padding:6px 14px}
.flow-step:not(:last-child)::after{content:"→";position:absolute;right:-7px;top:18px;color:var(--brand);font-weight:800;font-size:16px}
.flow-step .n{width:34px;height:34px;margin:0 auto 8px;border-radius:50%;background:var(--grad);color:#fff;font-weight:800;display:flex;align-items:center;justify-content:center;font-size:14px;box-shadow:0 6px 16px rgba(37,99,235,.3)}
.flow-step .t{font-weight:700;font-size:13.5px}
.flow-step .d{font-size:12px;color:var(--muted);margin-top:3px;line-height:1.4}

.states{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin:14px 0}
.states .s{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:99px;font-size:12.5px;font-weight:700;background:var(--surface-2);border:1px solid var(--line);color:var(--ink-2)}
.states .arr{color:var(--muted-2);font-weight:800}
.states .s.start{background:var(--brand-soft);border-color:#c7d2fe;color:var(--brand-d)}
.states .s.good{background:var(--good-soft);border-color:#bbf7d0;color:#166534}
.states .s.warn{background:var(--warn-soft);border-color:#fde68a;color:#92400e}
.states .s.bad{background:var(--bad-soft);border-color:#fecaca;color:#991b1b}
.states .branch{font-size:12px;color:var(--muted-2);width:100%;margin-top:2px}

.b{display:inline-block;padding:1px 8px;border-radius:99px;font-size:11.5px;font-weight:700;background:var(--surface-2);border:1px solid var(--line);color:var(--ink-2);white-space:nowrap}
.b.blue{background:var(--brand-soft);border-color:#c7d2fe;color:var(--brand-d)}
.b.green{background:var(--good-soft);border-color:#bbf7d0;color:#166534}
.b.amber{background:var(--warn-soft);border-color:#fde68a;color:#92400e}
.b.red{background:var(--bad-soft);border-color:#fecaca;color:#991b1b}
.b.violet{background:#F5F3FF;border-color:#ddd6fe;color:#6d28d9}

.tbl-wrap{overflow-x:auto;margin:16px 0;border:1px solid var(--line);border-radius:var(--radius)}
table.doc-table{width:100%;border-collapse:collapse;font-size:13.5px;min-width:480px}
table.doc-table th,table.doc-table td{text-align:left;padding:10px 14px;border-bottom:1px solid var(--line-2);vertical-align:top}
table.doc-table th{background:var(--surface-2);font-weight:700;color:var(--ink-2);font-size:12px;text-transform:uppercase;letter-spacing:.03em}
table.doc-table tr:last-child td{border-bottom:0}
table.doc-table td code{font-size:.82em}
table.doc-table td:first-child{white-space:nowrap}

ol.steps{counter-reset:st;list-style:none;padding:0;margin:16px 0}
ol.steps>li{counter-increment:st;position:relative;padding:4px 0 14px 42px;margin:0}
ol.steps>li::before{content:counter(st);position:absolute;left:0;top:0;width:28px;height:28px;border-radius:50%;background:var(--ink);color:#fff;font-weight:700;font-size:13px;display:flex;align-items:center;justify-content:center}
ol.steps>li:not(:last-child)::after{content:"";position:absolute;left:13.5px;top:30px;bottom:2px;width:1.5px;background:var(--line)}
ol.steps>li b{display:block;margin-bottom:1px}

/* FAQ */
.faq{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;margin:16px 0}
.faq details{border-bottom:1px solid var(--line-2)}
.faq details:last-child{border-bottom:0}
.faq summary{cursor:pointer;padding:13px 16px;font-weight:700;font-size:14.5px;list-style:none;display:flex;justify-content:space-between;gap:12px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--brand);font-weight:800}
.faq details[open] summary::after{content:"−"}
.faq .a{padding:0 16px 14px;color:var(--muted);font-size:14px}
.faq .a p{margin:6px 0}

/* prev / next */
.page-foot{display:flex;justify-content:space-between;gap:12px;margin-top:46px;padding-top:22px;border-top:1px solid var(--line);flex-wrap:wrap}
.page-foot a{flex:1 1 220px;border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;color:var(--ink);background:var(--surface)}
.page-foot a:hover{border-color:var(--brand);text-decoration:none;box-shadow:var(--shadow)}
.page-foot .lbl{font-size:11.5px;color:var(--muted-2);font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.page-foot .t{font-weight:700;margin-top:2px}
.page-foot .next{text-align:right}

@media (max-width:980px){
  :root{--side-w:0px}
  .menu-btn{display:inline-flex}
  .layout{grid-template-columns:minmax(0,1fr)}
  .sidebar{position:fixed;top:var(--top-h);left:0;width:310px;max-width:86vw;height:calc(100dvh - var(--top-h));z-index:45;transform:translateX(-105%);transition:transform .22s ease;box-shadow:var(--shadow-lg)}
  body.nav-open .sidebar{transform:translateX(0)}
  .scrim{position:fixed;inset:var(--top-h) 0 0 0;background:rgba(15,23,42,.4);z-index:44;opacity:0;visibility:hidden;transition:opacity .2s}
  body.nav-open .scrim{opacity:1;visibility:visible}
  .topbar .open-app{padding:8px 12px;font-size:12.5px}
  /* Force .main to honor the grid track on phones. Without width:100%+max-width
     +overflow-x:hidden, a child .tbl-wrap with overflow-x:auto still leaks the
     inner table's min-width:480px up the chain (Chrome's auto-min-content rule
     doesn't transitively clamp grandchildren), so .main grows to ~528px and
     the whole page scrolls horizontally. The hidden overflow is the safety
     net — .tbl-wrap keeps its own overflow-x:auto so wide tables still scroll
     locally, just inside a properly-sized container. */
  .main{padding:24px 18px 80px;width:100%;max-width:100%;min-width:0;overflow-x:hidden}
  .content{min-width:0;max-width:100%}
  .tbl-wrap{max-width:100%;min-width:0}
}
@media (max-width:560px){
  /* The topbar packs menu + brand + search + a flex:1 spacer + the CTA. On
     phones the spacer and the flex:1 search split the leftover room 50/50,
     crushing the search to ~48px. Drop the spacer here so the (now uncapped)
     search fills the row and the CTA still anchors right; tighten gaps/padding
     to claw back space for the field. */
  .brand .tag{display:none}
  .topbar{gap:9px;padding:0 13px}
  .topbar .search{max-width:none;margin-left:2px}
  .topbar .spacer{display:none}
  .topbar .open-app{padding:8px 11px}
}
@media (max-width:430px){
  /* Logo-only brand frees the last sliver so the search placeholder fits. */
  .brand span{display:none}
  .topbar .open-app{padding:8px 10px;font-size:12px}
}
