:root{
  --cream:#FBF1DD;
  --cream-deep:#F4E4C3;
  --red:#E11C13;
  --red-dark:#B5140C;
  --ink:#1A130E;
  --ink-soft:#3A2E24;
  --banana:#F8C12B;
  --banana-soft:#FFD968;
  --leaf:#2F7D3A;
  --paper:#FFFAF0;
  --line:rgba(26,19,14,.14);
  --shadow:18px 18px 0 rgba(26,19,14,1);
  --r:22px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Hanken Grotesk',sans-serif;
  background:var(--cream);
  color:var(--ink);
  line-height:1.65;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
/* film grain overlay */
body::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

h1,h2,h3,.display{font-family:'Anton',sans-serif;font-weight:400;line-height:.96;letter-spacing:.5px;text-transform:uppercase}
.eyebrow{font-family:'Archivo',sans-serif;font-weight:800;text-transform:uppercase;letter-spacing:.28em;font-size:.72rem}
::selection{background:var(--red);color:#fff}

a{color:inherit;text-decoration:none}
.wrap{width:min(1180px,92vw);margin-inline:auto}
section{position:relative}

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:'Archivo',sans-serif;font-weight:800;text-transform:uppercase;letter-spacing:.06em;
  font-size:.86rem;padding:.95em 1.6em;border-radius:100px;border:2px solid var(--ink);
  background:var(--red);color:#fff;cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
  box-shadow:5px 5px 0 var(--ink);
}
.btn:hover{transform:translate(-2px,-2px);box-shadow:8px 8px 0 var(--ink)}
.btn:active{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--ink)}
.btn--ghost{background:var(--banana);color:var(--ink)}
.btn--ink{background:var(--ink);color:var(--cream)}

/* ============ NAV ============ */
header.nav{
  position:sticky;top:0;z-index:1000;background:#0E0A07;
  border-bottom:3px solid var(--red);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.55rem 0}
.brand{display:flex;align-items:center;gap:.7rem}
.brand img{height:46px;width:auto;display:block}
.brand .reg{color:#fff;font-family:'Archivo';font-weight:700;font-size:.6rem;letter-spacing:.2em;opacity:.55;align-self:flex-start;margin-top:6px}
.nav-links{display:flex;align-items:center;gap:2rem}
.nav-links a{color:#F4E4C3;font-family:'Archivo';font-weight:700;font-size:.82rem;text-transform:uppercase;letter-spacing:.08em;position:relative;padding:.3em 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--red);transition:width .25s ease}
.nav-links a:hover::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:.8rem}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.burger span{width:26px;height:3px;background:var(--cream);border-radius:2px;transition:.3s}

/* ============ HERO ============ */
.hero{padding:clamp(3rem,7vw,6rem) 0 clamp(4rem,8vw,7rem);position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(2rem,4vw,4rem);align-items:center}
.hero .tagline-chip{display:inline-flex;align-items:center;gap:.6rem;background:var(--ink);color:var(--banana);padding:.5em 1.1em;border-radius:100px;margin-bottom:1.5rem}
.hero h1{font-size:clamp(3.2rem,9vw,7rem);color:var(--ink)}
.hero h1 .red{color:var(--red);-webkit-text-stroke:2px var(--ink);paint-order:stroke fill}
.hero p.lead{font-size:clamp(1.05rem,1.6vw,1.25rem);max-width:46ch;margin:1.4rem 0 2.2rem;color:var(--ink-soft)}
.hero-actions{display:flex;flex-wrap:wrap;gap:1rem;align-items:center}
.hero-stats{display:flex;gap:2.2rem;margin-top:2.8rem;flex-wrap:wrap}
.hero-stats .s b{font-family:'Anton';font-size:2.1rem;color:var(--red);display:block;line-height:1}
.hero-stats .s span{font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;font-family:'Archivo';font-weight:700;color:var(--ink-soft)}

/* product visual */
.hero-visual{position:relative}
.product-card{
  position:relative;background:linear-gradient(160deg,#15100B,#241A11);
  border:3px solid var(--ink);border-radius:34px;padding:2.4rem 2rem 2.6rem;
  box-shadow:var(--shadow);text-align:center;overflow:hidden;
}
.product-card::before{
  content:"";position:absolute;inset:0;opacity:.5;
  background:radial-gradient(circle at 50% 0%,rgba(225,28,19,.5),transparent 60%);
}
.product-card img.hero-photo{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:22px;position:relative;z-index:2;border:2px solid rgba(255,255,255,.12);box-shadow:0 14px 30px rgba(0,0,0,.45)}
.chip-row{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap;margin-top:1.6rem;position:relative;z-index:2}
.mini{font-family:'Archivo';font-weight:800;font-size:.66rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink);background:var(--banana);padding:.45em .9em;border-radius:100px}
.price-badge{
  position:absolute;top:-22px;right:-22px;z-index:5;width:108px;height:108px;border-radius:50%;
  background:var(--red);color:#fff;display:grid;place-content:center;text-align:center;
  border:3px solid var(--ink);box-shadow:5px 5px 0 var(--ink);transform:rotate(8deg);
  animation:wobble 5s ease-in-out infinite;
}
.price-badge b{font-family:'Anton';font-size:1.05rem;line-height:1;display:block}
.price-badge span{font-family:'Archivo';font-weight:700;font-size:.55rem;letter-spacing:.12em;text-transform:uppercase}
@keyframes wobble{0%,100%{transform:rotate(8deg)}50%{transform:rotate(-4deg)}}

/* floating bananas */
.banana{position:absolute;color:var(--banana);opacity:.9;z-index:0;animation:float 7s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0) rotate(var(--rot,0deg))}50%{transform:translateY(-22px) rotate(var(--rot,0deg))}}

/* marquee */
.marquee{background:var(--red);color:#fff;border-block:3px solid var(--ink);overflow:hidden;padding:.8rem 0}
.marquee-track{display:flex;gap:2.5rem;white-space:nowrap;width:max-content;animation:scroll 26s linear infinite;font-family:'Anton';font-size:1.35rem;text-transform:uppercase;letter-spacing:1px}
.marquee-track span{display:inline-flex;align-items:center;gap:2.5rem}
.marquee .dot{color:var(--banana)}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ============ SECTION SHELL ============ */
.sec{padding:clamp(4rem,8vw,7rem) 0}
.sec-head{max-width:60ch;margin-bottom:3rem}
.sec-head .eyebrow{color:var(--red);display:flex;align-items:center;gap:.7rem}
.sec-head .eyebrow::before{content:"";width:34px;height:3px;background:var(--red)}
.sec-head h2{font-size:clamp(2.2rem,5vw,3.6rem);margin-top:1rem;color:var(--ink)}
.sec-head p{margin-top:1rem;color:var(--ink-soft);font-size:1.05rem}

/* gallery */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.gcard{position:relative;border:3px solid var(--ink);border-radius:24px;overflow:hidden;aspect-ratio:3/4;box-shadow:6px 6px 0 var(--ink);transition:transform .25s ease,box-shadow .25s ease}
.gcard:hover{transform:translateY(-6px);box-shadow:12px 12px 0 var(--ink)}
.gcard img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}
.gcard:hover img{transform:scale(1.05)}
.gcard .cap{position:absolute;left:1rem;bottom:1rem;z-index:2;background:var(--banana);color:var(--ink);font-family:'Archivo';font-weight:800;text-transform:uppercase;letter-spacing:.08em;font-size:.72rem;padding:.5em 1em;border-radius:100px;border:2px solid var(--ink)}

/* features grid */
.features{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.feat{background:var(--paper);border:2px solid var(--ink);border-radius:var(--r);padding:1.8rem 1.5rem;transition:transform .25s ease,box-shadow .25s ease}
.feat:hover{transform:translateY(-6px);box-shadow:8px 8px 0 var(--ink)}
.feat .ic{width:56px;height:56px;border-radius:14px;background:var(--banana);display:grid;place-content:center;margin-bottom:1.1rem;border:2px solid var(--ink)}
.feat h3{font-size:1.15rem;letter-spacing:.5px;margin-bottom:.5rem}
.feat p{font-size:.92rem;color:var(--ink-soft)}

/* ============ MISSION (dark) ============ */
.mission{background:#100B07;color:var(--cream);border-block:3px solid var(--ink)}
.mission .sec-head h2{color:var(--cream)}
.mission .sec-head p{color:#C9B79A}
.mission .sec-head .eyebrow{color:var(--banana)}
.mission .sec-head .eyebrow::before{background:var(--banana)}
.mlist{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem}
.mitem{display:flex;gap:1.3rem;padding:1.6rem;border:1px solid rgba(255,255,255,.12);border-radius:var(--r);background:rgba(255,255,255,.03);transition:border-color .25s,background .25s}
.mitem:hover{border-color:var(--banana);background:rgba(248,193,43,.06)}
.mitem .num{font-family:'Anton';font-size:2.4rem;color:var(--red);line-height:.8;-webkit-text-stroke:1px var(--banana)}
.mitem h3{font-size:1.2rem;color:var(--cream);margin-bottom:.4rem}
.mitem p{font-size:.92rem;color:#C9B79A}

/* ============ STORY ============ */
.story-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.story-art{position:relative;aspect-ratio:4/5;border-radius:30px;border:3px solid var(--ink);box-shadow:var(--shadow);overflow:hidden;background:linear-gradient(160deg,var(--banana),var(--banana-soft))}
.story-art img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.story-art .tag{position:absolute;left:1.4rem;bottom:1.4rem;z-index:2;background:var(--ink);color:var(--cream);padding:.7em 1.2em;border-radius:14px;font-family:'Archivo';font-weight:800;font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;box-shadow:4px 4px 0 rgba(0,0,0,.25)}
.story-body h2{font-size:clamp(2rem,4.5vw,3.2rem)}
.story-body p{margin-top:1.2rem;color:var(--ink-soft);font-size:1.05rem}
.story-body .quote{margin-top:1.8rem;border-left:4px solid var(--red);padding-left:1.2rem;font-family:'Archivo';font-weight:700;font-size:1.15rem;font-style:italic;color:var(--ink)}

/* ============ STEPS ============ */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;counter-reset:step}
.step{position:relative;background:var(--paper);border:2px solid var(--ink);border-radius:var(--r);padding:2.4rem 1.7rem 1.8rem;overflow:hidden}
.step::before{counter-increment:step;content:"0" counter(step);position:absolute;top:-.4rem;right:.6rem;font-family:'Anton';font-size:5.5rem;color:var(--cream-deep);z-index:0}
.step h3{position:relative;z-index:1;font-size:1.25rem;margin-bottom:.5rem}
.step p{position:relative;z-index:1;color:var(--ink-soft);font-size:.95rem}

/* ============ CTA ============ */
.cta{background:var(--red);color:#fff;border-block:3px solid var(--ink);text-align:center;overflow:hidden}
.cta h2{font-size:clamp(2.6rem,7vw,5.5rem);color:#fff;-webkit-text-stroke:2px var(--ink);paint-order:stroke fill}
.cta p{max-width:48ch;margin:1.2rem auto 2.2rem;font-size:1.1rem;color:#FFE9CF}
.cta .hero-actions{justify-content:center}
.cta .btn{box-shadow:5px 5px 0 #fff;border-color:#fff}
.cta .btn:hover{box-shadow:8px 8px 0 #fff}

/* ============ CONTACT ============ */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
.ccard{background:var(--paper);border:2px solid var(--ink);border-radius:var(--r);padding:1.8rem;display:flex;gap:1.2rem;align-items:flex-start;transition:transform .2s,box-shadow .2s}
.ccard:hover{transform:translateY(-5px);box-shadow:8px 8px 0 var(--ink)}
.ccard .ic{flex:none;width:54px;height:54px;border-radius:14px;background:var(--ink);color:var(--banana);display:grid;place-content:center}
.ccard .lab{font-family:'Archivo';font-weight:800;text-transform:uppercase;letter-spacing:.12em;font-size:.7rem;color:var(--red)}
.ccard .val{font-size:1.15rem;font-weight:700;color:var(--ink);word-break:break-word}
.ccard .sub{font-size:.85rem;color:var(--ink-soft)}

/* ============ FAQ ============ */
.faq{display:grid;gap:.9rem;max-width:820px;margin-inline:auto}
details.q{background:var(--paper);border:2px solid var(--ink);border-radius:16px;overflow:hidden}
details.q summary{list-style:none;cursor:pointer;padding:1.2rem 1.5rem;font-family:'Archivo';font-weight:800;font-size:1.02rem;display:flex;justify-content:space-between;align-items:center;gap:1rem}
details.q summary::-webkit-details-marker{display:none}
details.q summary .pm{flex:none;width:30px;height:30px;border-radius:50%;background:var(--banana);border:2px solid var(--ink);display:grid;place-content:center;font-family:'Anton';transition:transform .25s}
details.q[open] summary .pm{transform:rotate(45deg);background:var(--red);color:#fff}
details.q .a{padding:0 1.5rem 1.3rem;color:var(--ink-soft)}

/* ============ FOOTER ============ */
footer{background:#0C0805;color:#C9B79A;padding:3.5rem 0 2rem;border-top:3px solid var(--red)}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.5rem;padding-bottom:2.5rem;border-bottom:1px solid rgba(255,255,255,.1)}
footer img.flogo{height:54px;margin-bottom:1.1rem}
footer p.tag{max-width:34ch;font-size:.92rem}
footer h4{font-family:'Archivo';font-weight:800;text-transform:uppercase;letter-spacing:.14em;font-size:.78rem;color:var(--banana);margin-bottom:1.1rem}
footer ul{list-style:none;display:grid;gap:.6rem}
footer ul a{font-size:.95rem;transition:color .2s}
footer ul a:hover{color:var(--cream)}
.socials{display:flex;gap:.7rem;margin-top:1.2rem}
.socials a{width:42px;height:42px;border-radius:12px;border:1px solid rgba(255,255,255,.18);display:grid;place-content:center;color:#C9B79A;transition:.2s}
.socials a:hover{background:var(--red);color:#fff;border-color:var(--red);transform:translateY(-3px)}
.copy{padding-top:1.6rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:.6rem;font-size:.8rem;color:#7d6e5b}

/* ============ CUSTOM PAGES ============ */
.page-hero{background:#100B07;color:var(--cream);border-bottom:3px solid var(--red);padding:clamp(2.5rem,6vw,4.5rem) 0}
.page-hero h1{font-size:clamp(2.4rem,6vw,4.5rem);color:var(--cream)}
.page-hero .page-sub{margin-top:1rem;color:#C9B79A;font-size:1.1rem;max-width:60ch}
.page-back{display:inline-block;margin-bottom:1.2rem;color:var(--banana);font-family:'Archivo';font-weight:700;font-size:.82rem;text-transform:uppercase;letter-spacing:.1em}
.page-hero-img{width:100%;max-height:460px;object-fit:cover;border:3px solid var(--ink);border-radius:24px;box-shadow:var(--shadow);margin-top:2.5rem}
.page-body{padding:clamp(2.5rem,6vw,4.5rem) 0;display:grid;gap:2rem}
.prose{max-width:74ch;font-size:1.08rem;color:var(--ink-soft)}
.prose h2{font-size:clamp(1.8rem,4vw,2.6rem);color:var(--ink);margin:1.5rem 0 .5rem}
.prose h3{font-size:1.3rem;color:var(--ink);margin:1.2rem 0 .4rem}
.prose p{margin:.9rem 0}
.prose ul,.prose ol{margin:.9rem 0 .9rem 1.4rem}
.prose li{margin:.35rem 0}
.prose a{color:var(--red);text-decoration:underline;font-weight:600}
.prose img{max-width:100%;border-radius:16px;border:2px solid var(--ink)}
.pg-img{margin:0}
.pg-img img{width:100%;border:3px solid var(--ink);border-radius:20px;box-shadow:8px 8px 0 var(--ink)}
.pg-img figcaption{margin-top:.7rem;font-family:'Archivo';font-weight:700;font-size:.85rem;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.08em}

/* ============ REVEAL ============ */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.stagger>*{opacity:0;transform:translateY(26px);transition:opacity .6s ease,transform .6s ease}
.stagger.in>*{opacity:1;transform:none}
.stagger.in>*:nth-child(1){transition-delay:.05s}
.stagger.in>*:nth-child(2){transition-delay:.13s}
.stagger.in>*:nth-child(3){transition-delay:.21s}
.stagger.in>*:nth-child(4){transition-delay:.29s}
@media (prefers-reduced-motion:reduce){.reveal,.stagger>*{transition:none;opacity:1;transform:none}}

/* ============ RESPONSIVE ============ */
@media (max-width:980px){
  .hero-grid,.story-grid{grid-template-columns:1fr}
  .hero-visual{order:-1;max-width:420px;margin-inline:auto}
  .gallery{grid-template-columns:repeat(3,1fr)}
  .features{grid-template-columns:repeat(2,1fr)}
  .mlist,.contact-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr;gap:2rem}
}
@media (max-width:680px){
  .nav-links,.nav-cta .btn{display:none}
  .burger{display:flex}
  .nav-links.open{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;background:#0E0A07;padding:1.4rem 6vw;gap:1.3rem;border-bottom:3px solid var(--red)}
  .features{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr;gap:1rem}
  .hero-stats{gap:1.6rem}
}
