/* Hansum — the hansum beer. Palette + system from DESIGN.md */
:root{
  --green:#1f3b2c;
  --green-deep:#15281e;
  --gold:#c89b3c;
  --gold-soft:#d9b765;
  --cream:#f4eedd;
  --cream-deep:#ece3cb;
  --ink:#23241f;
  --maxw:1080px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Inter","Helvetica Neue",Arial,sans-serif;
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,.display{
  font-family:"Arvo","Rockwell",Georgia,serif;
  font-weight:700;
  line-height:1.08;
  letter-spacing:-.01em;
}
a{color:inherit}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{
  font-family:"Inter",sans-serif;font-weight:700;
  text-transform:uppercase;letter-spacing:.22em;font-size:.72rem;
  color:var(--gold-soft);  /* lighter gold clears AA on the green bands */
}
/* On cream backgrounds gold-on-cream fails contrast — use brand green instead */
.band.cream .eyebrow,.band.creamdeep .eyebrow{color:var(--green)}

/* Visible keyboard focus everywhere (was relying on browser default) */
:focus-visible{outline:3px solid var(--gold-soft);outline-offset:2px;border-radius:3px}
.hero :focus-visible{outline-color:var(--gold-soft)}
.society input[type=email]:focus-visible{outline:3px solid var(--green-deep);outline-offset:1px}
.btn{
  display:inline-block;background:var(--gold);color:var(--green-deep);
  font-weight:700;text-decoration:none;padding:14px 26px;border-radius:4px;
  border:2px solid var(--green-deep);letter-spacing:.02em;cursor:pointer;
  transition:transform .12s ease, background .12s ease;
}
.btn:hover{background:var(--gold-soft);transform:translateY(-1px)}

/* ---- Hero ---- */
.hero{
  background:var(--green);color:var(--cream);
  border-bottom:6px solid var(--gold);
  position:relative;overflow:hidden;
  text-align:center;padding:64px 0 76px;
}
.hero:before{ /* faint starburst rays behind the badge */
  content:"";position:absolute;inset:0;
  background:
    repeating-conic-gradient(from 0deg at 50% 38%,
      rgba(200,155,60,.05) 0deg 4deg, transparent 4deg 12deg);
  opacity:.6;pointer-events:none;
}
.hero .wrap{position:relative;z-index:1}
.badge{
  width:180px;height:180px;border-radius:50%;
  border:3px double var(--gold);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 22px;background:var(--cream);overflow:hidden;
  box-shadow:0 6px 22px rgba(0,0,0,.28);
}
.badge img{width:100%;height:100%;border-radius:50%;object-fit:cover}
.badge .mug{font-size:62px;line-height:1}
.wordmark{
  font-size:clamp(3.4rem,12vw,7rem);color:var(--cream);
  letter-spacing:-.02em;margin:0;
}
.wordmark .beer{display:block;font-size:.28em;color:var(--gold);
  letter-spacing:.08em;margin-top:-.1em}
.tagline{
  font-family:"Arvo",Georgia,serif;font-size:clamp(1.1rem,3.4vw,1.6rem);
  max-width:660px;margin:20px auto 4px;color:var(--cream);
}
.tagline .gold{color:var(--gold-soft)}
.kicker{font-size:.85rem;color:var(--gold-soft);letter-spacing:.12em;
  text-transform:uppercase}

/* ---- Logo-led hero (the original badge IS the hero) ---- */
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.hero-logo{background:#fcf7f0;color:var(--ink);padding:40px 0 60px}
.hero-logo:before{content:none;display:none}      /* logo has its own starburst */
.hero-logo-img{display:block;width:min(540px,86vw);height:auto;margin:0 auto}
.hero-cap{color:var(--green);text-align:center;margin-top:6px}
/* Form needs contrast on the cream hero */
.hero-logo .society{margin-top:26px}
.hero-logo .society input[type=email]{background:#fff;border:2px solid var(--green);color:var(--ink)}
.hero-logo .society input[type=email]:focus-visible{outline:3px solid var(--green-deep);outline-offset:1px}
.hero-logo .society .fine{color:var(--ink);opacity:.72}
.hero-logo .society .ok{color:var(--green)}

/* ---- Signup ---- */
.society{margin:34px auto 0;max-width:520px}
.society form{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}
.society input[type=email]{
  flex:1 1 260px;padding:14px 16px;border-radius:4px;border:2px solid var(--gold);
  background:var(--cream);color:var(--ink);font-size:1rem;font-family:inherit;
}
.society .fine{font-size:.8rem;color:var(--cream-deep);opacity:.92;margin-top:12px}
.band.cream .society .fine{color:var(--ink);opacity:.75}
.society .hp{position:absolute;left:-9999px}
.society .ok{display:none;margin-top:16px;font-family:"Arvo",serif;color:var(--gold-soft)}

/* ---- Sections ---- */
section.band{padding:72px 0}
.band.cream{background:var(--cream)}
.band.creamdeep{background:var(--cream-deep)}
.band.green{background:var(--green);color:var(--cream)}
/* .lead is now an <h2> for heading hierarchy; pin font so the look is unchanged */
.lead{font-family:"Inter","Helvetica Neue",Arial,sans-serif;font-weight:400;font-size:clamp(1.5rem,4vw,2.4rem);line-height:1.28;letter-spacing:0;max-width:760px;margin:0 auto;text-align:center}
.lead .gold{color:var(--gold)}
.sub{max-width:680px;margin:18px auto 0;text-align:center;font-size:1.08rem;opacity:.92}

/* "Why Hansum" — a vintage three-reason ledger, not a SaaS card grid */
.reasons-title{color:var(--cream);font-size:clamp(1.4rem,3.6vw,2rem);max-width:720px;
  margin:14px auto 4px;text-align:center}
.reasons-list{list-style:none;display:grid;grid-template-columns:repeat(3,1fr);
  gap:0;margin-top:40px;padding:0}
.reasons-list li{padding:6px 30px;position:relative}
.reasons-list li + li{border-left:1px solid rgba(217,183,101,.38)}
.reasons-list .rn{font-family:"Arvo",serif;font-weight:700;font-size:2.6rem;
  color:var(--gold-soft);display:block;line-height:1;margin-bottom:12px}
.reasons-list h3{color:var(--cream);font-size:1.18rem;margin-bottom:8px}
.reasons-list p{color:var(--cream);opacity:.9;font-size:.99rem}
@media(max-width:760px){
  .reasons-list{grid-template-columns:1fr}
  .reasons-list li{padding:22px 0}
  .reasons-list li + li{border-left:none;border-top:1px solid rgba(217,183,101,.38)}
  .reasons-list .rn{margin-bottom:6px;font-size:2.2rem}
}

/* ---- Origin (Kai's drawing) ---- */
.origin-grid{display:grid;grid-template-columns:0.85fr 1.15fr;gap:46px;align-items:center;margin-top:26px}
.origin-art{margin:0}
.origin-art img{width:100%;height:auto;display:block;border:12px solid #fffdf8;border-radius:3px;
  box-shadow:0 12px 34px rgba(21,40,30,.22)}
.origin-art figcaption{margin-top:14px;text-align:center;font-style:italic;color:var(--ink);opacity:.68;font-size:.9rem}
.origin-copy .lead{margin-bottom:16px}
.origin-copy p{font-size:1.1rem;margin-bottom:14px}
@media(max-width:760px){ .origin-grid{grid-template-columns:1fr;gap:26px} }

/* ---- Store ---- */
.btn.ghost{background:transparent;color:var(--green);border:2px solid var(--green)}
.btn.ghost:hover{background:var(--green);color:var(--cream)}
.store-feature{display:grid;grid-template-columns:0.7fr 1.3fr;gap:44px;align-items:center}
.store-feature-art img{width:min(260px,60vw);height:auto;border-radius:50%;background:var(--cream);
  padding:14px;box-shadow:0 10px 28px rgba(0,0,0,.3);display:block;margin:0 auto}
.store-perks{list-style:none;margin:8px 0 14px;padding:0;color:var(--cream)}
.store-perks li{padding:4px 0 4px 26px;position:relative}
.store-perks li:before{content:"✦";position:absolute;left:0;color:var(--gold-soft)}
.store-price{font-family:"Arvo",serif;font-weight:700;color:var(--gold-soft);font-size:2rem;margin:6px 0 14px}
.store-price span{font-size:.8rem;font-weight:400;opacity:.8}
.store-price.dark{color:var(--green)}
.store-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:40px}
.store-card{background:var(--cream);border:2px solid var(--green);border-radius:8px;padding:24px;text-align:center}
.store-card-art{font-size:48px;line-height:1;margin-bottom:12px}
.store-card-art img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:8px;display:block;border:1px solid var(--cream-deep)}
/* product variant selector (color swatches + size) */
.product .store-card-art img{background:#fff}
.pv-swatches{display:flex;flex-wrap:wrap;gap:7px;justify-content:center;margin:2px 0 10px;min-height:24px;max-height:132px;overflow-y:auto;padding:2px 4px}
.pv-swatches::-webkit-scrollbar{width:6px}
.pv-swatches::-webkit-scrollbar-thumb{background:var(--cream-deep);border-radius:3px}
.pv-swatches .sw{width:22px;height:22px;border-radius:50%;border:2px solid #fff;box-shadow:0 0 0 1px var(--cream-deep);cursor:pointer;padding:0;transition:transform .1s}
.pv-swatches .sw:hover{transform:scale(1.12)}
.pv-swatches .sw.on{box-shadow:0 0 0 2px var(--green)}
.pv-controls{margin:0 0 10px;min-height:30px}
.pv-sizelbl{font-size:.85rem;color:var(--ink);opacity:.85;display:inline-flex;align-items:center;gap:8px}
.pv-size{padding:6px 10px;border:2px solid var(--green);border-radius:4px;background:#fff;color:var(--ink);font-family:inherit;font-size:.95rem;cursor:pointer}
.store-card h3{font-size:1.05rem;margin-bottom:6px}
.store-card-line{font-size:.9rem;opacity:.85;margin-bottom:8px;min-height:2.4em}
.store-card .btn{margin-top:6px}
@media(max-width:900px){ .store-grid{grid-template-columns:repeat(2,1fr)} }
@media(max-width:760px){ .store-feature{grid-template-columns:1fr;gap:24px;text-align:center} .store-perks{display:inline-block;text-align:left} }

/* ---- Lineup ---- */
.lineup{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:44px}
.sku{display:flex;justify-content:space-between;align-items:baseline;gap:16px;
  padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.18)}
.band.green .sku{border-color:rgba(244,238,221,.18)}
.sku .name{font-family:"Arvo",serif;font-weight:700}
.sku .line{font-style:italic;opacity:.82;text-align:right}
.sku .soon{font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-soft)}

/* ---- Footer ---- */
footer{background:var(--green-deep);color:var(--cream-deep);padding:48px 0;text-align:center;
  border-top:6px solid var(--gold)}
footer .wm{font-family:"Arvo",serif;font-size:2rem;color:var(--cream)}
footer a{color:var(--gold-soft)}
.legal{font-size:.8rem;opacity:.7;margin-top:18px}
.drink{font-size:.78rem;opacity:.7;margin-top:8px}

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