/* DirectOps / str-agent — shared design system (Phase 7.1).
 *
 * One stylesheet for every server-rendered surface: the operator dashboard
 * (scripts/dashboard.py _page), the login + onboarding-chat pages, the public
 * signup landing (scripts/onboard_routes.py), and the Stripe payment-result
 * pages (scripts/payment_pages.py). Served via the /static mount
 * (CachedStaticFiles, 1-day cache + ETag).
 *
 * Class names are kept identical to the prior inline _STYLE so existing markup
 * is unchanged. Two distinct page containers:
 *   .wrap      — dashboard content column (wide)
 *   .cardpage  — centered narrow card (login / signup / payment result)
 */

/* ── Brand web fonts (self-hosted woff2, OFL). Playfair Display = display /
 *    statements, Inter = body/UI, Inter Tight = the Direct·Ops wordmark.
 *    font-display:swap → render in the fallback immediately, swap on load. ── */
@font-face{font-family:'Playfair Display';font-style:normal;font-weight:600;font-display:swap;src:url(fonts/playfair-600.woff2) format('woff2');}
@font-face{font-family:'Playfair Display';font-style:normal;font-weight:700;font-display:swap;src:url(fonts/playfair-700.woff2) format('woff2');}
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url(fonts/inter-400.woff2) format('woff2');}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url(fonts/inter-500.woff2) format('woff2');}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url(fonts/inter-600.woff2) format('woff2');}
@font-face{font-family:'Inter Tight';font-style:normal;font-weight:600;font-display:swap;src:url(fonts/inter-tight-600.woff2) format('woff2');}
@font-face{font-family:'Inter Tight';font-style:normal;font-weight:700;font-display:swap;src:url(fonts/inter-tight-700.woff2) format('woff2');}

:root {
  /* Brand tokens (approved guide, 2026-06-05): Navy / Brass / Porcelain / Slate /
   * Deep Teal + line + derived tints. New components reference these directly. */
  --navy:#1F1B4F; --navy-900:#17143C; --brass:#BF9F66; --brass-bright:#D4B985;
  --porcelain:#F6F4EF; --porcelain-dim:#E9E5DC; --slate:#5B6670; --teal:#123A3A;
  --line-dark:#2A323D; --line-light:#E4DFD4;
  /* Existing var NAMES kept (markup + tests depend on them); values → brand.
   * --green is the success/active/primary-CTA token; mapped to Deep Teal so Brass
   * (--gold) stays the scarce single accent. --ink → Navy, --bg → Porcelain. */
  --ink:#1F1B4F; --ink-soft:#5B6670; --muted:#7B828C; --faint:#9AA0A8;
  --bg:#F6F4EF; --surface:#fff; --surface-soft:#F1EEE7;
  --border:#E4DFD4; --border-strong:#D8D3C8;
  --link:#123A3A;
  --green:#123A3A; --green-dark:#0E2E2E;
  --red:#C0392B; --red-soft:#e3b9b3; --red-bg:#fdecea; --red-ink:#a5342a;
  --gold:#BF9F66; --warn-bg:#FBF3E0; --warn-border:#E8D6A6; --warn-ink:#6E5410;
  --ok-bg:#E7F0EE; --ok-border:#B9D4CF; --ok-ink:#123A3A;
  --serif:'Playfair Display',Georgia,'Times New Roman',serif;
  --sans:'Inter',-apple-system,system-ui,Segoe UI,Roboto,sans-serif;
  --mono:ui-monospace,SFMono-Regular,Menlo,monospace;
  --r-sm:6px; --r:8px; --r-lg:12px; --r-pill:20px;
  --shadow-sm:0 1px 2px rgba(31,27,79,.05);
  --shadow:0 4px 16px rgba(31,27,79,.08);
  --shadow-lg:0 10px 30px rgba(31,27,79,.12);
  --gap:14px;
}

* { box-sizing:border-box; }
html { -webkit-text-size-adjust:100%; }
body {
  margin:0; background:var(--bg); color:var(--ink);
  font-family:var(--sans); font-size:14px; line-height:1.5;
}
a { color:var(--link); text-decoration:none; }
a:hover { text-decoration:underline; }

:focus-visible { outline:2px solid var(--link); outline-offset:2px; border-radius:4px; }

h1, h2, h3 { color:var(--ink); }
h1.page { font-family:var(--serif); font-weight:500; font-size:22px; margin:0 0 4px; }
h2.page { font-family:var(--serif); font-weight:500; font-size:18px; margin:18px 0 8px; }

/* ── Form controls ──────────────────────────────────────────────────────── */
select, input[type=text], input[type=email], input[type=password], input[type=number], textarea {
  font:inherit; padding:7px 10px; border:1px solid var(--border-strong);
  border-radius:var(--r); background:var(--surface); color:var(--ink);
  transition:border-color .12s ease, box-shadow .12s ease;
}
select:focus, input:focus, textarea:focus {
  outline:none; border-color:var(--brass); box-shadow:0 0 0 3px rgba(191,159,102,.28);
}
textarea { width:100%; min-height:220px; resize:vertical; line-height:1.5; }
label.fld { display:block; font-size:13px; color:var(--ink-soft); margin:14px 0 4px; }

/* ── Header / nav ───────────────────────────────────────────────────────── */
header.top {
  display:flex; align-items:center; gap:20px; padding:14px 24px;
  background:var(--surface); border-bottom:1px solid var(--border);
  position:sticky; top:0; z-index:10; flex-wrap:wrap;
}
.brand { font-family:'Inter Tight',var(--sans); font-size:19px; font-weight:700; letter-spacing:-.01em; }
.brand .wm-d { color:var(--ink); }          /* "Direct" — Navy on light surfaces */
.brand .wm-o { color:var(--brass); }        /* "Ops" — Brass accent */
.brand .wm-dot { color:var(--brass); margin:0 1px; }
.brand.on-dark .wm-d { color:var(--porcelain); }   /* "Direct" → Porcelain on Navy */
header.top nav { display:flex; gap:18px; flex:1; flex-wrap:wrap; }
header.top nav a {
  color:var(--ink-soft); font-weight:500; padding:4px 0;
  transition:color .12s ease, border-color .12s ease;
  display:inline-flex; align-items:center; gap:6px; border-bottom:2px solid transparent;
}
header.top nav a:hover { color:var(--ink); text-decoration:none; }
header.top nav a.active { color:var(--ink); border-bottom-color:var(--gold); }
.navbadge {
  display:inline-block; min-width:18px; text-align:center; background:var(--red);
  color:#fff; font-size:11px; font-weight:700; border-radius:10px; padding:1px 6px;
}
header.top .who { color:var(--muted); font-size:12.5px; margin-left:auto; white-space:nowrap; }

/* ── Page containers ────────────────────────────────────────────────────── */
.wrap { max-width:980px; margin:0 auto; padding:24px; }
.cardpage {
  max-width:560px; margin:8vh auto; padding:40px 32px; background:var(--surface);
  border:1px solid var(--border); border-radius:var(--r-lg); box-shadow:var(--shadow-sm);
}
.cardpage.narrow { max-width:380px; }
.login { max-width:360px; margin:12vh auto; padding:0 20px; }

/* ── Cards ──────────────────────────────────────────────────────────────── */
.card {
  background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg);
  padding:18px 20px; margin-bottom:var(--gap); box-shadow:var(--shadow-sm);
  transition:box-shadow .14s ease, border-color .14s ease;
}
.card.draft:hover, .card.hover:hover { box-shadow:var(--shadow); border-color:#d8d5cf; }
.card h3 { margin:0 0 6px; font-size:15px; }
.toolbar { display:flex; align-items:center; gap:10px; margin:10px 0 16px; flex-wrap:wrap; }
.row { display:flex; gap:10px; align-items:center; flex-wrap:wrap; }
.muted { color:var(--muted); font-size:12.5px; }
.faint { color:var(--faint); }

/* ── Badges / pills ─────────────────────────────────────────────────────── */
.badge {
  display:inline-block; font-size:11px; font-weight:600; color:#fff; border-radius:var(--r-sm);
  padding:2px 8px; text-transform:uppercase; letter-spacing:.3px;
}
.badge.live { background:var(--green); }
.badge.paused { background:#999; }
.pill {
  display:inline-block; font-size:11.5px; border:1px solid var(--border-strong);
  border-radius:var(--r-pill); padding:2px 10px; color:var(--ink-soft); background:var(--surface-soft);
}

/* ── Buttons ────────────────────────────────────────────────────────────── */
.btn {
  display:inline-block; font:inherit; font-weight:600; border:none; border-radius:var(--r);
  padding:8px 14px; cursor:pointer; line-height:1.2;
  transition:filter .12s ease, transform .04s ease, box-shadow .12s ease;
}
.btn:hover { filter:brightness(1.06); text-decoration:none; }
.btn:active { transform:translateY(1px); }
.btn:disabled, .btn[aria-disabled=true] { opacity:.55; cursor:not-allowed; filter:none; transform:none; }
.btn.primary { background:var(--ink); color:#fff; }
.btn.green { background:var(--green); color:#fff; box-shadow:0 1px 2px rgba(30,158,87,.25); }
.btn.red { background:var(--surface); color:var(--red); border:1px solid var(--red-soft); }
.btn.ghost { background:var(--surface); color:var(--ink-soft); border:1px solid var(--border-strong); }
.btn.sm { padding:5px 10px; font-size:12.5px; }
.btn.lg { padding:11px 20px; font-size:15px; }
.btn.link { background:none; border:none; color:var(--red); padding:0; font-weight:600; }

/* ── Tables / quotes ────────────────────────────────────────────────────── */
.body-quote {
  white-space:pre-wrap; background:var(--surface-soft); border:1px solid #eee;
  border-left:3px solid var(--ink); border-radius:var(--r-sm); padding:12px 14px;
  margin:8px 0; font-size:13.5px;
}
table { width:100%; border-collapse:collapse; }
th, td { text-align:left; padding:8px 10px; border-bottom:1px solid #eee; font-size:13px; vertical-align:top; }
th { color:var(--muted); font-weight:600; font-size:11.5px; text-transform:uppercase; letter-spacing:.3px; }

/* key→value detail grid (property overview, etc.) */
.kv { display:grid; grid-template-columns:160px 1fr; gap:6px 16px; font-size:13.5px; }
.kv dt { color:var(--muted); }
.kv dd { margin:0; }
@media (max-width:560px){ .kv { grid-template-columns:1fr; gap:2px 0; } .kv dd { margin-bottom:8px; } }

/* ── Notices ────────────────────────────────────────────────────────────── */
.warn { background:var(--warn-bg); border:1px solid var(--warn-border); border-radius:var(--r); padding:10px 14px; color:var(--warn-ink); font-size:12.5px; margin-bottom:var(--gap); }
.empty { text-align:center; color:var(--faint); padding:56px 20px; font-size:15px; }
.empty .big { font-size:34px; display:block; margin-bottom:10px; opacity:.7; }
.flash { background:var(--ok-bg); border:1px solid var(--ok-border); border-radius:var(--r); padding:10px 14px; color:var(--ok-ink); font-size:13px; margin-bottom:var(--gap); }
.flash.err, .err { background:var(--red-bg); border:1px solid var(--red-soft); border-radius:var(--r); padding:10px 14px; color:var(--red-ink); font-size:13px; margin-bottom:var(--gap); }
.tag { font-size:14px; color:var(--muted); margin-bottom:20px; }
.footer { text-align:center; margin-top:18px; font-size:12px; color:var(--muted); }

/* ── Chat thread (inbox + onboarding + operator) ────────────────────────── */
.thread { display:flex; flex-direction:column; gap:8px; margin:8px 0 2px; }
.msg { max-width:80%; padding:8px 12px; border-radius:13px; font-size:13.5px; white-space:pre-wrap; word-wrap:break-word; }
.msg .meta { font-size:11px; color:#999; margin-bottom:3px; text-transform:none; letter-spacing:0; }
.msg.in { align-self:flex-start; background:#f1f0ec; border:1px solid var(--border); border-bottom-left-radius:3px; }
.msg.out { align-self:flex-end; background:#e8f0fe; border:1px solid #cfe0fb; border-bottom-right-radius:3px; }
.msg.latest-in { box-shadow:0 0 0 2px var(--warn-border); }

fieldset { border:1px solid var(--border); border-radius:10px; padding:12px 14px; margin:0 0 12px; }
legend { font-size:12px; color:var(--muted); padding:0 6px; }
label.chk { display:inline-flex; gap:6px; align-items:center; margin:2px 12px 2px 0; font-size:13px; }

/* monospace reference (payment pages, ids) */
.ref { font-family:var(--mono); font-size:12px; color:var(--muted); margin-top:24px; padding:12px; background:var(--surface-soft); border-radius:var(--r-sm); word-break:break-all; }
.icon { font-size:48px; margin-bottom:16px; }

/* ── Onboarding journey + property pages (Phase 7.2) ────────────────────── */
.steps { display:flex; gap:8px; align-items:center; flex-wrap:wrap; margin:0 0 16px; font-size:12.5px; }
.steps .step { display:inline-flex; align-items:center; gap:6px; color:var(--muted); }
.steps .step .dot { width:20px; height:20px; border-radius:50%; display:inline-flex; align-items:center; justify-content:center; background:#eceae4; color:var(--muted); font-size:11px; font-weight:700; }
.steps .step.done .dot { background:var(--green); color:#fff; }
.steps .step.active { color:var(--ink); font-weight:600; }
.steps .step.active .dot { background:var(--ink); color:#fff; }
.steps .sep { flex:1; height:1px; background:var(--border); min-width:12px; }

.gallery { display:grid; grid-template-columns:repeat(auto-fill,minmax(150px,1fr)); gap:10px; }
.photo { position:relative; aspect-ratio:4/3; border-radius:var(--r); overflow:hidden; border:1px solid var(--border); background:var(--surface-soft); }
.photo img { width:100%; height:100%; object-fit:cover; display:block; }
.photo .del { position:absolute; top:6px; right:6px; background:rgba(0,0,0,.55); color:#fff; border:none; border-radius:6px; padding:3px 8px; font-size:12px; cursor:pointer; }
.photo .del:hover { background:rgba(192,57,43,.9); }
.dropzone { border:2px dashed var(--border-strong); border-radius:var(--r-lg); padding:24px; text-align:center; color:var(--muted); background:var(--surface-soft); }
.gobar { display:flex; align-items:center; gap:12px; flex-wrap:wrap; padding:14px 16px; border-radius:var(--r-lg); border:1px solid var(--border); background:var(--surface-soft); }

/* ── Radio-card chooser (signup product picker, Phase 8) ─────────────────── */
.choices { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin:6px 0 4px; }
@media (max-width:520px){ .choices { grid-template-columns:1fr; } }
.choice { position:relative; }
.choice input { position:absolute; opacity:0; width:0; height:0; }
.choice label { display:block; height:100%; border:1.5px solid var(--border-strong); border-radius:var(--r-lg); padding:14px; cursor:pointer; transition:border-color .12s, box-shadow .12s, background .12s; }
.choice label:hover { border-color:#bdbab2; }
.choice input:checked + label { border-color:var(--green); background:#f3fbf6; box-shadow:0 0 0 3px rgba(30,158,87,.12); }
.choice input:focus-visible + label { box-shadow:0 0 0 3px rgba(37,99,235,.25); }
.choice .t { font-weight:700; font-size:14px; }
.choice .d { color:var(--muted); font-size:12.5px; margin-top:4px; line-height:1.4; }

/* ── Marketing landing (Phase 10) ── */
.section { margin:48px 0; }
.hero { text-align:center; padding:24px 0 8px; }
.hero h1 {
  font-family:var(--serif); font-weight:500; line-height:1.12;
  font-size:clamp(28px,5vw,44px); max-width:760px; margin:0 auto 14px;
}
.hero-ctas { display:flex; gap:12px; flex-wrap:wrap; justify-content:center; }
.grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:var(--gap); }
@media (max-width:560px){ .grid-2 { grid-template-columns:1fr; } }

/* ── Mobile reflow (Phase 10 polish) ──────────────────────────────────────────
   Additive — every rule here is gated behind ≤560px, so desktop rendering is
   byte-for-byte unchanged. Tightens the header + content gutters and stacks form
   controls full-width so forms reflow cleanly on a phone. (.row/.toolbar/nav
   already flex-wrap; this just gives the controls inside them room.) */
@media (max-width:560px){
  .wrap { padding:16px; }
  header.top { padding:12px 16px; gap:8px 14px; }
  header.top nav { flex-basis:100%; gap:10px 14px; }
  header.top .who { margin-left:0; }
  select,
  input[type=text], input[type=email], input[type=password], input[type=number] { width:100%; }
  /* Wide data tables (owner statement, payments) overflow a phone. Contain the
     horizontal scroll INSIDE the card so the page itself never shifts sideways.
     Cards without a wide child simply never show a scrollbar. */
  .card { overflow-x:auto; }
}

/* ════════════════════════════════════════════════════════════════════════════
   LANDING PAGE — 2026 premium rebuild (Slice 2). ADDITIVE. Full-bleed
   alternating navy/porcelain bands, brass single accent, one Deep-Teal band.
   Only the public landing (.lp) consumes these classes; dashboard + tests
   untouched. The full-bleed .section here supersedes the old Phase-10
   .section{margin} (same name, only the landing used it).
   ════════════════════════════════════════════════════════════════════════════ */
.lp { --lp-pad-x:clamp(20px,5vw,40px); --lp-pad-y:clamp(80px,12vh,150px); --lp-max:1200px; color:var(--navy); }
.lp h1, .lp h2, .lp h3 { margin:0; }

.section { position:relative; margin:0; padding:var(--lp-pad-y) var(--lp-pad-x);
  background:var(--porcelain); color:var(--navy); border-bottom:1px solid var(--line-light); }
.section-inner { max-width:var(--lp-max); margin:0 auto; }
.section-narrow { max-width:760px; margin:0 auto; }
.section-dark { background:var(--navy); color:var(--porcelain); border-bottom:1px solid var(--line-dark); }
.section-dark h1, .section-dark h2, .section-dark h3 { color:var(--porcelain); }
.section-dark .lead { color:var(--porcelain-dim); }
.section-teal { background:var(--teal); color:var(--porcelain); border-bottom:1px solid rgba(255,255,255,.10); }
.section-teal h2 { color:var(--porcelain); } .section-teal .lead { color:var(--porcelain-dim); }

.eyebrow { font-family:var(--sans); font-size:13px; font-weight:600; letter-spacing:.18em;
  text-transform:uppercase; color:var(--slate); margin:0 0 18px; }
.section-dark .eyebrow, .section-teal .eyebrow { color:var(--brass-bright); }
.eyebrow.brass { color:var(--brass); }

.lp h1 { font-family:var(--serif); font-weight:700; line-height:1.04; font-size:clamp(2.75rem,6vw,5rem);
  letter-spacing:-.01em; max-width:16ch; }
.lp h2 { font-family:var(--serif); font-weight:600; line-height:1.1; font-size:clamp(2rem,4vw,3.25rem);
  letter-spacing:-.005em; max-width:18ch; }
.brass-word { color:var(--brass); }
.section-dark .brass-word, .section-teal .brass-word { color:var(--brass-bright); }
.lead { font-family:var(--sans); font-weight:400; font-size:17px; line-height:1.6; color:var(--slate);
  max-width:62ch; margin:18px 0 0; }
.lead.lg { font-size:19px; }
.center { text-align:center; } .center .lead, .center .eyebrow, .center h2 { margin-inline:auto; }

.lp .btn { border-radius:10px; }
.lp .btn.lg { padding:13px 24px; font-size:15px; }
.lp .btn.green:hover { transform:translateY(-1px); box-shadow:0 6px 18px rgba(191,159,102,.28); filter:none; }
.lp .btn.ghost { background:transparent; color:var(--navy); border:1px solid var(--border-strong); }
.lp .btn.ghost:hover { border-color:var(--brass); color:var(--navy); }
.section-dark .btn.ghost, .section-teal .btn.ghost { color:var(--porcelain); border:1px solid var(--line-dark); }
.section-dark .btn.ghost:hover, .section-teal .btn.ghost:hover { border-color:var(--brass-bright); color:var(--porcelain); }
.cta-row { display:flex; gap:14px; flex-wrap:wrap; align-items:center; margin-top:28px; }
.center .cta-row { justify-content:center; }

.lp-nav { position:sticky; top:0; z-index:50; display:flex; align-items:center; gap:24px;
  padding:14px clamp(20px,5vw,40px); background:rgba(31,27,79,.78);
  backdrop-filter:saturate(140%) blur(14px); -webkit-backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid var(--line-dark); }
.lp-nav .brand { font-size:20px; }
.lp-nav nav { display:flex; gap:24px; margin-left:24px; flex:1; flex-wrap:wrap; }
.lp-nav nav a { color:var(--porcelain-dim); font-family:var(--sans); font-weight:500; font-size:14px;
  padding:4px 0; position:relative; }
.lp-nav nav a::after { content:""; position:absolute; left:0; bottom:-2px; height:1.5px; width:0;
  background:var(--brass); transition:width .2s ease; }
.lp-nav nav a:hover { color:var(--porcelain); text-decoration:none; } .lp-nav nav a:hover::after { width:100%; }
.lp-nav .nav-cta { display:flex; gap:12px; align-items:center; }
.lp-nav .nav-cta a.signin { color:var(--porcelain-dim); font-weight:500; font-size:14px; }
.lp-nav .nav-cta a.signin:hover { color:var(--porcelain); text-decoration:none; }

.lp-hero { overflow:hidden; }
.lp-hero .section-inner { position:relative; z-index:1; display:grid; grid-template-columns:7fr 5fr;
  gap:clamp(32px,5vw,72px); align-items:center; }
.lp-hero .hero-copy h1 { max-width:14ch; }
.lp-hero .trust-line { display:inline-flex; align-items:center; gap:8px; margin-top:28px;
  font-family:var(--sans); font-size:13.5px; color:var(--porcelain-dim); }
.lp-hero .trust-line .dot { width:7px; height:7px; border-radius:50%; background:var(--brass);
  box-shadow:0 0 0 4px rgba(191,159,102,.18); }
.lp-hero::before { content:""; position:absolute; inset:0; pointer-events:none; z-index:0;
  background:radial-gradient(60% 50% at 78% 18%, rgba(191,159,102,.16), transparent 70%),
             radial-gradient(50% 50% at 12% 92%, rgba(18,58,58,.30), transparent 70%); }
.lp-hero::after { content:""; position:absolute; inset:0; pointer-events:none; z-index:0; opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }

.glass { background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.10); border-radius:16px;
  padding:18px 18px 20px; backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  box-shadow:0 24px 60px rgba(0,0,0,.35); }
.glass .glass-head { display:flex; align-items:center; gap:8px; padding:0 2px 14px;
  border-bottom:1px solid rgba(255,255,255,.08); margin-bottom:14px; }
.glass .glass-head .title { font-family:var(--sans); font-size:12.5px; font-weight:600; color:var(--porcelain); }
.glass .glass-head .lang { margin-left:auto; font-size:11px; color:var(--porcelain-dim); }
.glass .glass-head .dotrow { display:flex; gap:5px; }
.glass .glass-head .dotrow i { width:8px; height:8px; border-radius:50%; background:rgba(255,255,255,.18); }
.chatfeed { display:flex; flex-direction:column; gap:10px; }
.chatline { max-width:84%; padding:10px 13px; font-family:var(--sans); font-size:13.5px; line-height:1.5; border-radius:14px; }
.chatline.guest { align-self:flex-start; background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.10);
  border-bottom-left-radius:4px; color:var(--porcelain); }
.chatline.reply { align-self:flex-end; background:rgba(191,159,102,.14); border:1px solid rgba(191,159,102,.30);
  border-bottom-right-radius:4px; color:var(--porcelain); }
.chatline .who { display:block; font-size:10.5px; letter-spacing:.04em; text-transform:uppercase;
  color:var(--porcelain-dim); margin-bottom:4px; }
.chat-approved { display:inline-flex; align-items:center; gap:7px; align-self:flex-end; margin-top:4px;
  font-family:var(--sans); font-size:11.5px; font-weight:600; color:var(--brass-bright); }
.chat-approved svg { width:14px; height:14px; stroke:var(--brass-bright); stroke-width:1.5; fill:none; }
.lang-chips { display:flex; gap:8px; flex-wrap:wrap; margin-top:22px; justify-content:center; }
.lang-chips .pill { background:rgba(255,255,255,.05); border:1px solid var(--line-dark); color:var(--porcelain-dim); }

.split { display:grid; grid-template-columns:1fr 1fr; gap:clamp(20px,4vw,40px); margin-top:44px; }
.split .col-label { font-family:var(--sans); font-size:13px; font-weight:600; letter-spacing:.14em;
  text-transform:uppercase; color:var(--brass); padding-bottom:14px; border-bottom:1px solid var(--line-light); margin-bottom:18px; }
.split p { margin:0 0 12px; font-family:var(--sans); font-size:15.5px; line-height:1.6; color:var(--navy); }
.split .pull { font-family:var(--serif); font-style:italic; font-size:1.15rem; color:var(--slate); margin-top:14px; }

.steps3 { display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,3vw,32px); margin-top:52px; }
.step-n { font-family:var(--serif); font-weight:700; font-size:2.4rem; line-height:1; color:var(--brass); display:block; margin-bottom:14px; }
.step h3 { font-family:var(--sans); font-weight:600; font-size:18px; color:var(--navy); margin:0 0 8px; }
.step p { font-family:var(--sans); font-size:15px; line-height:1.55; color:var(--slate); margin:0; }

.proof-grid { display:grid; grid-template-columns:1fr 1fr; gap:clamp(20px,3vw,28px); margin-top:44px; }
.villa-card { background:var(--surface); border:1px solid var(--line-light); border-radius:14px; padding:26px 28px;
  transition:box-shadow .16s ease, border-color .16s ease; }
.villa-card:hover { box-shadow:var(--shadow); border-color:var(--border-strong); }
.villa-card .flagrow { display:flex; align-items:center; gap:10px; margin-bottom:12px; }
.villa-card .flag { font-size:22px; line-height:1; }
.villa-card .geo { font-family:var(--sans); font-size:12.5px; font-weight:600; letter-spacing:.06em;
  text-transform:uppercase; color:var(--slate); }
.villa-card h3 { font-family:var(--serif); font-weight:600; font-size:1.5rem; color:var(--navy); margin:0 0 6px; }
.villa-card p { font-family:var(--sans); font-size:15px; line-height:1.55; color:var(--slate); margin:0 0 16px; }
.villa-card .meta { display:flex; gap:8px; flex-wrap:wrap; }
.proof-strip { text-align:center; margin-top:36px; font-family:var(--sans); font-size:14px; color:var(--slate); }
.proof-strip b { color:var(--navy); font-weight:600; }

.tenets { display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,3vw,36px); margin-top:40px; }
.tenet h3 { font-family:var(--sans); font-weight:600; font-size:16px; color:var(--porcelain); margin:0 0 6px; }
.tenet p { font-family:var(--sans); font-size:14px; line-height:1.55; color:var(--porcelain-dim); margin:0; }
.tenet .k { color:var(--brass-bright); font-weight:700; margin-right:6px; }

.bento { display:grid; grid-template-columns:repeat(6,1fr); gap:16px; margin-top:44px; }
.bento-item { background:rgba(255,255,255,.04); border:1px solid var(--line-dark); border-radius:14px;
  padding:22px 24px; backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px); grid-column:span 2; }
.bento-item.wide { grid-column:span 3; } .bento-item.lead-tile { grid-column:span 6; }
.bento-item h3 { font-family:var(--sans); font-weight:600; font-size:16px; color:var(--porcelain); margin:0 0 6px; }
.bento-item p { font-family:var(--sans); font-size:14px; line-height:1.5; color:var(--porcelain-dim); margin:0; }
.roadmap { display:inline-block; margin-top:12px; font-size:11px; font-weight:600; letter-spacing:.08em;
  text-transform:uppercase; color:var(--brass-bright); border:1px solid rgba(191,159,102,.35); border-radius:20px; padding:2px 10px; }

.pricing-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:48px; align-items:stretch; }
.tier { background:var(--surface); border:1px solid var(--line-light); border-radius:16px; padding:30px 28px;
  display:flex; flex-direction:column; }
.tier.featured { border-color:var(--brass); box-shadow:0 18px 44px rgba(191,159,102,.22); position:relative; transform:translateY(-10px); }
.tier.featured::before { content:"Recommended"; position:absolute; top:-12px; left:28px; background:var(--brass);
  color:var(--navy); font-family:var(--sans); font-size:11px; font-weight:700; letter-spacing:.06em;
  text-transform:uppercase; padding:3px 12px; border-radius:20px; }
.tier .tier-name { font-family:var(--sans); font-weight:600; font-size:14px; letter-spacing:.04em;
  text-transform:uppercase; color:var(--slate); margin:0 0 12px; }
.tier .price { font-family:var(--serif); font-weight:700; font-size:2.4rem; line-height:1; color:var(--navy); }
.tier .price .per { font-family:var(--sans); font-weight:500; font-size:14px; color:var(--slate); }
.tier .setup { font-family:var(--sans); font-size:13.5px; color:var(--slate); margin:8px 0 0; }
.tier ul { list-style:none; padding:0; margin:20px 0 24px; display:flex; flex-direction:column; gap:10px; flex:1; }
.tier ul li { font-family:var(--sans); font-size:14.5px; line-height:1.45; color:var(--navy); padding-left:22px; position:relative; }
.tier ul li::before { content:"✓"; position:absolute; left:0; color:var(--brass); font-weight:700; }
.tier .btn { width:100%; text-align:center; }
.founding-note { margin-top:32px; padding:22px 26px; border:1px solid var(--line-light); border-radius:14px;
  background:var(--surface-soft); text-align:center; }
.founding-note .tag-brass { font-family:var(--sans); font-weight:600; font-size:12.5px; letter-spacing:.1em;
  text-transform:uppercase; color:var(--brass); display:block; margin-bottom:6px; }
.founding-note p { font-family:var(--sans); font-size:14.5px; line-height:1.55; color:var(--porcelain-dim);
  margin:0 auto; max-width:62ch; }
.section .founding-note p { color:var(--slate); }

.founder { max-width:820px; margin:0 auto; text-align:center; }
.founder blockquote { font-family:var(--serif); font-weight:600; font-size:clamp(1.4rem,2.4vw,1.9rem);
  line-height:1.3; color:var(--porcelain); margin:0; }
.founder .byline { font-family:var(--sans); font-size:14px; color:var(--porcelain-dim); margin-top:16px; }
.founder .byline b { color:var(--porcelain); font-weight:600; }

.faq { max-width:780px; margin:44px auto 0; }
.faq details { border-bottom:1px solid var(--line-light); padding:4px 0; }
.faq summary { list-style:none; cursor:pointer; padding:20px 36px 20px 0; position:relative;
  font-family:var(--sans); font-weight:600; font-size:17px; color:var(--navy); }
.faq summary::-webkit-details-marker { display:none; }
.faq summary::after { content:"+"; position:absolute; right:4px; top:50%; transform:translateY(-50%);
  font-family:var(--sans); font-weight:400; font-size:24px; color:var(--brass); }
.faq details[open] summary::after { content:"\2013"; }
.faq details > div { padding:0 36px 22px 0; font-family:var(--sans); font-size:15.5px; line-height:1.6; color:var(--slate); }

.lp-footer { background:var(--navy-900); color:var(--porcelain-dim); padding:clamp(48px,7vh,80px) var(--lp-pad-x) 40px; }
.lp-footer .section-inner { display:flex; flex-wrap:wrap; gap:28px 48px; align-items:flex-start; justify-content:space-between; }
.lp-footer .brand { font-size:22px; }
.lp-footer .foot-col { display:flex; flex-direction:column; gap:8px; }
.lp-footer a { color:var(--porcelain-dim); font-family:var(--sans); font-size:14px; }
.lp-footer a:hover { color:var(--porcelain); text-decoration:none; }
.lp-footer .legal { width:100%; margin-top:24px; padding-top:24px; border-top:1px solid var(--line-dark);
  font-family:var(--sans); font-size:12.5px; color:var(--slate); }

.reveal { opacity:0; transform:translateY(18px); transition:opacity .5s ease, transform .5s ease; }
.reveal.in-view { opacity:1; transform:none; }
@keyframes lp-float { 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-6px); } }
.lp-hero .glass { animation:lp-float 6s ease-in-out infinite; }

@media (max-width:560px){
  .section { padding:clamp(56px,10vh,80px) 20px; }
  .lp h1 { font-size:clamp(2.2rem,9vw,2.9rem); }
  .lp h2 { font-size:clamp(1.7rem,7vw,2.1rem); }
  .lp-nav { gap:12px; } .lp-nav nav { display:none; }
  .lp-hero .section-inner { grid-template-columns:1fr; gap:36px; }
  .lp-hero .hero-copy h1 { max-width:none; }
  .split, .steps3, .proof-grid, .pricing-grid, .tenets { grid-template-columns:1fr; }
  .bento { grid-template-columns:1fr; }
  .bento-item, .bento-item.wide, .bento-item.lead-tile { grid-column:auto; }
  .cta-row .btn { width:100%; text-align:center; }
  .tier.featured { order:-1; transform:none; }
  .lp-footer .section-inner { flex-direction:column; gap:20px; }
}
@media (prefers-reduced-motion: reduce){
  .reveal { opacity:1; transform:none; transition:none; }
  .lp-hero .glass { animation:none; }
  .lp .btn.green:hover { transform:none; }
}

/* ── Auth split-screen (login) — navy pitch panel + porcelain form ─────────── */
.auth { display:grid; grid-template-columns:1fr 1fr; min-height:100vh; }
.auth .auth-aside { position:relative; overflow:hidden; background:var(--navy); color:var(--porcelain);
  display:flex; flex-direction:column; justify-content:space-between; gap:32px; padding:clamp(32px,5vw,56px); }
.auth .auth-aside::before { content:""; position:absolute; inset:0; pointer-events:none;
  background:radial-gradient(70% 60% at 28% 18%, rgba(191,159,102,.16), transparent 70%); }
.auth .auth-aside > * { position:relative; z-index:1; }
.auth .auth-aside .brand { font-size:22px; }
.auth .auth-aside .pitch h2 { font-family:var(--serif); font-weight:600; font-size:clamp(1.8rem,3vw,2.6rem);
  line-height:1.12; color:var(--porcelain); max-width:14ch; margin:0; }
.auth .auth-aside .pitch p { font-family:var(--sans); font-size:14.5px; color:var(--porcelain-dim); margin-top:14px; }
.auth .auth-aside .foot { font-family:var(--sans); font-size:12.5px; color:var(--slate); }
.auth .auth-main { display:flex; align-items:center; justify-content:center; padding:clamp(28px,5vw,56px); background:var(--porcelain); }
.auth .auth-card { width:100%; max-width:360px; }
.auth .auth-card h1 { font-family:var(--serif); font-weight:600; font-size:1.9rem; color:var(--navy); margin:0 0 4px; }
@media (max-width:760px){
  .auth { grid-template-columns:1fr; min-height:auto; }
  .auth .auth-aside { padding:28px 24px; gap:18px; }
  .auth .auth-aside .pitch h2 { font-size:1.6rem; }
  .auth .auth-aside .foot { display:none; }
}

/* ── Landing Step 0: standard-fix polish (scroll, anchors, hover, a11y, mid-bp) ── */
html { scroll-behavior:smooth; }
.lp .section[id], .lp .faq details { scroll-margin-top:84px; }   /* clear the sticky nav on anchor jumps */
.lp .tier { transition:border-color .16s ease, box-shadow .16s ease; }
.lp .tier:hover { border-color:var(--border-strong); box-shadow:var(--shadow); }
.lp .bento-item { transition:border-color .16s ease, background .16s ease; }
.lp .bento-item:hover { border-color:rgba(191,159,102,.35); background:rgba(255,255,255,.06); }
.lp .faq summary { transition:color .14s ease; }
.lp .faq summary:hover { color:var(--brass); }
.lp-nav a:focus-visible, .lp-logo:focus-visible, .lp-footer a:focus-visible {
  outline:2px solid var(--brass-bright); outline-offset:3px; border-radius:3px;
}
@media (max-width:860px){
  .lp-hero .section-inner { grid-template-columns:1fr; gap:36px; }
  .lp-hero .hero-copy h1 { max-width:none; }
  .bento { grid-template-columns:repeat(2,1fr); }
  .bento-item, .bento-item.wide, .bento-item.lead-tile { grid-column:auto; }
}
@media (prefers-reduced-motion: reduce){ html { scroll-behavior:auto; } }

/* ── Landing Step 1: logo lockup (arrow mark + Direct·Ops) + mobile menu ─────── */
.lp-logo { display:inline-flex; align-items:center; gap:9px; }
.lp-logo:hover { text-decoration:none; }
.lp-logo-mark { height:28px; width:auto; display:block; }
.lp-footer .lp-logo-mark { height:30px; }
/* Mobile disclosure menu (the anchor nav hides ≤560px; this restores it). */
.lp-menu { display:none; position:relative; }
.lp-menu > summary { list-style:none; cursor:pointer; color:var(--porcelain); font-size:20px;
  line-height:1; padding:6px 8px; border-radius:8px; }
.lp-menu > summary::-webkit-details-marker { display:none; }
.lp-menu > summary:hover { background:rgba(255,255,255,.06); }
.lp-menu-panel { position:absolute; right:0; top:calc(100% + 10px); background:var(--navy);
  border:1px solid var(--line-dark); border-radius:12px; padding:8px; display:flex;
  flex-direction:column; gap:2px; min-width:190px; box-shadow:0 14px 34px rgba(0,0,0,.42); z-index:60; }
.lp-menu-panel a { color:var(--porcelain-dim); font-family:var(--sans); font-size:14px;
  padding:9px 12px; border-radius:8px; }
.lp-menu-panel a:hover { background:rgba(255,255,255,.06); color:var(--porcelain); text-decoration:none; }
@media (max-width:560px){ .lp-menu { display:block; } }

/* ── Landing Step 2: hero stat ribbon + approved-chip status footer ─────────── */
.hero-stats { display:flex; gap:28px; margin-top:30px; flex-wrap:wrap; }
.hero-stats .stat b { font-family:var(--serif); font-weight:700; font-size:1.6rem;
  color:var(--porcelain); line-height:1; display:block; }
.hero-stats .stat span { font-family:var(--sans); font-size:12.5px; color:var(--porcelain-dim);
  letter-spacing:.03em; margin-top:5px; display:block; }
.glass .chatfeed .chat-approved { align-self:stretch; justify-content:flex-end;
  border-top:1px solid rgba(255,255,255,.08); margin-top:8px; padding-top:10px; }

/* ── Landing Step 3: locale code chip (cross-platform; replaces emoji flags) ── */
.villa-card .locale { display:inline-flex; align-items:center; justify-content:center;
  min-width:32px; height:23px; padding:0 8px; border:1px solid var(--line-light);
  border-radius:6px; font-family:var(--sans); font-weight:700; font-size:11.5px;
  letter-spacing:.05em; color:var(--brass); background:var(--surface-soft); }

/* ── Landing Step 4: live concierge embed (#try) ───────────────────────────── */
.lp-embed-frame { display:block; width:100%; height:560px; border:0; border-radius:12px;
  background:var(--porcelain); }
.embed-note { max-width:560px; margin:18px auto 0; text-align:center; font-family:var(--sans);
  font-size:13px; line-height:1.55; color:var(--porcelain-dim); }
.muted-fine { margin:10px auto 0; text-align:center; font-family:var(--sans); font-size:11.5px;
  line-height:1.5; color:var(--porcelain-dim); opacity:.72; }
@media (max-width:680px){ .lp-embed-frame { height:520px; } }

/* ── Landing Step 5: control ring-checks · step connectors · bento hero tile ── */
/* Control band — brass ring + 1.5px line check (replaces the text ✓) */
.tenet h3 { display:flex; align-items:center; gap:10px; }
.tenet .k { flex:0 0 auto; display:inline-flex; align-items:center; justify-content:center;
  width:26px; height:26px; margin:0; border-radius:50%; border:1.5px solid rgba(212,185,133,.45);
  background:rgba(212,185,133,.12); color:var(--brass-bright); }
.tenet .k svg { width:14px; height:14px; }
/* How-it-works — hairline connector between the three numbered steps (desktop only) */
.steps3 .step { position:relative; }
@media (min-width:861px){
  .steps3 .step:not(:last-child)::after { content:""; position:absolute; top:19px;
    left:calc(100% + 4px); width:calc(clamp(20px,3vw,32px) - 8px); height:2px; border-radius:2px;
    background:linear-gradient(90deg, var(--brass) 0%, rgba(191,159,102,.12) 100%); }
}
/* Revenue bento — distinguish the lead/hero tile from the roadmap tiles */
.bento-item.lead-tile { background:linear-gradient(180deg, rgba(212,185,133,.12), rgba(255,255,255,.03));
  border-color:rgba(212,185,133,.34); }
.bento-item.lead-tile h3 { font-size:18px; }

/* ════════════════════════════════════════════════════════════════════════════
   DASHBOARD 2026 — Slice 1: left-sidebar app shell + stable single-row topbar.
   ADDITIVE and scoped under .app / body.app, so the landing layer (above) and
   every existing dashboard class are untouched. Modern hand-written CSS only
   (grid, :has(), color-mix, clamp, container query) — no build step. The old
   header.top / .wrap rules become dead for the dashboard (left in place; cleaned
   in a later slice). Never edit the Mobile-reflow block. Braces are balanced.
   ════════════════════════════════════════════════════════════════════════════ */
.app { --rail-w:248px; --rail-w-min:76px; --topbar-h:60px; }
body.app { display:grid; grid-template-columns:var(--rail-w) 1fr; min-height:100vh; min-height:100dvh; background:var(--bg); }

/* ── Sidebar (navy chrome) ─────────────────────────────────────────────────── */
.sidebar { position:sticky; top:0; align-self:start; height:100vh; height:100dvh; display:flex; flex-direction:column;
  background:var(--navy); border-right:1px solid var(--navy-900); color:var(--porcelain); overflow:hidden; }
.sidebar-head { display:flex; align-items:center; justify-content:space-between; gap:10px; padding:16px 16px 12px; }
.sidebar-head .lp-logo { gap:9px; }
.sidebar-head .lp-logo-mark { width:30px; height:24px; }
.sidebar-head .brand { font-size:17px; }
.sidenav { flex:1; overflow-y:auto; padding:8px 12px 16px; scrollbar-width:thin; }
.sidebar-foot { padding:12px 16px; border-top:1px solid color-mix(in srgb, var(--porcelain) 12%, transparent); }
.signout { display:inline-flex; align-items:center; gap:8px; color:var(--porcelain-dim); font-size:13px; font-weight:500; }
.signout:hover { color:var(--porcelain); text-decoration:none; }

/* ── Grouped nav ───────────────────────────────────────────────────────────── */
.nav-group { margin-bottom:12px; }
.nav-group + .nav-group { padding-top:12px; border-top:1px solid color-mix(in srgb, var(--porcelain) 8%, transparent); }
.nav-group-label { margin:2px 0 6px; padding:0 10px; font-family:var(--sans); font-size:10.5px; font-weight:700;
  letter-spacing:.13em; text-transform:uppercase; color:color-mix(in srgb, var(--porcelain) 46%, var(--navy)); }
.sidenav a { position:relative; display:flex; align-items:center; gap:11px; padding:9px 12px; margin:1px 0; border-radius:var(--r);
  color:var(--porcelain-dim); font-family:var(--sans); font-weight:500; font-size:13.5px; transition:background .14s ease, color .14s ease; }
.sidenav a:hover { background:color-mix(in srgb, var(--porcelain) 9%, transparent); color:var(--porcelain); text-decoration:none; }
.sidenav a[aria-current="page"] { color:var(--porcelain); background:color-mix(in srgb, var(--brass) 18%, transparent); }
.sidenav a[aria-current="page"]::before { content:""; position:absolute; left:0; top:7px; bottom:7px; width:3px; border-radius:0 3px 3px 0; background:var(--brass-bright); }
.nav-ico { display:inline-flex; width:18px; height:18px; flex:0 0 auto; }
.nav-ico svg { width:18px; height:18px; stroke:currentColor; fill:none; stroke-width:1.6; stroke-linecap:round; stroke-linejoin:round; }
.sidenav a[aria-current="page"] .nav-ico { color:var(--brass-bright); }
.nav-label { flex:1; min-width:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sidenav .navbadge { margin-left:auto; background:var(--red); color:#fff; }

/* ── Main column + stable topbar ───────────────────────────────────────────── */
.app-main { display:flex; flex-direction:column; min-width:0; }
.topbar { display:flex; align-items:center; gap:16px; min-height:var(--topbar-h); padding:0 clamp(16px,2.4vw,28px);
  background:var(--surface); border-bottom:1px solid var(--border); position:sticky; top:0; z-index:20; }
.topbar-fill { flex:1; min-width:0; }
.page-actions { display:flex; align-items:center; gap:10px; }
.page-actions:empty { display:none; }
.topbar .tenant-switcher { margin:0; }
.topbar .tenant-switcher select { padding:6px 10px; font-size:13px; }
.topbar .who { display:inline-flex; flex-direction:column; line-height:1.18; text-align:right; white-space:nowrap; }
.topbar .who-name { color:var(--ink); font-size:12.5px; font-weight:600; }
.topbar .who-role { color:var(--muted); font-size:11px; text-transform:capitalize; }
.content { flex:1; width:100%; max-width:1060px; margin:0 auto; padding:clamp(18px,2.2vw,28px); container-type:inline-size; }
.content > h1.page:first-child { margin-top:4px; }

/* ── Toggle controls (CSS-only via the hidden #navtoggle checkbox) ─────────── */
.hamburger, .rail-btn { cursor:pointer; user-select:none; }
.hamburger { display:none; width:40px; height:40px; border-radius:var(--r); align-items:center; justify-content:center; }
.hamburger span, .hamburger span::before, .hamburger span::after { content:""; display:block; width:18px; height:2px; background:var(--ink); border-radius:2px; }
.hamburger span { position:relative; }
.hamburger span::before { position:absolute; top:-6px; }
.hamburger span::after { position:absolute; top:6px; }
.hamburger:hover { background:var(--surface-soft); }
.rail-btn { display:inline-flex; width:28px; height:28px; border-radius:var(--r-sm); align-items:center; justify-content:center; color:var(--porcelain-dim); }
.rail-btn:hover { background:color-mix(in srgb, var(--porcelain) 10%, transparent); color:var(--porcelain); }
.rail-ico { width:15px; height:2px; background:currentColor; box-shadow:0 -5px 0 currentColor, 0 5px 0 currentColor; }

/* Collapse to an icon rail (desktop) via :has() on the hidden checkbox. */
body.app:has(#navtoggle:checked) { grid-template-columns:var(--rail-w-min) 1fr; }
body.app:has(#navtoggle:checked) .sidebar .nav-label,
body.app:has(#navtoggle:checked) .sidebar .nav-group-label,
body.app:has(#navtoggle:checked) .sidebar .brand,
body.app:has(#navtoggle:checked) .sidebar .signout { opacity:0; visibility:hidden; width:0; overflow:hidden; }
body.app:has(#navtoggle:checked) .sidenav a { justify-content:center; }
body.app:has(#navtoggle:checked) .sidenav .navbadge { position:absolute; top:3px; right:5px; margin:0; }

/* ── Responsive: under 860px the sidebar becomes an off-canvas drawer ───────── */
@media (max-width:860px){
  body.app { grid-template-columns:1fr; }
  .hamburger { display:inline-flex; }
  .sidebar { position:fixed; inset:0 auto 0 0; z-index:60; width:min(84vw,var(--rail-w)); transform:translateX(-100%); transition:transform .22s ease; box-shadow:var(--shadow-lg); }
  body.app:has(#navtoggle:checked) { grid-template-columns:1fr; }
  body.app:has(#navtoggle:checked) .sidebar { transform:none; }
  body.app:has(#navtoggle:checked) .sidebar .nav-label,
  body.app:has(#navtoggle:checked) .sidebar .nav-group-label,
  body.app:has(#navtoggle:checked) .sidebar .brand,
  body.app:has(#navtoggle:checked) .sidebar .signout { opacity:1; visibility:visible; width:auto; }
  body.app:has(#navtoggle:checked) .app-main::before { content:""; position:fixed; inset:0; z-index:55; background:color-mix(in srgb, var(--navy-900) 55%, transparent); }
}

@media (prefers-reduced-motion: reduce){
  .sidenav a, .sidebar { transition:none; }
}

/* ════════════════════════════════════════════════════════════════════════════
   DASHBOARD 2026 — Slice 2: refined-premium tokens + component restyle.
   ADDITIVE. New tokens (second :root, merges with the original) + restyles
   SCOPED under .app, so the public landing (which shares .btn/.pill/.badge) is
   untouched. Modern CSS: color-mix/OKLAB scale, layered shadows, :has(),
   container query, ≤200ms motion (reduced-motion-guarded). Braces balanced.
   ════════════════════════════════════════════════════════════════════════════ */
:root {
  --brass-50:color-mix(in oklab, var(--brass) 12%, var(--surface));
  --brass-100:color-mix(in oklab, var(--brass) 22%, var(--surface));
  --brass-200:color-mix(in oklab, var(--brass) 40%, var(--surface));
  --brass-ring:color-mix(in oklab, var(--brass) 38%, transparent);
  --surface-2:color-mix(in oklab, var(--surface) 92%, var(--porcelain));
  --surface-3:color-mix(in oklab, var(--navy) 4%, var(--surface));
  --hairline:color-mix(in oklab, var(--border) 72%, transparent);
  --ring-focus:0 0 0 3px var(--brass-ring);
  --elev-1:0 1px 2px rgba(31,27,79,.05), 0 1px 1px rgba(31,27,79,.04);
  --elev-2:0 2px 4px rgba(31,27,79,.05), 0 8px 20px rgba(31,27,79,.08);
  --elev-3:0 4px 8px rgba(31,27,79,.06), 0 18px 38px rgba(31,27,79,.12);
  --dur-1:90ms; --dur-2:150ms; --ease-out:cubic-bezier(.2,.7,.3,1);
  --r-xl:16px;
}

/* Cards — layered elevation, hover lift, stateful :has() */
.app .card { background:var(--surface); border:1px solid var(--hairline); border-radius:var(--r-xl); box-shadow:var(--elev-1);
  transition:box-shadow var(--dur-2) var(--ease-out), border-color var(--dur-2) var(--ease-out), transform var(--dur-2) var(--ease-out); }
.app .card.draft:hover, .app .card.hover:hover { box-shadow:var(--elev-2); border-color:var(--brass-200); transform:translateY(-1px); }
.app .card > h3 { letter-spacing:-.005em; }
.app .card:has(.badge.live) { border-color:color-mix(in oklab, var(--green) 26%, var(--hairline)); }

/* Inbox draft cards — brass spine signals "actionable"; refined quote block */
.app .card.draft { border-left:3px solid transparent; }
.app .card.draft:hover { border-left-color:var(--brass); }
.app .body-quote { background:var(--surface-2); border:1px solid var(--hairline); border-left:3px solid var(--navy); border-radius:var(--r-sm); }

/* Modern data-tables (markup is bare table/th/td, no .table class) */
.app table { border-collapse:separate; border-spacing:0; }
.app thead th { position:sticky; top:var(--topbar-h); z-index:1; background:var(--surface-3); color:var(--ink-soft); border-bottom:1px solid var(--border); }
.app tbody td { border-bottom:1px solid var(--hairline); }
.app tbody tr { transition:background var(--dur-1) var(--ease-out); }
.app tbody tr:nth-child(even) { background:color-mix(in oklab, var(--porcelain) 45%, var(--surface)); }
.app tbody tr:hover { background:var(--brass-50); }
.app tbody tr:last-child td { border-bottom:none; }

/* Forms — filled fields + brass focus ring */
.app select, .app input[type=text], .app input[type=email], .app input[type=password], .app input[type=number], .app textarea {
  background:var(--surface-2); transition:border-color var(--dur-2) var(--ease-out), box-shadow var(--dur-2) var(--ease-out), background var(--dur-2) var(--ease-out); }
.app select:hover, .app input:hover, .app textarea:hover { border-color:var(--brass-200); }
.app select:focus, .app input:focus, .app textarea:focus { background:var(--surface); border-color:var(--brass); box-shadow:var(--ring-focus); }

/* Buttons — refined scale (dashboard only; landing .btn untouched) */
.app .btn { border-radius:var(--r); box-shadow:var(--elev-1);
  transition:background var(--dur-2) var(--ease-out), box-shadow var(--dur-2) var(--ease-out), transform var(--dur-1) var(--ease-out); }
.app .btn:hover { filter:none; box-shadow:var(--elev-2); }
.app .btn:active { transform:translateY(1px); }
.app .btn.primary { background:var(--navy); }
.app .btn.primary:hover { background:color-mix(in oklab, var(--navy) 88%, #fff); }
.app .btn.green:hover { background:color-mix(in oklab, var(--green) 86%, #fff); }
.app .btn.accent { background:var(--brass); color:var(--navy); }
.app .btn.accent:hover { background:var(--brass-bright); }
.app .btn.ghost:hover { border-color:var(--brass); color:var(--ink); background:var(--brass-50); }
.app .btn.red:hover { background:var(--red-bg); }
.app .btn.sm, .app .btn.link { box-shadow:none; }

/* Badges + pills — semantic chrome */
.app .badge { border-radius:var(--r-pill); box-shadow:var(--elev-1); font-weight:600; }
.app .badge.paused { background:color-mix(in oklab, var(--slate) 68%, #fff); color:#fff; }
.app .pill { border:1px solid var(--hairline); background:var(--surface-2); border-radius:var(--r-pill); transition:border-color var(--dur-1) var(--ease-out); }
.app .pill:hover { border-color:var(--brass-200); }

/* Inbox filter bar → segmented-control look (keeps btn sm primary/ghost markup) */
.app .toolbar[role=group] { gap:6px; padding:4px; background:var(--surface-2); border:1px solid var(--hairline); border-radius:var(--r-pill); width:max-content; max-width:100%; }

/* Chat thread — re-point off-brand blues to brand */
.app .msg.in { background:var(--surface-2); border-color:var(--hairline); }
.app .msg.out { background:var(--brass-50); border-color:var(--brass-100); }
.app .msg.latest-in { box-shadow:var(--ring-focus); }

/* Page heading rhythm + container-query stack for dense rows */
.app h1.page { letter-spacing:-.01em; }
@container (max-width:560px){ .app .row { gap:8px; } }

@media (prefers-reduced-motion: reduce){
  .app .card, .app .btn, .app .pill, .app .badge, .app .msg, .app tbody tr, .app select, .app input, .app textarea { transition:none; }
  .app .card.draft:hover, .app .card.hover:hover, .app .btn:active { transform:none; }
}
