/* ============================================================
   KAHOA COFFEE — Highland soul, Texas craft
   Design system: editorial serif + spec-sheet mono, espresso/
   cream/brass palette, Kenyan green/red as restrained accents.
   ============================================================ */

:root{
  /* palette */
  --espresso:#14100B;
  --espresso-2:#0D0905;
  --roast:#241811;
  --roast-2:#352318;
  --cream:#F3EBDB;
  --cream-2:#FBF6EC;
  --bone:#FFFDF8;
  --ink:#211810;
  --ink-soft:#6B5A47;
  --gold:#C0902E;
  --gold-2:#E6CB82;
  --gold-deep:#9A6C1C;
  --green:#15673A;   /* Kenya, refined */
  --red:#A81E2E;     /* Kenya, refined */
  --line:rgba(33,24,16,.13);
  --line-2:rgba(33,24,16,.07);
  --line-light:rgba(255,255,255,.13);

  /* type */
  --serif:'Fraunces',Georgia,'Times New Roman',serif;
  --sans:'Inter',system-ui,-apple-system,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;

  /* motion */
  --ease:cubic-bezier(.22,1,.36,1);
  --ease-2:cubic-bezier(.65,.05,.36,1);

  --wrap:1240px;
  --r:14px;
  --r-lg:22px;
  --shadow:0 1px 2px rgba(20,16,11,.06),0 18px 50px -24px rgba(20,16,11,.35);
  --shadow-gold:0 18px 44px -18px rgba(154,108,28,.5);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;
  font-family:var(--sans);
  background:var(--cream);
  color:var(--ink);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block;height:auto}
[hidden]{display:none !important}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none}
h1,h2,h3,h4{margin:0;font-weight:400;letter-spacing:-.02em}
p{margin:0 0 1em}
ul{margin:0;padding:0;list-style:none}
.ic{width:1.25em;height:1.25em;fill:none;stroke:currentColor;flex:none}
section{scroll-margin-top:90px}
::selection{background:var(--gold);color:#1a1208}

.wrap{width:100%;max-width:var(--wrap);margin:0 auto;padding:0 clamp(20px,5vw,56px)}
.skip-link{position:absolute;left:-999px;top:0;background:var(--espresso);color:#fff;padding:.7em 1.2em;z-index:200;border-radius:0 0 10px 0}
.skip-link:focus{left:0}

/* ---------- typography helpers ---------- */
.display{
  font-family:var(--serif);
  font-optical-sizing:auto;
  font-weight:380;
  font-size:clamp(2.4rem,6vw,4.6rem);
  line-height:1.02;
  letter-spacing:-.025em;
}
.display-sm{
  font-family:var(--serif);font-weight:400;
  font-size:clamp(1.7rem,3.4vw,2.6rem);line-height:1.06;letter-spacing:-.02em;
}
.display em,.hero__title em{font-style:italic;color:var(--gold-deep)}
.eyebrow{
  font-family:var(--mono);
  font-size:.72rem;font-weight:500;
  letter-spacing:.26em;text-transform:uppercase;
  color:var(--gold-deep);
  margin:0 0 1.1rem;
}
.eyebrow--gold{color:var(--gold-2)}
.eyebrow--light{color:rgba(255,255,255,.62)}

.sec-head{max-width:680px;margin:0 auto clamp(40px,6vw,72px);text-align:center}
.sec-head .display{margin-bottom:.5em}
.sec-head__lede{color:var(--ink-soft);font-size:1.08rem;margin:0}
.sec-head--light .eyebrow{color:var(--gold-2)}
.sec-head--light .display,.sec-head--light .sec-head__lede{color:var(--cream)}
.sec-head--light .sec-head__lede{color:rgba(243,235,219,.72)}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55em;
  font-family:var(--sans);font-weight:600;font-size:.96rem;letter-spacing:-.01em;
  padding:.95em 1.5em;border-radius:100px;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease),background .3s,color .3s,border-color .3s;
  position:relative;white-space:nowrap;
}
.btn .ic{width:1.1em;height:1.1em;transition:transform .4s var(--ease)}
.btn:hover .ic{transform:translateX(3px)}
.btn--gold{background:linear-gradient(180deg,var(--gold-2),var(--gold) 55%,var(--gold-deep));color:#231706;box-shadow:var(--shadow-gold)}
.btn--gold:hover{transform:translateY(-2px);box-shadow:0 22px 50px -16px rgba(154,108,28,.62)}
.btn--dark{background:var(--espresso);color:var(--cream-2)}
.btn--dark:hover{transform:translateY(-2px);background:#1d160e}
.btn--ghost{background:rgba(255,255,255,.06);color:var(--cream);border:1px solid var(--line-light)}
.btn--ghost:hover{background:rgba(255,255,255,.12)}
.btn--outline-light{border:1px solid rgba(255,255,255,.32);color:var(--cream)}
.btn--outline-light:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.5)}
.btn--full{width:100%;justify-content:center}
.btn--sm{padding:.65em 1.1em;font-size:.86rem}

/* ---------- reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ============================================================ ANNOUNCE */
.announce{background:var(--espresso-2);color:rgba(243,235,219,.86);overflow:hidden;font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase}
.announce__track{display:flex;gap:1.4rem;align-items:center;white-space:nowrap;padding:.6rem 0;width:max-content;animation:ticker 34s linear infinite}
.announce strong{color:var(--gold-2);font-weight:600}
.announce .dot{color:var(--gold-deep)}
@keyframes ticker{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.announce__track{animation:none;justify-content:center}}

/* ============================================================ HEADER */
.site-head{position:fixed;top:0;left:0;right:0;z-index:90;transition:background .5s var(--ease),box-shadow .5s,backdrop-filter .5s}
.site-head__inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding-top:14px;padding-bottom:14px}
.brand__logo{height:46px;width:auto;transition:height .45s var(--ease);filter:drop-shadow(0 2px 8px rgba(0,0,0,.3))}
.site-head.scrolled{background:rgba(13,9,5,.82);backdrop-filter:blur(16px) saturate(1.2);box-shadow:0 1px 0 var(--line-light)}
.site-head.scrolled .brand__logo{height:38px}
.nav{display:flex;gap:2rem;margin-left:auto}
.nav a{font-size:.93rem;font-weight:500;color:rgba(243,235,219,.82);position:relative;padding:.3em 0;transition:color .3s}
.nav a::after{content:"";position:absolute;left:0;bottom:0;height:1.5px;width:0;background:var(--gold-2);transition:width .4s var(--ease)}
.nav a:hover{color:#fff}
.nav a:hover::after{width:100%}
.head-actions{display:flex;align-items:center;gap:.9rem}
.head-actions .btn--ghost{color:var(--cream)}
.cart-toggle{position:relative;color:var(--cream);width:42px;height:42px;display:grid;place-items:center;border-radius:50%;transition:background .3s}
.cart-toggle .ic{width:22px;height:22px}
.cart-toggle:hover{background:rgba(255,255,255,.1)}
.cart-count{position:absolute;top:2px;right:2px;background:var(--red);color:#fff;font-family:var(--mono);font-size:.6rem;min-width:17px;height:17px;border-radius:9px;display:grid;place-items:center;padding:0 4px;font-weight:600}
.burger{display:none;flex-direction:column;gap:5px;width:42px;height:42px;align-items:center;justify-content:center;border-radius:50%}
.burger span{width:22px;height:1.6px;background:var(--cream);transition:transform .4s var(--ease),opacity .3s}
.burger[aria-expanded="true"] span:first-child{transform:translateY(3.3px) rotate(45deg)}
.burger[aria-expanded="true"] span:last-child{transform:translateY(-3.3px) rotate(-45deg)}

/* mobile menu */
.mobile-menu{position:fixed;inset:0;z-index:80;background:var(--espresso);padding:120px clamp(28px,8vw,56px) 48px;display:flex;flex-direction:column;justify-content:space-between;transform:translateY(-100%);transition:transform .55s var(--ease);visibility:hidden}
.mobile-menu.open{transform:none;visibility:visible}
.mobile-menu__nav{display:flex;flex-direction:column;gap:.2rem}
.mobile-menu__nav a{font-family:var(--serif);font-size:clamp(2rem,9vw,2.8rem);color:var(--cream);padding:.25em 0;border-bottom:1px solid var(--line-light)}
.mobile-menu__nav a:active{color:var(--gold-2)}
.mobile-menu__foot{display:flex;justify-content:space-between;align-items:center;color:rgba(243,235,219,.7);font-family:var(--mono);font-size:.82rem}
.mobile-menu .social{display:flex;gap:.8rem}
.mobile-menu .social a{width:40px;height:40px;border:1px solid var(--line-light);border-radius:50%;display:grid;place-items:center;color:var(--cream)}

/* ============================================================ HERO */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;color:var(--cream);overflow:hidden;background:var(--espresso)}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media img{width:100%;height:100%;object-fit:cover;object-position:center;transform:scale(1.06);animation:heroZoom 16s var(--ease) forwards}
@keyframes heroZoom{to{transform:scale(1)}}
.hero__scrim{position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(13,9,5,.55) 0%,rgba(13,9,5,.15) 30%,rgba(13,9,5,.55) 70%,rgba(13,9,5,.92) 100%),
  radial-gradient(120% 80% at 15% 90%,rgba(13,9,5,.7),transparent 60%)}
.hero__inner{position:relative;z-index:2;padding-bottom:clamp(72px,12vh,140px);padding-top:160px;max-width:880px}
.hero__title{font-family:var(--serif);font-weight:360;font-size:clamp(2.9rem,8vw,6.2rem);line-height:.99;letter-spacing:-.03em;margin:0 0 .55em;text-wrap:balance;text-shadow:0 2px 30px rgba(0,0,0,.4)}
.hero__title em{color:var(--gold-2);font-style:italic}
.hero__lede{max-width:54ch;font-size:clamp(1.02rem,1.7vw,1.22rem);color:rgba(243,235,219,.82);margin:0 0 2rem}
.hero__cta{display:flex;flex-wrap:wrap;gap:.9rem;margin-bottom:2.2rem}
.hero__rating{display:flex;align-items:center;gap:.7rem;font-size:.92rem;color:rgba(243,235,219,.8)}
.hero__rating strong{color:var(--cream)}
.stars{display:inline-flex;color:var(--gold-2)}
.stars .ic{width:17px;height:17px}
.hero__scroll{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:10px;font-family:var(--mono);font-size:.64rem;letter-spacing:.28em;text-transform:uppercase;color:rgba(243,235,219,.6)}
.hero__scroll-line{width:1px;height:46px;background:linear-gradient(var(--gold-2),transparent);position:relative;overflow:hidden}
.hero__scroll-line::after{content:"";position:absolute;top:-50%;left:0;width:100%;height:50%;background:var(--gold-2);animation:scrollPulse 2.2s var(--ease) infinite}
@keyframes scrollPulse{0%{transform:translateY(-100%)}60%,100%{transform:translateY(300%)}}

/* ============================================================ SPEC STRIP */
.spec-strip{background:var(--espresso);color:var(--gold-2);overflow:hidden;border-top:1px solid var(--line-light)}
.spec-strip__track{display:flex;gap:2.2rem;align-items:center;width:max-content;white-space:nowrap;padding:1.05rem 0;font-family:var(--serif);font-style:italic;font-size:clamp(1.1rem,2.4vw,1.7rem);animation:ticker 30s linear infinite}
.spec-strip .sep{color:var(--gold-deep);font-style:normal;font-size:.7em}
@media (prefers-reduced-motion:reduce){.spec-strip__track{animation:none}}

/* ============================================================ STORY */
.story{background:var(--cream);padding:clamp(70px,11vw,150px) 0}
.story__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,6vw,92px);align-items:center}
.story__copy .display{margin-bottom:.6em}
.story__copy p{color:var(--ink-soft);max-width:46ch}
.story__stats{display:flex;gap:clamp(20px,4vw,48px);margin-top:2.4rem;padding-top:2rem;border-top:1px solid var(--line)}
.story__stats .num{font-family:var(--serif);font-size:clamp(1.8rem,3.6vw,2.7rem);color:var(--gold-deep);display:block;line-height:1;letter-spacing:-.02em}
.story__stats small{font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft)}
.story__media{position:relative;margin:0;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:9/11}
.story__media img{width:100%;height:100%;object-fit:cover}
.story__chip{position:absolute;left:18px;bottom:18px;display:inline-flex;align-items:center;gap:.5em;background:rgba(13,9,5,.7);backdrop-filter:blur(8px);color:var(--cream);font-family:var(--mono);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;padding:.55em .9em;border-radius:100px;border:1px solid var(--line-light)}
.story__chip .ic{width:14px;height:14px;color:var(--gold-2)}

/* regions / map */
.regions{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(30px,6vw,80px);align-items:center;margin-top:clamp(60px,9vw,120px)}
.regions__map{display:grid;place-items:center}
.kenya-map{width:100%;max-width:330px;overflow:visible}
.kenya-shape{fill:rgba(21,103,58,.07);stroke:var(--green);stroke-width:1.4;stroke-dasharray:4 5;opacity:.8}
.region circle{fill:var(--gold);stroke:var(--cream);stroke-width:2}
.region text{font-family:var(--mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;fill:var(--ink-soft)}
.region--lake circle{fill:none;stroke:var(--green);stroke-width:1.5;fill:rgba(21,103,58,.15)}
.region--lake text{fill:var(--green)}
.region--mt circle{fill:var(--red)}
.regions__legend .display-sm{margin:.2em 0 .7em}
.regions__legend p{color:var(--ink-soft);max-width:44ch}
.regions__list{display:flex;flex-wrap:wrap;gap:.6rem 1.4rem;margin-top:1.4rem;font-family:var(--mono);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink)}
.regions__list li{display:flex;align-items:center;gap:.5em}
.regions__list span{width:7px;height:7px;border-radius:50%;background:var(--gold)}

/* ============================================================ FOUNDER */
.founder{position:relative;background:var(--espresso);color:var(--cream);padding:clamp(80px,13vw,170px) 0;overflow:hidden}
.founder__media{position:absolute;inset:0;z-index:0;opacity:.32}
.founder__media img{width:100%;height:100%;object-fit:cover;object-position:center 40%}
.founder::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,var(--espresso) 12%,rgba(20,16,11,.55) 70%,rgba(20,16,11,.2))}
.founder__inner{position:relative;z-index:2;max-width:840px}
.founder__quote{margin:0}
.founder__quote p{font-family:var(--serif);font-weight:340;font-size:clamp(1.5rem,3.4vw,2.55rem);line-height:1.28;letter-spacing:-.02em;color:var(--cream)}
.founder__quote em{color:var(--gold-2);font-style:italic}
.founder__sign{display:flex;flex-direction:column;margin-top:2.2rem;padding-left:1.2rem;border-left:2px solid var(--gold)}
.founder__name{font-family:var(--serif);font-style:italic;font-size:1.4rem;color:var(--gold-2)}
.founder__role{font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(243,235,219,.6);margin-top:.3em}

/* ============================================================ CONNECT */
.connect{background:var(--roast);color:var(--cream);padding:clamp(70px,11vw,140px) 0;text-align:center}
.connect .display{color:var(--cream);margin-bottom:.5em}
.connect__lede{max-width:60ch;margin:0 auto 3.5rem;color:rgba(243,235,219,.72)}
.journey{display:flex;align-items:center;justify-content:center;gap:clamp(8px,3vw,40px);max-width:760px;margin:0 auto}
.journey__node{display:flex;flex-direction:column;align-items:center;gap:.5rem;flex:none}
.journey__flag{width:66px;border-radius:7px;overflow:hidden;box-shadow:0 10px 24px -10px rgba(0,0,0,.65);border:1px solid var(--line-light);line-height:0}
.journey__flag img,.journey__flag svg{display:block;width:100%;height:auto}
.journey__place{font-family:var(--serif);font-size:1.4rem}
.journey__role{font-family:var(--mono);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-2)}
.journey__line{flex:1;display:flex;flex-direction:column;align-items:center;gap:.4rem;position:relative;min-width:90px}
.journey__line svg{width:100%;height:48px}
.journey__line .arc{stroke:var(--gold);stroke-width:1.4;stroke-dasharray:3 5;opacity:.7;stroke-dashoffset:0}
.journey__dist{font-family:var(--mono);font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(243,235,219,.66)}
.journey__plane{position:absolute;top:6px;color:var(--gold-2);animation:fly 5s var(--ease) infinite}
.journey__plane .ic{width:18px;height:18px}
@keyframes fly{0%{left:8%;opacity:0}15%{opacity:1}85%{opacity:1}100%{left:86%;opacity:0}}
.connect__tag{font-family:var(--serif);font-style:italic;font-size:1.15rem;color:var(--gold-2);margin:3rem 0 0}

/* ============================================================ COFFEE */
.coffee{background:var(--cream-2);padding:clamp(70px,11vw,150px) 0}
.blends{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2vw,28px)}
.blend{position:relative;background:var(--bone);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(26px,3vw,38px) clamp(22px,2.5vw,32px) clamp(24px,3vw,34px);display:flex;flex-direction:column;transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .5s}
.blend:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:rgba(192,144,46,.4)}
.blend__tag{position:absolute;top:18px;right:18px;font-family:var(--mono);font-size:.6rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;padding:.45em .8em;border-radius:100px}
.blend__tag--best{background:var(--gold);color:#231706}
.blend__tag--new{background:var(--green);color:#fff}
.blend__region{display:flex;align-items:center;gap:.45em;font-family:var(--mono);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-deep);margin:0 0 1rem}
.blend__region .ic{width:14px;height:14px}
.blend__name{font-family:var(--serif);font-size:clamp(1.7rem,2.6vw,2.1rem);line-height:1;margin:0 0 .25em}
.blend__kind{font-family:var(--mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);margin:0 0 1.1rem}
.blend__desc{color:var(--ink-soft);font-size:.95rem;margin:0 0 1.3rem;flex:1}
.notes{display:flex;flex-wrap:wrap;gap:.5rem;margin:0 0 1.3rem}
.notes li{font-size:.78rem;font-weight:500;padding:.42em .8em;border:1px solid var(--line);border-radius:100px;color:var(--ink);background:rgba(192,144,46,.06)}
.roast{display:flex;align-items:center;gap:.6rem;margin-bottom:1.5rem;font-family:var(--mono);font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft)}
.roast__meter{display:inline-flex;gap:4px}
.roast__meter i{width:13px;height:6px;border-radius:3px;background:var(--line);transition:background .4s}
.roast[data-on] {}
.blend[data-roast="2"] .roast__meter i:nth-child(-n+2),
.blend[data-roast="3"] .roast__meter i:nth-child(-n+3),
.blend[data-roast="5"] .roast__meter i:nth-child(-n+5){background:linear-gradient(90deg,var(--gold-2),var(--gold-deep))}
.roast__val{margin-left:auto;color:var(--ink);font-weight:500}
.blend__buy{display:flex;flex-direction:column;gap:.8rem}
.grind{display:flex;gap:6px;background:rgba(33,24,16,.05);padding:5px;border-radius:100px}
.grind__opt{flex:1;font-family:var(--mono);font-size:.7rem;letter-spacing:.04em;padding:.7em .4em;border-radius:100px;color:var(--ink-soft);transition:background .3s,color .3s;font-weight:500}
.grind__opt.is-active{background:var(--espresso);color:var(--cream-2)}
.link-sub{display:inline-flex;align-items:center;justify-content:center;gap:.45em;font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--gold-deep);transition:color .3s}
.link-sub .ic{width:14px;height:14px}
.link-sub:hover{color:var(--ink)}

/* flight */
.flight{margin-top:clamp(28px,4vw,44px);background:var(--espresso);color:var(--cream);border-radius:var(--r-lg);padding:clamp(30px,4vw,52px);display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:2rem;position:relative;overflow:hidden}
.flight::before{content:"";position:absolute;right:-60px;top:-60px;width:280px;height:280px;background:radial-gradient(circle,rgba(192,144,46,.22),transparent 65%)}
.flight__copy{position:relative;z-index:1;max-width:40ch}
.flight__copy .eyebrow{color:var(--gold-2)}
.flight__copy .display-sm{color:var(--cream);margin:.1em 0 .5em}
.flight__copy p{color:rgba(243,235,219,.74);margin:0}
.flight__buy{position:relative;z-index:1;display:flex;flex-direction:column;align-items:flex-start;gap:.9rem}
.flight__price{display:flex;align-items:baseline;gap:.6rem;font-family:var(--serif)}
.flight__price .was{color:rgba(243,235,219,.5);text-decoration:line-through;font-size:1.2rem}
.flight__price .now{color:var(--gold-2);font-size:2.4rem;line-height:1}
.flight__price .save{font-family:var(--mono);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;background:var(--red);color:#fff;padding:.4em .7em;border-radius:100px}
.flight__ship{display:flex;align-items:center;gap:.5em;font-family:var(--mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(243,235,219,.6)}
.flight__ship .ic{width:15px;height:15px;color:var(--gold-2)}

/* ============================================================ BREW */
.brew{background:var(--espresso);color:var(--cream);padding:clamp(70px,11vw,150px) 0}
.brew__tabs{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;margin-bottom:clamp(32px,5vw,56px)}
.brew__tab{font-family:var(--mono);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(243,235,219,.6);padding:.7em 1.2em;border-radius:100px;border:1px solid var(--line-light);transition:all .3s}
.brew__tab:hover{color:var(--cream);border-color:rgba(255,255,255,.3)}
.brew__tab.is-active{background:var(--gold);color:#231706;border-color:var(--gold)}
.brew__panel{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(36px,5vw,72px);align-items:start}
.steps{display:flex;flex-direction:column;gap:1.6rem;counter-reset:s}
.steps li{display:flex;gap:1.3rem;opacity:0;transform:translateY(16px);animation:stepIn .6s var(--ease) forwards}
.steps li:nth-child(2){animation-delay:.08s}.steps li:nth-child(3){animation-delay:.16s}.steps li:nth-child(4){animation-delay:.24s}.steps li:nth-child(5){animation-delay:.32s}
@keyframes stepIn{to{opacity:1;transform:none}}
.steps__n{flex:none;width:44px;height:44px;border-radius:50%;display:grid;place-items:center;font-family:var(--serif);font-style:italic;font-size:1.2rem;color:var(--gold-2);border:1px solid var(--gold-deep);background:rgba(192,144,46,.08)}
.steps h4{font-family:var(--serif);font-size:1.3rem;margin:.35rem 0 .35rem}
.steps p{color:rgba(243,235,219,.72);font-size:.96rem;margin:0;max-width:50ch}
.brew__side{display:flex;flex-direction:column;gap:1.4rem}
.brew__img{margin:0;border-radius:var(--r);overflow:hidden;aspect-ratio:4/3}
.brew__img img{width:100%;height:100%;object-fit:cover}
.spec-card{background:rgba(255,255,255,.04);border:1px solid var(--line-light);border-radius:var(--r);padding:1.6rem}
.spec-card__title{font-family:var(--mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-2);margin:0 0 1.1rem}
.spec-card__grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem 1.4rem;margin:0 0 1.4rem}
.spec-card__grid dt{font-family:var(--mono);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(243,235,219,.5);margin-bottom:.25rem}
.spec-card__grid dd{margin:0;font-family:var(--serif);font-size:1.5rem;color:var(--cream)}
.grindscale{padding-top:1.2rem;border-top:1px solid var(--line-light)}
.grindscale__label{font-family:var(--mono);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(243,235,219,.5)}
.grindscale__bar{position:relative;height:8px;border-radius:6px;margin:.7rem 0 .5rem;background:linear-gradient(90deg,#4a3322,#caa15f,#e6cb82,#caa15f,#4a3322)}
.grindscale__pin{position:absolute;top:50%;width:16px;height:16px;border-radius:50%;background:var(--cream);border:3px solid var(--espresso);transform:translate(-50%,-50%);left:38%;transition:left .5s var(--ease);box-shadow:0 2px 8px rgba(0,0,0,.4)}
.grindscale__ticks{display:flex;justify-content:space-between;font-family:var(--mono);font-size:.56rem;letter-spacing:.06em;text-transform:uppercase;color:rgba(243,235,219,.45)}
.grindscale__note{font-size:.84rem;color:rgba(243,235,219,.7);margin:.8rem 0 0}
.protip{background:linear-gradient(180deg,rgba(192,144,46,.16),rgba(192,144,46,.04));border:1px solid rgba(192,144,46,.3);border-radius:var(--r);padding:1.4rem}
.protip__badge{display:inline-flex;align-items:center;gap:.4em;font-family:var(--mono);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-2);margin-bottom:.6rem}
.protip__badge .ic{width:14px;height:14px;fill:var(--gold-2);stroke:none}
.protip p{font-size:.9rem;color:rgba(243,235,219,.82);margin:0}

/* ============================================================ REVIEWS */
.reviews{background:var(--cream);padding:clamp(70px,11vw,150px) 0}
.reviews__score{display:flex;align-items:center;justify-content:center;gap:.5rem;font-family:var(--mono);font-size:.82rem;letter-spacing:.06em;color:var(--ink-soft);margin:1rem 0 0}
.reviews__score strong{color:var(--ink)}
.stars--gold{color:var(--gold)}
.reviews__grid{columns:3;column-gap:24px}
.review{break-inside:avoid;margin:0 0 24px;background:var(--bone);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.8rem}
.review .stars{margin-bottom:1rem}
.review .ic--empty{color:var(--line)}
.review blockquote{margin:0 0 1.2rem;font-size:1rem;line-height:1.62;color:var(--ink)}
.review figcaption{display:flex;flex-direction:column;gap:.3rem;padding-top:1rem;border-top:1px solid var(--line-2)}
.review__who{font-size:.9rem}
.review__who b{font-weight:600}
.review__verified{display:flex;align-items:center;gap:.4em;font-family:var(--mono);font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--green)}
.review__verified .ic{width:14px;height:14px;color:var(--green)}
.reviews__cta{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1.6rem;margin-top:clamp(34px,5vw,56px);padding:clamp(28px,4vw,44px);background:var(--bone);border:1px solid var(--line);border-radius:var(--r-lg)}
.reviews__cta .display-sm{margin:0 0 .3em}
.reviews__cta p{color:var(--ink-soft);margin:0;max-width:48ch}

/* ============================================================ PROCESS */
.process{background:var(--roast);color:var(--cream);padding:clamp(70px,11vw,150px) 0}
.steps-row{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(20px,2.5vw,32px)}
.pstep{position:relative;padding-top:1.6rem;border-top:1px solid var(--line-light)}
.pstep__n{font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;color:var(--gold-2);display:block;margin-bottom:1.4rem}
.pstep__ic{display:grid;place-items:center;width:58px;height:58px;border-radius:50%;background:rgba(192,144,46,.1);border:1px solid rgba(192,144,46,.28);color:var(--gold-2);margin-bottom:1.2rem}
.pstep__ic .ic{width:26px;height:26px}
.pstep h3{font-family:var(--serif);font-size:1.4rem;margin:0 0 .5rem}
.pstep p{color:rgba(243,235,219,.7);font-size:.93rem;margin:0}

/* ============================================================ SUBSCRIBE */
.subscribe{position:relative;background:var(--espresso);color:var(--cream);padding:clamp(70px,11vw,150px) 0;overflow:hidden}
.subscribe__media{position:absolute;inset:0;opacity:.16}
.subscribe__media img{width:100%;height:100%;object-fit:cover}
.subscribe__inner{position:relative;z-index:1}
.subscribe__copy{text-align:center;max-width:620px;margin:0 auto clamp(38px,5vw,56px)}
.subscribe__copy .display{color:var(--cream);margin-bottom:.4em}
.subscribe__copy p{color:rgba(243,235,219,.74);margin:0}
.subscribe__cards{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,24px);margin-bottom:clamp(30px,4vw,44px)}
.subcard{position:relative;background:rgba(255,255,255,.04);border:1px solid var(--line-light);border-radius:var(--r-lg);padding:2rem 1.7rem;text-align:center}
.subcard--feature{background:linear-gradient(180deg,rgba(192,144,46,.16),rgba(192,144,46,.03));border-color:rgba(192,144,46,.36)}
.subcard__flag{position:absolute;top:-12px;left:50%;transform:translateX(-50%);font-family:var(--mono);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;background:var(--gold);color:#231706;padding:.4em .9em;border-radius:100px;font-weight:600;white-space:nowrap}
.subcard__ic{display:inline-grid;place-items:center;width:54px;height:54px;border-radius:50%;background:rgba(192,144,46,.12);color:var(--gold-2);margin-bottom:1rem}
.subcard__ic .ic{width:24px;height:24px}
.subcard h4{font-family:var(--serif);font-size:1.35rem;margin:0 0 .5rem}
.subcard p{color:rgba(243,235,219,.7);font-size:.9rem;margin:0}
.ship-tiers{max-width:760px;margin:0 auto;text-align:center;background:rgba(0,0,0,.22);border:1px solid var(--line-light);border-radius:var(--r-lg);padding:clamp(24px,3vw,36px)}
.ship-tiers__label{font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-2);margin:0 0 1.3rem}
.ship-tiers__row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.8rem}
.ship-tiers__row>div{display:flex;flex-direction:column;gap:.3rem;padding:1rem .5rem;border-radius:var(--r);background:rgba(255,255,255,.03)}
.ship-tiers__row .is-free{background:rgba(21,103,58,.18);border:1px solid rgba(21,103,58,.4)}
.ship-tiers__price{font-family:var(--serif);font-size:1.4rem;color:var(--cream)}
.is-free .ship-tiers__price{color:#7dd1a0}
.ship-tiers__row small{font-family:var(--mono);font-size:.6rem;letter-spacing:.08em;text-transform:uppercase;color:rgba(243,235,219,.55)}

/* ============================================================ SAMPLE */
.sample{background:var(--cream-2);padding:clamp(70px,11vw,150px) 0}
.sample__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,90px);align-items:center}
.sample__copy .display{margin-bottom:.5em}
.sample__copy>p{color:var(--ink-soft);max-width:44ch}
.sample__perks{display:flex;flex-direction:column;gap:1.1rem;margin:2rem 0}
.sample__perks li{display:flex;gap:1rem;align-items:flex-start}
.sample__perks span{flex:none;width:46px;height:46px;border-radius:50%;display:grid;place-items:center;background:var(--espresso);color:var(--gold-2)}
.sample__perks span .ic{width:22px;height:22px}
.sample__perks div{display:flex;flex-direction:column}
.sample__perks b{font-weight:600}
.sample__perks div{font-size:.92rem;color:var(--ink-soft)}
.sample__fine{font-size:.85rem;color:var(--ink-soft)}
.sample__fine a{color:var(--gold-deep);text-decoration:underline;text-underline-offset:3px}
.sample__form{background:var(--bone);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(26px,3.5vw,44px);box-shadow:var(--shadow)}
.sample__form-title{font-family:var(--serif);font-size:1.6rem;margin:0 0 1.5rem}
.sample__form label{display:flex;flex-direction:column;gap:.4rem;font-family:var(--mono);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:1rem}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.sample__form input,.sample__form select{font-family:var(--sans);font-size:.95rem;letter-spacing:0;text-transform:none;color:var(--ink);padding:.8em .9em;border:1px solid var(--line);border-radius:10px;background:var(--cream-2);transition:border-color .3s,box-shadow .3s}
.sample__form input:focus,.sample__form select:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(192,144,46,.18)}
.sample__format{border:0;padding:0;margin:0 0 1.4rem}
.sample__format legend{font-family:var(--mono);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:.7rem;padding:0}
.radio{display:flex !important;flex-direction:row !important;align-items:center;gap:.7rem;border:1px solid var(--line);border-radius:10px;padding:.8rem 1rem !important;margin-bottom:.6rem !important;cursor:pointer;text-transform:none !important;letter-spacing:0 !important;font-family:var(--sans) !important;transition:border-color .3s,background .3s}
.radio:has(input:checked){border-color:var(--gold);background:rgba(192,144,46,.07)}
.radio input{width:18px;height:18px;accent-color:var(--gold-deep)}
.radio span{display:flex;flex-direction:column}
.radio b{font-size:.95rem;color:var(--ink)}
.radio span{font-size:.8rem;color:var(--ink-soft)}
.sample__note{font-size:.78rem;color:var(--ink-soft);text-align:center;margin:1rem 0 0}
.sample__note b{color:var(--ink)}

/* ============================================================ FOOTER */
.site-foot{background:var(--espresso-2);color:rgba(243,235,219,.7);padding:clamp(60px,8vw,100px) 0 0}
.site-foot__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:clamp(32px,5vw,72px);padding-bottom:clamp(40px,6vw,64px)}
.site-foot__logo{height:54px;width:auto;margin-bottom:1.2rem}
.site-foot__tag{font-family:var(--serif);font-style:italic;font-size:1.3rem;color:var(--gold-2);margin:0 0 1rem}
.site-foot__about{font-size:.92rem;max-width:42ch;margin:0 0 1.2rem}
.site-foot__mail{font-family:var(--mono);font-size:.85rem;color:var(--cream);border-bottom:1px solid var(--gold-deep);padding-bottom:2px}
.site-foot__col h4{font-family:var(--mono);font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-2);margin:0 0 1.2rem}
.site-foot__col{display:flex;flex-direction:column;gap:.7rem}
.site-foot__col a{font-size:.93rem;transition:color .3s}
.site-foot__col a:hover{color:var(--cream)}
.site-foot__bar{display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;align-items:center;padding:1.6rem 0;border-top:1px solid var(--line-light);font-family:var(--mono);font-size:.68rem;letter-spacing:.06em;color:rgba(243,235,219,.5)}
.site-foot__bar a:hover{color:var(--gold-2)}

/* ============================================================ NI BIASHARA */
.nb{background:linear-gradient(180deg,#0a0703,#120c06);color:var(--cream);padding:clamp(60px,9vw,110px) 0;border-top:1px solid rgba(192,144,46,.18)}
.nb__inner{text-align:center;max-width:900px;margin:0 auto}
.nb__by{font-family:var(--mono);font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(243,235,219,.6);margin:0 0 1.2rem}
.nb__by a{color:var(--gold-2);border-bottom:1px solid var(--gold-deep);padding-bottom:1px}
.nb__head{font-family:var(--serif);font-size:clamp(1.6rem,3.4vw,2.5rem);line-height:1.12;letter-spacing:-.02em;margin:0 0 .6em;text-wrap:balance}
.nb__lede{color:rgba(243,235,219,.66);max-width:56ch;margin:0 auto 3rem}
.nb__cards{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,2vw,22px);text-align:left;margin-bottom:2.6rem}
.nb__card{background:rgba(255,255,255,.03);border:1px solid var(--line-light);border-radius:var(--r);padding:1.6rem;transition:border-color .4s,transform .4s var(--ease)}
.nb__card:hover{border-color:rgba(192,144,46,.4);transform:translateY(-4px)}
.nb__num{font-family:var(--mono);font-size:.7rem;letter-spacing:.16em;color:var(--gold-deep)}
.nb__card h4{font-family:var(--serif);font-size:1.25rem;margin:.7rem 0 .5rem}
.nb__card p{font-size:.88rem;color:rgba(243,235,219,.66);margin:0}
.nb__cta{margin-top:0}

/* ============================================================ CART */
.cart-overlay{position:fixed;inset:0;background:rgba(13,9,5,.55);backdrop-filter:blur(3px);z-index:100;opacity:0;animation:fadeIn .4s forwards}
@keyframes fadeIn{to{opacity:1}}
.cart{position:fixed;top:0;right:0;bottom:0;width:min(440px,92vw);background:var(--cream-2);z-index:110;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .5s var(--ease);box-shadow:-20px 0 60px -20px rgba(0,0,0,.4)}
.cart.open{transform:none}
.cart__head{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 1.6rem;border-bottom:1px solid var(--line)}
.cart__head h3{font-family:var(--serif);font-size:1.5rem}
.cart__close{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;color:var(--ink);transition:background .3s}
.cart__close:hover{background:rgba(33,24,16,.07)}
.cart__progress{padding:1rem 1.6rem;border-bottom:1px solid var(--line);font-family:var(--mono);font-size:.68rem;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft)}
.cart__progress-bar{height:6px;border-radius:4px;background:rgba(33,24,16,.08);overflow:hidden;margin-bottom:.6rem}
.cart__progress-bar i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--gold),var(--green));transition:width .6s var(--ease)}
.cart__progress p{display:flex;align-items:center;gap:.4em;margin:0}
.cart__progress .ic{width:14px;height:14px;color:var(--gold-deep)}
.cart__progress b{color:var(--ink)}
.cart__items{flex:1;overflow-y:auto;padding:1rem 1.6rem}
.cart__empty{text-align:center;padding:3rem 1rem;display:flex;flex-direction:column;align-items:center;gap:.6rem}
.cart__empty-ic{width:64px;height:64px;border-radius:50%;display:grid;place-items:center;background:rgba(33,24,16,.05);color:var(--gold-deep)}
.cart__empty-ic .ic{width:30px;height:30px}
.cart__empty p{font-family:var(--serif);font-size:1.3rem;margin:0}
.cart__empty small{color:var(--ink-soft);max-width:30ch;margin-bottom:.6rem}
.citem{display:flex;gap:1rem;padding:1.1rem 0;border-bottom:1px solid var(--line-2)}
.citem__bean{flex:none;width:54px;height:54px;border-radius:12px;background:var(--espresso);color:var(--gold-2);display:grid;place-items:center}
.citem__bean .ic{width:26px;height:26px}
.citem__main{flex:1;min-width:0}
.citem__name{font-family:var(--serif);font-size:1.1rem;margin:0}
.citem__meta{font-family:var(--mono);font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);margin:.2rem 0 .6rem}
.citem__row{display:flex;align-items:center;justify-content:space-between}
.qty{display:inline-flex;align-items:center;gap:.4rem;border:1px solid var(--line);border-radius:100px;padding:.2rem}
.qty button{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;color:var(--ink);transition:background .3s}
.qty button:hover{background:rgba(33,24,16,.07)}
.qty button .ic{width:14px;height:14px}
.qty span{font-family:var(--mono);font-size:.85rem;min-width:18px;text-align:center}
.citem__price{font-family:var(--mono);font-size:.92rem;font-weight:500}
.citem__rm{font-family:var(--mono);font-size:.58rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);text-decoration:underline;text-underline-offset:2px;margin-top:.4rem}
.citem__rm:hover{color:var(--red)}
.cart__foot{padding:1.4rem 1.6rem;border-top:1px solid var(--line);background:var(--bone)}
.cart__line{display:flex;justify-content:space-between;font-size:.95rem;margin-bottom:.6rem}
.cart__line--muted{color:var(--ink-soft);font-size:.85rem}
.cart__line--total{font-family:var(--serif);font-size:1.4rem;margin:.6rem 0 1.1rem;padding-top:.8rem;border-top:1px solid var(--line)}
.cart__secure{display:flex;align-items:center;justify-content:center;gap:.4em;font-family:var(--mono);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);margin:.9rem 0 0}
.cart__secure .ic{width:13px;height:13px;color:var(--green)}

/* ============================================================ MODAL */
.modal{position:fixed;inset:0;z-index:120;display:none;place-items:center;padding:24px;background:rgba(13,9,5,.6);backdrop-filter:blur(4px)}
.modal.open{display:grid}
.modal__panel{position:relative;background:var(--cream-2);border-radius:var(--r-lg);padding:clamp(30px,4vw,52px);max-width:480px;width:100%;box-shadow:var(--shadow);animation:popIn .45s var(--ease)}
@keyframes popIn{from{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:none}}
.modal__panel .display-sm{margin:.1em 0 .6em}
.modal__panel>p{color:var(--ink-soft);margin-bottom:1.6rem}
.modal__close{position:absolute;top:16px;right:16px;width:40px;height:40px;border-radius:50%;display:grid;place-items:center;color:var(--ink);transition:background .3s}
.modal__close:hover{background:rgba(33,24,16,.07)}

/* ============================================================ TOAST */
.toast{position:fixed;left:50%;bottom:28px;transform:translate(-50%,140%);z-index:200;background:var(--espresso);color:var(--cream);font-size:.92rem;font-weight:500;padding:.9em 1.4em;border-radius:100px;box-shadow:var(--shadow);display:flex;align-items:center;gap:.6em;transition:transform .5s var(--ease);max-width:90vw}
.toast.show{transform:translate(-50%,0)}
.toast .ic{width:18px;height:18px;color:var(--gold-2)}

/* ============================================================ RESPONSIVE */
@media (max-width:1024px){
  .reviews__grid{columns:2}
  .blends{grid-template-columns:1fr 1fr}
  .blend:last-child{grid-column:1/-1}
  .steps-row{grid-template-columns:1fr 1fr;gap:36px 24px}
}
@media (max-width:860px){
  .nav,.hide-sm{display:none}
  .burger{display:flex}
  .story__grid,.regions,.sample__grid,.brew__panel{grid-template-columns:1fr}
  .story__media{aspect-ratio:4/3;max-height:460px}
  .regions__map{order:2}
  .subscribe__cards,.nb__cards{grid-template-columns:1fr}
  .subcard--feature{order:-1}
  .site-foot__grid{grid-template-columns:1fr}
  .flight{flex-direction:column;align-items:flex-start}
}
@media (max-width:680px){
  body{font-size:16px}
  .blends{grid-template-columns:1fr}
  .blend:last-child{grid-column:auto}
  .reviews__grid{columns:1}
  .steps-row{grid-template-columns:1fr}
  .ship-tiers__row{grid-template-columns:1fr 1fr}
  .journey{flex-direction:column;gap:1.4rem}
  .journey__line{width:100%;min-height:60px;transform:rotate(90deg);max-width:120px}
  .field-row{grid-template-columns:1fr}
  .hero__inner{padding-top:130px}
  .reviews__cta{flex-direction:column;align-items:flex-start}
}
