/* ============================================================
   SUPRENO — Bold Maximalist (Webshop + Bemutató)
   Színek: piros / sárga / krém / fekete
   Tipográfia: Bricolage Grotesque + Archivo Black + Space Grotesk + Instrument Serif
   ============================================================ */

:root{
  --red:#FF3D2E;
  --red-d:#C0341B;
  --red-deep:#7a1610;
  --yel:#FFD33A;
  --yel-d:#E5B520;
  --cream:#FFF6E8;
  --black:#0A0A0A;
  --black-2:#1A140C;
  --gri:#666;
  --linie:#0A0A0A;
  --auriu:#C8941E;
  --auriu-l:#E8B84B;

  --display:'Bricolage Grotesque', 'Archivo Black', sans-serif;
  --black-display:'Archivo Black', Impact, sans-serif;
  --sans:'Space Grotesk', sans-serif;
  --serif:'Instrument Serif', serif;
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{background:var(--cream);color:var(--black);font-family:var(--sans);line-height:1.5;overflow-x:hidden;}
h1,h2,h3,h4{font-family:var(--display);font-weight:800;line-height:.92;letter-spacing:-1.5px;}
a{color:inherit;text-decoration:none;}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit;}
img,svg{max-width:100%;display:block;}
.wrap{max-width:1280px;margin:0 auto;padding:0 28px;}
.serif{font-family:var(--serif);font-style:italic;font-weight:400;}

/* Language toggle base */
.lang-hu{display:none;}
body.hu .lang-ro{display:none;}
body.hu .lang-hu{display:inline;}
body.hu .lang-hu.block{display:block;}

/* =========== TICKER (MARQUEE) =========== */
.tickerbar{background:var(--black);color:var(--cream);overflow:hidden;border-bottom:2px solid var(--black);}
.tickerbar-track{display:flex;gap:48px;padding:9px 0;font-family:var(--black-display);font-size:13px;letter-spacing:.5px;animation:marq 30s linear infinite;white-space:nowrap;}
.tickerbar-track span{flex-shrink:0;text-transform:uppercase;display:inline-flex;align-items:center;gap:48px;}
.tickerbar-track .dot{width:6px;height:6px;background:var(--yel);border-radius:50%;display:inline-block;}
@keyframes marq{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* =========== NAV =========== */
nav.top{position:sticky;top:0;z-index:100;background:var(--cream);border-bottom:2px solid var(--black);}
.nav-in{max-width:1280px;margin:0 auto;padding:14px 28px;display:flex;align-items:center;justify-content:space-between;gap:18px;}
.brand{display:flex;align-items:center;gap:10px;transition:transform .25s cubic-bezier(.5,1.5,.5,1);}
.brand:hover{transform:rotate(-2deg) scale(1.04);}
.brand-logo{height:84px;width:auto;display:block;}
.brand-logo-sm{height:84px;}
.nav-links{display:flex;gap:6px;align-items:center;}
.nav-links a{padding:8px 14px;font-size:13px;font-weight:600;color:var(--black);transition:.15s;border:1.5px solid transparent;}
.nav-links a:hover{background:var(--yel);border-color:var(--black);transform:translate(-2px,-2px);box-shadow:3px 3px 0 var(--black);}
.nav-links a.active{background:var(--black);color:var(--yel);border-color:var(--black);}
.nav-side{display:flex;align-items:center;gap:10px;}
.lang{display:inline-flex;border:2px solid var(--black);}
.lang a, .lang button{padding:6px 12px;font-size:11px;font-weight:700;color:var(--black);letter-spacing:1px;text-decoration:none;display:inline-block;}
.lang a.active, .lang button.active{background:var(--black);color:var(--yel);}
.cart-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--black);color:var(--cream);font-size:12px;font-weight:700;letter-spacing:1px;text-transform:uppercase;border:2px solid var(--black);transition:.15s;}
.cart-btn:hover{background:var(--yel);color:var(--black);transform:translate(-2px,-2px);box-shadow:4px 4px 0 var(--black);}
.cart-btn .count{background:var(--red);color:var(--cream);font-size:10px;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;}
.user-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;background:transparent;border:2px solid var(--black);color:var(--black);font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;}
.user-btn:hover{background:var(--yel);transform:translate(-2px,-2px);box-shadow:3px 3px 0 var(--black);}
.burger{display:none;background:none;border:2px solid var(--black);color:var(--black);font-size:18px;padding:6px 10px;cursor:pointer;}

section{padding:90px 0;position:relative;}

/* =========== HERO =========== */
.hero{padding:60px 0 40px;background:var(--red);color:var(--cream);position:relative;overflow:hidden;border-bottom:2px solid var(--black);}
.hero::before{content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle at 90% 20%, rgba(255,211,58,.35), transparent 30%),
    radial-gradient(circle at 5% 70%, rgba(122,22,16,.45), transparent 45%);
  pointer-events:none;}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:30px;align-items:center;position:relative;z-index:2;}
.hero-tag{display:inline-block;padding:6px 14px;background:var(--yel);color:var(--black);font-family:var(--black-display);font-size:11px;letter-spacing:2px;text-transform:uppercase;margin-bottom:24px;border:2px solid var(--black);box-shadow:4px 4px 0 var(--black);}
.hero h1{font-size:clamp(60px,11vw,180px);line-height:.85;letter-spacing:-4px;color:var(--cream);font-weight:800;text-transform:uppercase;font-family:var(--black-display);}
.hero h1 .stroke{-webkit-text-stroke:3px var(--cream);color:transparent;}
.hero h1 .yel{color:var(--yel);}
.hero h1 .blk{color:var(--black);}
.hero h1 em{font-family:var(--serif);font-style:italic;text-transform:none;font-weight:400;letter-spacing:-2px;}
.hero h1 .underline-art{display:inline-block;position:relative;}
.hero h1 .underline-art::after{content:"";position:absolute;left:0;right:0;bottom:6px;height:18px;background:var(--yel);z-index:-1;}
.hero .sub{font-size:20px;color:var(--cream);max-width:520px;margin:28px 0 32px;font-weight:500;line-height:1.45;}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap;align-items:center;}
.btn{display:inline-flex;align-items:center;gap:10px;padding:18px 30px;font-family:var(--sans);font-size:14px;letter-spacing:1px;font-weight:700;text-transform:uppercase;transition:.15s;cursor:pointer;border:2px solid var(--black);text-decoration:none;}
.btn-yellow{background:var(--yel);color:var(--black);box-shadow:6px 6px 0 var(--black);}
.btn-yellow:hover{transform:translate(-2px,-2px);box-shadow:8px 8px 0 var(--black);}
.btn-black{background:var(--black);color:var(--cream);box-shadow:6px 6px 0 var(--cream);}
.btn-black:hover{transform:translate(-2px,-2px);box-shadow:8px 8px 0 var(--cream);}
.btn-out{background:transparent;color:var(--cream);border-color:var(--cream);}
.btn-out:hover{background:var(--cream);color:var(--red);transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--black);}
.btn-red{background:var(--red);color:var(--cream);box-shadow:6px 6px 0 var(--black);}
.btn-red:hover{transform:translate(-2px,-2px);box-shadow:8px 8px 0 var(--black);}
.btn-gold{background:var(--yel);color:var(--black);box-shadow:6px 6px 0 var(--black);}
.btn-gold:hover{transform:translate(-2px,-2px);box-shadow:8px 8px 0 var(--black);}
.btn-ghost{background:transparent;color:var(--black);border:2px solid var(--black);}
.btn-ghost:hover{background:var(--yel);transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--black);}
.btn:disabled{opacity:.5;cursor:not-allowed;}

/* HERO particles */
.spice-particles{position:absolute;inset:0;pointer-events:none;z-index:1;}
.spice-particles span{position:absolute;width:6px;height:6px;background:var(--yel);border-radius:50%;animation:float-up linear infinite;opacity:0;}
.spice-particles span:nth-child(odd){background:var(--cream);width:4px;height:4px;}
.spice-particles span:nth-child(3n){background:var(--black);width:5px;height:5px;border:1px solid var(--cream);}
@keyframes float-up{
  0%{transform:translateY(20vh) scale(.5);opacity:0;}
  10%{opacity:1;}
  90%{opacity:1;}
  100%{transform:translateY(-110vh) scale(1.2);opacity:0;}
}
.hero-visual{position:relative;aspect-ratio:1/1.05;display:flex;align-items:center;justify-content:center;}
.hero-blob{position:absolute;width:100%;height:100%;background:var(--yel);border-radius:50% 50% 50% 50% / 60% 40% 60% 40%;animation:morph 10s ease-in-out infinite;border:3px solid var(--black);box-shadow:10px 10px 0 var(--black);}
@keyframes morph{
  0%,100%{border-radius:62% 38% 50% 50% / 50% 50% 50% 50%;transform:rotate(-2deg);}
  33%{border-radius:50% 50% 60% 40% / 60% 40% 60% 40%;transform:rotate(2deg) scale(1.02);}
  66%{border-radius:40% 60% 40% 60% / 45% 55% 45% 55%;transform:rotate(-1deg) scale(.98);}
}
.hero-pouch{position:absolute;width:46%;z-index:3;filter:drop-shadow(0 24px 24px rgba(0,0,0,.4));animation:bobble 4s ease-in-out infinite;}
@keyframes bobble{0%,100%{transform:translateY(0) rotate(-4deg);}50%{transform:translateY(-16px) rotate(4deg);}}
.hero-stars{position:absolute;width:100%;height:100%;pointer-events:none;}
.hero-stars .star{position:absolute;font-family:var(--black-display);font-size:32px;color:var(--black);animation:spin 12s linear infinite;}
.hero-stars .s1{top:8%;right:8%;}
.hero-stars .s2{bottom:14%;left:6%;animation-duration:8s;animation-direction:reverse;}
.hero-stars .s3{top:50%;right:-2%;animation-duration:16s;}
@keyframes spin{to{transform:rotate(360deg);}}
.hero-rating{position:absolute;bottom:-10px;right:-10px;background:var(--black);color:var(--cream);padding:10px 14px;font-family:var(--sans);font-weight:700;font-size:12px;border:2px solid var(--cream);z-index:4;}
.hero-rating strong{color:var(--yel);font-size:18px;display:block;}

.hero-bottom{background:var(--yel);border-top:2px solid var(--black);border-bottom:2px solid var(--black);overflow:hidden;padding:14px 0;}
.hero-bottom-track{display:flex;gap:50px;animation:marq 18s linear infinite;font-family:var(--black-display);font-size:48px;letter-spacing:-2px;color:var(--black);text-transform:uppercase;white-space:nowrap;}
.hero-bottom-track span{display:inline-flex;align-items:center;gap:50px;}
.hero-bottom-track svg{width:36px;height:36px;}

/* =========== VALUES =========== */
.values{background:var(--cream);border-bottom:2px solid var(--black);padding:60px 0;}
.values-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;}
.val{padding:30px 24px;border-right:2px solid var(--black);}
.val:last-child{border-right:none;}
.val-num{font-family:var(--black-display);font-size:54px;color:var(--red);line-height:1;letter-spacing:-2px;}
.val-lbl{font-size:14px;font-weight:600;margin-top:8px;color:var(--black);}

/* =========== PRODUCTS =========== */
.products{background:var(--cream);}
.sec-head{margin-bottom:60px;max-width:900px;}
.sec-head h2{font-size:clamp(48px,8vw,120px);font-weight:800;line-height:.9;letter-spacing:-3px;text-transform:uppercase;}
.sec-head h2 em{font-family:var(--serif);font-style:italic;text-transform:none;font-weight:400;letter-spacing:-1.5px;color:var(--red);}
.sec-head p{font-size:18px;margin-top:18px;color:var(--black);max-width:560px;font-weight:500;}

.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:2px solid var(--black);background:var(--cream);}
.prod-card{position:relative;background:var(--cream);border-right:2px solid var(--black);padding:32px;cursor:pointer;transition:.25s;overflow:hidden;}
.prod-card:last-child{border-right:none;}
.prod-card:nth-child(3n+1){background:var(--yel);color:var(--black);}
.prod-card:nth-child(3n+2){background:var(--cream);color:var(--black);}
.prod-card:nth-child(3n+3){background:var(--red);color:var(--cream);}
.prod-card:hover{transform:scale(1.02);z-index:2;box-shadow:0 0 0 4px var(--black);}
.prod-card .stage{aspect-ratio:4/4.2;display:flex;align-items:center;justify-content:center;position:relative;text-decoration:none;}
.prod-card .pouch-slot{width:68%;transition:transform .4s;filter:drop-shadow(0 20px 24px rgba(0,0,0,.25));}
.prod-card:hover .pouch-slot{transform:rotate(-4deg) scale(1.04);}
.prod-card .ribbon{position:absolute;top:18px;left:-30px;background:var(--black);color:var(--yel);padding:5px 36px;font-family:var(--black-display);font-size:11px;letter-spacing:2px;transform:rotate(-12deg);z-index:5;border:1px solid var(--black);}
.prod-card .body{padding-top:20px;border-top:2px solid var(--black);}
.prod-card:nth-child(3n+3) .body{border-color:var(--cream);}
.prod-card .cat{font-family:var(--black-display);font-size:11px;letter-spacing:2px;text-transform:uppercase;margin-bottom:8px;}
.prod-card h3{font-size:32px;letter-spacing:-1px;text-transform:uppercase;margin-bottom:8px;}
.prod-card h3 a{color:inherit;}
.prod-card .desc{font-size:13px;margin-bottom:18px;min-height:42px;font-weight:500;line-height:1.5;}
.prod-foot{display:flex;justify-content:space-between;align-items:center;gap:10px;}
.prod-price{font-family:var(--black-display);font-size:28px;letter-spacing:-.5px;}
.prod-add{padding:8px 14px;font-family:var(--sans);font-size:11px;letter-spacing:1.5px;font-weight:700;text-transform:uppercase;background:var(--black);color:var(--cream);border:2px solid var(--black);transition:.15s;cursor:pointer;}
.prod-card:nth-child(3n+3) .prod-add{background:var(--cream);color:var(--red);border-color:var(--cream);}
.prod-add:hover{transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--cream);}
.prod-card:nth-child(3n+2) .prod-add:hover{box-shadow:3px 3px 0 var(--red);}
.prod-add:disabled{opacity:.55;cursor:not-allowed;}

/* =========== ORIGIN MAP / GLOBE =========== */
.origin{background:var(--black);color:var(--cream);border-top:2px solid var(--black);border-bottom:2px solid var(--black);}
.origin .sec-head h2 em{color:var(--yel);}
.origin .sec-head{color:var(--cream);}
.origin .sec-head h2{color:var(--cream);}
.origin .sec-head p{color:var(--cream);opacity:.8;}
.map-wrap{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;background:var(--black-2);border:2px solid var(--cream);padding:40px;position:relative;overflow:hidden;}
.globe-wrap{
  background:
    radial-gradient(ellipse 70% 50% at 30% 30%, rgba(255,211,58,.10), transparent 60%),
    radial-gradient(ellipse 60% 50% at 80% 70%, rgba(255,61,46,.12), transparent 60%),
    var(--black-2);
}
.globe-wrap::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Ccircle cx='10' cy='30' r='1' fill='%23FFF6E8' opacity='.18'/%3E%3Ccircle cx='80' cy='20' r='.8' fill='%23FFF6E8' opacity='.25'/%3E%3Ccircle cx='150' cy='60' r='1.2' fill='%23FFD33A' opacity='.4'/%3E%3Ccircle cx='40' cy='110' r='1' fill='%23FFF6E8' opacity='.2'/%3E%3Ccircle cx='190' cy='140' r='.7' fill='%23FFF6E8' opacity='.3'/%3E%3Ccircle cx='110' cy='170' r='1' fill='%23FFD33A' opacity='.35'/%3E%3Ccircle cx='30' cy='180' r='.9' fill='%23FFF6E8' opacity='.2'/%3E%3C/svg%3E");
}
.globe-stage{aspect-ratio:1/1;position:relative;display:flex;align-items:center;justify-content:center;}
.globe-stage .ghint{position:absolute;bottom:-6px;left:50%;transform:translateX(-50%);font-family:var(--sans);font-size:11px;letter-spacing:2px;color:var(--cream);opacity:.45;text-transform:uppercase;white-space:nowrap;pointer-events:none;}
.globe-stage svg{width:100%;height:100%;display:block;overflow:visible;}
.globe-stage .globe-pin{cursor:pointer;}
.globe-stage .globe-pin > circle.gp-core{transition:r .15s ease;}
.globe-stage .globe-pin:hover > circle.gp-core{r:9;}
.map-info{position:relative;z-index:2;}
.map-info .label{font-family:var(--black-display);font-size:11px;letter-spacing:3px;color:var(--yel);text-transform:uppercase;margin-bottom:12px;}
.map-info h3{font-size:44px;text-transform:uppercase;letter-spacing:-1px;margin-bottom:6px;color:var(--cream);}
.map-info .flag{font-size:34px;vertical-align:-4px;margin-right:8px;}
.map-info .region{font-family:var(--serif);font-style:italic;font-size:22px;color:var(--yel);margin-bottom:14px;}
.map-info p{color:var(--cream);opacity:.85;font-size:14.5px;line-height:1.65;margin-bottom:16px;}
.map-info .stats{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.map-info .stat{background:rgba(255,246,232,.06);border:1px solid var(--cream);padding:12px 14px;}
.map-info .stat .k{font-family:var(--black-display);font-size:9px;letter-spacing:2px;color:var(--yel);text-transform:uppercase;}
.map-info .stat .v{font-size:15px;color:var(--cream);margin-top:4px;font-weight:600;}
.origin-tabs{display:flex;gap:8px;margin-top:26px;flex-wrap:wrap;justify-content:center;}
.origin-tab{padding:10px 18px;background:transparent;border:2px solid var(--cream);color:var(--cream);font-family:var(--sans);font-size:11px;letter-spacing:1.5px;font-weight:700;text-transform:uppercase;cursor:pointer;transition:.15s;}
.origin-tab.active, .origin-tab:hover{background:var(--yel);color:var(--black);border-color:var(--yel);}

/* =========== STORY =========== */
.story{background:var(--cream);}
.story-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center;}
.story-visual{aspect-ratio:4/4.2;background:var(--red);border:2px solid var(--black);box-shadow:14px 14px 0 var(--black);position:relative;overflow:hidden;}
.story-visual::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 30%, rgba(255,211,58,.4), transparent 60%);}
.story-quote{position:absolute;inset:auto 30px 50px 30px;color:var(--cream);font-family:var(--serif);font-style:italic;font-size:32px;line-height:1.2;font-weight:400;z-index:2;}
.story-attribution{position:absolute;left:30px;bottom:24px;font-family:var(--black-display);font-size:11px;letter-spacing:2px;color:var(--yel);text-transform:uppercase;z-index:2;}
.story-visual .big-q{position:absolute;top:24px;left:30px;font-family:var(--black-display);font-size:160px;color:var(--yel);line-height:.8;opacity:.5;}
.story-text h2{font-size:80px;letter-spacing:-2px;line-height:.95;text-transform:uppercase;margin-bottom:24px;}
.story-text h2 em{color:var(--red);font-family:var(--serif);font-style:italic;text-transform:none;letter-spacing:-1px;font-weight:400;}
.story-text > p{font-size:17px;color:var(--black);font-weight:500;line-height:1.65;margin-bottom:18px;}
.checklist{list-style:none;margin-top:28px;}
.checklist li{padding:12px 0 12px 44px;position:relative;font-size:15px;color:var(--black);font-weight:600;border-bottom:2px solid var(--black);}
.checklist li:last-child{border:none;}
.checklist li::before{content:"✓";position:absolute;left:0;top:6px;width:28px;height:28px;background:var(--red);color:var(--cream);font-weight:800;display:flex;align-items:center;justify-content:center;border:2px solid var(--black);box-shadow:3px 3px 0 var(--black);}

/* =========== VISION =========== */
.vision{background:var(--yel);border-top:2px solid var(--black);border-bottom:2px solid var(--black);color:var(--black);}
.vision .sec-head h2 em{color:var(--red);}
.vision-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:50px;}
.vstep{background:var(--cream);padding:32px;border:2px solid var(--black);box-shadow:8px 8px 0 var(--black);position:relative;transition:.2s;}
.vstep:hover{transform:translate(-3px,-3px);box-shadow:11px 11px 0 var(--black);}
.vstep .n{font-family:var(--black-display);font-size:60px;color:var(--red);line-height:1;}
.vstep h3{font-size:26px;margin:8px 0 12px;text-transform:uppercase;letter-spacing:-.5px;}
.vstep p{font-size:14.5px;color:var(--black);line-height:1.6;font-weight:500;}
.vstep .status{display:inline-block;background:var(--black);color:var(--yel);font-family:var(--sans);font-size:10px;letter-spacing:1.5px;padding:5px 10px;text-transform:uppercase;font-weight:700;margin-bottom:14px;}
.vstep.current .status{background:var(--red);color:var(--cream);}

/* =========== AI =========== */
.ai{background:var(--cream);}
.ai-wrap{background:var(--black);color:var(--cream);padding:50px;border:2px solid var(--black);box-shadow:14px 14px 0 var(--red);position:relative;overflow:hidden;}
.ai-wrap::before{content:"AI · AI · AI · AI · AI · AI · AI ·";position:absolute;top:14px;left:-20%;width:200%;font-family:var(--black-display);font-size:80px;color:rgba(255,255,255,.04);letter-spacing:-2px;text-transform:uppercase;animation:marq 30s linear infinite;pointer-events:none;}
.ai-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:48px;align-items:start;position:relative;z-index:2;}
.ai-side h2{font-size:50px;line-height:.95;text-transform:uppercase;margin-bottom:16px;letter-spacing:-1.5px;color:var(--cream);}
.ai-side h2 em{font-family:var(--serif);font-style:italic;color:var(--yel);text-transform:none;font-weight:400;letter-spacing:-1px;}
.ai-side p{color:var(--cream);opacity:.85;font-size:15.5px;line-height:1.65;font-weight:500;margin-bottom:22px;}
.ai-prompts{display:flex;flex-wrap:wrap;gap:8px;}
.ai-prompt{font-family:var(--sans);font-size:12.5px;padding:9px 16px;background:transparent;border:2px solid var(--cream);color:var(--cream);font-weight:600;cursor:pointer;transition:.15s;}
.ai-prompt:hover{background:var(--yel);color:var(--black);border-color:var(--yel);}
.ai-chat{background:var(--cream);color:var(--black);padding:24px;border:2px solid var(--cream);min-height:380px;display:flex;flex-direction:column;}
.ai-messages{flex:1;display:flex;flex-direction:column;gap:14px;overflow-y:auto;max-height:380px;}
.ai-msg{padding:14px 18px;font-size:14.5px;line-height:1.6;max-width:88%;}
.ai-msg.bot{background:var(--cream);border:2px solid var(--black);align-self:flex-start;color:var(--black);}
.ai-msg.bot h4{font-family:var(--black-display);font-size:16px;color:var(--red);text-transform:uppercase;margin-bottom:6px;letter-spacing:.5px;}
.ai-msg.user{background:var(--red);color:var(--cream);align-self:flex-end;font-weight:600;border:2px solid var(--black);}
.ai-msg.loading{display:flex;gap:6px;align-self:flex-start;background:var(--yel);border:2px solid var(--black);padding:18px;}
.ai-msg.loading span{width:10px;height:10px;background:var(--black);border-radius:50%;animation:bounce 1.4s ease-in-out infinite;}
.ai-msg.loading span:nth-child(2){animation-delay:.15s;}
.ai-msg.loading span:nth-child(3){animation-delay:.3s;}
@keyframes bounce{0%,80%,100%{transform:translateY(0);opacity:.4;}40%{transform:translateY(-8px);opacity:1;}}
.ai-input-row{display:flex;gap:10px;margin-top:16px;padding-top:16px;border-top:2px solid var(--black);}
.ai-input{flex:1;background:var(--cream);border:2px solid var(--black);padding:13px 18px;color:var(--black);font:inherit;font-size:14.5px;outline:none;font-weight:500;}
.ai-input:focus{background:var(--yel);}
.ai-send{padding:0 24px;background:var(--red);color:var(--cream);border:2px solid var(--black);font-family:var(--sans);font-size:12px;letter-spacing:1.5px;font-weight:700;text-transform:uppercase;cursor:pointer;}
.ai-send:hover{background:var(--black);}
.ai-send:disabled{opacity:.5;cursor:not-allowed;}

/* =========== RECIPES =========== */
.recipes{background:var(--cream);}
.recipe-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.recipe{background:var(--cream);border:2px solid var(--black);cursor:pointer;transition:.2s;box-shadow:8px 8px 0 var(--black);overflow:hidden;}
.recipe:hover{transform:translate(-3px,-3px);box-shadow:11px 11px 0 var(--red);}
.recipe-img{height:240px;display:flex;align-items:center;justify-content:center;position:relative;border-bottom:2px solid var(--black);}
.recipe:nth-child(3n+1) .recipe-img{background:var(--red);}
.recipe:nth-child(3n+2) .recipe-img{background:var(--yel);}
.recipe:nth-child(3n+3) .recipe-img{background:var(--black);}
.recipe-img .emoji{font-size:100px;}
.recipe:nth-child(3n+3) .recipe-img .emoji{color:var(--yel);}
.recipe-img .time{position:absolute;top:14px;right:14px;background:var(--black);color:var(--yel);padding:6px 14px;font-family:var(--sans);font-size:11px;letter-spacing:1.5px;font-weight:700;border:1.5px solid var(--cream);text-transform:uppercase;}
.recipe-body{padding:22px;}
.recipe-body .meta{font-family:var(--black-display);font-size:10.5px;letter-spacing:2.5px;color:var(--red);text-transform:uppercase;margin-bottom:8px;}
.recipe-body h3{font-size:24px;text-transform:uppercase;letter-spacing:-.5px;margin-bottom:8px;}
.recipe-body p{font-size:14px;color:var(--black);line-height:1.55;font-weight:500;}

/* =========== NEWSLETTER =========== */
.newsletter{background:var(--red);color:var(--cream);border-top:2px solid var(--black);border-bottom:2px solid var(--black);text-align:center;padding:90px 0;position:relative;overflow:hidden;}
.newsletter::before{content:"JOIN · JOIN · JOIN · JOIN ·";position:absolute;top:20px;left:-10%;width:200%;font-family:var(--black-display);font-size:100px;color:rgba(255,246,232,.07);letter-spacing:-4px;text-transform:uppercase;animation:marq 18s linear infinite;pointer-events:none;}
.nl-in{max-width:680px;margin:0 auto;position:relative;z-index:2;}
.nl-in .eyebrow{display:inline-block;padding:5px 12px;background:var(--yel);color:var(--black);font-family:var(--black-display);font-size:11px;letter-spacing:2px;margin-bottom:18px;border:2px solid var(--black);box-shadow:3px 3px 0 var(--black);}
.nl-in h2{font-size:80px;letter-spacing:-2px;line-height:.95;color:var(--cream);text-transform:uppercase;margin-bottom:14px;}
.nl-in h2 em{font-family:var(--serif);font-style:italic;color:var(--yel);text-transform:none;font-weight:400;}
.nl-in p{font-size:17px;margin-bottom:30px;font-weight:500;}
.nl-form{display:flex;gap:8px;max-width:520px;margin:0 auto;flex-wrap:wrap;justify-content:center;}
.nl-form input{flex:1;min-width:200px;background:var(--cream);border:2px solid var(--black);padding:14px 22px;color:var(--black);font:inherit;font-size:14.5px;outline:none;font-weight:500;}
.nl-form .btn{background:var(--black);color:var(--yel);}
.nl-form .btn:hover{background:var(--yel);color:var(--black);}

/* =========== CONTACT =========== */
.contact{background:var(--cream);}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.contact-card{background:var(--cream);border:2px solid var(--black);padding:32px;box-shadow:8px 8px 0 var(--black);}
.contact-card.alt{background:var(--yel);}
.contact-card h3{font-size:28px;text-transform:uppercase;letter-spacing:-.5px;margin-bottom:24px;}
.contact-row{display:flex;gap:14px;align-items:center;margin-bottom:16px;font-size:14.5px;font-weight:500;}
.contact-row svg{width:20px;height:20px;color:var(--red);}

/* =========== SHOP =========== */
.shop-hero{padding:80px 0 30px;background:var(--yel);border-bottom:2px solid var(--black);}
.shop-hero h1{font-size:clamp(60px,10vw,140px);text-transform:uppercase;letter-spacing:-3px;line-height:.9;color:var(--black);}
.shop-hero h1 em{font-family:var(--serif);font-style:italic;color:var(--red);text-transform:none;font-weight:400;letter-spacing:-1.5px;}
.shop-hero p{font-size:17px;margin-top:18px;font-weight:500;}
.shop-hero .eyebrow{display:inline-block;background:var(--black);color:var(--yel);padding:5px 12px;font-family:var(--black-display);font-size:11px;letter-spacing:2px;border:2px solid var(--black);box-shadow:3px 3px 0 var(--red);margin-bottom:18px;}
.shop-main{padding:60px 0 100px;background:var(--cream);}
.shop-grid{display:grid;grid-template-columns:240px 1fr;gap:32px;}
.shop-filter{background:var(--cream);border:2px solid var(--black);padding:22px;height:fit-content;position:sticky;top:90px;box-shadow:6px 6px 0 var(--black);}
.shop-filter h4{font-family:var(--black-display);font-size:11px;letter-spacing:2px;color:var(--red);margin-bottom:14px;text-transform:uppercase;}
.shop-filter ul{list-style:none;margin-bottom:24px;}
.shop-filter li{padding:8px 0;font-size:14px;cursor:pointer;display:flex;justify-content:space-between;font-weight:500;}
.shop-filter li a{display:flex;justify-content:space-between;width:100%;color:inherit;}
.shop-filter li.active a, .shop-filter li.active{color:var(--red);font-weight:700;}
.shop-filter li a span:last-child, .shop-filter li span:last-child{color:var(--gri);font-size:12px;}
.shop-cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:2px solid var(--black);background:var(--cream);}
.shop-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:14px;}
.shop-toolbar .count{font-family:var(--black-display);font-size:22px;text-transform:uppercase;letter-spacing:-.5px;}
.shop-toolbar select,.shop-toolbar input{background:var(--cream);border:2px solid var(--black);padding:8px 14px;font:inherit;font-size:13px;font-weight:600;}
.shop-empty{padding:80px 24px;text-align:center;border:2px dashed var(--black);background:var(--cream);}

/* =========== PRODUCT DETAIL =========== */
.prod-page{padding:60px 0 90px;background:var(--cream);}
.crumbs{font-family:var(--sans);font-size:12px;font-weight:600;color:var(--black);margin-bottom:28px;text-transform:uppercase;letter-spacing:1px;}
.crumbs a{color:var(--red);}
.crumbs span.sep{margin:0 8px;}
.prod-detail{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;}
.prod-stage{aspect-ratio:1/1.05;background:var(--yel);border:2px solid var(--black);box-shadow:14px 14px 0 var(--black);padding:24px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;}
.prod-stage::after{content:"SUPRENO · SUPRENO ·";position:absolute;top:-5px;left:-10%;width:120%;font-family:var(--black-display);font-size:36px;color:var(--black);opacity:.1;text-align:center;white-space:nowrap;}
.prod-stage .pouch-slot{width:55%;position:relative;z-index:2;}
.prod-stage .stamp{position:absolute;top:16px;right:16px;background:var(--red);color:var(--cream);padding:8px 14px;font-family:var(--black-display);font-size:12px;letter-spacing:2px;text-transform:uppercase;border:2px solid var(--black);transform:rotate(8deg);z-index:3;}
.prod-thumbs{display:flex;gap:12px;margin-top:16px;}
.prod-thumb{flex:1;aspect-ratio:1/1;background:var(--cream);border:2px solid var(--black);display:flex;align-items:center;justify-content:center;cursor:pointer;font-family:var(--black-display);font-size:11px;letter-spacing:1px;color:var(--black);text-transform:uppercase;}
.prod-thumb.active{background:var(--red);color:var(--cream);}
.prod-info .cat{display:inline-block;background:var(--black);color:var(--yel);padding:5px 12px;font-family:var(--black-display);font-size:11px;letter-spacing:2px;text-transform:uppercase;margin-bottom:18px;}
.prod-info h1{font-size:clamp(48px,7vw,90px);line-height:.9;letter-spacing:-2px;text-transform:uppercase;}
.prod-info h1 em{font-family:var(--serif);font-style:italic;color:var(--red);text-transform:none;font-weight:400;letter-spacing:-1px;}
.prod-info .lead{font-size:18px;color:var(--black);font-weight:500;line-height:1.6;margin:18px 0 28px;max-width:480px;}
.prod-price-row{display:flex;align-items:baseline;gap:14px;margin-bottom:24px;}
.prod-price-row .now{font-family:var(--black-display);font-size:60px;color:var(--red);letter-spacing:-2px;line-height:1;}
.prod-price-row .unit{font-size:13px;color:var(--gri);font-weight:600;}
.prod-meta{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:26px;}
.prod-meta div{background:var(--cream);border:2px solid var(--black);padding:13px 16px;}
.prod-meta .k{font-family:var(--black-display);font-size:9px;letter-spacing:2px;color:var(--red);text-transform:uppercase;}
.prod-meta .v{font-size:15px;color:var(--black);margin-top:4px;font-weight:700;}
.qty-row{display:flex;gap:12px;align-items:stretch;margin-bottom:18px;}
.qty{display:flex;align-items:center;border:2px solid var(--black);background:var(--cream);}
.qty button{padding:11px 16px;color:var(--black);font-weight:800;font-size:18px;cursor:pointer;background:none;}
.qty span,.qty input{padding:0 14px;font-size:15px;font-weight:700;min-width:50px;text-align:center;border:none;background:none;width:60px;}
.prod-cta{flex:1;}
.prod-features{margin-top:26px;padding-top:26px;border-top:2px solid var(--black);display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.prod-features div{display:flex;gap:10px;align-items:center;font-size:13.5px;color:var(--black);font-weight:600;}
.prod-features svg{width:18px;height:18px;color:var(--red);}
.prod-tabs{margin-top:80px;}
.tab-list{display:flex;gap:0;border:2px solid var(--black);background:var(--cream);}
.tab-btn{padding:16px 24px;font-family:var(--sans);font-size:12px;letter-spacing:2px;color:var(--black);text-transform:uppercase;font-weight:700;border-right:2px solid var(--black);transition:.2s;cursor:pointer;flex:1;}
.tab-btn:last-child{border-right:none;}
.tab-btn.active{background:var(--red);color:var(--cream);}
.tab-content{padding:28px 0;display:none;}
.tab-content.active{display:block;}
.tab-content p, .tab-content li{font-size:15.5px;color:var(--black);line-height:1.75;margin-bottom:12px;font-weight:500;}
.tab-content ul{padding-left:20px;}
.tab-content h3{font-size:24px;text-transform:uppercase;margin-bottom:10px;}

/* =========== CART =========== */
.cart-page{padding:60px 0 90px;background:var(--cream);min-height:80vh;}
.cart-page h1{font-size:clamp(60px,9vw,120px);text-transform:uppercase;letter-spacing:-2px;line-height:.9;color:var(--black);}
.cart-page h1 em{font-family:var(--serif);font-style:italic;color:var(--red);text-transform:none;font-weight:400;letter-spacing:-1px;}
.cart-page .sub{font-size:15px;font-weight:500;margin:14px 0 40px;}
.cart-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:24px;align-items:start;}
.cart-items{background:var(--cream);border:2px solid var(--black);box-shadow:8px 8px 0 var(--black);}
.cart-item{padding:20px;border-bottom:2px solid var(--black);display:grid;grid-template-columns:80px 1fr auto auto auto;gap:18px;align-items:center;}
.cart-item:last-child{border-bottom:none;}
.cart-item-thumb{width:80px;height:80px;background:var(--yel);border:2px solid var(--black);display:flex;align-items:center;justify-content:center;padding:6px;overflow:hidden;}
.cart-item-thumb .sr-pouch,.cart-item-thumb svg{max-width:60px;max-height:70px;}
.cart-item-thumb img{width:100%;height:100%;object-fit:cover;}
.cart-item h4{font-size:18px;text-transform:uppercase;letter-spacing:-.5px;margin-bottom:4px;}
.cart-item h4 a{color:inherit;}
.cart-item .meta{font-size:12px;color:var(--red);font-weight:700;letter-spacing:1px;text-transform:uppercase;}
.cart-item .price{font-family:var(--black-display);font-size:24px;color:var(--black);}
.cart-item .rm{color:var(--red);font-size:20px;font-weight:800;background:none;border:none;cursor:pointer;}
.cart-empty{text-align:center;padding:80px 24px;background:var(--cream);border:2px solid var(--black);box-shadow:8px 8px 0 var(--black);}
.cart-empty p{margin:18px 0 28px;font-weight:500;}
.cart-summary{background:var(--black);color:var(--cream);padding:32px;border:2px solid var(--black);box-shadow:8px 8px 0 var(--red);height:fit-content;position:sticky;top:90px;}
.cart-summary h3{font-size:26px;text-transform:uppercase;margin-bottom:22px;color:var(--yel);}
.cart-line{display:flex;justify-content:space-between;padding:8px 0;font-size:14.5px;}
.cart-line.total{font-family:var(--black-display);font-size:28px;color:var(--yel);padding-top:18px;border-top:2px solid var(--cream);margin-top:14px;text-transform:uppercase;}
.cart-summary .btn{width:100%;justify-content:center;margin-top:18px;background:var(--yel);color:var(--black);border-color:var(--cream);box-shadow:4px 4px 0 var(--cream);}
.cart-summary .btn:hover{background:var(--cream);transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--cream);}
.cart-summary .btn.alt{background:transparent;color:var(--cream);}
.cart-summary .btn.alt:hover{background:var(--cream);color:var(--black);}
.promo-row{display:flex;gap:6px;margin-top:14px;}
.promo-row input{flex:1;background:transparent;border:1px solid var(--cream);padding:9px 14px;color:var(--cream);font:inherit;font-size:13px;outline:none;}
.promo-row button{padding:9px 14px;background:var(--cream);color:var(--black);font-size:11px;letter-spacing:1.5px;font-weight:700;text-transform:uppercase;border:none;cursor:pointer;}

/* =========== CHECKOUT =========== */
.checkout-page{padding:60px 0 90px;background:var(--cream);}
.checkout-page h1{font-size:clamp(48px,8vw,100px);text-transform:uppercase;letter-spacing:-2px;line-height:.9;}
.checkout-page h1 em{font-family:var(--serif);font-style:italic;color:var(--red);text-transform:none;font-weight:400;letter-spacing:-1px;}
.checkout-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:30px;align-items:start;margin-top:40px;}
.co-card{background:var(--cream);border:2px solid var(--black);box-shadow:8px 8px 0 var(--black);padding:30px;margin-bottom:20px;}
.co-card h3{font-size:24px;text-transform:uppercase;letter-spacing:-.5px;margin-bottom:20px;display:flex;align-items:center;gap:14px;}
.co-card h3 .badge{display:inline-block;background:var(--red);color:var(--cream);font-family:var(--black-display);font-size:18px;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;letter-spacing:0;}
.co-pay-option{display:block;padding:16px 18px;background:var(--cream);border:2px solid var(--black);margin-bottom:10px;cursor:pointer;font-weight:500;transition:.15s;}
.co-pay-option:hover{background:var(--yel);transform:translate(-2px,-2px);box-shadow:4px 4px 0 var(--black);}
.co-pay-option strong{font-family:var(--black-display);text-transform:uppercase;letter-spacing:.5px;display:block;margin-bottom:4px;}
.co-pay-option input{margin-right:8px;}

/* =========== AUTH =========== */
.auth-page{padding:80px 0;min-height:65vh;background:var(--cream);}
.auth-card{max-width:480px;margin:0 auto;background:var(--cream);border:2px solid var(--black);padding:36px;box-shadow:10px 10px 0 var(--black);}
.auth-card h1{font-size:48px;text-transform:uppercase;letter-spacing:-1.5px;margin-bottom:8px;line-height:.95;}
.auth-card h1 em{font-family:var(--serif);font-style:italic;color:var(--red);text-transform:none;letter-spacing:-1px;font-weight:400;}
.auth-card .sub{font-size:14px;color:var(--gri);font-weight:500;margin-bottom:24px;}

/* =========== FORMS =========== */
.form-row{margin-bottom:16px;}
.form-row label{display:block;font-family:var(--black-display);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:6px;}
.form-row input,.form-row select,.form-row textarea{
  width:100%;background:var(--cream);border:2px solid var(--black);padding:13px 16px;color:var(--black);
  font:inherit;font-size:14.5px;outline:none;font-weight:500;}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{background:var(--yel);}
.form-row textarea{min-height:80px;resize:vertical;}
.form-err{background:var(--red);color:var(--cream);padding:12px 16px;border:2px solid var(--black);margin-bottom:18px;font-weight:600;font-size:13.5px;}
.form-ok{background:var(--yel);color:var(--black);padding:12px 16px;border:2px solid var(--black);margin-bottom:18px;font-weight:700;font-size:13.5px;}

/* =========== ACCOUNT / ORDER =========== */
.account-page{padding:60px 0 90px;background:var(--cream);min-height:60vh;}
.account-page h1{font-size:clamp(48px,8vw,100px);text-transform:uppercase;letter-spacing:-1.5px;line-height:.95;}
.account-page h1 em{font-family:var(--serif);font-style:italic;color:var(--red);text-transform:none;letter-spacing:-1px;font-weight:400;}
.order-table{width:100%;border-collapse:collapse;background:var(--cream);border:2px solid var(--black);box-shadow:8px 8px 0 var(--black);}
.order-table th,.order-table td{padding:14px 16px;text-align:left;border-bottom:2px solid var(--black);}
.order-table th{font-family:var(--black-display);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;background:var(--yel);}
.order-table tr:last-child td{border-bottom:none;}
.badge{display:inline-block;padding:4px 10px;background:var(--black);color:var(--yel);font-family:var(--black-display);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;}
.badge.green{background:#22c55e;color:#fff;}
.badge.red{background:var(--red);color:var(--cream);}
.badge.gray{background:var(--gri);color:var(--cream);}

/* =========== LEGAL PAGES =========== */
.legal-page{padding:60px 0 90px;background:var(--cream);}
.legal-page h1{font-size:clamp(48px,7vw,80px);text-transform:uppercase;letter-spacing:-1.5px;line-height:.95;margin-bottom:8px;}
.legal-page h1 em{font-family:var(--serif);font-style:italic;color:var(--red);text-transform:none;letter-spacing:-1px;font-weight:400;}
.legal-page h2{font-size:24px;text-transform:uppercase;margin:32px 0 12px;letter-spacing:-.5px;}
.legal-page h3{font-size:18px;text-transform:uppercase;margin:24px 0 8px;}
.legal-page p,.legal-page li{font-size:15px;color:var(--black);line-height:1.7;margin-bottom:10px;font-weight:500;}
.legal-page ul{padding-left:24px;margin-bottom:16px;}
.legal-page hr{border:none;border-top:2px solid var(--black);margin:30px 0;}
.legal-content{max-width:820px;}

/* =========== FOOTER =========== */
footer{background:var(--black);color:var(--cream);padding:0 0;border-top:2px solid var(--black);}
.foot-marquee{background:var(--red);color:var(--cream);border-bottom:2px solid var(--black);overflow:hidden;padding:18px 0;}
.foot-marquee-track{display:flex;gap:40px;animation:marq 25s linear infinite;font-family:var(--black-display);font-size:38px;letter-spacing:-1px;text-transform:uppercase;white-space:nowrap;}
.foot-marquee-track span{display:inline-flex;align-items:center;gap:40px;}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:36px;padding:50px 0 40px;}
.foot-col h4{font-family:var(--black-display);font-size:12px;letter-spacing:2px;color:var(--yel);text-transform:uppercase;margin-bottom:16px;}
.foot-col a{display:block;color:var(--cream);font-size:13.5px;margin-bottom:10px;}
.foot-col a:hover{color:var(--yel);}
.foot-col p{font-size:13.5px;color:var(--cream);opacity:.7;margin-bottom:8px;}
.foot-brand .brand-logo{height:90px;margin-bottom:18px;}
.foot-legal{border-top:1px solid rgba(255,246,232,.18);padding:18px 0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:12px;color:var(--cream);opacity:.6;}

/* =========== COOKIE / TOAST =========== */
.cookie{position:fixed;bottom:20px;left:20px;right:20px;max-width:580px;margin:0 auto;background:var(--black);color:var(--cream);padding:18px 22px;z-index:200;display:flex;gap:16px;align-items:center;border:2px solid var(--cream);box-shadow:6px 6px 0 var(--red);}
.cookie p{font-size:12.5px;}
.cookie-btns{display:flex;gap:8px;flex-shrink:0;}
.cookie button{padding:8px 14px;font-size:11px;font-weight:700;letter-spacing:1px;border:2px solid var(--cream);text-transform:uppercase;color:var(--cream);background:transparent;cursor:pointer;}
.cookie .accept{background:var(--yel);color:var(--black);border-color:var(--black);}
.cookie.hide{display:none;}
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(150%);background:var(--red);color:var(--cream);padding:14px 24px;font-family:var(--sans);font-size:13px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;z-index:300;transition:.4s cubic-bezier(.2,.7,.2,1);border:2px solid var(--black);box-shadow:4px 4px 0 var(--black);}
.toast.show{transform:translateX(-50%) translateY(0);}

.reveal{opacity:0;transform:translateY(20px);transition:.7s ease;}
.reveal.in{opacity:1;transform:none;}

/* =========== RESPONSIVE =========== */
@media(max-width:1000px){
  .hero-grid,.story-grid,.contact-grid,.ai-grid,.map-wrap,.prod-detail,.cart-grid,.shop-grid,.checkout-grid{grid-template-columns:1fr;}
  .ai-wrap{padding:28px;}
  .prod-grid,.shop-cat-grid{grid-template-columns:1fr;}
  .prod-card{border-right:none;border-bottom:2px solid var(--black);}
  .prod-card:last-child{border-bottom:none;}
  .recipe-grid,.vision-steps,.values-grid{grid-template-columns:1fr 1fr;}
  .val{border-right:none;border-bottom:2px solid var(--black);}
  .nav-links{display:none;}
  .burger{display:block;}
  .nav-links.show{display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:var(--cream);border-bottom:2px solid var(--black);padding:14px 28px;gap:8px;}
  .foot-grid{grid-template-columns:1fr 1fr;}
  .shop-filter{position:static;}
  .cart-summary{position:static;}
  .cart-item{grid-template-columns:60px 1fr;grid-gap:8px;}
  .cart-item-thumb{width:60px;height:60px;}
  .cart-item .qty,.cart-item .price,.cart-item .rm{grid-column:2;}
  .brand-logo{height:60px;}
}
@media(max-width:640px){
  .recipe-grid,.vision-steps,.values-grid{grid-template-columns:1fr;}
  .foot-grid{grid-template-columns:1fr;}
  section{padding:60px 0;}
  .auth-card{padding:24px;}
}
