/* =====================================================================
   Stencil & Thread — demo site
   Consumes brand-kit tokens (brandkit/tokens.css). Press-red accent,
   tee-cream ground, print-black ink. Bricolage Grotesque + Inter.
   ===================================================================== */

:root{
  /* raw palette — actual Stencil & Thread identity (navy / blue / cream) */
  --brand-ink:#1A1E37;     /* deep navy — header, headings, dark sections */
  --brand-paper:#FCFBF8;   /* near-white body */
  --brand-press:#2563EB;   /* brand blue — primary action (was the "Home" button) */
  --brand-thread:#F2B231;  /* gold — review stars / sparing accent */
  --brand-cream:#F4EFE2;   /* logo badge cream / warm accents */
  --brand-mint:#E7F2EC;    /* soft mint — alternate section bg (reviews) */

  /* roles */
  --color-bg:var(--brand-paper);
  --color-surface:#F6F4EE;
  --color-surface-alt:var(--brand-mint);
  --color-surface-ink:var(--brand-ink);
  --color-text:var(--brand-ink);
  --color-text-muted:#5A6172;
  --color-text-on-ink:var(--brand-cream);
  --color-accent:var(--brand-press);
  --color-accent-2:var(--brand-thread);
  --color-border:#E7E3D8;
  --color-border-ink:rgba(244,239,226,.16);
  --color-focus:var(--brand-press);

  /* type — serif display (their look) + clean sans body */
  --font-display:"Fraunces","Playfair Display",Georgia,serif;
  --font-body:"Inter",system-ui,-apple-system,sans-serif;
  --fs-display:clamp(2.9rem,7vw,5.5rem);
  --fs-h1:clamp(2rem,4vw,3rem);
  --fs-h2:clamp(1.7rem,3.4vw,2.6rem);
  --fs-h3:1.2rem;
  --fs-body:1.0625rem;
  --fs-small:.85rem;

  /* spacing */
  --space-2:8px; --space-3:16px; --space-4:24px; --space-5:40px;
  --space-6:64px; --space-7:96px; --space-8:128px;

  --content-max:1180px;
  --gutter:clamp(20px,5vw,40px);
  --section-y:clamp(64px,9vw,120px);

  --radius-sm:6px; --radius-md:12px; --radius-lg:20px; --radius-btn:9px;
  --shadow-soft:0 1px 2px rgba(23,19,15,.04),0 14px 40px rgba(23,19,15,.08);
  --shadow-lift:0 20px 60px rgba(23,19,15,.16);

  --ease-out:cubic-bezier(.16,1,.3,1);
  --dur-fast:160ms; --dur-base:260ms; --dur-slow:600ms;
}

/* ---------- reset / base ---------- */
*{box-sizing:border-box;margin:0}
html{-webkit-text-size-adjust:100%}
body{
  background:var(--color-bg);color:var(--color-text);
  font-family:var(--font-body);font-size:var(--fs-body);line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:1.06;letter-spacing:-.01em}
h1{font-weight:700} h3,h4{letter-spacing:0}
::selection{background:var(--color-accent);color:#fff}

.wrap{max-width:var(--content-max);margin-inline:auto;padding-inline:var(--gutter);width:100%}
.eyebrow{font-size:var(--fs-small);font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--color-accent)}
.skip{position:absolute;left:-999px;top:0;background:var(--brand-ink);color:#fff;padding:.6rem 1rem;z-index:200}
.skip:focus{left:8px;top:8px}

/* focus ring */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{
  outline:2px solid var(--color-focus);outline-offset:2px;border-radius:4px}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-weight:600;font-size:.97rem;line-height:1;
  padding:.85rem 1.4rem;border-radius:var(--radius-btn);border:1.5px solid transparent;
  transition:transform var(--dur-base) var(--ease-out),background var(--dur-base) var(--ease-out),color var(--dur-base) var(--ease-out);
}
.btn:hover{transform:translateY(-2px)}
.btn-sm{padding:.6rem 1rem;font-size:.9rem}
.btn-block{width:100%;padding:1rem}
.btn-uppercase{text-transform:uppercase;letter-spacing:.05em;font-weight:700;padding:.95rem 1.7rem;font-size:.95rem}
.btn-primary{background:var(--color-accent);color:#fff}
.btn-primary:hover{background:#1b4fd1}
.btn-ghost{background:transparent;color:var(--color-accent)}
.btn-ghost:hover{color:#1b4fd1}
.btn-outline{background:transparent;border-color:var(--color-text);color:var(--color-text)}

/* ---------- header (navy, like their real site) ---------- */
.site-header{position:sticky;top:0;z-index:100;background:var(--brand-ink);border-bottom:1px solid rgba(244,239,226,.10);transition:box-shadow var(--dur-base)}
.site-header.scrolled{box-shadow:0 6px 24px rgba(13,15,28,.28)}
.header-inner{display:flex;align-items:center;gap:var(--space-5);height:74px}
.logo{display:inline-flex;align-items:center}
.logo img{height:42px;width:auto;border-radius:6px;display:block}
.nav{display:flex;gap:1.6rem;margin-inline:auto;font-size:.95rem;font-weight:500}
.nav a{color:rgba(244,239,226,.78);transition:color var(--dur-fast)}
.nav a:hover{color:var(--brand-cream)}
.nav a[aria-current="page"]{color:var(--brand-cream)}
.header-cta{display:flex;align-items:center;gap:1rem}
.phone-link{display:inline-flex;align-items:center;gap:.45rem;font-weight:600;font-size:.92rem;color:var(--brand-cream)}
.phone-link svg{color:var(--color-accent)}
.phone-link:hover{color:#fff}
.nav-toggle{color:var(--brand-cream)}
.site-header .btn-outline{border-color:rgba(244,239,226,.4);color:var(--brand-cream)}
.site-header .btn-outline:hover{border-color:var(--brand-cream)}

/* ---------- hero ---------- */
.hero{padding-block:clamp(48px,7vw,90px) var(--section-y)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,5vw,72px);align-items:center}
.hero-copy .eyebrow{margin-bottom:var(--space-4)}
.hero-title{font-size:var(--fs-display);max-width:17ch;margin-bottom:var(--space-4);font-weight:800;line-height:1.02;letter-spacing:-.02em}
.hero-sub{font-size:clamp(1.05rem,1.6vw,1.22rem);color:var(--color-text-muted);max-width:46ch;margin-bottom:var(--space-5)}
.hero-actions{display:flex;gap:.9rem;flex-wrap:wrap;align-items:center;margin-bottom:var(--space-6)}
.hero-trust{list-style:none;display:flex;gap:clamp(20px,4vw,48px);padding:0;border-top:1px solid var(--color-border);padding-top:var(--space-4)}
.hero-trust li{display:flex;flex-direction:column;gap:.15rem}
.hero-trust strong{font-family:var(--font-display);font-size:1.5rem;font-weight:800;line-height:1}
.hero-trust span{font-size:var(--fs-small);color:var(--color-text-muted)}
.hero-media{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-soft)}
.hero-media img{width:100%;height:100%;aspect-ratio:4/3.2;object-fit:cover}
.method-tag{display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;background:var(--brand-ink);color:var(--color-text-on-ink);padding:.35rem .7rem;border-radius:999px}
.hero-media .method-tag{position:absolute;left:14px;bottom:14px;background:rgba(23,19,15,.78);backdrop-filter:blur(4px)}

/* ---------- cinematic centered hero (video/image bg — Amped/pest standard) ---------- */
.hero-cinematic{position:relative;min-height:85vh;display:flex;align-items:center;justify-content:center;overflow:hidden;padding-block:var(--space-7);text-align:center;isolation:isolate}
.hero-cinematic .hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;background-size:cover;background-position:center;z-index:-2}
.hero-cinematic .hero-overlay{position:absolute;inset:0;z-index:-1;background:linear-gradient(135deg,rgba(13,15,30,.86) 0%,rgba(26,30,55,.6) 50%,rgba(13,15,30,.92) 100%)}
.hero-cinematic-inner{position:relative;z-index:1;color:#fff;max-width:880px;margin-inline:auto;min-width:0}
.hero-pill{display:inline-flex;align-items:center;gap:.5rem;border:1px solid rgba(255,255,255,.3);background:rgba(255,255,255,.1);backdrop-filter:blur(6px);border-radius:999px;padding:.5rem 1.15rem;font-size:.78rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:#fff;margin-bottom:var(--space-5)}
.hero-wordmark{font-family:var(--font-display);font-weight:700;color:#fff;font-size:clamp(2.6rem,8vw,6.5rem);line-height:1.02;letter-spacing:-.02em;margin-bottom:var(--space-4);overflow-wrap:break-word}
.hero-tagline{font-size:clamp(1.05rem,1.8vw,1.3rem);color:rgba(255,255,255,.9);max-width:48ch;margin:0 auto var(--space-6);line-height:1.5}
.hero-cta{display:flex;flex-wrap:wrap;gap:.9rem;justify-content:center;align-items:center}
.btn-outline-light{background:transparent;border-color:rgba(255,255,255,.6);color:#fff}
.btn-outline-light:hover{background:#fff;color:var(--brand-ink)}
@keyframes heroFade{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.hero-fade{opacity:0;animation:heroFade .8s var(--ease-out) both}
@media (prefers-reduced-motion:reduce){.hero-fade{animation:none;opacity:1;transform:none}}
@media(max-width:560px){
  .hero-cinematic{min-height:80vh}
  .hero-wordmark{font-size:clamp(2rem,9.5vw,2.8rem)}
  .hero-pill{font-size:.62rem;letter-spacing:.03em;white-space:normal;max-width:100%;line-height:1.4}
  .hero-tagline{font-size:1rem;max-width:34ch}
  .hero-cta{flex-direction:column;width:100%}
  .hero-cta .btn{width:100%}
}

/* ---------- marquee ---------- */
.marquee{background:var(--color-surface-ink);color:var(--color-text-on-ink);overflow:hidden;padding-block:.9rem;border-block:1px solid var(--brand-ink)}
.marquee-track{display:flex;gap:1.4rem;align-items:center;white-space:nowrap;width:max-content;font-family:var(--font-display);font-weight:700;font-size:1.05rem;letter-spacing:-.01em;will-change:transform;animation:marquee 32s linear infinite}
.marquee .dot{color:var(--color-accent)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- section heads ---------- */
section[id], .how, .hero{scroll-margin-top:84px}
.services,.work,.updates,.reviews,.how,.contact{padding-block:var(--section-y)}
.section-head{max-width:46ch;margin-bottom:var(--space-6)}
.section-head .eyebrow{margin-bottom:var(--space-3)}
.section-head h2{font-size:var(--fs-h2)}
.section-lead{color:var(--color-text-muted);margin-top:var(--space-3)}

/* ---------- services ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}
.svc-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;padding-bottom:var(--space-4);transition:transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out)}
.svc-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft)}
.svc-media{aspect-ratio:4/3;overflow:hidden;margin-bottom:var(--space-4)}
.svc-media img{width:100%;height:100%;object-fit:cover;transition:transform var(--dur-slow) var(--ease-out)}
.svc-card:hover .svc-media img{transform:scale(1.04)}
.svc-card h3{padding-inline:var(--space-4);margin-bottom:.4rem}
.svc-card p{padding-inline:var(--space-4);color:var(--color-text-muted);font-size:.98rem}
.audience-row{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4);margin-top:var(--space-6);border-top:1px solid var(--color-border);padding-top:var(--space-6)}
.aud-k{font-family:var(--font-display);font-weight:700;color:var(--color-accent);font-size:.9rem}
.aud h4{margin-block:.5rem .3rem;font-size:1.05rem}
.aud p{color:var(--color-text-muted);font-size:.95rem}

/* ---------- work / gallery ---------- */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:220px;gap:var(--space-3)}
.g-item{position:relative;border-radius:var(--radius-md);overflow:hidden;background:var(--color-surface)}
.g-item img{width:100%;height:100%;object-fit:cover;transition:transform var(--dur-slow) var(--ease-out)}
.g-item:hover img{transform:scale(1.05)}
.g-tall{grid-row:span 2}
.g-item figcaption{position:absolute;left:10px;bottom:10px;opacity:0;transform:translateY(6px);transition:opacity var(--dur-base),transform var(--dur-base)}
.g-item:hover figcaption{opacity:1;transform:none}
.g-item .method-tag{background:rgba(23,19,15,.8);backdrop-filter:blur(4px)}

/* ---------- signature: order updates ---------- */
.updates{background:var(--color-surface-ink);color:var(--color-text-on-ink)}
.updates-grid{display:grid;grid-template-columns:1fr .85fr;gap:clamp(32px,6vw,80px);align-items:center}
.updates-copy .eyebrow{color:var(--color-accent-2)}
.updates-copy h2{font-size:var(--fs-h2);margin-block:var(--space-3) var(--space-4)}
.updates-copy>p{color:rgba(244,239,230,.78);max-width:44ch;margin-bottom:var(--space-4)}
.updates-list{list-style:none;padding:0;display:flex;flex-direction:column;gap:.7rem;margin-bottom:var(--space-5)}
.updates-list li{display:flex;align-items:center;gap:.7rem;color:rgba(244,239,230,.9);font-size:.98rem}
.u-dot{width:8px;height:8px;border-radius:50%;background:var(--color-accent);flex:none}

.phone-wrap{display:flex;justify-content:center}
.phone{width:300px;max-width:78vw;background:#0c0a08;border-radius:38px;padding:12px;box-shadow:var(--shadow-lift);border:1px solid rgba(244,239,230,.12);position:relative}
.phone-notch{position:absolute;top:18px;left:50%;transform:translateX(-50%);width:120px;height:24px;background:#0c0a08;border-radius:999px;z-index:3}
.phone-screen{background:var(--color-bg);border-radius:28px;overflow:hidden;height:660px;display:flex;flex-direction:column}
.sms-head{display:flex;align-items:center;gap:.6rem;padding:46px 16px 12px;background:var(--color-surface);border-bottom:1px solid var(--color-border)}
.sms-avatar{width:38px;height:38px;border-radius:50%;background:var(--color-accent);color:#fff;display:grid;place-items:center;font-family:var(--font-display);font-weight:800;font-size:.85rem}
.sms-name{font-weight:600;font-size:.95rem;color:var(--color-text)}
.sms-status{font-size:.75rem;color:var(--color-text-muted)}
.sms-body{flex:1;padding:16px 14px;display:flex;flex-direction:column;gap:12px;overflow:hidden}
.bubble{max-width:84%;align-self:flex-start;background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text);padding:10px 12px;border-radius:16px 16px 16px 4px;font-size:.86rem;line-height:1.4;box-shadow:0 1px 2px rgba(23,19,15,.05)}
.bubble time{display:block;font-size:.66rem;color:var(--color-text-muted);margin-top:4px}
.bubble.highlight{background:var(--color-accent);border-color:var(--color-accent);color:#fff}
.bubble.highlight time{color:rgba(255,255,255,.8)}
/* JS-driven reveal start state */
.js-anim .bubble[data-step]{opacity:0;transform:translateY(14px)}

/* ---------- reviews ---------- */
.reviews{background:var(--brand-mint)}
.review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}
.review{background:#fff;border:1px solid rgba(26,30,55,.07);border-radius:var(--radius-md);padding:var(--space-5);display:flex;flex-direction:column;gap:.6rem;box-shadow:0 1px 2px rgba(26,30,55,.04)}
.stars{color:var(--color-accent-2);letter-spacing:.1em;font-size:1rem}
.review p{font-size:1.1rem;font-family:var(--font-display);font-weight:600;line-height:1.3;letter-spacing:-.01em}
.review cite{font-style:normal;font-size:.9rem;font-weight:600;color:var(--color-text);margin-top:auto;display:flex;flex-direction:column;gap:.1rem}
.review cite span{font-weight:400;font-size:.8rem;color:var(--color-text-muted)}
.review-cta{background:var(--color-surface-ink);color:var(--color-text-on-ink);justify-content:center;align-items:flex-start;gap:.3rem;transition:transform var(--dur-base) var(--ease-out)}
.review-cta:hover{transform:translateY(-4px)}
.review-cta span{color:rgba(244,239,230,.7);font-size:.9rem}
.review-cta strong{font-family:var(--font-display);font-size:1.3rem;font-weight:700}

/* ---------- how it works ---------- */
.steps{list-style:none;padding:0;display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4)}
.step{border-top:2px solid var(--color-text);padding-top:var(--space-4)}
.step-n{font-family:var(--font-display);font-weight:800;font-size:1rem;color:var(--color-accent)}
.step h3{margin-block:.5rem .4rem;font-size:1.1rem}
.step p{color:var(--color-text-muted);font-size:.96rem}

/* ---------- contact ---------- */
.contact{background:var(--color-surface);border-top:1px solid var(--color-border)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,6vw,80px);align-items:start}
.contact-copy .eyebrow{margin-bottom:var(--space-3)}
.contact-copy h2{font-size:var(--fs-h2);margin-bottom:var(--space-3)}
.contact-lead{color:var(--color-text-muted);max-width:40ch;margin-bottom:var(--space-5)}
.contact-direct{display:flex;flex-direction:column;border-top:1px solid var(--color-border)}
.contact-line{display:flex;align-items:baseline;gap:1rem;padding-block:var(--space-3);border-bottom:1px solid var(--color-border);transition:color var(--dur-fast)}
.contact-line:hover{color:var(--color-accent)}
.cl-label{font-size:var(--fs-small);text-transform:uppercase;letter-spacing:.12em;color:var(--color-text-muted);width:54px;flex:none}
.cl-value{font-family:var(--font-display);font-weight:700;font-size:clamp(1.2rem,2.4vw,1.7rem)}
.contact-meta{display:flex;gap:var(--space-6);margin-top:var(--space-5)}
.contact-meta dt{font-size:var(--fs-small);text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);margin-bottom:.25rem}
.contact-meta dd{font-size:.95rem}

.quote-form{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:clamp(20px,3vw,32px)}
.quote-form h3{margin-bottom:var(--space-4);font-size:1.25rem}
.field{margin-bottom:var(--space-3);display:flex;flex-direction:column;gap:.35rem}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}
.field label{font-size:.82rem;font-weight:600;color:var(--color-text-muted)}
.field input,.field select,.field textarea{font:inherit;font-size:.95rem;padding:.7rem .85rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text);width:100%}
.field textarea{resize:vertical}
.form-note{font-size:.85rem;color:var(--color-text-muted);margin-top:var(--space-3);text-align:center}
.form-note a{color:var(--color-accent);font-weight:600}

/* ---------- footer ---------- */
.site-footer{background:var(--color-surface-ink);color:var(--color-text-on-ink);padding-top:var(--space-7)}
.footer-grid{display:grid;grid-template-columns:1.5fr .8fr .8fr 1.1fr;gap:var(--space-5);padding-bottom:var(--space-6)}
.footer-brand .logo img{height:52px;border-radius:6px;margin-bottom:var(--space-3);display:block}
.footer-brand p{color:rgba(244,239,226,.65);max-width:32ch;font-size:.95rem}
.footer-col{display:flex;flex-direction:column;gap:.55rem}
.footer-col h3{font-family:var(--font-body);font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;color:rgba(244,239,226,.5);margin-bottom:.3rem;font-weight:600}
.footer-col a,.footer-contact a{color:rgba(244,239,226,.82);transition:color var(--dur-fast)}
.footer-col a:hover,.footer-contact a:hover{color:var(--color-accent-2)}
.footer-contact{font-size:.95rem}
.footer-contact span{color:rgba(244,239,226,.6)}
.footer-social{display:flex;gap:1rem;margin-top:.5rem}
.footer-base{display:flex;justify-content:space-between;border-top:1px solid var(--color-border-ink);padding-block:var(--space-4);font-size:var(--fs-small);color:rgba(244,239,230,.5)}

/* ---------- chatbot launcher ---------- */
.chat-launch{position:fixed;right:18px;bottom:18px;z-index:90;display:inline-flex;align-items:center;gap:.5rem;background:var(--color-accent);color:#fff;border:none;border-radius:999px;padding:.8rem 1.2rem;font-weight:600;font-size:.92rem;box-shadow:var(--shadow-lift);transition:transform var(--dur-base) var(--ease-out)}
.chat-launch:hover{transform:translateY(-3px)}

/* ---------- scroll reveal base ---------- */
.js-anim .reveal{opacity:0;transform:translateY(20px)}
.reveal.is-in{opacity:1;transform:none;transition:opacity var(--dur-slow) var(--ease-out),transform var(--dur-slow) var(--ease-out)}

/* =====================================================================
   Multi-page additions
   ===================================================================== */

/* nav active + toggle */
.nav a[aria-current="page"]{color:var(--brand-cream)}
.nav a[aria-current="page"]::after{content:"";display:block;height:2px;background:var(--color-accent);margin-top:3px;border-radius:2px}
.nav-toggle{display:none;background:none;border:none;color:var(--color-text);padding:.3rem;align-items:center}
.mobile-nav{display:none}

/* card link affordance on anchor service cards */
.svc-card{display:flex;flex-direction:column}
.card-link{padding:0 var(--space-4) ;color:var(--color-accent);font-weight:600;font-size:.92rem;margin-top:auto;padding-top:var(--space-3)}
a.svc-card{color:inherit}
a.svc-card:hover .card-link{text-decoration:underline}

/* page hero (interior) */
.page-hero{padding-block:clamp(40px,6vw,72px) clamp(32px,5vw,56px)}
.page-hero h1{font-size:clamp(2.4rem,5.5vw,4rem);max-width:18ch;margin-block:var(--space-3) var(--space-4)}
.page-hero-sub{font-size:clamp(1.05rem,1.6vw,1.25rem);color:var(--color-text-muted);max-width:54ch;margin-bottom:var(--space-5)}

/* breadcrumb */
.breadcrumb{padding-top:var(--space-4);font-size:var(--fs-small);color:var(--color-text-muted);display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}
.breadcrumb a{color:var(--color-text-muted)}
.breadcrumb a:hover{color:var(--color-accent)}
.breadcrumb .sep{opacity:.5}
.breadcrumb span[aria-current]{color:var(--color-text);font-weight:600}

/* services hub rows */
.svc-detail-list{padding-block:var(--section-y)}
.svc-row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,5vw,64px);align-items:center;padding-block:var(--space-5)}
.svc-row + .svc-row{border-top:1px solid var(--color-border)}
.svc-row.reverse .svc-row-media{order:2}
.svc-row-media{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-soft)}
.svc-row-media img{width:100%;height:100%;aspect-ratio:4/3;object-fit:cover}
.svc-row-copy h2{font-size:var(--fs-h2);margin-bottom:var(--space-3)}
.svc-row-copy p{color:var(--color-text-muted);margin-bottom:var(--space-4);max-width:46ch}
.svc-row-copy .card-link{padding:0;font-size:1rem}

/* prose + aside (service detail, about) */
.prose-section{padding-block:var(--section-y)}
.prose-grid{display:grid;grid-template-columns:1.5fr .8fr;gap:clamp(28px,5vw,64px);align-items:start}
.prose p{font-size:1.08rem;margin-bottom:var(--space-4);max-width:62ch}
.prose a{color:var(--color-accent);font-weight:500;text-decoration:underline;text-underline-offset:3px}
.prose-aside{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-5);position:sticky;top:90px}
.prose-aside h3{font-size:1.1rem;margin-bottom:var(--space-3)}
.prose-aside ul{list-style:none;padding:0;margin-bottom:var(--space-4);display:flex;flex-direction:column;gap:.6rem}
.prose-aside li{padding-left:1.4rem;position:relative;color:var(--color-text-muted);font-size:.96rem}
.prose-aside li::before{content:"";position:absolute;left:0;top:.5rem;width:8px;height:8px;border-radius:50%;background:var(--color-accent)}
.aside-note{font-size:var(--fs-small);color:var(--color-text-muted);margin-top:var(--space-3);text-align:center}

/* points */
.points{padding-block:var(--section-y);background:var(--color-surface);border-block:1px solid var(--color-border)}
.points-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-5)}
.point{border-top:2px solid var(--color-accent);padding-top:var(--space-3)}
.point h3{font-size:1.15rem;margin-bottom:.4rem}
.point p{color:var(--color-text-muted);font-size:.98rem}

/* cta band */
.cta-band{background:var(--color-surface-ink);color:var(--color-text-on-ink);padding-block:var(--section-y)}
.cta-band-inner{display:flex;justify-content:space-between;align-items:center;gap:var(--space-5);flex-wrap:wrap}
.cta-band h2{font-size:var(--fs-h2);max-width:18ch}
.cta-band p{color:rgba(244,239,230,.75);margin-top:var(--space-3);max-width:46ch}
.cta-band-actions{display:flex;gap:.8rem;flex-wrap:wrap}
.btn-outline-light{background:transparent;border-color:rgba(244,239,230,.4);color:var(--color-text-on-ink)}
.btn-outline-light:hover{border-color:var(--color-text-on-ink)}
.center-link{text-align:center;margin-top:var(--space-5)}
.center-link a{color:var(--color-accent);font-weight:600}

/* 404 */
.nf{min-height:64vh;display:grid;align-items:center;padding-block:var(--section-y)}
.nf h1{font-size:clamp(2.4rem,7vw,5rem);line-height:1;margin-block:var(--space-3) var(--space-4)}
.nf p{color:var(--color-text-muted);max-width:38ch;margin-bottom:var(--space-5)}

/* ============ CATALOG ============ */
.catalog-section{padding-block:var(--section-y)}
.catalog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4);margin-bottom:var(--space-6)}
.cat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;display:flex;flex-direction:column;transition:transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out)}
.cat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft)}
.cat-media{aspect-ratio:4/3;overflow:hidden}
.cat-media img{width:100%;height:100%;object-fit:cover;transition:transform var(--dur-slow) var(--ease-out)}
.cat-card:hover .cat-media img{transform:scale(1.05)}
.cat-body{padding:var(--space-4);display:flex;flex-direction:column;gap:.35rem;flex:1}
.cat-method{font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-accent)}
.cat-body h3{font-size:1.15rem}
.cat-body p{color:var(--color-text-muted);font-size:.92rem;flex:1;margin-bottom:.6rem}
.cat-body .btn{align-self:flex-start}
.catalog-note{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);flex-wrap:wrap;background:var(--brand-mint);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-5)}
.catalog-note h3{font-size:1.3rem;margin-bottom:.3rem}
.catalog-note p{color:var(--color-text-muted);max-width:52ch}
@media(max-width:760px){.catalog-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.catalog-grid{grid-template-columns:1fr}}

/* ============ BLOG ============ */
.blog-section{padding-block:var(--section-y)}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}
.post-card{display:flex;flex-direction:column;gap:.5rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-5);color:inherit;transition:transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out)}
.post-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft)}
.post-card-meta{font-size:var(--fs-small);text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted)}
.post-card h2{font-size:1.3rem;line-height:1.2}
.post-card-excerpt{color:var(--color-text-muted);font-size:.96rem}
.post-card .card-link{padding:0;margin-top:auto}
/* post detail */
.post-head{padding-block:clamp(36px,6vw,72px) var(--space-5);border-bottom:1px solid var(--color-border)}
.post-head h1{font-size:clamp(2rem,4.5vw,3.4rem);max-width:24ch;margin-top:var(--space-3)}
.post-body{padding-block:var(--section-y);max-width:none}
.post-body h2{font-size:1.5rem;margin-block:var(--space-5) var(--space-3)}
.post-body p{max-width:68ch}

/* ============ MODAL ============ */
.modal{position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;padding:var(--space-4)}
.modal.is-open{display:flex}
.modal-overlay{position:absolute;inset:0;background:rgba(11,9,7,.55);backdrop-filter:blur(3px)}
.modal-card{position:relative;z-index:1;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lift);width:min(560px,100%);max-height:92vh;overflow-y:auto;padding:clamp(22px,4vw,40px)}
.modal-card .eyebrow{margin-bottom:var(--space-2)}
.modal-card h2{font-size:clamp(1.6rem,3vw,2.1rem);margin-bottom:.5rem}
.modal-sub{color:var(--color-text-muted);margin-bottom:var(--space-4);font-size:.96rem}
.modal-sub a{color:var(--color-accent);font-weight:600}
.modal-close{position:absolute;top:14px;right:14px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:50%;width:38px;height:38px;display:grid;place-items:center;color:var(--color-text)}
.modal-close:hover{color:var(--color-accent);border-color:var(--color-accent)}
.modal-card .quote-form{background:none;border:none;padding:0}
body.modal-locked{overflow:hidden}
.form-thanks{text-align:center;padding:var(--space-4) 0}
.form-thanks h3{font-size:1.4rem;margin-bottom:.5rem}
.form-thanks p{color:var(--color-text-muted);margin-bottom:var(--space-4)}
@media(prefers-reduced-motion:no-preference){
  .modal.is-open .modal-card{animation:modalIn .26s cubic-bezier(.16,1,.3,1)}
}
@keyframes modalIn{from{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:none}}

/* =====================================================================
   Responsive
   ===================================================================== */
@media(max-width:1000px){
  .nav{display:none}
  .nav-toggle{display:inline-flex}
  .hero-grid{grid-template-columns:1fr;gap:var(--space-5)}
  .hero-media{order:-1}
  .hero-media img{aspect-ratio:16/10}
  .updates-grid,.contact-grid,.prose-grid,.svc-row,.svc-row.reverse{grid-template-columns:1fr}
  .svc-row.reverse .svc-row-media{order:0}
  .prose-aside{position:static}
  .gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:200px}
  .points-grid{grid-template-columns:1fr;gap:var(--space-4)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:var(--space-5)}
  /* mobile nav drawer */
  .mobile-nav{display:flex;flex-direction:column;gap:.2rem;max-height:0;overflow:hidden;transition:max-height var(--dur-base) var(--ease-out);background:var(--color-surface);border-top:1px solid var(--color-border)}
  body.nav-open .mobile-nav{max-height:70vh}
  .mobile-nav a{padding:.85rem var(--gutter);border-bottom:1px solid var(--color-border);font-weight:500;color:var(--color-text)}
  .mobile-nav a[aria-current="page"]{color:var(--color-accent)}
  .mobile-nav .btn{margin:var(--space-3) var(--gutter)}
}
@media(max-width:760px){
  .svc-grid,.review-grid,.audience-row,.steps{grid-template-columns:1fr}
  .review-grid{gap:var(--space-3)}
  .steps{gap:var(--space-3)}
  .header-cta .phone-link span{display:none}
  .phone-link{padding:.4rem}
  .contact-meta{flex-direction:column;gap:var(--space-4)}
}
@media(max-width:560px){
  .field-row{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr 1fr;grid-auto-rows:150px}
  .footer-grid{grid-template-columns:1fr}
  .hero-trust{flex-wrap:wrap;gap:var(--space-4)}
  .chat-launch span{display:none}
  .chat-launch{padding:.9rem}
}

/* =====================================================================
   Reduced motion — show everything, kill movement
   ===================================================================== */
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .js-anim .reveal,.js-anim .bubble[data-step]{opacity:1!important;transform:none!important}
  .marquee-track{animation:none!important}
  .mobile-nav{transition:none!important}
}

/* ===== motion v2: animated order tracking + ambient polish ===== */
.phone-col{display:flex;flex-direction:column;align-items:center;gap:18px}
.order-track{display:flex;align-items:center;gap:8px;font-size:.72rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--color-text-muted)}
.track-step{display:flex;align-items:center;gap:6px;opacity:.45;transition:opacity .4s,color .4s}
.track-step.is-active{opacity:1;color:var(--color-accent)}
.track-step.is-done{opacity:.85;color:var(--color-text)}
.track-dot{width:9px;height:9px;border-radius:50%;background:currentColor;flex:none;transition:transform .3s}
.track-step.is-active .track-dot{transform:scale(1.35);box-shadow:0 0 0 4px rgba(37,99,235,.15)}
.track-line{width:26px;height:2px;background:var(--color-border);flex:none}
@media(prefers-reduced-motion:no-preference){
  .js-anim .phone{animation:phoneFloat 7s ease-in-out infinite}
  @keyframes phoneFloat{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-9px) rotate(.4deg)}}
  .hero-media img{animation:heroZoom 18s ease-out both}
  @keyframes heroZoom{from{transform:scale(1.07)}to{transform:scale(1)}}
}
.bubble.typing{display:none;width:64px;padding:12px 14px;gap:5px}
.bubble.typing.is-on{display:flex}
.t-dot{width:7px;height:7px;border-radius:50%;background:var(--color-text-muted);opacity:.5;animation:tBlink 1.1s infinite}
.t-dot:nth-child(2){animation-delay:.18s}
.t-dot:nth-child(3){animation-delay:.36s}
@keyframes tBlink{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}
.g-item{overflow:hidden}
.g-item img{transition:transform .8s cubic-bezier(.16,1,.3,1)}
.g-item:hover img{transform:scale(1.05)}
.review{transition:transform .5s cubic-bezier(.16,1,.3,1),box-shadow .5s}
.review:hover{transform:translateY(-4px);box-shadow:0 14px 36px rgba(23,19,15,.09)}

/* ===== interior page hero: annotated media (PV-inspired, ST language) ===== */
.page-hero.has-media .ph-grid{display:grid;grid-template-columns:1.02fr .98fr;gap:clamp(28px,4vw,56px);align-items:center}
.ph-media{position:relative;margin:0}
.ph-media img{width:100%;height:auto;border-radius:18px;display:block;box-shadow:0 18px 48px rgba(23,19,15,.14)}
.chip{position:absolute;transform:translate(-50%,-50%);display:inline-flex;align-items:center;gap:.45rem;
  background:#fff;border:1px solid var(--color-border);border-radius:999px;padding:.42rem .85rem;
  font-size:.78rem;font-weight:600;color:var(--color-text);white-space:nowrap;
  box-shadow:0 8px 22px rgba(23,19,15,.16)}
.chip .c-dot{width:8px;height:8px;border-radius:50%;background:var(--color-accent);flex:none}
.js-anim .chip{opacity:0;animation:chipPop .55s cubic-bezier(.34,1.56,.64,1) forwards}
@keyframes chipPop{from{opacity:0;transform:translate(-50%,-30%) scale(.7)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}
@media(prefers-reduced-motion:reduce){.js-anim .chip{animation:none;opacity:1}}
@media(prefers-reduced-motion:no-preference){
  .ph-media .chip:nth-of-type(odd){animation-name:chipPop;}
  .ph-media:hover .chip{box-shadow:0 10px 26px rgba(23,19,15,.22)}
}
@media(max-width:760px){
  .page-hero.has-media .ph-grid{grid-template-columns:1fr}
  .chip{font-size:.7rem;padding:.34rem .65rem}
}

/* ============================================================
   SHOP + CART + PAYROC CHECKOUT
   ============================================================ */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

/* header cart button */
.cart-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:50%;background:transparent;border:1px solid var(--color-border-ink);color:var(--brand-cream);cursor:pointer;transition:border-color var(--dur-fast),color var(--dur-fast)}
.cart-btn:hover{color:#fff;border-color:rgba(244,239,230,.4)}
.cart-count{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--color-accent);color:#fff;font-size:.7rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center;line-height:1}

/* shop grid */
.shop-section{padding-block:var(--section-y)}
.shop-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4);margin-bottom:var(--space-6)}
.shop-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;display:flex;flex-direction:column;transition:transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out)}
.shop-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft)}
.shop-media{aspect-ratio:4/3;overflow:hidden}
.shop-media img{width:100%;height:100%;object-fit:cover;transition:transform var(--dur-slow) var(--ease-out)}
.shop-card:hover .shop-media img{transform:scale(1.05)}
.shop-body{padding:var(--space-4);display:flex;flex-direction:column;gap:.4rem;flex:1}
.shop-method{font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-accent)}
.shop-body h3{font-size:1.15rem}
.shop-body p{color:var(--color-text-muted);font-size:.9rem;flex:1;margin-bottom:.4rem}
.shop-buy{display:flex;align-items:center;justify-content:space-between;gap:.6rem;margin-bottom:.6rem}
.shop-price{font-family:var(--font-display);font-size:1.4rem;font-weight:600;color:var(--color-text)}
.shop-size select{font:inherit;font-size:.9rem;padding:.45rem .6rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);color:var(--color-text)}
.shop-onesize{font-size:.8rem;color:var(--color-text-muted);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:.4rem .6rem}
.shop-add{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
.shop-add .btn{flex:1 1 auto;min-width:120px;white-space:nowrap}

/* qty stepper */
.qty{display:inline-flex;align-items:center;border:1px solid var(--color-border);border-radius:var(--radius-sm);overflow:hidden;background:var(--color-bg)}
.qty button{width:34px;height:38px;border:none;background:transparent;font-size:1.1rem;color:var(--color-text);cursor:pointer;line-height:1}
.qty button:hover{background:var(--color-surface);color:var(--color-accent)}
.qty input{width:38px;height:38px;border:none;border-left:1px solid var(--color-border);border-right:1px solid var(--color-border);text-align:center;font:inherit;font-size:.95rem;background:transparent;color:var(--color-text)}
.qty-sm button{width:28px;height:30px;font-size:1rem}
.qty-sm input{width:30px;height:30px;font-size:.85rem}
.btn.is-added{background:#1f8a4c}

/* cart drawer */
.cart-drawer{position:fixed;inset:0;z-index:240;display:none}
.cart-drawer.is-open{display:block}
.cart-overlay{position:absolute;inset:0;background:rgba(11,9,7,.5);backdrop-filter:blur(3px)}
.cart-panel{position:absolute;top:0;right:0;height:100%;width:min(420px,100%);background:var(--color-bg);box-shadow:var(--shadow-lift);display:flex;flex-direction:column;transform:translateX(100%);transition:transform var(--dur-base) var(--ease-out)}
.cart-drawer.is-open .cart-panel{transform:translateX(0)}
.cart-head{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);border-bottom:1px solid var(--color-border)}
.cart-head h2{font-size:1.3rem}
.cart-close{background:var(--color-surface);border:1px solid var(--color-border);border-radius:50%;width:38px;height:38px;display:grid;place-items:center;color:var(--color-text);cursor:pointer}
.cart-close:hover{color:var(--color-accent);border-color:var(--color-accent)}
.cart-scroll{flex:1;overflow-y:auto;padding:var(--space-4)}
.cart-items{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-3)}
.cart-item{display:grid;grid-template-columns:64px 1fr auto;gap:.8rem;padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border)}
.ci-media{width:64px;height:64px;border-radius:var(--radius-sm);overflow:hidden;background:var(--color-surface)}
.ci-media img{width:100%;height:100%;object-fit:cover}
.ci-info{display:flex;flex-direction:column;gap:.2rem;min-width:0}
.ci-name{font-weight:600;font-size:.95rem}
.ci-size{font-size:.78rem;color:var(--color-text-muted)}
.ci-price{font-size:.78rem;color:var(--color-text-muted)}
.ci-controls{display:flex;align-items:center;gap:.6rem;margin-top:.3rem}
.ci-remove{background:none;border:none;color:var(--color-text-muted);font-size:.78rem;text-decoration:underline;cursor:pointer;padding:0}
.ci-remove:hover{color:var(--color-accent)}
.ci-line-total{font-weight:600;font-size:.95rem;white-space:nowrap}
.cart-empty{text-align:center;color:var(--color-text-muted);padding:var(--space-6) var(--space-3);display:flex;flex-direction:column;gap:var(--space-3);align-items:center}
.cart-foot{border-top:1px solid var(--color-border);padding:var(--space-4);background:var(--color-surface)}
.cart-line{display:flex;justify-content:space-between;font-size:.92rem;margin-bottom:.4rem}
.cart-line-muted{color:var(--color-text-muted)}
.cart-total{font-size:1.1rem;font-weight:700;margin:.6rem 0 var(--space-3);padding-top:.6rem;border-top:1px solid var(--color-border)}
.cart-secure{display:flex;align-items:center;justify-content:center;gap:.4rem;font-size:.76rem;color:var(--color-text-muted);margin-top:.7rem}
.cart-secure svg{color:#1f8a4c}

/* Payroc demo checkout overlay */
.payroc-demo{position:fixed;inset:0;z-index:260;display:flex;align-items:center;justify-content:center;padding:var(--space-4);opacity:0;transition:opacity var(--dur-base)}
.payroc-demo.is-open{opacity:1}
.pd-overlay{position:absolute;inset:0;background:rgba(11,9,7,.6);backdrop-filter:blur(4px)}
.pd-card{position:relative;z-index:1;width:min(420px,100%);background:var(--color-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-lift);padding:clamp(20px,4vw,32px);max-height:92vh;overflow-y:auto}
.pd-demo-flag{background:#FEF3C7;color:#7c5e10;border:1px solid #f3d77a;border-radius:var(--radius-sm);font-size:.74rem;padding:.5rem .7rem;margin-bottom:var(--space-4);line-height:1.4}
.pd-head{display:flex;align-items:center;gap:.5rem;font-weight:600;margin-bottom:var(--space-4);font-size:1.05rem}
.pd-lock{color:#1f8a4c;display:inline-flex}
.pd-by{margin-left:auto;font-size:.74rem;font-weight:400;color:var(--color-text-muted)}
.pd-amount{display:flex;align-items:baseline;justify-content:space-between;padding:var(--space-3);background:var(--color-surface);border-radius:var(--radius-sm);margin-bottom:var(--space-4)}
.pd-amount span{font-size:.85rem;color:var(--color-text-muted)}
.pd-amount strong{font-family:var(--font-display);font-size:1.5rem}
.pd-field{display:flex;flex-direction:column;gap:.3rem;margin-bottom:var(--space-3);min-width:0}
.pd-field span{font-size:.78rem;font-weight:600;color:var(--color-text-muted)}
.pd-field input{font:inherit;font-size:.95rem;padding:.7rem .85rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text)}
.pd-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}
.pd-pay{margin-top:.4rem}
.pd-cancel{display:block;width:100%;text-align:center;background:none;border:none;color:var(--color-text-muted);font-size:.85rem;margin-top:.6rem;cursor:pointer}
.pd-cancel:hover{color:var(--color-accent)}

/* checkout result pages */
.checkout-result{text-align:center;max-width:560px;margin-inline:auto;padding-block:var(--space-6)}
.checkout-result .eyebrow{justify-content:center}
.checkout-result .hero-actions{justify-content:center}
.result-badge{width:72px;height:72px;border-radius:50%;display:grid;place-items:center;margin:0 auto var(--space-4)}
.result-ok{background:#e6f4ec;color:#1f8a4c}
.result-cancel{background:#fdecec;color:#c0392b}

@media(max-width:760px){.shop-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.shop-grid{grid-template-columns:1fr}}

/* shop page: compact hero so products show on load */
body[data-page="shop"] .page-hero{padding-block:clamp(20px,3vw,34px) clamp(14px,2vw,22px)}
body[data-page="shop"] .page-hero h1{font-size:clamp(1.9rem,3.6vw,2.8rem);margin-block:.4rem .7rem}
body[data-page="shop"] .page-hero-sub{margin-bottom:var(--space-4);max-width:48ch}
body[data-page="shop"] .page-hero .hero-actions{margin-top:0}
body[data-page="shop"] .ph-media img{max-height:260px;width:100%;object-fit:cover}
body[data-page="shop"] .shop-section{padding-top:var(--space-5)}
/* mobile: drop the stacked hero image + tighten so products reach the fold */
@media(max-width:760px){
  body[data-page="shop"] .page-hero .ph-media{display:none}
  body[data-page="shop"] .page-hero{padding-block:12px 4px}
  body[data-page="shop"] .shop-section{padding-top:var(--space-4)}
}

/* homepage shop preview */
.shop-preview{padding-block:var(--section-y);background:var(--color-surface)}
.shop-preview-head{display:flex;justify-content:space-between;align-items:flex-end;gap:var(--space-4);flex-wrap:wrap;text-align:left;margin-bottom:0}
.shop-preview-head>div{max-width:60ch}
.shop-preview-cta{flex:none;white-space:nowrap}
.link-btn{background:none;border:none;color:var(--color-accent);font:inherit;font-weight:600;cursor:pointer;padding:0;text-decoration:underline}
.link-btn:hover{color:#1b4fd1}
.shop-preview-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4);margin:var(--space-5) 0 var(--space-4)}
.shop-pcard{display:flex;flex-direction:column;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;transition:transform var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out)}
.shop-pcard:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft)}
.shop-pmedia{aspect-ratio:1/1;overflow:hidden}
.shop-pmedia img{width:100%;height:100%;object-fit:cover;transition:transform var(--dur-slow) var(--ease-out)}
.shop-pcard:hover .shop-pmedia img{transform:scale(1.06)}
.shop-pbody{padding:var(--space-3);display:flex;flex-direction:column;gap:.25rem}
.shop-pmethod{font-size:.68rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-accent)}
.shop-pbody h3{font-size:1rem}
.shop-pprice{font-family:var(--font-display);font-size:1.15rem;font-weight:600;color:var(--color-text)}
@media(max-width:760px){.shop-preview-grid{grid-template-columns:1fr 1fr}.shop-preview-cta{width:100%;text-align:center}}
