/* Ensure hamburger hidden on desktop and nav visible */
@media (min-width: 961px){
  .nav-toggle{display:none !important}
  .site-nav{
    display:flex !important;
    position:static !important;
    background:transparent !important;
    height:auto !important;
    min-height:auto !important;
    opacity:1 !important;
    visibility:visible !important;
    pointer-events:auto !important;
    transform:none !important;
    align-items:center;
    justify-content:flex-end;
    gap:26px;
    padding:0;
    z-index:1001 !important;
    bottom:auto !important;
    top:auto !important;
    left:auto !important;
    right:auto !important;
  }
}
/* Theme tokens */
:root{
  --color-primary:#724b3a;
  --on-primary:#ffffff;
  --bg:#f7f3ef;
  --surface:#ffffff;
  --text:#2b1e18;
  --muted:#6b5246;
  --accent:#c9a27a;
  --accent-alt:#9e7b63;
  --success:#4f8a3f;
  --warning:#d98e3e;
  --radius:16px;
  --shadow:0 10px 30px rgba(114,75,58,0.12);
  --container:1180px;
  --heading:'Poppins', system-ui, -apple-system, 'Segoe UI', Roboto, Arial, sans-serif;
  --body:'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, Arial, sans-serif;
  --display-weight:700;
  --body-weight:400;
  --ls:0.2px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; background:var(--bg); color:var(--text);
  font-family:var(--body); letter-spacing:var(--ls); font-weight:var(--body-weight);
}
/* Prevent background scroll when mobile menu is open */
body.no-scroll{overflow:hidden; position:fixed; width:100%; left:0; right:0; overscroll-behavior:none}
img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}

.container{width:100%; max-width:var(--container); margin-inline:auto; padding:0 20px}
.section{padding:72px 0}
.section h2{opacity:0; transform:translateY(30px); transition:all 0.6s ease}
.section h2.animate{opacity:1; transform:translateY(0)}
.section.alt{background:var(--surface)}
.section-subtitle{color:var(--muted); margin-top:-8px}
.note{color:var(--muted); font-size:0.95rem}
.disclaimer{color:var(--muted); font-size:0.9rem}

/* Header */
.site-header{position:sticky; top:0; z-index:50; background:rgba(255,255,255,0.7); backdrop-filter:saturate(180%) blur(14px); border-bottom:1px solid rgba(201,162,122,0.25); transform:translateY(-100%); animation:slideDown 0.8s ease 0.2s forwards}
@keyframes slideDown{from{transform:translateY(-100%)} to{transform:translateY(0)}}
.nav-wrap{display:flex; align-items:center; justify-content:space-between; padding:14px 0}
.brand{display:flex; align-items:center; gap:10px; font-weight:700; transition:all 0.3s ease}
.brand:hover{transform:scale(1.05)}
.logo-image{width:32px; height:32px; object-fit:contain; transition:all 0.3s ease}
.brand:hover .logo-image{animation:bounce 0.6s ease}
.logo-emoji{font-size:22px}
.logo-text{font-family:var(--heading); font-weight:700}

.site-nav ul{display:flex; gap:18px; align-items:center; list-style:none; margin:0; padding:0}
.site-nav a{padding:10px 12px; border-radius:999px; transition:all 0.3s ease; position:relative; overflow:hidden}
.site-nav a::before{content:''; position:absolute; top:0; left:-100%; width:100%; height:100%; background:linear-gradient(90deg, transparent, rgba(114,75,58,0.1), transparent); transition:left 0.5s ease}
.site-nav a:hover::before{left:100%}
.site-nav a:hover{background:rgba(114,75,58,0.08); transform:translateY(-2px)}

/* Show navigation on desktop by default - FORCE VISIBLE */
/* (Removed global force-visible for .site-nav to avoid showing duplicated menu on mobile) */

.nav-toggle{display:none; border:0; background:transparent; font-size:22px}
/* Enhanced mobile nav toggle with animations */
.nav-toggle{cursor:pointer; color:#3a2a23; width:40px; height:40px; border-radius:10px; transition:all 0.3s ease; position:relative; overflow:hidden}
.nav-toggle:hover{background:rgba(114,75,58,0.08); transform:scale(1.1)}
.nav-toggle:focus-visible{outline:2px solid rgba(114,75,58,0.45); outline-offset:2px}
.nav-toggle:active{transform:scale(0.95)}
.nav-toggle .icon-close{display:none; opacity:0; transform:rotate(-90deg) scale(0.8); transition:all 0.3s ease}
.nav-toggle .icon-menu{display:inline; opacity:1; transform:rotate(0deg) scale(1); transition:all 0.3s ease}
.nav-toggle[aria-expanded="true"] .icon-menu{display:none; opacity:0; transform:rotate(90deg) scale(0.8)}
.nav-toggle[aria-expanded="true"] .icon-close{display:inline; opacity:1; transform:rotate(0deg) scale(1)}
.nav-toggle[aria-expanded="false"] .icon-close{display:none; opacity:0; transform:rotate(-90deg) scale(0.8)}
.nav-toggle[aria-expanded="false"] .icon-menu{display:inline; opacity:1; transform:rotate(0deg) scale(1)}
.nav-toggle{z-index:4000 !important}


/* Hero */
.hero{position:relative; padding:64px 0; background:linear-gradient(0deg, rgba(114,75,58,0.06), rgba(114,75,58,0.06)), var(--bg)}
.hero-copy{opacity:0; transform:translateY(50px); animation:fadeInUp 1s ease 0.3s forwards}
.hero-media{opacity:0; transform:translateX(50px); animation:slideInRight 1s ease 0.6s forwards}
.hero-grid{display:grid; grid-template-columns:1.1fr 0.9fr; gap:36px; align-items:center}
.eyebrow{color:var(--accent-alt); font-weight:600; letter-spacing:0.4px}
.hero h1{font-family:var(--heading); font-weight:var(--display-weight); margin:8px 0 12px; line-height:1.15}
.subtitle{color:var(--muted); font-size:1.05rem}
.hero-ctas{display:flex; gap:12px; flex-wrap:wrap; margin:22px 0 16px}
.trust-badges, .quick-points{display:flex; gap:10px; flex-wrap:wrap; padding:0; list-style:none; color:var(--muted)}
.hero-media{position:relative}
.grain-overlay{position:absolute; inset:0; pointer-events:none; mix-blend-mode:multiply; background:
  radial-gradient( circle at 10% 10%, rgba(0,0,0,0.03), transparent 40%),
  radial-gradient( circle at 90% 20%, rgba(0,0,0,0.02), transparent 45%),
  radial-gradient( circle at 20% 80%, rgba(0,0,0,0.02), transparent 40%);
  border-radius:var(--radius);
}

/* Hero gallery (images under heading) */
.hero-gallery{display:flex; gap:10px; margin:10px 0 8px; flex-wrap:nowrap}
.hero-gallery img{width:32%; aspect-ratio:4/3; object-fit:cover; border-radius:12px; box-shadow:var(--shadow); border:1px solid rgba(201,162,122,0.35); background:#fff; transition:all 0.4s ease; opacity:0; transform:scale(0.8)}
.hero-gallery img.animate{opacity:1; transform:scale(1); animation:scaleIn 0.8s ease forwards}
.hero-gallery img:hover{transform:scale(1.05); box-shadow:0 15px 35px rgba(114,75,58,0.25)}

/* Cards & grids */
.features-grid{display:grid; grid-template-columns:repeat(5,1fr); gap:16px; max-width:980px; margin:0 auto; justify-content:center}
.feature-card{background:var(--surface); border:1px solid rgba(201,162,122,0.35); border-radius:var(--radius); padding:18px; box-shadow:var(--shadow); transition:all 0.4s ease; opacity:0; transform:translateY(30px)}
.feature-card.animate{opacity:1; transform:translateY(0); animation:fadeInUp 0.6s ease forwards}
.feature-card:hover{transform:translateY(-8px); box-shadow:0 15px 40px rgba(114,75,58,0.2); border-color:var(--accent)}
.feature-card .icon{font-size:22px; width:40px; height:40px; display:grid; place-items:center; background:#f2e7de; border-radius:10px; color:var(--primary); transition:all 0.3s ease}
.feature-card:hover .icon{animation:bounce 0.6s ease; background:var(--accent)}
/* Ensure inline SVG inside feature icon scales well */
.feature-card .icon svg{width:22px; height:22px; display:block}
/* Ensure img (Halal Indonesia logo) scales well */
.feature-card .icon img{width:22px; height:22px; object-fit:contain; display:block}

.products-grid{display:grid; grid-template-columns:repeat(2,1fr); gap:18px}
.product-card{background:var(--surface); border:1px solid rgba(201,162,122,0.35); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); transition:all 0.4s ease; opacity:0; transform:scale(0.9)}
.product-card.animate{opacity:1; transform:scale(1); animation:scaleIn 0.6s ease forwards}
.product-card:hover{transform:translateY(-10px) scale(1.02); box-shadow:0 20px 50px rgba(114,75,58,0.25); border-color:var(--accent)}
.product-image{aspect-ratio:4/3; overflow:hidden}
.product-image img{width:100%; height:100%; object-fit:cover; display:block; transition:all 0.4s ease}
.product-card:hover .product-image img{transform:scale(1.1)}
.product-body{padding:18px}
.price{color:var(--primary); font-weight:700}
.ingredients{display:flex; gap:8px; flex-wrap:wrap; padding:0; list-style:none; color:var(--muted); font-size:0.95rem}
.card-ctas{display:flex; gap:10px; flex-wrap:wrap; margin-top:10px}

.benefits-grid{display:grid; grid-template-columns:repeat(4, minmax(220px, 1fr)); gap:20px; justify-content:center; max-width:1200px; margin:0 auto;}
.benefits-grid article{background:var(--surface); border:1px solid rgba(201,162,122,0.28); border-radius:var(--radius); padding:18px; transition:all 0.4s ease; opacity:0; transform:translateY(30px)}
.benefits-grid article.animate{opacity:1; transform:translateY(0); animation:fadeInUp 0.6s ease forwards}
.benefits-grid article:hover{transform:translateY(-8px); box-shadow:0 15px 35px rgba(114,75,58,0.15); border-color:var(--accent)}

/* Center title and disclaimer for benefits section */
#manfaat h2{text-align:center}
#manfaat .disclaimer{text-align:center}
/* Center title for features section */
#unggulan h2{text-align:center}

/* Center for products and steps */
#produk h2,
#cara-seduh h2,
#cara-seduh .section-subtitle {
  text-align: center;
}

.steps{list-style:none; padding:0; margin:22px 0; display:grid; gap:12px}
.steps li{display:grid; grid-template-columns:auto 1fr; gap:12px; align-items:flex-start; background:var(--surface); border:1px solid rgba(201,162,122,0.28); border-radius:var(--radius); padding:14px; transition:all 0.4s ease; opacity:0; transform:translateX(-30px)}
.steps li.animate{opacity:1; transform:translateX(0); animation:slideInLeft 0.6s ease forwards}
.steps li:hover{transform:translateX(5px); box-shadow:0 8px 25px rgba(114,75,58,0.15); border-color:var(--accent)}
.step-num{width:36px; height:36px; border-radius:999px; background:#f2e7de; color:var(--primary); display:grid; place-items:center; font-weight:700; transition:all 0.3s ease}
.steps li:hover .step-num{animation:pulse 1s ease; background:var(--accent); color:#fff}

.testimonials{display:grid; grid-template-columns:repeat(3, minmax(240px, 1fr)); gap:20px; justify-content:center; max-width:1100px; margin:0 auto}
.testimonial{background:var(--surface); border:1px solid rgba(201,162,122,0.2); border-radius:16px; padding:24px; font-style:normal; box-shadow:0 4px 20px rgba(114,75,58,0.08); transition:all 0.4s ease; position:relative; overflow:hidden; opacity:0; transform:translateY(30px)}
.testimonial.animate{opacity:1; transform:translateY(0); animation:fadeInUp 0.6s ease forwards}
.testimonial:hover{transform:translateY(-4px); box-shadow:0 8px 30px rgba(114,75,58,0.15); border-color:rgba(201,162,122,0.4)}
.testimonial::before{content:''; position:absolute; top:0; left:0; right:0; height:3px; background:linear-gradient(90deg, var(--primary), var(--accent)); opacity:0; transition:opacity 0.3s ease}
.testimonial:hover::before{opacity:1}
.testimonial blockquote{margin:0 0 16px; font-size:1.05rem; line-height:1.6; color:var(--text); position:relative}
.instagram-link{display:inline-block; margin:12px 0 8px 0; padding:10px 18px; background:#6c4737; color:white; text-decoration:none; border-radius:10px; font-size:0.9rem; font-weight:600; transition:all 0.3s ease; box-shadow:0 3px 12px rgba(24,119,242,0.25); letter-spacing:0.3px}
.instagram-link:hover{background:#d6b798; transform:translateY(-2px); box-shadow:0 6px 20px rgba(214,183,152,1); text-decoration:none}
.testimonial figcaption{margin-top:8px; font-weight:600; color:var(--primary); font-size:0.95rem}

/* Center testimonials title */
#ulasan h2{text-align:center}
#faq h2{text-align:center;}

/* Testimonial with image styling */
.testimonial-with-image{
  display:flex;
  flex-direction:column;
  gap:16px;
}
.testimonial-image{
  width:100%;
  border-radius:12px;
  overflow:hidden;
  box-shadow:0 4px 16px rgba(114,75,58,0.15);
}
.testimonial-image img{
  width:100%;
  height:200px;
  object-fit:cover;
  display:block;
}

.faq details{background:var(--surface); border:1px solid rgba(201,162,122,0.28); border-radius:var(--radius); padding:14px 16px; margin-bottom:10px; overflow:hidden; transition:all .4s ease; opacity:0; transform:translateY(20px)}
.faq details.animate{opacity:1; transform:translateY(0); animation:fadeInUp 0.5s ease forwards}
.faq details:hover{transform:translateY(-2px); box-shadow:0 8px 25px rgba(114,75,58,0.15)}
.faq summary{cursor:pointer; font-weight:600}

.faq details[open] { 
  box-shadow:0 8px 25px rgba(114,75,58,0.15); 
  border-color:var(--accent);
  transform:translateY(-1px);
}
.faq details > *:not(summary) {
  opacity: 0;
  max-height: 0;
  padding-top: 0;
  margin-top: 0;
  transform: translateY(-10px);
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  will-change:opacity,max-height,padding-top,margin-top,transform;
}
.faq details[open] > *:not(summary) {
  opacity: 1;
  max-height: 400px;
  padding-top: 16px;
  margin-top: 8px;
  transform: translateY(0);
  transition: all 0.5s cubic-bezier(0.4, 0, 0.2, 1) 0.1s;
}

/* Buttons with enhanced animations */
.btn{display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:12px 18px; border-radius:999px; border:1.5px solid transparent; transition:all .3s ease; font-weight:600; position:relative; overflow:hidden}
.btn::before{content:''; position:absolute; top:0; left:-100%; width:100%; height:100%; background:linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent); transition:left 0.6s ease}
.btn:hover::before{left:100%}
.btn:hover{transform:translateY(-3px); box-shadow:0 8px 25px rgba(114,75,58,0.25)}
.btn:active{transform:translateY(-1px)}
.btn-lg{padding:14px 22px}
.btn-primary{background:var(--color-primary); color:var(--on-primary)}
.btn-primary:hover{filter:brightness(1.05); animation:pulse 2s infinite}
.btn-secondary{background:#fff; color:var(--color-primary); border-color:var(--accent)}
.btn-secondary:hover{background:#fffaf5; border-color:var(--color-primary)}

/* CTA banner */
.section.cta{background:linear-gradient(180deg, rgba(201,162,122,0.15), rgba(201,162,122,0.08))}
/* Center CTA content and buttons */
.section.cta .container{ text-align:center; }
.section.cta .hero-ctas{ justify-content:center; }

/* Footer */
.site-footer{background:#efe6dd; padding:28px 0 16px; color:#3a2a23}
.footer-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
.footer-grid h4{margin:0 0 8px}
.footer-grid ul{margin:0; padding:0; list-style:none}
.footer-grid a{color:#3a2a23}
.legal{margin-top:16px; padding-top:8px; border-top:1px solid rgba(114,75,58,0.25); color:#594236}

/* Skip link */
.skip-link{position:absolute; left:-999px; top:auto; width:1px; height:1px; overflow:hidden}
.skip-link:focus{left:10px; top:10px; width:auto; height:auto; background:#000; color:#fff; padding:8px; border-radius:6px; z-index:100}

/* Desktop first - ensure nav is always visible on desktop */
@media (min-width: 961px){
  .site-nav{
    display:flex !important;
    position:static !important;
    opacity:1 !important;
    visibility:visible !important;
    pointer-events:auto !important;
    transform:none !important;
    background:transparent !important;
    height:auto !important;
    width:auto !important;
    padding:0 !important;
    margin:0 !important;
    top:auto !important;
    left:auto !important;
    right:auto !important;
    bottom:auto !important;
    z-index:auto !important;
  }
  .nav-toggle{display:none !important;}
}

/* Responsive */
@media (max-width: 960px){
  .hero-grid{grid-template-columns:1fr; padding-top:8px}
  .hero-gallery{flex-wrap:wrap}
  .hero-gallery img{width:48%}
  .features-grid{grid-template-columns:repeat(2,1fr)}
  .benefits-grid{grid-template-columns:repeat(2, minmax(240px, 1fr)); max-width:660px; gap:14px;}
  .products-grid{grid-template-columns:1fr}
  .testimonials{grid-template-columns:1fr}
  .site-header{position:sticky; top:0; z-index:50;}
  /* Keep toggle inside header when menu closed; fixed only when open */
}

@media (max-width: 600px){
  .hero-gallery{flex-direction:column; gap:14px; align-items:center;}
  .hero-gallery img{width:100%;}
  .benefits-grid{grid-template-columns:1fr; max-width:98vw; gap:12px;}
  .benefits-grid article{padding:14px;}
  /* Give more side padding on small screens and account for safe areas */
  .container{padding-left:calc(24px + env(safe-area-inset-left)); padding-right:calc(24px + env(safe-area-inset-right))}
  .nav-toggle{
    display:grid; place-items:center; position:absolute; width:44px; height:44px; border-radius:999px; top:6px; right:16px; bottom:auto; z-index:4000 !important; background:transparent; box-shadow:none; border:none; pointer-events:auto; margin-top:0;
  }
  .nav-toggle[aria-expanded="true"]{
    position:fixed;
    top:calc(6px + env(safe-area-inset-top));
    right:calc(16px + env(safe-area-inset-right));
    left:auto;
    margin-top:0;
  }
  /* Hide navigation on mobile - only show when hamburger is clicked */
  .site-nav{position:fixed; top:0; left:0; width:100vw; height:100vh; background:#fff; display:none; align-items:center; justify-content:center; z-index:1500; padding:calc(80px + env(safe-area-inset-top)) 24px calc(24px + env(safe-area-inset-bottom)); opacity:0; visibility:hidden; pointer-events:none; transform:translateY(-8px); transition:opacity .25s ease, transform .25s ease, visibility 0s linear .25s; min-height:100vh; overflow:auto; backface-visibility:hidden; -webkit-font-smoothing:antialiased}
  .site-nav.open{display:flex; opacity:1; visibility:visible; pointer-events:auto; transform:none; transition:opacity .25s ease, transform .25s ease; min-height:100vh}
  .site-nav ul{flex-direction:column; align-items:center; gap:28px}
  .site-nav a{padding:10px 14px; font-size:20px; font-weight:600; color:#3a2a23}
  /* Stagger items */
  .site-nav.open li{animation:fadeUp .24s ease both}
  .site-nav.open li:nth-child(1){animation-delay:.02s}
  .site-nav.open li:nth-child(2){animation-delay:.06s}
  .site-nav.open li:nth-child(3){animation-delay:.10s}
  .site-nav.open li:nth-child(4){animation-delay:.14s}
  .site-nav.open li:nth-child(5){animation-delay:.18s}
  .site-nav.open li:nth-child(6){animation-delay:.22s}
  /* Keep toggle fixed and visible on mobile: top-right (avoid Safari bottom toolbar) */
  .nav-toggle{
    place-items:center; position:fixed; 
    width:44px; height:44px; border-radius:999px; 
    top:calc(6px + env(safe-area-inset-top));
    right:calc(16px + env(safe-area-inset-right));
    bottom:auto;
    z-index:3000; background:transparent; 
    box-shadow:none;
    border:none;
    pointer-events:auto;
  }
}

@media (max-width: 600px){
  .hero-gallery img{width:100%}
  /* Give more side padding on small screens and account for safe areas */
  .container{padding-left:calc(24px + env(safe-area-inset-left)); padding-right:calc(24px + env(safe-area-inset-right))}
}

/* Fallbacks and failsafes */
/* Ensure overlay is truly fullscreen even if media queries misbehave */
.site-nav.open{
  position:fixed !important; inset:0 !important; background:#ffffff !important; z-index:1500 !important;
}
@supports not (height: 100dvh){
  .site-nav{height:100vh}
  .site-nav.open{height:100vh}
}

/* Enhanced Animations */
@keyframes fadeUp{
  from{opacity:0; transform:translateY(6px)}
  to{opacity:1; transform:none}
}

@keyframes fadeInUp{
  from{opacity:0; transform:translateY(30px)}
  to{opacity:1; transform:translateY(0)}
}

@keyframes slideInLeft{
  from{opacity:0; transform:translateX(-30px)}
  to{opacity:1; transform:translateX(0)}
}

@keyframes slideInRight{
  from{opacity:0; transform:translateX(30px)}
  to{opacity:1; transform:translateX(0)}
}

@keyframes scaleIn{
  from{opacity:0; transform:scale(0.9)}
  to{opacity:1; transform:scale(1)}
}

@keyframes bounce{
  0%, 20%, 50%, 80%, 100%{transform:translateY(0)}
  40%{transform:translateY(-10px)}
  60%{transform:translateY(-5px)}
}

@keyframes pulse{
  0%{transform:scale(1)}
  50%{transform:scale(1.05)}
  100%{transform:scale(1)}
}

@keyframes rotate{
  from{transform:rotate(0deg)}
  to{transform:rotate(360deg)}
}

@keyframes hamburgerTop{
  0%{transform:translateY(0) rotate(0)}
  50%{transform:translateY(6px) rotate(0)}
  100%{transform:translateY(6px) rotate(45deg)}
}

@keyframes hamburgerMiddle{
  0%{opacity:1}
  50%{opacity:0}
  100%{opacity:0}
}

@keyframes hamburgerBottom{
  0%{transform:translateY(0) rotate(0)}
  50%{transform:translateY(-6px) rotate(0)}
  100%{transform:translateY(-6px) rotate(-45deg)}
}
