/* ════════════════════════════════════════════════════════════════════
   4THWALL — Homeowner surface (the Home Record + the directory lens).
   Shared by find/contractor/pro/record/signin/auth-confirm/request pages.
   Same design language as the rest of 4thwall.solutions: cream, ink,
   green, Fraunces display, Inter Tight body. No framework, no build.
   ════════════════════════════════════════════════════════════════════ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
[hidden]{display:none!important}
:root{
  --cream:#f7f3ec;
  --cream-2:#efe9df;
  --ink:#1a1a18;
  --ink-2:#2a2a26;
  --muted:rgba(26,26,24,0.62);
  --dim:rgba(26,26,24,0.38);
  --line:rgba(26,26,24,0.12);
  --orange:#1e6642;
  --orange-2:#165535;
  --orange-soft:rgba(30,102,66,0.10);
  --display:'Fraunces',Georgia,serif;
  --body:'Inter Tight','Inter',-apple-system,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --pad:clamp(1.25rem,4.5vw,4rem);
  --max:1100px;
}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--ink);background:var(--cream);-webkit-font-smoothing:antialiased;letter-spacing:-0.011em;line-height:1.55;min-height:100vh;display:flex;flex-direction:column}
a{text-decoration:none;color:inherit}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
main{flex:1}

/* ── NAV (same skeleton as contact.html) ───────────────────── */
nav.topnav{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:1.1rem var(--pad);background:rgba(247,243,236,.85);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav-logo{display:flex;align-items:center;gap:.5rem;font-size:.78rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--ink)}
.nav-logo svg{width:18px;height:18px}
.nav-logo .home-tag{font-family:var(--mono);font-size:.58rem;letter-spacing:.14em;color:var(--orange);border:1px solid var(--orange-soft);background:var(--orange-soft);border-radius:4px;padding:2px 6px;margin-left:.35rem}
.nav-links{display:flex;align-items:center;gap:1.6rem}
.nav-a{font-size:.84rem;color:var(--muted);transition:color .2s}
.nav-a:hover,.nav-a.is-current{color:var(--ink)}
.nav-who{font-family:var(--mono);font-size:.66rem;letter-spacing:.06em;color:var(--dim);max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
#nav-acct{display:inline-flex;gap:1.6rem;align-items:center}
@media(max-width:560px){#nav-acct{gap:1rem}}
@media(max-width:560px){.nav-links{gap:1rem}.nav-who{display:none}}

/* ── PAGE HERO ─────────────────────────────────────────────── */
.page-hero{padding:4rem var(--pad) 1.8rem;max-width:var(--max);margin:0 auto;width:100%}
.eyebrow{font-family:var(--mono);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--orange);margin-bottom:1.1rem}
.page-h{font-family:var(--display);font-size:clamp(2rem,4.6vw,3.4rem);font-weight:500;line-height:1.06;letter-spacing:-.03em;max-width:24ch}
.page-h em{font-style:italic;color:var(--orange);font-weight:400}
.page-sub{font-size:.98rem;line-height:1.65;color:var(--muted);margin-top:1.1rem;max-width:52ch}
.crumb{display:inline-block;font-family:var(--mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--dim);margin-bottom:1.4rem;transition:color .2s}
.crumb:hover{color:var(--ink)}

/* ── SECTIONS ─────────────────────────────────────────────── */
.section{padding:1.2rem var(--pad) 2.4rem;max-width:var(--max);margin:0 auto;width:100%}
.section-h{font-family:var(--display);font-size:clamp(1.25rem,2.4vw,1.7rem);font-weight:500;letter-spacing:-.025em;margin:1.6rem 0 .9rem}
.note{font-size:.82rem;line-height:1.65;color:var(--muted);margin-top:.8rem;max-width:62ch}
.note b,.note strong{color:var(--ink);font-weight:600}
.warn{background:rgba(176,138,40,.09);border:1px solid rgba(176,138,40,.25);color:#6e5616;border-radius:10px;padding:.8rem 1rem;font-size:.84rem;line-height:1.55;margin:.9rem 0}
.empty{padding:2rem 1.2rem;text-align:center;color:var(--muted);font-size:.9rem;background:var(--cream-2);border:1px dashed var(--line);border-radius:14px}

/* ── PILLS (site-wide button language) ─────────────────────── */
.pill{display:inline-flex;align-items:center;gap:.5rem;padding:11px 22px;border-radius:50px;font-size:.86rem;font-weight:500;cursor:pointer;white-space:nowrap;transition:opacity .2s,background .2s,transform .2s,box-shadow .2s;font-family:inherit}
.pill .arr{font-family:var(--display);line-height:1;transition:transform .25s}
.pill:hover .arr{transform:translateX(2px)}
.pill-ink{background:var(--ink);color:var(--cream)}
.pill-ink:hover{background:var(--ink-2);box-shadow:0 12px 30px -16px rgba(0,0,0,.4)}
.pill-orange{background:var(--orange);color:var(--cream)}
.pill-orange:hover{background:var(--orange-2);box-shadow:0 12px 30px -16px rgba(30,102,66,.55)}
.pill-ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}
.pill-ghost:hover{border-color:var(--ink);background:rgba(0,0,0,.02)}
.pill:disabled{opacity:.55;cursor:wait}
.pill-sm{padding:8px 16px;font-size:.8rem}

/* ── SEARCH BAR ───────────────────────────────────────────── */
.searchbar{display:flex;gap:.5rem;background:#fff;border:1px solid var(--line);border-radius:50px;padding:.35rem .35rem .35rem 1.1rem;box-shadow:0 1px 2px rgba(26,26,24,.04),0 12px 32px -18px rgba(26,26,24,.18);margin:1.4rem 0 .4rem;flex-wrap:wrap;align-items:center;max-width:640px}
.searchbar input{border:none;background:transparent;font-family:inherit;font-size:.94rem;color:var(--ink);outline:none;padding:.55rem .4rem}
.searchbar input::placeholder{color:var(--dim)}
.searchbar .q{flex:2;min-width:150px}
.searchbar .zip{flex:0 0 92px;border-left:1px solid var(--line);padding-left:.9rem}
@media(max-width:560px){.searchbar{border-radius:18px}.searchbar .q{flex:1 1 100%;border-bottom:1px solid var(--line)}.searchbar .zip{border-left:none;padding-left:.4rem}}

/* ── TRADE CHIPS ──────────────────────────────────────────── */
.chips{display:flex;flex-wrap:wrap;gap:.45rem;margin:.9rem 0 .2rem}
.chips a,.chips button{font-family:var(--mono);font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;border-radius:50px;padding:.42rem .85rem;border:1px solid var(--line);color:var(--muted);background:transparent;transition:all .15s;cursor:pointer}
.chips a:hover,.chips button:hover{border-color:var(--ink);color:var(--ink)}
.chips a.on,.chips button.on{background:var(--ink);border-color:var(--ink);color:var(--cream)}

/* ── CARD GRID ────────────────────────────────────────────── */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(265px,1fr));gap:1rem;margin:1rem 0}
.card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:1.3rem 1.4rem;display:flex;flex-direction:column;gap:.45rem;transition:box-shadow .2s,transform .2s}
.card.lift:hover{box-shadow:0 18px 44px -22px rgba(26,26,24,.28);transform:translateY(-2px)}
.card h3{font-family:var(--display);font-size:1.12rem;font-weight:500;letter-spacing:-.02em;line-height:1.2}
.card .sub{font-size:.8rem;color:var(--muted);line-height:1.5}
.card .spacer{flex:1}
.card-block{background:var(--cream-2);border:1px solid var(--line);border-radius:18px;padding:clamp(1.3rem,2.6vw,1.9rem);margin:.9rem 0;max-width:680px}
a.cardlink:hover h3{color:var(--orange)}

/* ── BADGES (render ONLY what the ledger sent) ─────────────── */
.badges{display:flex;flex-wrap:wrap;gap:.35rem;margin:.3rem 0}
.badge{display:inline-flex;align-items:center;gap:.3rem;background:var(--orange-soft);color:var(--orange-2);border:1px solid rgba(30,102,66,.18);border-radius:50px;padding:.28rem .7rem;font-size:.72rem;font-weight:600;letter-spacing:-.005em}
.badge.plain{background:transparent;border-color:var(--line);color:var(--muted);font-weight:500}

/* ── FORMS (contact.html language) ─────────────────────────── */
.form-row{margin-bottom:1.05rem}
.form-row.row-pair{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:600px){.form-row.row-pair{grid-template-columns:1fr}}
.form-label{display:block;font-family:var(--mono);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--dim);margin-bottom:.4rem}
.form-input,.form-textarea,.form-select{width:100%;padding:.8rem 1rem;background:var(--cream);border:1px solid var(--line);border-radius:8px;font-family:inherit;font-size:.92rem;color:var(--ink);transition:border-color .2s,background .2s}
.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--ink);background:#fff}
.form-textarea{min-height:96px;resize:vertical;line-height:1.55}
.form-input::placeholder,.form-textarea::placeholder{color:var(--dim)}
.fine{font-size:.72rem;line-height:1.65;color:var(--dim);margin-top:.8rem}
.form-status{font-size:.74rem;color:var(--muted);font-family:var(--mono);text-transform:uppercase;letter-spacing:.08em;margin-left:.8rem}
.form-status.is-error{color:#8a2a1f}
.form-status.is-success{color:var(--orange)}

/* ── LOCKBOX (contact info gate) ───────────────────────────── */
.lockbox{border:1.5px dashed rgba(30,102,66,.3);background:linear-gradient(180deg,var(--orange-soft),rgba(255,255,255,.6));border-radius:16px;padding:1.4rem;text-align:center;margin:.9rem 0;max-width:560px}
.lockbox .blur{filter:blur(5px);user-select:none;color:var(--muted);font-size:.92rem;margin-bottom:.8rem}
.contactrow{display:flex;align-items:center;gap:.8rem;font-size:.94rem;padding:.6rem 0;border-bottom:1px dashed var(--line)}
.contactrow:last-child{border-bottom:none}
.contactrow b{min-width:84px;font-family:var(--mono);font-size:.6rem;color:var(--dim);font-weight:500;text-transform:uppercase;letter-spacing:.1em}
.contactrow a{color:var(--orange);font-weight:500;word-break:break-all}
.contactrow a:hover{color:var(--ink)}

/* ── RECORD TIMELINE ──────────────────────────────────────── */
.timeline{list-style:none;margin:.8rem 0}
.timeline li{border-left:2px solid var(--orange);padding:.1rem 0 1.1rem 1.1rem;margin-left:.4rem;position:relative}
.timeline li::before{content:"";position:absolute;left:-6px;top:6px;width:10px;height:10px;border-radius:50%;background:var(--orange)}
.timeline .src{font-family:var(--mono);font-size:.58rem;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}
.timeline .ev-title{font-family:var(--display);font-size:1.02rem;font-weight:500;letter-spacing:-.015em;margin:.15rem 0 .05rem}
.timeline .ev-meta{font-size:.78rem;color:var(--muted)}
.kv{display:flex;justify-content:space-between;gap:.8rem;font-size:.86rem;padding:.5rem 0;border-bottom:1px dashed var(--line)}
.kv:last-child{border-bottom:none}
.kv b{font-weight:600}

/* ── RECORD FOOTER PROMISES ────────────────────────────────── */
.rec-promises{margin-top:2.2rem;border-top:1px solid var(--line);padding-top:1.1rem;font-size:.78rem;color:var(--muted)}
.rec-promises b{color:var(--ink)}
.rec-promises li{margin:.25rem 0 .25rem 1.1rem;line-height:1.6}

/* ── FOOTER ───────────────────────────────────────────────── */
footer{border-top:1px solid var(--line);padding:1.8rem var(--pad);background:var(--cream-2);margin-top:2.5rem}
.foot-row{max-width:var(--max);margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.foot-brand{font-family:var(--mono);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink);font-weight:500}
.foot-links{display:flex;gap:1.2rem;font-size:.72rem;color:var(--muted);font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase}
.foot-links a{transition:color .2s}
.foot-links a:hover{color:var(--ink)}

/* ── LOADING / SKELETON ───────────────────────────────────── */
.loading{font-family:var(--mono);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--dim);padding:1.6rem 0;animation:homePulse 1.4s ease-in-out infinite}
@keyframes homePulse{0%,100%{opacity:.45}50%{opacity:1}}

/* ── VERIFIED-ACTIVITY FEED (documented jobs, not reviews) ── */
.feed{list-style:none;margin:.8rem 0;max-width:680px}
.feed li{display:flex;gap:.9rem;align-items:baseline;padding:.65rem 0;border-bottom:1px dashed var(--line);font-size:.88rem;line-height:1.55}
.feed li:last-child{border-bottom:none}
.feed .mo{font-family:var(--mono);font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;color:var(--dim);flex:0 0 76px}
.feed b{font-weight:600}

/* ── SEARCH MODE TOGGLE (by trade ↔ by name) ───────────────── */
.modes{display:inline-flex;gap:0;margin-top:1.3rem;border:1px solid var(--line);border-radius:50px;padding:3px;background:#fff}
.modes button,.modes a{font-family:var(--mono);font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;border-radius:50px;padding:.45rem .95rem;color:var(--muted);cursor:pointer;transition:all .15s}
.modes .on{background:var(--ink);color:var(--cream)}

/* ── WARRANTY WALLET ───────────────────────────────────────── */
.wrow{display:flex;gap:.9rem;align-items:flex-start;padding:.85rem 0;border-bottom:1px dashed var(--line)}
.wrow:last-child{border-bottom:none}
.wrow .wmain{flex:1;min-width:0}
.wrow .wname{font-weight:600;font-size:.92rem}
.wrow .wmeta{font-size:.78rem;color:var(--muted);margin-top:.15rem;line-height:1.5}
.wrow .wacts{display:flex;gap:.5rem;flex-shrink:0;align-items:center}
.wpill{font-family:var(--mono);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;border-radius:50px;padding:.3rem .7rem;white-space:nowrap}
.wpill.ok{background:var(--orange-soft);color:var(--orange-2)}
.wpill.soon{background:rgba(176,138,40,.12);color:#6e5616}
.wpill.gone{background:rgba(138,42,31,.1);color:#8a2a1f}
.linkish{font-size:.78rem;color:var(--orange);cursor:pointer;background:none;border:none;font-family:inherit;padding:0}
.linkish:hover{color:var(--ink)}
.linkish.danger{color:#8a2a1f}

/* ── SHARE / RESALE REPORT BOX ─────────────────────────────── */
.sharebox{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;margin-top:.9rem}
.sharebox input{flex:1;min-width:220px;font-family:var(--mono);font-size:.74rem;padding:.7rem .9rem;border:1px solid var(--line);border-radius:8px;background:var(--cream);color:var(--ink)}
.report-banner{background:var(--orange-soft);border:1px solid rgba(30,102,66,.2);border-radius:12px;padding:.8rem 1.1rem;font-size:.84rem;color:var(--orange-2);margin:.9rem 0}

/* ── PRINT (the Resale Report on paper) ────────────────────── */
@media print{
  nav.topnav,footer,.pill,.sharebox,form,.rec-promises,.no-print{display:none !important}
  body{background:#fff}
  .page-hero,.section{padding-top:.4rem;padding-bottom:.4rem}
}

/* ════════════════════════════════════════════════════════════════════
   VESTA — product surfaces (vesta.html + find.html ONLY).
   Scoped entirely under body.v-dark: the lens is a dark instrument; the
   records it opens stay paper-cream. Append-only — nothing above this
   line changed, so the wired pages (record/signin/myhome/…) are inert.
   ════════════════════════════════════════════════════════════════════ */
body.v-dark{
  --vk:#0f1310;--vk-2:#151b16;--vk-3:#1b221c;
  --vcream:#f2eee5;
  --vmut:rgba(242,238,229,.64);
  --vdim:rgba(242,238,229,.38);
  --vline:rgba(242,238,229,.1);
  --vline-2:rgba(242,238,229,.22);
  --vgreen:#67c694;
  --vgreen-2:#8fdcb2;
  --vgreen-soft:rgba(103,198,148,.12);
  background:
    radial-gradient(1100px 540px at 78% -180px,rgba(103,198,148,.14),transparent 62%),
    radial-gradient(900px 520px at -140px 36%,rgba(103,198,148,.05),transparent 55%),
    var(--vk);
  color:var(--vcream);
}
body.v-dark::after{ /* film grain */
  content:"";position:fixed;inset:0;pointer-events:none;z-index:60;opacity:.045;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23n)' opacity='0.55'/%3E%3C/svg%3E");
}
body.v-dark nav.topnav{background:rgba(15,19,16,.82);border-bottom-color:var(--vline)}
body.v-dark .nav-logo{color:var(--vcream)}
body.v-dark .nav-logo .home-tag{color:var(--vgreen);border-color:rgba(103,198,148,.28);background:var(--vgreen-soft)}
body.v-dark .nav-a{color:var(--vmut)}
body.v-dark .nav-a:hover,body.v-dark .nav-a.is-current{color:var(--vcream)}
body.v-dark .eyebrow{color:var(--vgreen)}
body.v-dark .page-h em{color:var(--vgreen-2)}
body.v-dark .page-sub,body.v-dark .note{color:var(--vmut)}
body.v-dark .note b,body.v-dark .note strong{color:var(--vcream)}
body.v-dark .loading{color:var(--vdim)}
body.v-dark .fine{color:var(--vdim)}
body.v-dark .searchbar{background:var(--vk-3);border-color:var(--vline-2);box-shadow:0 24px 60px -30px rgba(0,0,0,.8)}
body.v-dark .searchbar input{color:var(--vcream)}
body.v-dark .searchbar input::placeholder{color:var(--vdim)}
body.v-dark .searchbar .zip{border-left-color:var(--vline)}
@media(max-width:560px){body.v-dark .searchbar .q{border-bottom-color:var(--vline)}}
body.v-dark .pill-ink{background:var(--vcream);color:#12150f}
body.v-dark .pill-ink:hover{background:#fff;box-shadow:0 12px 30px -14px rgba(0,0,0,.7)}
body.v-dark .pill-ghost{color:var(--vcream);border-color:var(--vline-2)}
body.v-dark .pill-ghost:hover{border-color:var(--vcream);background:rgba(255,255,255,.05)}
body.v-dark .chips a,body.v-dark .chips button{border-color:var(--vline-2);color:var(--vmut)}
body.v-dark .chips a:hover,body.v-dark .chips button:hover{border-color:var(--vcream);color:var(--vcream)}
body.v-dark .chips a.on,body.v-dark .chips button.on{background:var(--vcream);border-color:var(--vcream);color:#12150f}
body.v-dark .modes{background:var(--vk-3);border-color:var(--vline-2)}
body.v-dark .modes button,body.v-dark .modes a{color:var(--vmut)}
body.v-dark .modes .on{background:var(--vcream);color:#12150f}
body.v-dark .card{background:var(--vk-2);border-color:var(--vline)}
body.v-dark .card.lift:hover{box-shadow:0 24px 60px -24px rgba(0,0,0,.85);border-color:var(--vline-2)}
body.v-dark .card .sub{color:var(--vmut)}
body.v-dark a.cardlink:hover h3{color:var(--vgreen-2)}
body.v-dark .badge{background:var(--vgreen-soft);color:var(--vgreen-2);border-color:rgba(103,198,148,.26)}
body.v-dark .badge.plain{background:transparent;border-color:var(--vline-2);color:var(--vmut)}
body.v-dark .card-block{background:var(--vk-2);border-color:var(--vline)}
body.v-dark .empty{background:var(--vk-2);border-color:var(--vline-2);color:var(--vmut)}
body.v-dark .warn{background:rgba(217,185,106,.08);border-color:rgba(217,185,106,.32);color:#d9b96a}
body.v-dark .feed li{border-bottom-color:var(--vline)}
body.v-dark .feed .mo{color:var(--vdim)}
body.v-dark footer{background:#0c0f0d;border-top-color:var(--vline)}
body.v-dark .foot-brand{color:var(--vcream)}
body.v-dark .foot-links{color:var(--vmut)}

/* ── DARK PROFILE SURFACES (/c listed pro on the dark desk) ─── */
body.v-dark .crumb{color:var(--vdim)}
body.v-dark .crumb:hover{color:var(--vcream)}
body.v-dark .lockbox{border-color:rgba(103,198,148,.34);background:linear-gradient(180deg,var(--vgreen-soft),rgba(242,238,229,.02))}
body.v-dark .lockbox .blur{color:var(--vmut)}
body.v-dark .contactrow{border-bottom-color:var(--vline)}
body.v-dark .contactrow b{color:var(--vdim)}
body.v-dark .contactrow a{color:var(--vgreen-2)}
body.v-dark .contactrow a:hover{color:var(--vcream)}
body.v-dark .form-status{color:var(--vmut)}
body.v-dark .form-status.is-error{color:#e6a08f}
body.v-dark .form-status.is-success{color:var(--vgreen-2)}

/* record timeline / warranty wallet / share — dark variants */
body.v-dark .timeline li{border-left-color:var(--vgreen)}
body.v-dark .timeline li::before{background:var(--vgreen)}
body.v-dark .timeline .src,body.v-dark .timeline .ev-meta{color:var(--vmut)}
body.v-dark .rec-promises{border-top-color:var(--vline);color:var(--vmut)}
body.v-dark .rec-promises b{color:var(--vcream)}
body.v-dark .wrow{border-bottom-color:var(--vline)}
body.v-dark .wrow .wmeta{color:var(--vmut)}
body.v-dark .wpill.ok{background:var(--vgreen-soft);color:var(--vgreen-2)}
body.v-dark .wpill.soon{background:rgba(217,185,106,.12);color:#d9b96a}
body.v-dark .wpill.gone{background:rgba(230,160,143,.12);color:#e6a08f}
body.v-dark .linkish{color:var(--vgreen-2)}
body.v-dark .linkish:hover{color:var(--vcream)}
body.v-dark .linkish.danger{color:#e6a08f}
body.v-dark .sharebox input{border-color:var(--vline-2);background:var(--vk-3);color:var(--vcream)}
body.v-dark .report-banner{background:var(--vgreen-soft);border-color:rgba(103,198,148,.28);color:var(--vgreen-2)}

/* ── VESTA HERO (oversize, editorial) ──────────────────────── */
.vhero{padding:4.2rem var(--pad) 1.6rem;max-width:var(--max);margin:0 auto;width:100%;position:relative}
.vhero h1{font-family:var(--display);font-size:clamp(2.5rem,6.4vw,4.6rem);font-weight:500;line-height:1.03;letter-spacing:-.035em;max-width:17ch}
.vhero h1 em{font-style:italic;color:var(--vgreen-2);font-weight:400}
.vhero .sub{font-size:clamp(.95rem,1.7vw,1.1rem);color:var(--vmut);line-height:1.7;margin-top:1.3rem;max-width:54ch}
.vlab{font-family:var(--mono);font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--vgreen);margin-bottom:.9rem}
.vh2{font-family:var(--display);font-size:clamp(1.6rem,3.6vw,2.5rem);font-weight:500;letter-spacing:-.03em;line-height:1.12;max-width:28ch}
.vh2 em{font-style:italic;color:var(--vgreen-2);font-weight:400}

/* ── TRADE TILES (the guided entry) ────────────────────────── */
.vtiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(158px,1fr));gap:.7rem;margin:1.5rem 0 .4rem;max-width:920px}
.vtile{position:relative;display:flex;flex-direction:column;gap:.55rem;align-items:flex-start;text-align:left;background:var(--vk-2);border:1px solid var(--vline);border-radius:16px;padding:1.05rem 1rem .95rem;cursor:pointer;transition:transform .18s,border-color .18s,background .18s,box-shadow .18s}
.vtile svg{width:26px;height:26px;stroke:var(--vgreen);stroke-width:1.6;fill:none;stroke-linecap:round;stroke-linejoin:round}
.vtile .tl{font-family:var(--display);font-size:1.04rem;font-weight:500;letter-spacing:-.015em;color:var(--vcream)}
.vtile .ts{font-size:.69rem;color:var(--vdim);line-height:1.45}
.vtile:hover{transform:translateY(-2px);border-color:rgba(103,198,148,.42);box-shadow:0 18px 44px -20px rgba(0,0,0,.75)}
.vtile.on{border-color:var(--vgreen);background:var(--vgreen-soft)}
.vtile.on::after{content:"✓";position:absolute;top:.65rem;right:.85rem;color:var(--vgreen-2);font-size:.85rem}
.vzip{display:none;margin:1.3rem 0 .4rem;max-width:600px}
.vzip.show{display:block;animation:vUp .35s ease both}
.vzip .lab{font-family:var(--mono);font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:var(--vgreen);margin-bottom:.2rem}
@keyframes vUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.vdoors{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.6rem}

/* ── RICH VERIFIED CARD + FINGERPRINT ──────────────────────── */
body.v-dark .card.vcard{background:linear-gradient(180deg,rgba(103,198,148,.08),rgba(103,198,148,.02)),var(--vk-2);border-color:rgba(103,198,148,.34)}
body.v-dark .card.vcard:hover{border-color:rgba(103,198,148,.6)}
.vrib{display:inline-flex;align-items:center;gap:.35rem;font-family:var(--mono);font-size:.58rem;letter-spacing:.14em;text-transform:uppercase;color:var(--vgreen-2)}
.vfp{font-size:.78rem;color:var(--vmut);line-height:1.55;border-top:1px dashed var(--vline);padding-top:.6rem;margin-top:.2rem}
.vfp b{color:var(--vcream);font-weight:600}

/* ── WHY / EDITORIAL BANDS ─────────────────────────────────── */
.vwhy{display:grid;grid-template-columns:repeat(auto-fit,minmax(236px,1fr));gap:1rem;margin:1.4rem 0}
.vwhy .w{background:var(--vk-2);border:1px solid var(--vline);border-radius:18px;padding:1.3rem 1.4rem}
.vwhy .w .k{font-family:var(--mono);font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--vdim);margin-bottom:.55rem}
.vwhy .w h3{font-family:var(--display);font-size:1.1rem;font-weight:500;letter-spacing:-.02em;margin-bottom:.4rem}
.vwhy .w p{font-size:.82rem;color:var(--vmut);line-height:1.65}
.vturn{border-left:2px solid var(--vgreen);padding:.35rem 0 .35rem 1.2rem;margin:1.8rem 0 .4rem;max-width:62ch}
.vturn p{font-family:var(--display);font-size:clamp(1.05rem,2vw,1.3rem);line-height:1.5;letter-spacing:-.015em}
.vturn p em{font-style:italic;color:var(--vgreen-2)}
.vangles{margin:1.4rem 0;border-top:1px solid var(--vline)}
.vangle{display:grid;grid-template-columns:88px 1fr;gap:1.2rem;padding:1.45rem 0;border-bottom:1px solid var(--vline)}
.vangle .no{font-family:var(--mono);font-size:.7rem;color:var(--vgreen);letter-spacing:.14em;padding-top:.35rem}
.vangle h3{font-family:var(--display);font-size:clamp(1.15rem,2.2vw,1.5rem);font-weight:500;letter-spacing:-.02em;margin-bottom:.35rem}
.vangle p{font-size:.88rem;color:var(--vmut);line-height:1.65;max-width:58ch}
.vangle .ga{margin-top:.55rem;font-size:.8rem;color:var(--vgreen-2);font-weight:600;display:inline-block}
.vangle .ga:hover{color:var(--vcream)}
@media(max-width:560px){.vangle{grid-template-columns:1fr;gap:.3rem}}

/* ── PAPER ARTIFACT (the record stays cream on the dark desk) ─ */
.vpaper{background:var(--cream);color:var(--ink);border:1px solid rgba(0,0,0,.2);border-radius:22px;padding:clamp(1.4rem,3.2vw,2.3rem);max-width:640px;box-shadow:0 50px 110px -45px rgba(0,0,0,.85);position:relative}
body.v-dark .vpaper .note{color:rgba(26,26,24,.62)}
body.v-dark .vpaper .note b{color:var(--ink)}
.vpaper .demo-tag{font-family:var(--mono);font-size:.58rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(26,26,24,.38);margin-bottom:1rem}
.vpaper .addr{font-family:var(--display);font-size:1.4rem;font-weight:500;letter-spacing:-.02em;margin-bottom:1rem}

/* ── ACCOUNT BAND + END CTA ────────────────────────────────── */
.vacct{background:var(--vk-2);border:1px solid var(--vline);border-radius:26px;padding:clamp(1.8rem,4vw,2.6rem);margin:1.4rem 0}
.vacct .usegrid .use{background:var(--vk-3);border-color:var(--vline)}
.vacct .use h3{color:var(--vcream)}
.vacct .use p{color:var(--vmut)}
.vacct .use .n{color:var(--vgreen)}
.vcta{text-align:center;padding:3.6rem var(--pad) 5rem;max-width:var(--max);margin:0 auto;width:100%}
.vcta .searchbar{margin-left:auto;margin-right:auto}
.vpromises{margin-top:.6rem;font-size:.84rem;color:var(--vmut)}
.vpromises li{margin:.3rem 0 .3rem 1.1rem;line-height:1.65}
.vpromises b{color:var(--vcream)}

/* ── REVEAL ON SCROLL ──────────────────────────────────────── */
.vr{opacity:0;transform:translateY(14px);transition:opacity .55s ease,transform .55s ease}
.vr.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .vr{opacity:1;transform:none;transition:none}
  .vzip.show{animation:none}
  .vtile,.card,.pill{transition:none}
}

/* ── ZIP-GATE (location-first entry — "Where to?" moment) ────── */
.vzip-hero-form{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap;margin:1.4rem 0 .5rem;max-width:500px}
.vzip-gate-input{font-family:var(--body);font-size:1.5rem;font-weight:500;letter-spacing:.2em;padding:.6rem .85rem .6rem 1rem;width:145px;background:var(--vk-2);border:1.5px solid var(--vline-2);border-radius:12px;color:var(--vcream);outline:none;text-align:center;transition:border-color .2s,box-shadow .2s}
.vzip-gate-input::placeholder{color:var(--vdim);letter-spacing:.06em;font-size:1rem}
.vzip-gate-input:focus{border-color:var(--vgreen);box-shadow:0 0 0 3px rgba(103,198,148,.15)}

/* ── NEIGHBORHOOD PULSE ────────────────────────────────────────── */
.vpulse{display:flex;align-items:flex-start;gap:.9rem;background:var(--vk-2);border:1px solid rgba(103,198,148,.22);border-radius:14px;padding:1rem 1.2rem;margin:.6rem 0 1.4rem;max-width:560px;animation:vUp .3s ease both}
.vpulse .pdot{width:8px;height:8px;border-radius:50%;background:var(--vgreen);flex-shrink:0;margin-top:.42rem;box-shadow:0 0 10px rgba(103,198,148,.6);animation:vpulse-dot 2s ease-in-out infinite}
@keyframes vpulse-dot{0%,100%{opacity:1}50%{opacity:.28}}
.vpulse .ptext{font-size:.88rem;color:var(--vcream);line-height:1.6}
.vpulse .pzip{display:block;font-family:var(--mono);font-size:.6rem;color:var(--vgreen);letter-spacing:.12em;text-transform:uppercase;margin-bottom:.18rem}
.vpulse .pdim{color:var(--vmut)}

/* ── TRADE TILE BADGE (per-tile supply count) ─────────────────── */
.vtile .tbadge{margin-top:.38rem;font-family:var(--mono);font-size:.55rem;letter-spacing:.09em;text-transform:uppercase;color:var(--vgreen-2)}
.vtile .tbadge.none{color:var(--vdim)}
.vtile .tbadge.loading{color:var(--vdim);opacity:.5}

/* ── TRADES GATE HEADER ────────────────────────────────────────── */
.vzip-display{display:flex;align-items:baseline;gap:.9rem;margin-bottom:.55rem}
.vzd-zip{font-family:var(--display);font-size:1.55rem;font-weight:500;letter-spacing:-.02em}
.vzd-change{font-family:var(--mono);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--vdim);text-decoration:underline;text-underline-offset:3px;cursor:pointer}
.vzd-change:hover{color:var(--vcream)}
.vtrades-lab{font-family:var(--mono);font-size:.63rem;letter-spacing:.18em;text-transform:uppercase;color:var(--vgreen);margin-bottom:.45rem}

/* ════════════════════════════════════════════════════════════════════
   VESTA APP SHELL (body.v-shell — find.html).
   Two-column layout: sidebar (240px) + scrollable main.
   Sidebar hidden on mobile; regular topnav (.vsn-mob) takes over.
   All existing v-dark tokens apply unchanged — just the layout shifts.
   ════════════════════════════════════════════════════════════════════ */
body.v-shell{height:100vh;overflow:hidden;display:flex;flex-direction:column}
body.v-shell nav.vsn-mob{display:none}
body.v-shell footer{display:none}

/* Shell container: sidebar + main side by side */
.vshell-wrap{display:flex;flex:1;overflow:hidden;min-height:0}

/* ── Sidebar ── */
.vsb{
  width:232px;flex-shrink:0;
  display:flex;flex-direction:column;
  background:var(--vk);
  border-right:1px solid var(--vline);
  padding:1.5rem 0 1.2rem;
  overflow-y:auto;
}

.vsb-brand{padding:0 1.2rem 2rem}
.vsb-logo-link{display:flex;align-items:center;gap:.6rem;text-decoration:none}
.vsb-logo-link svg{width:19px;height:19px;stroke:var(--vcream);flex-shrink:0}
.vsb-wordmark{display:flex;flex-direction:column;gap:2px}
.vsb-name{font-size:.7rem;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:var(--vcream);line-height:1}
.vsb-product{font-family:var(--mono);font-size:.52rem;letter-spacing:.16em;color:var(--vgreen);background:var(--vgreen-soft);border:1px solid rgba(103,198,148,.26);border-radius:4px;padding:1px 5px;line-height:1.6;width:fit-content}

.vsb-nav{display:flex;flex-direction:column;gap:.1rem;padding:0 .8rem;flex:1}
.vsb-item{display:flex;align-items:center;gap:.75rem;padding:.68rem .85rem;border-radius:10px;font-size:.84rem;color:var(--vmut);text-decoration:none;transition:background .14s,color .14s;line-height:1}
.vsb-item svg{width:16px;height:16px;flex-shrink:0;stroke:currentColor;opacity:.65;transition:opacity .14s}
.vsb-item:hover{background:var(--vk-3);color:var(--vcream)}
.vsb-item:hover svg{opacity:1}
.vsb-item.vsb-active{background:var(--vk-2);color:var(--vcream);font-weight:500}
.vsb-item.vsb-active svg{opacity:1;stroke:var(--vgreen)}

.vsb-foot{padding:1.4rem 1.2rem 0;border-top:1px solid var(--vline);margin-top:auto;display:flex;flex-direction:column;gap:.4rem}
.vsb-foot #nav-acct{display:block}
.vsb-signin{font-family:var(--mono);font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--vmut);text-decoration:none;transition:color .15s}
.vsb-signin:hover{color:var(--vcream)}
/* When signed in, navAccount() injects a .nav-who + sign-out link — style both */
.vsb-foot .nav-who{display:block;max-width:none;margin-bottom:.55rem;font-size:.65rem}
.vsb-foot .nav-a{display:block;font-family:var(--mono);font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--vmut)}
.vsb-foot .nav-a:hover{color:var(--vcream)}

/* ── Main scroll area ── */
.vsm{
  flex:1;overflow-y:auto;
  display:flex;flex-direction:column;
  padding:2.4rem clamp(1.5rem,4vw,3rem) 0;
  min-width:0;
}

/* In a column-flex container children default to align-self:stretch.
   Prevent that for inline elements that should size to their content. */
body.v-shell .modes{align-self:flex-start}
body.v-shell .searchbar{max-width:600px}

/* App header — replaces the full-bleed page-hero */
.vapp-head{margin-bottom:1.6rem;max-width:720px}
.vapp-eyebrow{font-family:var(--mono);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--vgreen);margin-bottom:.7rem}
.vapp-h{font-family:var(--display);font-size:clamp(1.75rem,3.6vw,2.6rem);font-weight:500;line-height:1.07;letter-spacing:-.03em;max-width:28ch}
.vapp-h em{font-style:italic;color:var(--vgreen-2);font-weight:400}
.vapp-sub{font-size:.9rem;line-height:1.65;color:var(--vmut);margin-top:.75rem;max-width:56ch}

/* Inline footer inside the scroll area */
.vsm-foot{
  border-top:1px solid var(--vline);
  padding:1.1rem 0 1.8rem;
  margin-top:2rem;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;
  background:transparent;
}

/* ── Mobile: show topnav, hide sidebar, restore scroll ── */
@media(max-width:860px){
  body.v-shell{height:auto;overflow:auto}
  body.v-shell nav.vsn-mob{display:flex}
  .vshell-wrap{flex-direction:column}
  .vsb{display:none}
  .vsm{padding:1.8rem var(--pad) 0;overflow-y:visible}
}

/* ════════════════════════════════════════════════════════════════════
   VESTA APP (va-) — the ZIP-gated contractor haven (vesta.html).
   Three-column shell: sidebar (v-shell) + center + sticky right rail.
   Append-only, dark-scope only.
   ════════════════════════════════════════════════════════════════════ */

/* ── ZIP module in the sidebar (your location is a first-class object) ── */
.vsb-zip{margin:0 1.2rem 1.1rem;padding:.8rem .95rem;background:var(--vk-2);border:1px solid var(--vline);border-radius:12px;display:none;align-items:center;justify-content:space-between;gap:.6rem}
.vsb-zip.show{display:flex}
.vsb-zip .zlab{font-family:var(--mono);font-size:.5rem;letter-spacing:.14em;text-transform:uppercase;color:var(--vdim);display:block;margin-bottom:.15rem}
.vsb-zip .z{font-family:var(--display);font-size:1.2rem;font-weight:500;letter-spacing:.04em;line-height:1;color:var(--vcream)}
.vsb-zip .zchg{font-family:var(--mono);font-size:.54rem;letter-spacing:.1em;text-transform:uppercase;color:var(--vdim);text-decoration:underline;text-underline-offset:3px;cursor:pointer;flex-shrink:0}
.vsb-zip .zchg:hover{color:var(--vcream)}

/* ── The gate (state 1: full-height entry moment) ── */
.va-gate{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;max-width:720px;margin:0 auto;width:100%;padding:2.5rem 0 4rem}
.va-gate-eyebrow{font-family:var(--mono);font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--vgreen);margin-bottom:1rem}
.va-gate-h{font-family:var(--display);font-size:clamp(2.3rem,5.4vw,3.9rem);font-weight:500;line-height:1.04;letter-spacing:-.034em}
.va-gate-h em{font-style:italic;color:var(--vgreen-2);font-weight:400}
.va-gate-sub{font-size:clamp(.92rem,1.6vw,1.05rem);color:var(--vmut);line-height:1.7;margin-top:1rem;max-width:50ch}
.va-gate .vzip-hero-form{justify-content:center;margin:1.8rem auto .4rem}
.va-gate .vdoors{justify-content:center}
.va-gate-why{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.7rem;margin-top:3rem;width:100%}
.va-gate-why .gw{background:var(--vk-2);border:1px solid var(--vline);border-radius:14px;padding:1rem 1.1rem;text-align:left}
.va-gate-why .gw b{display:block;font-family:var(--display);font-weight:500;font-size:.95rem;letter-spacing:-.015em;margin-bottom:.3rem;color:var(--vcream)}
.va-gate-why .gw span{font-size:.74rem;color:var(--vmut);line-height:1.55}

/* ── App header (state 2) ── */
.va-head{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:.4rem}
.va-head h1{font-family:var(--display);font-size:clamp(1.7rem,3.4vw,2.5rem);font-weight:500;line-height:1.07;letter-spacing:-.03em}
.va-head h1 em{font-style:italic;color:var(--vgreen-2);font-weight:400}
.va-sub{font-size:.88rem;line-height:1.6;color:var(--vmut);max-width:64ch;margin-bottom:.4rem}
.va-sub b{color:var(--vcream);font-weight:600}

/* ── Trade strip (the Coursue stat-card row, as live filters) ── */
.va-strip{display:grid;grid-template-columns:repeat(auto-fill,minmax(122px,1fr));gap:.6rem;margin:1.1rem 0 1.5rem}
.va-tile{display:flex;flex-direction:column;align-items:flex-start;gap:.35rem;text-align:left;background:var(--vk-2);border:1px solid var(--vline);border-radius:14px;padding:.85rem .9rem .8rem;cursor:pointer;transition:transform .16s,border-color .16s,background .16s}
.va-tile svg{width:19px;height:19px;stroke:var(--vgreen);stroke-width:1.6;fill:none;stroke-linecap:round;stroke-linejoin:round}
.va-tile .tn{font-family:var(--display);font-size:.94rem;font-weight:500;letter-spacing:-.012em;color:var(--vcream);line-height:1.1}
.va-tile .tc{font-family:var(--mono);font-size:.52rem;letter-spacing:.08em;text-transform:uppercase;color:var(--vdim);line-height:1.4}
.va-tile .tc.has{color:var(--vgreen-2)}
.va-tile:hover{transform:translateY(-1px);border-color:rgba(103,198,148,.4)}
.va-tile.on{border-color:var(--vgreen);background:var(--vgreen-soft)}

/* ── Main grid: center + sticky rail ── */
.vmain-grid{display:grid;grid-template-columns:minmax(0,1fr) 292px;gap:1.5rem;align-items:start}
.va-rail{position:sticky;top:0;display:flex;flex-direction:column;gap:.85rem;min-width:0}
@media(max-width:1120px){.vmain-grid{grid-template-columns:1fr}.va-rail{position:static;margin-top:1.6rem}}

/* ── Rail panels ── */
.va-panel{background:var(--vk-2);border:1px solid var(--vline);border-radius:16px;padding:1.1rem 1.2rem}
.va-ph{font-family:var(--mono);font-size:.56rem;letter-spacing:.16em;text-transform:uppercase;color:var(--vdim);margin-bottom:.8rem}
.va-vitals{display:flex;gap:1.1rem;margin-bottom:.4rem}
.va-vital .n{font-family:var(--display);font-size:1.7rem;font-weight:500;letter-spacing:-.03em;line-height:1;color:var(--vcream)}
.va-vital .l{font-size:.68rem;color:var(--vmut);margin-top:.25rem;line-height:1.35}
.va-rail .feed{margin:.2rem 0;max-width:none}
.va-rail .feed li{font-size:.8rem;padding:.55rem 0}
.va-rail .feed .mo{flex:0 0 64px;font-size:.56rem}

/* ── Public-footprint line on listed cards (Places, honestly framed) ── */
.vpub{font-size:.78rem;color:var(--vmut);line-height:1.55;border-top:1px dashed var(--vline);padding-top:.55rem;margin-top:.2rem}
.vpub b{color:var(--vcream);font-weight:600}
.vpub .gsrc{font-family:var(--mono);font-size:.52rem;letter-spacing:.08em;text-transform:uppercase;color:var(--vdim)}
.vattr{font-family:var(--mono);font-size:.54rem;letter-spacing:.1em;text-transform:uppercase;color:var(--vdim);margin:.7rem 0 0}

/* ── Vesta-analyzed tier (search + directory) ──
   A public-record analysis: state registration, licensing, manufacturer certs,
   and a plain read of the reviews. Deliberately cream/muted — a step BELOW the
   green "✓ Verified network" ribbon, which is reserved for ledger-backed clients. */
.vtag{display:inline-flex;align-items:center;gap:.35rem;width:fit-content;font-family:var(--mono);font-size:.57rem;letter-spacing:.13em;text-transform:uppercase;color:var(--vmut);background:rgba(242,238,229,.05);border:1px solid var(--vline-2);border-radius:50px;padding:.2rem .6rem;margin-bottom:.5rem}
.card-syn{font-size:.86rem;line-height:1.55;color:var(--vmut);margin:.2rem 0 .1rem;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.card-syn .syn-lbl{display:block;font-family:var(--mono);font-size:.6rem;letter-spacing:.09em;text-transform:uppercase;color:var(--vdim);margin-bottom:.25rem}
.section-h.sub{font-family:var(--display);font-size:1.02rem;font-weight:500;color:var(--vmut);margin:1.7rem 0 .5rem}
.vdir-link{margin:1rem 0 .2rem}
.vdir-link a{font-family:var(--mono);font-size:.68rem;letter-spacing:.04em;color:var(--vgreen-2);text-decoration:none}
.vdir-link a:hover{text-decoration:underline}

/* ── Compare-the-proof ── */
.vcmp-btn{font-family:var(--mono);font-size:.54rem;letter-spacing:.1em;text-transform:uppercase;color:var(--vdim);border:1px solid var(--vline);border-radius:50px;padding:.32rem .7rem;cursor:pointer;transition:all .15s;background:transparent}
.vcmp-btn:hover{border-color:var(--vcream);color:var(--vcream)}
.vcmp-btn.on{background:var(--vgreen);border-color:var(--vgreen);color:#12150f}
.va-cmp-bar{position:fixed;left:50%;transform:translateX(-50%);bottom:1.1rem;z-index:70;background:var(--vk-3);border:1px solid rgba(103,198,148,.45);border-radius:50px;padding:.5rem .55rem .5rem 1.15rem;display:flex;align-items:center;gap:.9rem;box-shadow:0 28px 70px -22px rgba(0,0,0,.95);max-width:min(94vw,640px)}
.va-cmp-bar .names{font-size:.8rem;color:var(--vcream);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.va-cmp-bar .names b{color:var(--vgreen-2);font-weight:600}
.va-cmp-bar .clr{font-family:var(--mono);font-size:.54rem;letter-spacing:.08em;text-transform:uppercase;color:var(--vdim);cursor:pointer;flex-shrink:0}
.va-cmp-bar .clr:hover{color:var(--vcream)}
.va-cmp-ov{position:fixed;inset:0;z-index:80;background:rgba(8,11,9,.8);backdrop-filter:blur(7px);display:flex;align-items:center;justify-content:center;padding:1.2rem}
.va-cmp{background:var(--vk-2);border:1px solid var(--vline-2);border-radius:20px;max-width:880px;width:100%;max-height:88vh;overflow:auto;padding:clamp(1.2rem,3vw,1.9rem)}
.va-cmp h2{font-family:var(--display);font-size:1.4rem;font-weight:500;letter-spacing:-.02em;margin-bottom:.2rem}
.va-cmp .cmp-sub{font-size:.78rem;color:var(--vmut);margin-bottom:1rem;line-height:1.55}
.va-cmp table{width:100%;border-collapse:collapse;font-size:.84rem}
.va-cmp th{font-family:var(--display);font-size:.98rem;font-weight:500;letter-spacing:-.015em;text-align:left;padding:.6rem .7rem;border-bottom:1px solid var(--vline-2);vertical-align:bottom;color:var(--vcream)}
.va-cmp th .vrib{display:block;margin-bottom:.3rem}
.va-cmp th .lrib{display:block;font-family:var(--mono);font-size:.52rem;letter-spacing:.12em;text-transform:uppercase;color:var(--vdim);margin-bottom:.3rem}
.va-cmp td{padding:.55rem .7rem;border-bottom:1px dashed var(--vline);color:var(--vcream);vertical-align:top;line-height:1.5}
.va-cmp td.k{font-family:var(--mono);font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;color:var(--vdim);white-space:nowrap;padding-top:.7rem}
.va-cmp td .dash{color:var(--vdim)}
.va-cmp td .yes{color:var(--vgreen-2);font-weight:600}
.va-cmp .cmp-close{margin-top:1.1rem}
.va-cmp .cmp-note{font-size:.72rem;color:var(--vdim);line-height:1.6;margin-top:.9rem;border-top:1px solid var(--vline);padding-top:.8rem}

/* ── Loading shimmer ── */
.va-skel{height:104px;border-radius:14px;background:linear-gradient(100deg,var(--vk-2) 35%,var(--vk-3) 50%,var(--vk-2) 65%);background-size:200% 100%;animation:vaShimmer 1.2s linear infinite;border:1px solid var(--vline)}
@keyframes vaShimmer{to{background-position:-200% 0}}
@media(prefers-reduced-motion:reduce){.va-skel{animation:none}}

/* ── Center keyword bar (compact) ── */
.va-q{display:flex;gap:.45rem;background:var(--vk-3);border:1px solid var(--vline-2);border-radius:50px;padding:.28rem .3rem .28rem 1rem;max-width:430px;margin:.2rem 0 1rem;align-items:center}
.va-q input{flex:1;border:none;background:transparent;font-family:inherit;font-size:.88rem;color:var(--vcream);outline:none;padding:.45rem .2rem;min-width:0}
.va-q input::placeholder{color:var(--vdim)}
.va-q button{flex-shrink:0}

/* ── Dark-scope forms (in-shell address check + sign-in) ── */
body.v-dark .form-label{color:var(--vdim)}
body.v-dark .form-input,body.v-dark .form-textarea,body.v-dark .form-select{background:var(--vk-3);border-color:var(--vline-2);color:var(--vcream)}
body.v-dark .form-input:focus,body.v-dark .form-textarea:focus,body.v-dark .form-select:focus{border-color:var(--vgreen);background:var(--vk-2)}
body.v-dark .form-input::placeholder,body.v-dark .form-textarea::placeholder{color:var(--vdim)}
body.v-dark .form-status{color:var(--vmut)}
body.v-dark .form-status.is-error{color:#e0917e}
body.v-dark .form-status.is-success{color:var(--vgreen-2)}
body.v-dark .kv{border-bottom-color:var(--vline)}

/* ── Request targets (the one-ask form) ── */
.rq-t{display:flex;align-items:flex-start;gap:.65rem;padding:.55rem 0;border-bottom:1px dashed var(--vline);cursor:pointer}
.rq-t:last-child{border-bottom:none}
.rq-t input{margin-top:.3rem;accent-color:var(--vgreen);flex-shrink:0}
.rq-t .tmain{flex:1;min-width:0}
.rq-t .tname{font-size:.9rem;font-weight:600;color:var(--vcream)}
.rq-t .tmeta{font-size:.74rem;color:var(--vmut);line-height:1.45}
.rq-t .tinst{font-family:var(--mono);font-size:.52rem;letter-spacing:.1em;text-transform:uppercase;color:var(--vgreen-2)}

/* ── Rail shortlist (live compare picks) ── */
.va-short-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.45rem 0;border-bottom:1px dashed var(--vline);font-size:.82rem;color:var(--vcream)}
.va-short-row:last-of-type{border-bottom:none}
.va-short-row .x{font-family:var(--mono);font-size:.56rem;letter-spacing:.08em;text-transform:uppercase;color:var(--vdim);cursor:pointer;flex-shrink:0;background:none;border:none}
.va-short-row .x:hover{color:var(--vcream)}
.va-short-empty{font-size:.78rem;color:var(--vmut);line-height:1.6}
