/* ============================================================
   BARRETT'S OF CATERHAM — Home page mockup
   Barrett's own identity: gun-black / blued-steel / walnut / brass,
   engraving-plate serif, precise grotesque, proof-mark mono.
   Dark, atmospheric, reduced-motion safe.
   ============================================================ */

/* ---- Type: engraving-plate serif + precise grotesque + proof-mark mono ---- */
@import url('https://fonts.googleapis.com/css2?family=Cormorant:ital,wght@0,300;0,400;0,500;0,600;1,400;1,500&family=Schibsted+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');

:root{
  /* Brand palette (Barrett's own) — warm gun room, not a black void */
  --gun-black:    #1A1610;  /* warm deep charcoal-walnut base (lifted) */
  --gun-deep:     #120E09;  /* deepest shadow */
  --char:         #271F16;  /* warm charcoal-brown panel */
  --blued:        #283038;  /* cold blued steel, used sparingly */
  --blued-deep:   #1E242A;
  --walnut:       #43291A;
  --walnut-warm:  #6A4429;
  --walnut-lit:   #7C5230;  /* lit walnut for pools of light */
  --brass:        #B08D4F;
  --brass-bright: #D4B074;
  --bone:         #EDE6D6;
  --bone-dim:     rgba(237,230,214,0.62);
  --steel:        #8A9098;
  --proof-red:    #7E2A23;

  /* Fonts */
  --serif: 'Cormorant', Georgia, 'Times New Roman', serif;
  --sans:  'Schibsted Grotesk', system-ui, sans-serif;
  --mono:  'JetBrains Mono', ui-monospace, monospace;

  /* Easing (from studio system) */
  --expo:  cubic-bezier(0.16, 1, 0.3, 1);
  --quart: cubic-bezier(0.76, 0, 0.24, 1);

  --maxw: 1440px;
  --pad:  clamp(1.25rem, 5vw, 6rem);
  --hair: rgba(176,141,79,0.30); /* brass hairline / inlay line */
}

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }

html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }

body{
  background:var(--gun-black);
  background-image:
    radial-gradient(120% 80% at 50% -5%, rgba(124,82,48,0.22), transparent 55%),
    radial-gradient(100% 60% at 50% 100%, rgba(67,41,26,0.20), transparent 60%);
  background-attachment:fixed;
  color:var(--bone);
  font-family:var(--sans);
  font-size:1.0625rem;
  line-height:1.6;
  letter-spacing:-0.005em;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}

::selection{ background:var(--brass); color:var(--gun-black); }

a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; background:none; border:none; color:inherit; }
img{ display:block; max-width:100%; }

/* Brass focus ring — fine, like an inlay line */
:focus-visible{ outline:2px solid var(--brass-bright); outline-offset:3px; border-radius:1px; }

::-webkit-scrollbar{ width:9px; }
::-webkit-scrollbar-track{ background:var(--gun-black); }
::-webkit-scrollbar-thumb{ background:var(--char); border:2px solid var(--gun-black); }
::-webkit-scrollbar-thumb:hover{ background:var(--walnut); }

/* ============================================================
   ATMOSPHERE — grain, vignette, scroll progress
   ============================================================ */
.grain{
  position:fixed; inset:0; z-index:200; pointer-events:none;
  mix-blend-mode:overlay; opacity:0.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.82' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='220' height='220' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:220px;
  animation:grain .2s steps(6) infinite;
}
@keyframes grain{
  0%{background-position:0 0}
  20%{background-position:-24px 8px}
  40%{background-position:14px -18px}
  60%{background-position:-16px 22px}
  80%{background-position:22px -8px}
}

.vignette{
  position:fixed; inset:0; z-index:1; pointer-events:none;
  background:
    radial-gradient(120% 80% at 50% -10%, rgba(176,141,79,0.05), transparent 55%),
    radial-gradient(140% 120% at 50% 120%, rgba(32,38,43,0.45), transparent 60%),
    radial-gradient(100% 100% at 50% 50%, transparent 60%, rgba(0,0,0,0.55) 100%);
}

#progress{
  position:fixed; top:0; left:0; height:2px; width:0%;
  background:linear-gradient(90deg, var(--walnut-warm), var(--brass), var(--brass-bright));
  z-index:600; pointer-events:none; transition:width .1s linear;
}

/* Custom cursor — fine brass crosshair */
.cur-x, .cur-dot{ position:fixed; z-index:650; pointer-events:none; top:0; left:0; }
.cur-x{
  width:26px; height:26px; transform:translate(-50%,-50%);
  transition:width .3s var(--expo), height .3s var(--expo), opacity .3s;
  opacity:0;
}
.cur-x::before,.cur-x::after{
  content:''; position:absolute; background:rgba(212,176,116,0.7);
}
.cur-x::before{ left:50%; top:0; bottom:0; width:1px; transform:translateX(-50%); }
.cur-x::after{ top:50%; left:0; right:0; height:1px; transform:translateY(-50%); }
.cur-dot{
  width:5px; height:5px; border-radius:50%; background:var(--brass-bright);
  transform:translate(-50%,-50%); opacity:0;
  box-shadow:0 0 8px rgba(212,176,116,0.6);
}
.cur-x.hot{ width:46px; height:46px; }
body.cursor-on{ cursor:none; }
body.cursor-on a, body.cursor-on button, body.cursor-on input,
body.cursor-on select, body.cursor-on textarea{ cursor:none; }

/* ============================================================
   LAYOUT PRIMITIVES
   ============================================================ */
.wrap{ max-width:var(--maxw); margin:0 auto; padding-left:var(--pad); padding-right:var(--pad); }
section{ position:relative; }

.eyebrow{
  font-family:var(--mono); font-size:0.72rem; font-weight:500;
  letter-spacing:0.32em; text-transform:uppercase; color:var(--brass);
  display:inline-flex; align-items:center; gap:0.7em;
}
.eyebrow .idx{ color:var(--steel); }

/* Brass hairline — like an inlay line */
.rule{ height:1px; background:linear-gradient(90deg, transparent, var(--hair) 12%, var(--hair) 88%, transparent); border:0; }
.rule-solid{ height:1px; background:var(--hair); border:0; }

/* Hairline that draws in on reveal */
.rule-draw{ position:relative; height:1px; background:rgba(176,141,79,0.12); overflow:hidden; }
.rule-draw::after{
  content:''; position:absolute; inset:0; transform:scaleX(0); transform-origin:left;
  background:linear-gradient(90deg, var(--brass), var(--brass-bright));
  transition:transform 1.1s var(--expo);
}
.rule-draw.in::after{ transform:scaleX(1); }

h1,h2,h3,h4{ font-family:var(--serif); font-weight:500; line-height:1; letter-spacing:-0.01em; color:var(--bone); }

.display{
  font-family:var(--serif); font-weight:500;
  font-size:clamp(3rem, 7.4vw, 6.6rem); line-height:0.96;
  letter-spacing:-0.018em; color:var(--bone);
}
.h2{ font-size:clamp(2.1rem, 4.4vw, 3.6rem); line-height:1.1; }

.lead{ font-size:clamp(1.02rem, 1.35vw, 1.22rem); line-height:1.62; color:var(--bone-dim); font-weight:400; }
.mono{ font-family:var(--mono); letter-spacing:0.04em; }
.spec{ font-family:var(--mono); font-size:0.74rem; letter-spacing:0.12em; color:var(--steel); text-transform:uppercase; }

/* Ghosted editorial word behind product — kept subtle and traditional */
.ghost{
  position:absolute; font-family:var(--serif); font-weight:600;
  color:rgba(237,230,214,0.022); letter-spacing:-0.03em; line-height:0.8;
  pointer-events:none; user-select:none; white-space:nowrap; z-index:0;
}

/* Big editorial section numerals */
.bignum{
  font-family:var(--serif); font-weight:300; font-style:italic;
  font-size:clamp(2.4rem,5vw,4rem); color:var(--brass);
  line-height:0.8; opacity:0.85;
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex; align-items:center; gap:0.7em;
  font-family:var(--sans); font-size:0.82rem; font-weight:600;
  letter-spacing:0.12em; text-transform:uppercase;
  padding:1.05em 1.8em; position:relative; transition:all .4s var(--quart);
  border:1px solid transparent; white-space:nowrap;
}
.btn .arr{ transition:transform .4s var(--expo); }
.btn:hover .arr{ transform:translateX(4px); }

.btn-brass{
  background:linear-gradient(180deg, var(--brass-bright), var(--brass));
  color:var(--gun-black);
  box-shadow:0 1px 0 rgba(255,255,255,0.18) inset, 0 14px 30px -16px rgba(176,141,79,0.7);
}
.btn-brass:hover{ filter:brightness(1.08); box-shadow:0 1px 0 rgba(255,255,255,0.25) inset, 0 18px 40px -14px rgba(212,176,116,0.8); }

.btn-outline{ border:1px solid var(--hair); color:var(--bone); }
.btn-outline:hover{ border-color:var(--brass-bright); color:var(--brass-bright); background:rgba(176,141,79,0.06); }

/* Brass text link with drawing underline */
.tlink{
  display:inline-flex; align-items:center; gap:0.55em;
  font-family:var(--mono); font-size:0.78rem; letter-spacing:0.14em; text-transform:uppercase;
  color:var(--brass-bright); position:relative; padding-bottom:0.35em;
}
.tlink::after{
  content:''; position:absolute; left:0; bottom:0; height:1px; width:100%;
  background:var(--brass); transform:scaleX(0); transform-origin:left; transition:transform .5s var(--expo);
}
.tlink:hover::after{ transform:scaleX(1); }
.tlink .arr{ transition:transform .4s var(--expo); }
.tlink:hover .arr{ transform:translateX(4px); }

/* ============================================================
   PLATE — warm "pool of light" panel. ALWAYS renders rich and
   visible even with no photograph, so the page is never a black
   void. A real photo can layer on top; if it fails to load it
   falls back to this warm panel (never black).
   ============================================================ */
.plate{
  position:relative; overflow:hidden; isolation:isolate;
  background:
    radial-gradient(95% 75% at 50% 34%, rgba(176,141,79,0.20), transparent 60%),
    radial-gradient(120% 95% at 50% 40%, var(--walnut-lit) 0%, var(--walnut) 30%, #241710 58%, var(--gun-deep) 92%);
}
/* faint damascus / engraving-scroll texture */
.plate::before{
  content:''; position:absolute; inset:0; z-index:0; opacity:0.45; mix-blend-mode:soft-light; pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='400' height='400'%3E%3Cfilter id='d'%3E%3CfeTurbulence type='turbulence' baseFrequency='0.012 0.05' numOctaves='3' seed='7'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='400' height='400' filter='url(%23d)' opacity='0.55'/%3E%3C/svg%3E");
  background-size:cover;
}
/* warm vignette + soft top light, sits ABOVE any photo for legibility.
   Kept light so the photographs read clearly. */
.plate::after{
  content:''; position:absolute; inset:0; z-index:3; pointer-events:none;
  background:
    radial-gradient(78% 58% at 50% 30%, rgba(237,230,214,0.10), transparent 60%),
    radial-gradient(125% 125% at 50% 50%, transparent 64%, rgba(12,10,7,0.42) 100%);
}

/* Photographic placeholder. All imagery is placeholder, to be replaced
   with Barrett's own photography before launch. Fades in on load; on
   error it hides and the warm panel beneath shows through. */
.plate-photo{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:1;
  opacity:0; transition:opacity 1.1s var(--expo), transform 1.6s var(--expo);
  filter:saturate(1.05) contrast(0.99) brightness(1.22);
}
.plate-photo.loaded{ opacity:1; }
.plate-photo.failed{ display:none; }
/* Product mode: contained shot sitting in a pool of light on the warm
   panel (for catalogue/product photography on white or transparent),
   rather than a full-bleed atmospheric crop. */
.plate-photo.is-product{
  object-fit:contain; padding:7%;
  filter:saturate(1.03) contrast(1.0) brightness(1.14) drop-shadow(0 22px 44px rgba(0,0,0,0.5));
}
/* Drop a white/light studio background into the warm panel (works for both
   cover and contained product shots). */
.plate-photo.on-white{ mix-blend-mode:multiply; filter:saturate(1.05) contrast(1.05) brightness(1.12); }
.plate-photo.is-product.on-white{ filter:saturate(1.06) contrast(1.05) brightness(1.14) drop-shadow(0 18px 38px rgba(0,0,0,0.45)); }
.plate.has-product{
  background:
    radial-gradient(60% 52% at 50% 44%, rgba(214,176,116,0.30), transparent 72%),
    radial-gradient(120% 95% at 50% 42%, #3a2817 0%, #271c11 48%, #140f0a 92%);
}
.plate-photo.is-product ~ .plate-tint{ background:none; }
/* warm wash over photos to bind them to the gun-room palette (kept light) */
.plate-tint{
  position:absolute; inset:0; z-index:2; pointer-events:none;
  background:linear-gradient(180deg, rgba(58,36,23,0.04), transparent 46%, rgba(12,10,7,0.05) 100%);
  mix-blend-mode:multiply;
}
.plate-label{
  position:absolute; z-index:4; left:0; right:0; bottom:0;
  padding:1.4rem 1.5rem; display:flex; flex-direction:column; gap:0.3rem;
  background:linear-gradient(0deg, rgba(12,10,7,0.88), transparent);
}
.plate-name{ font-family:var(--serif); font-size:1.5rem; font-weight:500; color:var(--bone); line-height:1.05; text-shadow:0 2px 18px rgba(0,0,0,0.6); }
.plate-sub{ font-family:var(--mono); font-size:0.66rem; letter-spacing:0.2em; text-transform:uppercase; color:var(--brass-bright); }

/* engraved center caption for hero-grade plates */
.plate-center{
  position:absolute; z-index:4; inset:0; display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:0.6rem; text-align:center; padding:2rem;
  text-shadow:0 2px 22px rgba(0,0,0,0.7);
}
.plate-mark{
  font-family:var(--mono); font-size:0.64rem; letter-spacing:0.34em; text-transform:uppercase;
  color:var(--brass);
}

/* light-sweep on hover (light moving across blued steel) */
.sweep{ position:absolute; inset:0; z-index:4; pointer-events:none; overflow:hidden; }
.sweep::before{
  content:''; position:absolute; top:-30%; bottom:-30%; left:-60%; width:40%;
  background:linear-gradient(105deg, transparent, rgba(237,230,214,0.16), rgba(212,176,116,0.12), transparent);
  transform:skewX(-12deg) translateX(0); opacity:0;
}
.plate-zoom{
  position:absolute; inset:0; z-index:0; transition:transform 1.6s var(--expo);
  background:inherit;
}

/* ============================================================
   1 / UTILITY BAR
   ============================================================ */
.utility{
  background:var(--gun-black); position:relative; z-index:30;
  font-family:var(--mono); font-size:0.7rem; letter-spacing:0.1em;
  color:var(--steel); border-bottom:1px solid rgba(176,141,79,0.16);
}
.utility .wrap{ display:flex; align-items:center; justify-content:space-between; gap:1.5rem; height:38px; }
.utility .u-left{ text-transform:uppercase; letter-spacing:0.24em; color:var(--brass); white-space:nowrap; }
.utility .u-right{ display:flex; align-items:center; gap:1.6rem; white-space:nowrap; }
.utility a:hover{ color:var(--bone); }
.utility .u-note{ color:var(--steel); }
.utility .dot{ color:var(--walnut-warm); }
@media (max-width:880px){
  .utility .u-note{ display:none; }
  .utility .u-right{ gap:1rem; }
  .utility .u-left{ letter-spacing:0.14em; }
}
@media (max-width:560px){
  .utility .u-mail{ display:none; }
}

/* ============================================================
   2 / HEADER
   ============================================================ */
.header{
  position:sticky; top:0; z-index:100; transition:all .5s var(--expo);
  border-bottom:1px solid transparent;
}
.header.scrolled{
  background:rgba(18,16,11,0.86); backdrop-filter:blur(14px) saturate(120%);
  border-bottom:1px solid rgba(176,141,79,0.18);
}
.header .wrap{ display:flex; align-items:center; justify-content:space-between; gap:1.4rem; transition:height .5s var(--expo); height:88px; }
.header.scrolled .wrap{ height:68px; }

/* Wordmark — engraved shopfront banner */
.wordmark{ display:flex; flex-direction:column; line-height:1; gap:0.12rem; }
.wordmark .wm-main{
  font-family:var(--serif); font-weight:600; font-size:1.2rem; letter-spacing:0.05em;
  color:var(--bone); text-transform:uppercase; white-space:nowrap;
  transition:font-size .5s var(--expo);
  text-shadow:0 1px 0 rgba(0,0,0,0.6);
}
.header.scrolled .wordmark .wm-main{ font-size:1.08rem; }
.wordmark .wm-sub{
  font-family:var(--mono); font-size:0.54rem; letter-spacing:0.36em; text-transform:uppercase;
  color:var(--brass); padding-left:0.1em;
}

.nav{ display:flex; align-items:center; gap:1.25rem; }
.nav-links{ display:flex; align-items:center; gap:0.95rem; }
.nav-links a{
  font-size:0.75rem; font-weight:500; letter-spacing:0.015em; color:var(--bone-dim);
  position:relative; padding:0.4rem 0; transition:color .3s; white-space:nowrap;
}
.nav-links a::after{
  content:''; position:absolute; left:0; bottom:-2px; height:1px; width:100%;
  background:var(--brass-bright); transform:scaleX(0); transform-origin:left; transition:transform .4s var(--expo);
}
.nav-links a:hover{ color:var(--bone); }
.nav-links a:hover::after{ transform:scaleX(1); }
.nav-links a.nav-shop{ color:var(--brass-bright); font-weight:600; }
.nav-links a.nav-shop::after{ transform:scaleX(1); background:var(--brass); }

.nav-tools{ display:flex; align-items:center; gap:0.9rem; }
.icon-btn{ width:38px; height:38px; display:grid; place-items:center; color:var(--bone-dim); transition:color .3s; position:relative; }
.icon-btn:hover{ color:var(--brass-bright); }
.icon-btn svg{ width:18px; height:18px; }
.cart-count{
  position:absolute; top:2px; right:2px; min-width:15px; height:15px; padding:0 3px;
  background:var(--brass); color:var(--gun-black); font-family:var(--mono); font-size:0.56rem;
  border-radius:8px; display:grid; place-items:center; font-weight:500;
}
.nav-cta{ margin-left:0.2rem; }
.nav-cta.btn{ padding:0.72em 1.25em; font-size:0.74rem; }

.burger{ display:none; width:42px; height:42px; flex-direction:column; gap:5px; justify-content:center; align-items:flex-end; }
.burger span{ display:block; height:1.5px; background:var(--bone); transition:all .4s var(--expo); }
.burger span:nth-child(1){ width:24px; }
.burger span:nth-child(2){ width:18px; }
.burger span:nth-child(3){ width:24px; }
.burger.open span:nth-child(1){ transform:translateY(6.5px) rotate(45deg); width:24px; }
.burger.open span:nth-child(2){ opacity:0; }
.burger.open span:nth-child(3){ transform:translateY(-6.5px) rotate(-45deg); width:24px; }

@media (max-width:1280px){
  .nav-links{ display:none; }
  .burger{ display:flex; }
  .nav-cta{ display:none; }
}
@media (max-width:560px){
  .wordmark .wm-main{ font-size:1.12rem; }
  .header .wrap{ height:74px; }
}

/* Mobile slide-in menu */
.mobile-menu{
  position:fixed; inset:0; z-index:120; pointer-events:none; visibility:hidden;
}
.mobile-menu .mm-scrim{
  position:absolute; inset:0; background:rgba(6,6,5,0.6); backdrop-filter:blur(2px);
  opacity:0; transition:opacity .5s var(--expo);
}
.mobile-menu .mm-panel{
  position:absolute; top:0; right:0; bottom:0; width:min(86vw, 380px);
  background:linear-gradient(160deg, var(--char), var(--gun-black));
  border-left:1px solid rgba(176,141,79,0.22);
  transform:translateX(100%); transition:transform .55s var(--expo);
  display:flex; flex-direction:column; padding:1.6rem 1.6rem 2rem;
  box-shadow:-40px 0 80px -30px rgba(0,0,0,0.8);
}
.mobile-menu.open{ pointer-events:auto; visibility:visible; }
.mobile-menu.open .mm-scrim{ opacity:1; }
.mobile-menu.open .mm-panel{ transform:translateX(0); }
.mm-head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:1.6rem; }
.mm-close{ font-family:var(--mono); font-size:1.4rem; color:var(--bone-dim); width:40px; height:40px; }
.mm-links{ display:flex; flex-direction:column; }
.mm-links a{
  font-family:var(--serif); font-size:1.7rem; font-weight:500; color:var(--bone); padding:0.62rem 0;
  border-bottom:1px solid rgba(176,141,79,0.12); display:flex; align-items:baseline; gap:0.8rem;
}
.mm-links a .mm-i{ font-family:var(--mono); font-size:0.62rem; color:var(--brass); letter-spacing:0.1em; }
.mm-links a:hover{ color:var(--brass-bright); }
.mm-foot{ margin-top:auto; padding-top:1.6rem; }
.mm-foot .mono{ font-size:0.72rem; color:var(--steel); display:block; line-height:1.9; }
.mm-foot a:hover{ color:var(--brass-bright); }

/* ============================================================
   3 / HERO
   ============================================================ */
.hero{ position:relative; overflow:hidden; padding-top:clamp(2.5rem,6vh,5rem); padding-bottom:clamp(3rem,7vh,6rem); }
.hero-grid{ display:grid; grid-template-columns:1.02fr 1.1fr; gap:clamp(1.5rem,4vw,4rem); align-items:center; }
.hero-copy{ position:relative; z-index:5; max-width:620px; }
.hero-eyebrow{ margin-bottom:1.6rem; }
.hero h1{
  font-size:clamp(2.7rem, 6vw, 5.2rem); line-height:1.12; letter-spacing:-0.02em;
  margin-bottom:2.6rem;
}
.hero h1 em{ display:inline; }
.hero h1 em{ font-style:italic; color:var(--brass-bright); font-weight:400; }
.hero .lead{ max-width:46ch; margin-bottom:2.2rem; }
.hero-ctas{ display:flex; flex-wrap:wrap; gap:1rem; align-items:center; margin-bottom:2.2rem; }
.hero-detail{ display:flex; flex-wrap:wrap; align-items:center; gap:0.6rem 1.4rem; font-family:var(--mono); font-size:0.74rem; letter-spacing:0.08em; color:var(--steel); }
.hero-detail a{ color:var(--bone-dim); }
.hero-detail a:hover{ color:var(--brass-bright); }
.hero-detail .dot{ color:var(--walnut-warm); }

.hero-stage{ position:relative; min-height:clamp(340px, 52vh, 560px); z-index:2; }
.hero-plate{
  position:absolute; inset:0; border:1px solid rgba(176,141,79,0.16);
  box-shadow:0 60px 120px -50px rgba(0,0,0,0.9), 0 0 0 1px rgba(0,0,0,0.4);
}
.hero-ghost{ font-size:clamp(6rem, 11vw, 12rem); top:auto; bottom:5%; left:6%; transform:none; }
.hero-diag{
  position:absolute; z-index:3; left:6%; right:6%; top:50%; height:1px;
  background:linear-gradient(90deg, transparent, rgba(212,176,116,0.5), transparent);
  transform:rotate(-9deg);
}
.hero-stamp{
  position:absolute; z-index:6; right:6%; top:7%; bottom:auto;
  display:inline-flex; align-items:center; gap:0.6em;
  border:1px solid rgba(176,141,79,0.4); padding:0.55em 0.9em;
  font-family:var(--mono); font-size:0.62rem; letter-spacing:0.22em; text-transform:uppercase; color:var(--brass-bright);
  background:rgba(14,14,13,0.5); backdrop-filter:blur(4px);
}
.hero-stamp .pip{ width:5px; height:5px; border-radius:50%; background:var(--proof-red); box-shadow:0 0 8px rgba(126,42,35,0.9); }

@media (max-width:960px){
  .hero-grid{ grid-template-columns:1fr; gap:2.5rem; }
  .hero-stage{ min-height:48vh; order:2; }
  .hero-copy{ order:1; }
}

/* ============================================================
   WELCOME BAND — warm, human reassurance for a traditional customer
   ============================================================ */
.welcome{
  position:relative; padding:clamp(2.6rem,5vh,4.2rem) 0;
  background:linear-gradient(180deg, var(--gun-black), #2A1C10 50%, var(--gun-black));
  border-top:1px solid rgba(176,141,79,0.14); border-bottom:1px solid rgba(176,141,79,0.14);
}
.welcome .wrap{ display:flex; align-items:center; gap:clamp(1.4rem,3vw,3rem); }
.welcome-mark{
  flex:none; font-family:var(--serif); font-style:italic; font-weight:500;
  font-size:clamp(2.4rem,4vw,3.4rem); color:var(--brass); line-height:0.9;
}
.welcome-rule{ flex:none; width:1px; align-self:stretch; background:linear-gradient(180deg, transparent, var(--hair), transparent); }
.welcome-text{
  font-family:var(--serif); font-weight:400; font-size:clamp(1.3rem,2.1vw,1.95rem);
  line-height:1.4; color:var(--bone); max-width:40ch;
}
.welcome-text .brass{ color:var(--brass-bright); font-style:italic; }
@media (max-width:680px){
  .welcome .wrap{ flex-direction:column; align-items:flex-start; gap:1.2rem; text-align:left; }
  .welcome-rule{ display:none; }
}

/* ============================================================
   4 / KRIEGHOFF K-80 FEATURE
   ============================================================ */
.krieg{ padding:clamp(4rem,9vh,8rem) 0; background:linear-gradient(180deg, var(--gun-black), #2A1C10 55%, var(--gun-black)); }
.krieg-grid{ display:grid; grid-template-columns:1.25fr 1fr; gap:clamp(2rem,4vw,4.5rem); align-items:center; }
.krieg-stage{ position:relative; min-height:clamp(360px,56vh,620px); }
.krieg-plate{ position:absolute; inset:0; border:1px solid rgba(176,141,79,0.16); box-shadow:0 70px 130px -50px rgba(0,0,0,0.95); }
.krieg-ghost{ font-size:clamp(5rem,11vw,12rem); top:auto; bottom:6%; left:6%; transform:none; }
.krieg-copy{ position:relative; z-index:5; }
.krieg-copy .h2{ margin:1.4rem 0 1.6rem; }
.krieg-quote{
  font-family:var(--serif); font-style:italic; font-weight:400;
  font-size:clamp(1.5rem,2.6vw,2.2rem); line-height:1.25; color:var(--bone);
  margin-bottom:1.6rem; border-left:1px solid var(--brass); padding-left:1.4rem;
}
.krieg-quote span{ color:var(--brass-bright); }
.krieg-copy p{ color:var(--bone-dim); margin-bottom:1.8rem; max-width:48ch; }
.krieg-specs{ display:flex; flex-wrap:wrap; gap:1.6rem 2.4rem; margin-bottom:2rem; }
.krieg-specs .ks{ display:flex; flex-direction:column; gap:0.3rem; }
.krieg-specs .ks-n{ font-family:var(--serif); font-size:1.7rem; color:var(--bone); line-height:1; }
.krieg-specs .ks-l{ font-family:var(--mono); font-size:0.62rem; letter-spacing:0.18em; text-transform:uppercase; color:var(--steel); }
@media (max-width:960px){ .krieg-grid{ grid-template-columns:1fr; gap:2.5rem; } .krieg-stage{ min-height:46vh; } }

/* ============================================================
   5 / SHOP BY DISCIPLINE
   ============================================================ */
.disc{ padding:clamp(4rem,9vh,8rem) 0; }
.section-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:2rem; flex-wrap:wrap; margin-bottom:2.6rem; }
.section-head .sh-l{ max-width:680px; }
.section-head .sh-l .h2{ margin-top:1.1rem; }
.section-head .sh-l p{ color:var(--bone-dim); margin-top:1rem; max-width:52ch; }

.disc-grid{ display:grid; grid-template-columns:repeat(12,1fr); gap:clamp(0.8rem,1.4vw,1.3rem); }
.tile{ position:relative; overflow:hidden; border:1px solid rgba(176,141,79,0.14); display:block; }
.tile .plate-photo{ } /* zoom target */
.tile:hover .plate-photo{ transform:scale(1.06); }
.tile:hover .plate-zoom{ transform:scale(1.06); }
.tile:hover .sweep::before{ animation:sweep 1.1s var(--expo); }
@keyframes sweep{ 0%{ opacity:0; transform:skewX(-12deg) translateX(0); } 15%{opacity:1;} 100%{ opacity:0; transform:skewX(-12deg) translateX(560%); } }
.tile-inner{ position:relative; z-index:3; height:100%; display:flex; flex-direction:column; justify-content:flex-end; padding:1.4rem; }
.tile-idx{ position:absolute; top:1.1rem; left:1.3rem; font-family:var(--mono); font-size:0.66rem; letter-spacing:0.1em; color:var(--steel); z-index:3; }
.tile-name{ font-family:var(--serif); font-size:clamp(1.3rem,1.8vw,1.7rem); font-weight:500; color:var(--bone); line-height:1.04; }
.tile-sub{ font-family:var(--mono); font-size:0.62rem; letter-spacing:0.14em; text-transform:uppercase; color:var(--bone-dim); margin-top:0.45rem; }
.tile-underline{ height:1px; width:38px; background:var(--brass); margin-top:0.9rem; transition:width .55s var(--expo); }
.tile:hover .tile-underline{ width:80px; }

/* asymmetric spans */
.t-a{ grid-column:span 7; min-height:360px; }
.t-b{ grid-column:span 5; min-height:360px; }
.t-c{ grid-column:span 4; min-height:300px; }
.t-d{ grid-column:span 4; min-height:300px; }
.t-e{ grid-column:span 4; min-height:300px; }
.t-f{ grid-column:span 5; min-height:320px; }
.t-g{ grid-column:span 4; min-height:320px; }
.t-h{ grid-column:span 3; min-height:320px; }
@media (max-width:880px){
  .disc-grid{ grid-template-columns:repeat(6,1fr); }
  .t-a,.t-b{ grid-column:span 6; min-height:300px; }
  .t-c,.t-d,.t-e{ grid-column:span 3; min-height:240px; }
  .t-f{ grid-column:span 6; }
  .t-g,.t-h{ grid-column:span 3; }
}
@media (max-width:520px){
  .disc-grid{ grid-template-columns:1fr; }
  .tile{ min-height:220px !important; grid-column:span 1 !important; }
}

/* ============================================================
   6 / SERVICES / THE GUNSMITH
   ============================================================ */
.services{ padding:clamp(4rem,9vh,8rem) 0; background:linear-gradient(180deg, var(--gun-black), var(--char) 50%, var(--gun-black)); position:relative; }
.services::before{
  content:''; position:absolute; inset:0; z-index:0; opacity:0.06; pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='600' height='600'%3E%3Cfilter id='s'%3E%3CfeTurbulence type='turbulence' baseFrequency='0.008 0.04' numOctaves='3' seed='3'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='600' height='600' filter='url(%23s)'/%3E%3C/svg%3E");
  background-size:cover;
}
.services .wrap{ position:relative; z-index:2; }
.svc-list{ margin-top:2.4rem; border-top:1px solid rgba(176,141,79,0.16); }
.svc-row{
  display:grid; grid-template-columns:auto 1.2fr 2fr auto; gap:2rem; align-items:center;
  padding:2.1rem 0.6rem; border-bottom:1px solid rgba(176,141,79,0.14);
  transition:background .5s var(--quart), padding .5s var(--quart); position:relative;
}
.svc-row::before{
  content:''; position:absolute; left:0; top:0; bottom:0; width:2px; background:var(--brass); transform:scaleY(0); transform-origin:top; transition:transform .5s var(--expo);
}
.svc-row:hover{ background:linear-gradient(90deg, rgba(90,58,35,0.16), transparent 70%); padding-left:1.4rem; }
.svc-row:hover::before{ transform:scaleY(1); }
.svc-num{ font-family:var(--serif); font-style:italic; font-size:2rem; color:var(--brass); line-height:1; width:3rem; }
.svc-title{ font-family:var(--serif); font-size:clamp(1.5rem,2.2vw,2rem); font-weight:500; color:var(--bone); line-height:1.05; }
.svc-desc{ color:var(--bone-dim); font-size:0.98rem; max-width:48ch; }
.svc-go{ font-family:var(--mono); font-size:1.4rem; color:var(--steel); transition:color .4s, transform .4s var(--expo); }
.svc-row:hover .svc-go{ color:var(--brass-bright); transform:translateX(5px); }
.svc-cta{ margin-top:2.6rem; display:flex; align-items:center; gap:1.4rem; flex-wrap:wrap; }
@media (max-width:880px){
  .svc-row{ grid-template-columns:auto 1fr; gap:0.4rem 1.2rem; row-gap:0.6rem; padding:1.7rem 0.4rem; }
  .svc-desc{ grid-column:2; }
  .svc-go{ display:none; }
}

/* ============================================================
   7 / FEATURED PIECES
   ============================================================ */
.featured{ padding:clamp(4rem,9vh,8rem) 0; }
.lots{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(0.9rem,1.4vw,1.4rem); margin-top:2.6rem; }
.lot{ border:1px solid rgba(176,141,79,0.14); background:var(--char); display:flex; flex-direction:column; transition:border-color .5s var(--quart), transform .6s var(--expo); }
.lot:hover{ border-color:rgba(212,176,116,0.5); transform:translateY(-5px); }
.lot-plate{ position:relative; height:280px; overflow:hidden; }
.lot:hover .plate-photo{ transform:scale(1.05); }
.lot:hover .plate-zoom{ transform:scale(1.05); }
.lot:hover .sweep::before{ animation:sweep 1.1s var(--expo); }
.lot-lotno{ position:absolute; top:0.9rem; left:1rem; z-index:3; font-family:var(--mono); font-size:0.6rem; letter-spacing:0.18em; color:var(--brass); }
.lot-body{ padding:1.3rem 1.3rem 1.5rem; display:flex; flex-direction:column; gap:0.5rem; flex:1; }
.lot-cat{ font-family:var(--mono); font-size:0.6rem; letter-spacing:0.2em; text-transform:uppercase; color:var(--steel); }
.lot-name{ font-family:var(--serif); font-size:1.35rem; font-weight:500; color:var(--bone); line-height:1.1; }
.lot-meta{ font-size:0.84rem; color:var(--bone-dim); line-height:1.5; }
.lot-foot{ margin-top:auto; padding-top:1rem; display:flex; align-items:center; justify-content:space-between; border-top:1px solid rgba(176,141,79,0.12); }
.lot-price{ font-family:var(--mono); font-size:0.74rem; letter-spacing:0.08em; color:var(--brass-bright); text-transform:uppercase; }
.lot-enq{ font-family:var(--mono); font-size:0.66rem; letter-spacing:0.12em; text-transform:uppercase; color:var(--bone-dim); display:inline-flex; align-items:center; gap:0.4em; }
.lot:hover .lot-enq{ color:var(--brass-bright); }
@media (max-width:980px){ .lots{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:480px){ .lots{ grid-template-columns:1fr; } }

/* ============================================================
   8 / BRANDS / ACCREDITATIONS
   ============================================================ */
.brands{ padding:clamp(3rem,6vh,5rem) 0; border-top:1px solid rgba(176,141,79,0.14); border-bottom:1px solid rgba(176,141,79,0.14); background:linear-gradient(180deg, var(--gun-black), #241810 50%, var(--gun-black)); }
.marquee{ position:relative; overflow:hidden; -webkit-mask-image:linear-gradient(90deg, transparent, #000 9%, #000 91%, transparent); mask-image:linear-gradient(90deg, transparent, #000 9%, #000 91%, transparent); }
.mq-track{ display:inline-flex; gap:3.2rem; white-space:nowrap; animation:mqmove 46s linear infinite; will-change:transform; }
.marquee:hover .mq-track{ animation-play-state:paused; }
@keyframes mqmove{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }
.mq-item{ font-family:var(--serif); font-size:clamp(1.6rem,2.4vw,2.3rem); font-weight:500; color:var(--bone-dim); letter-spacing:0.02em; transition:color .3s; }
.mq-item:hover{ color:var(--brass-bright); }
.mq-sep{ color:var(--walnut-warm); font-size:1.2rem; align-self:center; }
.accred{ margin-top:2.6rem; text-align:center; }
.accred .spec{ display:inline; color:var(--steel); font-size:0.72rem; line-height:2.2; }
.accred .spec b{ color:var(--brass); font-weight:500; }

/* ============================================================
   9 / VISIT / FIND US
   ============================================================ */
.visit{ padding:clamp(4rem,9vh,8rem) 0; background:linear-gradient(180deg, var(--gun-black), #241810); }
.visit-grid{ display:grid; grid-template-columns:0.92fr 1.08fr; gap:clamp(2rem,4vw,4rem); align-items:start; }
.visit-media{ display:flex; flex-direction:column; gap:1.3rem; }
.visit-shop{ position:relative; margin:0; border-radius:6px; overflow:hidden; min-height:clamp(220px,30vh,320px); border:1px solid rgba(176,141,79,0.34); box-shadow:0 30px 70px -34px rgba(0,0,0,0.85); background:linear-gradient(150deg, var(--walnut-lit), var(--walnut) 38%, #241710 80%, var(--gun-deep)); }
.visit-shop::before{ content:''; position:absolute; inset:0; opacity:0.5; mix-blend-mode:soft-light; pointer-events:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='400' height='400'%3E%3Cfilter id='v'%3E%3CfeTurbulence type='turbulence' baseFrequency='0.012 0.05' numOctaves='3' seed='9'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='400' height='400' filter='url(%23v)' opacity='0.5'/%3E%3C/svg%3E"); background-size:cover; }
.visit-shop img{ display:block; position:relative; z-index:1; width:100%; height:clamp(220px,30vh,320px); object-fit:cover; filter:sepia(0.30) saturate(0.78) hue-rotate(-8deg) contrast(1.04) brightness(1.02); }
.visit-shop img.failed{ display:none; }
/* warm wash + edge vignette so the blue facia melts into the warm dark page */
.visit-shop::after{ content:''; position:absolute; inset:0; z-index:2; pointer-events:none; box-shadow:inset 0 0 0 1px rgba(255,255,255,0.04), inset 0 0 60px rgba(20,15,9,0.5); background:linear-gradient(0deg, rgba(18,14,9,0.62), transparent 46%), radial-gradient(120% 95% at 50% 34%, rgba(176,141,79,0.12), transparent 62%), linear-gradient(0deg, rgba(74,48,28,0.22), rgba(74,48,28,0.22)); }
.visit-shop figcaption{ position:absolute; left:0; right:0; bottom:0; z-index:3; padding:1rem 1.2rem; font-family:var(--mono); font-size:0.64rem; letter-spacing:0.14em; text-transform:uppercase; color:var(--bone); }
.visit-shop .vs-mark{ color:var(--brass-bright); margin-right:0.5em; }
.visit-copy .h2{ margin:1.2rem 0 1.6rem; }
.visit-invite{ font-family:var(--serif); font-style:italic; font-size:clamp(1.4rem,2.2vw,1.9rem); color:var(--bone); line-height:1.25; margin-bottom:2rem; max-width:20ch; }
.visit-rows{ display:flex; flex-direction:column; gap:1.4rem; }
.visit-row{ display:grid; grid-template-columns:130px 1fr; gap:1.2rem; padding-bottom:1.4rem; border-bottom:1px solid rgba(176,141,79,0.12); }
.visit-row .vr-l{ font-family:var(--mono); font-size:0.64rem; letter-spacing:0.18em; text-transform:uppercase; color:var(--brass); padding-top:0.25rem; }
.visit-row .vr-r{ color:var(--bone); font-size:0.98rem; line-height:1.6; }
.visit-row .vr-r a:hover{ color:var(--brass-bright); }
.visit-map{ position:relative; border-radius:6px; border:1px solid rgba(176,141,79,0.2); overflow:hidden; min-height:340px; box-shadow:0 30px 70px -38px rgba(0,0,0,0.85); }
.visit-map iframe{ width:100%; height:100%; min-height:340px; border:0; filter:grayscale(1) invert(0.92) contrast(0.92) sepia(0.18) brightness(0.9); }
.visit-map .map-frame{ position:absolute; inset:0; pointer-events:none; box-shadow:inset 0 0 0 1px rgba(176,141,79,0.18), inset 0 0 90px rgba(0,0,0,0.7); }
.visit-map .map-stamp{ position:absolute; top:1rem; left:1rem; z-index:3; font-family:var(--mono); font-size:0.6rem; letter-spacing:0.2em; text-transform:uppercase; color:var(--brass-bright); background:rgba(14,14,13,0.7); padding:0.5em 0.8em; border:1px solid rgba(176,141,79,0.3); }
@media (max-width:880px){ .visit-grid{ grid-template-columns:1fr; } .visit-map{ min-height:300px; } .visit-map iframe{ min-height:300px; } }

/* ============================================================
   10 / CONTACT / ENQUIRY
   ============================================================ */
.contact{ padding:clamp(4rem,9vh,8rem) 0; }
.contact-grid{ display:grid; grid-template-columns:0.9fr 1.1fr; gap:clamp(2rem,5vw,5rem); }
.contact-copy .h2{ margin:1.2rem 0 1.4rem; }
.contact-copy p{ color:var(--bone-dim); max-width:40ch; margin-bottom:1.8rem; }
.contact-copy .c-phones{ display:flex; flex-direction:column; gap:0.7rem; }
.contact-copy .c-phones a{ font-family:var(--serif); font-size:1.6rem; color:var(--bone); }
.contact-copy .c-phones a:hover{ color:var(--brass-bright); }
.contact-copy .c-phones span{ font-family:var(--mono); font-size:0.62rem; letter-spacing:0.16em; text-transform:uppercase; color:var(--steel); display:block; }

.form{ display:grid; grid-template-columns:1fr 1fr; gap:1.4rem 1.3rem; }
.field{ display:flex; flex-direction:column; gap:0.55rem; }
.field.full{ grid-column:1 / -1; }
.field label{ font-family:var(--mono); font-size:0.64rem; letter-spacing:0.16em; text-transform:uppercase; color:var(--brass); }
.field label .req{ color:var(--proof-red); }
.field input, .field select, .field textarea{
  font-family:var(--sans); font-size:0.98rem; color:var(--bone); background:rgba(26,25,23,0.6);
  border:1px solid rgba(176,141,79,0.2); padding:0.95em 1em; transition:border-color .35s, background .35s; width:100%;
}
.field textarea{ resize:vertical; min-height:130px; line-height:1.55; }
.field select{ appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23B08D4F' stroke-width='1.3' fill='none'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 1em center; padding-right:2.4em; }
.field input::placeholder, .field textarea::placeholder{ color:var(--steel); opacity:0.7; }
.field input:focus, .field select:focus, .field textarea:focus{ outline:none; border-color:var(--brass-bright); background:rgba(26,25,23,0.9); }
.field.err input, .field.err select, .field.err textarea{ border-color:var(--proof-red); }
.field .err-msg{ font-family:var(--mono); font-size:0.6rem; letter-spacing:0.1em; color:var(--proof-red); text-transform:uppercase; min-height:0.8rem; opacity:0; transition:opacity .3s; }
.field.err .err-msg{ opacity:1; }
.form-foot{ grid-column:1 / -1; display:flex; align-items:center; justify-content:space-between; gap:1.5rem; flex-wrap:wrap; margin-top:0.4rem; }
.form-note{ font-family:var(--mono); font-size:0.62rem; letter-spacing:0.08em; color:var(--steel); max-width:32ch; line-height:1.7; }
.form-success{
  grid-column:1 / -1; border:1px solid rgba(176,141,79,0.4); background:rgba(90,58,35,0.14);
  padding:1.2rem 1.4rem; display:none; align-items:center; gap:1rem;
  font-family:var(--mono); font-size:0.74rem; letter-spacing:0.06em; color:var(--brass-bright);
}
.form-success.show{ display:flex; }
.form-success .pip{ width:7px; height:7px; border-radius:50%; background:var(--brass); }
@media (max-width:880px){ .contact-grid{ grid-template-columns:1fr; } }
@media (max-width:520px){ .form{ grid-template-columns:1fr; } }

/* ============================================================
   11 / FOOTER
   ============================================================ */
.footer{ background:linear-gradient(180deg, var(--gun-black), #221710); border-top:1px solid rgba(176,141,79,0.22); padding:clamp(3.5rem,7vh,6rem) 0 2.5rem; }
.footer-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:2.5rem; padding-bottom:3rem; border-bottom:1px solid rgba(176,141,79,0.14); }
.f-brand .wordmark{ margin-bottom:1.3rem; }
.f-brand p{ color:var(--bone-dim); font-size:0.9rem; max-width:34ch; }
.f-col h4{ font-family:var(--mono); font-size:0.62rem; font-weight:500; letter-spacing:0.2em; text-transform:uppercase; color:var(--brass); margin-bottom:1.2rem; }
.f-col a{ display:block; font-size:0.9rem; color:var(--bone-dim); padding:0.4rem 0; transition:color .3s; }
.f-col a:hover{ color:var(--brass-bright); }
.f-col a .ext{ font-size:0.7rem; color:var(--steel); margin-left:0.3em; }
.footer-legal{ padding-top:2.2rem; display:flex; flex-direction:column; gap:1.1rem; }
.legal-line{ font-family:var(--mono); font-size:0.62rem; letter-spacing:0.04em; line-height:1.9; color:var(--steel); max-width:90ch; }
.legal-compliance{ color:var(--bone-dim); border-left:2px solid var(--proof-red); padding-left:1rem; }
.footer-base{ display:flex; align-items:center; justify-content:space-between; gap:1rem; flex-wrap:wrap; margin-top:1.4rem; }
.footer-base .spec{ font-size:0.62rem; }
@media (max-width:880px){ .footer-top{ grid-template-columns:1fr 1fr; gap:2rem; } .f-brand{ grid-column:1 / -1; } }
@media (max-width:480px){ .footer-top{ grid-template-columns:1fr; } }

/* ============================================================
   REVEAL ANIMATIONS (gated, reduced-motion safe)
   ============================================================ */
/* Base state is VISIBLE. Hiding only applies once JS adds .reveal to <html>,
   so if JS fails (or motion is paused) every section still renders in full. */
.rev{ transition:opacity .85s var(--expo), transform .85s var(--expo); }
.reveal .rev{ opacity:0; transform:translateY(26px); }
.reveal .rev.in{ opacity:1; transform:none; }
.rev-d1{ transition-delay:.08s; } .rev-d2{ transition-delay:.16s; } .rev-d3{ transition-delay:.24s; }
.rev-d4{ transition-delay:.32s; } .rev-d5{ transition-delay:.40s; }

/* Hero page-load sequence — ANIMATION based (runs on the document
   timeline, so it completes even in a background tab, unlike transitions).
   Base state is visible; only the .reveal flag (added by JS) arms the
   entrance. If JS never runs, the hero shows immediately. */
.reveal .hero-anim .ha{ animation:haIn 1s var(--expo) both; }
.reveal .hero-anim .ha1{ animation-delay:.12s; }
.reveal .hero-anim .ha2{ animation-delay:.26s; }
.reveal .hero-anim .ha3{ animation-delay:.40s; }
.reveal .hero-anim .ha4{ animation-delay:.54s; }
.reveal .hero-anim .ha5{ animation-delay:.68s; }
.reveal .hero-anim .ha-stage{ animation:haStage 1.3s var(--expo) .2s both; }
@keyframes haIn{ from{ opacity:0; transform:translateY(20px); } to{ opacity:1; transform:none; } }
@keyframes haStage{ from{ opacity:0; transform:scale(1.03); } to{ opacity:1; transform:none; } }
/* engraver's underline draws */
.hero-underline{ position:relative; display:inline-block; }
.hero-underline::after{
  content:''; position:absolute; left:0; bottom:-0.12em; height:2px; width:100%;
  background:linear-gradient(90deg, var(--brass), var(--brass-bright));
  transform:scaleX(1); transform-origin:left;
}
.reveal .hero-anim .hero-underline::after{ animation:drawLine 1.1s var(--expo) 1s both; }
@keyframes drawLine{ from{ transform:scaleX(0); } to{ transform:scaleX(1); } }

@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  *,*::before,*::after{ animation-duration:.001ms !important; animation-delay:0ms !important; transition-duration:.001ms !important; }
  .grain{ animation:none; }
  .reveal .rev{ opacity:1; transform:none; }
  .reveal .hero-anim .ha, .reveal .hero-anim .ha-stage{ opacity:1; transform:none; }
  .reveal .hero-anim .hero-underline::after{ transform:scaleX(1); }
  .rule-draw::after{ transform:scaleX(1); }
  .mq-track{ animation:none; }
  .cur-x,.cur-dot{ display:none !important; }
}
