/* ── RESET & BASE ─────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;overflow-x:clip}
body{font-family:'Inter',sans-serif;background:#FDF6EC;color:#2C1A0E;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:clip}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}

/* ── TOKENS ───────────────────────────────────── */
:root{
  --brown-900:#1A0D05;
  --brown-800:#2C1A0E;
  --brown-700:#3B1F0E;
  --brown-600:#5C2E12;
  --brown-500:#7B3F1E;
  --brown-400:#A0522D;
  --brown-300:#C4845A;
  --cream-100:#FDF6EC;
  --cream-200:#F5E9D6;
  --cream-300:#EDD5B3;
  --border:#E5D5C0;
  --white:#FFFFFF;
  --green:#2D6A4F;
  --sp-xs:4px;--sp-sm:8px;--sp-md:16px;--sp-lg:24px;
  --sp-xl:32px;--sp-2xl:48px;--sp-3xl:64px;--sp-4xl:96px;
  --radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;
}

/* ── TYPOGRAPHY ───────────────────────────────── */
.serif{font-family:'Playfair Display',Georgia,serif}
.eyebrow{font-size:11px;letter-spacing:2px;text-transform:uppercase;font-weight:600;color:var(--brown-400)}
h1{font-family:'Playfair Display',serif;font-size:clamp(38px,5.5vw,68px);font-weight:700;line-height:1.08;color:var(--brown-800)}
h2{font-family:'Playfair Display',serif;font-size:clamp(28px,4vw,42px);font-weight:700;line-height:1.15;color:var(--brown-800)}
h3{font-size:18px;font-weight:600;color:var(--brown-800);line-height:1.3}
p{color:var(--brown-600);line-height:1.7}

/* ── LAYOUT ───────────────────────────────────── */
.container{max-width:1080px;margin:0 auto;padding:0 var(--sp-xl)}
.section{padding:var(--sp-4xl) 0}
.section-header{text-align:center;margin-bottom:var(--sp-3xl)}
.section-header p{max-width:480px;margin:var(--sp-sm) auto 0;font-size:17px}

/* ── BUTTONS ──────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-sm);padding:14px 28px;border-radius:var(--radius-sm);font-size:15px;font-weight:600;cursor:pointer;border:none;font-family:'Inter',sans-serif;transition:all .2s;min-height:48px;white-space:nowrap}
.btn-primary{background:var(--brown-700);color:var(--white)}
.btn-primary:hover{background:var(--brown-800)}
.btn-ghost{background:transparent;color:var(--brown-700);border:1.5px solid var(--brown-700)}
.btn-ghost:hover{background:var(--cream-200)}
.btn-wa{background:#25D366;color:#fff}
.btn-wa:hover{background:#1DAE57}
.btn-lg{padding:16px 36px;font-size:16px}

/* ── NAV ──────────────────────────────────────── */
nav{position:sticky;top:0;z-index:200;background:rgba(253,246,236,0.96);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}
.nav-inner{max-width:1080px;margin:0 auto;padding:0 var(--sp-xl);height:88px;display:flex;align-items:center;justify-content:space-between;gap:var(--sp-xl)}
.nav-logo{font-family:'Playfair Display',serif;font-size:22px;font-weight:700;color:var(--brown-800);letter-spacing:-0.5px;flex-shrink:0}
.nav-logo span{color:var(--brown-400);font-style:italic;font-size:13px;font-weight:400;display:block;letter-spacing:0.5px;margin-top:-4px}
.nav-links{display:flex;gap:var(--sp-xl);align-items:center}
.nav-links a{font-size:14px;font-weight:500;color:var(--brown-600);transition:color .2s}
.nav-links a:hover{color:var(--brown-800)}
.nav-cta{display:flex;gap:var(--sp-sm);align-items:center}
.hamburger{display:none;background:none;border:none;cursor:pointer;padding:8px;color:var(--brown-800)}
.hamburger svg{width:24px;height:24px}
.mobile-menu{display:none;position:fixed;inset:0;top:88px;background:var(--cream-100);z-index:199;padding:var(--sp-xl);flex-direction:column;gap:var(--sp-md)}
.mobile-menu.open{display:flex}
.mobile-menu a{font-size:18px;font-weight:500;color:var(--brown-800);padding:var(--sp-md) 0;border-bottom:1px solid var(--border)}

/* ── HERO ─────────────────────────────────────── */
.hero{background:var(--cream-100);padding:var(--sp-4xl) 0 var(--sp-3xl);overflow:hidden}
.hero-inner{max-width:1080px;margin:0 auto;padding:0 var(--sp-xl);display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-4xl);align-items:center}
.hero-text{max-width:520px}
.hero-text .eyebrow{margin-bottom:var(--sp-md)}
.hero-text h1{margin-bottom:var(--sp-lg);letter-spacing:-1px}
.hero-text h1 em{color:var(--brown-400);font-style:italic}
.hero-sub{font-size:18px;color:var(--brown-600);margin-bottom:var(--sp-xl);line-height:1.6;max-width:430px}
.hero-actions{display:flex;gap:var(--sp-md);flex-wrap:wrap;margin-bottom:var(--sp-xl)}
.launch-pill{display:inline-flex;align-items:center;gap:var(--sp-sm);background:var(--cream-200);border:1px solid var(--border);border-radius:50px;padding:8px 18px;font-size:13px;color:var(--brown-500);font-weight:500}
.launch-pill s{color:var(--brown-300)}
.launch-pill strong{color:var(--brown-700)}
.hero-visual{position:relative}
.hero-img-wrap{background:transparent;display:flex;align-items:center;justify-content:center}
.hero-img-placeholder{text-align:center;padding:var(--sp-3xl)}
.cup-hero{font-size:140px;line-height:1;display:block;filter:drop-shadow(0 8px 24px rgba(0,0,0,0.12))}
.img-caption{font-size:12px;color:var(--brown-400);margin-top:var(--sp-md);text-align:center;letter-spacing:0.5px}
.hero-badge{position:absolute;top:-36px;right:var(--sp-lg);background:var(--brown-700);color:var(--white);border-radius:50%;width:80px;height:80px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}
.hero-badge .price{font-family:'Playfair Display',serif;font-size:22px;font-weight:700;line-height:1}
.hero-badge .label{font-size:9px;letter-spacing:1px;text-transform:uppercase;opacity:0.8}

/* ── SOCIAL PROOF STRIP ───────────────────────── */
.proof-strip{background:var(--brown-800);padding:var(--sp-lg) 0}
.proof-inner{max-width:1080px;margin:0 auto;padding:0 var(--sp-xl);display:flex;align-items:center;justify-content:center;gap:var(--sp-3xl);flex-wrap:wrap}
.proof-item{display:flex;align-items:center;gap:var(--sp-sm);color:rgba(255,255,255,0.9);font-size:14px;font-weight:500}
.proof-item .num{font-family:'Playfair Display',serif;font-size:24px;font-weight:700;color:var(--white)}
.proof-divider{width:1px;height:36px;background:rgba(255,255,255,0.15)}
.stars{color:#F5C518;font-size:16px;letter-spacing:2px}

/* ── PRODUCT ──────────────────────────────────── */
.product-section{background:var(--white);padding:var(--sp-4xl) 0}
.product-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-4xl);align-items:center}
.product-img-wrap{background:var(--cream-100);border-radius:var(--radius-lg);border:1px solid var(--border);padding:var(--sp-3xl);text-align:center}
.cup-product{font-size:120px;display:block;filter:drop-shadow(0 4px 16px rgba(0,0,0,0.1))}
.product-tag{font-size:12px;color:var(--brown-400);margin-top:var(--sp-md);font-weight:500;letter-spacing:0.5px}
.product-info h2{margin-bottom:var(--sp-md)}
.product-info > p{font-size:16px;margin-bottom:var(--sp-xl);max-width:420px}
.spec-list{list-style:none;display:flex;flex-direction:column;gap:12px;margin-bottom:var(--sp-xl)}
.spec-list li{display:flex;align-items:flex-start;gap:12px;font-size:15px;color:var(--brown-700)}
.spec-check{color:var(--green);font-size:18px;flex-shrink:0;margin-top:-1px}
.spec-text strong{display:block;font-weight:600;color:var(--brown-800);font-size:14px}
.spec-text span{font-size:13px;color:var(--brown-400)}
.price-block{background:var(--cream-100);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--sp-lg) var(--sp-xl);display:flex;align-items:center;flex-wrap:wrap;gap:var(--sp-md);margin-bottom:var(--sp-lg)}
.price-row{display:flex;align-items:stretch;gap:var(--sp-md);margin-bottom:var(--sp-lg)}
.price-row .price-block{flex:1;margin-bottom:0}
.order-cta-card{flex:1;display:flex;align-items:center;justify-content:center;text-align:center;background:var(--brown-700);color:var(--white);border-radius:var(--radius-md);padding:var(--sp-lg) var(--sp-xl);font-size:16px;font-weight:700;transition:background .2s,transform .2s}
.order-cta-card:hover{background:var(--brown-800);transform:translateY(-2px)}
.price-current{font-family:'Playfair Display',serif;font-size:44px;font-weight:700;color:var(--brown-800);line-height:1}
.price-meta{display:flex;flex-direction:column;gap:4px}
.price-old{font-size:16px;color:var(--brown-300);text-decoration:line-through}
.price-note{font-size:12px;color:var(--brown-400);font-weight:500;text-transform:uppercase;letter-spacing:1px}
.halal-note{display:inline-flex;align-items:center;gap:var(--sp-sm);background:#E8F5E9;border:1px solid #A5D6A7;border-radius:var(--radius-sm);padding:8px 14px;font-size:13px;color:#2D6A4F;font-weight:500}

/* ── GALLERY ──────────────────────────────────── */
.gallery-section{background:var(--white);padding:var(--sp-4xl) 0}
.gallery-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp-lg)}
.gallery-item{aspect-ratio:4/3;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);background:var(--cream-100)}
.gallery-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s cubic-bezier(.22,1,.36,1)}
.gallery-item:hover img{transform:scale(1.07)}
.gallery-note{text-align:center;font-size:12px;color:var(--brown-400);margin-top:var(--sp-lg);font-style:italic}

/* ── BENEFITS ─────────────────────────────────── */
.benefits-section{background:var(--cream-100);padding:var(--sp-4xl) 0}
.benefits-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-lg)}
.benefit-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--sp-xl) var(--sp-lg)}
.benefit-icon-wrap{width:80px;height:80px;background:var(--cream-200);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:38px;margin-bottom:var(--sp-lg)}
.benefit-icon-wrap img{width:60px;height:60px;object-fit:contain}
.benefit-card h3{margin-bottom:var(--sp-sm)}
.benefit-card p{font-size:15px}

/* ── PROCESS ──────────────────────────────────── */
.process-section{background:var(--white);padding:var(--sp-4xl) 0}
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-lg);position:relative}
.process-steps::before{content:'';position:absolute;top:28px;left:calc(12.5% + 28px);right:calc(12.5% + 28px);height:2px;background:var(--border);z-index:0}
.step{text-align:center;position:relative;z-index:1}
.step-num{width:56px;height:56px;background:var(--brown-700);color:var(--white);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-size:22px;font-weight:700;margin:0 auto var(--sp-md)}
.step-icon{font-size:28px;margin-bottom:var(--sp-sm);display:block}
.step-icon img{width:84px;height:84px;border-radius:50%;object-fit:cover;margin:0 auto;border:2px solid var(--cream-300)}
.step h3{font-size:15px;font-weight:600;margin-bottom:var(--sp-xs);color:var(--brown-800)}
.step p{font-size:13px;color:var(--brown-400);line-height:1.5}

/* ── ABOUT ────────────────────────────────────── */
.about-section{background:var(--brown-800);padding:var(--sp-4xl) 0}
.about-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:var(--sp-4xl);align-items:center}
.about-visual-wrap{background:var(--brown-700);border-radius:var(--radius-lg);padding:var(--sp-3xl);text-align:center}
.chef-avatar{width:120px;height:120px;background:var(--brown-600);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:56px;margin:0 auto var(--sp-lg)}
.hotel-badges{display:flex;flex-direction:column;gap:var(--sp-sm);margin-top:var(--sp-lg)}
.hotel-badge{display:flex;align-items:center;gap:var(--sp-sm);background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.15);border-radius:var(--radius-sm);padding:10px 14px;font-size:13px;color:rgba(255,255,255,0.8);font-weight:500}
.about-content .eyebrow{color:var(--brown-300);margin-bottom:var(--sp-md)}
.about-content h2{color:var(--white);margin-bottom:var(--sp-xl)}
.about-content p{color:rgba(255,255,255,0.72);margin-bottom:var(--sp-md);font-size:16px}
.about-content p strong{color:var(--white)}
.about-content p:last-child{margin-bottom:0}
.about-quote{border-left:3px solid var(--brown-400);padding-left:var(--sp-lg);margin:var(--sp-xl) 0}
.about-quote p{font-family:'Playfair Display',serif;font-size:20px;font-style:italic;color:rgba(255,255,255,0.9);line-height:1.4}

/* ── TESTIMONIALS ─────────────────────────────── */
.testi-section{background:var(--cream-100);padding:var(--sp-4xl) 0}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-lg)}
.testi-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--sp-xl)}
.testi-stars{color:#F5C518;font-size:16px;margin-bottom:var(--sp-md);letter-spacing:2px}
.testi-quote{font-size:15px;color:var(--brown-700);line-height:1.7;margin-bottom:var(--sp-lg);font-style:italic}
.testi-quote::before{content:'\201C';font-family:'Playfair Display',serif;font-size:28px;color:var(--brown-300);display:block;margin-bottom:4px;line-height:1}
.testi-author{display:flex;align-items:center;gap:var(--sp-sm)}
.testi-avatar{width:36px;height:36px;border-radius:50%;background:var(--cream-200);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:var(--brown-600)}
.testi-name{font-size:14px;font-weight:600;color:var(--brown-800)}
.testi-loc{font-size:12px;color:var(--brown-400)}

/* ── ORDER ────────────────────────────────────── */
.order-section{background:var(--cream-200);padding:var(--sp-4xl) 0}
.order-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:var(--sp-3xl);align-items:start}
.order-info h2{margin-bottom:var(--sp-md)}
.order-info p{font-size:16px;margin-bottom:var(--sp-xl)}
.order-steps{display:flex;flex-direction:column;gap:var(--sp-md)}
.order-step{display:flex;gap:var(--sp-md);align-items:flex-start}
.order-step-num{width:28px;height:28px;background:var(--brown-700);color:var(--white);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0;margin-top:2px}
.order-step-text strong{display:block;font-size:15px;font-weight:600;color:var(--brown-800);margin-bottom:2px}
.order-step-text span{font-size:13px;color:var(--brown-400)}
.order-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--sp-2xl)}
.order-card h3{font-size:22px;margin-bottom:4px}
.order-card-sub{font-size:14px;color:var(--brown-400);margin-bottom:var(--sp-xl)}
.form-group{margin-bottom:var(--sp-lg)}
.form-group label{display:block;font-size:13px;font-weight:600;color:var(--brown-700);margin-bottom:var(--sp-sm)}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:13px 16px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:15px;font-family:'Inter',sans-serif;background:var(--cream-100);color:var(--brown-800);transition:border-color .2s;outline:none;-webkit-appearance:none;appearance:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--brown-500);background:var(--white)}
.form-group select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%237B3F1E' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
.form-group textarea{resize:vertical;min-height:72px;line-height:1.5}
.form-optional{font-size:11px;color:var(--brown-300);font-weight:400;margin-left:4px}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-md)}
.order-summary{background:var(--cream-100);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--sp-lg);margin-bottom:var(--sp-lg)}
.sum-row{display:flex;justify-content:space-between;align-items:center;font-size:14px;color:var(--brown-600);padding:5px 0}
.sum-total{display:flex;justify-content:space-between;align-items:center;font-size:17px;font-weight:700;color:var(--brown-800);border-top:1px solid var(--border);padding-top:var(--sp-sm);margin-top:var(--sp-sm)}
.form-note{font-size:12px;color:var(--brown-400);margin-bottom:var(--sp-lg);line-height:1.6}
.btn-submit{width:100%;font-size:16px;padding:16px;border-radius:var(--radius-sm);letter-spacing:0.3px}
.success-msg{display:none;background:#E8F5E9;border:1px solid #A5D6A7;border-radius:var(--radius-md);padding:var(--sp-xl);text-align:center}
.success-msg .icon{font-size:40px;margin-bottom:var(--sp-md)}
.success-msg h3{color:var(--green);font-size:20px;margin-bottom:var(--sp-sm)}
.success-msg p{color:var(--green);font-size:15px}

/* ── FAQ ──────────────────────────────────────── */
.faq-section{background:var(--white);padding:var(--sp-4xl) 0}
.faq-list{max-width:680px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{width:100%;text-align:left;background:none;border:none;padding:var(--sp-lg) 0;font-size:16px;font-weight:600;color:var(--brown-800);cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-family:'Inter',sans-serif;gap:var(--sp-lg)}
.faq-icon{font-size:22px;color:var(--brown-400);flex-shrink:0;transition:transform .25s;line-height:1}
.faq-q.is-open .faq-icon{transform:rotate(45deg)}
.faq-a{display:none;padding-bottom:var(--sp-lg);font-size:15px;color:var(--brown-600);line-height:1.7;max-width:600px}
.faq-a.is-open{display:block}

/* ── FOOTER ───────────────────────────────────── */
footer{background:var(--brown-900);color:rgba(255,255,255,0.55);padding:var(--sp-3xl) 0 var(--sp-2xl)}
.footer-inner{max-width:1080px;margin:0 auto;padding:0 var(--sp-xl)}
.footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:var(--sp-3xl);padding-bottom:var(--sp-2xl);border-bottom:1px solid rgba(255,255,255,0.1)}
.footer-brand h3{font-family:'Playfair Display',serif;font-size:22px;font-weight:700;color:var(--white);margin-bottom:4px}
.footer-brand em{font-size:13px;color:var(--brown-300);font-style:italic;display:block;margin-bottom:var(--sp-lg)}
.footer-brand p{font-size:14px;color:rgba(255,255,255,0.5);line-height:1.6;max-width:260px}
.footer-col h4{font-size:13px;font-weight:600;color:rgba(255,255,255,0.8);text-transform:uppercase;letter-spacing:1px;margin-bottom:var(--sp-md)}
.footer-col a{display:block;font-size:14px;color:rgba(255,255,255,0.5);margin-bottom:var(--sp-sm);transition:color .2s}
.footer-col a:hover{color:rgba(255,255,255,0.9)}
.footer-col p{font-size:14px;color:rgba(255,255,255,0.5);margin-bottom:var(--sp-sm)}
.footer-bottom{padding-top:var(--sp-xl);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--sp-md)}
.footer-bottom p{font-size:13px}
.footer-halal{display:inline-flex;align-items:center;gap:var(--sp-sm);background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.12);border-radius:var(--radius-sm);padding:6px 12px;font-size:12px;color:rgba(255,255,255,0.7)}

/* ── STICKY MOBILE BAR ────────────────────────── */
.sticky-order-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:300;background:var(--brown-700);padding:var(--sp-md) var(--sp-xl);padding-bottom:calc(var(--sp-md) + env(safe-area-inset-bottom));box-shadow:0 -4px 24px rgba(0,0,0,0.2)}
.sticky-order-bar .inner{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-md);max-width:480px;margin:0 auto}
.sticky-bar-text{color:var(--white)}
.sticky-bar-text strong{display:block;font-size:15px;font-weight:600}
.sticky-bar-text span{font-size:12px;opacity:0.7}
.sticky-bar-btn{background:var(--white);color:var(--brown-700);padding:12px 22px;border-radius:var(--radius-sm);font-size:14px;font-weight:700;border:none;cursor:pointer;font-family:'Inter',sans-serif;flex-shrink:0;white-space:nowrap}

/* ── ANIMATIONS ───────────────────────────────

/* Keyframes */
@keyframes fadeUp{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideRight{from{opacity:0;transform:translateX(-40px)}to{opacity:1;transform:translateX(0)}}
@keyframes slideLeft{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}
@keyframes scaleIn{from{opacity:0;transform:scale(0.88)}to{opacity:1;transform:scale(1)}}
@keyframes floatCup{0%,100%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-18px) rotate(1deg)}}
@keyframes pulseBadge{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes drawLine{from{width:0}to{width:100%}}
@keyframes popIn{0%{opacity:0;transform:scale(0.6) rotate(-8deg)}70%{transform:scale(1.06) rotate(2deg)}100%{opacity:1;transform:scale(1) rotate(0)}}
@keyframes steam{0%{opacity:0;transform:translateY(0) scaleX(1)}30%{opacity:0.6}100%{opacity:0;transform:translateY(-28px) scaleX(1.6)}}
@keyframes marqueeScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@keyframes glowPulse{0%,100%{box-shadow:0 0 0 0 rgba(160,82,45,0)}50%{box-shadow:0 0 0 8px rgba(160,82,45,0.18)}}
@keyframes countUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
@keyframes waveIn{0%{clip-path:inset(0 100% 0 0)}100%{clip-path:inset(0 0% 0 0)}}

/* Scroll-reveal base state */
.reveal{opacity:0;transform:translateY(36px);transition:opacity .65s cubic-bezier(.22,1,.36,1),transform .65s cubic-bezier(.22,1,.36,1)}
.reveal.from-left{transform:translateX(-40px)}
.reveal.from-right{transform:translateX(40px)}
.reveal.scale-in{transform:scale(0.9);opacity:0}
.reveal.is-visible{opacity:1;transform:none}

/* Stagger children */
.stagger-children > *{opacity:0;transform:translateY(28px);transition:opacity .5s cubic-bezier(.22,1,.36,1),transform .5s cubic-bezier(.22,1,.36,1)}
.stagger-children.is-visible > *:nth-child(1){transition-delay:.05s;opacity:1;transform:none}
.stagger-children.is-visible > *:nth-child(2){transition-delay:.15s;opacity:1;transform:none}
.stagger-children.is-visible > *:nth-child(3){transition-delay:.25s;opacity:1;transform:none}
.stagger-children.is-visible > *:nth-child(4){transition-delay:.35s;opacity:1;transform:none}

/* Hero entrance */
.hero-text .eyebrow{animation:fadeUp .6s .1s both}
.hero-text h1{animation:fadeUp .7s .2s both}
.hero-text .hero-sub{animation:fadeUp .7s .35s both}
.hero-text .hero-actions{animation:fadeUp .6s .5s both}
.hero-text .launch-pill{animation:fadeUp .6s .65s both}
.hero-visual .hero-img-wrap{animation:scaleIn .8s .3s both}
.hero-badge{animation:popIn .7s .9s both}

/* Floating cup */
.cup-hero{animation:floatCup 4s ease-in-out infinite}
.cup-product{animation:floatCup 5s ease-in-out infinite 0.5s}

/* Badge pulse */
.hero-badge{animation:popIn .7s .9s both,pulseBadge 2.5s 1.6s ease-in-out infinite}

/* Proof strip counter */
.proof-item .num{animation:countUp .5s ease both}

/* Button hover lift */
.btn{transform:translateY(0);box-shadow:0 0 0 rgba(0,0,0,0)}
.btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(59,31,14,0.18)}
.btn:active{transform:translateY(0)}

/* Primary CTA glow pulse after 3s */
.btn-primary{animation:glowPulse 3s 3s ease-in-out infinite}

/* Step numbers */
.step-num{transition:transform .2s,background .2s}
.step:hover .step-num{transform:scale(1.15);background:var(--brown-500)}
.step-icon{transition:transform .3s}
.step:hover .step-icon{transform:scale(1.2) rotate(-5deg)}

/* Benefit cards */
.benefit-card{transition:transform .25s,border-color .25s}
.benefit-card:hover{transform:translateY(-6px);border-color:var(--brown-300)}
.benefit-icon-wrap{transition:transform .3s}
.benefit-card:hover .benefit-icon-wrap{transform:scale(1.12) rotate(-4deg)}

/* Testimonial cards */
.testi-card{transition:transform .25s,border-color .25s}
.testi-card:hover{transform:translateY(-5px);border-color:var(--brown-300)}

/* Spec list items */
.spec-list li{transition:transform .2s}
.spec-list li:hover{transform:translateX(4px)}

/* Nav link underline animation */
.nav-links a{position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:2px;background:var(--brown-500);transition:width .25s ease}
.nav-links a:hover::after{width:100%}

/* Sticky bar slide up */
.sticky-order-bar{transform:translateY(100%);transition:transform .4s cubic-bezier(.22,1,.36,1)}
.sticky-order-bar.bar-visible{transform:translateY(0)}

/* Form focus ring animation */
.form-group input,.form-group select,.form-group textarea{transition:border-color .2s,transform .15s,background .2s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{transform:scale(1.01)}

/* Process line animation */
.process-steps::before{width:0;animation:drawLine 1s .5s ease forwards}

/* About section text reveal */
.about-quote{opacity:0;transform:translateX(-20px);transition:opacity .6s,transform .6s}
.about-quote.is-visible{opacity:1;transform:none}

/* Hotel badges stagger */
.hotel-badge{opacity:0;transform:translateX(-16px);transition:opacity .4s,transform .4s}
.hotel-badge:nth-child(1){transition-delay:.1s}
.hotel-badge:nth-child(2){transition-delay:.2s}
.hotel-badge:nth-child(3){transition-delay:.3s}
.hotel-badge:nth-child(4){transition-delay:.4s}
.hotel-badges.is-visible .hotel-badge{opacity:1;transform:none}

/* Order step reveal */
.order-step{opacity:0;transform:translateY(16px);transition:opacity .4s,transform .4s}
.order-step:nth-child(1){transition-delay:.05s}
.order-step:nth-child(2){transition-delay:.15s}
.order-step:nth-child(3){transition-delay:.25s}
.order-step:nth-child(4){transition-delay:.35s}
.order-steps.is-visible .order-step{opacity:1;transform:none}

/* FAQ item hover */
.faq-item{transition:background .2s}
.faq-item:hover{background:var(--cream-100)}
.faq-q{transition:color .2s}

/* Footer links */
.footer-col a{transition:color .2s,transform .2s;display:inline-block}
.footer-col a:hover{transform:translateX(4px)}

/* Particle steam wrapper */
.steam-wrap{position:absolute;top:10px;left:50%;transform:translateX(-50%);pointer-events:none;width:60px;display:flex;justify-content:space-around}
.steam-particle{width:6px;height:16px;border-radius:50%;background:rgba(196,132,90,0.35);animation:steam 2s ease-in-out infinite}
.steam-particle:nth-child(1){animation-delay:0s}
.steam-particle:nth-child(2){animation-delay:.4s}
.steam-particle:nth-child(3){animation-delay:.8s}

/* Page load overlay */
#page-loader{position:fixed;inset:0;background:var(--cream-100);z-index:9999;display:flex;align-items:center;justify-content:center;transition:opacity .5s,visibility .5s}
#page-loader.loaded{opacity:0;visibility:hidden}
.loader-cup{font-size:56px;animation:floatCup 1s ease-in-out infinite}
.loader-text{font-family:'Playfair Display',serif;font-size:22px;color:var(--brown-700);margin-top:16px;font-style:italic}

/* ── RESPONSIVE ───────────────────────────────── */
@media(max-width:900px){
  .hero-inner{grid-template-columns:1fr;gap:var(--sp-2xl)}
  .hero-text{max-width:100%;text-align:center}
  .hero-sub{margin-left:auto;margin-right:auto}
  .hero-actions{justify-content:center}
  .launch-pill{justify-content:center}
  .hero-visual{max-width:360px;margin:0 auto}
  .product-grid,.about-grid,.order-grid{grid-template-columns:1fr}
  .about-visual-wrap{max-width:360px}
  .benefits-grid{grid-template-columns:1fr 1fr}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .testi-grid{grid-template-columns:1fr}
  .process-steps{grid-template-columns:1fr 1fr;gap:var(--sp-lg)}
  .process-steps::before{display:none}
  .footer-top{grid-template-columns:1fr 1fr}
  .footer-brand{grid-column:1/-1}
}
@media(max-width:640px){
  .container{padding:0 var(--sp-lg)}
  .nav-inner{padding:0 var(--sp-lg)}
  .nav-links{display:none}
  .hamburger{display:flex}
  .nav-cta .btn{display:none}
  .benefits-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr}
  .price-row{flex-direction:column}
  .process-steps{grid-template-columns:1fr 1fr}
  .proof-inner{gap:var(--sp-xl)}
  .proof-divider{display:none}
  .form-row-2{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;text-align:center}
  .sticky-order-bar{display:block}
  body{padding-bottom:80px}
  .section{padding:var(--sp-3xl) 0}
}

/* ── REDUCED MOTION ───────────────────────────── */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .cup-hero,.cup-product,.loader-cup,.hero-badge,.steam-particle{animation:none!important}
  .reveal,.stagger-children>*,.about-quote,.hotel-badge,.order-step{opacity:1!important;transform:none!important}
}
