:root{
  --pink:#f7a8c4;
  --pink-deep:#ec6f9e;
  --pink-soft:#fde4ee;
  --rose:#e8638c;
  --cream:#fff6f1;
  --peach:#fdeee6;
  --lav:#f1e8fb;
  --tan:#c89b6f;
  --brown:#6b4226;
  --ink:#4a3540;
  --ink-soft:#7a6571;
  --white:#ffffff;
  --shadow:0 18px 40px rgba(236,111,158,.18);
  --shadow-sm:0 8px 22px rgba(236,111,158,.14);
  --radius:28px;
  --radius-sm:18px;
  --font-head:'Fredoka',system-ui,sans-serif;
  --font-body:'Poppins',system-ui,sans-serif;
  --font-script:'Dancing Script',cursive;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);color:var(--ink);background:var(--cream);line-height:1.6;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{width:min(1120px,92%);margin:0 auto;position:relative;z-index:2}
.script{font-family:var(--font-script);font-weight:700}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4em;font-family:var(--font-head);font-weight:600;border:none;cursor:pointer;border-radius:999px;padding:.8em 1.8em;font-size:1rem;transition:transform .2s ease,box-shadow .2s ease,background .2s ease;text-align:center}
.btn-primary{background:linear-gradient(135deg,var(--pink) 0%,var(--rose) 100%);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{transform:translateY(-3px) scale(1.02);box-shadow:var(--shadow)}
.btn-ghost{background:rgba(255,255,255,.85);color:var(--rose);backdrop-filter:blur(6px)}
.btn-ghost:hover{transform:translateY(-3px) scale(1.02)}
.btn-lg{font-size:1.1rem;padding:.95em 2.3em}
.btn-sm{font-size:.85rem;padding:.6em 1.2em}
.btn-block{width:100%}

/* ---------- Header ---------- */
.site-header{position:fixed;top:0;left:0;right:0;z-index:100;padding:.7rem 0;transition:background .3s ease,box-shadow .3s ease,padding .3s ease}
.site-header.scrolled{background:rgba(255,246,241,.92);backdrop-filter:blur(12px);box-shadow:0 6px 20px rgba(236,111,158,.12);padding:.45rem 0}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.brand{display:flex;align-items:center;gap:.6rem}
.brand-logo{width:48px;height:48px;border-radius:50%;box-shadow:var(--shadow-sm);background:var(--rose);object-fit:cover}
.brand-name{font-family:var(--font-head);font-weight:700;font-size:1.25rem;color:var(--rose)}
.nav{display:flex;align-items:center;gap:1.6rem}
.nav a{font-family:var(--font-head);font-weight:500;color:var(--ink);transition:color .2s}
.nav a:hover{color:var(--rose)}
.nav-socials{display:flex;gap:.7rem;color:var(--rose)}
.nav-socials a{display:flex;transition:transform .2s}
.nav-socials a:hover{transform:translateY(-2px) scale(1.1)}
.header-cta{margin-left:.4rem}
.nav-call{font-family:var(--font-head);font-weight:600;color:var(--rose)!important}
.header-call{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;background:var(--rose);color:#fff;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s;flex:0 0 auto}
.header-call:hover{transform:translateY(-2px) scale(1.05);box-shadow:var(--shadow)}
/* the "Call (661)…" menu link is for the mobile dropdown; hide it on desktop where the icon + socials cover it */
@media(min-width:641px){.nav-call{display:none}}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.hamburger span{width:26px;height:3px;background:var(--rose);border-radius:3px;transition:.3s}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;background:linear-gradient(160deg,#fde4ee,#fbd3e4 45%,#f6bcd6)}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(253,228,238,.55) 0%,rgba(247,168,196,.35) 50%,rgba(236,111,158,.45) 100%);z-index:1}
.hero-content{z-index:3;padding:7rem 0 4rem;max-width:760px}
.hero-eyebrow{font-family:var(--font-head);font-weight:500;letter-spacing:.5px;color:#fff;background:rgba(236,111,158,.55);display:inline-block;padding:.4em 1.1em;border-radius:999px;font-size:.9rem;margin-bottom:1.2rem;backdrop-filter:blur(4px)}
.hero-title{font-family:var(--font-head);font-weight:700;font-size:clamp(2.6rem,7vw,5rem);line-height:1.02;color:#fff;text-shadow:0 4px 24px rgba(180,60,110,.35)}
.hero-title .script{color:#fff;font-size:1.15em;display:inline-block;text-shadow:0 6px 24px rgba(180,60,110,.45)}
.hero-sub{color:#fff;font-size:clamp(1rem,2.2vw,1.25rem);margin:1.3rem auto 2rem;max-width:540px;text-shadow:0 2px 12px rgba(180,60,110,.35)}
.hero-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.hero-fade{position:absolute;bottom:0;left:0;right:0;height:90px;background:linear-gradient(to bottom,transparent,var(--cream));z-index:3}

/* ---------- Floating bits ---------- */
.float{position:absolute;z-index:2;pointer-events:none;filter:drop-shadow(0 8px 14px rgba(180,60,110,.18))}
.float-bow-1{width:120px;top:14%;left:7%;animation:bob 6s ease-in-out infinite}
.float-spark-1{width:46px;top:22%;right:12%;animation:twinkle 3.5s ease-in-out infinite}
.float-spark-2{width:32px;bottom:24%;left:14%;animation:twinkle 4.2s ease-in-out infinite .6s}
.float-straw-1{width:74px;bottom:18%;right:9%;animation:bob 7s ease-in-out infinite 1s}
.float-peb-1{width:90px;top:30%;left:4%;animation:bob 5.5s ease-in-out infinite .4s}
.float-deco{position:absolute;z-index:1;opacity:.85;pointer-events:none;filter:drop-shadow(0 8px 14px rgba(180,60,110,.12))}
.bean-a{width:46px;top:10%;right:8%;animation:bob 6s ease-in-out infinite}
.heart-a{width:40px;bottom:14%;left:6%;animation:bob 7s ease-in-out infinite .5s}
.bow-b{width:110px;top:6%;right:5%;animation:bob 6.5s ease-in-out infinite}
.spark-b{width:50px;bottom:10%;left:7%;animation:twinkle 4s ease-in-out infinite}
.heart-c{width:46px;top:12%;right:9%;animation:bob 6s ease-in-out infinite}
.bean-d{width:42px;bottom:12%;right:8%;animation:bob 6.5s ease-in-out infinite}
.spark-d{width:44px;top:14%;left:6%;animation:twinkle 3.8s ease-in-out infinite}
.spark-e{width:48px;top:10%;right:7%;animation:twinkle 4.1s ease-in-out infinite}
.straw-e{width:62px;bottom:10%;left:6%;animation:bob 7s ease-in-out infinite .3s}
.straw-why{width:66px;top:14%;right:6%;animation:bob 7s ease-in-out infinite}
.peb-why{width:84px;bottom:12%;left:4%;animation:bob 6s ease-in-out infinite .4s}
.bow-why{width:104px;top:8%;left:5%;animation:bob 6.5s ease-in-out infinite .8s}

@keyframes bob{0%,100%{transform:translateY(0) rotate(-4deg)}50%{transform:translateY(-18px) rotate(4deg)}}
@keyframes twinkle{0%,100%{transform:scale(1) rotate(0);opacity:.7}50%{transform:scale(1.25) rotate(20deg);opacity:1}}
@keyframes spin-slow{from{transform:rotate(0)}to{transform:rotate(360deg)}}

/* ---------- Ticker ---------- */
.ticker{background:linear-gradient(90deg,var(--pink),var(--rose));overflow:hidden;padding:.85rem 0}
.ticker-track{display:flex;gap:1.6rem;white-space:nowrap;width:max-content;animation:scrollx 26s linear infinite}
.ticker-track span{font-family:var(--font-head);font-weight:600;color:#fff;font-size:1.05rem;letter-spacing:.4px}
@keyframes scrollx{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- Scrolling cups band ---------- */
.cup-band{position:relative;background:linear-gradient(135deg,var(--pink) 0%,var(--rose) 55%,var(--pink-deep) 100%);padding:3rem 0 3.4rem;overflow:hidden}
.cup-band-title{text-align:center;color:#fff;font-size:clamp(2.2rem,5vw,3.6rem);margin-bottom:1.2rem;text-shadow:0 6px 20px rgba(160,40,90,.3)}
.cup-row{width:100%;margin:.3rem 0}
.cup-track{display:flex;width:max-content;align-items:center;will-change:transform;animation:cupscroll 40s linear infinite}
.cup-row-rev .cup-track{animation-direction:reverse;animation-duration:48s}
/* spacing lives on each cup (margin) — NOT gap — so the duplicated half tiles exactly at -50% for a seamless loop */
.cup{height:188px;width:auto;margin-right:2.4rem;flex:0 0 auto;filter:drop-shadow(0 14px 20px rgba(120,40,70,.35));transition:transform .3s ease}
.cup:hover{transform:translateY(-10px) scale(1.05) rotate(-2deg)}
@keyframes cupscroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- Sections ---------- */
.section{position:relative;padding:6rem 0;overflow:hidden}
.section-cream{background:var(--cream)}
.section-pink{background:linear-gradient(180deg,var(--pink-soft),#fcd6e6)}
.section-lav{background:linear-gradient(180deg,var(--lav),#e9ddfa)}
.section-title{font-family:var(--font-head);font-weight:700;font-size:clamp(2rem,4.5vw,3rem);text-align:center;color:var(--rose);line-height:1.1}
.section-title.left{text-align:left}
.section-lead{text-align:center;font-size:1.1rem;color:var(--ink-soft);max-width:620px;margin:1rem auto 0}
.section-lead a{color:var(--rose);font-weight:600;text-decoration:underline}
.milk-note{font-size:.92rem;color:var(--tan);font-weight:500}

/* ---------- Why ---------- */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem;margin-top:3rem}
.why-card{background:#fff;border-radius:var(--radius);padding:2.2rem 1.8rem;text-align:center;box-shadow:var(--shadow-sm);border:2px solid #fff;transition:transform .25s,box-shadow .25s}
.why-card:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:var(--pink-soft)}
.why-emoji{font-size:2.6rem;margin-bottom:.6rem}
.why-card h3{font-family:var(--font-head);font-weight:600;color:var(--rose);font-size:1.3rem;margin-bottom:.5rem}
.why-card p{color:var(--ink-soft);font-size:.98rem}

/* ---------- Drinks ---------- */
.drink-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.6rem;margin-top:3rem}
.drink-card{background:#fff;border-radius:var(--radius);padding:1.4rem;text-align:center;box-shadow:var(--shadow-sm);transition:transform .25s,box-shadow .25s;display:flex;flex-direction:column}
.drink-card:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.drink-img-wrap{position:relative;border-radius:var(--radius-sm);padding:1rem;margin-bottom:1rem;aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;overflow:hidden}
.c-pink{background:radial-gradient(circle at 50% 30%,#ffe1ee,#fbc4dc)}
.c-rose{background:radial-gradient(circle at 50% 30%,#ffd9e2,#f7aec0)}
.c-brown{background:radial-gradient(circle at 50% 30%,#e9cbb3,#cda080)}
.c-caramel{background:radial-gradient(circle at 50% 30%,#f5dcb8,#e6bd8a)}
.c-cream{background:radial-gradient(circle at 50% 30%,#fff3dd,#f5e3bf)}
.drink-img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 12px 18px rgba(120,60,40,.25));border-radius:14px}
.drink-emoji{display:flex;align-items:center;justify-content:center;font-size:4.5rem;filter:none}
.drink-accent{position:absolute;width:46px;top:8px;right:8px;z-index:2;animation:bob 5s ease-in-out infinite}
.drink-card h3{font-family:var(--font-head);font-weight:600;color:var(--ink);font-size:1.12rem;margin-bottom:.4rem}
.drink-card p{color:var(--ink-soft);font-size:.9rem;flex:1;margin-bottom:1rem}
.drink-foot{display:flex;align-items:center;justify-content:space-between;gap:.6rem}
.price{font-family:var(--font-head);font-weight:700;color:var(--rose);font-size:1.3rem}

/* special card */
.special-card{background:linear-gradient(160deg,#fff,#ffeaf3);border:2px dashed var(--pink)}
.special-inner{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:.3rem;padding:.6rem}
.special-eyebrow{text-transform:uppercase;letter-spacing:2px;font-size:.72rem;color:var(--ink-soft)}
.special-title{color:var(--rose);font-size:2.6rem;line-height:1}
.special-text{color:var(--ink);font-size:.98rem}
.special-when{font-family:var(--font-head);font-weight:600;color:var(--rose);margin-top:.2rem}
.special-sub{font-size:.82rem;color:var(--ink-soft);margin-bottom:.6rem}

/* ---------- Testimonials ---------- */
.testi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem;margin-top:3rem}
.testi-card{background:#fff;border-radius:var(--radius);padding:1.8rem 1.5rem;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:.8rem}
.stars{color:#ffc83d;letter-spacing:2px;font-size:1rem}
.testi-card p{font-size:.95rem;color:var(--ink);font-style:italic}
.testi-card cite{font-family:var(--font-head);font-weight:500;color:var(--rose);font-style:normal;font-size:.9rem}

/* ---------- Story ---------- */
.story-inner{display:grid;grid-template-columns:.85fr 1.15fr;gap:3.5rem;align-items:center}
.story-visual{position:relative;display:flex;justify-content:center}
.polaroid{background:#fff;padding:1rem 1rem 2.6rem;border-radius:14px;box-shadow:var(--shadow);transform:rotate(-4deg);position:relative}
.polaroid-img{width:260px;height:260px;object-fit:cover;border-radius:8px}
.polaroid-cap{position:absolute;bottom:.6rem;left:0;right:0;text-align:center;color:var(--rose);font-size:1.6rem}
.polaroid-bow{position:absolute;width:96px;top:-44px;right:6%;z-index:3;animation:bob 6s ease-in-out infinite}
.story-text .kicker{font-family:var(--font-head);text-transform:uppercase;letter-spacing:2px;color:var(--pink-deep);font-weight:600;font-size:.85rem;margin-bottom:.4rem}
.story-text .section-title{margin-bottom:1rem}
.story-text p{color:var(--ink-soft);margin-bottom:1rem}
.story-text .btn{margin-top:.6rem}

/* ---------- Order ---------- */
.order-inner{max-width:760px;margin:0 auto}
.order-head{text-align:center;margin-bottom:2.5rem}
.order-contact{margin-top:1.2rem}
.order-loc{margin-top:.8rem;color:var(--ink-soft);font-size:.92rem;font-weight:500}
.order-logo-vid{width:min(360px,76%);height:auto;margin:0 auto .2rem;display:block}
.order-form{background:#fff;border-radius:var(--radius);padding:2.4rem;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:1.1rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.order-form label{display:flex;flex-direction:column;gap:.4rem;font-family:var(--font-head);font-weight:500;color:var(--ink);font-size:.92rem;min-width:0}
.order-form input,.order-form select,.order-form textarea{width:100%;max-width:100%;min-width:0;display:block;font-family:var(--font-body);font-size:1rem;padding:.75rem .9rem;border:2px solid var(--pink-soft);border-radius:14px;background:var(--cream);color:var(--ink);transition:border .2s}
.order-form input:focus,.order-form select:focus,.order-form textarea:focus{outline:none;border-color:var(--pink)}
.order-form textarea{resize:vertical}
.form-success{display:none;background:#eafbe7;color:#3a7d34;border-radius:14px;padding:1rem;text-align:center;font-weight:500}
.form-success.show{display:block;animation:pop .4s ease}
@keyframes pop{from{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}
.form-fineprint{font-size:.78rem;color:var(--ink-soft);text-align:center}

/* ---------- Payment step ---------- */
.pay-panel{margin-top:1.6rem;padding-top:1.6rem;border-top:2px dashed var(--pink-soft);animation:pop .4s ease}
.pay-title{font-family:var(--font-head);font-weight:600;color:var(--rose);text-align:center;font-size:1.25rem}
.pay-sub{text-align:center;color:var(--ink-soft);font-size:.9rem;margin:.4rem auto 1.2rem;max-width:480px}
.pay-methods{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}
.pay-card{flex:1 1 180px;max-width:220px;background:var(--cream);border:2px solid var(--pink-soft);border-radius:var(--radius-sm);padding:1.2rem 1rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.7rem}
.pay-badge{font-family:var(--font-head);font-weight:700;padding:.25em .9em;border-radius:999px;color:#fff;font-size:.95rem}
.pay-zelle{background:#6d1ed4}
.pay-cash{background:#00c244}
.pay-apple{background:#111}
.pay-qr{width:140px;height:140px;object-fit:contain;border-radius:12px;background:#fff;padding:6px}
.pay-handle{font-family:var(--font-body);font-weight:600;color:var(--ink);word-break:break-word;font-size:.95rem}
.pay-fallback{text-align:center;color:var(--ink-soft)}
.pay-fallback a{color:var(--rose);font-weight:600;text-decoration:underline}

/* ---------- Newsletter ---------- */
.news-inner{text-align:center;max-width:560px;margin:0 auto}
.news-form{display:flex;gap:.7rem;margin:1.6rem auto 0;max-width:440px}
.news-form input{flex:1;padding:.85rem 1.1rem;border:2px solid #fff;border-radius:999px;font-size:1rem;font-family:var(--font-body);box-shadow:var(--shadow-sm)}
.news-form input:focus{outline:none;border-color:var(--pink)}
.news-fine{font-size:.82rem;color:var(--ink-soft);margin-top:.9rem}

/* ---------- FAQ ---------- */
.faq-inner{max-width:760px;margin:0 auto}
.faq-list{margin-top:2.5rem;display:flex;flex-direction:column;gap:1rem}
.faq-item{background:#fff;border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);padding:0 1.4rem;overflow:hidden}
.faq-item summary{font-family:var(--font-head);font-weight:600;color:var(--ink);font-size:1.05rem;padding:1.2rem 0;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:'+';color:var(--rose);font-size:1.6rem;font-weight:400;transition:transform .25s}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item p{color:var(--ink-soft);padding:0 0 1.2rem;font-size:.96rem}
.faq-item p a{color:var(--rose);font-weight:600}

/* ---------- Footer ---------- */
.footer{background:linear-gradient(160deg,var(--rose),var(--pink-deep));color:#fff;padding:3.5rem 0 1.6rem}
.footer-inner{display:flex;flex-wrap:wrap;gap:2rem;justify-content:space-between;align-items:center}
.footer-brand{display:flex;flex-direction:column;align-items:center;gap:.4rem}
.footer-logo{width:84px;height:84px;border-radius:50%;box-shadow:0 8px 20px rgba(0,0,0,.15);background:var(--rose);object-fit:cover}
.footer-tag{font-size:1.5rem;color:#fff}
.footer-links,.footer-social{display:flex;flex-direction:column;gap:.6rem}
.footer-links a,.footer-social a{font-family:var(--font-head);font-weight:500;opacity:.92;transition:opacity .2s}
.footer-links a:hover,.footer-social a:hover{opacity:1;text-decoration:underline}
.footer-loc{font-family:var(--font-head);font-weight:500;opacity:.92}
.footer-copy{text-align:center;margin-top:2.5rem;opacity:.85;font-size:.88rem}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media(max-width:900px){
  .why-grid{grid-template-columns:1fr}
  .drink-grid{grid-template-columns:repeat(2,1fr)}
  .testi-grid{grid-template-columns:repeat(2,1fr)}
  .story-inner{grid-template-columns:1fr;gap:2.5rem}
  .story-visual{order:-1}
  .section-title.left{text-align:center}
  .story-text{text-align:center}
}
@media(max-width:640px){
  .nav{position:fixed;inset:62px 0 auto 0;background:rgba(255,246,241,.98);backdrop-filter:blur(12px);flex-direction:column;padding:1.5rem;gap:1.4rem;transform:translateY(-150%);transition:transform .35s ease;box-shadow:0 10px 30px rgba(236,111,158,.18)}
  .nav.open{transform:translateY(0)}
  .nav a{font-size:1.15rem}
  .nav-socials{justify-content:center;gap:1.4rem}
  .hamburger{display:flex}
  .header-cta{display:none}
  .brand-name{font-size:1.1rem}
  .brand-logo{width:42px;height:42px}
  .section{padding:3.6rem 0}
  /* hide decorative floats on phones so they never overlap text */
  .float,.float-deco{display:none}
  /* hero */
  .hero{min-height:92vh}
  .hero-content{padding:5.5rem 0 3rem}
  .hero-eyebrow{font-size:.74rem;padding:.35em .9em}
  .hero-actions .btn{flex:1 1 auto}
  /* cup band lighter on mobile */
  .cup{height:122px;margin-right:1.4rem}
  .cup-band{padding:2.2rem 0 2.6rem}
  /* grids stack */
  .form-row{grid-template-columns:1fr}
  .drink-grid,.testi-grid{grid-template-columns:1fr}
  .drink-card{padding:1.1rem}
  .news-form{flex-direction:column}
  .news-form .btn{width:100%}
  /* order + payments full width */
  .order-form{padding:1.5rem}
  .pay-card{flex:1 1 100%;max-width:none}
  /* story polaroid scales to screen */
  .polaroid-img{width:74vw;max-width:260px;height:auto;aspect-ratio:1/1;object-fit:cover}
  /* footer stacks + centers */
  .footer-inner{flex-direction:column;text-align:center;gap:1.6rem}
  .footer-links,.footer-social{align-items:center}
}
@media(max-width:400px){
  .hero-title{font-size:2.15rem}
  .hero-title .script{font-size:1.1em}
  .section-title{font-size:1.7rem}
  .brand-name{font-size:1rem}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}
