/* ============================================================
   DIRECTION B — "THE DECISION ROOM"
   Dark-dominant, cinematic. Full-bleed photography, glass panels,
   progressive blur, brass accents. One bright light moment at the price.
   Palette: #151515 ink / #ededed paper, terracotta + brass accents.
   ============================================================ */

:root{
  --ink:#131312;
  --ink-2:#1a1917;
  --ink-3:#211f1c;
  --paper:#ededed;
  --paper-2:#e3e1dc;
  --head-d:#f3f1ea;        /* heading on dark */
  --body-d:#a7a49c;        /* body on dark */
  --cap-d:#7e7a72;         /* caption on dark */
  --ink-on-l:#151515;
  --body-l:#56544f;
  --cap-l:#86837c;
  --terra:#c25c34;
  --brass:#bd934f;
  --brass-soft:#d4b483;
  --line-d:rgba(255,255,255,.12);
  --line-l:#d2d0c8;
  --glass:rgba(255,255,255,.045);
  --display:"Termina","Arial Narrow",system-ui,sans-serif;
  --sans:"InterVar",system-ui,-apple-system,"Segoe UI",sans-serif;
  --max:1280px;
  --pad:48px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--ink);color:var(--body-d);
  font-family:var(--sans);font-size:18px;line-height:1.62;
  font-feature-settings:"ss01","cv05";
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

h1,h2,h3{font-family:var(--display);font-weight:500;line-height:1;letter-spacing:-.01em}
h1{font-size:clamp(44px,7vw,104px);letter-spacing:-.02em}
h2{font-size:clamp(32px,4.3vw,60px)}
em{font-style:normal;color:inherit}

.wrap{max-width:var(--max);margin:0 auto;padding:0 var(--pad)}

/* tone system */
.tone-dark{--bg:var(--ink);--accent:var(--brass);--head:var(--head-d);--body:var(--body-d);--cap:var(--cap-d);--hair:var(--line-d)}
.tone-dark2{--bg:var(--ink-2);--accent:var(--brass);--head:var(--head-d);--body:var(--body-d);--cap:var(--cap-d);--hair:var(--line-d)}
.tone-paper{--bg:var(--paper);--accent:var(--terra);--head:var(--ink-on-l);--body:var(--body-l);--cap:var(--cap-l);--hair:var(--line-l)}
section{background:var(--bg);color:var(--body);position:relative;z-index:2}
.tone-dark h2,.tone-dark2 h2,.tone-dark h3,.tone-dark2 h3{color:var(--head-d)}
.tone-paper h2,.tone-paper h3{color:var(--ink-on-l)}

section{padding:112px 0}

/* ---- header / ledger ---- */
.eyebrow{font-family:var(--display);font-weight:800;font-size:11px;letter-spacing:.24em;
         text-transform:uppercase;color:var(--cap)}
.ledger{display:grid;grid-template-columns:minmax(0,1fr) minmax(250px,420px);gap:28px 64px;
        align-items:end;margin-bottom:60px}
.ledger .fig{grid-column:1/-1;display:flex;align-items:center;gap:18px;margin-bottom:8px}
.ledger .fig .num{font-family:var(--display);font-weight:800;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--cap)}
.ledger .fig .ln{flex:1;height:1px;background:var(--hair);transform:scaleX(0);transform-origin:left;transition:transform 1.2s cubic-bezier(.2,.7,.2,1) .15s}
.ledger.in .fig .ln{transform:scaleX(1)}
@media(prefers-reduced-motion:reduce){.ledger .fig .ln{transform:none}}
.ledger .fig .nm{font-family:var(--display);font-weight:800;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--cap)}
.ledger h2{max-width:15ch}
.ledger .lede{font-size:19px;line-height:1.5;color:var(--body);max-width:42ch}
@media(max-width:900px){.ledger{grid-template-columns:1fr;gap:16px}}

/* ---- brandbar with progressive blur ---- */
.brandbar{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;justify-content:space-between;align-items:center;
          padding:20px var(--pad);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:#f3f1ea}
.brandbar .logo{font-family:var(--display);font-weight:800;letter-spacing:.06em;font-size:15px}
.brandbar .marks{display:flex;gap:26px}
.brandbar .marks a{color:rgba(243,241,234,.7)}
.brandbar .marks a:hover{color:#fff}
@media(max-width:700px){.brandbar .marks{display:none}}
/* progressive blur scrim that fades downward */
.pblur{position:fixed;top:0;left:0;right:0;height:120px;z-index:49;pointer-events:none}
.pblur::before{content:"";position:absolute;inset:0;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  -webkit-mask-image:linear-gradient(180deg,#000 0%,#000 32%,transparent 100%);
  mask-image:linear-gradient(180deg,#000 0%,#000 32%,transparent 100%)}
.pblur::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,15,14,.72),transparent)}

/* ---- HERO cinematic ---- */
.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end;background:#0b0b0a;overflow:hidden}
.hero .bg{position:absolute;inset:0;background-size:cover;background-position:center;
          transform:scale(1.04);animation:heroDrift 24s ease-in-out infinite alternate}
@keyframes heroDrift{from{transform:scale(1.04) translateY(0)}to{transform:scale(1.1) translateY(-1.5%)}}
@media(prefers-reduced-motion:reduce){.hero .bg{animation:none;transform:scale(1.04)}}
.hero .grain{position:absolute;inset:0;opacity:.05;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.hero .shade{position:absolute;inset:0;background:
  radial-gradient(120% 90% at 70% 18%,rgba(0,0,0,0) 0%,rgba(0,0,0,.25) 60%,rgba(0,0,0,.55) 100%),
  linear-gradient(180deg,rgba(0,0,0,.5) 0%,rgba(0,0,0,0) 30%,rgba(0,0,0,0) 42%,rgba(0,0,0,.86) 100%)}
/* progressive blur at the very bottom of the hero photo */
.hero .pbottom{position:absolute;left:0;right:0;bottom:0;height:300px;pointer-events:none;z-index:1}
.hero .pbottom::before{content:"";position:absolute;inset:0;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  -webkit-mask-image:linear-gradient(0deg,#000 0%,#000 22%,transparent 78%);
  mask-image:linear-gradient(0deg,#000 0%,#000 22%,transparent 78%)}
.hero .inner{position:relative;z-index:3;max-width:var(--max);margin:0 auto;width:100%;padding:112px var(--pad) 76px;color:#fff}
.hero .eyebrow{color:rgba(255,255,255,.66);display:block;margin-bottom:26px}
.hero h1{color:#fff;max-width:14ch}
.hero h1 em{font-weight:800}
/* subtle optical aberration on the headline */
.hero h1{text-shadow:.012em 0 rgba(194,92,52,.22),-.012em 0 rgba(80,140,170,.16)}
.hero .lede{color:rgba(255,255,255,.9);font-size:clamp(18px,1.6vw,22px);max-width:50ch;margin-top:24px;line-height:1.5}
/* glass facts plate */
.hero .plate{margin-top:46px;display:flex;flex-wrap:wrap;gap:1px;background:var(--line-d);
             border:1px solid rgba(255,255,255,.14);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
             background-color:rgba(20,19,17,.32)}
.hero .plate .f{flex:1 1 160px;padding:20px 24px;background:rgba(18,17,15,.3)}
.hero .plate .k{font-family:var(--display);font-weight:800;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:9px}
.hero .plate .v{font-size:15px;color:#fff}
.hero .scrollcue{position:absolute;right:var(--pad);bottom:40px;z-index:3;font-family:var(--display);font-weight:800;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.6);writing-mode:vertical-rl}
@media(max-width:700px){.hero .scrollcue{display:none}}

/* ---- glass card primitive ---- */
.glass{background:var(--glass);border:1px solid var(--hair);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}

/* observations */
.obs{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}
.obs .o{padding:26px 24px 30px;background:var(--glass);border:1px solid var(--hair);transition:border-color .4s,transform .5s,background .4s}
.obs .o:hover{border-color:rgba(189,147,79,.5);background:rgba(189,147,79,.05);transform:translateY(-3px)}
.obs .o .n{font-family:var(--display);font-weight:800;font-size:12px;letter-spacing:.16em;color:var(--cap)}
.obs .o h3{font-family:var(--display);font-weight:500;font-size:21px;color:var(--head);margin:18px 0 12px;line-height:1.08}
.obs .o p{font-size:15px;color:var(--body);line-height:1.56}
@media(max-width:900px){.obs{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.obs{grid-template-columns:1fr}}

/* full-bleed band */
.band{position:relative;overflow:hidden}
.band img{width:100%;height:clamp(340px,62vh,640px);object-fit:cover}
.band .scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,15,14,.4),transparent 30%,transparent 65%,rgba(15,15,14,.92))}
.band .bcap{position:absolute;left:var(--pad);bottom:30px;font-family:var(--display);font-weight:800;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.85)}

/* metrics — big brass figures */
.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--hair);border:1px solid var(--hair)}
.metric{padding:30px 26px;background:var(--ink)}
.metric .big{font-family:var(--display);font-weight:500;font-size:clamp(32px,3.6vw,50px);color:var(--head);line-height:.95}
.metric .cap{margin-top:12px;font-family:var(--display);font-weight:800;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--cap)}
@media(max-width:780px){.metrics{grid-template-columns:1fr 1fr}}

/* spec badges + comparison */
.badges{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:var(--hair);border:1px solid var(--hair);margin:0 0 48px}
.badge{padding:22px 20px;background:var(--bg)}
.badge .b{font-family:var(--display);font-weight:500;font-size:clamp(22px,2.4vw,30px);color:var(--head)}
.badge .c{font-family:var(--display);font-weight:800;font-size:10px;letter-spacing:.13em;text-transform:uppercase;color:var(--cap);margin-top:9px}
@media(max-width:780px){.badges{grid-template-columns:1fr 1fr 1fr}}
table.cmp{width:100%;border-collapse:collapse;font-size:16px}
.cmp th,.cmp td{text-align:left;padding:17px 18px 17px 0;border-bottom:1px solid var(--hair);vertical-align:top}
.cmp thead th{font-family:var(--display);font-weight:800;font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--cap)}
.cmp td:first-child{color:var(--cap);width:20%;font-family:var(--display);font-weight:800;font-size:11px;letter-spacing:.1em;text-transform:uppercase}
.cmp .yes{color:var(--head);font-weight:600}
.src{font-size:13.5px;color:var(--cap);margin-top:22px;font-style:italic}

/* ---- PRICE (light moment) ---- */
.opts{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.opt{padding:34px 32px;border:1px solid var(--hair);background:#fff;position:relative}
.opt.feature{border-color:var(--ink-on-l);box-shadow:0 30px 70px -42px rgba(0,0,0,.35)}
.opt .tag{position:absolute;top:-1px;right:24px;background:var(--ink-on-l);color:#fff;font-family:var(--display);font-weight:800;font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;padding:7px 12px}
.opt .meta{font-family:var(--display);font-weight:800;font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--cap-l)}
.opt h3{font-family:var(--display);font-weight:500;font-size:25px;color:var(--ink-on-l);margin:12px 0 16px}
.opt .num{font-family:var(--display);font-weight:500;font-size:clamp(40px,5.2vw,62px);color:var(--ink-on-l);line-height:.95;letter-spacing:-.02em}
.opt .num .accent{color:var(--cap-l)}
.opt .od{font-size:15px;color:var(--body-l);margin:18px 0 16px}
.opt ul{list-style:none;border-top:1px solid var(--line-l);margin-top:6px}
.opt li{font-size:14.5px;color:var(--body-l);padding:11px 0 11px 22px;position:relative;border-bottom:1px solid var(--line-l)}
.opt li::before{content:"";position:absolute;left:0;top:19px;width:9px;height:1.5px;background:var(--terra)}
@media(max-width:760px){.opts{grid-template-columns:1fr}}

/* single-system bars (template default) */
.bars{border-top:1px solid var(--line-l)}
.bar{padding:24px 0;border-bottom:1px solid var(--line-l)}
.bar .top{display:flex;justify-content:space-between;align-items:baseline;gap:16px}
.bar .name{font-size:18px;font-weight:600;color:var(--ink-on-l)}
.bar .amt{font-family:var(--display);font-weight:500;font-size:24px;color:var(--ink-on-l)}
.bar .meter{height:3px;background:var(--line-l);margin:14px 0 10px}
.bar .fill{height:100%;background:var(--terra)}
.bar .desc{font-size:14.5px;color:var(--body-l)}
.lines{width:100%;border-collapse:collapse;font-size:15px;margin-top:34px}
.lines th,.lines td{padding:13px 14px 13px 0;border-bottom:1px solid var(--line-l);text-align:left}
.lines td:last-child,.lines th:last-child{text-align:right;white-space:nowrap}
.lines .cat td{font-family:var(--display);font-weight:800;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--terra)}
.lines .total td{font-weight:700;font-size:17px;border-top:2px solid var(--ink-on-l);color:var(--ink-on-l)}

/* decision check — works on dark + light */
.check{margin-top:56px;border-top:1px solid var(--cap);padding-top:26px;max-width:760px}
.check .eyebrow{display:block;margin-bottom:14px}
.check h3{font-family:var(--display);font-weight:500;font-size:clamp(24px,3vw,34px);color:var(--head);line-height:1.08;margin-bottom:14px}
.check p{font-size:18px;line-height:1.56;color:var(--body);max-width:66ch}
.tone-paper .check h3{color:var(--ink-on-l)}.tone-paper .check p{color:var(--body-l)}

/* ---- INSPECTION evidence bars (collapsible, glass) ---- */
.evidence{border-top:1px solid var(--hair)}
.evidence details{border-bottom:1px solid var(--hair);transition:background .4s}
.evidence details[open]{background:rgba(189,147,79,.04)}
.evidence summary{list-style:none;cursor:pointer;display:grid;grid-template-columns:66px minmax(0,1fr) 28px;gap:24px;align-items:center;padding:26px 0}
.evidence summary::-webkit-details-marker{display:none}
.evidence .fno{font-family:var(--display);font-weight:800;font-size:12px;letter-spacing:.1em;color:var(--cap)}
.evidence .ftitle{font-family:var(--display);font-weight:500;font-size:clamp(19px,2.1vw,26px);color:var(--head);line-height:1.1}
.evidence .fsub{font-size:14px;color:var(--cap);margin-top:5px}
.evidence .chev{justify-self:end;width:13px;height:13px;border-right:1.5px solid var(--accent);border-bottom:1.5px solid var(--accent);transform:rotate(45deg);transition:transform .4s}
.evidence details[open] .chev{transform:rotate(225deg)}
.evidence .body{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,1fr);gap:34px;padding:6px 0 36px 90px}
.evidence .body .ph{overflow:hidden;background:#0b0b0a;position:relative}
.evidence .body .ph img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform .9s ease}
.evidence .body .ph:hover img{transform:scale(1.05)}
.evidence .rows .row{padding:14px 0;border-top:1px solid var(--hair)}
.evidence .rows .row:first-child{border-top:0;padding-top:0}
.evidence .rows .lab{font-family:var(--display);font-weight:800;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--cap);margin-bottom:7px}
.evidence .rows .val{font-size:15.5px;color:var(--body);line-height:1.55}
.evidence .rows .val strong{color:var(--head);font-weight:600}
@media(max-width:760px){.evidence summary{grid-template-columns:42px minmax(0,1fr) 22px;gap:14px}.evidence .body{grid-template-columns:1fr;gap:18px;padding-left:0}}

/* gallery */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.shot{overflow:hidden;background:#0b0b0a;position:relative}
.shot img{aspect-ratio:4/3;object-fit:cover;width:100%;transition:transform .8s ease}
.shot:hover img{transform:scale(1.05)}
.shot .cap{position:absolute;left:0;bottom:0;width:100%;padding:30px 16px 14px;font-family:var(--display);font-weight:800;font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:#fff;background:linear-gradient(0deg,rgba(0,0,0,.78),transparent)}
@media(max-width:760px){.gallery{grid-template-columns:1fr}}

/* 3D embed */
.embed{position:relative;aspect-ratio:16/9;width:100%;border:1px solid var(--hair);background:#000;overflow:hidden}
.embed iframe{width:100%;height:100%;border:0;display:block}
.cap-play{position:absolute;inset:0;border:0;padding:0;cursor:pointer;background:#000;display:block;width:100%;height:100%}
.cap-play img{width:100%;height:100%;object-fit:cover;opacity:.66;transition:opacity .4s,transform .9s}
.cap-play:hover img{opacity:.9;transform:scale(1.03)}
.cap-play .play{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);display:inline-flex;gap:12px;align-items:center;
  background:rgba(20,19,15,.55);color:#fff;font-family:var(--display);font-weight:800;font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  padding:16px 26px;border:1px solid rgba(255,255,255,.4);backdrop-filter:blur(8px)}
.cap-play:hover .play{background:var(--brass);border-color:var(--brass);color:#151515}

/* buttons */
.btn{position:relative;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;gap:12px;min-height:54px;padding:16px 30px;
     background:transparent;color:#151515;font-family:var(--display);font-weight:800;font-size:11px;letter-spacing:.16em;text-transform:uppercase;
     border:1px solid #f3f1ea;transition:color .3s,border-color .3s,transform .2s;z-index:0}
.btn::before{content:"";position:absolute;inset:0;z-index:-2;background:#f3f1ea}
.btn::after{content:"";position:absolute;inset:0;z-index:-1;background:var(--brass);transform:translateX(-101%);transition:transform .45s cubic-bezier(.2,.7,.2,1)}
.btn:hover{color:#151515;border-color:var(--brass);transform:translateY(-2px)}
.btn:hover::after{transform:translateX(0)}
.btn.ghost{color:#f3f1ea;border-color:rgba(255,255,255,.4)}
.btn.ghost::before{background:transparent}
.btn.ghost:hover{color:#151515;border-color:var(--brass)}

/* FAQ */
.faq .qa{border-top:1px solid var(--hair)}
.faq details{border-bottom:1px solid var(--hair)}
.faq summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;gap:24px;align-items:baseline;padding:26px 0;
             font-family:var(--display);font-weight:500;font-size:clamp(18px,2vw,24px);color:var(--head);line-height:1.2;transition:color .2s}
.faq summary::-webkit-details-marker{display:none}
.faq summary:hover{color:var(--head)}
.faq summary .pm{flex:none;width:14px;height:14px;position:relative;margin-top:6px}
.faq summary .pm::before,.faq summary .pm::after{content:"";position:absolute;background:var(--cap);transition:transform .3s}
.faq summary .pm::before{left:0;top:6px;width:14px;height:1.5px}
.faq summary .pm::after{left:6px;top:0;width:1.5px;height:14px}
.faq details[open] summary .pm::after{transform:scaleY(0)}
.faq .a{padding:0 0 28px;max-width:72ch;font-size:16px;line-height:1.66;color:var(--body)}
.faq .a strong{color:var(--head);font-weight:600}

/* next step */
.repcard{margin-top:50px;border-top:1px solid var(--hair);padding-top:34px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:26px;align-items:flex-end}
.repcard .label{font-family:var(--display);font-weight:800;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--cap)}
.repcard .rep{font-family:var(--display);font-weight:500;font-size:27px;color:var(--head);margin-top:10px}
.repcard .role{color:var(--body);font-size:15px;margin-top:4px}
.repcard .actions{display:flex;gap:10px;flex-wrap:wrap}
footer{padding:44px 0 64px;background:#0e0e0d;color:#7e7a72;font-size:13px;border-top:1px solid var(--line-d)}
footer .wrap{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap}

/* reveal — with a progressive-blur resolve for finesse (content stays in DOM) */
.rv{opacity:0;transform:translateY(22px);filter:blur(7px);
    transition:opacity 1s cubic-bezier(.2,.7,.2,1),transform 1s cubic-bezier(.2,.7,.2,1),filter 1.1s cubic-bezier(.2,.7,.2,1)}
.rv.in{opacity:1;transform:none;filter:blur(0)}
@media(prefers-reduced-motion:reduce){.rv{opacity:1;transform:none;filter:none;transition:none}}

@media(max-width:900px){:root{--pad:24px}section{padding:78px 0}}

/* ============================================================
   VISUAL FINESSE LAYER (all over real DOM text — crawl-safe)
   ============================================================ */
::selection{background:var(--brass);color:#151312}

/* filmic grain over the whole page */
body::after{content:"";position:fixed;inset:0;z-index:60;pointer-events:none;opacity:.045;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* scroll progress hairline */
.progress{position:fixed;top:0;left:0;height:2px;width:0;z-index:70;background:linear-gradient(90deg,var(--terra),var(--brass));
  box-shadow:0 0 14px rgba(189,147,79,.55)}

/* hero pointer spotlight (subtle) */
.hero .spot{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(420px circle at var(--mx,72%) var(--my,28%),rgba(212,180,131,.12),transparent 60%);
  transition:background .25s ease}
@media(prefers-reduced-motion:reduce){.hero .spot{display:none}}

/* eyebrow gets a growing brass tick */
.ledger h2{position:relative}

/* evidence: brass accent rail on hover/open + smooth body */
.evidence summary{position:relative;transition:padding-left .3s ease}
.evidence summary::before{content:"";position:absolute;left:-22px;top:50%;width:3px;height:0;background:var(--brass);transform:translateY(-50%);transition:height .35s ease}
.evidence details:hover summary::before,.evidence details[open] summary::before{height:60%}
.evidence summary:hover{padding-left:6px}
.evidence details[open] .ftitle{color:var(--head)}
@keyframes evOpen{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.evidence details[open] .body{animation:evOpen .5s cubic-bezier(.2,.7,.2,1)}
@media(prefers-reduced-motion:reduce){.evidence details[open] .body{animation:none}}

/* metric count-up: tabular figures so width doesn't jump */
.metric .big{font-variant-numeric:tabular-nums}

/* ---- BRAVA STORY CARDS (spec → meaning) ---- */
.stories{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--hair);border:1px solid var(--hair);margin:0 0 46px}
.story{padding:30px 30px 28px;background:var(--bg);position:relative;transition:background .4s}
.story:hover{background:rgba(255,255,255,.035)}
.story .st-tag{font-family:var(--display);font-weight:800;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--cap)}
.story h4{font-family:var(--display);font-weight:500;font-size:clamp(21px,2.3vw,27px);color:var(--head);line-height:1.05;margin:16px 0 12px;letter-spacing:-.01em}
.story p{font-size:15.5px;color:var(--body);line-height:1.58}
.story .st-spec{margin-top:18px;padding-top:14px;border-top:1px solid var(--hair);font-family:var(--display);font-weight:800;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--cap)}
@media(max-width:720px){.stories{grid-template-columns:1fr}}

/* ---- STICKY CALL PILL (appears after hero) ---- */
.callpill{position:fixed;right:22px;bottom:22px;z-index:58;display:inline-flex;align-items:center;gap:12px;
  padding:13px 20px 13px 16px;border:1px solid rgba(255,255,255,.22);border-radius:46px;
  background:rgba(20,19,17,.55);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  color:#f3f1ea;font-family:var(--display);font-weight:800;font-size:11px;letter-spacing:.14em;text-transform:uppercase;text-decoration:none;
  opacity:0;transform:translateY(14px) scale(.96);pointer-events:none;
  transition:opacity .5s ease,transform .5s cubic-bezier(.2,.7,.2,1),background .3s,border-color .3s}
.callpill.show{opacity:1;transform:none;pointer-events:auto}
.callpill:hover{background:var(--brass);border-color:var(--brass);color:#151312}
.callpill .dot{width:9px;height:9px;border-radius:50%;background:var(--brass);box-shadow:0 0 0 0 rgba(189,147,79,.6);animation:pulse 2.4s infinite}
.callpill:hover .dot{background:#151312;animation:none}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(189,147,79,.55)}70%{box-shadow:0 0 0 9px rgba(189,147,79,0)}100%{box-shadow:0 0 0 0 rgba(189,147,79,0)}}
@media(prefers-reduced-motion:reduce){.callpill .dot{animation:none}}
@media(max-width:600px){.callpill{right:14px;bottom:14px;padding:12px 17px 12px 14px}}

/* ============================================================
   FIELD EVIDENCE — ranked photo grid + lightbox
   All text (what you're looking at, why it affects price, the
   rankings) lives as visible HTML so LLM crawlers read it.
   The lightbox is a human-only enhancement on top.
   ============================================================ */
.motto{margin:0 0 52px;border-left:3px solid var(--brass);padding:4px 0 4px 26px;
  font-family:var(--display);font-weight:500;font-size:clamp(27px,4.4vw,56px);line-height:1.0;color:var(--head);letter-spacing:-.015em}
.motto em{font-style:normal}
.motto cite{display:block;margin-top:18px;font-family:var(--display);font-weight:800;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--cap);font-style:normal}

.evgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:860px){.evgrid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.evgrid{grid-template-columns:1fr}}
.evcard{display:flex;flex-direction:column;background:var(--glass);border:1px solid var(--hair);transition:border-color .4s,transform .5s}
.evcard:hover{border-color:rgba(189,147,79,.45);transform:translateY(-3px)}
.evopen{position:relative;display:block;width:100%;border:0;padding:0;cursor:zoom-in;background:#0b0b0a;overflow:hidden}
.evopen img{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform .8s ease,opacity .4s}
.evopen:hover img{transform:scale(1.05);opacity:.94}
.evno{position:absolute;left:12px;top:11px;font-family:var(--display);font-weight:800;font-size:11px;letter-spacing:.1em;color:#fff;background:rgba(19,19,18,.6);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);padding:5px 9px;border:1px solid rgba(255,255,255,.18)}
.evzoom{position:absolute;right:12px;bottom:11px;display:inline-flex;align-items:center;gap:8px;color:#151312;background:var(--brass-soft);padding:8px 13px;font-family:var(--display);font-weight:800;font-size:10px;letter-spacing:.12em;text-transform:uppercase;opacity:0;transform:translateY(6px);transition:opacity .3s,transform .3s}
.evcard:hover .evzoom{opacity:1;transform:none}
@media(hover:none){.evzoom{opacity:1;transform:none}}
.evcard figcaption{padding:20px 20px 22px;display:flex;flex-direction:column;gap:14px}
.evcard figcaption h3{font-family:var(--display);font-weight:500;font-size:20px;color:var(--head);line-height:1.08}
.evwhy{font-size:14.5px;color:var(--body);line-height:1.56}
.ranks{display:flex;flex-direction:column;gap:10px;border-top:1px solid var(--hair);padding-top:15px}
.rank{display:grid;grid-template-columns:74px 1fr auto;align-items:center;gap:12px}
.rk-lab{font-family:var(--display);font-weight:800;font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--cap)}
.dots{display:flex;gap:4px}
.dots i{width:13px;height:4px;background:rgba(255,255,255,.15);display:block}
.dots i.on{background:var(--brass)}
/* automation-friendly: set data-level="1".."5" and the fill follows */
.dots[data-level="1"] i:nth-child(-n+1),
.dots[data-level="2"] i:nth-child(-n+2),
.dots[data-level="3"] i:nth-child(-n+3),
.dots[data-level="4"] i:nth-child(-n+4),
.dots[data-level="5"] i:nth-child(-n+5){background:var(--brass)}
.rk-word{font-family:var(--display);font-weight:800;font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--head);justify-self:end}

/* lightbox (human enhancement; content mirrored from the visible card) */
.lbx{position:fixed;inset:0;z-index:90;display:none;place-items:center;padding:32px;background:rgba(9,9,8,.88);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.lbx.open{display:grid;animation:lbIn .35s ease}
@keyframes lbIn{from{opacity:0}to{opacity:1}}
.lbx .box{max-width:980px;width:100%;max-height:90vh;overflow:auto;background:var(--ink-2);border:1px solid var(--hair)}
.lbx .box img{width:100%;max-height:60vh;object-fit:cover;display:block}
.lbx .cap{padding:26px 30px 32px}
.lbx .cap .lno{font-family:var(--display);font-weight:800;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--brass);margin-bottom:12px}
.lbx .cap h3{font-family:var(--display);font-weight:500;font-size:clamp(24px,3vw,32px);color:var(--head);margin-bottom:14px;letter-spacing:-.01em}
.lbx .cap p{font-size:16.5px;color:var(--body);line-height:1.62}
.lbx .x{position:fixed;top:22px;right:26px;width:46px;height:46px;border:1px solid rgba(255,255,255,.3);background:rgba(19,19,18,.6);color:#fff;font-size:18px;cursor:pointer;border-radius:50%;display:grid;place-items:center;transition:background .25s,color .25s,border-color .25s}
.lbx .x:hover{background:var(--brass);color:#151312;border-color:var(--brass)}
@media(prefers-reduced-motion:reduce){.lbx.open{animation:none}}
