/* ═══════════════════════════════════════════════
   TOKENS — DARK EDITION
═══════════════════════════════════════════════ */
:root{
  --cream:#F5EFE0;
  --parchment:#EDE3CC;
  --espresso:#1A0A00;
  --roast:#3D1C06;
  --caramel:#C8843A;
  --gold:#E8B86D;
  --gold-dk:#B87333;
  --mist:#F9F4EC;
  --white:#FFFDF7;
  --text:#2C1A0E;
  --subtle:#7A5C3E;
  --gold-line:rgba(232,184,109,.22);
  --gold-glow:rgba(232,184,109,.14);
  --ff-display:'Bebas Neue',sans-serif;
  --ff-serif:'Cormorant Garamond',Georgia,serif;
  --ff-body:'DM Sans',sans-serif;
  --expo:cubic-bezier(0.16,1,0.3,1);
  --inout:cubic-bezier(0.65,0,0.35,1);
}

/* ═══════════════════════════════════════════════
   RESET
═══════════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-tap-highlight-color:transparent}
body{font-family:var(--ff-body);background:var(--espresso);color:var(--cream);overflow-x:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;border:none;cursor:pointer;background:none}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--espresso)}
::-webkit-scrollbar-thumb{background:var(--caramel);border-radius:99px}
body::before{content:'';position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.03;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)'/%3E%3C/svg%3E");background-size:180px}

/* ═══════════════════════════════════════════════
   GOLD DIVIDER
═══════════════════════════════════════════════ */
.gold-divider{display:flex;align-items:center;gap:1rem;margin:1.5rem 0}
.gold-divider::before,.gold-divider::after{content:'';flex:1;height:1px;background:linear-gradient(to right,transparent,var(--caramel),transparent)}
.gold-divider span{font-size:.55rem;letter-spacing:.35em;text-transform:uppercase;color:var(--caramel);white-space:nowrap}

/* ═══════════════════════════════════════════════
   NAV
═══════════════════════════════════════════════ */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:0 5vw;height:70px;display:flex;align-items:center;justify-content:space-between;transition:background .4s var(--inout),border-color .4s,box-shadow .4s;border-bottom:1px solid transparent}
nav.scrolled{background:rgba(26,10,0,.95);backdrop-filter:blur(16px);border-color:var(--gold-line);box-shadow:0 4px 40px rgba(0,0,0,.4)}
.nav-logo-main{font-family:var(--ff-display);font-size:1.5rem;letter-spacing:.1em;color:var(--gold)}
.nav-logo-sub{font-family:var(--ff-body);font-size:.48rem;letter-spacing:.3em;text-transform:uppercase;color:var(--caramel);opacity:.7;margin-top:.15rem}
.nav-logo{display:flex;flex-direction:column;line-height:1;}
.logo{width: auto;height: 60px;display: flex;}
.nav-links{display:flex;gap:2.8rem;list-style:none}
.nav-links a{font-family:var(--ff-body);font-size:.72rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--cream);opacity:.7;position:relative;padding-bottom:.2rem;transition:opacity .2s,color .2s}
.nav-links a::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:right;transition:transform .3s var(--expo)}
.nav-links a:hover{opacity:1;color:var(--gold)}
.nav-links a:hover::after{transform:scaleX(1);transform-origin:left}
.nav-cta{visibility: hidden;  font-family:var(--ff-body);font-size:.7rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--espresso);background:var(--gold);padding:.6rem 1.5rem;border-radius:99px;border:none;position:relative;overflow:hidden;transition:background .2s,color .2s,transform .2s,box-shadow .2s}
.nav-cta:hover{background:var(--caramel);color:var(--cream);transform:scale(1.04);box-shadow:0 6px 20px rgba(200,132,58,.3)}
.nav-ham{display:none;flex-direction:column;gap:5px;padding:4px;z-index:101}
.nav-ham span{display:block;width:24px;height:1.5px;background:var(--cream);border-radius:99px;transition:transform .3s,opacity .3s}
.nav-ham.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-ham.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-ham.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.mob-drawer{position:fixed;inset:0;z-index:99;background:var(--espresso);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;opacity:0;pointer-events:none;transition:opacity .35s}
.mob-drawer.open{opacity:1;pointer-events:all}
.mob-drawer a{font-family:var(--ff-display);font-size:clamp(2.5rem,8vw,4rem);letter-spacing:.08em;color:var(--cream);transition:color .2s}
.mob-drawer a:hover{color:var(--gold)}
.mob-drawer .mob-order{visibility: hidden;  font-family:var(--ff-body);font-size:.8rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--espresso);background:var(--gold);padding:.8rem 2.5rem;border-radius:99px;margin-top:1rem}

/* ═══════════════════════════════════════════════
   HERO
═══════════════════════════════════════════════ */
#home{min-height:100svh;background:var(--espresso);position:relative;overflow:hidden;display:grid;grid-template-columns:1fr 1fr;align-items:center}
.hero-bg-circle{position:absolute;border-radius:50%;pointer-events:none}
.hero-bg-1{width:70vmax;height:70vmax;top:-20vmax;right:-20vmax;background:radial-gradient(circle,rgba(61,28,6,.7) 0%,transparent 70%)}
.hero-bg-2{width:40vmax;height:40vmax;bottom:-10vmax;left:-5vmax;background:radial-gradient(circle,rgba(200,132,58,.15) 0%,transparent 70%)}
.hero-left{padding:10rem 6vw 6rem 8vw;position:relative;z-index:2}
.hero-eyebrow{display:inline-flex;align-items:center;gap:.7rem;font-family:var(--ff-body);font-size:.65rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-bottom:1.5rem;opacity:0;transform:translateY(16px);animation:riseUp .7s .2s var(--expo) forwards}
.hero-eyebrow::before{content:'';display:block;width:30px;height:1px;background:var(--gold)}
.hero-heading{font-family:var(--ff-display);font-size:clamp(4.5rem,9vw,9rem);line-height:.92;letter-spacing:.02em;color:var(--cream);margin-bottom:1.6rem;opacity:0;transform:translateY(28px);animation:riseUp .9s .4s var(--expo) forwards}
.hero-heading .italic-gold{font-style:italic;font-family:var(--ff-serif);color:var(--gold);font-size:.85em}
.hero-sub{font-family:var(--ff-serif);font-size:clamp(1.1rem,1.8vw,1.35rem);font-style:italic;color:var(--parchment);opacity:0;letter-spacing:.04em;margin-bottom:2.8rem;transform:translateY(16px);animation:riseUp .8s .6s var(--expo) forwards}
.hero-actions{display:flex;gap:1rem;align-items:center;opacity:0;transform:translateY(16px);animation:riseUp .8s .8s var(--expo) forwards}
.btn-primary{display: none;align-items:center;gap:.6rem;font-family:var(--ff-body);font-size:.8rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--espresso);background:var(--gold);padding:.85rem 2rem;border-radius:99px;border:none;cursor:pointer;transition:background .25s,transform .25s,box-shadow .25s}
.btn-primary:hover{background:var(--caramel);color:var(--cream);transform:translateY(-2px);box-shadow:0 10px 30px rgba(200,132,58,.4)}
.btn-primary svg{transition:transform .25s}
.btn-primary:hover svg{transform:translateX(3px)}
.btn-ghost{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--ff-body);font-size:.8rem;font-weight:400;letter-spacing:.12em;text-transform:uppercase;color:var(--cream);opacity:.5;transition:opacity .2s}
.btn-ghost:hover{opacity:1}
.hero-stats{display:flex;gap:2.5rem;margin-top:3.5rem;padding-top:2.5rem;border-top:1px solid rgba(232,184,109,.15);opacity:0;transform:translateY(16px);animation:riseUp .7s 1s var(--expo) forwards}
.hero-stat-num{font-family:var(--ff-display);font-size:2rem;color:var(--gold);line-height:1}
.hero-stat-label{font-family:var(--ff-body);font-size:.6rem;font-weight:400;letter-spacing:.18em;text-transform:uppercase;color:var(--cream);opacity:.4;margin-top:.25rem}
.hero-scroll-hint{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);z-index:5;display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--parchment);opacity:.35;font-family:var(--ff-body);font-size:.58rem;letter-spacing:.22em;text-transform:uppercase;animation:scrollBounce 2.4s ease-in-out infinite}
.hero-scroll-hint::after{content:'';display:block;width:1px;height:36px;background:linear-gradient(to bottom,var(--caramel),transparent)}

/* ═══════════════════════════════════════════════
   HERO RIGHT — DARK ANIMATED SCENE
═══════════════════════════════════════════════ */
.hero-right{position:relative;z-index:2;display:flex;align-items:center;justify-content:center;padding:8rem 6vw 6rem 2vw;opacity:0;animation:fadeIn 1.1s .9s var(--expo) forwards}

.cup-scene{position:relative;width:min(400px,88vw);height:min(540px,95vw);display:flex;align-items:center;justify-content:center}

/* Glows */
.cup-glow{position:absolute;border-radius:50%;pointer-events:none}
.cup-glow-outer{inset:-60px;background:radial-gradient(circle at 50% 60%,rgba(200,132,58,.12) 0%,rgba(200,132,58,.04) 40%,transparent 70%);animation:glowPulse 5s ease-in-out infinite}
.cup-glow-inner{width:270px;height:270px;bottom:30px;left:50%;transform:translateX(-50%);background:radial-gradient(circle,rgba(200,132,58,.22) 0%,transparent 70%);filter:blur(28px);animation:glowPulse 5s ease-in-out infinite reverse}

/* Rings */
.cup-ring{position:absolute;border-radius:50%;border:1px solid rgba(232,184,109,.18);left:50%;top:50%;transform:translate(-50%,-50%) scale(.6);opacity:0;animation:ringReveal 1s var(--expo) forwards}
.cup-ring-1{width:400px;height:400px;animation-delay:.2s}
.cup-ring-2{width:490px;height:490px;border-style:dashed;border-color:rgba(232,184,109,.08);animation-delay:.4s}
.cup-ring-3{width:580px;height:580px;border-color:rgba(232,184,109,.04);animation-delay:.55s}

/* Orbit */
.cup-orbit{position:absolute;width:370px;height:370px;left:50%;top:50%;opacity:0;animation:orbitIn 1s .8s var(--expo) forwards}
.cup-orbit.live{animation:orbitSpin 22s linear infinite}
.cup-orbit-item{position:absolute;width:28px;height:28px;border-radius:50%;background:rgba(61,28,6,.9);border:1px solid rgba(232,184,109,.2);display:flex;align-items:center;justify-content:center;font-size:.85rem;box-shadow:0 2px 10px rgba(0,0,0,.3)}
.cup-orbit.live .cup-orbit-item{animation:counterOrbit 22s linear infinite}
.cup-orbit-item:nth-child(1){top:calc(50% - 185px);left:calc(50% - 14px)}
.cup-orbit-item:nth-child(2){top:calc(50% - 129px);left:calc(50% + 136px)}
.cup-orbit-item:nth-child(3){top:calc(50% + 62px);left:calc(50% + 167px)}
.cup-orbit-item:nth-child(4){top:calc(50% + 167px);left:calc(50% + 26px)}
.cup-orbit-item:nth-child(5){top:calc(50% + 167px);left:calc(50% - 75px)}
.cup-orbit-item:nth-child(6){top:calc(50% + 62px);left:calc(50% - 182px)}
.cup-orbit-item:nth-child(7){top:calc(50% - 129px);left:calc(50% - 162px)}

/* Particles */
.cup-particles{position:absolute;inset:0;pointer-events:none}
.cup-dot{position:absolute;border-radius:50%;background:var(--caramel)}
.cup-dot:nth-child(1){width:4px;height:4px;top:12%;left:8%;opacity:.3;animation:drift 7s .5s ease-in-out infinite}
.cup-dot:nth-child(2){width:3px;height:3px;top:22%;left:84%;opacity:.22;animation:drift 9s 1.2s ease-in-out infinite reverse}
.cup-dot:nth-child(3){width:5px;height:5px;top:72%;left:5%;opacity:.18;animation:drift 8s 2.1s ease-in-out infinite}
.cup-dot:nth-child(4){width:3px;height:3px;top:80%;left:88%;opacity:.25;animation:drift 6s .8s ease-in-out infinite reverse}
.cup-dot:nth-child(5){width:4px;height:4px;top:8%;left:44%;opacity:.12;animation:drift 10s 1.6s ease-in-out infinite}
.cup-dot:nth-child(6){width:3px;height:3px;top:55%;left:92%;opacity:.2;animation:drift 7.5s 3s ease-in-out infinite reverse}

/* Cup */
.cup-frame{position:relative;width:290px;z-index:10;opacity:0;transform:translateY(36px) scale(.92);animation:cupIn 1.1s .5s var(--expo) forwards}
.cup-float{animation:floatBob 6s ease-in-out infinite}
/* Gold border + slider - DARK */
.cup-border{position:relative;border-radius:36px;padding:3px;background:linear-gradient(145deg,var(--caramel) 0%,var(--gold) 40%,var(--gold-dk) 70%,var(--caramel) 100%);background-size:300% 300%;box-shadow:0 0 0 1px rgba(255,255,255,.1) inset,0 28px 70px rgba(0,0,0,.5),0 8px 24px rgba(0,0,0,.3),0 0 50px rgba(200,132,58,.18);animation:borderShimmerDk 4s ease-in-out infinite,goldSweep 6s ease-in-out infinite;overflow:hidden}
/* Slider track */
.cup-slider{position:relative;border-radius:33px;overflow:hidden;aspect-ratio:4/5;width:100%}
.cup-slides{display:flex;height:100%;will-change:transform;transition:none}
.cup-slide{flex:0 0 100%;height:100%;position:relative;overflow:hidden}
.cup-img{width:100%;height:100%;display:block;object-fit:cover;filter:brightness(.92) contrast(1.06) saturate(1.1);user-select:none;-webkit-user-drag:none;border-radius:0}
.cup-slides.animating{transition:transform .95s cubic-bezier(0.77,0,0.18,1)}
/* Gold shimmer wipe */
.cup-flash{position:absolute;inset:0;pointer-events:none;z-index:5;border-radius:33px;opacity:0;background:linear-gradient(110deg,transparent 20%,rgba(200,132,58,.7) 48%,rgba(240,190,100,.45) 52%,transparent 80%);background-size:250% 100%;background-position:150% 0}
.cup-flash.active{animation:cupWipe .85s cubic-bezier(0.4,0,0.2,1) forwards}
@keyframes cupWipe{0%{opacity:0;background-position:150% 0}15%{opacity:1}70%{opacity:.8;background-position:-30% 0}100%{opacity:0;background-position:-80% 0}}
/* Scale-bloom on incoming slide */
.cup-slide.bloom img{animation:slideBloom .95s cubic-bezier(0.16,1,0.3,1) forwards}
@keyframes slideBloom{from{transform:scale(1.1);filter:brightness(.6) saturate(.4)}to{transform:scale(1);filter:brightness(.92) contrast(1.06) saturate(1.1)}}
/* Dot indicators */
.cup-dots{position:absolute;bottom:-26px;left:50%;transform:translateX(-50%);display:flex;gap:7px;z-index:30}
.cup-dot-ind{width:6px;height:6px;border-radius:99px;background:rgba(61,28,6,.7);border:1px solid rgba(200,132,58,.3);cursor:pointer;transition:background .35s,width .45s cubic-bezier(0.16,1,0.3,1),box-shadow .35s}
.cup-dot-ind.on{width:22px;background:var(--caramel);border-color:var(--gold);box-shadow:0 0 8px rgba(200,132,58,.5)}
/* Badge text flip */
.cup-badge-price.flipping{animation:badgeFlip .55s cubic-bezier(0.16,1,0.3,1)}
@keyframes badgeFlip{0%{transform:translateY(0) scale(1);opacity:1}25%{transform:translateY(-10px) scale(.88);opacity:0}65%{transform:translateY(12px) scale(.88);opacity:0}100%{transform:translateY(0) scale(1);opacity:1}}
/* Chip content swap */
.cup-chip.chip-swap{animation:chipSwap .5s cubic-bezier(0.16,1,0.3,1)}
@keyframes chipSwap{0%,100%{transform:translateY(0);opacity:1}50%{transform:translateY(-6px);opacity:0}}

/* Steam */
.cup-steam{position:absolute;top:-28px;left:50%;transform:translateX(-50%);width:110px;height:75px;pointer-events:none;z-index:20}
/* .steam-puff{position:absolute;bottom:0;border-radius:50%;background:rgba(255,255,255,.4);filter:blur(7px);opacity:0} */
.steam-puff{position:absolute;bottom:0;border-radius:50%;background:rgba(255, 255, 255, 1);filter:blur(7px);opacity:0}

.steam-puff:nth-child(1){width:16px;height:16px;left:28%;animation:steamRise 3.2s 1.2s ease-out infinite}
.steam-puff:nth-child(2){width:20px;height:20px;left:48%;animation:steamRise 3.2s 1.9s ease-out infinite}
.steam-puff:nth-child(3){width:14px;height:14px;left:68%;animation:steamRise 3.2s 2.5s ease-out infinite}
.steam-puff:nth-child(4){width:18px;height:18px;left:18%;animation:steamRise 3.6s 3s ease-out infinite}
.steam-puff:nth-child(5){width:12px;height:12px;left:58%;animation:steamRise 3s 3.6s ease-out infinite}

/* Price badge */
.cup-badge-price{display: none;  position:absolute;bottom:7%;left:-16%;z-index:20;background:var(--roast);border:1px solid rgba(232,184,109,.25);border-radius:14px;padding:1rem 1.3rem;box-shadow:0 8px 36px rgba(0,0,0,.4),0 0 20px rgba(200,132,58,.12);min-width:130px;opacity:0;animation:badgeIn .75s 1.3s var(--expo) forwards,badgeFloat 5s 2.1s ease-in-out infinite}
.cup-badge-amount{font-family:var(--ff-display);font-size:2.2rem;line-height:1;color:var(--gold);animation:goldSlide 3s ease-in-out infinite;background:linear-gradient(135deg,var(--gold-dk) 0%,var(--gold) 50%,var(--gold-dk) 100%);background-size:200% 100%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.cup-badge-label{font-family:var(--ff-body);font-size:.58rem;letter-spacing:.22em;text-transform:uppercase;color:var(--cream);opacity:.5;margin-top:.3rem}

/* Roast badge */
.cup-badge-roast{position:absolute;top:5%;right:-8%;z-index:20;width:78px;height:78px;border-radius:50%;background:linear-gradient(145deg,var(--roast),var(--espresso));border:2px solid var(--caramel);display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 8px 26px rgba(0,0,0,.5),0 0 0 4px rgba(200,132,58,.1);opacity:0;animation:roastIn .7s 1.55s var(--expo) forwards,roastSpin 12s 2.3s linear infinite}
.cup-badge-roast-inner{display:flex;flex-direction:column;align-items:center;animation:counterRoast 12s 2.3s linear infinite}
.cup-badge-roast span:first-child{font-family:var(--ff-serif);font-size:1rem;font-weight:700;color:var(--gold);line-height:1}
.cup-badge-roast span:last-child{font-family:var(--ff-body);font-size:.4rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(232,184,109,.5);margin-top:.15rem}

/* Aroma chips */
.cup-chip{position:absolute;display:inline-flex;align-items:center;gap:.4rem;background:rgba(61,28,6,.9);backdrop-filter:blur(12px);border:1px solid rgba(232,184,109,.2);border-radius:99px;padding:.4rem .9rem .4rem .45rem;box-shadow:0 4px 18px rgba(0,0,0,.3);opacity:0;z-index:25}
.cup-chip-dot{width:20px;height:20px;border-radius:50%;background:linear-gradient(135deg,var(--gold-dk),var(--gold));display:flex;align-items:center;justify-content:center;font-size:.65rem;flex-shrink:0}
.cup-chip-text{font-family:var(--ff-body);font-size:.55rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold)}
.cup-chip-1{top:16%;right:-6%;animation:chipIn .65s 1.7s var(--expo) forwards,chipFloat 6s 2.4s ease-in-out infinite}
.cup-chip-2{top:38%;right:-12%;animation:chipIn .65s 2s var(--expo) forwards,chipFloat2 7s 2.7s ease-in-out infinite}

/* Drip */
.cup-drip{position:absolute;bottom:-6px;left:50%;transform:translateX(-50%);z-index:8;pointer-events:none}
.drip-drop{width:7px;height:7px;border-radius:50% 50% 55% 55%;background:linear-gradient(to bottom,#5C2B0A,#3D1600);opacity:0;animation:dripFall 4s 2.2s ease-in infinite}
.drip-drop:nth-child(2){animation-delay:5s}
.drip-drop:nth-child(3){animation-delay:7.5s}

/* ═══════════════════════════════════════════════
   MARQUEE
═══════════════════════════════════════════════ */
.marquee-strip{background:var(--roast);padding:.85rem 0;overflow:hidden;border-top:1px solid rgba(232,184,109,.12);border-bottom:1px solid rgba(232,184,109,.12)}
.marquee-track{display:flex;width:max-content;animation:marqueeScroll 28s linear infinite}
.marquee-item{display:flex;align-items:center;gap:1.2rem;padding:0 2rem;font-family:var(--ff-body);font-size:.65rem;letter-spacing:.26em;text-transform:uppercase;color:rgba(232,184,109,.4);white-space:nowrap}
.marquee-dot{width:3px;height:3px;border-radius:50%;background:var(--caramel);opacity:.5;flex-shrink:0}

/* ═══════════════════════════════════════════════
   SECTION HEADERS
═══════════════════════════════════════════════ */
.sec-eyebrow{font-family:var(--ff-body);font-size:.68rem;letter-spacing:.28em;text-transform:uppercase;color:var(--caramel);display:block;margin-bottom:.9rem}
.sec-title{font-family:var(--ff-display);font-size:clamp(2.6rem,5vw,4.5rem);letter-spacing:.04em;color:var(--cream);line-height:1}
.sec-title.dark-title{color:var(--espresso)}
.sec-title .gold-word{color:var(--gold)}
.sec-sub{font-family:var(--ff-serif);font-style:italic;font-size:clamp(1rem,1.5vw,1.2rem);color:var(--subtle);margin-top:.8rem}
.sec-sub.light-sub{color:var(--parchment);opacity:.65}

/* ═══════════════════════════════════════════════
   ABOUT
═══════════════════════════════════════════════ */
#about{padding:8rem 5vw;background:var(--mist,#F9F4EC);position:relative;overflow:hidden}
.mist{background:#F9F4EC}
#about::before{content:'BREW';font-family:var(--ff-display);font-size:min(28vw,340px);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--caramel);opacity:.04;pointer-events:none;letter-spacing:-.02em;white-space:nowrap}
.about-grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.about-body{font-family:var(--ff-serif);font-size:clamp(1.05rem,1.4vw,1.2rem);line-height:1.85;color:var(--text);opacity:.85;margin-top:1.5rem}
.about-body p+p{margin-top:1.2rem}
.about-body strong{color:var(--roast);font-weight:600}
.about-pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:2.5rem}
.pillar{padding:1.3rem 1rem 1.2rem;border:1px solid rgba(200,132,58,.15);border-radius:8px;text-align:center;background:white;transition:border-color .3s,box-shadow .3s,transform .3s}
.pillar:hover{border-color:rgba(200,132,58,.35);box-shadow:0 8px 30px rgba(200,132,58,.1);transform:translateY(-4px)}
.pillar-icon{font-size:1.4rem;margin-bottom:.5rem}
.pillar-name{font-family:var(--ff-body);font-size:.62rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--subtle)}
.about-photos{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:12px;position:relative}
.about-photo{border-radius:10px;overflow:hidden;position:relative}
.about-photo img{width:100%;height:100%;object-fit:cover;transition:transform .55s var(--expo)}
.about-photo:hover img{transform:scale(1.06)}
.about-photo:first-child{grid-row:1/3;border-radius:14px;box-shadow:0 20px 60px rgba(26,10,0,.18)}
.about-photo:nth-child(2){aspect-ratio:4/3;box-shadow:0 8px 25px rgba(26,10,0,.1)}
.about-photo:nth-child(3){aspect-ratio:4/3;box-shadow:0 8px 25px rgba(26,10,0,.1)}
.about-photos::after{content:'';position:absolute;top:-16px;left:-16px;width:50px;height:50px;border-top:2px solid var(--caramel);border-left:2px solid var(--caramel);pointer-events:none;opacity:.5}
.about-photos::before{content:'';position:absolute;bottom:-16px;right:-16px;width:50px;height:50px;border-bottom:2px solid var(--caramel);border-right:2px solid var(--caramel);pointer-events:none;opacity:.5;z-index:0}

/* ═══════════════════════════════════════════════
   GALLERY
═══════════════════════════════════════════════ */
#gallery{padding:8rem 5vw;background:var(--espresso)}
.gallery-header{text-align:center;margin-bottom:4rem}
.gallery-strip{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;max-width:1400px;margin:0 auto}
.gallery-item{border-radius:10px;overflow:hidden;aspect-ratio:2/3;position:relative;cursor:pointer}
.gallery-item:nth-child(2),.gallery-item:nth-child(5){aspect-ratio:2/4;margin-top:-15%}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--expo),filter .4s;filter:brightness(.85) saturate(.9)}
.gallery-item:hover img{transform:scale(1.08);filter:brightness(.95) saturate(1.15)}
.gallery-item-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(26,10,0,.8) 0%,transparent 50%);opacity:0;transition:opacity .35s;display:flex;align-items:flex-end;padding:1rem}
.gallery-item:hover .gallery-item-overlay{opacity:1}
.gallery-item-label{font-family:var(--ff-body);font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(245,239,224,.75)}

/* ═══════════════════════════════════════════════
   MENU
═══════════════════════════════════════════════ */
#menu{padding:8rem 5vw;background:var(--mist,#F9F4EC)}
.menu-header{text-align:center;margin-bottom:3.5rem}
.tab-bar{display:flex;justify-content:center;margin-bottom:3.5rem;border:1px solid rgba(200,132,58,.2);border-radius:6px;overflow:hidden;max-width:700px;margin-left:auto;margin-right:auto;box-shadow:0 2px 12px rgba(26,10,0,.1)}
.tab{flex:1;font-family:var(--ff-body);font-size:.68rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--subtle);background:#F9F4EC;padding:.75rem .5rem;border:none;cursor:pointer;border-right:1px solid rgba(200,132,58,.15);transition:background .25s,color .25s}
.tab:last-child{border-right:none}
.tab.active{background:var(--espresso);color:var(--gold)}
.tab:not(.active):hover{background:var(--parchment);color:var(--roast)}
.menu-panel{display:none}
.menu-panel.active{display:block}
.menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:1.4rem;max-width:1200px;margin:0 auto}
.menu-card{background:var(--white);border:1px solid rgba(200,132,58,.12);border-radius:10px;padding:1.5rem 1.1rem 1.3rem;text-align:center;transition:transform .3s var(--expo),box-shadow .3s,border-color .3s;position:relative;overflow:hidden}
.menu-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(to right,var(--gold-dk),var(--gold));transform:scaleX(0);transform-origin:left;transition:transform .35s var(--expo)}
.menu-card:hover{transform:translateY(-6px);box-shadow:0 16px 50px rgba(26,10,0,.12),0 4px 12px rgba(200,132,58,.08);border-color:rgba(200,132,58,.3)}
.menu-card:hover::after{transform:scaleX(1)}
.menu-img-wrap{width:88px;height:88px;margin:0 auto .9rem;border-radius:50%;overflow:hidden;background:var(--mist,#F9F4EC);border:2px solid rgba(200,132,58,.15);transition:border-color .3s}
.menu-card:hover .menu-img-wrap{border-color:var(--caramel)}
.menu-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .4s var(--expo)}
.menu-card:hover .menu-img-wrap img{transform:scale(1.12)}
.menu-card-name{font-family:var(--ff-serif);font-size:1rem;font-weight:600;color:var(--roast);margin-bottom:.45rem;line-height:1.2}
.menu-card-price{display: none; font-family:var(--ff-display);font-size:1.1rem;letter-spacing:.06em;color:var(--caramel)}
.menu-card-price .cur{font-family:var(--ff-body);font-size:.65rem;letter-spacing:.1em;opacity:.6;vertical-align:super;margin-right:.1rem}

/* ═══════════════════════════════════════════════
   CONTACT
═══════════════════════════════════════════════ */
#contact{padding:8rem 5vw;background:var(--roast);position:relative;overflow:hidden}
#contact::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 50% at 80% 50%,rgba(200,132,58,.12),transparent),radial-gradient(ellipse 40% 60% at 10% 80%,rgba(0,0,0,.3),transparent)}
.contact-grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start;position:relative;z-index:1}
.contact-item{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.5rem}
.contact-icon{width:40px;height:40px;border-radius:10px;background:rgba(232,184,109,.1);border:1px solid rgba(232,184,109,.2);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--gold)}
.contact-icon svg{width:16px;height:16px}
.contact-key{font-family:var(--ff-body);font-size:.6rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);opacity:.55;margin-bottom:.3rem}
.contact-val{font-family:var(--ff-serif);font-size:1rem;color:var(--cream);line-height:1.6}
.contact-map-wrap{border-radius:14px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.5);border:1px solid rgba(255,255,255,.06)}
.contact-map-wrap iframe{width:100%;height:380px;display:block;border:none;filter:grayscale(.35) contrast(1.05)}

/* ═══════════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════════ */
footer{background:var(--espresso);padding:3.5rem 5vw 2rem;border-top:2px solid var(--gold-dk)}
.footer-top{display:flex;align-items:flex-start;justify-content:space-between;gap:3rem;flex-wrap:wrap;padding-bottom:2rem;border-bottom:1px solid rgba(232,184,109,.1);margin-bottom:2rem}
.footer-logo{font-family:var(--ff-display);font-size:1.8rem;letter-spacing:.1em;color:var(--gold)}
.footer-tagline{font-family:var(--ff-serif);font-style:italic;font-size:.85rem;color:rgba(232,184,109,.35);margin-top:.4rem}
.footer-nav-group h4{font-family:var(--ff-body);font-size:.6rem;font-weight:500;letter-spacing:.24em;text-transform:uppercase;color:rgba(232,184,109,.35);margin-bottom:1rem}
.footer-nav-list{list-style:none;display:flex;flex-direction:column;gap:.7rem}
.footer-nav-list a{font-family:var(--ff-body);font-size:.8rem;color:rgba(232,184,109,.45);transition:color .2s}
.footer-nav-list a:hover{color:var(--gold)}

/* Social icons */
.footer-social{display:flex;gap:.75rem;margin-top:1.5rem}
.social-icon{width:38px;height:38px;border-radius:8px;background:rgba(232,184,109,.07);border:1px solid rgba(232,184,109,.12);display:flex;align-items:center;justify-content:center;transition:background .25s,border-color .25s,transform .25s,box-shadow .25s;color:rgba(232,184,109,.45)}
.social-icon svg{width:17px;height:17px;fill:currentColor}
.social-icon:hover{background:rgba(232,184,109,.15);border-color:rgba(232,184,109,.35);color:var(--gold);transform:translateY(-3px);box-shadow:0 6px 20px rgba(232,184,109,.15)}
.social-icon.fb:hover{background:rgba(24,119,242,.15);border-color:rgba(24,119,242,.35);color:#5B9BD5}
.social-icon.ig:hover{background:rgba(225,48,108,.1);border-color:rgba(225,48,108,.3);color:#E1306C}
.social-icon.yt:hover{background:rgba(255,0,0,.1);border-color:rgba(255,0,0,.25);color:#FF4444}
.social-icon.wa:hover{background:rgba(37,211,102,.1);border-color:rgba(37,211,102,.25);color:#25D366}

.footer-bottom{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.footer-copy{font-family:var(--ff-body);font-size:.65rem;letter-spacing:.12em;color:rgba(240,200,122,.4)}
.footer-craft{font-family:var(--ff-body);font-size:.62rem;letter-spacing:.12em;color:rgba(240,200,122,.4)}

/* ═══════════════════════════════════════════════
   WA FAB
═══════════════════════════════════════════════ */
.wa-fab{position:fixed;bottom:2rem;right:2rem;z-index:200;width:54px;height:54px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(37,211,102,.45);transition:transform .25s var(--expo),box-shadow .25s}
.wa-fab:hover{transform:scale(1.12) translateY(-2px);box-shadow:0 10px 30px rgba(37,211,102,.55)}
.wa-fab svg{width:26px;height:26px;fill:white}

/* ═══════════════════════════════════════════════
   MODAL
═══════════════════════════════════════════════ */
.modal-bg{position:fixed;inset:0;z-index:500;background:rgba(26,10,0,.85);backdrop-filter:blur(8px);display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .35s}
.modal-bg.open{opacity:1;pointer-events:all}
.modal-box{background:var(--espresso);border-radius:20px 20px 0 0;padding:0 2rem 3rem;width:min(480px,100%);border:1px solid rgba(232,184,109,.15);border-bottom:none;transform:translateY(100%);transition:transform .45s var(--expo)}
.modal-bg.open .modal-box{transform:translateY(0)}
.modal-pull{width:36px;height:3px;border-radius:99px;background:rgba(245,239,224,.15);margin:1.2rem auto 2rem}
.modal-title{font-family:var(--ff-display);font-size:2.2rem;letter-spacing:.05em;color:var(--cream);text-align:center;margin-bottom:.4rem}
.modal-desc{font-family:var(--ff-serif);font-style:italic;font-size:1rem;color:var(--parchment);opacity:.55;text-align:center;margin-bottom:2rem}
.modal-wa-cta{display:flex;align-items:center;justify-content:center;gap:.8rem;width:100%;font-family:var(--ff-body);font-size:.78rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:white;background:#25D366;border:none;border-radius:8px;padding:1.1rem;cursor:pointer;box-shadow:0 4px 20px rgba(37,211,102,.25);transition:background .2s,transform .2s,box-shadow .2s}
.modal-wa-cta:hover{background:#1db954;transform:translateY(-2px);box-shadow:0 8px 28px rgba(37,211,102,.4)}
.modal-wa-cta svg{width:20px;height:20px;fill:white;flex-shrink:0}
.modal-dismiss{display:block;width:100%;margin-top:.9rem;padding:.7rem;font-family:var(--ff-body);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--cream);opacity:.3;background:transparent;border:none;cursor:pointer;transition:opacity .2s}
.modal-dismiss:hover{opacity:.7}

/* ═══════════════════════════════════════════════
   REVEAL
═══════════════════════════════════════════════ */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .75s var(--expo),transform .75s var(--expo)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal[data-delay="1"]{transition-delay:.1s}
.reveal[data-delay="2"]{transition-delay:.18s}
.reveal[data-delay="3"]{transition-delay:.26s}
.reveal[data-delay="4"]{transition-delay:.34s}
.reveal[data-delay="5"]{transition-delay:.42s}

/* ═══════════════════════════════════════════════
   KEYFRAMES
═══════════════════════════════════════════════ */
@keyframes riseUp{to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{to{opacity:1}}
@keyframes scrollBounce{0%,100%{transform:translateX(-50%) translateY(0)}55%{transform:translateX(-50%) translateY(5px)}}
@keyframes glowPulse{0%,100%{transform:scale(1);opacity:.7}50%{transform:scale(1.08);opacity:1}}
@keyframes ringReveal{to{transform:translate(-50%,-50%) scale(1);opacity:1}}
@keyframes orbitIn{to{opacity:1}}
@keyframes orbitSpin{from{transform:translate(-50%,-50%) rotate(0deg)}to{transform:translate(-50%,-50%) rotate(360deg)}}
@keyframes counterOrbit{from{transform:rotate(0deg)}to{transform:rotate(-360deg)}}
@keyframes cupIn{to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes floatBob{0%,100%{transform:translateY(0px) rotate(0deg)}30%{transform:translateY(-12px) rotate(.4deg)}60%{transform:translateY(-6px) rotate(-.3deg)}}
@keyframes borderShimmerDk{0%,100%{box-shadow:0 0 0 1px rgba(255,255,255,.1) inset,0 28px 70px rgba(0,0,0,.5),0 8px 24px rgba(0,0,0,.3),0 0 50px rgba(200,132,58,.18)}50%{box-shadow:0 0 0 1px rgba(255,255,255,.1) inset,0 32px 80px rgba(0,0,0,.6),0 8px 24px rgba(0,0,0,.35),0 0 80px rgba(200,132,58,.32)}}
@keyframes goldSweep{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
@keyframes steamRise{0%{opacity:0;transform:translateY(0) translateX(0) scale(.4)}20%{opacity:.5;transform:translateY(-16px) translateX(4px) scale(.8)}50%{opacity:.3;transform:translateY(-42px) translateX(-6px) scale(1.2)}80%{opacity:.1;transform:translateY(-65px) translateX(4px) scale(1.6)}100%{opacity:0;transform:translateY(-78px) translateX(0) scale(2)}}
@keyframes badgeIn{to{opacity:1;transform:translateX(0) scale(1)}}
@keyframes badgeFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}
@keyframes goldSlide{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
@keyframes roastIn{to{opacity:1;transform:scale(1) rotate(0deg)}}
@keyframes roastSpin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@keyframes counterRoast{from{transform:rotate(0deg)}to{transform:rotate(-360deg)}}
@keyframes chipIn{to{opacity:1;transform:translateX(0) scale(1)}}
@keyframes chipFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes chipFloat2{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes dripFall{0%{opacity:0;transform:translateY(0) scaleY(.5)}10%{opacity:.8;transform:translateY(0) scaleY(1.2)}60%{opacity:.6;transform:translateY(18px) scaleY(1)}100%{opacity:0;transform:translateY(30px) scaleY(.8) scale(.6)}}
@keyframes drift{0%,100%{transform:translateY(0) translateX(0) scale(1)}33%{transform:translateY(-18px) translateX(8px) scale(1.3)}66%{transform:translateY(-8px) translateX(-5px) scale(.8)}}
@keyframes marqueeScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ═══════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════ */
/* ═══════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════ */

/* ── Tablet: 900px and below ── */
@media(max-width:900px){
  /* Hero: stack vertically, cup BELOW text */
  #home{
    display:flex;flex-direction:column;
    min-height:100svh;height:auto;
    padding-bottom:3rem;
  }
  .hero-left{
    padding:8rem 7vw 1.5rem;
    order:1;flex-shrink:0;
  }
  .hero-heading{font-size:clamp(3.5rem,12vw,6.5rem)}

  /* Cup: visible, centred, full animations */
  .hero-right{
    order:2;
    display:flex;
    justify-content:center;align-items:center;
    padding:1rem 0 4rem;
    opacity:1 !important;
    animation:none !important;
    flex-shrink:0;
  }
  .cup-scene{
    width:clamp(280px,74vw,370px);height:clamp(380px,104vw,500px);
    opacity:1 !important;animation:none !important;
  }
  .cup-ring-1{width:clamp(260px,76vw,345px);height:clamp(260px,76vw,345px)}
  .cup-ring-2{width:clamp(320px,94vw,424px);height:clamp(320px,94vw,424px)}
  .cup-ring-3{width:clamp(380px,112vw,504px);height:clamp(380px,112vw,504px)}
  .cup-orbit{width:clamp(250px,73vw,325px);height:clamp(250px,73vw,325px)}
  .cup-orbit-item:nth-child(1){top:calc(50% - 149px);left:calc(50% - 14px)}
  .cup-orbit-item:nth-child(2){top:calc(50% - 104px);left:calc(50% + 110px)}
  .cup-orbit-item:nth-child(3){top:calc(50% + 50px); left:calc(50% + 134px)}
  .cup-orbit-item:nth-child(4){top:calc(50% + 134px);left:calc(50% + 22px)}
  .cup-orbit-item:nth-child(5){top:calc(50% + 134px);left:calc(50% - 61px)}
  .cup-orbit-item:nth-child(6){top:calc(50% + 50px); left:calc(50% - 147px)}
  .cup-orbit-item:nth-child(7){top:calc(50% - 104px);left:calc(50% - 131px)}
  .cup-frame{width:clamp(180px,53vw,240px)}
  .cup-glow-inner{width:clamp(170px,50vw,220px);height:clamp(170px,50vw,220px)}
  .cup-badge-price{left:-4%;bottom:5%;padding:.8rem 1.1rem;min-width:112px}
  .cup-badge-amount{font-size:1.65rem}
  .cup-badge-label{font-size:.52rem}
  .cup-badge-roast{width:64px;height:64px;right:-2%;top:5%}
  .cup-badge-roast span:first-child{font-size:.82rem}
  .cup-chip-1{top:13%;right:2%}
  .cup-chip-2{top:36%;right:-2%}
  .cup-chip-text{font-size:.5rem;letter-spacing:.12em}
  .cup-chip{padding:.3rem .7rem .3rem .35rem}
  .cup-chip-dot{width:16px;height:16px;font-size:.55rem}
  .cup-dots{bottom:-20px}

  .about-grid{grid-template-columns:1fr;gap:3rem}
  .about-photos{display:none}
  .gallery-strip{grid-template-columns:repeat(3,1fr);gap:8px}
  .gallery-item:nth-child(2),.gallery-item:nth-child(5){margin-top:0;aspect-ratio:2/3}
  .contact-grid{grid-template-columns:1fr;gap:3rem}
  .nav-links,.nav-cta{display:none}
  .nav-ham{display:flex}
  footer .footer-top{flex-direction:column}
}

/* ── Mobile: 600px and below ── */
@media(max-width:600px){
  .hero-left{padding:7rem 5vw 1rem}
  .hero-heading{font-size:clamp(3rem,13vw,5rem)}
  .hero-stats{gap:1.2rem}

  .cup-scene{width:clamp(230px,80vw,300px);height:clamp(320px,114vw,420px)}
  .cup-ring-1{width:clamp(214px,66vw,275px);height:clamp(214px,66vw,275px)}
  .cup-ring-2{width:clamp(264px,81vw,338px);height:clamp(264px,81vw,338px)}
  .cup-ring-3{width:clamp(312px,97vw,400px);height:clamp(312px,97vw,400px)}
  .cup-orbit{width:clamp(200px,61vw,260px);height:clamp(200px,61vw,260px)}
  .cup-orbit-item:nth-child(1){top:calc(50% - 117px);left:calc(50% - 14px)}
  .cup-orbit-item:nth-child(2){top:calc(50% - 82px); left:calc(50% + 86px)}
  .cup-orbit-item:nth-child(3){top:calc(50% + 39px); left:calc(50% + 106px)}
  .cup-orbit-item:nth-child(4){top:calc(50% + 106px);left:calc(50% + 17px)}
  .cup-orbit-item:nth-child(5){top:calc(50% + 106px);left:calc(50% - 48px)}
  .cup-orbit-item:nth-child(6){top:calc(50% + 39px); left:calc(50% - 116px)}
  .cup-orbit-item:nth-child(7){top:calc(50% - 82px); left:calc(50% - 103px)}
  .cup-frame{width:clamp(145px,44vw,190px)}
  .cup-glow-inner{width:clamp(140px,43vw,180px);height:clamp(140px,43vw,180px)}
  .cup-badge-price{left:0%;bottom:2%;padding:.65rem .9rem;min-width:96px}
  .cup-badge-amount{font-size:1.35rem}
  .cup-badge-label{font-size:.48rem}
  .cup-badge-roast{width:52px;height:52px;right:0%;top:2%}
  .cup-badge-roast span:first-child{font-size:.72rem}
  .cup-badge-roast span:last-child{font-size:.33rem}
  .cup-chip-1,.cup-chip-2{display:none}
  .cup-dots{bottom:-15px}
  .cup-dot-ind{width:5px;height:5px}
  .cup-dot-ind.on{width:17px}

  .gallery-strip{grid-template-columns:repeat(2,1fr)}
  .menu-grid{grid-template-columns:repeat(2,1fr)}
  .tab-bar{flex-wrap:wrap}
  .tab{min-width:calc(50% - 1px);border-bottom:1px solid rgba(200,132,58,.15)}
   .logo{height: 40px;}
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}
