/* ============================================================
   PACC ARMOR — Pistol Pants store
   Tactical-premium DTC design system
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Saira+Condensed:wght@500;600;700;800;900&family=Archivo:wght@400;500;600;700&family=Space+Mono:wght@400;700&display=swap');

:root{
  --ink:#0c0d09;
  --ink-2:#121309;
  --panel:#16180f;
  --panel-2:#1d1f14;
  --line:#2c2e20;
  --line-soft:#23251a;

  --tan:#c79a57;          /* coyote / primary accent */
  --tan-bright:#e2b673;
  --tan-deep:#a87f3f;
  --od:#73794f;           /* OD green secondary */
  --blaze:#d9622b;        /* urgency / alert */

  --bone:#ece7d8;         /* primary text on dark */
  --bone-dim:#b6b2a2;
  --muted:#8c897a;
  --muted-2:#6b695d;

  --ok:#7fae5a;

  --display:'Saira Condensed',sans-serif;
  --body:'Archivo',sans-serif;
  --mono:'Space Mono',monospace;

  --maxw:1280px;
  --radius:3px;          /* tactical = sharp */
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--body);
  background:var(--ink);
  color:var(--bone);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}

/* atmospheric backdrop: warm grain + faint grid */
body::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(900px 600px at 80% -10%, rgba(199,154,87,.10), transparent 60%),
    radial-gradient(700px 500px at -10% 110%, rgba(115,121,79,.10), transparent 60%);
}
body::after{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.035;
  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='.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
main,header,footer,.bar{position:relative;z-index:1}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(24px,4.5vw,64px)}

/* ---------- typographic helpers ---------- */
.kicker{
  font-family:var(--mono);font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--tan);display:inline-flex;align-items:center;gap:10px;
}
.kicker::before{content:"";width:26px;height:1px;background:var(--tan);display:inline-block}
.kicker.center::after{content:"";width:26px;height:1px;background:var(--tan);display:inline-block}
.kicker.center{justify-content:center}

h1,h2,h3,.display{font-family:var(--display);font-weight:800;line-height:.95;letter-spacing:.01em;text-transform:uppercase}
.h-xl{font-size:clamp(44px,7.4vw,104px)}
.h-lg{font-size:clamp(34px,5vw,68px)}
.h-md{font-size:clamp(26px,3.4vw,42px)}

.lead{font-size:clamp(16px,1.5vw,19px);color:var(--bone-dim);max-width:54ch}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:12px;
  font-family:var(--display);font-weight:700;font-size:18px;letter-spacing:.06em;text-transform:uppercase;
  padding:17px 30px;border-radius:var(--radius);transition:.25s var(--ease);
  position:relative;white-space:nowrap;
}
.btn-primary{background:var(--tan);color:#1a1404;box-shadow:0 0 0 0 rgba(199,154,87,.5)}
.btn-primary:hover{background:var(--tan-bright);transform:translateY(-2px);box-shadow:0 14px 34px -12px rgba(199,154,87,.7)}
.btn-ghost{background:transparent;color:var(--bone);border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--tan);color:var(--tan)}
.btn-dark{background:#0e0f0a;color:var(--bone);border:1px solid var(--line)}
.btn-dark:hover{background:#000;border-color:var(--tan)}
.btn-block{width:100%}
.btn-lg{font-size:21px;padding:20px 34px}
.btn .arrow{transition:transform .25s var(--ease)}
.btn:hover .arrow{transform:translateX(5px)}

/* tactical tag */
.tag{font-family:var(--mono);font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--muted);border:1px solid var(--line);padding:5px 10px;border-radius:2px}
.tag-tan{color:var(--tan);border-color:rgba(199,154,87,.4)}

/* ============================================================
   ANNOUNCEMENT BAR
   ============================================================ */
.announce{
  background:var(--tan);color:#1a1404;font-family:var(--mono);
  font-size:12px;letter-spacing:.16em;text-transform:uppercase;
  height:38px;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;z-index:60;
}
.announce .track{display:flex;align-items:center;gap:60px;white-space:nowrap;animation:marq 26s linear infinite}
.announce .track span{display:inline-flex;align-items:center;gap:60px}
.announce b{font-weight:700}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============================================================
   HEADER
   ============================================================ */
.hdr{
  position:sticky;top:0;z-index:55;
  background:rgba(12,13,9,.78);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line-soft);
}
.hdr-in{display:flex;align-items:center;justify-content:space-between;height:72px}
.brandmark{display:flex;align-items:center;gap:11px}
.brand-logo{height:40px;width:auto;display:block}
.foot .brand-logo{height:48px}
.brandmark .glyph{
  width:34px;height:34px;border:2px solid var(--tan);border-radius:3px;
  display:grid;place-items:center;font-family:var(--display);font-weight:900;color:var(--tan);font-size:20px;
  position:relative;
}
.brandmark .glyph::after{content:"";position:absolute;inset:5px;border:1px solid rgba(199,154,87,.35)}
.brandmark .word{font-family:var(--display);font-weight:900;font-size:23px;letter-spacing:.06em;line-height:1}
.brandmark .word small{display:block;font-family:var(--mono);font-weight:400;font-size:8.5px;letter-spacing:.42em;color:var(--muted);margin-top:3px}

.nav{display:flex;gap:30px}
.nav a{font-family:var(--display);font-weight:600;font-size:16px;letter-spacing:.05em;text-transform:uppercase;color:var(--bone-dim);position:relative;padding:6px 0;transition:.2s}
.nav a::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--tan);transition:width .25s var(--ease)}
.nav a:hover{color:var(--bone)}
.nav a:hover::after{width:100%}
.nav a.hot{color:var(--tan)}

.hdr-actions{display:flex;align-items:center;gap:6px}
.icon-btn{width:42px;height:42px;display:grid;place-items:center;border-radius:3px;color:var(--bone-dim);transition:.2s;position:relative}
.icon-btn:hover{color:var(--tan);background:var(--panel)}
.icon-btn svg{width:21px;height:21px}
.cart-count{
  position:absolute;top:5px;right:4px;min-width:17px;height:17px;padding:0 4px;border-radius:9px;
  background:var(--tan);color:#1a1404;font-family:var(--mono);font-size:10px;font-weight:700;
  display:grid;place-items:center;line-height:1;
}
.menu-toggle{display:none}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line-soft)}

/* faded autoplay background video */
.hero-bg{position:absolute;inset:0;z-index:0;overflow:hidden;background:var(--ink)}
.hero-bg-vid{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  opacity:0;transition:opacity 1.6s var(--ease);
  filter:grayscale(.25) contrast(1.05) brightness(.85);transform:scale(1.04);
}
.hero-bg-vid.ready{opacity:.30}
/* scrim keeps headline + lead legible over the footage */
.hero-bg-scrim{position:absolute;inset:0;
  background:
    linear-gradient(90deg, rgba(12,13,9,.92) 0%, rgba(12,13,9,.7) 38%, rgba(12,13,9,.32) 70%, rgba(12,13,9,.55) 100%),
    linear-gradient(180deg, rgba(12,13,9,.55) 0%, transparent 22%, transparent 70%, rgba(12,13,9,.9) 100%),
    radial-gradient(120% 80% at 78% 30%, rgba(199,154,87,.10), transparent 60%);
}
/* when JS gates out the video (mobile / save-data / slow link / reduced motion) */
.hero.novid .hero-bg{background:#0c0d09 url('video/hero-poster.jpg') center/cover no-repeat}
.hero.novid .hero-bg-vid,.hero.novid .hero-vidtoggle{display:none}
@media (prefers-reduced-motion: reduce){
  .hero-bg-vid{display:none}
  .hero-bg{background:#0c0d09 url('video/hero-poster.jpg') center/cover no-repeat}
}

/* WCAG 2.2.2 pause/play control for the auto-playing backdrop */
.hero-vidtoggle{
  position:absolute;bottom:16px;right:16px;z-index:3;
  width:38px;height:38px;display:grid;place-items:center;
  background:rgba(12,13,9,.7);backdrop-filter:blur(6px);
  border:1px solid var(--line);border-radius:3px;color:var(--bone-dim);transition:.2s var(--ease)}
.hero-vidtoggle:hover{color:var(--tan);border-color:var(--tan)}
.hero-vidtoggle:focus-visible{outline:2px solid var(--tan);outline-offset:2px}
.hero-vidtoggle svg{width:17px;height:17px}

.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;align-items:center;gap:30px;min-height:84vh;padding-block:40px 30px}
.hero-copy{max-width:600px}
.hero-copy h1{margin:18px 0 0}
.hero-copy h1 .em{color:var(--tan);-webkit-text-stroke:0}
.hero-copy .lead{margin:22px 0 32px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero-proof{display:flex;gap:26px;margin-top:36px;flex-wrap:wrap}
.hero-proof .pp{display:flex;flex-direction:column;gap:3px}
.hero-proof .pp b{font-family:var(--display);font-size:30px;font-weight:800;color:var(--bone);line-height:1}
.hero-proof .pp span{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.stars{color:var(--tan);letter-spacing:2px;font-size:15px}

.hero-media{position:relative}
.hero-media .stage{
  position:relative;border:1px solid var(--line);border-radius:6px;overflow:hidden;
  background:
    radial-gradient(120% 90% at 50% 0%, rgba(199,154,87,.12), transparent 55%),
    linear-gradient(180deg,#191b12,#0e0f0a);
}
.hero-media .stage::before{
  content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:34px 34px;opacity:.5;
}
.hero-media img{position:relative;width:100%;object-fit:contain;padding:18px 18px 0}
.hero-media .float{
  position:absolute;background:rgba(12,13,9,.86);backdrop-filter:blur(8px);border:1px solid var(--line);
  border-radius:4px;padding:11px 14px;display:flex;gap:11px;align-items:center;animation:floaty 5s var(--ease) infinite;
}
.hero-media .float .dot{width:9px;height:9px;border-radius:50%;background:var(--ok);box-shadow:0 0 10px var(--ok);flex:none}
.hero-media .float b{font-family:var(--display);font-size:15px;letter-spacing:.04em;text-transform:uppercase}
.hero-media .float small{display:block;font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;color:var(--muted)}
.hero-media .f1{top:26px;left:-14px;animation-delay:.2s}
.hero-media .f2{bottom:60px;right:-14px;animation-delay:1.2s}
.hero-media .price-flag{
  position:absolute;bottom:22px;left:22px;background:var(--tan);color:#1a1404;
  font-family:var(--display);font-weight:800;border-radius:4px;padding:10px 16px;line-height:1;
}
.hero-media .price-flag b{font-size:34px}
.hero-media .price-flag span{font-family:var(--mono);font-size:10px;letter-spacing:.12em;display:block;margin-bottom:3px;text-transform:uppercase}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}

/* reveal animation */
.reveal{opacity:0;transform:translateY(26px);transition:.8s var(--ease)}
.reveal.in{opacity:1;transform:none}
[data-d="1"]{transition-delay:.08s}[data-d="2"]{transition-delay:.16s}[data-d="3"]{transition-delay:.24s}
[data-d="4"]{transition-delay:.32s}[data-d="5"]{transition-delay:.4s}[data-d="6"]{transition-delay:.48s}

/* ============================================================
   MARQUEE TRUST STRIP
   ============================================================ */
.trust-strip{border-bottom:1px solid var(--line-soft);background:var(--ink-2);overflow:hidden}
.trust-strip .track{display:flex;gap:54px;white-space:nowrap;padding:18px 0;animation:marq 32s linear infinite}
.trust-strip .track span{display:inline-flex;gap:54px}
.trust-strip .it{display:inline-flex;align-items:center;gap:12px;font-family:var(--display);font-weight:700;font-size:19px;letter-spacing:.05em;text-transform:uppercase;color:var(--bone-dim)}
.trust-strip .it svg{width:20px;height:20px;color:var(--tan);flex:none}

/* ============================================================
   SECTION SHELL
   ============================================================ */
section{padding:96px 0}
.sec-head{max-width:720px;margin-bottom:52px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head h2{margin:16px 0 14px}
.sec-head p{color:var(--bone-dim);font-size:17px}

/* ============================================================
   FEATURED PRODUCT SPLIT
   ============================================================ */
.feature{background:linear-gradient(180deg,var(--ink),var(--ink-2))}
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.split-media{position:relative;border:1px solid var(--line);border-radius:6px;overflow:hidden;background:linear-gradient(180deg,#1a1c12,#0d0e09)}
.split-media img{width:100%}
.split-media .corner{position:absolute;top:14px;left:14px;font-family:var(--mono);font-size:10px;letter-spacing:.2em;color:var(--tan);text-transform:uppercase}
.spec-list{list-style:none;margin:26px 0 32px;display:grid;gap:2px}
.spec-list li{display:grid;grid-template-columns:30px 1fr;gap:16px;align-items:start;padding:15px 0;border-top:1px solid var(--line-soft)}
.spec-list li:last-child{border-bottom:1px solid var(--line-soft)}
.spec-list .n{font-family:var(--mono);font-size:12px;color:var(--tan)}
.spec-list b{font-family:var(--display);font-weight:700;font-size:19px;letter-spacing:.03em;text-transform:uppercase;display:block;margin-bottom:2px}
.spec-list p{color:var(--muted);font-size:14.5px}
.buy-inline{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.buy-inline .price{font-family:var(--display);font-weight:800;font-size:42px;line-height:1}
.buy-inline .price small{font-family:var(--mono);font-size:12px;color:var(--muted);display:block;letter-spacing:.1em}

/* ============================================================
   TECH / FEATURE CARDS
   ============================================================ */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{border:1px solid var(--line);border-radius:6px;overflow:hidden;background:var(--panel);transition:.3s var(--ease);position:relative}
.card:hover{transform:translateY(-6px);border-color:var(--tan);box-shadow:0 24px 50px -28px rgba(0,0,0,.9)}
.card .ph{aspect-ratio:1/1;overflow:hidden;position:relative;background:#0e0f09}
.card .ph img{width:100%;height:100%;object-fit:cover;transition:.6s var(--ease)}
.card:hover .ph img{transform:scale(1.06)}
.card .ph .num{position:absolute;top:12px;left:12px;font-family:var(--mono);font-size:10px;letter-spacing:.2em;color:var(--bone);background:rgba(12,13,9,.7);padding:5px 8px;border-radius:2px;text-transform:uppercase}
.card .body{padding:22px 22px 26px}
.card h3{font-size:24px;margin-bottom:9px}
.card p{color:var(--bone-dim);font-size:14.5px}

/* ============================================================
   COLOR SWITCHER SHOWCASE
   ============================================================ */
.colors{background:var(--ink-2)}
.color-stage{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.color-view{border:1px solid var(--line);border-radius:6px;overflow:hidden;background:linear-gradient(180deg,#1a1c12,#0d0e09);position:relative;aspect-ratio:1/1}
.color-view img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;opacity:0;transition:.5s var(--ease);padding:20px}
.color-view img.on{opacity:1}
.swatches{display:flex;gap:14px;margin:26px 0 30px;flex-wrap:wrap}
.sw{display:flex;flex-direction:column;align-items:center;gap:9px;cursor:pointer}
.sw .chip{width:54px;height:54px;border-radius:4px;border:2px solid var(--line);transition:.2s;position:relative}
.sw.active .chip{border-color:var(--tan);box-shadow:0 0 0 3px rgba(199,154,87,.2)}
.sw .chip::after{content:"";position:absolute;inset:0;border-radius:2px;opacity:0;transition:.2s}
.sw span{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.sw.active span{color:var(--bone)}
.chip-coyote{background:#9c7b4e}.chip-od{background:#5d6342}.chip-gray{background:#8a8c87}.chip-black{background:#1c1d1a}

/* ============================================================
   SPEC BANNER
   ============================================================ */
.specbanner{background:var(--ink);border-block:1px solid var(--line-soft)}
.specbanner .split{gap:60px}
.spec-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line-soft);border:1px solid var(--line-soft);border-radius:6px;overflow:hidden}
.spec-grid div{background:var(--panel);padding:22px}
.spec-grid b{font-family:var(--display);font-weight:800;font-size:30px;color:var(--tan);line-height:1;display:block}
.spec-grid span{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:7px;display:block}

/* ============================================================
   BIG & TALL CALLOUT
   ============================================================ */
.bigtall{position:relative;overflow:hidden;
  background:linear-gradient(110deg,#16180f 0%,#1d1f12 55%,#221d11 100%);border-block:1px solid var(--line-soft)}
.bigtall .wrap{display:grid;grid-template-columns:1.2fr .8fr;gap:50px;align-items:center}
.bigtall h2{margin:14px 0 16px}
.bigtall .scale{display:flex;align-items:flex-end;gap:4px;height:120px;margin-top:30px}
.bigtall .scale i{flex:1;background:linear-gradient(180deg,var(--tan),var(--tan-deep));border-radius:2px 2px 0 0;opacity:.35;transition:.4s var(--ease)}
.bigtall .scale i:last-child{opacity:1}
.bigtall .scale .lab{font-family:var(--mono);font-size:11px;color:var(--tan);writing-mode:vertical-rl}

/* ============================================================
   REVIEWS
   ============================================================ */
.reviews{background:var(--ink-2)}
.rev-top{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:24px;margin-bottom:46px}
.rev-score{display:flex;align-items:center;gap:18px}
.rev-score .big{font-family:var(--display);font-weight:900;font-size:74px;line-height:.8;color:var(--tan)}
.rev-score .meta .stars{font-size:20px}
.rev-score .meta p{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:6px}
.rev-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.rev{border:1px solid var(--line);border-radius:6px;background:var(--panel);padding:26px;display:flex;flex-direction:column;gap:14px}
.rev .stars{font-size:14px}
.rev p{color:var(--bone-dim);font-size:15px;line-height:1.6;flex:1}
.rev .who{display:flex;align-items:center;gap:11px;border-top:1px solid var(--line-soft);padding-top:15px}
.rev .av{width:38px;height:38px;border-radius:50%;background:var(--panel-2);border:1px solid var(--line);display:grid;place-items:center;font-family:var(--display);font-weight:800;color:var(--tan);font-size:16px}
.rev .who b{font-size:14px;font-family:var(--body);font-weight:600}
.rev .who small{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.08em;color:var(--ok);text-transform:uppercase}

/* ============================================================
   COMPARISON
   ============================================================ */
.compare table{width:100%;border-collapse:collapse;border:1px solid var(--line);border-radius:6px;overflow:hidden}
.compare th,.compare td{padding:18px 22px;text-align:left;border-bottom:1px solid var(--line-soft)}
.compare thead th{font-family:var(--display);font-weight:700;font-size:18px;letter-spacing:.04em;text-transform:uppercase;background:var(--panel)}
.compare thead th.us{color:var(--tan);background:var(--panel-2)}
.compare td{font-size:15px;color:var(--bone-dim)}
.compare td.us{color:var(--bone);font-weight:500;background:rgba(199,154,87,.05)}
.compare tr:last-child td{border-bottom:none}
.compare .yes{color:var(--ok)}.compare .no{color:var(--muted-2)}
.compare td:first-child{font-family:var(--display);font-weight:600;font-size:16px;letter-spacing:.03em;text-transform:uppercase;color:var(--bone)}

/* ============================================================
   FAQ
   ============================================================ */
.faq{max-width:820px;margin:0 auto}
.qa{border-bottom:1px solid var(--line-soft)}
.qa button{width:100%;display:flex;justify-content:space-between;align-items:center;gap:20px;padding:24px 0;text-align:left;
  font-family:var(--display);font-weight:700;font-size:21px;letter-spacing:.02em;text-transform:uppercase}
.qa button .pm{flex:none;width:26px;height:26px;border:1px solid var(--line);border-radius:3px;display:grid;place-items:center;color:var(--tan);transition:.25s}
.qa.open button .pm{background:var(--tan);color:#1a1404;transform:rotate(45deg)}
.qa .ans{max-height:0;overflow:hidden;transition:max-height .35s var(--ease)}
.qa .ans p{padding:0 0 24px;color:var(--bone-dim);font-size:15.5px;max-width:64ch}

/* ============================================================
   EMAIL BAND
   ============================================================ */
.emailband{background:linear-gradient(110deg,#1c1810,#16180f);border-block:1px solid var(--line-soft);text-align:center}
.emailband form{display:flex;gap:12px;max-width:520px;margin:26px auto 0}
.emailband input{flex:1;background:var(--ink);border:1px solid var(--line);border-radius:3px;padding:16px 18px;color:var(--bone);font-family:var(--mono);font-size:13px;letter-spacing:.05em}
.emailband input:focus{outline:none;border-color:var(--tan)}

/* ============================================================
   FOOTER
   ============================================================ */
.foot{background:var(--ink-2);border-top:1px solid var(--line-soft);padding:70px 0 0}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;padding-bottom:50px}
.foot h4{font-family:var(--display);font-weight:700;font-size:15px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:18px}
.foot ul{list-style:none;display:grid;gap:11px}
.foot ul a{color:var(--bone-dim);font-size:14.5px;transition:.2s}
.foot ul a:hover{color:var(--tan)}
.foot .blurb{color:var(--muted);font-size:14px;max-width:34ch;margin-top:16px}
.foot .socials{display:flex;gap:10px;margin-top:20px}
.foot .socials a{width:38px;height:38px;border:1px solid var(--line);border-radius:3px;display:grid;place-items:center;color:var(--bone-dim);transition:.2s}
.foot .socials a:hover{border-color:var(--tan);color:var(--tan)}
.foot-bottom{border-top:1px solid var(--line-soft);padding:22px 0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--muted-2);text-transform:uppercase}

/* ============================================================
   10% POPUP
   ============================================================ */
.modal-veil{position:fixed;inset:0;z-index:90;background:rgba(5,5,3,.78);backdrop-filter:blur(5px);
  display:grid;place-items:center;padding:24px;opacity:0;pointer-events:none;transition:.35s}
.modal-veil.show{opacity:1;pointer-events:auto}
.modal{width:min(880px,100%);background:var(--panel);border:1px solid var(--line);border-radius:8px;overflow:hidden;
  display:grid;grid-template-columns:1fr 1fr;transform:translateY(20px) scale(.98);transition:.4s var(--ease)}
.modal-veil.show .modal{transform:none}
.modal .pic{position:relative;background:linear-gradient(180deg,#1a1c12,#0d0e09)}
.modal .pic img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.modal .pic .vig{position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(22,24,15,.6))}
.modal .body{padding:42px 40px;position:relative}
.modal .close{position:absolute;top:14px;right:16px;font-size:26px;color:var(--muted);line-height:1}
.modal .close:hover{color:var(--tan)}
.modal .off{font-family:var(--display);font-weight:900;font-size:64px;line-height:.85;color:var(--tan);margin:6px 0 4px}
.modal h3{font-size:30px;margin-bottom:12px}
.modal p{color:var(--bone-dim);font-size:15px;margin-bottom:22px}
.modal form{display:flex;flex-direction:column;gap:11px}
.modal input{background:var(--ink);border:1px solid var(--line);border-radius:3px;padding:15px 16px;color:var(--bone);font-family:var(--mono);font-size:13px}
.modal input:focus{outline:none;border-color:var(--tan)}
.modal .fine{font-family:var(--mono);font-size:10px;letter-spacing:.06em;color:var(--muted-2);margin-top:14px;text-align:center}
.modal .nope{background:none;border:none;color:var(--muted-2);font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;margin-top:10px;text-decoration:underline;width:100%}

/* ============================================================
   CART DRAWER
   ============================================================ */
.drawer-veil{position:fixed;inset:0;z-index:80;background:rgba(5,5,3,.6);opacity:0;pointer-events:none;transition:.3s}
.drawer-veil.show{opacity:1;pointer-events:auto}
.drawer{position:fixed;top:0;right:0;height:100%;width:min(420px,100%);background:var(--panel);border-left:1px solid var(--line);
  z-index:81;transform:translateX(100%);transition:.4s var(--ease);display:flex;flex-direction:column}
.drawer.show{transform:none}
.drawer .dh{display:flex;justify-content:space-between;align-items:center;padding:22px 24px;border-bottom:1px solid var(--line-soft)}
.drawer .dh h3{font-size:22px}
.drawer .dh .close{font-size:24px;color:var(--muted)}
.drawer .items{flex:1;overflow-y:auto;padding:8px 24px}
.drawer .ci{display:grid;grid-template-columns:64px 1fr auto;gap:14px;padding:18px 0;border-bottom:1px solid var(--line-soft);align-items:center}
.drawer .ci img{width:64px;height:64px;object-fit:cover;border-radius:4px;border:1px solid var(--line);background:#0e0f09}
.drawer .ci b{font-family:var(--display);font-weight:700;font-size:16px;letter-spacing:.02em;text-transform:uppercase;display:block}
.drawer .ci small{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.05em}
.drawer .ci .pr{font-family:var(--display);font-weight:700;font-size:17px}
.drawer .empty{text-align:center;color:var(--muted);font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;padding:60px 0}
.drawer .df{padding:22px 24px;border-top:1px solid var(--line-soft);background:var(--ink-2)}
.ship-bar{margin-bottom:18px}
.ship-bar .lab{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--bone-dim);margin-bottom:8px;display:flex;justify-content:space-between}
.ship-bar .track{height:6px;background:var(--ink);border:1px solid var(--line);border-radius:6px;overflow:hidden}
.ship-bar .fill{height:100%;background:linear-gradient(90deg,var(--tan-deep),var(--tan-bright));width:0;transition:.5s var(--ease)}
.drawer .subtotal{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:16px}
.drawer .subtotal span{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.drawer .subtotal b{font-family:var(--display);font-weight:800;font-size:28px}

/* toast */
.toast{position:fixed;bottom:26px;left:50%;transform:transl(-50%,20px);translate:-50% 20px;z-index:95;
  background:var(--tan);color:#1a1404;font-family:var(--display);font-weight:700;font-size:15px;letter-spacing:.04em;text-transform:uppercase;
  padding:14px 22px;border-radius:4px;opacity:0;pointer-events:none;transition:.3s var(--ease);display:flex;align-items:center;gap:10px}
.toast.show{opacity:1;translate:-50% 0}

/* ============================================================
   PRODUCT PAGE
   ============================================================ */
.pdp{padding:40px 0 90px}
.crumb{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:26px;display:flex;gap:10px}
.crumb a:hover{color:var(--tan)}
.pdp-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:54px;align-items:start}

.gallery{position:sticky;top:90px}
.gal-main{border:1px solid var(--line);border-radius:6px;overflow:hidden;background:linear-gradient(180deg,#1a1c12,#0d0e09);aspect-ratio:1/1;position:relative}
.gal-main img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;padding:24px;opacity:0;transition:.4s var(--ease)}
.gal-main img.on{opacity:1}
.gal-main .badge{position:absolute;top:16px;left:16px;z-index:2;background:var(--blaze);color:#fff;font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:6px 11px;border-radius:3px}
.thumbs{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-top:12px}
.thumb{border:1px solid var(--line);border-radius:4px;overflow:hidden;aspect-ratio:1/1;background:#0e0f09;cursor:pointer;transition:.2s;position:relative}
.thumb img{width:100%;height:100%;object-fit:cover}
.thumb.active{border-color:var(--tan);box-shadow:0 0 0 2px rgba(199,154,87,.25)}
.thumb:hover{border-color:var(--tan)}

.pinfo .eyebrow{display:flex;align-items:center;gap:12px;margin-bottom:14px;flex-wrap:wrap}
.pinfo h1{font-size:clamp(34px,4.4vw,52px);line-height:.95}
.pinfo .ratingrow{display:flex;align-items:center;gap:12px;margin:14px 0 18px}
.pinfo .ratingrow a{font-family:var(--mono);font-size:12px;color:var(--muted);text-decoration:underline;text-underline-offset:3px}
.pinfo .ratingrow a:hover{color:var(--tan)}
.priceline{display:flex;align-items:baseline;gap:14px;margin-bottom:8px}
.priceline .now{font-family:var(--display);font-weight:800;font-size:46px;line-height:1}
.priceline .was{font-family:var(--display);font-weight:600;font-size:24px;color:var(--muted-2);text-decoration:line-through}
.priceline .save{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--blaze);border:1px solid rgba(217,98,43,.4);padding:4px 9px;border-radius:3px}
.paynote{font-family:var(--mono);font-size:12px;color:var(--muted);margin-bottom:26px}
.paynote b{color:var(--bone-dim)}

.opt{margin-bottom:24px}
.opt .lbl{font-family:var(--display);font-weight:700;font-size:15px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:12px;display:flex;justify-content:space-between;align-items:center}
.opt .lbl .val{color:var(--tan)}
.opt .lbl a{font-family:var(--body);font-weight:400;font-size:12px;color:var(--muted);text-decoration:underline;text-underline-offset:3px;text-transform:none;letter-spacing:0}
.opt .lbl a:hover{color:var(--tan)}

.col-opts{display:flex;gap:12px;flex-wrap:wrap}
.col-opt{cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:7px}
.col-opt .chip{width:46px;height:46px;border-radius:4px;border:2px solid var(--line);transition:.2s}
.col-opt.active .chip{border-color:var(--tan);box-shadow:0 0 0 3px rgba(199,154,87,.2)}
.col-opt small{font-family:var(--mono);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.col-opt.active small{color:var(--bone)}

.size-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}
.size{border:1px solid var(--line);border-radius:3px;padding:13px 0;text-align:center;font-family:var(--display);font-weight:700;font-size:17px;color:var(--bone-dim);transition:.18s;position:relative}
.size:hover{border-color:var(--tan);color:var(--bone)}
.size.active{background:var(--tan);color:#1a1404;border-color:var(--tan)}
.size.low::after{content:"";position:absolute;top:-3px;right:-3px;width:8px;height:8px;border-radius:50%;background:var(--blaze)}
.size-note{font-family:var(--mono);font-size:11px;color:var(--muted);margin-top:10px}

.qty-add{display:grid;grid-template-columns:auto 1fr;gap:12px;margin:26px 0 14px}
.qty{display:flex;align-items:center;border:1px solid var(--line);border-radius:3px;overflow:hidden}
.qty button{width:46px;height:100%;font-size:20px;color:var(--bone-dim);transition:.15s}
.qty button:hover{color:var(--tan);background:var(--panel)}
.qty input{width:44px;text-align:center;background:none;border:none;color:var(--bone);font-family:var(--display);font-weight:700;font-size:18px}
.qty input:focus{outline:none}

.shoppay{width:100%;background:#5a31f4;color:#fff;border-radius:3px;padding:15px;font-family:var(--body);font-weight:600;font-size:15px;display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:18px;transition:.2s}
.shoppay:hover{filter:brightness(1.12)}

.assurance{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin:24px 0;padding:22px 0;border-block:1px solid var(--line-soft)}
.assurance .a{display:flex;gap:11px;align-items:flex-start}
.assurance svg{width:22px;height:22px;color:var(--tan);flex:none;margin-top:1px}
.assurance b{font-family:var(--display);font-weight:700;font-size:14.5px;letter-spacing:.03em;text-transform:uppercase;display:block}
.assurance small{font-size:12.5px;color:var(--muted)}

.urgency{display:flex;align-items:center;gap:11px;background:rgba(217,98,43,.08);border:1px solid rgba(217,98,43,.3);border-radius:4px;padding:13px 16px;margin-bottom:22px}
.urgency .pulse{width:9px;height:9px;border-radius:50%;background:var(--blaze);box-shadow:0 0 0 0 rgba(217,98,43,.6);animation:pulse 1.8s infinite;flex:none}
.urgency p{font-size:13.5px;color:var(--bone-dim)}
.urgency b{color:var(--blaze)}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(217,98,43,.6)}70%{box-shadow:0 0 0 10px rgba(217,98,43,0)}100%{box-shadow:0 0 0 0 rgba(217,98,43,0)}}

.acc{border-top:1px solid var(--line-soft);margin-top:26px}
.acc .qa button{font-size:17px;padding:20px 0}

/* sticky buy bar */
.buybar{position:fixed;left:0;right:0;bottom:0;z-index:50;background:rgba(12,13,9,.94);backdrop-filter:blur(12px);
  border-top:1px solid var(--line);transform:translateY(110%);transition:.4s var(--ease)}
.buybar.show{transform:none}
.buybar .in{max-width:var(--maxw);margin:0 auto;padding:12px 28px;display:flex;align-items:center;justify-content:space-between;gap:18px}
.buybar .l{display:flex;align-items:center;gap:14px;min-width:0}
.buybar img{width:50px;height:50px;object-fit:contain;border:1px solid var(--line);border-radius:4px;background:#0e0f09;flex:none}
.buybar b{font-family:var(--display);font-weight:700;font-size:18px;letter-spacing:.02em;text-transform:uppercase;white-space:nowrap}
.buybar .meta{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.05em}
.buybar .r{display:flex;align-items:center;gap:14px}
.buybar .price{font-family:var(--display);font-weight:800;font-size:26px}

/* feature highlight rows on PDP */
.fhl{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center;padding:70px 0;border-top:1px solid var(--line-soft)}
.fhl:nth-child(even) .fhl-media{order:2}
.fhl-media{border:1px solid var(--line);border-radius:6px;overflow:hidden;background:#0e0f09}
.fhl-media img{width:100%;aspect-ratio:4/3;object-fit:cover}
.fhl h3{font-size:30px;margin:14px 0 12px}
.fhl p{color:var(--bone-dim);font-size:15.5px}

/* cross sell */
.xsell{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.xcard{border:1px solid var(--line);border-radius:6px;overflow:hidden;background:var(--panel);transition:.3s var(--ease)}
.xcard:hover{transform:translateY(-5px);border-color:var(--tan)}
.xcard .ph{aspect-ratio:1/1;background:#0e0f09;overflow:hidden}
.xcard .ph img{width:100%;height:100%;object-fit:cover;transition:.5s}
.xcard:hover .ph img{transform:scale(1.05)}
.xcard .b{padding:18px}
.xcard b{font-family:var(--display);font-weight:700;font-size:18px;letter-spacing:.02em;text-transform:uppercase;display:block;margin-bottom:6px}
.xcard .pr{font-family:var(--display);font-weight:700;font-size:18px;color:var(--tan)}

/* ============================================================
   COMPARE / PROPOSAL PAGE
   ============================================================ */
.cmp-hero{padding:70px 0 30px;text-align:center}
.cmp-hero .lead{margin:18px auto 0;text-align:center}
.cmp-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:30px}

/* before/after slider */
.ba-wrap{margin:18px 0 10px}
.ba-cap{display:flex;justify-content:center;margin-bottom:16px}
.ba{position:relative;aspect-ratio:1440/900;border:1px solid var(--line);border-radius:8px;overflow:hidden;
  background:#0e0f09;user-select:none;touch-action:none;cursor:ew-resize;--pos:50%}
.ba img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none;-webkit-user-drag:none}
.ba-top{position:absolute;inset:0;clip-path:inset(0 calc(100% - var(--pos)) 0 0)}
.ba-tag{position:absolute;top:16px;z-index:4;font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  padding:7px 12px;border-radius:3px;backdrop-filter:blur(6px)}
.ba-tag.cur{left:16px;background:rgba(12,13,9,.78);border:1px solid var(--line);color:var(--bone-dim)}
.ba-tag.new{right:16px;background:var(--tan);color:#1a1404}
.ba-line{position:absolute;top:0;bottom:0;left:var(--pos);width:2px;background:var(--tan);z-index:5;transform:translateX(-1px);box-shadow:0 0 14px rgba(199,154,87,.7)}
.ba-grab{position:absolute;top:50%;left:var(--pos);z-index:6;width:46px;height:46px;border-radius:50%;
  background:var(--tan);color:#1a1404;display:grid;place-items:center;transform:translate(-50%,-50%);
  box-shadow:0 6px 20px rgba(0,0,0,.6);font-size:18px}
.ba-grab svg{width:24px;height:24px}
.ba-hint{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);text-align:center;margin-top:14px}

/* improvements list */
.imp-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.imp{border:1px solid var(--line);border-radius:6px;background:var(--panel);padding:24px;display:grid;grid-template-columns:44px 1fr;gap:16px;transition:.25s var(--ease)}
.imp:hover{border-color:var(--tan);transform:translateY(-3px)}
.imp .ico{width:44px;height:44px;border:1px solid var(--line);border-radius:4px;display:grid;place-items:center;color:var(--tan)}
.imp .ico svg{width:22px;height:22px}
.imp h3{font-size:20px;margin-bottom:10px;letter-spacing:.02em}
.imp .ba-rows{display:grid;gap:7px}
.imp .row{display:flex;gap:9px;align-items:flex-start;font-size:13.5px;line-height:1.45}
.imp .row .mk{flex:none;font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;padding:2px 6px;border-radius:2px;margin-top:1px}
.imp .row.was .mk{color:var(--muted-2);border:1px solid var(--line)}
.imp .row.now .mk{color:#1a1404;background:var(--tan)}
.imp .row.was span{color:var(--muted)}
.imp .row.now span{color:var(--bone-dim)}

/* estimate / calculator */
.est{background:linear-gradient(160deg,#16180f,#1c1810);border-block:1px solid var(--line-soft)}
.est-note{display:flex;gap:11px;align-items:flex-start;max-width:760px;margin:0 auto 40px;
  background:rgba(217,98,43,.07);border:1px solid rgba(217,98,43,.3);border-radius:6px;padding:16px 18px}
.est-note svg{width:20px;height:20px;color:var(--blaze);flex:none;margin-top:1px}
.est-note p{font-size:13.5px;color:var(--bone-dim);line-height:1.55}
.est-note b{color:var(--bone)}
.calc{display:grid;grid-template-columns:.85fr 1.15fr;gap:30px;border:1px solid var(--line);border-radius:8px;background:var(--panel);overflow:hidden}
.calc-in{padding:32px;border-right:1px solid var(--line-soft)}
.calc-in h3{font-size:22px;margin-bottom:6px}
.calc-in .sub{font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--muted);text-transform:uppercase;margin-bottom:24px}
.field{margin-bottom:20px}
.field label{display:flex;justify-content:space-between;font-family:var(--display);font-weight:700;font-size:14px;letter-spacing:.05em;text-transform:uppercase;margin-bottom:9px}
.field label b{color:var(--tan)}
.field input[type=range]{width:100%;accent-color:var(--tan)}
.field .num{display:flex;align-items:center;border:1px solid var(--line);border-radius:3px;overflow:hidden}
.field .num span{padding:0 12px;color:var(--muted);font-family:var(--mono);font-size:14px}
.field .num input{flex:1;background:none;border:none;color:var(--bone);font-family:var(--display);font-weight:700;font-size:18px;padding:11px 12px}
.field .num input:focus{outline:none}
.calc-out{padding:32px;display:flex;flex-direction:column;justify-content:center;gap:18px;
  background:radial-gradient(120% 90% at 100% 0%,rgba(199,154,87,.1),transparent 60%)}
.scenario{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:baseline;padding:16px 18px;border:1px solid var(--line);border-radius:6px;background:var(--ink-2)}
.scenario.hi{border-color:var(--tan);background:rgba(199,154,87,.06)}
.scenario .lab{font-family:var(--display);font-weight:700;font-size:15px;letter-spacing:.04em;text-transform:uppercase}
.scenario .lab small{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.08em;color:var(--muted);text-transform:uppercase;margin-top:3px;font-weight:400}
.scenario .amt{font-family:var(--display);font-weight:800;font-size:26px;color:var(--tan);text-align:right;line-height:1}
.scenario .amt small{display:block;font-family:var(--mono);font-size:10px;color:var(--muted);letter-spacing:.06em;margin-top:4px}
.calc-base{font-family:var(--mono);font-size:12px;letter-spacing:.06em;color:var(--muted);text-align:center}
.calc-base b{color:var(--bone-dim)}

@media(max-width:820px){
  .calc{grid-template-columns:1fr}
  .calc-in{border-right:none;border-bottom:1px solid var(--line-soft)}
  .imp-grid{grid-template-columns:1fr}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr;min-height:auto}
  .hero-media{order:-1;max-width:520px}
  .split,.color-stage,.bigtall .wrap,.specbanner .split,.pdp-grid,.fhl{grid-template-columns:1fr;gap:34px}
  .fhl:nth-child(even) .fhl-media{order:0}
  .cards,.rev-cards,.xsell{grid-template-columns:1fr 1fr}
  .gallery{position:static}
  .modal{grid-template-columns:1fr}
  .modal .pic{display:none}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .wrap{padding:0 18px}
  section{padding:64px 0}
  .nav{display:none}
  .menu-toggle{display:grid}
  .cards,.rev-cards,.xsell,.spec-grid,.assurance{grid-template-columns:1fr}
  .size-grid{grid-template-columns:repeat(5,1fr)}
  .hero-proof{gap:18px}
  .foot-grid{grid-template-columns:1fr}
  .buybar .meta,.buybar .price small{display:none}
  .trust-strip .it{font-size:16px}
}
