/* Supreme Açaí Smoothie Bar — Organic Vibrant Tropical
   açaí-purple + lime green + tropical accents, bright & rounded */

:root{
  --acai:#7b3fb0;
  --acai-deep:#42175f;
  --acai-bright:#9a52d4;
  --lime:#9fe23a;
  --lime-deep:#6fbf17;
  --lime-soft:#eafbd0;
  --berry-pink:#ff5d8f;
  --mango:#ffb43d;
  --leaf:#3fb87a;
  --cream:#fff9f2;
  --ink:#2c1740;
  --ink-soft:#5d4a6e;
  --white:#ffffff;
  --shadow:0 14px 40px -16px rgba(66,23,95,.35);
  --shadow-sm:0 6px 18px -8px rgba(66,23,95,.3);
  --radius:26px;
  --radius-lg:40px;
  --maxw:1120px;
  --font-head:'Baloo 2',system-ui,sans-serif;
  --font-body:'Nunito',system-ui,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:var(--acai);text-decoration:none}
h1,h2,h3{font-family:var(--font-head);line-height:1.1;margin:0 0 .4em;color:var(--ink)}

.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 20px}

/* Skip + focus */
.skip-link{
  position:absolute;left:-999px;top:0;background:var(--acai);color:#fff;
  padding:12px 18px;border-radius:0 0 14px 0;z-index:1000;font-weight:700;
}
.skip-link:focus{left:0}
a:focus-visible,button:focus-visible{outline:3px solid var(--acai);outline-offset:3px;border-radius:8px}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  min-height:48px;padding:0 26px;border-radius:999px;
  font-family:var(--font-head);font-weight:700;font-size:1.02rem;
  cursor:pointer;border:none;transition:transform .18s ease,box-shadow .18s ease;
}
.btn-primary{background:var(--acai);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.btn-ghost{background:var(--lime-soft);color:var(--acai-deep);border:2px solid var(--lime)}
.btn-ghost:hover{transform:translateY(-2px);background:var(--lime)}

/* Header */
.site-header{
  position:sticky;top:0;z-index:90;
  background:rgba(255,249,242,.9);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(123,63,176,.08);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;min-height:64px;gap:12px}
.logo{display:flex;align-items:center;gap:10px;color:var(--ink)}
.logo-mark{display:flex;flex:0 0 auto}
.logo-text{font-family:var(--font-head);font-weight:800;font-size:1.12rem;line-height:1;display:flex;flex-direction:column}
.logo-sub{font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--acai);font-weight:700;margin-top:3px}
.main-nav{display:none;align-items:center;gap:6px}
.main-nav a{
  padding:10px 14px;border-radius:999px;color:var(--ink-soft);font-weight:700;min-height:44px;display:inline-flex;align-items:center;
}
.main-nav a:hover{color:var(--acai);background:var(--lime-soft)}
.main-nav .nav-cta{background:var(--acai);color:#fff}
.main-nav .nav-cta:hover{background:var(--acai-bright);color:#fff}

/* HERO */
.hero{position:relative;overflow:hidden;padding:48px 0 60px;
  background:radial-gradient(120% 90% at 80% 0%,#f4e8ff 0%,var(--cream) 60%);}
.hero-inner{position:relative;z-index:3;max-width:640px}
.eyebrow{font-weight:800;color:var(--acai);text-transform:uppercase;letter-spacing:.08em;font-size:.78rem;margin:0 0 14px;display:flex;align-items:center;gap:8px}
.flag{font-size:1.1rem}
.hero h1{font-size:clamp(2.6rem,11vw,4.6rem);font-weight:800;letter-spacing:-.01em}
.grad-text{background:linear-gradient(100deg,var(--lime-deep),var(--leaf) 50%,var(--acai));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-lede{font-size:1.12rem;color:var(--ink-soft);max-width:30ch;margin:.4em 0 1.4em;font-weight:600}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px}
.hero-note{margin-top:20px;font-size:.92rem;color:var(--ink-soft)}
.hero-note strong{color:var(--acai-deep)}

/* blobs */
.hero-blobs .blob{position:absolute;border-radius:50%;filter:blur(8px);opacity:.5;z-index:1}
.blob-1{width:240px;height:240px;background:var(--lime);top:-60px;right:-40px;opacity:.35}
.blob-2{width:180px;height:180px;background:var(--berry-pink);bottom:40px;left:-50px;opacity:.28}
.blob-3{width:140px;height:140px;background:var(--mango);top:140px;right:30%;opacity:.22}

/* floating fruit */
.fruit-field{position:absolute;inset:0;z-index:2;pointer-events:none}
.fruit{position:absolute;filter:drop-shadow(0 8px 14px rgba(66,23,95,.18))}
.fruit-a{top:8%;right:6%}
.fruit-b{top:46%;right:14%}
.fruit-c{bottom:14%;right:30%}
.fruit-d{top:24%;right:38%}

/* hero bowl */
.hero-bowl-wrap{position:relative;z-index:3;display:flex;justify-content:center;margin-top:18px}
.hero-bowl{max-width:280px;width:80%;height:auto}

/* Sections */
.section{padding:64px 0}
.section-head{text-align:center;max-width:620px;margin:0 auto 40px}
.kicker{font-family:var(--font-head);font-weight:700;color:var(--lime-deep);text-transform:uppercase;letter-spacing:.12em;font-size:.8rem;margin:0 0 8px}
.section h2{font-size:clamp(2rem,7vw,2.9rem);font-weight:800}
.section-sub{color:var(--ink-soft);font-size:1.04rem;font-weight:600}

/* MENU */
.section-menu{background:linear-gradient(180deg,var(--cream),#faf3ff)}
.menu-grid{display:grid;grid-template-columns:1fr;gap:20px}
.menu-card{
  background:var(--white);border-radius:var(--radius);padding:26px;
  box-shadow:var(--shadow-sm);border:2px solid #f2e8fa;
  transition:transform .2s ease,box-shadow .2s ease;
}
.menu-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.menu-card-top{display:flex;align-items:center;gap:12px;margin-bottom:8px}
.menu-emoji{font-size:1.8rem;width:54px;height:54px;display:flex;align-items:center;justify-content:center;background:var(--lime-soft);border-radius:50%}
.menu-card h3{margin:0;font-size:1.4rem}
.menu-card p{color:var(--ink-soft);margin:.2em 0 1em;font-weight:600}
.menu-list{list-style:none;margin:0;padding:0}
.menu-list li{display:flex;flex-direction:column;padding:10px 0;border-top:1px dashed #ecdef7;font-weight:700}
.menu-list li span{font-weight:600;color:var(--ink-soft);font-size:.88rem}
.menu-card-addons{background:linear-gradient(140deg,var(--acai),var(--acai-bright));color:#fff;border-color:transparent}
.menu-card-addons h3,.menu-card-addons p{color:#fff}
.menu-card-addons .menu-emoji{background:rgba(255,255,255,.2)}
.addon-chips{list-style:none;margin:8px 0 0;padding:0;display:flex;flex-wrap:wrap;gap:8px}
.addon-chips li{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.35);padding:6px 12px;border-radius:999px;font-weight:700;font-size:.86rem}
.menu-foot{text-align:center;color:var(--ink-soft);font-size:.9rem;margin-top:24px;font-weight:600}

/* ABOUT */
.section-about{background:var(--white)}
.about-grid{display:grid;grid-template-columns:1fr;gap:30px;align-items:center}
.about-art{max-width:280px;margin:0 auto}
.about-copy .kicker{color:var(--lime-deep)}
.about-copy p{color:var(--ink-soft);font-weight:600;font-size:1.05rem}
.about-points{list-style:none;margin:18px 0 0;padding:0;display:flex;flex-direction:column;gap:10px}
.about-points li{padding:12px 16px;background:var(--lime-soft);border-radius:16px;font-weight:700;color:var(--acai-deep)}

/* LOCATION */
.section-location{background:linear-gradient(180deg,#faf3ff,var(--cream))}
.loc-grid{display:grid;grid-template-columns:1fr;gap:28px}
.loc-address{font-style:normal;font-size:1.1rem;font-weight:600;margin:6px 0 14px;color:var(--ink)}
.loc-note{color:var(--ink-soft);font-weight:600;font-size:.95rem}
.hours-table{width:100%;border-collapse:collapse;margin:18px 0 22px;background:var(--white);border-radius:18px;overflow:hidden;box-shadow:var(--shadow-sm)}
.hours-table th,.hours-table td{padding:14px 18px;text-align:left}
.hours-table th{font-family:var(--font-head);color:var(--acai-deep)}
.hours-table td{text-align:right;font-weight:700;color:var(--ink-soft)}
.hours-table tr+tr th,.hours-table tr+tr td{border-top:1px solid #f0e6fa}
.loc-map svg{border-radius:24px;box-shadow:var(--shadow-sm)}

/* REVIEWS */
.section-reviews{background:var(--white)}
.reviews-grid{display:grid;grid-template-columns:1fr;gap:18px}
.review-card{background:var(--cream);border-radius:var(--radius);padding:24px;border:2px solid #f2e8fa;box-shadow:var(--shadow-sm)}
.stars{color:var(--mango);font-size:1.2rem;letter-spacing:2px}
.review-card p{color:var(--ink-soft);font-weight:600;margin:.6em 0}
.review-by{font-size:.82rem;font-weight:800;color:var(--acai);text-transform:uppercase;letter-spacing:.06em}
.reviews-foot{text-align:center;color:var(--ink-soft);font-size:.85rem;margin-top:22px;font-weight:600}

/* CONTACT */
.section-contact{background:linear-gradient(180deg,var(--cream),#f4e8ff)}
.contact-card{
  background:var(--white);border-radius:var(--radius-lg);padding:34px 28px;
  box-shadow:var(--shadow);display:grid;grid-template-columns:1fr;gap:20px;align-items:center;
  border:2px solid #f2e8fa;
}
.contact-copy p{color:var(--ink-soft);font-weight:600}
.contact-list{list-style:none;margin:18px 0;padding:0;display:flex;flex-direction:column;gap:12px}
.contact-list li{display:flex;align-items:center;gap:12px;font-weight:700}
.ci{width:42px;height:42px;flex:0 0 auto;display:flex;align-items:center;justify-content:center;background:var(--lime-soft);border-radius:50%;font-size:1.1rem}
.phone-placeholder{color:var(--ink-soft);font-style:italic;font-weight:600}
.social-row{display:flex;gap:14px;margin-top:6px}
.social-row a{font-weight:800;color:var(--acai);padding:8px 0}
.contact-art{display:flex;justify-content:center;order:-1}

/* Footer */
.site-footer{background:var(--acai-deep);color:#f3e9fb;padding:40px 0 96px}
.footer-inner{text-align:center}
.footer-brand{font-family:var(--font-head);font-weight:800;font-size:1.3rem;color:#fff;margin:0 0 6px}
.footer-meta{margin:0 0 10px;opacity:.85}
.footer-fine{font-size:.82rem;opacity:.6;margin:0}

/* Sticky mobile CTA */
.sticky-cta{
  position:fixed;left:0;right:0;bottom:0;z-index:95;
  display:flex;gap:10px;padding:10px 14px;
  background:rgba(255,249,242,.96);backdrop-filter:blur(10px);
  border-top:1px solid rgba(123,63,176,.1);
  box-shadow:0 -8px 24px -12px rgba(66,23,95,.3);
}
.scta{flex:1;min-height:50px;display:flex;align-items:center;justify-content:center;border-radius:999px;font-family:var(--font-head);font-weight:800;font-size:1.05rem}
.scta-order{background:var(--acai);color:#fff}
.scta-visit{background:var(--lime);color:var(--acai-deep)}

/* ===== Motion ===== */
@keyframes floaty{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-14px) rotate(6deg)}}
.fruit-a{animation:floaty 6s ease-in-out infinite}
.fruit-b{animation:floaty 7.5s ease-in-out infinite .6s}
.fruit-c{animation:floaty 6.8s ease-in-out infinite 1.1s}
.fruit-d{animation:floaty 8s ease-in-out infinite .3s}

@keyframes pinDrop{0%{transform:translateY(-16px)}50%{transform:translateY(0)}100%{transform:translateY(-16px)}}
.map-pin{animation:pinDrop 3s ease-in-out infinite;transform-origin:center}

/* bowl fill + toppings (JS-driven via .is-filled; CSS fallback below) */
.acai-fill{transform:translateY(100px)}
.top{opacity:0;transform:translateY(-30px)}
.is-filled .acai-fill{transition:transform 1s cubic-bezier(.22,1,.36,1);transform:translateY(0)}
.is-filled .top{transition:opacity .5s ease,transform .6s cubic-bezier(.34,1.56,.64,1)}
.is-filled .top{opacity:1;transform:translateY(0)}
.is-filled .t1{transition-delay:.7s}
.is-filled .t2{transition-delay:.85s}
.is-filled .t3{transition-delay:1s}
.is-filled .t4{transition-delay:1.15s}
.is-filled .t5{transition-delay:1.3s}
.is-filled .t6{transition-delay:1.45s}

/* reveal */
.reveal{opacity:0;transform:translateY(28px)}
.reveal.in{opacity:1;transform:translateY(0);transition:opacity .7s ease,transform .7s cubic-bezier(.22,1,.36,1)}

/* Desktop */
@media (min-width:760px){
  .main-nav{display:flex}
  .sticky-cta{display:none}
  .site-footer{padding-bottom:40px}
  .hero{padding:72px 0 80px}
  .hero-inner{max-width:560px}
  .menu-grid{grid-template-columns:repeat(2,1fr);gap:24px}
  .about-grid{grid-template-columns:300px 1fr;gap:48px}
  .about-art{margin:0}
  .loc-grid{grid-template-columns:1fr 1fr;gap:40px;align-items:start}
  .reviews-grid{grid-template-columns:repeat(3,1fr)}
  .contact-card{grid-template-columns:1fr 200px;padding:48px}
  .contact-art{order:0}
  .hero-bowl-wrap{position:absolute;right:4%;top:90px;margin:0;width:320px}
  .hero-bowl{width:320px;max-width:none}
}

@media (min-width:1040px){
  .hero h1{font-size:4.8rem}
  .hero-bowl{width:360px}
  .hero-bowl-wrap{width:360px;top:80px}
}

/* Reduced motion */
@media (prefers-reduced-motion:reduce){
  *{animation:none !important;scroll-behavior:auto !important}
  .acai-fill{transform:translateY(0)}
  .top{opacity:1;transform:none}
  .reveal{opacity:1;transform:none}
  html{scroll-behavior:auto}
}
