/* ════════════════════════════════════════════════════════════════
   CaprockWorks Tools — product-surface stylesheet
   Extends tokens.css (the shared CaprockWorks identity).
   Shared by the hub (index.html) and every product page.
   Warm-paper identity + an engineered "datasheet" layer for
   technical buyers: charcoal preview windows, mono spec strips.
   ════════════════════════════════════════════════════════════════ */

/* ─── Reset ─── */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important}
}
body{
  margin:0;font-family:var(--font-body);font-size:var(--text-base);line-height:1.65;
  color:var(--charcoal);background:var(--paper);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;
}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;line-height:1.1;margin:0 0 var(--sp-md);letter-spacing:-.02em;color:var(--charcoal)}
h1{font-size:var(--text-5xl);font-weight:800}
h2{font-size:var(--text-3xl)}
h3{font-size:var(--text-xl)}
p{margin:0 0 var(--sp-md);max-width:64ch;color:var(--charcoal-mid)}
a{color:var(--rust);text-decoration:none;transition:color var(--dur-fast) var(--ease)}
a:hover{color:var(--rust-hover);text-decoration:underline}
img,svg{max-width:100%;height:auto;display:block}
ul{margin:0;padding:0}
::selection{background:var(--rust);color:var(--cream)}
code,kbd{font-family:var(--font-mono);font-size:.9em;overflow-wrap:anywhere}

/* Grain overlay — paper texture */
body::after{content:'';position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.028;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='256' height='256' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:256px 256px}

/* ─── Layout ─── */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--sp-lg)}
.section{padding-block:var(--sp-5xl);position:relative}
.section-sm{padding-block:var(--sp-3xl)}
.section-limestone{background:var(--limestone)}
.section-charcoal{background:var(--charcoal-bg);color:var(--paper)}
.section-charcoal h1,.section-charcoal h2,.section-charcoal h3,.section-charcoal h4{color:var(--paper)}
.section-charcoal p{color:var(--limestone-deep)}
.section-charcoal .eyebrow{color:var(--gold)}
.hairline{height:1px;background:linear-gradient(90deg,transparent,var(--border-hi),transparent);border:0;margin:0}
.topo-bg{position:absolute;inset:0;pointer-events:none;opacity:.05;
  background-image:url("assets/topo-contour.svg");background-size:680px 680px;background-position:center}

/* ─── Header / nav ─── */
.site-header{position:sticky;top:0;z-index:50;background:rgba(244,237,228,.88);
  backdrop-filter:saturate(150%) blur(14px);-webkit-backdrop-filter:saturate(150%) blur(14px);
  border-bottom:1px solid var(--border)}
.nav{display:flex;align-items:center;justify-content:space-between;min-height:4.25rem}
.brand{display:inline-flex;align-items:center;gap:var(--sp-sm);font-family:var(--font-display);
  font-size:var(--text-lg);font-weight:700;color:var(--charcoal);letter-spacing:-.01em}
.brand:hover{text-decoration:none;color:var(--charcoal)}
.brand-mark{display:inline-flex;align-items:center;justify-content:center;width:2.1rem;height:2.1rem;flex-shrink:0}
.brand-mark img{width:100%;height:100%}
.brand-sub{font-weight:400;color:var(--charcoal-soft);margin-left:.12em}
.primary-nav ul{display:flex;list-style:none;gap:var(--sp-xl);margin:0;padding:0;align-items:center}
.primary-nav a{color:var(--charcoal-soft);font-weight:500;font-size:var(--text-sm)}
.primary-nav a:hover{text-decoration:none;color:var(--charcoal)}
.primary-nav a[aria-current="page"]{color:var(--charcoal);font-weight:600}
.primary-nav a.btn,.primary-nav a.btn:hover{color:var(--cream);text-decoration:none}
.nav-ext::after{content:'\2197';font-size:.85em;margin-left:.15em;color:var(--charcoal-faint)}
@media(max-width:48rem){.primary-nav{display:none}}

/* ─── Buttons ─── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-xs);
  padding:.85rem 1.5rem;border:1px solid transparent;border-radius:var(--radius-md);
  font-family:var(--font-body);font-size:var(--text-base);font-weight:600;text-decoration:none;
  cursor:pointer;transition:transform var(--dur-fast) var(--ease),background var(--dur-fast) var(--ease),box-shadow var(--dur-fast) var(--ease),border-color var(--dur-fast) var(--ease)}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn-primary{background:var(--rust);color:var(--cream);box-shadow:0 4px 16px rgba(184,83,58,.25)}
.btn-primary:hover{background:var(--rust-hover);color:var(--cream);box-shadow:0 8px 24px rgba(184,83,58,.35)}
.btn-ghost{background:transparent;color:var(--charcoal);border-color:var(--border-hi)}
.btn-ghost:hover{background:var(--limestone);color:var(--charcoal);border-color:var(--charcoal-soft)}
.btn-dark{background:var(--charcoal);color:var(--cream)}
.btn-dark:hover{background:var(--charcoal-bg);color:var(--cream)}
.btn-lg{padding:1.05rem 2rem;font-size:var(--text-lg)}
.btn svg{width:1.05em;height:1.05em;flex-shrink:0}

/* ─── Eyebrow + section head ─── */
.eyebrow{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:500;
  text-transform:uppercase;letter-spacing:.18em;color:var(--rust);margin:0 0 var(--sp-sm)}
.section-head{max-width:46rem;margin-bottom:var(--sp-2xl)}
.section-head h2{margin-bottom:var(--sp-sm)}
.section-head p{font-size:var(--text-lg);color:var(--charcoal-mid)}
.section-head.center{margin-inline:auto;text-align:center}
.section-head.center p{margin-inline:auto}

/* ─── Pills / tags ─── */
.pill{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--font-mono);
  font-size:var(--text-xs);font-weight:500;letter-spacing:.06em;padding:.28rem .6rem;
  border-radius:999px;border:1px solid var(--border-hi);color:var(--charcoal-soft);background:var(--cream)}
.pill-rust{color:var(--rust);border-color:var(--rust);background:var(--rust-soft)}
.pill-gold{color:var(--gold-deep);border-color:var(--gold);background:var(--gold-soft)}
.pill-dot{width:.45rem;height:.45rem;border-radius:50%;background:currentColor}

/* ─── Hub: hero ─── */
.hub-hero{padding:var(--sp-4xl) 0 var(--sp-3xl);position:relative;overflow:hidden}
.hub-hero h1{font-size:var(--text-5xl);max-width:18ch}
.hub-hero .lead{font-size:var(--text-xl);color:var(--charcoal-mid);max-width:40rem;margin-top:var(--sp-md)}
.hero-actions{display:flex;flex-wrap:wrap;gap:var(--sp-md);margin-top:var(--sp-xl)}

/* ─── Hub: product grid ─── */
.product-grid{display:grid;gap:var(--sp-xl);grid-template-columns:1fr}
@media(min-width:46rem){.product-grid{grid-template-columns:repeat(2,1fr)}}
.product-card{display:flex;flex-direction:column;background:var(--cream);
  border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--sp-2xl);
  text-decoration:none;color:inherit;position:relative;overflow:hidden;
  transition:transform var(--dur-normal) var(--ease),border-color var(--dur-normal) var(--ease),box-shadow var(--dur-normal) var(--ease)}
.product-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--rust);transform:scaleX(0);transform-origin:left;transition:transform var(--dur-normal) var(--ease)}
.product-card:hover{transform:translateY(-4px);border-color:var(--border-hi);box-shadow:var(--shadow-lg);text-decoration:none}
.product-card:hover::before{transform:scaleX(1)}
.product-card .card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--sp-md);margin-bottom:var(--sp-md)}
.product-card .card-glyph{font-family:var(--font-display);font-weight:800;font-size:var(--text-lg);
  width:2.6rem;height:2.6rem;border-radius:var(--radius-md);background:var(--charcoal);color:var(--cream);
  display:flex;align-items:center;justify-content:center;flex-shrink:0}
.product-card h3{font-size:var(--text-2xl);margin-bottom:var(--sp-2xs)}
.product-card .card-kicker{font-family:var(--font-mono);font-size:var(--text-xs);
  text-transform:uppercase;letter-spacing:.14em;color:var(--charcoal-faint);margin-bottom:var(--sp-sm)}
.product-card p{font-size:var(--text-sm);color:var(--charcoal-mid);margin-bottom:var(--sp-lg)}
.product-card .card-meta{display:flex;flex-wrap:wrap;gap:var(--sp-xs);margin-top:auto;
  padding-top:var(--sp-md);border-top:1px solid var(--border)}
.product-card .card-go{margin-top:var(--sp-md);font-family:var(--font-mono);font-size:var(--text-sm);
  font-weight:500;color:var(--rust);display:inline-flex;align-items:center;gap:.4rem}
.product-card:hover .card-go{gap:.7rem}
.card-go::after{content:'\2192';transition:transform var(--dur-fast) var(--ease)}

/* ─── Product status (driven by products.js) ─── */
.product-card[data-status="hidden"]{display:none !important}
.product-card[data-status="coming-soon"]{opacity:.72 !important}  /* overrides .reveal.is-visible */
.product-card[data-status="coming-soon"]::after{
  content:'Coming soon';position:absolute;bottom:var(--sp-md);right:var(--sp-md);
  background:var(--gold-soft);color:var(--gold-deep);border:1px solid var(--gold);
  padding:.2rem .6rem;border-radius:999px;
  font-family:var(--font-mono);font-size:var(--text-xs);font-weight:600;
  text-transform:uppercase;letter-spacing:.12em;pointer-events:none;z-index:2
}
.footer-soon{color:var(--gold-deep);font-family:var(--font-mono);font-size:.85em;margin-left:.25em}

/* ─── Principle row (hub) ─── */
.principle-grid{display:grid;gap:var(--sp-xl);grid-template-columns:1fr}
@media(min-width:46rem){.principle-grid{grid-template-columns:repeat(3,1fr)}}
.principle{padding:var(--sp-lg);border-left:2px solid var(--rust)}
.principle h3{font-size:var(--text-lg);margin-bottom:var(--sp-xs)}
.principle p{font-size:var(--text-sm);color:var(--charcoal-soft);margin:0}

/* ─── Product page: hero ─── */
.tool-hero{padding:var(--sp-4xl) 0 var(--sp-3xl);position:relative;overflow:hidden}
.tool-hero-inner{display:grid;grid-template-columns:1.05fr .95fr;gap:var(--sp-3xl);align-items:center}
@media(max-width:60rem){.tool-hero-inner{grid-template-columns:1fr;gap:var(--sp-2xl)}}
.tool-hero h1{font-size:var(--text-4xl);margin-bottom:var(--sp-md)}
.tool-hero .lead{font-size:var(--text-lg);color:var(--charcoal-mid);max-width:34rem}
.tool-hero-meta{display:flex;flex-wrap:wrap;gap:var(--sp-xs);margin-bottom:var(--sp-lg)}

/* ─── Preview window (CSS-composed app mock) ─── */
.preview-window{background:var(--charcoal-bg);border-radius:var(--radius-lg);
  border:1px solid rgba(244,237,228,.09);box-shadow:var(--shadow-lg);overflow:hidden}
.preview-bar{display:flex;align-items:center;gap:var(--sp-sm);padding:.7rem var(--sp-md);
  background:rgba(244,237,228,.045);border-bottom:1px solid rgba(244,237,228,.07);
  font-family:var(--font-mono);font-size:var(--text-xs);color:var(--charcoal-faint);
  text-transform:uppercase;letter-spacing:.12em}
.preview-dots{display:flex;gap:.42rem}
.preview-dots span{width:.62rem;height:.62rem;border-radius:50%;background:rgba(244,237,228,.15)}
.preview-body{padding:var(--sp-lg);font-family:var(--font-mono);font-size:var(--text-sm);
  color:var(--limestone-deep);display:grid;gap:.55rem;min-height:15rem}
.pv-prompt{color:var(--gold)}
.pv-dim{color:var(--charcoal-faint)}
.pv-rust{color:var(--rust-light)}
.pv-line{display:flex;gap:.6rem;align-items:baseline}
.pv-bar{height:.45rem;border-radius:2px;background:rgba(244,237,228,.13)}
.pv-card{background:rgba(244,237,228,.04);border:1px solid rgba(244,237,228,.08);
  border-radius:var(--radius-sm);padding:.7rem .85rem;display:grid;gap:.4rem}
.pv-tag{display:inline-block;font-size:var(--text-xs);padding:.1rem .45rem;border-radius:3px;
  background:var(--rust-soft);color:var(--rust-light);border:1px solid rgba(184,83,58,.3)}

/* ─── Spec strip (datasheet) ─── */
.spec-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border-hi);
  border:1px solid var(--border-hi);border-radius:var(--radius-md);overflow:hidden}
@media(max-width:46rem){.spec-strip{grid-template-columns:repeat(2,1fr)}}
.spec{background:var(--cream);padding:var(--sp-md) var(--sp-lg)}
.spec dt{font-family:var(--font-mono);font-size:var(--text-xs);text-transform:uppercase;
  letter-spacing:.12em;color:var(--charcoal-faint);margin-bottom:.3rem}
.spec dd{margin:0;font-family:var(--font-display);font-weight:700;font-size:var(--text-lg);color:var(--charcoal)}
.spec dd small{font-weight:500;font-size:var(--text-sm);color:var(--charcoal-soft)}

/* ─── Feature grid ─── */
.feature-grid{display:grid;gap:var(--sp-xl);grid-template-columns:1fr}
@media(min-width:46rem){.feature-grid{grid-template-columns:repeat(3,1fr)}}
.feature{padding:var(--sp-lg);background:var(--cream);border:1px solid var(--border);border-radius:var(--radius-lg);min-width:0}
.feature .feat-num{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--rust);
  letter-spacing:.12em;margin-bottom:var(--sp-sm)}
.feature h3{font-size:var(--text-lg);margin-bottom:var(--sp-xs)}
.feature p{font-size:var(--text-sm);color:var(--charcoal-soft);margin:0}

/* ─── Boundary: what it does / doesn't ─── */
.boundary{display:grid;gap:var(--sp-xl);grid-template-columns:1fr}
@media(min-width:46rem){.boundary{grid-template-columns:1fr 1fr}}
.boundary-col h3{font-size:var(--text-lg);margin-bottom:var(--sp-md);display:flex;align-items:center;gap:.5rem}
.boundary-col ul{list-style:none;display:grid;gap:var(--sp-sm)}
.boundary-col li{font-size:var(--text-sm);padding-left:1.6rem;position:relative;color:var(--charcoal-mid)}
.does li::before{content:'\2713';position:absolute;left:0;color:var(--rust);font-weight:700}
.doesnt li::before{content:'\2014';position:absolute;left:0;color:var(--charcoal-faint);font-weight:700}

/* ─── Who it's for ─── */
.who-list{list-style:none;display:grid;gap:var(--sp-md);max-width:46rem}
.who-list li{font-size:var(--text-base);padding-left:1.9rem;position:relative;color:var(--charcoal-mid)}
.who-list li::before{content:'';position:absolute;left:0;top:.55em;width:.7rem;height:.7rem;
  border-radius:50%;border:2px solid var(--rust)}
.who-list strong{color:var(--charcoal);font-weight:600}

/* ─── Tier cards (free GitHub / paid Polar) ─── */
.tier-grid{display:grid;gap:var(--sp-xl);grid-template-columns:1fr}
@media(min-width:52rem){.tier-grid{grid-template-columns:1fr 1fr}}
.tier-card{display:flex;flex-direction:column;padding:var(--sp-2xl);background:var(--cream);
  border:1px solid var(--border);border-radius:var(--radius-xl);position:relative}
.tier-card.featured{border-color:var(--rust);box-shadow:0 12px 40px rgba(184,83,58,.12)}
.tier-card .tag{position:absolute;top:-.75rem;left:var(--sp-2xl);background:var(--rust);color:var(--cream);
  padding:.25rem .75rem;border-radius:999px;font-size:var(--text-xs);font-weight:700;
  text-transform:uppercase;letter-spacing:.08em;font-family:var(--font-mono)}
.tier-kicker{font-family:var(--font-mono);font-size:var(--text-xs);text-transform:uppercase;
  letter-spacing:.14em;color:var(--charcoal-faint);margin-bottom:var(--sp-2xs)}
.tier-card h3{font-size:var(--text-xl);margin-bottom:var(--sp-2xs)}
.tier-price{font-family:var(--font-display);font-weight:800;font-size:var(--text-4xl);
  letter-spacing:-.02em;line-height:1;margin:var(--sp-sm) 0;color:var(--charcoal)}
.tier-price small{font-size:var(--text-base);font-weight:500;color:var(--charcoal-soft)}
.tier-card .pitch{font-size:var(--text-sm);color:var(--charcoal-soft);margin-bottom:var(--sp-lg)}
.tier-card ul{list-style:none;display:grid;gap:var(--sp-sm);margin-bottom:var(--sp-xl);flex-grow:1}
.tier-card ul li{font-size:var(--text-sm);color:var(--charcoal);padding-left:1.7rem;position:relative}
.tier-card ul li::before{content:'\2713';position:absolute;left:0;color:var(--rust);font-weight:700}
.tier-card .btn{width:100%}
.tier-note{font-size:var(--text-xs);color:var(--charcoal-faint);margin-top:var(--sp-sm);text-align:center}

/* ─── CTA band ─── */
.cta-band{padding:var(--sp-3xl);background:var(--rust);border-radius:var(--radius-xl);
  color:var(--cream);text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 70% 60% at 20% 0%,rgba(250,247,242,.09),transparent)}
.cta-band h2{color:var(--cream);margin-bottom:var(--sp-sm)}
.cta-band p{color:rgba(250,247,242,.78);max-width:38rem;margin-inline:auto;margin-bottom:var(--sp-xl);font-size:var(--text-lg)}
.cta-band .btn-primary{background:var(--cream);color:var(--charcoal);box-shadow:none}
.cta-band .btn-primary:hover{background:var(--paper);color:var(--charcoal)}
.cta-band .btn-ghost{color:var(--cream);border-color:rgba(250,247,242,.4)}
.cta-band .btn-ghost:hover{background:rgba(250,247,242,.1);color:var(--cream);border-color:var(--cream)}
.cta-actions{display:flex;flex-wrap:wrap;gap:var(--sp-md);justify-content:center}

/* ─── Prose callout ─── */
.callout{border-left:3px solid var(--rust);padding:var(--sp-md) 0 var(--sp-md) var(--sp-lg);
  font-size:var(--text-lg);color:var(--charcoal);max-width:48rem}
.callout strong{font-weight:600}

/* ─── Footer ─── */
.site-footer{border-top:1px solid var(--border);padding:var(--sp-3xl) 0 var(--sp-xl);background:var(--limestone)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:var(--sp-xl)}
.footer-grid>*{min-width:0}
@media(max-width:48rem){.footer-grid{grid-template-columns:1fr 1fr}}
.footer-brand{font-family:var(--font-display);font-size:var(--text-xl);font-weight:700;
  margin-bottom:var(--sp-xs);color:var(--charcoal)}
.site-footer h4{font-family:var(--font-mono);font-size:var(--text-xs);text-transform:uppercase;
  letter-spacing:.12em;color:var(--charcoal);margin-bottom:var(--sp-md)}
.site-footer ul{list-style:none}
.site-footer li{margin-bottom:var(--sp-xs)}
.site-footer a{color:var(--charcoal-soft);font-size:var(--text-sm);overflow-wrap:anywhere}
.site-footer a:hover{color:var(--charcoal)}
.footer-bottom{margin-top:var(--sp-xl);padding-top:var(--sp-lg);border-top:1px solid var(--border);
  color:var(--charcoal-faint);font-size:var(--text-xs);display:flex;flex-wrap:wrap;gap:var(--sp-md);justify-content:space-between}

/* ─── Reveal ─── */
.reveal{opacity:0;transform:translateY(22px);
  transition:opacity var(--dur-reveal) var(--ease-out),transform var(--dur-reveal) var(--ease-out)}
.reveal.is-visible{opacity:1;transform:translateY(0)}
.reveal-d1{transition-delay:80ms}.reveal-d2{transition-delay:160ms}
.reveal-d3{transition-delay:240ms}.reveal-d4{transition-delay:320ms}

/* ─── Mobile nav ─── */
.nav-toggle{display:none;background:none;border:0;padding:.5rem .75rem;cursor:pointer;
  font-family:var(--font-mono);font-size:var(--text-xs);text-transform:uppercase;
  letter-spacing:.14em;color:var(--charcoal);font-weight:600;align-items:center;gap:.6rem}
.nav-toggle:hover{color:var(--rust)}
.nav-toggle-icon{position:relative;display:block;width:1.1rem;height:2px;background:currentColor}
.nav-toggle-icon::before,.nav-toggle-icon::after{content:'';position:absolute;left:0;width:1.1rem;height:2px;
  background:currentColor;transition:transform var(--dur-fast) var(--ease),top var(--dur-fast) var(--ease)}
.nav-toggle-icon::before{top:-.45rem}
.nav-toggle-icon::after{top:.45rem}
.nav-toggle[aria-expanded="true"] .nav-toggle-icon{background:transparent}
.nav-toggle[aria-expanded="true"] .nav-toggle-icon::before{top:0;transform:rotate(45deg)}
.nav-toggle[aria-expanded="true"] .nav-toggle-icon::after{top:0;transform:rotate(-45deg)}
@media(max-width:48rem){
  .nav-toggle{display:inline-flex}
  .primary-nav{display:block;position:absolute;top:100%;left:0;right:0;
    background:rgba(244,237,228,.98);backdrop-filter:saturate(150%) blur(14px);
    -webkit-backdrop-filter:saturate(150%) blur(14px);border-bottom:1px solid var(--border);
    max-height:0;overflow:hidden;transition:max-height var(--dur-normal) var(--ease)}
  .primary-nav[data-open="true"]{max-height:84vh}
  .primary-nav ul{flex-direction:column;align-items:stretch;gap:0;padding:var(--sp-md) var(--sp-lg)}
  .primary-nav li{width:100%;border-bottom:1px solid var(--border)}
  .primary-nav li:last-child{border-bottom:0;margin-top:var(--sp-md)}
  .primary-nav a{display:block;padding:var(--sp-md) 0;font-size:var(--text-base)}
  .primary-nav a.btn{text-align:center;padding:var(--sp-md);margin:0}
}

/* ─── Subscribe band ─── */
.subscribe-band{
  background:var(--paper-warm);
  border:1px solid var(--border);
  border-radius:var(--radius-xl);
  padding:var(--sp-2xl) var(--sp-xl);
  display:flex;flex-direction:column;align-items:center;
  text-align:center;gap:var(--sp-lg);
  box-shadow:var(--shadow-sm);
}
.subscribe-copy h3{margin:0 0 .25em;font-size:var(--text-xl);color:var(--charcoal);font-weight:600}
.subscribe-copy p{margin:0;color:var(--charcoal-soft);font-size:var(--text-base);max-width:36rem;margin-inline:auto}
.subscribe-form{
  display:flex;flex-wrap:wrap;gap:var(--sp-sm);justify-content:center;
  width:100%;max-width:34rem;
}
.subscribe-form input[type="email"]{
  flex:1 1 16rem;min-width:0;
  padding:.85rem 1rem;font-size:var(--text-base);font-family:inherit;
  color:var(--charcoal);background:var(--cream);
  border:1px solid var(--border-hi);border-radius:var(--radius-md);
  transition:border-color var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out);
}
.subscribe-form input[type="email"]::placeholder{color:var(--charcoal-faint)}
.subscribe-form input[type="email"]:focus{
  outline:none;border-color:var(--rust);
  box-shadow:0 0 0 3px var(--rust-soft);
}
.subscribe-form .btn{flex:0 0 auto;padding:.85rem 1.5rem}
.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;
}

/* ─── Utilities ─── */
.mt-xl{margin-top:var(--sp-xl)}
.mt-2xl{margin-top:var(--sp-2xl)}
.text-center{text-align:center}
.hero-art-tilt{transform:rotate(1.4deg);transition:transform var(--dur-slow) var(--ease-out)}
.hero-art-tilt:hover{transform:rotate(0)}
