/* =========================================================================
   21 PLUS — COVER B v3  ·  Classy editorial · 85vh frames · bold + microtext
   ========================================================================= */
:root{
  --c-foundation:#121210; --c-oak:#1E211E; --c-smoke:#2A2D2A;
  --c-coral:#E3694B; --c-coral-bright:#EE8268;
  --c-amber:#C8924A; --c-malt:#A07943;
  --c-paper:#EDE3CE; --c-paper-warm:#E3D6B8;
  --fg-1:#F2E9D6; --fg-2:#C9B894; --fg-3:#8A7858; --fg-4:#5d5340;
  --on-paper-1:#1F190D; --on-paper-2:#5C4A2E; --on-paper-3:#8A7858;
  --border-warm:rgba(227,105,75,.14); --border-warm-2:rgba(227,105,75,.24);
  --border-soft:rgba(242,233,214,.10);
  --border-paper:rgba(31,25,13,.16);
  --font-display:'Oswald','Impact','Arial Narrow',sans-serif;
  --font-body:'Inter',system-ui,sans-serif;
  --font-caption:'Playfair Display SC','Didot',serif;
  --font-mono:'Space Mono','SF Mono',ui-monospace,monospace;
  --ease-out:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{background:var(--c-foundation); color:var(--fg-1); font-family:var(--font-body); font-size:17px; line-height:1.7; -webkit-font-smoothing:antialiased; overflow-x:hidden;}
a{color:inherit;text-decoration:none;} button{font:inherit;background:none;border:0;color:inherit;cursor:pointer;}
em{font-style:normal;} img{display:block;}

/* ===== fixed hero 3D backdrop ===== */
#hero-stage{position:fixed;inset:0;z-index:0;}
#hero-stage canvas{pointer-events:auto;}
.stage-fallback{position:fixed;left:50%;top:50%;transform:translate(-50%,-52%);height:80vh;max-height:840px;width:auto;z-index:0;filter:drop-shadow(0 40px 90px rgba(0,0,0,.7));transition:opacity .6s var(--ease-out);}
body.is-3d .stage-fallback{opacity:0;}
.beam{position:fixed;left:50%;top:-6vh;transform:translateX(-50%);width:38vw;max-width:520px;height:86vh;z-index:0;pointer-events:none;background:linear-gradient(180deg,rgba(227,105,75,.18),rgba(200,146,74,.06) 45%,transparent 80%);filter:blur(28px);opacity:.8;}
.floorglow{position:fixed;left:50%;bottom:4vh;transform:translateX(-50%);width:46vw;max-width:640px;height:120px;z-index:0;pointer-events:none;background:radial-gradient(ellipse at center,rgba(227,105,75,.20),transparent 70%);filter:blur(8px);}

/* ===== top bar ===== */
.topbar{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:22px 32px;transition:background .4s var(--ease-out);}
.topbar.is-scrolled{background:rgba(18,18,16,.72);backdrop-filter:blur(10px);}
.topbar__mark{font-family:var(--font-display);font-weight:700;font-size:21px;color:var(--c-coral);letter-spacing:.01em;}
.topbar__mark span{font-size:.55em;vertical-align:top;}
.topbar__meta{font-family:var(--font-mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--fg-3);}

/* ===== shared atoms ===== */
.content{position:relative;z-index:1;}
.wrap{max-width:1180px;margin:0 auto;padding:0 40px;width:100%;}
.kicker{font-family:var(--font-caption);font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--c-coral);display:inline-block;}
.micro{font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--fg-3);line-height:1.6;}
.micro--coral{color:var(--c-coral);}
.h-mega{font-family:var(--font-display);font-weight:700;text-transform:uppercase;line-height:.88;letter-spacing:-.012em;font-size:clamp(44px,7vw,108px);text-wrap:balance;}
.h-mega em{color:var(--c-coral);}
.lede{font-family:'Inter',sans-serif;font-size:clamp(17px,1.5vw,21px);line-height:1.6;color:var(--fg-2);font-weight:300;}

/* frame eyebrow row: index · — · label */
.eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:26px;}
.eyebrow__idx{font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;color:var(--c-coral);}
.eyebrow__bar{width:42px;height:1px;background:var(--border-warm-2);}
.eyebrow__label{font-family:var(--font-mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--fg-3);}

/* ===== 85vh FRAME ===== */
.frame{position:relative;z-index:1;min-height:85vh;display:flex;flex-direction:column;justify-content:center;padding:9vh 0;}
.frame--foundation{background:var(--c-foundation);}
.frame--oak{background:var(--c-oak);}
.frame--paper{background:var(--c-paper);color:var(--on-paper-1);}
.frame--paper .kicker,.frame--paper .eyebrow__idx{color:var(--c-coral);}
.frame--paper .eyebrow__label,.frame--paper .micro{color:var(--on-paper-3);}
.frame--paper .eyebrow__bar{background:var(--border-paper);}

/* ===== HERO (unchanged) ===== */
.hero{position:relative;z-index:1;height:100vh;min-height:640px;display:flex;flex-direction:column;align-items:center;text-align:center;padding:0 24px;
  background:linear-gradient(180deg,rgba(18,18,16,.55) 0%,rgba(18,18,16,0) 22%,rgba(18,18,16,0) 60%,rgba(18,18,16,.85) 92%,var(--c-foundation) 100%);}
.hero__top{padding-top:16vh;}
.hero__word{font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:.02em;line-height:.88;font-size:clamp(40px,9.5vw,150px);color:var(--fg-1);}
.hero__word .amp{color:var(--c-coral);}
.hero__sub{margin-top:14px;font-family:var(--font-caption);font-size:clamp(11px,1.4vw,14px);letter-spacing:.22em;text-transform:uppercase;color:var(--c-coral);}
.hero__lede{margin-top:10px;font-family:var(--font-mono);font-size:clamp(9px,1vw,11px);letter-spacing:.18em;text-transform:uppercase;color:var(--fg-3);}
.hero__spacer{flex:1;}
.hero__foot{padding-bottom:7vh;display:flex;flex-direction:column;align-items:center;gap:12px;}
.hero__tag{font-family:var(--font-display);font-weight:500;font-size:clamp(16px,2.4vw,24px);text-transform:uppercase;letter-spacing:.04em;}
.hero__detail{font-family:'Inter',sans-serif;font-size:clamp(13px,1.5vw,16px);color:var(--fg-3);margin-top:4px;font-weight:300;}
.hero__cue{font-family:var(--font-mono);font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--fg-3);margin-top:4px;}

/* ===== HOUSE ===== */
.house-grid{display:grid;grid-template-columns:1.25fr 1fr;gap:72px;align-items:end;margin-top:8px;}
.house-lede{margin-top:26px;max-width:520px;}
.house-lede .dropcap{float:left;font-family:var(--font-caption);font-size:66px;line-height:.78;color:var(--c-coral);padding:6px 14px 0 0;font-weight:700;}
.spec-list{display:flex;flex-direction:column;}
.spec-row{display:grid;grid-template-columns:108px 1fr;gap:16px;padding:13px 0;border-top:1px solid var(--border-soft);}
.spec-row dt{font-family:var(--font-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--c-coral);padding-top:3px;}
.spec-row dd{font-family:var(--font-display);font-weight:500;font-size:15px;letter-spacing:.03em;text-transform:uppercase;color:var(--fg-1);}

/* ===== BLEND ===== */
.blend-top{display:flex;justify-content:space-between;align-items:flex-end;gap:32px;flex-wrap:wrap;}
.blend-intro{max-width:440px;margin-top:6px;}
.blend-rows{margin-top:48px;border-top:1px solid var(--border-soft);}
.blend-row{display:grid;grid-template-columns:64px 1fr auto;gap:32px;align-items:center;padding:24px 0;border-bottom:1px solid var(--border-soft);transition:background .35s var(--ease-out);}
.blend-row:hover{background:rgba(227,105,75,.03);}
.blend-row__no{font-family:var(--font-mono);font-size:12px;letter-spacing:.1em;color:var(--fg-4);}
.blend-row__name{font-family:var(--font-display);font-weight:700;font-size:clamp(22px,3vw,40px);text-transform:uppercase;letter-spacing:-.01em;line-height:1;}
.blend-row__desc{font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;color:var(--fg-3);margin-top:8px;text-transform:uppercase;}
.blend-row__pct{font-family:var(--font-display);font-weight:700;font-size:clamp(32px,4.5vw,60px);color:var(--c-coral);line-height:1;letter-spacing:-.02em;}

/* ===== TASTING (paper) ===== */
.tasting-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:8px;}
.tasting-head .h-mega{color:var(--on-paper-1);}
.tasting-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:48px;border-top:1px solid var(--border-paper);}
.taste-card{border-left:1px solid var(--border-paper);padding:32px 28px 0;}
.taste-card:first-child{border-left:0;padding-left:0;}
.taste-numeral{font-family:var(--font-caption);font-size:clamp(40px,5vw,64px);color:var(--c-coral);line-height:1;letter-spacing:-.02em;font-weight:400;}
.taste-n{font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--c-coral);margin:18px 0 12px;}
.taste-h{font-family:var(--font-display);font-weight:700;font-size:clamp(20px,2.2vw,28px);text-transform:uppercase;line-height:.98;margin-bottom:14px;color:var(--on-paper-1);}
.taste-h em{color:var(--c-coral);}
.taste-p{font-size:14px;line-height:1.62;color:var(--on-paper-2);font-weight:300;}
.taste-tags{list-style:none;display:flex;flex-wrap:wrap;gap:7px;margin-top:18px;}
.taste-tags li{font-family:var(--font-mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--on-paper-2);border:1px solid var(--border-paper);padding:5px 10px;}

/* ===== RITUAL ===== */
.ritual-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:0;width:100%;align-items:stretch;}
.ritual-grid__txt{display:flex;flex-direction:column;justify-content:center;padding:0 64px 0 0;}
.ritual-steps{margin-top:32px;}
.rstep{display:grid;grid-template-columns:48px 1fr;gap:20px;align-items:baseline;padding:15px 0;border-top:1px solid var(--border-soft);}
.rstep__i{font-family:var(--font-mono);font-size:13px;letter-spacing:.04em;color:var(--c-coral);}
.rstep__t{font-family:var(--font-display);font-weight:700;font-size:clamp(18px,2vw,24px);text-transform:uppercase;letter-spacing:.01em;}
.rstep__d{font-family:var(--font-mono);font-size:11px;line-height:1.6;color:var(--fg-3);margin-top:6px;text-transform:uppercase;letter-spacing:.04em;}
.ritual-grid__vis{position:relative;min-height:46vh;}
#ritual-stage{position:absolute;inset:0;}
#ritual-stage canvas{width:100%!important;height:100%!important;}

/* ===== DISTILLERY ===== */
.dist-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;}
.dist-lede{margin-top:24px;max-width:480px;}
.dist-coords{display:flex;gap:40px;flex-wrap:wrap;margin-top:36px;padding-top:26px;border-top:1px solid var(--border-soft);}
.coord__k{font-family:var(--font-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--c-coral);margin-bottom:8px;}
.coord__v{font-family:var(--font-display);font-weight:500;font-size:15px;letter-spacing:.03em;text-transform:uppercase;color:var(--fg-1);line-height:1.5;}
.dist-still{width:100%;max-width:300px;height:auto;display:block;margin:0 auto;}
.dist-still-cap{text-align:center;margin-top:14px;}

/* ===== RANGE ===== */
.range-head{text-align:center;margin-bottom:8px;}
.range-head .h-mega{color:var(--fg-1);}
.range-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:56px;border-top:1px solid var(--border-soft);}
.rcard{text-align:center;padding:44px 24px 0;border-left:1px solid var(--border-soft);}
.rcard:first-child{border-left:0;}
.rcard__no{font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-4);margin-bottom:22px;}
.rcard__num{font-family:var(--font-display);font-weight:700;font-size:clamp(56px,7vw,84px);line-height:.9;letter-spacing:-.03em;}
.rcard__u{font-family:var(--font-caption);font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--c-coral);}
.rcard__mrp{font-family:var(--font-display);font-weight:500;font-size:19px;color:var(--c-coral);margin:16px 0 8px;letter-spacing:.02em;}
.rcard__d{font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-3);}

/* ===== CLOSE ===== */
.frame--close{text-align:center;align-items:center;}
.close-inner{display:flex;flex-direction:column;align-items:center;}
.close-inner .h-mega{margin:16px 0 20px;max-width:14ch;}
.close-inner .lede{max-width:520px;}
.btn{display:inline-flex;align-items:center;gap:10px;padding:17px 36px;font-family:var(--font-display);font-weight:700;font-size:12px;letter-spacing:.16em;text-transform:uppercase;border:1px solid var(--c-coral);color:var(--c-coral);transition:all .3s var(--ease-out);cursor:pointer;margin-top:28px;}
.btn--primary{background:var(--c-coral);color:#121210;} .btn--primary:hover{background:var(--c-coral-bright);}
.btn:hover{background:rgba(227,105,75,.08);} .btn--primary:hover{background:var(--c-coral-bright);}
/* contact strip (replaces footer) */
.contact{display:flex;justify-content:center;gap:0;flex-wrap:wrap;margin-top:36px;border-top:1px solid var(--border-soft);width:100%;max-width:760px;}
.contact__col{flex:1;min-width:180px;padding:20px 20px 0;border-left:1px solid var(--border-soft);}
.contact__col:first-child{border-left:0;}
.contact__k{font-family:var(--font-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--c-coral);margin-bottom:10px;}
.contact__v{font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;color:var(--fg-2);line-height:1.7;text-transform:uppercase;}
.contact__v a{color:var(--fg-2);}
.contact__v a:hover{color:var(--c-coral);}
.close-law{font-family:var(--font-mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-4);margin-top:28px;}

/* ===== gate + toast ===== */
.gate{position:fixed;inset:0;z-index:100;display:grid;place-items:center;}
.gate__veil{position:absolute;inset:0;background:rgba(18,18,16,.97);}
.gate__card{position:relative;text-align:center;padding:48px 40px;max-width:480px;}
.gate__rule{width:60px;height:2px;background:var(--c-coral);margin:0 auto 24px;}
.gate__num{font-family:var(--font-display);font-weight:700;font-size:clamp(88px,16vw,120px);color:var(--c-coral);line-height:.9;}
.gate__num span{font-size:.35em;vertical-align:top;}
.gate__caption{font-family:var(--font-mono);font-size:10px;letter-spacing:.2em;color:var(--c-coral);margin:16px 0 28px;text-transform:uppercase;}
.gate__h{font-family:var(--font-display);font-weight:500;font-size:clamp(18px,4vw,22px);line-height:1.3;text-transform:uppercase;margin-bottom:28px;}
.gate__row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:28px;}
.gate__law{font-family:var(--font-mono);font-size:9px;letter-spacing:.15em;color:var(--fg-3);text-transform:uppercase;}
.toast{position:fixed;left:50%;bottom:28px;transform:translateX(-50%) translateY(20px);background:var(--c-smoke,#2A2D2A);color:var(--fg-1);border:1px solid var(--border-warm-2);padding:14px 22px;font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;z-index:90;opacity:0;pointer-events:none;transition:all .4s var(--ease-out);}
.toast.is-in{opacity:1;transform:translateX(-50%) translateY(0);}

/* ===== responsive ===== */
@media(max-width:900px){
  .house-grid,.dist-grid{grid-template-columns:1fr;gap:40px;}
  .ritual-grid{grid-template-columns:1fr;}
  .ritual-grid__txt{padding:0;}
  .ritual-grid__vis{min-height:48vh;margin-top:32px;}
  .tasting-cols,.range-cols{grid-template-columns:1fr;}
  .taste-card{border-left:0;border-top:1px solid var(--border-paper);padding:28px 0 0;}
  .taste-card:first-child{border-top:0;}
  .rcard{border-left:0;border-top:1px solid var(--border-soft);padding:32px 0 0;}
  .rcard:first-child{border-top:0;}
  .frame{padding:11vh 0;min-height:auto;}
}
@media(max-width:520px){
  .topbar__meta{display:none;}
  .wrap{padding:0 24px;}
  .blend-row{grid-template-columns:1fr auto;gap:16px;}
  .blend-row__no{display:none;}
  .contact__col{border-left:0;border-top:1px solid var(--border-soft);}
  .contact__col:first-child{border-top:0;}
}
