/* ===== Paletas AZ — PLAYFUL BRIGHT POPSICLE ===== */
:root{
  --cream:#FFF7EC;
  --cream-2:#FFFCF6;
  --ink:#3A2A1E;          /* warm dark brown text — AA on cream */
  --ink-soft:#6A5848;
  --mango:#FF8A00;
  --mango-d:#E96E00;
  --straw:#FF477E;
  --straw-d:#E22E66;
  --lime:#5DCB4E;
  --lime-d:#3FA635;
  --tang:#FF6B35;
  --tang-d:#D8420F;       /* deep tangerine — AA text on cream */
  --white:#fff;
  --shadow:0 10px 30px rgba(58,42,30,.12);
  --shadow-sm:0 4px 14px rgba(58,42,30,.10);
  --r-lg:26px;
  --r-md:18px;
  --r-pill:999px;
  --maxw:1120px;
  --font: "Trebuchet MS", "Segoe UI", system-ui, -apple-system, "Helvetica Neue", Arial, sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}}
body{
  margin:0;
  font-family:var(--font);
  color:var(--ink);
  background:var(--cream);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,svg{max-width:100%}
a{color:var(--tang-d)}

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

.skip-link{
  position:absolute;left:-999px;top:0;background:var(--ink);color:#fff;
  padding:12px 18px;border-radius:0 0 12px 0;z-index:999;font-weight:700;
}
.skip-link:focus{left:0}

:focus-visible{outline:3px solid var(--straw-d);outline-offset:3px;border-radius:6px}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  min-height:48px;padding:13px 22px;border-radius:var(--r-pill);
  font-weight:800;font-size:1rem;text-decoration:none;cursor:pointer;
  border:3px solid transparent;transition:transform .15s ease, box-shadow .15s ease;
  line-height:1.1;text-align:center;
}
.btn-primary{background:var(--tang);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--tang-d);transform:translateY(-2px)}
.btn-ghost{background:#fff;color:var(--tang-d);border-color:var(--tang)}
.btn-ghost:hover{background:#fff;transform:translateY(-2px);border-color:var(--tang-d)}
@media (prefers-reduced-motion: reduce){.btn:hover{transform:none}}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:100;background:rgba(255,247,236,.92);
  backdrop-filter:saturate(140%) blur(8px);
  border-bottom:3px solid #FFE3C2;transition:box-shadow .2s ease;
}
.site-header.scrolled{box-shadow:0 6px 20px rgba(58,42,30,.10)}
.header-inner{display:flex;align-items:center;justify-content:space-between;min-height:64px}
.logo{display:inline-flex;align-items:center;gap:10px;text-decoration:none}
.logo-pop{display:inline-flex}
.logo-text{font-size:1.45rem;font-weight:900;color:var(--straw-d);letter-spacing:-.5px}
.logo-az{color:var(--lime-d);margin-left:2px}
.main-nav{display:none}
.main-nav a{
  text-decoration:none;color:var(--ink);font-weight:700;font-size:1rem;
  padding:8px 6px;border-radius:10px;
}
.main-nav a:hover{color:var(--straw-d)}
.main-nav .nav-cta{
  background:var(--lime);color:#173d11;padding:10px 18px;border-radius:var(--r-pill);
  min-height:44px;display:inline-flex;align-items:center;
}
.main-nav .nav-cta:hover{background:var(--lime-d);color:#fff}

@media(min-width:820px){
  .main-nav{display:flex;align-items:center;gap:6px}
}

/* ---------- Hero ---------- */
.hero{position:relative;background:
  radial-gradient(1200px 500px at 85% -10%, #FFE9C9 0%, transparent 60%),
  radial-gradient(900px 500px at 0% 0%, #FFE0EC 0%, transparent 55%),
  var(--cream);
  padding:46px 0 10px;overflow:hidden}
.hero-inner{display:grid;grid-template-columns:1fr;gap:26px;align-items:center;padding-bottom:50px}
.eyebrow{
  display:inline-block;font-weight:800;color:var(--lime-d);text-transform:uppercase;
  letter-spacing:.6px;font-size:.78rem;margin:0 0 10px;
}
.eyebrow.center{display:block;text-align:center}
.hero h1{
  font-size:clamp(2.1rem,8vw,3.5rem);line-height:1.05;margin:0 0 16px;
  font-weight:900;letter-spacing:-1px;color:var(--ink);
}
.hl{padding:0 .12em;border-radius:8px;color:#fff;white-space:nowrap}
.hl-mango{background:var(--mango-d)}
.hl-lime{background:var(--lime-d)}
.hl-straw{background:var(--straw-d)}
.hero-sub{font-size:1.1rem;color:var(--ink-soft);max-width:36ch;margin:0 0 22px}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px}
.hero-actions .btn{flex:1 1 auto;min-width:200px}
.hero-meta{font-size:.9rem;color:var(--ink-soft);margin:6px 0 0}

.hero-art{position:relative;display:flex;justify-content:center;align-items:flex-end;gap:8px;min-height:200px}
.pop{filter:drop-shadow(0 12px 14px rgba(58,42,30,.18))}
.pop1{transform:rotate(-8deg)}
.pop2{transform:translateY(-18px) rotate(2deg)}
.pop3{transform:rotate(9deg)}
.drip{position:absolute;border-radius:50%;opacity:.9}
.drip-mango{width:18px;height:18px;background:var(--mango);left:24%;bottom:6px}
.drip-straw{width:13px;height:13px;background:var(--straw);left:50%;bottom:0}
.drip-lime{width:15px;height:15px;background:var(--lime);left:72%;bottom:10px}

.wave-divider{position:absolute;left:0;right:0;bottom:-1px;line-height:0}
.wave-divider svg{width:100%;height:50px;display:block}

@media(min-width:820px){
  .hero{padding:64px 0 10px}
  .hero-inner{grid-template-columns:1.05fr .95fr;gap:40px}
  .hero-actions .btn{flex:0 0 auto}
  .hero-art{min-height:320px}
  .pop svg{width:84px;height:168px}
}

/* ---------- Sections ---------- */
.section{padding:56px 0}
.section-title{
  font-size:clamp(1.7rem,5.5vw,2.6rem);font-weight:900;letter-spacing:-.6px;
  margin:0 0 14px;color:var(--ink);line-height:1.1;
}
.section-title.center{text-align:center}
.section-lead{font-size:1.05rem;color:var(--ink-soft);max-width:60ch;margin:0 0 30px}
.section-lead.center{margin-left:auto;margin-right:auto;text-align:center}
.muted{color:var(--ink-soft);font-style:italic}
.center{text-align:center}

/* ---------- Menu ---------- */
.menu{background:linear-gradient(180deg,#fff 0%, #FFFBF4 100%)}
.menu-grid{display:grid;grid-template-columns:1fr;gap:18px}
.menu-card{
  background:#fff;border-radius:var(--r-lg);padding:24px 22px;
  border:3px solid #FFEAD3;box-shadow:var(--shadow-sm);
  border-top:8px solid var(--accent);position:relative;
  transition:transform .18s ease, box-shadow .18s ease;
}
.menu-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
@media (prefers-reduced-motion: reduce){.menu-card:hover{transform:none}}
.menu-icon{margin-bottom:8px;min-height:52px;display:flex;align-items:flex-end}
.menu-card h3{font-size:1.35rem;font-weight:900;margin:6px 0 2px;color:var(--ink)}
.menu-card .es{font-size:.86rem;font-weight:700;color:var(--accent);margin:0 0 10px;
  filter:saturate(1.1) brightness(.85)}
.menu-card p{margin:0;color:var(--ink-soft);font-size:.98rem}
.menu-note{text-align:center;margin:30px auto 0;color:var(--ink-soft);max-width:54ch}
.menu-note strong{color:var(--straw-d)}

@media(min-width:640px){.menu-grid{grid-template-columns:1fr 1fr}}
@media(min-width:980px){.menu-grid{grid-template-columns:repeat(3,1fr)}}

/* ---------- About ---------- */
.about{background:var(--cream)}
.about-inner{display:grid;grid-template-columns:1fr;gap:30px;align-items:center}
.about-art{display:flex;justify-content:center}
.badge-circle{filter:drop-shadow(0 14px 24px rgba(58,42,30,.16))}
.about-copy p{font-size:1.05rem;color:var(--ink-soft);margin:0 0 14px}
.about-copy strong{color:var(--ink)}
.about-tag{font-size:1.15rem !important;color:var(--ink) !important}
.about-tag strong{color:var(--straw-d)}
@media(min-width:820px){
  .about-inner{grid-template-columns:.8fr 1.2fr;gap:48px}
}

/* ---------- Location ---------- */
.location{background:linear-gradient(180deg,#FFFBF4 0%, #fff 100%)}
.location-inner{display:grid;grid-template-columns:1fr;gap:28px;align-items:center}
.address-line{font-size:1.15rem;color:var(--ink);margin:0 0 16px}
.hours-note{display:flex;align-items:flex-start;gap:10px;background:#FFF1DC;
  border:2px dashed var(--mango);border-radius:var(--r-md);padding:14px 16px;
  color:var(--ink);margin:0 0 20px}
.hours-note .dot{width:12px;height:12px;border-radius:50%;background:var(--lime);
  margin-top:6px;flex:0 0 auto;box-shadow:0 0 0 4px rgba(93,203,78,.25)}
.location-actions{display:flex;flex-wrap:wrap;gap:12px}
.location-actions .btn{flex:1 1 auto;min-width:180px}
.map-card{display:block;position:relative;border-radius:var(--r-lg);overflow:hidden;
  border:3px solid #FFEAD3;box-shadow:var(--shadow-sm);height:240px;text-decoration:none}
.map-art{position:absolute;inset:0}
.map-pill{position:absolute;left:50%;bottom:16px;transform:translateX(-50%);
  background:var(--straw-d);color:#fff;font-weight:800;padding:10px 18px;
  border-radius:var(--r-pill);box-shadow:var(--shadow-sm);font-size:.95rem;white-space:nowrap}
@media(min-width:820px){.location-inner{grid-template-columns:1fr 1fr;gap:44px}}

/* ---------- Reviews ---------- */
.reviews{background:
  radial-gradient(800px 400px at 100% 0, #FFE0EC 0, transparent 55%),
  radial-gradient(700px 400px at 0 100%, #E7F7E1 0, transparent 55%),
  var(--cream)}
.review-grid{display:grid;grid-template-columns:1fr;gap:18px}
.review-card{background:#fff;border-radius:var(--r-lg);padding:26px 22px;
  border:3px solid #FFEAD3;box-shadow:var(--shadow-sm);text-align:center}
.rev-emoji{font-size:2.4rem;line-height:1;margin-bottom:10px}
.review-card h3{font-size:1.25rem;font-weight:900;margin:0 0 8px;color:var(--ink)}
.review-card p{margin:0;color:var(--ink-soft)}
.reviews-disclaimer{text-align:center;margin:26px auto 0;max-width:54ch;
  color:var(--ink-soft);font-size:.92rem;font-style:italic}
@media(min-width:760px){.review-grid{grid-template-columns:repeat(3,1fr)}}

/* ---------- Contact ---------- */
.contact{background:var(--tang);color:#fff;padding:60px 0}
.contact .section-title,.contact .section-lead{color:#fff}
.contact .section-lead{opacity:.95}
.contact-cards{display:grid;grid-template-columns:1fr;gap:16px;margin-top:8px;max-width:820px;margin-left:auto;margin-right:auto}
.contact-card{display:flex;flex-direction:column;align-items:center;gap:4px;
  background:rgba(255,255,255,.14);border:2px solid rgba(255,255,255,.4);
  border-radius:var(--r-lg);padding:24px 18px;text-decoration:none;color:#fff;
  min-height:44px;transition:transform .15s ease, background .15s ease}
.contact-card:hover{background:rgba(255,255,255,.22);transform:translateY(-3px)}
@media (prefers-reduced-motion: reduce){.contact-card:hover{transform:none}}
.cc-icon{font-size:2rem}
.cc-label{font-weight:800;text-transform:uppercase;letter-spacing:.5px;font-size:.8rem;opacity:.9}
.cc-value{font-weight:800;font-size:1.1rem}
@media(min-width:760px){.contact-cards{grid-template-columns:repeat(3,1fr)}}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:#FCEFE0;padding:34px 0}
.footer-inner{text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px}
.footer-logo .logo-text{color:#fff}
.footer-logo .logo-az{color:var(--lime)}
.footer-nap{margin:0;font-weight:600}
.footer-nap a{color:#FFD9A0}
.footer-fine{margin:0;font-size:.88rem;opacity:.78}

/* ---------- Sticky mobile CTA ---------- */
.sticky-cta{
  position:fixed;left:0;right:0;bottom:0;z-index:120;display:flex;gap:8px;
  padding:9px 10px;background:rgba(255,247,236,.97);
  border-top:3px solid #FFE3C2;box-shadow:0 -6px 18px rgba(58,42,30,.12);
}
.scta{flex:1;display:flex;align-items:center;justify-content:center;
  min-height:48px;border-radius:var(--r-pill);font-weight:900;text-decoration:none;
  font-size:.98rem;padding:8px 6px}
.scta-call{background:var(--tang);color:#fff}
.scta-visit{background:var(--lime);color:#173d11}
body{padding-bottom:74px}
@media(min-width:820px){
  .sticky-cta{display:none}
  body{padding-bottom:0}
}

/* ---------- Reveal animation (JS-driven, reduced-motion safe) ---------- */
.reveal{opacity:0;transform:translateY(22px)}
.reveal.in{opacity:1;transform:none;transition:opacity .55s ease, transform .55s cubic-bezier(.22,1.3,.5,1)}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1 !important;transform:none !important;transition:none !important}
}

/* ---------- Hero entrance (CSS fallback if GSAP absent) ---------- */
.no-gsap .pop{animation:popDrop .8s cubic-bezier(.22,1.3,.5,1) both}
.no-gsap .pop2{animation-delay:.12s}
.no-gsap .pop3{animation-delay:.24s}
.no-gsap .drip{animation:dripFall 1.1s ease-in both}
.no-gsap .drip-straw{animation-delay:.2s}
.no-gsap .drip-lime{animation-delay:.35s}
@keyframes popDrop{0%{opacity:0;transform:translateY(-60px) rotate(-12deg)}100%{opacity:1}}
@keyframes dripFall{0%{opacity:0;transform:translateY(-30px) scale(.4)}60%{opacity:1}100%{opacity:.9;transform:translateY(0) scale(1)}}
@media (prefers-reduced-motion: reduce){
  .no-gsap .pop,.no-gsap .drip{animation:none}
}
