/* =========================================================================
   HIGH REGARDS ROSIN BAR — Design System
   Crisp white sticker-pop · thick black outlines · honey-gold rosin drip
   ========================================================================= */

/* ---------- Fonts ---------- */
@import url('https://fonts.googleapis.com/css2?family=Atkinson+Hyperlegible:ital,wght@0,400;0,700;1,400;1,700&family=Bricolage+Grotesque:opsz,wght@12..96,600;12..96,700;12..96,800&family=Permanent+Marker&display=swap');

/* ---------- Tokens ---------- */
:root{
  /* paper + ink */
  --paper:#ffffff;
  --cream:#fff7e8;
  --grey:#f3f4f7;
  --ink:#16120c;
  --ink-soft:#4b4337;

  /* honey */
  --gold:#f6b908;
  --gold-deep:#d98a00;
  --gold-pale:#ffe39a;

  /* pops */
  --blue:#2a27cf;
  --pink:#e5189a;
  --green:#56c12c;
  --red:#d8362b;
  --steel:#9aa0a8;
  --purple:#6c3bd1;

  /* structure */
  --bw:3px;                       /* sticker border width */
  --radius:10px;
  --radius-lg:14px;
  --shadow:3px 3px 0 rgba(22,18,12,.5);    /* hard offset, softer */
  --shadow-sm:2px 2px 0 rgba(22,18,12,.45);
  --shadow-lg:5px 5px 0 rgba(22,18,12,.45);
  --maxw:1180px;
  --ease:cubic-bezier(.34,1.56,.64,1); /* bouncy overshoot */

  --font-display:'Bricolage Grotesque',system-ui,sans-serif;
  --font-body:'Atkinson Hyperlegible',system-ui,sans-serif;
  --font-mark:'Permanent Marker',cursive;
}

/* ---------- Reset ---------- */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.55;
  font-size:18px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
ul{list-style:none}

/* ---------- Type ---------- */
h1,h2,h3,h4{font-family:var(--font-display);line-height:1.02;letter-spacing:-.02em;font-weight:800}
h1{font-size:clamp(2.6rem,6vw,5rem)}
h2{font-size:clamp(2rem,4.4vw,3.4rem)}
h3{font-size:clamp(1.3rem,2.2vw,1.7rem)}
p{text-wrap:pretty}
.lead{font-size:clamp(1.05rem,1.6vw,1.35rem);color:var(--ink-soft);max-width:60ch}
h2 + .lead{margin-top:13px}
.gold-text{color:var(--gold-deep)}

/* kicker — marker font, used sparingly */
.kicker{
  font-family:var(--font-mark);
  color:var(--gold-deep);
  font-size:calc(1.15rem + 1px);
  letter-spacing:.01em;
  transform:rotate(-2deg);
  display:inline-block;
  margin-bottom:calc(.4rem + 10px);
}

/* ---------- Layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,4vw,40px)}
section{position:relative}
.band{padding:clamp(64px,9vw,120px) 0}
.band--cream{background:var(--paper)}
.band--grey{background:var(--paper)}
.band--gold{background:var(--gold)}
.band--ink{background:var(--ink);color:var(--paper)}
.center{text-align:center}
.center .lead{margin-left:auto;margin-right:auto}
.grid{display:grid;gap:clamp(18px,2.4vw,30px)}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}
.section-head{margin-bottom:clamp(32px,5vw,56px)}
.section-head .lead{margin-top:.6rem}

/* ---------- Sticker card ---------- */
.sticker{
  background:var(--paper);
  border:1px solid var(--ink);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:clamp(20px,2.6vw,30px);
  transition:transform .3s var(--ease), box-shadow .3s var(--ease);
  position:relative;
}
.sticker:hover{transform:translate(-2px,-4px) rotate(-.6deg);box-shadow:var(--shadow-lg)}
.rot-1{transform:rotate(-1.4deg)}
.rot-2{transform:rotate(1.2deg)}
.rot-3{transform:rotate(-.7deg)}
.rot-1:hover,.rot-2:hover,.rot-3:hover{transform:translate(-2px,-4px) rotate(0deg);box-shadow:var(--shadow-lg)}

/* ---------- Tape strip (washi tape) ---------- */
.tape{
  position:absolute;
  top:-15px;left:50%;
  transform:translateX(-50%) rotate(-3deg);
  background:var(--gold-pale);
  border:2px solid var(--ink);
  font-family:var(--font-mark);
  font-size:.95rem;
  padding:2px 16px;
  box-shadow:2px 2px 0 var(--ink);
  white-space:nowrap;
  z-index:2;
}
.tape--blue{background:#bcd0ff}
.tape--pink{background:#ffc6e8}

/* ---------- Chips ---------- */
.chip{
  display:inline-flex;align-items:center;gap:.35em;
  font-weight:700;font-size:.78rem;letter-spacing:.01em;
  border:2px solid var(--ink);
  border-radius:7px;
  padding:3px 12px;
  background:var(--paper);
  box-shadow:2px 2px 0 var(--ink);
}
.chip--gold{background:var(--gold)}
.chip--blue{background:var(--blue);color:#fff}
.chip--pink{background:var(--pink);color:#fff}
.chip--green{background:var(--green)}
.chip--red{background:var(--red);color:#fff}
.chip--steel{background:var(--steel);color:#fff}
.chip--purple{background:var(--purple);color:#fff}
/* colored chips: white text + white outline */
.chip--gold,.chip--green,.chip--red,.chip--blue,.chip--pink,.chip--purple{color:#fff;border-color:#fff}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5em;
  font-family:var(--font-display);font-weight:800;font-size:1.02rem;
  border:var(--bw) solid var(--ink);
  border-radius:9px;
  padding:.7em 1.4em;
  background:var(--gold);color:var(--ink);
  box-shadow:var(--shadow-sm);
  transition:transform .18s var(--ease), box-shadow .18s var(--ease), background .2s;
  white-space:nowrap;
}
.btn:hover{transform:translate(-1px,-2px);box-shadow:var(--shadow)}
.btn:active{transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink)}
.btn--ink{background:var(--ink);color:#fff}
.btn--white{background:#fff}
.btn--pink{background:var(--pink);color:#fff}
.btn--blue{background:var(--blue);color:#fff}
.btn--ghost{background:transparent;box-shadow:none}
.btn--ghost:hover{background:var(--gold-pale);box-shadow:var(--shadow-sm)}
.btn--sm{font-size:.9rem;padding:.5em 1.1em}
.btn--lg{font-size:1.15rem;padding:.8em 1.7em}
/* solid (non-white/ghost/ink) buttons: white text + white outline */
.btn:not(.btn--white):not(.btn--ghost):not(.btn--ink){color:#fff;border-color:#fff}

/* ---------- Honey-drip divider ---------- */
.drip{display:block;width:100%;height:34px;color:var(--gold);position:relative;z-index:1}
.drip svg{width:100%;height:100%;display:block}
.drip--flip{transform:scaleY(-1)}

/* ---------- Image / scene placeholder ---------- */
.ph{
  border:var(--bw) dashed var(--ink);
  border-radius:var(--radius);
  background:
    repeating-linear-gradient(45deg,
      rgba(251,178,1,.10) 0 14px,
      rgba(251,178,1,.20) 14px 28px);
  display:flex;align-items:center;justify-content:center;text-align:center;
  color:var(--ink-soft);
  font-family:'Courier New',monospace;
  font-size:.82rem;
  padding:24px;
  min-height:240px;
}
.ph code{background:rgba(22,18,12,.07);padding:1px 6px;border-radius:5px}

/* ---------- Strain badge placeholder (honey circle) ---------- */
.badge-incoming{
  aspect-ratio:1;width:100%;
  border-radius:50%;
  border:var(--bw) solid var(--ink);
  background:radial-gradient(circle at 38% 32%, var(--gold-pale), var(--gold) 60%, var(--gold-deep));
  box-shadow:var(--shadow-sm), inset 0 -8px 22px rgba(0,0,0,.12);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:18px;
}
.badge-incoming .bi-name{font-family:var(--font-display);font-weight:800;font-size:1.15rem;line-height:1}
.badge-incoming .bi-tag{font-family:var(--font-mark);font-size:.8rem;margin-top:6px;color:var(--ink-soft)}

/* =========================================================================
   HEADER / NAV
   ========================================================================= */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(6px);
  border-bottom:var(--bw) solid var(--ink);
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:12px 0}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:800;font-size:1.25rem}
.brand-logo{height:42px;width:auto;display:block}
@media(max-width:520px){.brand-logo{height:34px}}
.brand .brand-globe{width:34px;height:34px;border-radius:50%;flex:none}
.brand-globe{
  border-radius:50%;
  background:
    radial-gradient(circle at 36% 28%, #ffffff 0%, #eef0f2 14%, #c2c7cd 42%, #868d95 66%, #5e646b 82%, #aeb3b9 100%);
  border:2.5px solid var(--ink);
  box-shadow:2px 2px 0 var(--ink), inset -6px -8px 16px rgba(0,0,0,.28), inset 5px 5px 12px rgba(255,255,255,.55);
}
.brand b{color:var(--gold-deep)}
.nav-links{display:flex;align-items:center;gap:6px}
.nav-links a{
  font-weight:700;font-size:.98rem;padding:7px 12px;border-radius:999px;
  border:2px solid transparent;transition:background .2s,border-color .2s;
}
.nav-links a:hover{background:var(--gold-pale)}
.nav-links a.active{background:var(--gold);border-color:#fff;box-shadow:2px 2px 0 var(--ink)}
.nav-shop{margin-left:6px}
.burger{display:none;border:var(--bw) solid var(--ink);background:var(--ink);
  width:46px;height:42px;border-radius:12px;box-shadow:var(--shadow-sm);
  flex-direction:column;gap:4px;align-items:center;justify-content:center}
.burger span{display:block;width:20px;height:2.6px;background:#fff;border-radius:2px;transition:.25s}

@media(max-width:880px){
  .nav-links{
    position:absolute;top:100%;left:0;right:0;
    flex-direction:column;align-items:stretch;gap:4px;
    background:var(--paper);border-bottom:var(--bw) solid var(--ink);
    padding:14px clamp(20px,4vw,40px);
    transform:translateY(-8px);opacity:0;pointer-events:none;transition:.25s var(--ease);
  }
  .nav-links.open{transform:none;opacity:1;pointer-events:auto}
  .nav-links a{padding:11px 12px}
  .nav-shop{margin:6px 0 0}
  .burger{display:flex}
}

/* =========================================================================
   FOOTER
   ========================================================================= */
.site-footer{background:var(--ink);color:#fff;padding:clamp(48px,7vw,80px) 0 0}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.3fr;gap:36px}
.footer-grid h4{color:var(--gold);font-size:1.05rem;margin-bottom:14px;font-family:var(--font-display)}
.footer-grid a{color:#d8d2c6;display:block;padding:4px 0;transition:color .2s}
.footer-grid a:hover{color:var(--gold)}
.footer-grid .btn{display:inline-flex;justify-content:center;text-align:center;color:#fff}
/* guide: equipment icons — white outline */
#kit .ic{border-color:#fff}
.footer-brand{font-family:var(--font-display);font-weight:800;font-size:1.4rem;margin-bottom:8px}
.footer-brand b{color:var(--gold)}
.footer-desc{color:#aaa498;max-width:34ch}
.footer-bar{
  margin-top:48px;border-top:1px solid rgba(255,255,255,.14);
  padding:20px 0;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;
  color:#8f8a80;font-size:.88rem;
}
.age-badge{
  font-family:var(--font-display);font-weight:800;color:var(--ink);
  background:var(--gold);border:2px solid var(--gold-pale);
  padding:5px 14px;border-radius:999px;font-size:.85rem;
}
@media(max-width:820px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footer-grid{grid-template-columns:1fr}}

/* =========================================================================
   AGE GATE
   ========================================================================= */
.agegate{
  position:fixed;inset:0;z-index:200;
  background:var(--gold);
  background-image:radial-gradient(rgba(255,255,255,.4) 1.4px,transparent 1.5px);
  background-size:26px 26px;
  display:flex;align-items:center;justify-content:center;padding:24px;
  transition:opacity .4s ease, visibility .4s;
}
.agegate.hide{opacity:0;visibility:hidden}
.agegate-card{
  background:var(--paper);border:var(--bw) solid var(--ink);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);max-width:440px;text-align:center;padding:clamp(28px,5vw,46px);
}
.agegate-card .brand-globe{width:62px;height:62px;margin:0 auto 18px}
.agegate-logo{width:min(280px,74%);height:auto;margin:0 auto 18px;display:block}
.agegate-card h2{margin-bottom:10px}
.agegate-card p{color:var(--ink-soft);margin-bottom:24px}
.agegate-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* =========================================================================
   HERO (home)
   ========================================================================= */
.hero{padding:clamp(40px,6vw,80px) 0 clamp(20px,3vw,40px)}
.hero-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(30px,5vw,60px);align-items:center}
.hero-mark{font-family:var(--font-display);font-weight:800;font-size:clamp(2rem,3.4vw,2.7rem);
  display:inline-flex;align-items:center;gap:12px;margin-bottom:14px}
.hero-mark .brand-globe{width:48px;height:48px}
.hero-logo{width:min(430px,82%);height:auto;display:block;margin-bottom:6px}
.hero h1{margin:.2em 0 .4em}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:26px}
.hero-scene{position:relative}
.hero-scene .ph{min-height:380px}
.hero-art{display:block;width:100%;height:auto;border-radius:var(--radius)}
.float-sticker{position:absolute;border:var(--bw) solid var(--ink);border-radius:50%;
  box-shadow:var(--shadow);display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-weight:800;text-align:center;background:#fff}
.float-1{width:96px;height:96px;bottom:-22px;left:-22px;background:var(--green);animation:bob 4s ease-in-out infinite}
.float-2{width:80px;height:80px;top:-22px;right:-14px;background:var(--ink);color:#fff;animation:bob 5s ease-in-out infinite .5s}
@keyframes bob{0%,100%{transform:translateY(0) rotate(-3deg)}50%{transform:translateY(-10px) rotate(3deg)}}

@media(max-width:880px){
  .hero-grid{grid-template-columns:1fr}
  .g-4{grid-template-columns:repeat(2,1fr)}
  .g-3{grid-template-columns:1fr}
  .g-2{grid-template-columns:1fr}
}
@media(max-width:520px){
  .g-4{grid-template-columns:1fr}
  body{font-size:17px}
}

/* ---------- Feature / icon card ---------- */
.feature{text-align:center}
.feature .ic{width:64px;height:64px;border-radius:16px;border:var(--bw) solid var(--ink);
  display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:1.8rem;
  box-shadow:var(--shadow-sm);background:var(--gold-pale)}
.feature h3{margin-bottom:6px;font-size:calc(1.05rem + 2pt)}
.feature .ic--img{background:#fff;padding:0;overflow:hidden;border-color:var(--gold)}
.feature .ic--img img{width:100%;height:100%;object-fit:cover}
/* welcome icons that use full hand-drawn art / logos */
.feature .ic--art{width:94px;height:94px;border:none;background:transparent;box-shadow:none;padding:0;border-radius:16px;overflow:hidden}
.feature .ic--art img{width:100%;height:100%;object-fit:contain}
.feature .ic--badge{border-radius:50%}
.feature .ic--badge img{object-fit:cover}
/* circular hand-drawn section badge (Rosin / Dab rigs / Rosin pressing logos) */
.hero-badge{display:block;margin:0 auto 20px;width:min(240px,56vw);height:auto}
.feature p{color:var(--ink-soft);font-size:.98rem}

/* ---------- Strain card ---------- */
.strain-card{display:flex;flex-direction:column;gap:14px;border:1px solid var(--ink)}
.strain-card .strain-tags .chip{color:#fff;border-color:#fff;box-shadow:var(--shadow)}
.strain-art{aspect-ratio:1;border-radius:8px;border:none;
  background:#fff;overflow:hidden;display:flex;align-items:center;justify-content:center;position:relative}
.strain-art img{width:100%;height:100%;object-fit:contain;padding:6px}
.house-flag{position:absolute;bottom:7px;right:10px;z-index:2;color:var(--red);
  font-family:var(--font-mark);font-size:.85rem;line-height:1}
/* flavour icon row */
.flav-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:2px}
.flav-lbl{font-family:var(--font-display);font-weight:800;color:var(--ink);font-size:.78rem;line-height:1.25}
.flav{width:20px;height:20px;border-radius:50%;border:none;object-fit:cover;background:#fff}
.strain-head{display:flex;align-items:center;justify-content:space-between;gap:8px}
.strain-card h3{font-size:1.2rem;line-height:1.1;min-height:2.4em;display:flex;align-items:flex-end}
.strain-tags{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:4px}
/* icon chip — uses the hand-drawn effect/terpene icons */
.ichip{display:inline-flex;align-items:center;gap:5px;font-weight:700;font-size:.78rem;
  border:2px solid var(--ink);border-radius:7px;padding:2px 11px 2px 3px;background:#fff;box-shadow:2px 2px 0 var(--ink)}
.ichip img{width:24px;height:24px;border-radius:50%;object-fit:cover;flex:none}
.ichip--eff{background:#fff}
.ichip--energy{background:#fff}
.strain-sub{font-family:var(--font-mark);color:var(--gold-deep);font-size:.85rem;margin-top:-6px}
.strain-note{color:var(--ink-soft);font-size:.95rem}
.terps{display:flex;align-items:center;flex-wrap:wrap;gap:6px;margin-top:auto;padding-top:6px}
/* ---------- Structured spec rows: Effect / Flavours / Terpenes ---------- */
.spec{display:grid;grid-template-columns:72px 1fr;gap:4px 8px;align-items:start;margin-top:7px}
.terps-row{margin-top:auto;padding-top:9px}
.spec .flav-lbl{padding-top:3px}
.spec-v{display:flex;flex-wrap:wrap;align-items:center;gap:5px 12px}
.spec-v .ichip,.spec-v .chip{border:none;box-shadow:none;background:none;padding:0;font-weight:700;font-size:.82rem;color:var(--ink);gap:6px}
.spec-v .ichip img{width:20px;height:20px}
.fitem{display:inline-flex;align-items:center;gap:6px;font-weight:600;font-size:.82rem;color:var(--ink)}
.terp{display:inline-flex;align-items:center;gap:6px;font-weight:700;font-size:.82rem;color:var(--ink)}
.terp::before{content:"";width:12px;height:12px;border-radius:3px;background:var(--tc,#ccc);flex:none;box-shadow:1px 1px 0 rgba(0,0,0,.22)}
.terp img{width:20px;height:20px;border-radius:50%;object-fit:cover;flex:none}
/* terpene key legend + guide colour dots */
.terp-key{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:11px 18px;max-width:840px;margin:36px auto 0;padding:16px 22px;border:var(--bw) solid var(--ink);border-radius:var(--radius);background:#fff;box-shadow:var(--shadow-sm)}
.terp-key-lbl{font-family:var(--font-display);font-weight:800;color:var(--ink);font-size:1rem}
.tdot{display:inline-block;width:15px;height:15px;border-radius:4px;background:var(--tc,#ccc);box-shadow:1px 1px 0 rgba(0,0,0,.22);margin-right:9px;vertical-align:-1px}
/* rig / slurper product image frame */
.rig-art{height:230px;display:flex;align-items:center;justify-content:center;margin-top:-4px}
.rig-art img{max-width:100%;max-height:100%;object-fit:contain}

/* ---------- Stat card ---------- */
.stat{text-align:center}
.stat .num{font-family:var(--font-display);font-weight:800;font-size:2.4rem;color:var(--gold-deep);line-height:1}
.stat .lbl{font-weight:700;margin-top:4px}
.stat .desc{color:var(--ink-soft);font-size:.9rem;margin-top:4px}

/* ---------- Eye of the universe ---------- */
.eye{height:130px;width:auto;display:block}
.eye .eye-iris{transform-origin:center;animation:blink 6s ease-in-out infinite}
@keyframes blink{0%,42%,48%,100%{transform:scaleY(1)}45%{transform:scaleY(.08)}}

/* ---------- Reveal on scroll ----------
   Content is visible by DEFAULT. Hiding only activates once JS adds .js to
   <html>, so if scripting fails (or is slow) everything still shows. */
.js .reveal{opacity:0;transform:translateY(26px);transition:opacity .6s ease,transform .6s var(--ease)}
.js .reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .js .reveal{opacity:1;transform:none;transition:none}
  .float-1,.float-2,.eye .eye-iris{animation:none}
}

/* ---------- Video / modal ---------- */
.play-ph{position:relative;cursor:pointer;min-height:300px}
.play-btn{position:absolute;inset:0;margin:auto;width:84px;height:84px;border-radius:50%;
  background:var(--gold);border:var(--bw) solid var(--ink);box-shadow:var(--shadow);
  display:flex;align-items:center;justify-content:center;transition:transform .2s var(--ease)}
.play-ph:hover .play-btn{transform:scale(1.08)}
.play-btn::after{content:"";border-left:22px solid var(--ink);border-top:14px solid transparent;
  border-bottom:14px solid transparent;margin-left:6px}
.modal{position:fixed;inset:0;z-index:150;background:rgba(22,18,12,.86);
  display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;visibility:hidden;transition:.3s}
.modal.open{opacity:1;visibility:visible}
.modal-box{background:var(--paper);border:var(--bw) solid var(--ink);border-radius:var(--radius);
  box-shadow:var(--shadow-lg);max-width:840px;width:100%;padding:18px}
.modal-box .ratio{aspect-ratio:16/9;background:var(--grey);border-radius:12px;display:flex;
  align-items:center;justify-content:center;border:2px solid var(--ink)}
.modal-close{float:right;border:2px solid var(--ink);background:var(--gold);border-radius:50%;
  width:38px;height:38px;font-weight:800;box-shadow:2px 2px 0 var(--ink);margin-bottom:8px}

/* =========================================================================
   PERFECT-DAB TIMER
   ========================================================================= */
.timer-card{max-width:520px;margin:0 auto;text-align:center}
.timer-lanes{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-bottom:26px}
.lane-btn{font-family:var(--font-display);font-weight:800;font-size:.92rem;
  border:var(--bw) solid var(--ink);border-radius:999px;padding:.5em 1.1em;background:#fff;
  box-shadow:var(--shadow-sm);transition:transform .18s var(--ease),box-shadow .18s var(--ease)}
.lane-btn:hover{transform:translate(-1px,-2px);box-shadow:var(--shadow)}
.lane-btn.lane-on[data-lane="flavour"]{background:var(--blue);color:#fff}
.lane-btn.lane-on[data-lane="standard"]{background:var(--gold)}
.lane-btn.lane-on[data-lane="clouds"]{background:var(--red);color:#fff}
.timer-ring{position:relative;width:220px;height:220px;margin:0 auto 22px}
.timer-ring svg{width:100%;height:100%;transform:rotate(-90deg)}
.ring-bg{fill:none;stroke:var(--grey);stroke-width:16}
.ring-fg{fill:none;stroke:var(--gold-deep);stroke-width:16;stroke-linecap:round;transition:stroke-dashoffset 1s linear,stroke .4s}
.ring-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.ring-center [data-read]{font-family:var(--font-display);font-weight:800;font-size:3.4rem;line-height:1}
.ring-center [data-phase]{font-family:var(--font-mark);color:var(--gold-deep);font-size:1.1rem;margin-top:2px}
.timer-chips{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-bottom:16px}
.timer-chips .chip{transition:opacity .3s}
[data-hint]{min-height:2.6em;color:var(--ink-soft);font-weight:600;max-width:36ch;margin:0 auto 18px}
.timer-actions{display:flex;gap:12px;justify-content:center}
.confetti-bit{position:absolute;width:10px;height:10px;border:2px solid var(--ink);border-radius:2px;
  pointer-events:none;animation:pop 1s var(--ease) forwards}
@keyframes pop{0%{transform:translate(-50%,-50%) scale(.4)}100%{transform:translate(calc(-50% + var(--dx)),calc(-50% + var(--dy))) scale(1) rotate(220deg);opacity:0}}

/* ---------- Strain library controls ---------- */
.lib-controls{display:flex;gap:14px;justify-content:space-between;align-items:center;flex-wrap:wrap;margin-bottom:32px}
.filter-row{display:flex;gap:8px;flex-wrap:wrap}
.search-box{position:relative}
.search-box input{font-family:var(--font-body);font-weight:600;font-size:1rem;
  border:var(--bw) solid var(--ink);border-radius:999px;padding:.6em 1.2em;background:#fff;
  box-shadow:var(--shadow-sm);min-width:240px}
.search-box input:focus{outline:none;box-shadow:var(--shadow)}
.empty-msg{text-align:center;padding:40px;font-family:var(--font-mark);font-size:1.3rem;color:var(--ink-soft)}

/* ---------- Step (numbered) ---------- */
.step{display:flex;gap:18px;align-items:flex-start}
.step .n{flex:none;width:46px;height:46px;border-radius:50%;border:var(--bw) solid #fff;
  background:var(--gold);color:#fff;font-family:var(--font-display);font-weight:800;font-size:1.3rem;
  display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}
.step h3{font-size:1.2rem;margin-bottom:2px}
.step p{color:var(--ink-soft);font-size:.97rem}

/* ---------- Temperature row ---------- */
.temp-row{display:flex;align-items:center;gap:18px;border:var(--bw) solid var(--ink);
  border-radius:var(--radius);padding:18px 22px;background:#fff;box-shadow:var(--shadow-sm)}
.temp-row .band-chip{flex:none;width:90px;font-family:var(--font-display);font-weight:800;color:#fff;
  text-align:center;padding:8px;border-radius:12px;border:2px solid #fff}
.temp-low .band-chip{background:var(--blue)}
.temp-mid .band-chip{background:var(--gold);color:var(--ink)}
.temp-high .band-chip{background:var(--red)}
.temp-row .t-deg{font-family:var(--font-display);font-weight:800;font-size:1.05rem}
.temp-row .t-desc{color:var(--ink-soft);font-size:.95rem}

/* ---------- Daily Melt time ---------- */
.melt-time{font-family:var(--font-display);font-weight:800;font-size:clamp(2.4rem,5.5vw,3.6rem);color:var(--gold-deep);line-height:1;letter-spacing:-.02em}
.melt-arrow{color:var(--steel);font-size:.7em;vertical-align:.06em}
/* bar price menu (on dark band) */
.melt-menu{display:grid;gap:9px;max-width:400px;margin-top:8px}
.melt-price{display:flex;align-items:baseline;justify-content:space-between;gap:10px;
  border-bottom:1px dashed rgba(255,255,255,.28);padding-bottom:7px;color:#e8e2d6;font-weight:600}
.melt-price .pp{font-family:var(--font-display);font-weight:800;color:var(--gold);font-size:1.25rem;white-space:nowrap}
.melt-price .pt{font-family:var(--font-mark);font-size:.72rem;color:#a59f93;margin-left:6px}
/* Daily Melt runs on the yellow band — flip the dark-band text to ink */
.band--gold .melt-price{border-bottom-color:rgba(22,18,12,.22);color:var(--ink)}
.band--gold .melt-price .pp{color:var(--ink)}
.band--gold .melt-price .pt{color:var(--ink-soft)}

/* ---------- Reference-code callout ---------- */
.refcode-card{background:var(--gold);border:var(--bw) solid var(--ink);border-radius:var(--radius);
  box-shadow:var(--shadow-sm);padding:22px 24px;max-width:560px;margin:24px auto 0;text-align:center}
.refcode{display:inline-flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:center;margin-top:10px}
.refcode-code{font-family:var(--font-display);font-weight:800;font-size:clamp(1.5rem,3.4vw,1.95rem);
  background:#fff;border:var(--bw) solid var(--ink);border-radius:10px;padding:3px 18px;
  box-shadow:2px 2px 0 var(--ink);color:var(--ink);letter-spacing:.01em}
.refcode-note{font-size:.9rem;color:var(--ink-soft);margin:12px auto 0;max-width:48ch}
.btn.is-copied{background:var(--green)}

/* ---------- Extra heading-to-text spacing (20pt) ---------- */
h2 + .lead{margin-top:20px}
.section-head .lead{margin-top:20px}

/* ---------- "The simple version" tape: red bg, white text+border ---------- */
.tape--simple{background:var(--red);color:#fff;border-color:#fff;box-shadow:2px 2px 0 rgba(22,18,12,.45)}

/* ---------- Terpene feature cards: border matches terpene colour, thicker ---------- */
.terp-border-myrcene{border-color:#4fa3e6;border-width:4px}
.terp-border-limonene{border-color:#f4d52e;border-width:4px}
.terp-border-caryophyllene{border-color:#e8a33d;border-width:4px}
.terp-border-pinene{border-color:#5fa878;border-width:4px}
.terp-border-linalool{border-color:#a653d4;border-width:4px}
.terp-border-terpinolene{border-color:#2bb1a6;border-width:4px}

/* ---------- Temp lane buttons: white outline, grey shadow ---------- */
.lane-btn{border-color:#fff;box-shadow:3px 3px 0 rgba(22,18,12,.3)}
.lane-btn:hover{box-shadow:4px 4px 0 rgba(22,18,12,.35)}

/* ---------- "The headline act" kicker in white ---------- */
.kicker--white{color:#fff}

/* ---------- utility ---------- */
.mt-s{margin-top:1rem}.mt{margin-top:2rem}.mt-l{margin-top:3rem}
.flex{display:flex}.aic{align-items:center}.jcc{justify-content:center}
.gap{gap:14px}.gap-s{gap:8px}.wrap-fl{flex-wrap:wrap}
.note{font-size:.85rem;color:var(--ink-soft);max-width:60ch}
