/* ============================================================
   DONDE PAPI — Santa Teresa beach landing page
   Hand-made, tropical, Pura Vida.
   ============================================================ */

:root{
  /* surfaces */
  --sand:      #EFE3C8;   /* page background, warm sand */
  --sand-soft: #F6EDD8;   /* lighter panels */
  --sand-deep: #E5D5B2;   /* deeper sand */
  --cream:     #FBF6EA;   /* coconut white */
  --ink:       #16110B;   /* warm chalkboard black */
  --ink-soft:  #221B12;   /* card on black */
  --ink-line:  #3a3022;

  /* brand */
  --gold:      #F2B01A;   /* pineapple gold */
  --gold-deep: #DD9412;
  --green:     #3E7D31;   /* palm green */
  --green-deep:#2C5E23;
  --ocean:     #2C7C9E;   /* ocean blue */
  --orange:    #E2622E;   /* sunset orange */

  /* text */
  --text:      #2A2015;   /* warm near-black on sand */
  --text-soft: #6A5A45;   /* muted on sand */
  --on-dark:   #F4ECDC;   /* text on chalkboard */
  --on-dark-soft:#C7B79C;

  --display: 'Permanent Marker', 'Comic Sans MS', cursive;
  --body: 'Nunito', system-ui, -apple-system, sans-serif;

  --wrap: 1180px;
  --radius: 18px;
  --shadow: 0 22px 50px -24px rgba(40,28,12,.45);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--body);
  background:var(--sand);
  color:var(--text);
  font-size:18px;
  line-height:1.62;
  font-weight:500;
  overflow-x:hidden;
  /* subtle paper grain */
  background-image:
    radial-gradient(rgba(120,90,40,.05) 1px, transparent 1px);
  background-size:4px 4px;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }

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

/* ---- type helpers ---- */
.kicker{
  font-family:var(--body);
  font-weight:800;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-size:.82rem;
  color:var(--orange);
}
.display{ font-family:var(--display); font-weight:400; line-height:.96; letter-spacing:.01em; }

.section{ padding:clamp(64px,9vw,128px) 0; position:relative; }
.section--dark{ background:var(--ink); color:var(--on-dark); }
.section--dark .kicker{ color:var(--gold); }

.sec-head{ text-align:center; max-width:760px; margin:0 auto clamp(40px,6vw,68px); }
.sec-head h2{
  font-family:var(--display);
  font-weight:400;
  font-size:clamp(2.6rem,7.5vw,4.8rem);
  line-height:.96;
  margin:.18em 0 .12em;
  color:var(--text);
}
.section--dark .sec-head h2{ color:var(--cream); }
.sec-head p{ font-size:1.18rem; color:var(--text-soft); margin:0; }
.section--dark .sec-head p{ color:var(--on-dark-soft); }
.sec-head .gold{ color:var(--gold-deep); }
.section--dark .sec-head .gold{ color:var(--gold); }

/* ---- buttons ---- */
.btn{
  display:inline-flex; align-items:center; gap:.55em;
  font-family:var(--body); font-weight:800;
  font-size:1.02rem; letter-spacing:.01em;
  padding:.85em 1.5em; border-radius:999px;
  border:2.5px solid transparent; cursor:pointer;
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease;
  white-space:nowrap;
}
.btn svg{ width:1.15em; height:1.15em; }
.btn--gold{ background:var(--gold); color:#3a2a05; box-shadow:0 12px 22px -10px rgba(221,148,18,.8); }
.btn--gold:hover{ transform:translateY(-2px) rotate(-.6deg); box-shadow:0 16px 28px -10px rgba(221,148,18,.9); }
.btn--green{ background:var(--green); color:#fff; box-shadow:0 12px 22px -12px rgba(44,94,35,.9); }
.btn--green:hover{ transform:translateY(-2px) rotate(.6deg); }
.btn--ghost{ background:transparent; border-color:currentColor; color:var(--cream); }
.btn--ghost:hover{ background:rgba(255,255,255,.12); transform:translateY(-2px); }
.btn--lg{ font-size:1.12rem; padding:1em 1.8em; }

/* =========================================================
   HEADER
   ========================================================= */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:60;
  transition:background .3s ease, box-shadow .3s ease, padding .3s ease;
  padding:18px 0;
}
.site-header.scrolled{
  background:rgba(239,227,200,.94);
  backdrop-filter:blur(10px);
  box-shadow:0 8px 24px -16px rgba(40,28,12,.5);
  padding:10px 0;
}
.nav{ display:flex; align-items:center; justify-content:space-between; gap:18px; }
.brand{
  font-family:var(--display); font-size:1.6rem; color:var(--gold);
  display:flex; align-items:center; gap:.35em; line-height:1;
  text-shadow:0 2px 0 rgba(0,0,0,.18);
}
.scrolled .brand{ text-shadow:none; }
.brand .pine{ font-size:1.5rem; filter:saturate(1.1); }
.nav-links{ display:flex; gap:30px; align-items:center; }
.nav-links a{
  font-weight:800; font-size:.96rem; letter-spacing:.02em; white-space:nowrap;
  color:var(--cream); position:relative; padding:4px 0;
  text-shadow:0 1px 6px rgba(0,0,0,.45);
}
.scrolled .nav-links a{ color:var(--text); text-shadow:none; }
.nav-links a::after{
  content:""; position:absolute; left:0; right:100%; bottom:-2px; height:3px;
  background:var(--gold); border-radius:2px; transition:right .25s ease;
}
.nav-links a:hover::after{ right:0; }
.nav-actions{ display:flex; align-items:center; gap:12px; }
.menu-toggle{
  display:none; background:none; border:0; cursor:pointer; padding:6px;
  color:var(--cream); 
}
.scrolled .menu-toggle{ color:var(--text); }
.menu-toggle svg{ width:30px; height:30px; }

/* mobile dropdown */
.mobile-menu{
  display:none; position:absolute; top:100%; left:0; right:0;
  background:var(--ink); padding:10px 24px 22px;
  flex-direction:column; gap:4px;
}
.mobile-menu.open{ display:flex; }
.mobile-menu a{ color:var(--cream); font-weight:800; font-size:1.1rem; padding:12px 4px; border-bottom:1px solid rgba(255,255,255,.08); }

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative; min-height:100svh; display:flex; align-items:center;
  background:#1a1206;
  overflow:hidden;
}
.hero__img{
  position:absolute; inset:0;
  background:url('assets/cart.jpg') center 42%/cover no-repeat;
}
.hero__scrim{
  position:absolute; inset:0;
  background:
    linear-gradient(102deg, rgba(12,8,3,.86) 0%, rgba(12,8,3,.55) 40%, rgba(12,8,3,.08) 68%, rgba(12,8,3,0) 100%),
    linear-gradient(to top, rgba(12,8,3,.7) 0%, rgba(12,8,3,0) 40%);
}
.hero__inner{ position:relative; z-index:2; padding-top:90px; padding-bottom:48px; }
.hero__content{ max-width:660px; }
.hero h1{
  font-family:var(--display); color:var(--cream);
  font-size:clamp(3.6rem,15vw,9.2rem); line-height:.86; margin:.1em 0 0;
  text-shadow:0 6px 22px rgba(0,0,0,.4);
}
.hero h1 .pop{ color:var(--gold); display:block; transform:rotate(-2deg); transform-origin:left; }
.hero__sub{
  font-size:clamp(1.15rem,2.6vw,1.5rem); color:#f3e9d6; font-weight:700;
  max-width:30ch; margin:1.3rem 0 2rem; line-height:1.4;
  text-shadow:0 2px 10px rgba(0,0,0,.55);
}
.hero__cta{ display:flex; gap:14px; flex-wrap:wrap; }
.hero__scroll{
  position:absolute; left:50%; bottom:26px; transform:translateX(-50%); z-index:2;
  color:#f3e9d6; font-weight:800; font-size:.8rem; letter-spacing:.2em; text-transform:uppercase;
  display:flex; flex-direction:column; align-items:center; gap:6px; opacity:.85;
}
.hero__scroll span{ animation:bob 1.8s ease-in-out infinite; }
@keyframes bob{ 50%{ transform:translateY(7px); } }

/* =========================================================
   THIS IS PAPI
   ========================================================= */
.papi{ background:var(--sand); }
.papi__grid{
  display:grid; grid-template-columns:0.9fr 1.1fr; gap:clamp(36px,6vw,82px);
  align-items:center; max-width:1120px; margin:0 auto;
}
.papi__photo{ position:relative; }
.polaroid{
  background:#fff; padding:14px 14px 56px; border-radius:6px;
  box-shadow:var(--shadow); transform:rotate(-3deg);
  position:relative;
}
.polaroid img{ width:100%; border-radius:3px; aspect-ratio:4/5; object-fit:cover; object-position:center 20%; }
.photo-ph{
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:6px;
  width:100%; aspect-ratio:4/5; border-radius:3px; text-align:center; padding:18px;
  border:2px dashed #b6a079; color:#8c7850;
  background:repeating-linear-gradient(45deg,#e9d9b8,#e9d9b8 11px,#e2d1ab 11px,#e2d1ab 22px);
}
.photo-ph .pine{ font-size:2.2rem; filter:grayscale(.2) opacity(.8); }
.photo-ph b{ font-family:'Courier New',monospace; font-weight:700; letter-spacing:.12em; font-size:.92rem; text-transform:uppercase; }
.photo-ph small{ font-family:'Courier New',monospace; font-size:.74rem; letter-spacing:.04em; opacity:.85; }
.polaroid figcaption{
  position:absolute; left:0; right:0; bottom:16px; text-align:center;
  font-family:var(--display); color:#7a6a52; font-size:1.3rem;
}
.tape{
  position:absolute; top:-16px; left:50%; transform:translateX(-50%) rotate(-4deg);
  width:120px; height:34px; background:rgba(242,176,26,.55);
  box-shadow:0 2px 6px rgba(0,0,0,.12); 
}
.papi__body h2{
  font-family:var(--display); font-size:clamp(2.4rem,5.6vw,3.9rem);
  line-height:1.04; margin:.15em 0 .55em; color:var(--text);
}
.papi__body p{ margin:0 0 1.1em; max-width:46ch; }
.papi__body .pura{
  font-family:var(--display); color:var(--green); font-size:clamp(1.8rem,4vw,2.6rem);
  margin-top:.4em; transform:rotate(-1.5deg); display:inline-block;
}
.stamp{
  position:absolute; top:-30px; right:-18px; width:138px; height:138px;
  color:var(--green); opacity:.9; transform:rotate(8deg);
  animation:spin 40s linear infinite;
}
@keyframes spin{ to{ transform:rotate(368deg); } }
.stamp .pine-c{ font-size:34px; }

/* =========================================================
   OUR DRINKS
   ========================================================= */
.drinks__grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:26px; max-width:1120px; margin:0 auto;
}
.drink{
  background:var(--ink-soft); border-radius:var(--radius); overflow:hidden;
  border:1px solid var(--ink-line); transition:transform .2s ease, box-shadow .2s ease;
}
.drink:hover{ transform:translateY(-6px); box-shadow:0 26px 44px -26px rgba(0,0,0,.7); }
.drink__img{ aspect-ratio:5/4; overflow:hidden; }
.drink__img img{ width:100%; height:100%; object-fit:cover; transition:transform .4s ease; }
.drink:hover .drink__img img{ transform:scale(1.05); }
.drink__body{ padding:22px 24px 28px; }
.drink__body h3{
  font-family:var(--display); color:var(--gold); font-size:1.9rem;
  margin:0 0 .35em; line-height:1; font-weight:400;
}
.drink__body p{ margin:0; color:var(--on-dark-soft); font-size:1.02rem; line-height:1.5; }
.drink__tag{
  display:inline-block; margin-top:14px; font-size:.78rem; font-weight:800; letter-spacing:.12em;
  text-transform:uppercase; color:var(--green); 
}
.drink__tag.alc{ color:var(--orange); }
.drinks__note{
  text-align:center; margin:40px auto 0; color:var(--on-dark-soft);
  font-family:var(--display); font-size:1.5rem; transform:rotate(-1deg);
}

/* =========================================================
   GALLERY — MORE THAN A DRINK
   ========================================================= */
.gallery{ background:var(--sand-soft); }
.collage{
  display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:170px; gap:14px;
  max-width:1120px; margin:0 auto;
}
.collage figure{
  margin:0; position:relative; overflow:hidden; border-radius:14px; box-shadow:var(--shadow);
}
.collage img{ width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.collage figure:hover img{ transform:scale(1.06); }
.collage figcaption{
  position:absolute; left:0; right:0; bottom:0; padding:24px 16px 12px;
  color:#fff; font-weight:700; font-size:.92rem;
  background:linear-gradient(to top, rgba(0,0,0,.6), transparent);
}
.g-rainbow{ grid-column:span 2; grid-row:span 2; }
.g-couple{ grid-row:span 2; }
.g-flag{ grid-row:span 2; }
.g-sunset{ grid-column:span 2; }

/* =========================================================
   FIND THE CART
   ========================================================= */
.find{ background:var(--sand); }
.find__features{
  display:flex; justify-content:center; gap:clamp(28px,6vw,72px); flex-wrap:wrap;
  margin:0 auto clamp(40px,5vw,56px); max-width:760px;
}
.feature{ text-align:center; max-width:160px; }
.feature svg{ width:42px; height:42px; color:var(--green); margin-bottom:8px; }
.feature b{ display:block; font-size:1rem; color:var(--text); }
.feature span{ font-size:.9rem; color:var(--text-soft); }

.find__grid{
  display:grid; grid-template-columns:1fr 1fr; gap:30px; align-items:stretch;
  max-width:1120px; margin:0 auto;
}
.find__photo{ border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); min-height:340px; }
.find__photo img{ width:100%; height:100%; object-fit:cover; }
.find__map{ display:flex; flex-direction:column; gap:18px; }
.map-frame{
  position:relative;
  flex:1; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow);
  border:6px solid #fff; min-height:300px; background:var(--sand-deep);
}
.map-frame iframe{ width:100%; height:100%; min-height:288px; border:0; display:block; }
.map-frame__pill{
  position:absolute; right:12px; bottom:12px; z-index:3; cursor:pointer;
  text-decoration:none; transition:transform .15s ease, box-shadow .15s ease;
  display:inline-flex; align-items:center; gap:6px; padding:8px 12px;
  background:var(--text); color:#fff; border-radius:999px;
  font-weight:800; font-size:.82rem; box-shadow:var(--shadow);
}
.map-frame__pill svg{ width:15px; height:15px; }
.map-frame__pill:hover{ transform:translateY(-2px); box-shadow:0 10px 22px rgba(0,0,0,.28); }
.find__loc{ font-weight:700; color:var(--text-soft); }
.find__loc b{ color:var(--text); }
.find__buttons{ display:flex; gap:14px; flex-wrap:wrap; }

/* =========================================================
   TESTIMONIALS + PAPI WALL
   ========================================================= */
.says__grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:22px; max-width:1120px;
  margin:0 auto clamp(56px,7vw,84px);
}
.quote{
  background:var(--ink-soft); border:1px solid var(--ink-line); border-radius:var(--radius);
  padding:28px 26px;
}
.stars{ color:var(--gold); letter-spacing:3px; font-size:1.1rem; margin-bottom:12px; }
.quote p{ font-size:1.22rem; color:var(--cream); margin:0 0 16px; line-height:1.4; font-weight:600; }
.quote cite{ color:var(--on-dark-soft); font-style:normal; font-weight:800; font-size:.95rem; }

.wall-head{ text-align:center; margin-bottom:26px; }
.wall-head h3{
  font-family:var(--display); color:var(--gold); font-size:2.2rem; margin:0 0 .1em; font-weight:400;
}
.wall-head span{ color:var(--on-dark-soft); font-weight:700; letter-spacing:.04em; }
.wall{
  display:grid; grid-template-columns:repeat(4,1fr); gap:14px; max-width:1120px; margin:0 auto;
}
.wall figure{ margin:0; border-radius:14px; overflow:hidden; aspect-ratio:1/1; box-shadow:0 18px 30px -22px rgba(0,0,0,.8); }
.wall img{ width:100%; height:100%; object-fit:cover; transition:transform .4s ease, filter .4s ease; filter:saturate(.96); }
.wall figure:hover img{ transform:scale(1.07); filter:saturate(1.1); }

/* =========================================================
   PURA VIDA BAND
   ========================================================= */
.purabanner{
  position:relative; min-height:62vh; display:flex; align-items:center; justify-content:center;
  text-align:center; background:url('assets/rainbow.jpg') center 60%/cover no-repeat fixed;
}
.purabanner__scrim{ position:absolute; inset:0; background:linear-gradient(to bottom, rgba(20,12,4,.25), rgba(20,12,4,.55)); }
.purabanner__inner{ position:relative; z-index:2; padding:60px 24px; width:100%; }
.purabanner h2{
  font-family:var(--display); color:#fff; font-size:clamp(2.8rem,9vw,5.6rem); line-height:1.05;
  margin:0; text-shadow:0 6px 26px rgba(0,0,0,.5);
}
.purabanner p{ color:#fbe6c9; font-weight:700; font-size:1.2rem; margin:1.2em 0 0; text-shadow:0 2px 12px rgba(0,0,0,.6); }

/* =========================================================
   FOOTER
   ========================================================= */
.footer{ background:var(--ink); color:var(--on-dark); padding:54px 0 38px; }
.footer__top{
  display:flex; justify-content:space-between; align-items:flex-start; gap:30px; flex-wrap:wrap;
  padding-bottom:30px; border-bottom:1px solid rgba(255,255,255,.1);
}
.footer .brand{ font-size:1.9rem; }
.footer__tag{ color:var(--on-dark-soft); margin:8px 0 0; max-width:30ch; }
.footer__cols{ display:flex; gap:clamp(34px,7vw,80px); flex-wrap:wrap; }
.footer__col h4{ font-family:var(--body); font-weight:800; letter-spacing:.14em; text-transform:uppercase; font-size:.78rem; color:var(--gold); margin:0 0 14px; }
.footer__col a, .footer__col p{ display:flex; align-items:center; gap:9px; color:var(--on-dark); margin:0 0 11px; font-weight:600; }
.footer__col a:hover{ color:var(--gold); }
.footer__col svg{ width:18px; height:18px; flex:none; }
.footer__bottom{ display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap; padding-top:26px; color:var(--on-dark-soft); font-size:.88rem; }

/* =========================================================
   SCROLL REVEAL
   ========================================================= */
@media (prefers-reduced-motion: no-preference){
  .reveal{ opacity:0; transform:translateY(28px); transition:opacity .7s ease, transform .7s ease; }
  .reveal.in{ opacity:1; transform:none; }
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:980px){
  .nav-links{ display:none; }
  .menu-toggle{ display:block; }
  .papi__grid{ grid-template-columns:1fr; gap:48px; }
  .papi__photo{ max-width:380px; margin:0 auto; }
  .stamp{ width:108px; height:108px; right:0; top:-22px; }
  .find__grid{ grid-template-columns:1fr; }
}
@media (max-width:760px){
  body{ font-size:17px; }
  .drinks__grid{ grid-template-columns:1fr; max-width:420px; }
  .says__grid{ grid-template-columns:1fr; max-width:480px; }
  .collage{ grid-template-columns:repeat(2,1fr); grid-auto-rows:140px; }
  .g-rainbow{ grid-column:span 2; grid-row:span 2; }
  .g-sunset{ grid-column:span 2; grid-row:span 1; }
  .g-couple,.g-flag{ grid-row:span 1; }
  .wall{ grid-template-columns:repeat(2,1fr); }
  .purabanner{ background-attachment:scroll; }
  .hero__cta .btn{ flex:1 1 auto; justify-content:center; }
}
@media (max-width:430px){
  .collage{ grid-template-columns:1fr 1fr; }
  .footer__top{ flex-direction:column; }
}
