/* Loupe — loupeculling.com marketing site
   Darkroom design language, recreated from the live app's tokens.
   Stand-in imagery only (Lorem Picsum / Unsplash-sourced, license-free). */

:root{
  --bg:#14110C; --bg2:#1A150F; --tile:#231D16; --edge:#3A3024;
  --ink:#E9E4D6; --dim:#A79E8C; --faint:#766C5A;
  --amber:#BA7517; --lit:#E2902A; --keep:#639922; --cut:#B0463E;
  /* light "print" palette for the long-copy philosophy band */
  --paper:#E6E2D5; --pink:#1A1815; --slate:#2C5470;
  --hd:'Fraunces',Georgia,serif; --bd:'Newsreader',Georgia,serif;
  --mo:'JetBrains Mono',ui-monospace,monospace;
  --wrap:1120px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family:var(--bd);font-size:18px;line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  background-image:radial-gradient(140% 80% at 50% -10%,#1d1810 0%,var(--bg) 60%);
}
img{max-width:100%;display:block}
a{color:var(--amber);text-decoration:none}
a:hover{color:var(--lit)}
h1,h2,h3{font-family:var(--hd);font-weight:500;line-height:1.05;margin:0}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 24px}
.mono{font-family:var(--mo)}
.amber{color:var(--amber)}
.serif-i{font-family:var(--bd);font-style:italic;color:var(--dim)}

/* section label — one safelight kicker per section */
.kicker{font-family:var(--mo);font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--amber);display:inline-flex;align-items:center;gap:9px;margin:0 0 14px}
.kicker::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--amber);
  box-shadow:0 0 10px 2px rgba(186,117,23,.5)}

/* ---------- NAV ---------- */
.nav{position:sticky;top:0;z-index:50;
  background:rgba(20,17,12,.82);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--edge)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:70px;gap:18px}
.nav .brand{display:flex;align-items:center;gap:12px;min-width:0}
.nav .brand svg{height:50px;width:86px;flex:none}
.nav .dom{font-family:var(--mo);font-size:12.5px;letter-spacing:.04em;color:var(--dim);white-space:nowrap}
.nav .dom b{color:var(--ink);font-weight:500}
.nav .links{display:flex;align-items:center;gap:8px}
.nav .links a{font-family:var(--mo);font-size:12.5px;color:var(--dim);padding:7px 11px;border-radius:7px}
.nav .links a:hover{color:var(--ink);background:var(--tile)}
.nav .links a.cta{color:var(--ink);border:1px solid var(--edge)}
.nav .links a.cta:hover{border-color:var(--amber);color:var(--lit);background:transparent}
@media (max-width:720px){
  .nav .dom{display:none}
  .nav .links a:not(.cta){display:none}
}

/* ---------- HERO ---------- */
.hero{padding:74px 0 46px;text-align:center;position:relative;overflow:hidden}
.hero .mark{height:124px;width:auto;margin:0 auto 26px;display:block;
  filter:drop-shadow(0 6px 26px rgba(0,0,0,.55))}
.hero .tag{font-family:var(--mo);font-size:13px;letter-spacing:.34em;text-transform:uppercase;
  color:var(--amber);margin:0 0 22px}
.hero h1{font-size:clamp(38px,6vw,68px);letter-spacing:-.01em;max-width:16ch;margin:0 auto 22px}
.hero h1 em{font-style:italic;color:var(--lit)}
.hero .lede{font-size:clamp(18px,2.3vw,22px);color:var(--dim);max-width:60ch;margin:0 auto 16px}
.hero .lede b{color:var(--ink);font-weight:400}
.hero .hbtns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:30px}
.btn{font-family:var(--mo);font-size:13px;letter-spacing:.04em;padding:12px 20px;border-radius:9px;
  border:1px solid var(--edge);color:var(--ink);cursor:pointer;transition:.14s;display:inline-block}
.btn:hover{border-color:var(--amber);color:var(--lit)}
.btn.amber{background:var(--amber);color:#160f06;border-color:var(--amber);font-weight:600}
.btn.amber:hover{background:var(--lit);color:#160f06}

/* flagship mockup under hero */
.flagship{max-width:980px;margin:48px auto 0;padding:0 24px}

/* ---------- SECTIONS ---------- */
section{padding:64px 0}
.feat{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.feat.flip .copy{order:2}
.feat .copy h2{font-size:clamp(26px,3.4vw,38px);margin:0 0 16px;letter-spacing:-.01em}
.feat .copy p{color:var(--dim);margin:0 0 14px}
.feat .copy p b{color:var(--ink);font-weight:400}
.feat .copy .pull{font-family:var(--bd);font-style:italic;font-size:20px;color:var(--ink);
  border-left:2px solid var(--amber);padding-left:16px;margin:18px 0 0}
.taglist{list-style:none;padding:0;margin:18px 0 0;display:flex;flex-wrap:wrap;gap:7px}
.taglist li{font-family:var(--mo);font-size:11.5px;color:var(--dim);
  border:1px solid var(--edge);border-radius:13px;padding:4px 11px;background:var(--tile)}
@media (max-width:820px){
  .feat{grid-template-columns:1fr;gap:26px}
  .feat.flip .copy{order:0}
}

.sechead{text-align:center;max-width:64ch;margin:0 auto 44px}
.sechead h2{font-size:clamp(28px,3.6vw,40px);margin:0 0 14px}
.sechead p{color:var(--dim);margin:0}

/* device frame around mockups */
.device{background:var(--bg);border:1px solid var(--edge);border-radius:14px;overflow:hidden;
  box-shadow:0 22px 60px -22px rgba(0,0,0,.8),0 0 0 1px rgba(0,0,0,.4);position:relative}
.device .titlebar{display:flex;align-items:center;gap:7px;padding:9px 13px;border-bottom:1px solid var(--edge);
  background:var(--bg2)}
.device .titlebar i{width:9px;height:9px;border-radius:50%;background:var(--edge);display:block}
.device .titlebar .url{margin-left:10px;font-family:var(--mo);font-size:10.5px;color:var(--faint)}

/* ================= APP MOCKUP RE-CREATIONS ================= */
/* header band */
.m-head{padding:9px 16px;border-bottom:1px solid var(--edge);background:var(--bg)}
.m-hrow{display:flex;align-items:center;justify-content:space-between;gap:12px}
.m-brand{display:flex;align-items:center;gap:10px;line-height:0}
.m-brand svg{height:30px;width:52px}
.m-brandtag{font-family:var(--mo);font-size:9px;letter-spacing:.18em;color:var(--faint)}
.m-hbtns{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}
.m-btn{font-family:var(--mo);font-size:10.5px;color:var(--dim);background:#221b13;
  border:1px solid var(--edge);border-radius:6px;padding:5px 8px;white-space:nowrap}
.m-crumb{font-family:var(--hd);font-size:13px;color:var(--dim);text-align:center;margin:8px 0 6px}
.m-crumb .cur{color:var(--ink);background:#2a2015;border:1px solid var(--edge);border-radius:6px;padding:2px 9px}
.m-crumb .sep{color:#5e4d3a;font-family:var(--mo);font-size:11px;margin:0 6px}
.m-stats{display:flex;justify-content:space-between;flex-wrap:wrap;gap:4px 14px;
  font-family:var(--mo);font-size:11px;color:var(--dim);padding-top:4px}
.m-stats b{color:var(--ink)} .m-stats .g{color:var(--keep)} .m-stats .r{color:var(--cut)}
.m-stats .pc{color:var(--amber)}

/* 35mm film-strip discovery carousel */
.m-carousel{position:relative;overflow:hidden;padding:6px 0 16px;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.m-marquee{display:flex;gap:0;width:max-content;will-change:transform;
  animation:m-marq 90s linear infinite;
  background-color:color-mix(in srgb,var(--bg) 66%,var(--edge));
  background-image:
    radial-gradient(ellipse 10px 5px at 15px 7px,color-mix(in srgb,var(--dim) 28%,var(--bg)) 60%,transparent 64%),
    radial-gradient(ellipse 10px 5px at 15px 7px,color-mix(in srgb,var(--dim) 28%,var(--bg)) 60%,transparent 64%);
  background-repeat:repeat-x,repeat-x;background-position:left top,left bottom;background-size:30px 14px,30px 14px}
.m-carousel:hover .m-marquee{animation-play-state:paused}
@keyframes m-marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.m-ctile{flex:none;display:flex;flex-direction:column;width:184px;height:158px;padding:13px 7px;cursor:pointer}
.m-cframe{position:relative;flex:0 0 116px;overflow:hidden;border-radius:2px;
  background:color-mix(in srgb,var(--bg) 66%,var(--edge))}
.m-cframe img{width:100%;height:100%;object-fit:cover;border-radius:2px}
.m-cframe img.port{width:auto;height:100%;margin:0 auto;object-fit:contain;
  box-shadow:0 0 0 1px color-mix(in srgb,var(--edge) 55%,transparent)}
.m-crebate{flex:1;display:flex;align-items:center;gap:7px;padding:0 1px;font-family:var(--mo);
  font-size:8px;letter-spacing:.06em;line-height:1;white-space:nowrap;overflow:hidden}
.m-cep{color:color-mix(in srgb,var(--dim) 80%,var(--bg))}
.m-cnum{color:color-mix(in srgb,var(--dim) 52%,var(--bg))}
.m-cstock{margin-left:auto;color:color-mix(in srgb,var(--dim) 36%,var(--bg))}
.m-ctile:hover .m-cframe{box-shadow:0 0 0 2px var(--amber)}
@media (prefers-reduced-motion:reduce){.m-marquee{animation:none;flex-wrap:nowrap;overflow:hidden}}

/* overview month-photobook tiles */
.m-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px;padding:16px}
.m-mtile{display:flex;flex-direction:column;gap:6px}
.m-spread{position:relative;aspect-ratio:4/5;border-radius:7px;overflow:hidden;border:1px solid var(--edge);
  display:flex;background:#000}
.m-spread.cur{border-color:var(--amber)}
.m-spread .pg{flex:1;overflow:hidden;position:relative}
.m-spread .pg img{width:100%;height:100%;object-fit:cover}
.m-spread .spine{position:absolute;left:calc(50% - 1px);top:0;bottom:0;width:2px;z-index:4;
  background:color-mix(in srgb,var(--bg) 40%,#000);box-shadow:0 0 7px 2px rgba(0,0,0,.55)}
.m-mcap .mn{font-family:var(--hd);font-size:16px;color:var(--ink)}
.m-mtile.cur .mn{color:var(--amber)}
.m-mcap .mprose{font-family:var(--bd);font-style:italic;font-size:12px;line-height:1.34;color:var(--dim);margin-top:2px}
.m-mcap .mmeta{font-family:var(--mo);font-size:9.5px;color:var(--faint);margin-top:4px}
.m-mcap .mmeta .pc{color:var(--amber)}

/* focus / review */
.m-focus{display:flex;min-height:340px}
.m-stage{flex:1;background:#000;display:flex;align-items:center;justify-content:center;position:relative}
.m-stage img{max-width:100%;max-height:380px;object-fit:contain}
.m-stage .fr{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-family:var(--hd);font-size:60px;color:var(--keep);opacity:.0}
.m-meta{flex:0 0 290px;width:290px;background:var(--bg2);border-left:1px solid var(--edge);padding:14px 15px;overflow:hidden}
.m-sig{margin:0 0 14px}
.m-sig-h{font-family:var(--mo);font-size:9.5px;letter-spacing:.09em;text-transform:uppercase;color:var(--amber);
  border-bottom:1px solid var(--edge);padding-bottom:3px;margin-bottom:8px}
.m-srow{display:grid;grid-template-columns:auto 1fr;font-family:var(--mo);font-size:11.5px;gap:3px 12px}
.m-srow .k{color:var(--dim)} .m-srow .v{color:var(--ink);text-align:right}
.m-score{margin:9px 0}
.m-score .top{display:flex;justify-content:space-between;font-family:var(--mo);font-size:11px}
.m-score .top .nm{color:var(--dim)} .m-score .top .vl{color:var(--ink)}
.m-pbar{height:6px;background:var(--tile);border:1px solid var(--edge);border-radius:4px;overflow:hidden;margin-top:4px}
.m-pbar i{display:block;height:100%;background:var(--amber)}
.m-chips{display:flex;flex-wrap:wrap;gap:5px;margin-top:4px}
.m-lchip{font-family:var(--mo);font-size:10.5px;padding:2px 8px;border:1px solid var(--edge);border-radius:12px;color:var(--ink);white-space:nowrap}
.m-lchip b{color:var(--dim);font-weight:400;margin-left:5px}
.m-pchip{font-family:var(--mo);font-size:10.5px;padding:3px 9px;border-radius:13px;background:var(--tile);border:1px solid var(--edge);color:var(--ink)}
.m-pchip.prot{border-color:var(--amber);box-shadow:inset 0 0 0 1px var(--amber);color:#f0d9b3}
.m-pchip.prot::before{content:'●';color:var(--amber);margin-right:5px;font-size:7px;vertical-align:1px}
.m-sdtag{display:inline-block;font-family:var(--mo);font-size:10.5px;font-weight:600;padding:3px 9px;border-radius:5px;
  background:#21343a;color:#a7d7df;border:1px solid #7fb0b8}
.m-acts{display:flex;gap:8px;padding:11px 14px;border-top:1px solid var(--edge);background:var(--bg)}
.m-acts .a{flex:1;text-align:center;font-family:var(--mo);font-size:13px;padding:12px 8px;border-radius:8px;border:1px solid}
.m-acts .bcut{background:#3a1d1a;border-color:var(--cut);color:#ff9a8f}
.m-acts .bkeep{background:#15301f;border-color:var(--keep);color:#9be8b6}
.m-acts .bskip{background:#221b13;border-color:var(--edge);color:var(--dim)}
@media (max-width:680px){.m-focus{flex-direction:column}.m-meta{width:auto;flex:none;border-left:none;border-top:1px solid var(--edge)}}

/* decision-review grid */
.m-dechead{font-family:var(--hd);font-size:18px;color:var(--ink);padding:12px 16px 4px;display:flex;align-items:baseline;gap:9px}
.m-dechead .c{font-family:var(--mo);font-size:11px;color:var(--dim)}
.m-tgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px;padding:8px 16px 16px}
.m-tile{position:relative;border:2px solid #2a2218;border-radius:7px;overflow:hidden;aspect-ratio:4/5;background:#0c0a07}
.m-tile img{width:100%;height:100%;object-fit:cover}
.m-tile.keep{border-color:var(--keep)} .m-tile.cut{border-color:var(--cut);opacity:.5}
.m-tile .st{position:absolute;bottom:4px;right:4px;font-family:var(--mo);font-size:9px;padding:1px 5px;border-radius:3px}
.m-tile .st.k{background:var(--keep);color:#04240f} .m-tile .st.c{background:var(--cut);color:#fff}
.m-tile .prot{position:absolute;top:4px;left:4px;font-family:var(--mo);font-size:8px;color:var(--amber);
  background:#000b;border:1px solid var(--amber);border-radius:3px;padding:1px 4px}

/* candidates bar */
.m-candbar{display:flex;gap:7px;flex-wrap:wrap;padding:12px 16px;border-bottom:1px solid var(--edge)}
.m-chip{font-family:var(--mo);font-size:11px;padding:5px 11px;border:1px solid var(--edge);border-radius:14px;color:var(--dim)}
.m-chip.on{border-color:var(--amber);color:var(--ink);background:#2a2015}

/* places postcards */
.m-postcards{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:18px;padding:18px}
.m-pc{position:relative;background:#efe7d6;border-radius:3px;padding:9px 9px 0;box-shadow:0 2px 5px #0007,0 0 0 1px #0004}
.m-pc .stripe{position:absolute;top:0;left:0;right:0;height:5px;border-radius:3px 3px 0 0;
  background:repeating-linear-gradient(-45deg,#B0463E 0 7px,transparent 7px 14px,#2e5a86 14px 21px,transparent 21px 28px)}
.m-pc .hero{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:1px}
.m-pc .pm{position:absolute;top:18px;right:15px;width:52px;height:52px;border:2px solid #9c2f28;border-radius:50%;
  color:#9c2f28;transform:rotate(-13deg);font-family:var(--mo);display:flex;flex-direction:column;
  align-items:center;justify-content:center;opacity:.82;background:#efe7d6aa}
.m-pc .pm b{font-size:13px;font-weight:700}.m-pc .pm i{font-size:8px;font-style:normal}
.m-pc .cap{padding:8px 2px 10px}
.m-pc .city{font-family:var(--hd);font-size:18px;color:#241d15;line-height:1.05}
.m-pc .reg{font-family:var(--bd);font-size:12px;color:#5e533f}
.m-pc .dr{font-family:var(--mo);font-size:10px;color:#7a6c50;margin-top:5px}

/* trips contact-sheet strip */
.m-tsmast{background:#efe7d6;color:#241d15;margin:14px 16px;border-radius:4px;padding:14px 16px;position:relative;
  box-shadow:0 2px 6px #0007,0 0 0 1px #0004}
.m-tsmast .pm{position:absolute;top:12px;right:16px;width:54px;height:54px;border:2px solid #9c2f28;border-radius:50%;
  color:#9c2f28;transform:rotate(-12deg);font-family:var(--mo);display:flex;flex-direction:column;
  align-items:center;justify-content:center;opacity:.82}
.m-tsmast .pm b{font-size:14px;font-weight:700}.m-tsmast .pm i{font-size:8px;font-style:normal}
.m-tsmast .city{font-family:var(--hd);font-size:24px}
.m-tsmast .reg{font-family:var(--bd);font-size:13px;color:#5e533f}
.m-tsmast .exif{font-family:var(--mo);font-size:11px;color:#6b5f4a;margin-top:9px;border-top:1px solid #cabfa9;
  padding-top:7px;display:flex;flex-wrap:wrap;gap:4px 14px}
.m-tsmast .exif b{color:#241d15}
.m-strip{position:relative;margin:14px 16px;background:#161210;border:1px solid #2a2118;border-radius:3px;
  padding:15px 0;display:flex;align-items:center;min-height:108px;overflow:hidden}
.m-strip .rail{position:absolute;left:0;right:0;height:9px;
  background:repeating-linear-gradient(90deg,transparent 0 7px,#000 7px 9px,transparent 9px 18px)}
.m-strip .rail.t{top:2px}.m-strip .rail.b{bottom:2px}
.m-strip .edge{position:absolute;top:1px;left:9px;font-family:var(--mo);font-size:8px;letter-spacing:.5px;color:var(--amber);opacity:.7}
.m-strip .frames{display:flex;gap:6px;padding:0 12px}
.m-fcell{position:relative;flex:0 0 auto;width:78px;height:78px;background:#000;border-radius:2px;overflow:hidden}
.m-fcell img{width:100%;height:100%;object-fit:cover}
.m-fcell.sel{box-shadow:inset 0 0 0 2px var(--amber)}
.m-fcell .gmark{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.m-fcell .gmark.keep::before{content:'';width:74%;height:80%;border:3px solid #6ad08e;border-radius:50%;transform:rotate(-7deg);opacity:.9}
.m-fcell .gmark.cut::before{content:'✕';color:#ef6a60;font-family:var(--hd);font-size:28px;opacity:.95}

/* ---------- PHILOSOPHY (print band) ---------- */
.print{background:var(--paper);color:var(--pink);
  background-image:radial-gradient(120% 60% at 50% 0,#f0ece0 0,var(--paper) 60%)}
.print .kicker{color:#9c6512}.print .kicker::before{background:#9c6512;box-shadow:none}
.print h2{font-size:clamp(28px,3.6vw,42px);color:var(--pink)}
.print .lede{font-family:var(--bd);font-size:21px;color:#3a352b;max-width:60ch;margin:14px 0 0}
.print .lede em{color:var(--slate);font-style:italic}
.safe{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:44px}
.safe .card{background:#fff;border:1px solid #d8d2c2;border-radius:10px;padding:22px;box-shadow:0 2px 10px #0000000d}
.safe .card h3{font-size:21px;color:var(--pink);margin-bottom:9px;display:flex;align-items:center;gap:9px}
.safe .card .g{color:#4e7d1d}.safe .card .r{color:#9c2f28}
.safe .card p{font-size:15.5px;color:#4a4438;margin:0;line-height:1.55}
.safe .card .lbl{font-family:var(--mo);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:#9a8f78}
@media (max-width:820px){.safe{grid-template-columns:1fr}}

/* ---------- SELF-HOSTED ---------- */
.host{text-align:center}
.host .pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:40px;text-align:left}
.host .pill{border:1px solid var(--edge);border-radius:12px;padding:24px;background:var(--bg2)}
.host .pill .ic{font-family:var(--mo);font-size:11px;letter-spacing:.12em;color:var(--amber);text-transform:uppercase}
.host .pill h3{font-size:20px;margin:10px 0 8px}
.host .pill p{color:var(--dim);font-size:15.5px;margin:0;line-height:1.55}
@media (max-width:820px){.host .pillars{grid-template-columns:1fr}}

/* feature-grid (smaller features) */
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:8px}
.grid3 .g3{border:1px solid var(--edge);border-radius:12px;overflow:hidden;background:var(--bg2)}
.grid3 .g3 .body{padding:18px 20px}
.grid3 .g3 h3{font-size:20px;margin:0 0 8px}
.grid3 .g3 p{color:var(--dim);font-size:15px;margin:0;line-height:1.5}
.grid3 .g3 .mb{border-bottom:1px solid var(--edge)}
@media (max-width:820px){.grid3{grid-template-columns:1fr}}

/* ---------- FOOTER ---------- */
footer{border-top:1px solid var(--edge);padding:48px 0 60px;text-align:center}
footer svg{height:46px;width:auto;margin:0 auto 16px;opacity:.92}
footer .dom{font-family:var(--mo);font-size:13px;color:var(--ink);letter-spacing:.04em}
footer .meta{font-family:var(--mo);font-size:11.5px;color:var(--faint);margin-top:10px;line-height:1.7}
footer .meta a{color:var(--dim)}
footer .tag{font-family:var(--bd);font-style:italic;color:var(--dim);margin-top:14px}

.divider{height:1px;background:linear-gradient(90deg,transparent,var(--edge),transparent);margin:0 auto;max-width:var(--wrap)}

/* ============================================================
   MOBILE REDESIGN PASS (≤640px). Desktop layout is untouched —
   everything below is gated behind variant toggles or the query.
   ============================================================ */
.hero-m{display:none}
.navmob{display:none}
.tag,.m-brandtag,.tag-m{white-space:nowrap}   /* tagline never wraps/overlaps */

@media (max-width:640px){
  body{font-size:16px}
  .wrap{padding:0 18px}

  /* --- nav: wordmark left + single Self-host link right --- */
  .nav .wrap{height:58px}
  .nav .brand svg{height:38px;width:65px}
  .nav .links a.cta{display:none}
  .nav .links a.navmob{display:inline-flex;align-items:center;min-height:44px;
    font-family:var(--mo);font-size:13px;letter-spacing:.04em;color:var(--ink);padding:0 4px;background:none}
  .nav .links a.navmob:hover{color:var(--lit)}

  /* --- hero: headline-first --- */
  .hero{padding:26px 0 22px;text-align:left;background-image:none}
  .hero-d{display:none}
  .hero-m{display:block}
  .hero-kick{color:var(--dim);margin:0 0 14px}
  .hero-kick::before{display:none}
  .hero-h{font-family:var(--hd);font-weight:500;font-size:clamp(33px,10.5vw,44px);
    line-height:1.05;letter-spacing:-.01em;margin:0 0 16px;color:var(--ink)}
  .hero-h em{font-style:normal;color:var(--lit)}
  .hero-body{font-family:var(--bd);font-size:17px;line-height:1.55;color:var(--dim);margin:0 0 18px}
  .tag-m{font-family:var(--mo);font-size:12px;letter-spacing:.14em;text-transform:uppercase;
    color:var(--amber);margin:0 0 22px}
  .hero-cta{display:flex;flex-direction:column;gap:11px}
  .hero-cta .btn{width:100%;text-align:center;padding:15px 18px;font-size:14px}

  /* --- flagship + every mockup card: tight, no voids --- */
  .flagship{margin-top:6px;padding:0 16px}
  .m-hbtns{display:none}                       /* removes the wrapping button stack = the void */
  .m-head{padding:10px 14px}
  .m-hrow{justify-content:flex-start;gap:9px}
  .m-brand{flex:0 0 auto}
  .m-brand svg{height:26px !important;width:45px !important}
  .m-brandtag{font-size:9px;letter-spacing:.16em}
  .m-crumb{margin:9px 0;font-size:13px}
  .m-stats{font-size:10.5px;gap:3px 12px;justify-content:flex-start}
  .m-carousel{padding:6px 0 0}                 /* film strip flush to card bottom */
  .device .titlebar .url{font-size:10px}

  /* --- section rhythm: comfortable, not cavernous --- */
  section{padding:42px 0}
  .feat{gap:22px}
  .feat .copy .pull{font-size:18px}
  .sechead{margin-bottom:30px}
  .grid3,.safe,.host .pillars{gap:14px}
  .print .lede,.host .sechead p{font-size:17px}

  /* --- tap targets --- */
  .btn{min-height:44px;display:inline-flex;align-items:center;justify-content:center}
}
