/* ════════════════════════════════════════════════════════════════════
   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)}

/* ── 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}
