/* =============================================================================
   BLEACH GOODS — Site v3 (polished)
   References pulled from: Found.store, Off-White, Heron Preston, Fear of God,
   Aimé Leon Dore. Quiet luxury + drop-culture mono codes.
   ============================================================================= */

*,*::before,*::after{box-sizing:border-box}
:root{
  --cream:#F4EFE6;
  --cream-2:#EAE2D2;
  --cream-3:#E6DFCE;
  --ink:#0d0d0d;
  --ink-soft:#202020;
  --stone:#5a5448;
  --stone-2:#8a8475;
  --bleach:#E12127;
  --bleach-d:#A7141A;
  --teal:#6F9DAA;
  --max:1320px;
  --gutter:clamp(20px,4vw,72px);
  --t-fast:.28s;
  --t:.6s cubic-bezier(.19,.7,.24,1);
  --t-slow:1.4s cubic-bezier(.19,.7,.24,1);

  --display:'Fraunces',Georgia,serif;
  --sans:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,Menlo,monospace;
}

html{
  -webkit-text-size-adjust:100%;
  scroll-behavior:smooth;
  scroll-padding-top:120px;       /* leave room for fixed bar+header when jumping to anchors */
  background:var(--cream);
  width:100vw;max-width:100vw;     /* prevent any horizontal overflow */
  overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
  box-sizing:border-box;
}
*,*::before,*::after{box-sizing:border-box;max-width:100%}
img,video,iframe{max-width:100%;height:auto}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
}
@media (max-width:780px){
  html{scroll-padding-top:90px}    /* mobile header is shorter (~76px), shorter scroll-padding */
}
body{
  margin:0;
  font-family:var(--sans);
  font-weight:400;font-size:16px;line-height:1.55;
  color:var(--ink);background:var(--cream);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  width:100%;max-width:100%;
  overflow-x:hidden;
  position:relative;
  -webkit-overflow-scrolling:touch;     /* smooth iOS momentum scroll */
  overscroll-behavior-y:auto;
  touch-action:pan-y;                    /* allow vertical pan/scroll on touch */
}
/* Only lock scroll when modal/menu is open AND we're on a small viewport */
@media (max-width:980px){
  body.menu-open{overflow:hidden;position:fixed;width:100%;top:0}
}
@media (min-width:981px){
  body.menu-open{overflow:auto}  /* desktop: never lock */
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color var(--t-fast)}
a:hover{color:var(--bleach)}
ul{list-style:none;margin:0;padding:0}
button{font:inherit;cursor:pointer;background:none;border:0;color:inherit}

/* Subtle paper grain — premium tactile feel */
body::before{
  content:"";position:fixed;inset:-50%;pointer-events:none;z-index:1;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='1'/></svg>");
  opacity:.05;mix-blend-mode:multiply;
}

/* Custom cursor disabled — was causing mouse lag from mix-blend-mode and per-element listeners.
   Native cursor is now used; element-specific cursors come from default browser styles. */
.cursor{display:none!important}

/* Selection */
::selection{background:var(--bleach);color:var(--cream)}

/* ================================ ACCESSIBILITY ============================
   Skip link, focus rings, screen-reader helper. WCAG 2.1 AA. */

.skip-link{
  position:absolute;left:-9999px;top:0;z-index:10000;
  background:var(--bleach);color:var(--cream);
  padding:14px 22px;border-radius:0 0 8px 0;
  font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;
}
.skip-link:focus{left:0}

/* Visually hidden but available to screen readers */
.visually-hidden{
  position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}

/* Visible focus ring — 2px bleach red outline */
*:focus-visible{
  outline:2px solid var(--bleach);
  outline-offset:3px;
  border-radius:4px;
}
.btn:focus-visible,
.lang-btn:focus-visible,
.event-cta:focus-visible{
  outline-offset:4px;
}
/* Suppress focus ring on mouse-only clicks */
:focus:not(:focus-visible){outline:none}

/* Card overlay — show "VIEW" on focus too, not just hover */
.card:focus-within .card-img::after{opacity:1}

/* Bigger touch target for language pill */
.lang-btn{min-height:44px}
@media (max-width:980px){.lang-btn{display:none}}

/* ================================ TYPOGRAPHY ================================ */
.kicker{
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--stone);margin:0 0 18px;
}
.section-h{
  font-family:var(--display);font-weight:300;font-style:normal;
  font-size:clamp(40px,5.6vw,84px);line-height:.96;letter-spacing:-.025em;
  margin:0 0 16px;
  font-variation-settings:"opsz" 100,"SOFT" 30;
}
.section-h em{font-style:italic;font-weight:300;color:var(--bleach)}
.lead{font-size:clamp(16px,1.4vw,19px);line-height:1.6;color:var(--ink-soft);margin:0 0 18px}

/* ================================== LOADER ================================== */
.loader{
  position:fixed;inset:0;background:var(--ink);z-index:1000;
  display:grid;place-items:center;
  transition:opacity .9s ease,visibility .9s;
}
.loader-logo{
  width:240px;max-width:54vw;
  filter:drop-shadow(0 0 24px rgba(225,33,39,.4));
  animation:logoBreath 1.6s ease-in-out infinite alternate;
}
@keyframes logoBreath{from{transform:scale(.97);opacity:.92}to{transform:scale(1.01);opacity:1}}
.loader.out{opacity:0;visibility:hidden}

/* ============================= ANNOUNCEMENT BAR ============================= */
.bar{
  background:var(--ink);color:var(--cream);
  overflow:hidden;border-bottom:1px solid #000;
  position:fixed;top:0;left:0;right:0;z-index:50;
}
.bar-track{
  display:flex;align-items:center;gap:36px;white-space:nowrap;padding:11px 0;
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  animation:marquee 60s linear infinite;width:max-content;
}
.bar-track .dot{width:6px;height:6px;border-radius:50%;background:var(--bleach);flex:none}
.mono-mark{
  width:18px;height:18px;flex:none;
  filter:brightness(0) invert(1) drop-shadow(0 0 4px rgba(225,33,39,.35));
  opacity:.85;
}
.mono-mark-dark{
  filter:brightness(0) saturate(100%) invert(20%) sepia(80%) saturate(2400%) hue-rotate(346deg) brightness(95%) contrast(95%);
  opacity:.85;
}
.bar:hover .bar-track{animation-play-state:paused}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.bar-track{animation:none}}

/* ================================== HEADER ================================== */
/* Header is fixed and transparent over the dark hero. Cream blur backdrop appears
   only after scrolling past the hero (.is-scrolled toggled by JS). */
.site-header{
  /* Always transparent. Sits below the fixed announcement bar (38px). */
  position:fixed;top:38px;left:0;right:0;z-index:40;
  background:transparent;
  border-bottom:1px solid transparent;
}
/* Nav text — solid ink with strong text-shadow halo. Works over any background.
   Per-section overrides flip text to cream over confirmed dark sections (hero, editorial, rewards). */
.site-header .nav-link,
.site-header .lang-btn{
  color:var(--ink);
  text-shadow:
     0 0 8px rgba(244,239,230,.85),
     0 0 4px rgba(244,239,230,.85),
     0 1px 2px rgba(244,239,230,.7);
}
.site-header .nav-link:hover,
.site-header .lang-btn:hover{color:var(--bleach)}
.site-header .nav-burger span{background:var(--ink);box-shadow:0 0 6px rgba(244,239,230,.7)}
/* Over the dark hero / editorial / rewards-dark sections, flip to cream */
body[data-section="hero"]      .site-header .nav-link,
body[data-section="editorial"] .site-header .nav-link,
body[data-section="rewards"]   .site-header .nav-link,
body[data-section="hero"]      .site-header .lang-btn,
body[data-section="editorial"] .site-header .lang-btn,
body[data-section="rewards"]   .site-header .lang-btn{
  color:var(--cream);
  text-shadow:0 1px 4px rgba(13,13,13,.7), 0 0 12px rgba(13,13,13,.5);
}
body[data-section="hero"]      .site-header .nav-burger span,
body[data-section="editorial"] .site-header .nav-burger span,
body[data-section="rewards"]   .site-header .nav-burger span{background:var(--cream);box-shadow:0 0 6px rgba(13,13,13,.5)}
.site-header .cart-btn{color:var(--ink);text-shadow:0 0 6px rgba(244,239,230,.85)}
body[data-section="hero"]      .site-header .cart-btn,
body[data-section="editorial"] .site-header .cart-btn,
body[data-section="rewards"]   .site-header .cart-btn{color:var(--cream);text-shadow:0 1px 4px rgba(13,13,13,.7)}
.nav{
  display:grid;
  /* 3 left links, 1fr spacer (logo), 3 right links, account, cart, lang, burger = 11 tracks */
  grid-template-columns:auto auto auto 1fr auto auto auto auto auto auto auto;
  align-items:center;gap:clamp(5px,.85vw,14px);
  padding:2px var(--gutter);
  max-width:var(--max);margin:0 auto;
}
/* Account link in header — same vibe as nav-link with subtle account hint */
.auth-link{
  font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  padding:6px 10px;border:1px solid rgba(13,13,13,.18);border-radius:999px;
  color:var(--ink);transition:all var(--t-fast);
  text-shadow:0 0 6px rgba(244,239,230,.85);
}
.auth-link:hover{border-color:var(--bleach);color:var(--bleach)}
body[data-section="hero"]      .auth-link,
body[data-section="editorial"] .auth-link,
body[data-section="rewards"]   .auth-link{
  color:var(--cream);border-color:rgba(244,239,230,.4);
  text-shadow:0 1px 4px rgba(13,13,13,.7);
}
@media (max-width:980px){.auth-link{display:none}}
.nav-link{
  font-family:var(--mono);font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  position:relative;padding:8px 0;color:var(--ink);
}
.nav-link::after{
  content:"";position:absolute;left:0;right:0;bottom:2px;height:1px;
  background:var(--bleach);transform:scaleX(0);transform-origin:left;
  transition:transform var(--t);
}
.nav-link:hover{color:var(--bleach)}
.nav-link:hover::after{transform:scaleX(1)}

.logo{
  grid-column:4;justify-self:center;display:block;
  width:clamp(96px,10vw,136px);
  transition:transform var(--t),filter .6s var(--t);
}
.logo img{display:block;width:100%;transition:filter .6s ease}
.logo:hover{transform:scale(1.04)}

/* Logo color cycling per active section.
   The IntersectionObserver in JS sets data-section on <body>; CSS hue-rotates the logo. */
body[data-section="hero"]      .logo img{filter:brightness(0) invert(1)}             /* white over dark photo */
body[data-section="capsule"]   .logo img{filter:none}                                  /* native red */
body[data-section="shop"]      .logo img{filter:hue-rotate(150deg) saturate(1.3)}     /* teal/blue */
body[data-section="archive"]   .logo img{filter:hue-rotate(45deg) saturate(1.4)}      /* orange */
body[data-section="editorial"] .logo img{filter:brightness(0) invert(1)}              /* white over dark */
body[data-section="materials"] .logo img{filter:hue-rotate(270deg) saturate(1.2)}     /* purple */
body[data-section="rewards"]   .logo img{filter:brightness(0) invert(1)}              /* white over dark */
body[data-section="events"]    .logo img{filter:brightness(0)}                        /* black */
body[data-section="newsletter"].logo img{filter:hue-rotate(90deg) saturate(1.3)}      /* green */
body[data-section="about"]     .logo img{filter:hue-rotate(330deg) saturate(1.4)}     /* magenta */

/* Language switcher */
.lang-wrap{position:relative;justify-self:end}
.lang-btn{
  display:inline-flex;align-items:center;gap:4px;
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink);padding:6px 10px;border:1px solid rgba(13,13,13,.18);border-radius:999px;
  transition:all var(--t-fast);
}
.lang-btn:hover{border-color:var(--bleach);color:var(--bleach)}
.lang-arrow{font-size:10px;transition:transform var(--t-fast)}
.lang-btn[aria-expanded="true"] .lang-arrow{transform:rotate(180deg)}
.lang-pop{
  position:absolute;top:calc(100% + 8px);right:0;
  background:var(--cream);border:1px solid rgba(13,13,13,.12);border-radius:10px;
  padding:8px 10px;min-width:200px;
  box-shadow:0 18px 40px -18px rgba(13,13,13,.18);
  z-index:50;
}
.lang-pop[hidden]{display:none}
/* Tame Google Translate's default styling */
.goog-te-gadget{font-family:var(--mono)!important;font-size:11px!important;color:var(--ink)!important}
.goog-te-gadget .goog-te-combo{
  font-family:var(--mono)!important;font-size:11px!important;
  padding:6px 10px!important;border-radius:6px!important;border:1px solid rgba(13,13,13,.15)!important;
  background:#fff!important;color:var(--ink)!important;width:100%!important;
}
.goog-te-gadget img{display:none!important}
.goog-te-gadget span{display:none!important}
/* Hide Google's banner that pushes the page down */
.skiptranslate iframe.goog-te-banner-frame{display:none!important}
body{top:0!important}
@media (max-width:980px){.lang-wrap{display:none}}

.nav-burger{display:none;width:36px;height:36px;flex-direction:column;justify-content:center;gap:5px}
.nav-burger span{display:block;width:22px;height:2px;background:var(--ink);transition:transform var(--t-fast),opacity var(--t-fast)}
.nav-burger[aria-expanded="true"] span:nth-child(1){transform:translateY(3px) rotate(45deg)}
.nav-burger[aria-expanded="true"] span:nth-child(2){transform:translateY(-4px) rotate(-45deg)}

/* Mobile menu — hidden by default at every viewport */
.mobile-menu{display:none}
.mobile-menu[hidden]{display:none!important}
/* Only show on small viewports when the burger has opened it (i.e. [hidden] removed) */
@media (max-width:980px){
  .mobile-menu:not([hidden]){
    position:fixed;
    top:0;right:0;bottom:0;left:0;
    width:100%;height:100%;
    background-color:var(--cream);
    background-image:
      radial-gradient(ellipse 60% 80% at 100% 0%,rgba(225,33,39,.06),transparent 60%),
      linear-gradient(180deg,var(--cream),var(--cream-2));
    display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:0;
    padding:calc(60px + 32px) var(--gutter) calc(32px + env(safe-area-inset-bottom));
    z-index:9000;
    overflow-y:auto;
    isolation:isolate;
    animation:menuSlide .35s cubic-bezier(.19,.7,.24,1) both;
  }
}
@keyframes menuSlide{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:none}}
.mobile-menu a{
  font-family:var(--display);font-size:clamp(26px,6.5vw,38px);font-weight:300;
  letter-spacing:-.015em;color:var(--ink);
  border-bottom:1px solid rgba(13,13,13,.1);width:100%;padding:16px 0;
  display:block;min-height:52px;     /* 52px touch target — comfortable thumb tap */
  text-decoration:none;
}
.mobile-menu a:hover{color:var(--bleach)}
.mobile-menu-foot{
  margin-top:auto;padding-top:24px;
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;
  color:var(--stone);text-transform:uppercase;
}

@media (max-width:980px){
  .nav{grid-template-columns:auto 1fr auto auto;padding:4px var(--gutter)}
  .nav-link{display:none}
  .logo{grid-column:2;width:90px;justify-self:center}     /* smaller logo prevents hero overlap */
  .cart-btn{grid-column:3;justify-self:end;padding:6px 8px}
  .nav-burger{display:flex;grid-column:4;justify-self:end;margin-left:4px;width:36px;height:36px} /* 36px hit target */
  .lang-wrap{display:none}
  .auth-link{display:none}
  /* Header sits flush under the bar — keep top:38px */
  .site-header{top:32px}
}
@media (max-width:480px){
  .nav{padding:3px 14px;gap:6px}
  .logo{width:74px}
  .bar-track{font-size:9.5px;letter-spacing:.16em;gap:18px;padding:8px 0}
  .mono-mark{width:12px;height:12px}
  .site-header{top:28px}
}

/* ============================ MOBILE-SPECIFIC FIXES ============================ */
@media (max-width:780px){
  /* Hero — anchor stack to TOP on mobile (not bottom). Header on mobile = bar (32px) + logo header (90px logo at ~28px tall + 8px padding ~ 44px) = ~76px. Add 24px breathing room → 100px padding-top. */
  .hero{padding:100px 18px 36px;min-height:78vh;align-items:start}
  .hero-stack{align-self:start;width:100%}
  .hero-display{font-size:clamp(46px,13.5vw,64px);line-height:.94;margin-top:14px}
  .hero-tag{font-size:10px;letter-spacing:.12em;margin:0}
  .hero-sub{font-size:14px}
  .hero-cta{flex-direction:column;align-items:stretch;gap:10px}
  .hero-cta .btn{width:100%;text-align:center;min-height:48px;display:inline-flex;align-items:center;justify-content:center}
  .hero-corners{display:none}
  .hero-mono{display:none}

  /* Cart drawer fills the screen */
  .cart-modal{max-width:100%;width:100%;border-radius:0;height:100vh;max-height:100vh}
  .cart-modal[open]{padding:60px 18px 30px}
  .cart-item{grid-template-columns:48px 1fr auto;gap:10px;padding:10px}
  .cart-item-img{width:48px;height:48px}
  .cart-item-title{font-size:15px}
  .cart-item-meta{font-size:10px}
  .cart-item-line{font-size:12px}
  .cart-cta{flex-direction:column}
  .cart-cta .btn{width:100%}

  /* Order modal: full-screen on phone for usability */
  .order-modal{max-width:100%;width:100%;border-radius:0;height:100vh;max-height:100vh;overflow-y:auto}
  .order-modal[open]{padding:50px 18px 24px}
  .order-form input,.order-form select,.order-form textarea{font-size:16px;padding:13px 14px} /* 16px prevents iOS zoom */
  .rf-grid{grid-template-columns:1fr;gap:12px}
  .order-bank{padding:14px;font-size:12px}
  .bank-grid{grid-template-columns:1fr;gap:4px 0}
  .bank-grid dt{margin-top:8px;font-size:10px}
  .bank-grid dd{font-size:12px;word-break:break-all}
  .order-summary{flex-direction:column;align-items:flex-start;gap:4px}
  .order-totals{font-size:12px}

  /* Members section */
  .members{padding:60px 18px}
  .members-col{padding:24px 18px}
  .members-col h3{font-size:24px}
  .dash-head{flex-direction:column;align-items:flex-start;gap:14px}
  .dash-name{font-size:28px}
  .dash-grid{grid-template-columns:1fr;gap:10px}
  .dash-card{padding:18px}
  .dash-card h4{font-size:28px}
  .dash-perks ul{grid-template-columns:1fr}
  .dash-actions{flex-direction:column}
  .dash-actions .btn{width:100%}

  /* Product modal: full-screen too */
  .product-modal{max-width:100%;width:100%;border-radius:0;height:100vh;max-height:100vh;overflow-y:auto}
  .product-modal-grid{grid-template-columns:1fr;gap:18px}
  .product-modal-img img{max-height:50vh;width:100%;object-fit:cover}
  .product-modal-cta{flex-direction:column;align-items:stretch}
  .product-modal-cta .btn{width:100%;text-align:center}
  .product-size-pick{justify-content:space-between}

  /* Mobile menu: cart link stand-out */
  #mobile-cart-link{color:var(--bleach)!important;font-weight:500}
  #mobile-cart-count{font-family:var(--mono);font-size:14px;margin-left:8px}

  /* Section headings sized for phones */
  .section-h{font-size:clamp(34px,9vw,52px)}
  .lead{font-size:15px}

  /* Footer columns stack on mobile */
  .footer-grid{grid-template-columns:1fr;gap:32px}
}

/* =================================== HERO =================================== */
.hero{
  position:relative;min-height:50vh;
  display:grid;align-items:end;
  padding:clamp(80px,10vw,140px) var(--gutter) clamp(40px,5vw,72px);
  overflow:hidden;background:var(--ink);color:var(--cream);
  isolation:isolate;
  scroll-margin-top:0;
}
.hero-bg{
  position:absolute;inset:-5%;width:110%;height:110%;
  object-fit:cover;z-index:-2;
  filter:saturate(.92) contrast(1.06) brightness(.85);
  will-change:transform;
}
.hero-overlay{
  position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(180deg,rgba(13,13,13,.18),rgba(13,13,13,.62) 65%,rgba(13,13,13,.94)),
    radial-gradient(ellipse 80% 60% at 80% 18%,rgba(225,33,39,.28),transparent 60%);
}
.hero-stack{max-width:1100px;position:relative;z-index:1}
.hero-tag{
  font-family:var(--mono);font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:rgba(244,239,230,.7);margin:0 0 22px;
  padding-left:14px;border-left:1px solid var(--bleach);
}
.hero-display{
  font-family:var(--display);
  font-weight:300;
  font-size:clamp(64px,12vw,200px);
  line-height:.92;letter-spacing:-.045em;
  margin:0 0 32px;
  text-transform:none;
  font-variation-settings:"opsz" 144,"SOFT" 50;
}
.hero-display em{
  font-style:italic;font-weight:300;color:var(--bleach);
  font-variation-settings:"opsz" 144,"SOFT" 100;
}
.d-line{display:block;overflow:hidden}
.d-line > span{display:block;animation:rise 1.2s cubic-bezier(.19,.7,.24,1) .35s both}
.d-line:nth-child(2) > span{animation-delay:.55s}
@keyframes rise{from{transform:translateY(110%);opacity:0}to{transform:translateY(0);opacity:1}}

.hero-sub{
  max-width:42ch;color:rgba(244,239,230,.85);
  font-size:clamp(15px,1.3vw,18px);line-height:1.6;margin:0 0 32px;
}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap}

/* Off-White-style quotation corner labels */
.hero-corners{position:absolute;inset:24px;pointer-events:none;z-index:1}
.hc{
  position:absolute;
  font-family:var(--mono);font-size:10px;letter-spacing:.32em;text-transform:uppercase;
  color:rgba(244,239,230,.6);
}
.hc.tl{top:0;left:var(--gutter)}
.hc.tr{top:0;right:var(--gutter);text-align:right}

/* Hero monogram watermark, low-opacity */
.hero-mono{
  position:absolute;right:8%;top:18%;
  width:clamp(120px,18vw,260px);
  opacity:.16;
  filter:brightness(0) saturate(100%) invert(20%) sepia(80%) saturate(2400%) hue-rotate(346deg) brightness(95%) contrast(95%);
  pointer-events:none;z-index:0;
  animation:slowSpin 60s linear infinite;
}
@keyframes slowSpin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@media (prefers-reduced-motion:reduce){.hero-mono{animation:none}}
@media (max-width:780px){.hero-mono{right:-30px;top:8%;width:160px}}

.hero-scroll{
  position:absolute;bottom:24px;right:var(--gutter);z-index:2;
  font-family:var(--mono);font-size:10px;letter-spacing:.32em;
  color:rgba(244,239,230,.5);
  animation:scrollPulse 2.4s ease-in-out infinite;
}
@keyframes scrollPulse{0%,100%{transform:translateY(0);opacity:.5}50%{transform:translateY(6px);opacity:1}}
@media (max-width:780px){.hero-scroll{right:auto;left:var(--gutter);bottom:16px}.hero-corners .hc.tr{display:none}}

/* Buttons */
.btn{
  display:inline-block;
  font-family:var(--mono);font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  padding:14px 24px;border-radius:999px;
  border:1px solid currentColor;transition:all var(--t-fast);
  position:relative;overflow:hidden;
}
.btn::after{content:" →";display:inline-block;transition:transform var(--t-fast)}
.btn:hover::after{transform:translateX(3px)}
.btn-primary{background:var(--bleach);color:var(--cream);border-color:var(--bleach)}
.btn-primary:hover{background:var(--cream);color:var(--ink);border-color:var(--cream)}
.btn-outline{color:var(--cream);border-color:rgba(244,239,230,.5)}
.btn-outline:hover{background:var(--cream);color:var(--ink);border-color:var(--cream)}

/* ================================ WORLD STRIP =============================== */
.world{
  background:var(--cream);
  border-bottom:1px solid rgba(13,13,13,.08);
  overflow:hidden;
}
.world-track{
  display:flex;align-items:center;gap:36px;white-space:nowrap;padding:14px 0;
  font-family:var(--mono);font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--ink);
  animation:marquee 80s linear infinite;width:max-content;
}
.world-track i{display:block;width:8px;height:8px;background:var(--bleach);transform:rotate(45deg);flex:none}
.world-track .mono-mark{width:16px;height:16px}
.world:hover .world-track{animation-play-state:paused}

/* ================================ CAPSULE ================================== */
.capsule{
  max-width:var(--max);margin:0 auto;
  padding:clamp(80px,12vw,160px) var(--gutter) clamp(40px,6vw,96px);
  scroll-margin-top:80px;
}
.capsule-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(24px,5vw,80px);align-items:end;
  border-bottom:1px solid rgba(13,13,13,.1);
  padding-bottom:56px;
}
.serial{
  display:inline-block;font-family:var(--mono);font-size:11px;letter-spacing:.24em;
  text-transform:uppercase;color:var(--bleach);
  border:1px solid var(--bleach);padding:6px 14px;border-radius:999px;margin-bottom:24px;
}
.big-type{
  font-family:var(--display);font-weight:300;
  font-size:clamp(80px,17vw,240px);line-height:.84;letter-spacing:-.05em;
  margin:0;
  font-variation-settings:"opsz" 144,"SOFT" 30;
}
.big-type em{font-style:italic;font-weight:300;color:var(--bleach)}
.dateline{
  font-family:var(--mono);font-size:11px;letter-spacing:.24em;
  text-transform:uppercase;color:var(--stone);margin:18px 0 0;
}
.capsule-body .lead{font-size:clamp(18px,1.6vw,22px);line-height:1.55;color:var(--ink)}
.signoff{font-family:var(--mono);font-size:12px;letter-spacing:.18em;color:var(--stone);margin:0 0 32px}
.capsule-spec{display:grid;gap:16px;border-top:1px solid rgba(13,13,13,.08);padding-top:24px}
.capsule-spec li{
  display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:start;
  font-size:14px;line-height:1.55;color:var(--ink-soft);
}
.capsule-spec li span{
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--bleach);
}

.capsule-trio{
  display:grid;grid-template-columns:repeat(3,1fr);gap:8px;
  padding:64px 0 0;
}
.capsule-trio figure{margin:0;overflow:hidden;background:var(--cream-2);position:relative}
.capsule-trio img{
  width:100%;height:clamp(380px,54vw,620px);object-fit:cover;
  transition:transform var(--t-slow);
}
.capsule-trio figure:hover img{transform:scale(1.04)}
.capsule-trio figcaption{
  position:absolute;left:14px;bottom:14px;
  font-family:var(--mono);font-size:10px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--cream);background:rgba(13,13,13,.6);padding:6px 10px;border-radius:4px;
  backdrop-filter:blur(4px);
}
@media (max-width:780px){
  .capsule-grid{grid-template-columns:1fr;align-items:start}
  .capsule-trio{grid-template-columns:1fr;gap:6px}
  .capsule-trio img{height:auto;aspect-ratio:3/4}
}

/* =================================== SHOP =================================== */
.shop{
  max-width:var(--max);margin:0 auto;
  padding:clamp(60px,8vw,100px) var(--gutter);
  scroll-margin-top:80px;
}
.section-head{
  display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;
  gap:24px;margin-bottom:clamp(40px,6vw,72px);
  border-bottom:1px solid rgba(13,13,13,.1);padding-bottom:24px;
}
.section-head .section-h{margin:0;flex:1 1 auto}
.section-link{
  font-family:var(--mono);font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--bleach);border-bottom:1px solid currentColor;padding-bottom:2px;
}
.section-sub{max-width:50ch;color:var(--ink-soft);font-size:15px;line-height:1.6;margin:0;flex-basis:100%}

.shop-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,1.8vw,28px)}
.card .card-link{display:block;color:inherit}
.card-img{
  overflow:hidden;background:var(--cream-2);border-radius:6px;aspect-ratio:3/4;
  position:relative;
}
.card-img::after{
  content:"VIEW";
  position:absolute;inset:0;display:grid;place-items:center;
  background:rgba(13,13,13,.55);color:var(--cream);
  font-family:var(--mono);font-size:11px;letter-spacing:.32em;
  opacity:0;transition:opacity var(--t);
}
.card:hover .card-img::after{opacity:1}
.card-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.6s cubic-bezier(.19,.7,.24,1);
}
.card:hover .card-img img{transform:scale(1.06)}
.card-meta{display:flex;flex-direction:column;gap:4px;margin-top:14px}
.card h3{margin:0;font-size:16px;font-weight:500;letter-spacing:-.005em}
.card-meta p{margin:0;font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--stone)}
.card-price{margin:6px 0 0;font-weight:500;font-size:15px}
.shop-note{margin-top:48px;text-align:center;color:var(--stone);font-family:var(--mono);font-size:12px;letter-spacing:.08em}
.shop-note a{color:var(--bleach);border-bottom:1px solid currentColor}

@media (max-width:1100px){.shop-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:780px){.shop-grid{grid-template-columns:1fr 1fr;gap:14px}}

/* ================================== ARCHIVE ================================= */
.archive{
  max-width:var(--max);margin:0 auto;
  padding:clamp(40px,6vw,80px) var(--gutter) clamp(60px,8vw,100px);
}
.archive-head{
  display:grid;grid-template-columns:auto 1fr auto;gap:24px;align-items:end;
  margin-bottom:32px;border-bottom:1px solid rgba(13,13,13,.1);padding-bottom:20px;
}
.archive-head .section-h{margin:0;font-size:clamp(36px,4.6vw,68px)}
.archive-sub{margin:0;color:var(--stone);font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;text-align:right;justify-self:end}

.archive-row{
  display:flex;gap:8px;overflow-x:auto;padding-bottom:6px;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
}
.archive-row::-webkit-scrollbar{height:4px}
.archive-row::-webkit-scrollbar-thumb{background:rgba(13,13,13,.18);border-radius:2px}
.ar{
  flex:0 0 clamp(220px,22vw,320px);
  position:relative;overflow:hidden;border-radius:4px;background:var(--cream-2);
  scroll-snap-align:start;aspect-ratio:3/4;
}
.ar img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.6s cubic-bezier(.19,.7,.24,1),filter var(--t);
  filter:grayscale(20%);
}
.ar:hover img{transform:scale(1.05);filter:grayscale(0%)}
.ar span{
  position:absolute;left:12px;bottom:12px;
  font-family:var(--mono);font-size:10px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--cream);background:rgba(13,13,13,.55);padding:5px 9px;border-radius:3px;
  backdrop-filter:blur(4px);
}
@media (max-width:780px){.archive-head{grid-template-columns:1fr}.archive-sub{text-align:left;justify-self:start}}

/* ================================ EDITORIAL ================================= */
.editorial{
  position:relative;background:var(--ink);color:var(--cream);
  overflow:hidden;
}
.editorial-img{position:absolute;inset:0}
.editorial-img img{
  width:100%;height:100%;object-fit:cover;
  filter:brightness(.5) saturate(.85) contrast(1.1);
  transform:scale(1.04);
  transition:transform 8s linear;
}
.editorial.in .editorial-img img{transform:scale(1.0)}
.editorial-quote{
  position:relative;max-width:1100px;margin:0 auto;
  padding:clamp(140px,20vw,300px) var(--gutter);
  text-align:center;
}
.editorial-quote p{
  font-family:var(--display);font-weight:300;font-style:normal;
  font-size:clamp(28px,5.4vw,76px);line-height:1.06;letter-spacing:-.025em;margin:0 0 28px;
  font-variation-settings:"opsz" 144,"SOFT" 50;
}
.editorial-quote em{font-style:italic;color:var(--bleach)}
.editorial-quote span{
  font-family:var(--mono);font-size:11px;letter-spacing:.32em;color:rgba(244,239,230,.6);
  text-transform:uppercase;
}

/* ================================== MATERIALS =============================== */
.materials{
  background:var(--ink);color:var(--cream);
  padding:clamp(80px,10vw,140px) var(--gutter);
  scroll-margin-top:80px;
}
.materials .kicker{color:rgba(244,239,230,.55)}
.materials .section-h{color:var(--cream);max-width:14ch}
.materials .section-h em{color:var(--bleach)}
.materials-head{border-color:rgba(244,239,230,.15);max-width:var(--max);margin:0 auto clamp(40px,6vw,80px)}
.material-list{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);gap:48px;
}
.material-list li{
  display:flex;flex-direction:column;gap:16px;
  border-top:1px solid rgba(244,239,230,.2);padding-top:24px;
}
.material-list .num{
  font-family:var(--mono);font-size:11px;letter-spacing:.24em;color:var(--bleach);
}
.material-list h3{
  margin:0;font-family:var(--display);font-weight:400;
  font-size:clamp(24px,2.6vw,36px);letter-spacing:-.015em;line-height:1.05;
  font-variation-settings:"opsz" 80;
}
.material-list p{margin:0;color:rgba(244,239,230,.78);font-size:15px;line-height:1.65;max-width:38ch}
@media (max-width:780px){.material-list{grid-template-columns:1fr;gap:24px}}

/* =================================== REWARDS ================================ */
.rewards{
  max-width:var(--max);margin:0 auto;
  padding:clamp(80px,10vw,140px) var(--gutter);
  scroll-margin-top:80px;
}
.rewards-head .section-h{max-width:18ch}
.rewards-head .section-sub{margin-top:8px}

.tiers{
  display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,1.6vw,22px);
  margin-top:clamp(40px,5vw,64px);
}
.tier{
  position:relative;background:var(--cream-2);border-radius:14px;
  padding:clamp(28px,3vw,40px);
  border:1px solid rgba(13,13,13,.06);
  transition:transform var(--t),box-shadow var(--t),background var(--t);
  display:flex;flex-direction:column;gap:18px;
  overflow:hidden;
}
.tier::before{
  content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--accent);
}
.tier:hover{transform:translateY(-6px);box-shadow:0 28px 56px -28px rgba(13,13,13,.18)}
.tier-tag{
  font-family:var(--mono);font-size:10px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--stone);
}
.tier h3{
  font-family:var(--display);font-weight:300;
  font-size:clamp(40px,5vw,68px);line-height:1;letter-spacing:-.025em;margin:6px 0 8px;
  font-variation-settings:"opsz" 144,"SOFT" 30;
}
.tier header p{margin:0;color:var(--ink-soft);font-size:14px}
.tier ul{display:grid;gap:10px;border-top:1px solid rgba(13,13,13,.1);padding-top:18px}
.tier li{font-size:14px;line-height:1.55;color:var(--ink-soft)}
.tier li b{color:var(--ink);font-weight:600}
.tier-foot{
  margin-top:auto;font-family:var(--mono);font-size:11px;letter-spacing:.18em;
  color:var(--stone);padding-top:12px;border-top:1px dashed rgba(13,13,13,.15);
}
.tier-flag{
  position:absolute;top:14px;right:14px;
  background:var(--bleach);color:var(--cream);
  font-family:var(--mono);font-size:9px;letter-spacing:.22em;text-transform:uppercase;
  padding:5px 9px;border-radius:999px;
}
.tier-mid{background:var(--ink);color:var(--cream)}
.tier-mid .tier-tag{color:rgba(244,239,230,.55)}
.tier-mid li{color:rgba(244,239,230,.85)}
.tier-mid li b{color:var(--cream)}
.tier-mid header p{color:rgba(244,239,230,.7)}
.tier-mid ul{border-color:rgba(244,239,230,.18)}
.tier-mid .tier-foot{color:rgba(244,239,230,.5);border-color:rgba(244,239,230,.25)}

@media (max-width:980px){.tiers{grid-template-columns:1fr;gap:14px}}

.tier-perks{
  margin-top:clamp(40px,5vw,72px);
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
  border-top:1px solid rgba(13,13,13,.1);padding-top:32px;
}
.perk{display:flex;flex-direction:column;gap:8px}
.perk-num{
  font-family:var(--display);font-weight:300;font-size:48px;line-height:1;color:var(--bleach);
  font-variation-settings:"opsz" 144;
}
.perk p{margin:0;font-size:14px;line-height:1.55;color:var(--ink-soft)}
.perk b{color:var(--ink)}
.rewards-cta{margin-top:48px;background:var(--ink);color:var(--cream);border-color:var(--ink)}
.rewards-cta:hover{background:var(--bleach);border-color:var(--bleach)}
@media (max-width:780px){.tier-perks{grid-template-columns:1fr 1fr}}
@media (max-width:480px){.tier-perks{grid-template-columns:1fr}}

/* ==================================== MEMBERS =============================== */
.members{
  max-width:var(--max);margin:0 auto;
  padding:clamp(80px,10vw,140px) var(--gutter);
  border-top:1px solid rgba(13,13,13,.08);
  scroll-margin-top:120px;
}
.members-head{margin-bottom:clamp(32px,4vw,56px)}
.members-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,3vw,48px);
}
.members-col{
  background:var(--cream-2);border:1px solid rgba(13,13,13,.08);border-radius:14px;
  padding:clamp(28px,3vw,40px);
}
.members-col h3{
  font-family:var(--display);font-weight:300;font-size:clamp(28px,3.4vw,42px);
  margin:8px 0 18px;line-height:1;letter-spacing:-.02em;
}
.members-login{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.members-login .kicker{color:rgba(244,239,230,.65)}
.members-login .lead-sm{font-size:14px;color:rgba(244,239,230,.8);margin:0 0 16px}
.members-login .rf-row input{background:rgba(255,255,255,.06);color:var(--cream);border-color:rgba(244,239,230,.2)}
.members-login .rf-row input:focus{border-color:var(--bleach);background:rgba(255,255,255,.1)}
.members-login .rf-label{color:rgba(244,239,230,.7)}
.members-foot{font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:rgba(244,239,230,.6);margin-top:20px}
.members-foot a{color:var(--bleach);text-decoration:underline}

/* Members dashboard (signed-in state) */
.members-dashboard{
  background:var(--cream-2);border:1px solid rgba(13,13,13,.08);border-radius:14px;
  padding:clamp(32px,4vw,56px);
}
.dash-head{
  display:flex;align-items:flex-start;justify-content:space-between;gap:24px;
  padding-bottom:24px;border-bottom:1px solid rgba(13,13,13,.1);
}
.dash-name{font-family:var(--display);font-weight:300;font-size:clamp(32px,4vw,52px);margin:6px 0 4px;letter-spacing:-.02em;line-height:1}
.dash-email{font-family:var(--mono);font-size:12px;letter-spacing:.06em;color:var(--stone);margin:0}
.dash-signout{background:transparent;border:1px solid rgba(13,13,13,.18);padding:8px 18px;font-size:11px;align-self:flex-start}
.dash-head-right{display:flex;gap:10px;align-items:flex-start;flex-wrap:wrap}
.dash-admin{background:var(--bleach);color:#fff;border-color:var(--bleach);padding:8px 18px;font-size:11px;font-weight:600;letter-spacing:.06em}
.dash-admin:hover{background:var(--ink);border-color:var(--ink);color:var(--cream)}
.dash-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:32px 0;
}
.dash-card{
  background:var(--cream);border:1px solid rgba(13,13,13,.08);border-radius:10px;padding:24px;
}
.dash-card h4{font-family:var(--display);font-weight:300;font-size:36px;margin:6px 0 8px;letter-spacing:-.02em;line-height:1}
.dash-card p{margin:0;font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--stone)}
.dash-perks{margin:32px 0}
.dash-perks ul{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-top:12px;list-style:none;padding:0}
.dash-perks li{
  font-family:var(--mono);font-size:12px;letter-spacing:.04em;
  padding:10px 14px;background:var(--cream);border-radius:6px;border:1px solid rgba(13,13,13,.06);
}
.dash-perks li::before{content:"✓ ";color:var(--bleach);font-weight:700}
.dash-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}

/* Profile edit (collapsible details on dashboard) */
.dash-profile{
  margin-top:24px;background:var(--cream);border:1px solid rgba(13,13,13,.08);border-radius:10px;
  padding:0;overflow:hidden;
}
.dash-profile summary{
  padding:14px 18px;cursor:pointer;list-style:none;
  font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink);
  display:flex;justify-content:space-between;align-items:center;
}
.dash-profile summary::after{content:"+";font-size:18px;color:var(--bleach);font-weight:700}
.dash-profile[open] summary::after{content:"−"}
.dash-profile summary:hover{color:var(--bleach)}
.dash-profile form{padding:8px 18px 18px;display:grid;gap:12px}
.dash-profile input,.dash-profile textarea,.dash-profile select{
  background:#fff;border:1px solid rgba(13,13,13,.18);color:var(--ink);
  padding:10px 12px;border-radius:6px;font:inherit;font-size:14px;
}

/* ============================ HUNT (monogram game) ============================ */
.dash-hunt{
  background:linear-gradient(135deg, rgba(225,33,39,.06), var(--cream));
  border:1px solid rgba(225,33,39,.2);border-radius:12px;
  padding:18px 22px;margin-top:24px;
}
.dash-hunt-head{display:flex;justify-content:space-between;align-items:baseline;gap:12px;flex-wrap:wrap;margin-bottom:14px}
.dash-hunt-head .kicker{margin:0;color:var(--bleach)}
.dash-hunt-score{font-family:var(--mono);font-size:12px;color:var(--ink);font-weight:600}
.dash-hunt-grid{display:flex;gap:10px;margin-bottom:12px}
.hunt-dot{
  width:32px;height:32px;border-radius:50%;
  background:var(--cream);border:2px solid rgba(13,13,13,.12);
  display:inline-block;transition:all .3s var(--t);
}
.hunt-dot.found{
  background:var(--bleach);border-color:var(--bleach);
  box-shadow:0 0 12px rgba(225,33,39,.4);
}
.hunt-dot.found::before{content:"✓";color:#fff;display:block;text-align:center;line-height:28px;font-weight:700;font-size:14px}
.dash-hunt-hint{margin:0;font-size:12px;color:var(--stone);font-style:italic;line-height:1.5}

/* The 6 hidden monograms — small, low-opacity, scattered. Visible only when signed in.
   Touch target padding makes them easy to tap on mobile without making them visually larger. */
.hunt-mono{
  position:fixed;background:transparent;border:0;cursor:pointer;
  width:24px;height:24px;opacity:0;pointer-events:none;
  padding:8px;margin:-8px;                    /* invisible 8px touch-padding around the icon */
  transition:opacity .4s var(--t),transform var(--t-fast);
  z-index:35;
  -webkit-tap-highlight-color:rgba(225,33,39,.3);
  touch-action:manipulation;
}
.hunt-mono img{width:100%;height:100%;display:block;filter:drop-shadow(0 2px 4px rgba(13,13,13,.3))}
.hunt-mono.hunt-active{opacity:.55;pointer-events:auto}
.hunt-mono.hunt-active:hover,.hunt-mono.hunt-active:active{opacity:1;transform:scale(1.25)}
.hunt-mono.claimed{opacity:.18;pointer-events:none}
/* Subtle pulse so an unclaimed active monogram has a visual heartbeat */
.hunt-mono.hunt-active:not(.claimed){animation:huntPulse 3.2s ease-in-out infinite}
@keyframes huntPulse{
  0%,100%{opacity:.45}
  50%{opacity:.75;transform:scale(1.08)}
}
@media (prefers-reduced-motion:reduce){.hunt-mono{animation:none!important}}

/* Worldwide-consistent monogram colors (hue-rotated from the base red monogram-sm.png).
   Drop 1 = m1-m6, Drop 2 = m7-m12 (+2 weeks), Drop 3 = m13-m18 (+4 weeks). */
.hunt-mono[data-hunt-id="m1"]  img{filter:none}                                                /* RED       */
.hunt-mono[data-hunt-id="m2"]  img{filter:hue-rotate(40deg)  saturate(1.3) brightness(1.05)}   /* ORANGE    */
.hunt-mono[data-hunt-id="m3"]  img{filter:hue-rotate(80deg)  saturate(1.4) brightness(1.1)}    /* GOLD      */
.hunt-mono[data-hunt-id="m4"]  img{filter:hue-rotate(140deg) saturate(1.2)}                    /* GREEN     */
.hunt-mono[data-hunt-id="m5"]  img{filter:hue-rotate(190deg) saturate(1.3)}                    /* TEAL      */
.hunt-mono[data-hunt-id="m6"]  img{filter:hue-rotate(280deg) saturate(1.3)}                    /* PURPLE    */
.hunt-mono[data-hunt-id="m7"]  img{filter:hue-rotate(310deg) saturate(1.5)}                    /* MAGENTA   */
.hunt-mono[data-hunt-id="m8"]  img{filter:hue-rotate(220deg) saturate(1.4) brightness(1.1)}    /* SKY       */
.hunt-mono[data-hunt-id="m9"]  img{filter:hue-rotate(110deg) saturate(1.6) brightness(1.15)}   /* LIME      */
.hunt-mono[data-hunt-id="m10"] img{filter:hue-rotate(20deg)  saturate(1.5) brightness(1.1)}    /* CORAL     */
.hunt-mono[data-hunt-id="m11"] img{filter:hue-rotate(245deg) saturate(1.3) brightness(.85)}    /* INDIGO    */
.hunt-mono[data-hunt-id="m12"] img{filter:hue-rotate(70deg)  saturate(.7)  brightness(.85)}    /* OLIVE     */
.hunt-mono[data-hunt-id="m13"] img,
.hunt-mono[data-hunt-id="m14"] img,
.hunt-mono[data-hunt-id="m15"] img,
.hunt-mono[data-hunt-id="m16"] img,
.hunt-mono[data-hunt-id="m17"] img,
.hunt-mono[data-hunt-id="m18"] img{filter:grayscale(.6) opacity(.7)}                            /* TBD       */

/* Each monogram lives on a different page (data-page) and at a different spot — truly scattered. */
.hunt-mono[data-hunt-id="m1"]{top:62%;right:14px;width:20px;height:20px}                /* /  home — right edge */
.hunt-mono[data-hunt-id="m2"]{bottom:88px;left:14px;width:22px;height:22px}             /* shop — bottom-left */
.hunt-mono[data-hunt-id="m3"]{top:24%;right:32px;width:20px;height:20px}                /* rewards — upper right */
.hunt-mono[data-hunt-id="m4"]{bottom:140px;right:60px;width:22px;height:22px}           /* events — near footer right */
.hunt-mono[data-hunt-id="m5"]{top:48%;left:24px;width:20px;height:20px}                 /* about — left edge mid */
.hunt-mono[data-hunt-id="m6"]{top:38%;right:24px;width:24px;height:24px}                /* catalog — right edge upper */
/* Mobile hunt monograms — bigger, fatter touch areas, opacity boosted so they're findable. */
@media (max-width:780px){
  .hunt-mono{
    width:26px!important;height:26px!important;
    padding:14px!important;margin:-14px!important;     /* 26 + 28px touch padding = 54px tap zone */
  }
  .hunt-mono.hunt-active{opacity:.7}                    /* slightly more visible than desktop's .55 */
  .hunt-mono.hunt-active:not(.claimed){animation:huntPulse 2.6s ease-in-out infinite}
  /* Positioned away from cart icon (top right ~50-80px), mobile burger (top right corner),
     and floating bottom UI. Mid-screen edges work best on mobile. */
  .hunt-mono[data-hunt-id="m1"]{top:auto;bottom:38%;right:14px}        /* home — right mid-low */
  .hunt-mono[data-hunt-id="m2"]{top:42%;left:14px;bottom:auto}         /* shop — left mid */
  .hunt-mono[data-hunt-id="m3"]{top:38%;right:14px;bottom:auto}        /* rewards — right upper-mid */
  .hunt-mono[data-hunt-id="m4"]{top:50%;right:14px;bottom:auto}        /* events — right mid */
  .hunt-mono[data-hunt-id="m5"]{top:48%;left:14px}                     /* about — left mid */
  .hunt-mono[data-hunt-id="m6"]{top:44%;right:14px}                    /* catalog — right mid */
}

/* Hunt toast position on mobile — sit above bottom safe area, never over fixed UI */
@media (max-width:780px){
  .hunt-toast{
    bottom:calc(20px + env(safe-area-inset-bottom));
    left:16px;right:16px;transform:none;
    text-align:center;font-size:12px;padding:12px 18px;
    border-radius:12px;
  }
  @keyframes huntPop{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
}

/* Welcome modal mobile fit */
@media (max-width:780px){
  .welcome-modal{max-width:calc(100% - 24px);width:calc(100% - 24px)}
  .welcome-modal[open]{padding:32px 22px 22px;max-height:88vh;overflow-y:auto}
  .welcome-modal h2{font-size:32px}
  .welcome-list{gap:6px;margin:14px 0 18px}
  .welcome-list li{font-size:12px;padding:9px 12px}
}

/* ============================ MONOGRAM ALBUM ============================ */
.dash-album{
  background:var(--cream);border:1px solid rgba(13,13,13,.08);border-radius:12px;
  padding:20px 22px;margin-top:16px;
}
.album-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:14px;flex-wrap:wrap;gap:8px}
.album-head .kicker{margin:0;color:var(--bleach)}
.album-progress{font-family:var(--mono);font-size:11px;color:var(--stone);font-weight:600}
.album-grid{
  display:grid;grid-template-columns:repeat(6,1fr);gap:14px;
}
@media (max-width:580px){.album-grid{grid-template-columns:repeat(3,1fr);gap:10px}}
.album-slot{
  position:relative;aspect-ratio:1;border-radius:10px;
  background:var(--cream-2);border:1px dashed rgba(13,13,13,.18);
  display:flex;align-items:center;justify-content:center;
  transition:all .4s var(--t);overflow:hidden;
}
.album-slot.empty::after{
  content:"?";font-family:var(--display);font-weight:300;font-size:32px;color:rgba(13,13,13,.18);
}
.album-slot.found{
  background:#fff;border-style:solid;border-color:rgba(13,13,13,.15);
  box-shadow:0 8px 20px -10px rgba(13,13,13,.18);
}
.album-slot.found::after{content:none}
.album-slot img{width:60%;height:60%;object-fit:contain;display:block}
/* SAME color filters as hunt monos (worldwide consistent) */
.album-slot[data-id="m1"]  img{filter:none}
.album-slot[data-id="m2"]  img{filter:hue-rotate(40deg)  saturate(1.3) brightness(1.05)}
.album-slot[data-id="m3"]  img{filter:hue-rotate(80deg)  saturate(1.4) brightness(1.1)}
.album-slot[data-id="m4"]  img{filter:hue-rotate(140deg) saturate(1.2)}
.album-slot[data-id="m5"]  img{filter:hue-rotate(190deg) saturate(1.3)}
.album-slot[data-id="m6"]  img{filter:hue-rotate(280deg) saturate(1.3)}
.album-slot[data-id="m7"]  img{filter:hue-rotate(310deg) saturate(1.5)}
.album-slot[data-id="m8"]  img{filter:hue-rotate(220deg) saturate(1.4) brightness(1.1)}
.album-slot[data-id="m9"]  img{filter:hue-rotate(110deg) saturate(1.6) brightness(1.15)}
.album-slot[data-id="m10"] img{filter:hue-rotate(20deg)  saturate(1.5) brightness(1.1)}
.album-slot[data-id="m11"] img{filter:hue-rotate(245deg) saturate(1.3) brightness(.85)}
.album-slot[data-id="m12"] img{filter:hue-rotate(70deg)  saturate(.7)  brightness(.85)}
.album-slot.empty img{opacity:.06;filter:grayscale(1)!important}
.album-slot.locked img{opacity:.04;filter:grayscale(1)!important}

/* Drop sections in album */
.album-drop{margin-bottom:14px}
.drop-title{
  font-family:var(--mono);font-size:10px;letter-spacing:.16em;color:var(--stone);
  margin:0 0 8px;text-transform:uppercase;
}
.drop-title:has(+.album-grid .album-slot.locked){color:var(--bleach)}
.album-slot.locked{
  background:repeating-linear-gradient(45deg,var(--cream-2) 0 6px,var(--cream) 6px 12px);
  border-style:dashed;opacity:.6;
}
.album-slot.locked::after{content:"🔒";font-size:16px;color:var(--stone)}
.album-slot.locked .album-label{color:var(--stone);font-style:italic}
.album-foot{
  margin:14px 0 0;font-family:var(--mono);font-size:11px;color:var(--stone);
  text-align:center;font-style:italic;
}
.album-label{
  position:absolute;bottom:6px;left:50%;transform:translateX(-50%);
  font-family:var(--mono);font-size:9px;letter-spacing:.08em;color:var(--stone);
  text-transform:uppercase;
}
.album-slot.found .album-label{color:var(--ink);font-weight:600}

/* Mobile album — bigger touch targets, single grid stays clean */
@media (max-width:780px){
  .dash-album{padding:16px}
  .album-grid{gap:8px}
  .album-slot{border-radius:8px}
  .album-slot.empty::after{font-size:24px}
  .album-label{font-size:8px;bottom:4px}
  .dash-hunt{padding:14px 16px;margin-top:18px}
  .dash-hunt-head{margin-bottom:8px}
  .dash-hunt-score{font-size:11px}
  .dash-hunt-hint{font-size:11px;margin-top:6px}
}

/* Hunt toast — bottom-center floating notification */
.hunt-toast{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%);
  background:var(--ink);color:var(--cream);
  padding:14px 24px;border-radius:999px;
  font-family:var(--mono);font-size:13px;font-weight:600;letter-spacing:.04em;
  box-shadow:0 16px 40px -12px rgba(13,13,13,.5);
  z-index:9999;animation:huntPop .35s cubic-bezier(.19,.7,.24,1);
  border:1px solid rgba(244,239,230,.15);
}
.hunt-toast.err{background:var(--bleach);color:#fff}
@keyframes huntPop{from{opacity:0;transform:translateX(-50%) translateY(20px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}

/* Welcome modal */
.welcome-modal{max-width:520px}
.welcome-list{list-style:none;padding:0;margin:18px 0 24px;display:grid;gap:8px}
.welcome-list li{
  font-family:var(--mono);font-size:13px;color:var(--cream);
  padding:10px 14px;background:rgba(244,239,230,.06);border-radius:8px;
  border:1px solid rgba(244,239,230,.1);
}
.welcome-list strong{color:var(--bleach)}

@media (max-width:780px){
  .members-grid{grid-template-columns:1fr}
  .dash-grid{grid-template-columns:1fr}
  .dash-perks ul{grid-template-columns:1fr}
  .dash-head{flex-direction:column}
}

/* ==================================== EVENTS ================================ */
.events{
  max-width:var(--max);margin:0 auto;
  padding:clamp(80px,10vw,140px) var(--gutter);
  border-top:1px solid rgba(13,13,13,.08);
  scroll-margin-top:80px;
}
.event-list{display:grid;gap:0}
.event-list li{
  display:grid;grid-template-columns:160px 1fr auto;align-items:center;gap:32px;
  padding:32px 0;border-bottom:1px solid rgba(13,13,13,.08);
  transition:background var(--t);
}
.event-list li:hover{background:var(--cream-2)}
.event-list li:last-child{border-bottom:0}
.event-date strong{
  font-family:var(--display);font-weight:400;font-size:42px;line-height:1;display:block;
  font-variation-settings:"opsz" 144;
}
.event-date span{
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;color:var(--stone);
  text-transform:uppercase;
}
.event-body h3{
  margin:0 0 6px;font-size:clamp(22px,2.4vw,32px);font-weight:500;letter-spacing:-.015em;
}
.event-body p{margin:0;color:var(--ink-soft);font-size:15px;line-height:1.55}
.event-meta{font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:var(--stone);text-transform:uppercase;margin-top:6px!important}
.event-cta{
  font-family:var(--mono);font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  color:var(--ink);border:1px solid var(--ink);padding:12px 18px;border-radius:999px;
  transition:all var(--t-fast);
}
.event-cta:hover{background:var(--ink);color:var(--cream)}
@media (max-width:780px){
  .event-list li{grid-template-columns:1fr;gap:8px;padding:24px 12px}
  .event-cta{justify-self:start}
}

/* ================================== NEWSLETTER ============================== */
.newsletter{padding:0 var(--gutter) clamp(80px,10vw,140px);scroll-margin-top:80px}
.newsletter-card{
  position:relative;overflow:hidden;
  max-width:var(--max);margin:0 auto;
  background:var(--ink);color:var(--cream);
  border-radius:18px;
  padding:clamp(56px,7vw,96px) clamp(28px,5vw,80px);
}
.newsletter-card::before{
  content:"";position:absolute;inset:auto -160px -200px auto;
  width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle at center,rgba(225,33,39,.55),transparent 60%);
  filter:blur(40px);pointer-events:none;
}
.newsletter-art{
  position:absolute;right:-40px;top:-40px;
  width:380px;max-width:48%;
  opacity:.78;mix-blend-mode:screen;
  pointer-events:none;
  filter:saturate(1.3);
}
.newsletter-card .kicker{color:rgba(244,239,230,.6)}
.newsletter-card h2{
  font-family:var(--display);font-weight:300;
  font-size:clamp(40px,5.6vw,80px);line-height:1;letter-spacing:-.025em;margin:0 0 18px;
  max-width:14ch;font-variation-settings:"opsz" 144,"SOFT" 50;
}
.newsletter-card h2 em{font-style:italic;color:var(--bleach)}
.newsletter-card > p{color:rgba(244,239,230,.8);max-width:50ch;margin:0 0 32px}
.newsletter-form{
  display:flex;gap:8px;flex-wrap:wrap;
  background:rgba(244,239,230,.08);
  border:1px solid rgba(244,239,230,.16);
  border-radius:999px;padding:6px;max-width:560px;
  position:relative;z-index:2;
}
.newsletter-form input{
  flex:1;min-width:200px;background:transparent;border:0;outline:0;color:var(--cream);
  padding:14px 18px;font:inherit;font-size:15px;
}
.newsletter-form input::placeholder{color:rgba(244,239,230,.4)}
.newsletter-form button{
  background:var(--bleach);color:var(--cream);
  padding:14px 22px;border-radius:999px;
  font-family:var(--mono);font-size:11px;letter-spacing:.24em;text-transform:uppercase;
  transition:transform var(--t-fast),background var(--t-fast);
}
.newsletter-form button:hover{background:#fff;color:var(--ink);transform:translateX(2px)}
.fineprint{
  margin-top:18px;font-family:var(--mono);font-size:11px;letter-spacing:.06em;
  color:rgba(244,239,230,.45);
}

/* ==================================== ABOUT ================================= */
.about{max-width:var(--max);margin:0 auto;padding:clamp(80px,10vw,140px) var(--gutter);scroll-margin-top:80px}

/* On multi-page, the first <section> needs top padding to clear the fixed bar+header. */
main.multipage > section:first-child{padding-top:140px!important}
@media (max-width:780px){
  main.multipage > section:first-child{padding-top:96px!important}    /* mobile header is shorter */
}

/* ================================ CHECKOUT PAGE ================================ */
.checkout-section{
  max-width:var(--max);margin:0 auto;
  padding:clamp(80px,10vw,120px) var(--gutter) clamp(60px,8vw,100px);
}
.checkout-section[hidden]{display:none}
.checkout-section h2 em{color:var(--bleach);font-style:italic}
.checkout-head{margin-bottom:clamp(28px,3vw,48px);max-width:780px}
.checkout-grid{
  display:grid;grid-template-columns:380px 1fr;gap:clamp(24px,3vw,40px);align-items:start;
}
.checkout-side{display:grid;gap:18px;position:sticky;top:120px}
.checkout-card{
  background:var(--cream-2);border:1px solid rgba(13,13,13,.08);border-radius:14px;
  padding:24px;
}
.checkout-card .kicker{margin:0 0 14px}

#checkout-items{display:grid;gap:10px;margin-bottom:18px}
.co-item{
  display:grid;grid-template-columns:48px 1fr auto;gap:12px;align-items:center;
  padding-bottom:10px;border-bottom:1px solid rgba(13,13,13,.08);
}
.co-item:last-child{border-bottom:0;padding-bottom:0}
.co-item img{width:48px;height:48px;object-fit:cover;border-radius:6px}
.co-item-meta{display:flex;flex-direction:column;gap:2px}
.co-item-title{font-family:var(--display);font-weight:300;font-size:15px;line-height:1.1;letter-spacing:-.005em}
.co-item-sub{font-family:var(--mono);font-size:10px;letter-spacing:.04em;color:var(--stone)}
.co-item-line{font-family:var(--mono);font-size:13px;font-weight:600;color:var(--ink)}

.checkout-totals{
  background:var(--cream);padding:14px 16px;border-radius:8px;
  font-family:var(--mono);font-size:13px;margin-bottom:14px;
}
.checkout-totals .ot-row{display:flex;justify-content:space-between;padding:3px 0;color:var(--stone)}
.checkout-totals .ot-total{padding-top:8px;margin-top:6px;border-top:1px solid rgba(13,13,13,.12);color:var(--ink);font-size:16px;font-weight:700}
.checkout-totals .ot-total span:last-child{color:var(--bleach)}
.checkout-back{display:block;text-align:center;font-size:11px;padding:10px 14px}

.checkout-bank{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.checkout-bank .kicker{color:rgba(244,239,230,.6)}
.checkout-bank .bank-grid dt{color:rgba(244,239,230,.55)}
.checkout-bank .bank-grid dd{color:var(--cream)}
.checkout-bank .bank-note{color:rgba(244,239,230,.7);font-style:italic;margin:8px 0 0;font-size:12px}
.checkout-bank .copy-btn{background:transparent;border-color:rgba(225,33,39,.5);color:var(--bleach)}

.checkout-main{
  background:var(--cream-2);border:1px solid rgba(13,13,13,.08);border-radius:14px;
  padding:clamp(24px,3vw,40px);
}
.checkout-main .kicker{color:var(--bleach);margin:0 0 14px}
.checkout-main .rf-row input,
.checkout-main .rf-row textarea,
.checkout-main .rf-row input[type=file]{
  background:var(--cream);color:var(--ink);border-color:rgba(13,13,13,.18);
}
.checkout-main .rf-row input:focus,
.checkout-main .rf-row textarea:focus{border-color:var(--bleach);background:#fff}
.checkout-main .rf-label{color:var(--stone)}
.checkout-main .rf-hint{color:var(--stone)}
.checkout-main .fineprint{color:var(--stone)}
.checkout-submit{margin-top:18px;width:100%;font-size:16px;padding:14px}

.checkout-empty{
  text-align:center;padding:60px 20px;background:var(--cream-2);border-radius:14px;
}
.checkout-empty p{color:var(--stone);margin-bottom:18px}

@media (max-width:980px){
  .checkout-grid{grid-template-columns:1fr}
  .checkout-side{position:static;order:2}
  .checkout-main{order:1}
}
@media (max-width:780px){
  .checkout-section{padding:80px 16px 40px}
  .checkout-card{padding:18px}
  .checkout-main{padding:20px}
}

/* ================================ CATALOG ================================ */
.catalog{
  max-width:var(--max);margin:0 auto;
  padding:clamp(80px,10vw,140px) var(--gutter);
  border-top:1px solid rgba(13,13,13,.08);
  scroll-margin-top:120px;
}
.catalog-head{margin-bottom:clamp(28px,3vw,40px);max-width:780px}
.catalog-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:32px}
.cat-tab{
  font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  padding:8px 16px;background:transparent;border:1px solid rgba(13,13,13,.18);border-radius:999px;
  color:var(--ink);cursor:pointer;transition:all var(--t-fast);
}
.cat-tab:hover{border-color:var(--bleach);color:var(--bleach)}
.cat-tab.is-active{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.catalog-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px;
}
.cat-item{
  background:var(--cream-2);border:1px solid rgba(13,13,13,.06);border-radius:12px;overflow:hidden;
  transition:transform var(--t),box-shadow var(--t);
}
.cat-item:hover{transform:translateY(-2px);box-shadow:0 18px 40px -22px rgba(13,13,13,.18)}
.cat-img{aspect-ratio:1;overflow:hidden;background:var(--cream-2)}
.cat-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--t)}
.cat-item:hover .cat-img img{transform:scale(1.04)}
.cat-meta{padding:16px}
.cat-meta h4{font-family:var(--display);font-weight:300;font-size:20px;margin:0 0 6px;letter-spacing:-.01em}
.cat-meta p{margin:0 0 10px;font-family:var(--mono);font-size:11px;color:var(--stone);letter-spacing:.04em}
.cat-status{
  display:inline-block;padding:3px 10px;border-radius:999px;
  font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;
}
.cat-status.sold{background:rgba(13,13,13,.1);color:var(--ink)}
.cat-status.soon{background:var(--bleach);color:#fff}
.cat-status.archive{background:rgba(225,33,39,.12);color:var(--bleach);border:1px solid rgba(225,33,39,.3)}
.catalog-foot{
  margin:40px 0 0;text-align:center;font-family:var(--mono);font-size:12px;color:var(--stone);
}
.catalog-foot a{color:var(--bleach);text-decoration:underline}
.cat-item.is-hidden{display:none}
@media (max-width:780px){
  .catalog{padding:60px 18px}
  .catalog-grid{grid-template-columns:1fr 1fr;gap:14px}
  .cat-meta{padding:12px}
  .cat-meta h4{font-size:16px}
}
@media (max-width:480px){
  .catalog-grid{grid-template-columns:1fr}
}

/* ================================ CREDITS ================================ */
.credits{
  max-width:var(--max);margin:0 auto;
  padding:clamp(80px,10vw,140px) var(--gutter);
  border-top:1px solid rgba(13,13,13,.08);
  scroll-margin-top:120px;
}
.credits-head{margin-bottom:clamp(32px,4vw,56px);max-width:780px}
.credits-head h2 em{color:var(--bleach);font-style:italic}
.credits-card{
  background:var(--cream-2);border:1px solid rgba(13,13,13,.08);border-radius:14px;
  padding:clamp(32px,4vw,56px);
  display:grid;gap:clamp(28px,3vw,40px);
}
.credit-block h3{
  font-family:var(--display);font-weight:300;
  font-size:clamp(36px,5vw,64px);line-height:1;letter-spacing:-.02em;
  margin:8px 0 6px;
}
.credit-role{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--stone);margin:0 0 14px}
.credit-block p{margin:8px 0;color:var(--ink-soft);max-width:680px}
.credit-block .kicker{margin:0 0 6px}
.credit-list{list-style:none;padding:0;display:grid;gap:12px}
.credit-list li{
  font-family:var(--sans);font-size:14px;color:var(--ink-soft);line-height:1.5;
  padding-left:18px;position:relative;
}
.credit-list li::before{content:"·";position:absolute;left:0;color:var(--bleach);font-weight:700;font-size:18px;line-height:1}
.credit-list strong{color:var(--ink);font-weight:600}
.credit-license{
  font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--stone);
  margin:8px 0 0;padding-top:18px;border-top:1px dashed rgba(13,13,13,.15);
}
@media (max-width:780px){
  .credits{padding:60px 18px}
  .credits-card{padding:24px 18px;gap:24px}
  .credit-block h3{font-size:32px}
}
.about-grid{
  display:grid;grid-template-columns:1.05fr 1fr;
  gap:clamp(24px,5vw,80px);align-items:center;
}
.about-grid .kicker{color:var(--stone)}
.about-grid p{font-size:16px;line-height:1.7;color:var(--ink-soft);margin:0 0 16px;max-width:48ch}
.about-grid .lead{font-size:clamp(18px,1.6vw,22px);line-height:1.55;color:var(--ink)}
.about-img{overflow:hidden;border-radius:6px;background:var(--cream-2)}
.about-img img{
  width:100%;aspect-ratio:4/5;object-fit:cover;
  transition:transform var(--t-slow);
}
.about:hover .about-img img{transform:scale(1.04)}
@media (max-width:780px){.about-grid{grid-template-columns:1fr}}

/* ==================================== FOOTER ================================ */
.footer{
  position:relative;background:var(--ink);color:var(--cream);
  padding:clamp(64px,8vw,120px) var(--gutter) 24px;overflow:hidden;
  scroll-margin-top:80px;
}
.footer-mark{
  position:absolute;left:50%;bottom:-2vw;transform:translateX(-50%);
  font-family:var(--display);font-weight:300;
  font-size:clamp(120px,22vw,360px);line-height:.8;letter-spacing:-.045em;
  color:rgba(244,239,230,.045);pointer-events:none;
  font-variation-settings:"opsz" 144,"SOFT" 50;
  white-space:nowrap;
}
.footer-grid{
  position:relative;z-index:1;
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:repeat(4,1fr);gap:48px;
}
.footer h4{
  margin:0 0 16px;font-family:var(--mono);font-size:11px;letter-spacing:.24em;
  text-transform:uppercase;color:rgba(244,239,230,.55);font-weight:500;
}
.footer p, .footer ul li{color:rgba(244,239,230,.85);font-size:15px;line-height:1.7}
.footer a:hover{color:var(--bleach)}
.footer-bottom{
  position:relative;z-index:1;
  max-width:var(--max);margin:64px auto 0;
  display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;
  padding-top:24px;border-top:1px solid rgba(244,239,230,.12);
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:rgba(244,239,230,.55);
}
.footer-mono{width:32px;height:32px;opacity:.85}
.back-top a{color:rgba(244,239,230,.7)}
.back-top a:hover{color:var(--cream)}
@media (max-width:780px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .footer-bottom{justify-content:flex-start}
}
@media (max-width:480px){.footer-grid{grid-template-columns:1fr}}

/* ============================ FORMS, MODALS, REGISTRATION ====================
   Founder modal + product modal. Built on top of the existing egg-modal styles
   so we share the open/close UX and the dark glassmorphic aesthetic.
   ============================================================================ */

body.modal-open{overflow:hidden}

/* ============================ CART BUTTON (nav) ============================ */
.cart-btn{
  display:inline-flex;align-items:center;gap:7px;
  padding:6px 12px;border:1px solid rgba(13,13,13,.18);border-radius:999px;
  font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink);background:transparent;cursor:pointer;
  text-shadow:0 0 6px rgba(244,239,230,.85);
  transition:all var(--t-fast);
}
.cart-btn:hover{border-color:var(--bleach);color:var(--bleach)}
.cart-ico{display:inline-block;width:14px;height:14px;flex:none}
.cart-count{
  min-width:18px;height:18px;padding:0 6px;border-radius:9px;
  background:transparent;color:inherit;font-weight:600;display:inline-flex;
  align-items:center;justify-content:center;font-size:10px;
  letter-spacing:0;line-height:1;
}
.cart-count.has-items{background:var(--bleach);color:#fff;text-shadow:none}
/* Over dark sections: cream lines */
body[data-section="hero"]      .cart-btn,
body[data-section="editorial"] .cart-btn,
body[data-section="rewards"]   .cart-btn{
  color:var(--cream);border-color:rgba(244,239,230,.4);
  text-shadow:0 1px 4px rgba(13,13,13,.7);
}
/* Mobile: cart button stays visible (smaller) so customers can access cart from any page */
@media (max-width:980px){
  .cart-btn{padding:5px 9px;font-size:10px;letter-spacing:.1em;gap:4px}
  .cart-btn .cart-ico{font-size:11px}
  .cart-count{min-width:16px;height:16px;font-size:9px}
}

/* ============================ CART DRAWER ============================ */
.cart-modal{max-width:520px;background:var(--cream);color:var(--ink)}
.cart-modal[open]{padding:clamp(28px,4vw,44px) clamp(24px,3vw,36px);background:var(--cream)}
.cart-modal .kicker{color:var(--stone)}
.cart-modal h2{color:var(--ink);margin:6px 0 24px}
.cart-empty{text-align:center;padding:24px 0}
.cart-empty p{color:var(--stone);margin-bottom:18px}
.cart-items{list-style:none;padding:0;margin:0 0 18px;display:grid;gap:10px}
.cart-item{
  display:grid;grid-template-columns:64px 1fr auto;gap:14px;align-items:center;
  padding:12px;background:#fff;border:1px solid rgba(13,13,13,.06);border-radius:10px;
}
.cart-item-img{width:64px;height:64px;object-fit:cover;border-radius:6px;background:var(--cream-2)}
.cart-item-title{font-family:var(--display);font-weight:300;font-size:18px;letter-spacing:-.01em;line-height:1.1}
.cart-item-meta{font-family:var(--mono);font-size:11px;color:var(--stone);letter-spacing:.04em;margin-top:4px}
.cart-item-qty{display:flex;align-items:center;gap:8px;margin-top:8px;font-family:var(--mono);font-size:12px}
.cart-item-qty button{
  width:24px;height:24px;border-radius:4px;border:1px solid rgba(13,13,13,.2);
  background:#fff;cursor:pointer;font-weight:600;color:var(--ink);
}
.cart-item-qty button:hover{background:var(--ink);color:var(--cream)}
.cart-item-qty span{min-width:24px;text-align:center}
.cart-item-remove{
  margin-left:8px;width:auto!important;padding:0 8px!important;font-size:10px;
  border-color:rgba(225,33,39,.3)!important;color:var(--bleach)!important;
}
.cart-item-line{font-family:var(--mono);font-size:13px;font-weight:600;color:var(--ink)}
.cart-totals{
  background:var(--cream-2);padding:14px 16px;border-radius:8px;
  font-family:var(--mono);font-size:13px;margin-bottom:14px;
}
.cart-totals .ot-row{display:flex;justify-content:space-between;padding:3px 0;color:var(--stone)}
.cart-totals .ot-total{padding-top:8px;margin-top:6px;border-top:1px solid rgba(13,13,13,.12);color:var(--ink);font-size:16px;font-weight:700}
.cart-totals .ot-total span:last-child{color:var(--bleach)}
.cart-cta{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:8px}
.cart-cta .btn{flex:1}

/* Mini items list shown inside the order modal */
.order-items-mini{
  background:rgba(244,239,230,.05);border:1px solid rgba(244,239,230,.1);
  border-radius:8px;padding:10px 14px;margin-bottom:14px;font-family:var(--mono);font-size:12px;
}
.omi-row{display:grid;grid-template-columns:1fr auto auto;gap:10px;padding:6px 0;color:rgba(244,239,230,.85)}
.omi-row + .omi-row{border-top:1px dashed rgba(244,239,230,.12)}
.omi-line{color:var(--cream);font-weight:600;min-width:70px;text-align:right}
.omi-qty{color:rgba(244,239,230,.55)}

/* Product modal: size picker */
.product-size-pick{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--stone)}
.product-size-pick select{padding:8px 12px;border:1px solid rgba(13,13,13,.2);border-radius:6px;font:inherit;background:#fff}

/* ===================== ORDER MODAL (pay by transfer) — fallback only ===================== */
.order-modal{max-width:680px;max-height:90vh;overflow-y:auto}
.order-modal[open]{padding:clamp(28px,4vw,48px) clamp(24px,3vw,40px);max-height:90vh;overflow-y:auto}
.order-modal .egg-close{position:sticky;top:0;float:right;background:var(--ink);z-index:5}
.order-summary{
  display:flex;justify-content:space-between;align-items:baseline;
  background:rgba(225,33,39,.08);border:1px solid rgba(225,33,39,.25);
  padding:14px 18px;border-radius:10px;margin:10px 0 18px;
}
.order-sum-title{font-family:var(--display);font-weight:300;font-size:20px;letter-spacing:-.01em}
.order-sum-price{font-family:var(--mono);font-size:14px;color:var(--bleach);font-weight:600}
.order-totals{
  background:rgba(244,239,230,.04);border:1px solid rgba(244,239,230,.1);
  padding:14px 18px;border-radius:8px;margin-bottom:18px;
  font-family:var(--mono);font-size:13px;
}
.ot-row{display:flex;justify-content:space-between;padding:4px 0;color:rgba(244,239,230,.75)}
.ot-row.ot-total{padding-top:10px;margin-top:6px;border-top:1px solid rgba(244,239,230,.15);color:var(--cream);font-size:16px;font-weight:600}
.ot-row.ot-total span:last-child{color:var(--bleach)}
.rf-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.rf-grid .rf-row{margin:0}
.rf-grid .rf-wide{grid-column:1 / -1}
.order-form select,.order-form textarea,.order-form input[type=file]{
  width:100%;padding:11px 13px;border:1px solid rgba(244,239,230,.25);
  background:rgba(255,255,255,.06);color:var(--cream);border-radius:8px;font:inherit;
  font-family:inherit;font-size:14px;
}
.order-form select:focus,.order-form textarea:focus,.order-form input[type=file]:focus{
  outline:none;border-color:var(--bleach);background:rgba(255,255,255,.1);
}
.order-form textarea{resize:vertical;min-height:72px}
.order-form input[type=file]{padding:8px;cursor:pointer}
.rf-hint{display:block;color:rgba(244,239,230,.55);font-size:11px;margin-top:6px;font-family:var(--mono);letter-spacing:.04em}

.order-bank{
  margin:18px 0;padding:18px 22px;border-radius:10px;
  background:rgba(244,239,230,.05);border:1px solid rgba(244,239,230,.12);
}
.order-bank .kicker{color:var(--bleach);margin-bottom:12px}
.bank-grid{display:grid;grid-template-columns:140px 1fr;gap:6px 14px;margin:0 0 8px}
.bank-grid dt{color:rgba(244,239,230,.55);font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase}
.bank-grid dd{margin:0;font-family:var(--mono);font-size:13px;color:var(--cream)}
.bank-note{font-size:12px;color:rgba(244,239,230,.65);margin:8px 0 0;font-style:italic}
.copy-btn{
  margin-left:8px;padding:2px 10px;font-size:10px;letter-spacing:.06em;text-transform:uppercase;
  background:transparent;color:var(--bleach);border:1px solid rgba(225,33,39,.5);border-radius:4px;cursor:pointer;
}
.copy-btn:hover{background:var(--bleach);color:#fff}

.rf-status.ok{color:#7CC392}
.rf-status.err{color:#E12127}
.rf-status{margin:14px 0 0;font-family:var(--mono);font-size:12px}

@media (max-width:580px){
  .rf-grid{grid-template-columns:1fr}
  .bank-grid{grid-template-columns:1fr}
  .bank-grid dt{margin-top:8px}
}

.form-msg{
  margin:14px 0 0;font-family:var(--mono);font-size:12px;letter-spacing:.1em;
}
.form-msg.ok{color:#7CC392}
.form-msg.err{color:#E12127}

/* ----- Founder registration modal ----- */
.register-modal{
  border:0;padding:0;background:transparent;
  max-width:560px;width:calc(100% - 32px);
  border-radius:18px;overflow:hidden;
}
.register-modal[open]{
  position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);
  background:var(--ink);color:var(--cream);
  padding:clamp(36px,5vw,56px) clamp(28px,4vw,48px);
  box-shadow:0 40px 80px -30px rgba(0,0,0,.6);
  animation:eggIn .35s cubic-bezier(.19,.7,.24,1) both;
}
.register-modal::backdrop{
  background:rgba(13,13,13,.78);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  animation:eggFade .25s ease both;
}
.register-modal .kicker{color:rgba(225,33,39,.85);margin:0 0 8px}
.register-modal h2{
  font-family:var(--display);font-weight:300;
  font-size:clamp(28px,4vw,52px);line-height:1;letter-spacing:-.02em;margin:0 0 16px;
  font-variation-settings:"opsz" 144,"SOFT" 50;
}
.register-modal h2 em{font-style:italic;color:var(--bleach)}
.register-body{color:rgba(244,239,230,.85);font-size:15px;line-height:1.55;margin:0 0 22px;max-width:46ch}
.register-modal .fineprint{margin:18px 0 0;color:rgba(244,239,230,.4);font-family:var(--mono);font-size:11px}

.register-form{display:flex;flex-direction:column;gap:10px}
.rf-row{}
.register-form input,
.register-form textarea{
  width:100%;padding:14px 16px;
  background:rgba(244,239,230,.08);
  border:1px solid rgba(244,239,230,.18);
  border-radius:10px;color:var(--cream);
  font:inherit;font-size:15px;outline:0;
  transition:border-color var(--t-fast),background var(--t-fast);
}
.register-form input::placeholder,
.register-form textarea::placeholder{color:rgba(244,239,230,.42)}
.register-form input:focus-visible,
.register-form textarea:focus-visible{border-color:var(--bleach);background:rgba(244,239,230,.12);outline:0}
.register-form textarea{resize:vertical;min-height:80px;font-family:var(--sans)}
.rf-consent{
  display:flex;gap:10px;align-items:flex-start;
  font-family:var(--mono);font-size:11px;letter-spacing:.05em;
  color:rgba(244,239,230,.7);cursor:pointer;
  margin:6px 0 8px;
}
.rf-consent input{width:auto;margin-top:2px;flex:none}
.register-form .btn{align-self:flex-start;margin-top:6px}

/* ----- Product detail modal ----- */
.product-modal{
  border:0;padding:0;background:transparent;
  max-width:1080px;width:calc(100% - 32px);
  border-radius:18px;overflow:hidden;
}
.product-modal[open]{
  position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);
  background:var(--cream);color:var(--ink);
  box-shadow:0 40px 80px -30px rgba(0,0,0,.55);
  animation:eggIn .35s cubic-bezier(.19,.7,.24,1) both;
  max-height:90vh;overflow-y:auto;overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
}
/* Sticky close button — always reachable even when modal content overflows */
.product-modal .product-close{
  position:sticky;top:14px;float:right;z-index:10;margin:14px 14px 0 0;
}
.product-modal::backdrop{
  background:rgba(13,13,13,.7);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
.product-close{
  background:rgba(13,13,13,.08);color:var(--ink);
}
.product-close:hover{background:var(--bleach);color:var(--cream)}
.product-modal-grid{
  display:grid;grid-template-columns:1.1fr 1fr;gap:0;
}
.product-modal-img{background:var(--cream-2)}
.product-modal-img img{
  width:100%;height:100%;object-fit:cover;
  aspect-ratio:4/5;
  display:block;
}
.product-modal-body{
  padding:clamp(28px,4vw,52px) clamp(28px,4vw,52px);
  display:flex;flex-direction:column;gap:14px;
}
.product-modal-body .kicker{color:var(--bleach);margin:0}
.product-modal-body h2{
  font-family:var(--display);font-weight:300;
  font-size:clamp(28px,3.4vw,46px);line-height:1.05;letter-spacing:-.018em;margin:0;
  font-variation-settings:"opsz" 144,"SOFT" 50;
}
.product-modal-meta{
  margin:0;font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--stone);
  text-transform:uppercase;
}
.product-modal-price{
  margin:0;font-weight:600;font-size:24px;color:var(--ink);
  font-variant-numeric:tabular-nums;
}
.product-modal-desc{
  margin:0;color:var(--ink-soft);font-size:15px;line-height:1.65;
}
.product-modal-cta{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
.product-modal-cta .btn-outline{color:var(--ink);border-color:var(--ink)}
.product-modal-cta .btn-outline:hover{background:var(--ink);color:var(--cream);border-color:var(--ink)}
@media (max-width:780px){
  .product-modal-grid{grid-template-columns:1fr}
  .product-modal[open]{max-height:96vh}
}

/* ============================ EASTER EGG ===================================
   Hidden monogram tucked into the editorial photo. Low-opacity, slightly
   off-axis. Visible to the curious; unobtrusive to others. Hover boosts. */
.egg{
  position:absolute;
  bottom:6%;right:7%;
  width:36px;height:36px;
  background:transparent;border:0;padding:0;
  cursor:pointer;
  opacity:.18;
  transition:opacity var(--t),transform var(--t);
  z-index:2;
}
.egg img{width:100%;height:100%;object-fit:contain;
  filter:brightness(0) invert(1);
  pointer-events:none;
}
.egg:hover{opacity:.95;transform:scale(1.12) rotate(-12deg)}
.egg:focus-visible{opacity:.95}
@media (max-width:780px){.egg{width:30px;height:30px;bottom:18px;right:18px}}

/* Easter egg modal */
.egg-modal{
  border:0;padding:0;background:transparent;
  max-width:560px;width:calc(100% - 40px);
  border-radius:18px;overflow:hidden;
}
.egg-modal[open]{
  position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);
  background:var(--ink);color:var(--cream);
  padding:clamp(36px,5vw,56px) clamp(28px,4vw,48px);
  box-shadow:0 40px 80px -30px rgba(0,0,0,.6);
  animation:eggIn .35s cubic-bezier(.19,.7,.24,1) both;
}
.egg-modal::backdrop{
  background:rgba(13,13,13,.7);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  animation:eggFade .25s ease both;
}
@keyframes eggIn  {from{opacity:0;transform:translate(-50%,-46%)}to{opacity:1;transform:translate(-50%,-50%)}}
@keyframes eggFade{from{opacity:0}to{opacity:1}}
.egg-modal .kicker{color:var(--bleach);margin:0 0 8px}
.egg-modal h2{
  font-family:var(--display);font-weight:300;
  font-size:clamp(28px,3.6vw,46px);line-height:1;letter-spacing:-.02em;margin:0 0 18px;
  font-variation-settings:"opsz" 144,"SOFT" 50;
}
.egg-modal h2 em{font-style:italic;color:var(--bleach)}
.egg-body{color:rgba(244,239,230,.85);font-size:15px;line-height:1.6;margin:0 0 20px;max-width:46ch}
.egg-body strong{color:var(--cream)}
.egg-code{
  display:flex;align-items:center;gap:8px;
  background:rgba(244,239,230,.08);border:1px solid rgba(244,239,230,.2);
  border-radius:999px;padding:6px;margin:0 0 12px;
}
.egg-code code{
  flex:1;font-family:var(--mono);font-size:16px;letter-spacing:.18em;
  color:var(--cream);padding:8px 16px;
}
.egg-copy{
  background:var(--bleach);color:var(--cream);
  padding:10px 18px;border-radius:999px;
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  transition:background var(--t-fast),transform var(--t-fast);
}
.egg-copy:hover{background:#fff;color:var(--ink);transform:translateX(2px)}
.egg-modal .fineprint{color:rgba(244,239,230,.45);margin:0 0 24px}
.egg-cta{margin:0}
.egg-art{
  position:absolute;right:-40px;top:-40px;
  width:200px;opacity:.55;pointer-events:none;mix-blend-mode:screen;
}
.egg-close{
  position:absolute;top:14px;right:18px;
  width:32px;height:32px;border-radius:50%;
  background:rgba(244,239,230,.1);color:var(--cream);
  font-size:22px;line-height:1;
  display:grid;place-items:center;
  transition:background var(--t-fast);
}
.egg-close:hover{background:var(--bleach)}

/* ============================ REVEAL / MOTION ==============================
   IMPORTANT: only hide sections when JS has flagged itself as ready (.js).
   If JS fails, html does not get .js, so content stays visible by default. */
.js .capsule,.js .shop,.js .archive,.js .editorial,.js .materials,.js .rewards,.js .events,.js .newsletter,.js .about,.js .footer{
  opacity:0;transform:translateY(28px);transition:opacity 1.1s var(--t),transform 1.1s var(--t);
}
.js .capsule.in,.js .shop.in,.js .archive.in,.js .editorial.in,.js .materials.in,.js .rewards.in,.js .events.in,.js .newsletter.in,.js .about.in,.js .footer.in{
  opacity:1;transform:none;
}
.js .card,.js .tier,.js .material-list li,.js .event-list li,.js .perk{
  opacity:0;transform:translateY(20px);transition:opacity .9s var(--t),transform .9s var(--t);
  transition-delay:calc(var(--i,0) * 80ms);
}
.js .card.in,.js .tier.in,.js .material-list li.in,.js .event-list li.in,.js .perk.in{opacity:1;transform:none}

@media (prefers-reduced-motion:reduce){
  .capsule,.shop,.archive,.editorial,.materials,.rewards,.events,.newsletter,.about,.footer,
  .card,.tier,.material-list li,.event-list li,.perk{
    opacity:1!important;transform:none!important;transition:none!important;
  }
  .hero-bg{transform:none!important}
  .editorial-img img{transform:none!important;transition:none!important}
}
