/* ============================================================
   XIRINGUITO ALOHA — shared styles
   Palette drawn from the brand image: cream, warm sand,
   sky blue, espresso brown + a sunset-terracotta accent.
   ============================================================ */

:root{
  --cream:#F7F0E3;
  --cream-2:#FCF8EF;
  --paper:#FBF5E9;
  --sand:#E7D4AF;
  --sand-soft:#EFE2C6;
  --sand-deep:#C9A86B;
  --sky:#A6C3D5;
  --sky-soft:#CCE0EA;
  --sea:#6F9AAD;
  --espresso:#3A2317;
  --espresso-2:#5A3B28;
  --espresso-soft:#7a5c46;
  --terracotta:#C76F45;
  --terracotta-deep:#A8542F;
  --whatsapp:#25D366;

  --shadow-sm:0 2px 12px rgba(58,35,23,.08);
  --shadow-md:0 12px 40px rgba(58,35,23,.14);
  --shadow-lg:0 30px 80px rgba(58,35,23,.20);

  --serif:"Playfair Display",Georgia,serif;
  --sans:"Jost",system-ui,sans-serif;
  --script:"Kaushan Script",cursive;

  --maxw:1240px;
  --pad:clamp(20px,5vw,72px);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--espresso);
  background:var(--cream);
  font-size:18px;
  line-height:1.7;
  font-weight:300;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* ---------- type ---------- */
.display{font-family:var(--serif);font-weight:500;line-height:.95;letter-spacing:-.01em}
.script{font-family:var(--script);font-weight:400;line-height:1}
.eyebrow{
  font-family:var(--sans);font-weight:400;text-transform:uppercase;
  letter-spacing:.42em;font-size:.72rem;color:var(--terracotta-deep);
}
.eyebrow.light{color:var(--sand)}
h1,h2,h3{font-family:var(--serif);font-weight:500;letter-spacing:-.01em;color:var(--espresso)}
p{text-wrap:pretty}
.lead{font-size:1.18rem;color:var(--espresso-2);font-weight:300}

.wordmark{
  font-family:var(--sans);font-weight:300;text-transform:uppercase;
  letter-spacing:.34em;white-space:nowrap;
}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad)}
section{position:relative}
.section-pad{padding-block:clamp(64px,9vw,128px)}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none}}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;padding:18px var(--pad);
  transition:background .4s ease,box-shadow .4s ease,padding .4s ease,color .4s ease;
  color:var(--cream);
}
.nav.solid{
  background:rgba(247,240,227,.92);backdrop-filter:blur(14px);
  box-shadow:var(--shadow-sm);color:var(--espresso);padding-block:12px;
}
.nav .brand{display:flex;flex-direction:column;line-height:1;gap:3px}
.nav .brand .b1{font-family:var(--sans);font-weight:300;letter-spacing:.3em;font-size:.92rem;text-transform:uppercase}
.nav .brand .b2{font-family:var(--script);font-size:1.15rem;opacity:.9;margin-top:-2px}
.nav-links{display:flex;align-items:center;gap:34px;list-style:none}
.nav-links a{
  font-size:.86rem;text-transform:uppercase;letter-spacing:.18em;font-weight:400;
  position:relative;padding-block:4px;opacity:.92;
}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:1.5px;background:currentColor;transition:right .35s ease;opacity:.8}
.nav-links a:hover::after,.nav-links a.active::after{right:0}
.nav-right{display:flex;align-items:center;gap:18px}

.lang{display:flex;align-items:center;gap:2px;font-size:.8rem;letter-spacing:.12em;font-weight:400}
.lang button{
  background:none;border:none;color:inherit;cursor:pointer;font:inherit;
  padding:4px 6px;opacity:.55;letter-spacing:.12em;transition:opacity .25s;
}
.lang button.on{opacity:1;font-weight:500}
.lang .sep{opacity:.4}

.nav-cta{
  display:inline-flex;align-items:center;gap:8px;
  border:1.5px solid currentColor;border-radius:999px;
  padding:9px 18px;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;
  transition:background .3s,color .3s;
}
.nav.solid .nav-cta:hover{background:var(--espresso);color:var(--cream);border-color:var(--espresso)}
.nav:not(.solid) .nav-cta:hover{background:var(--cream);color:var(--espresso)}

.burger{display:none;background:none;border:none;color:inherit;cursor:pointer;flex-direction:column;gap:5px;padding:6px}
.burger span{width:24px;height:2px;background:currentColor;transition:.3s;border-radius:2px}

/* mobile menu */
.mobile-menu{
  position:fixed;inset:0;z-index:99;background:var(--espresso);color:var(--cream);
  display:flex;flex-direction:column;justify-content:center;align-items:center;gap:6px;
  transform:translateY(-100%);transition:transform .5s cubic-bezier(.7,0,.2,1);
}
.mobile-menu.open{transform:none}
.mobile-menu a{font-family:var(--serif);font-size:2.4rem;padding:10px;opacity:.9}
.mobile-menu .mm-script{font-family:var(--script);color:var(--sand);font-size:2.6rem;margin-bottom:20px}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:var(--sans);font-weight:400;font-size:.84rem;letter-spacing:.16em;
  text-transform:uppercase;padding:16px 30px;border-radius:999px;cursor:pointer;
  border:1.5px solid transparent;transition:transform .3s,background .3s,color .3s,box-shadow .3s;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-3px)}
.btn-primary{background:var(--terracotta);color:#fff;box-shadow:0 10px 26px rgba(199,111,69,.36)}
.btn-primary:hover{background:var(--terracotta-deep)}
.btn-dark{background:var(--espresso);color:var(--cream)}
.btn-dark:hover{background:var(--espresso-2)}
.btn-outline{background:transparent;border-color:var(--espresso);color:var(--espresso)}
.btn-outline:hover{background:var(--espresso);color:var(--cream)}
.btn-outline.light{border-color:var(--cream);color:var(--cream)}
.btn-outline.light:hover{background:var(--cream);color:var(--espresso)}

/* ============================================================
   FLOATING SOCIAL
   ============================================================ */
.social-float{position:fixed;right:clamp(16px,3vw,28px);bottom:clamp(16px,3vw,28px);z-index:90;display:flex;flex-direction:column;gap:12px}
.social-float a{
  width:54px;height:54px;border-radius:50%;display:grid;place-items:center;
  color:#fff;box-shadow:var(--shadow-md);transition:transform .3s;
}
.social-float a:hover{transform:scale(1.1) translateY(-2px)}
.social-float .wa{background:var(--whatsapp)}
.social-float .ig{background:linear-gradient(45deg,#f09433,#e6683c 25%,#dc2743 50%,#cc2366 75%,#bc1888)}
.social-float svg{width:26px;height:26px}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--espresso);color:var(--sand-soft);padding-block:72px 36px}
.footer a:hover{color:#fff}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:48px}
.footer h4{font-family:var(--sans);font-weight:500;text-transform:uppercase;letter-spacing:.2em;font-size:.78rem;color:var(--sand);margin-bottom:18px}
.footer .f-brand .b1{font-family:var(--sans);font-weight:300;letter-spacing:.3em;font-size:1.1rem;text-transform:uppercase;color:var(--cream)}
.footer .f-brand .b2{font-family:var(--script);font-size:2rem;color:var(--terracotta)}
.footer ul{list-style:none;display:flex;flex-direction:column;gap:10px;font-weight:300;font-size:.96rem;color:var(--sand-soft)}
.footer .f-social{display:flex;gap:12px;margin-top:8px}
.footer .f-social a{width:40px;height:40px;border:1px solid rgba(231,210,172,.3);border-radius:50%;display:grid;place-items:center;transition:.3s}
.footer .f-social a:hover{background:var(--terracotta);border-color:var(--terracotta);color:#fff}
.footer .f-social svg{width:18px;height:18px}
.footer-bottom{border-top:1px solid rgba(231,210,172,.18);margin-top:52px;padding-top:24px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:.82rem;color:var(--espresso-soft);letter-spacing:.04em}
.footer-bottom .espresso-light{color:var(--sand-soft);opacity:.7}

/* ============================================================
   REVIEWS CAROUSEL
   ============================================================ */
.reviews{background:var(--sky-soft);overflow:hidden}
.reviews .stars{color:var(--terracotta);letter-spacing:.18em;font-size:1.2rem}
.review-stage{position:relative;max-width:880px;margin:0 auto;min-height:300px}
.review-slide{
  position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;text-align:center;gap:22px;
  opacity:0;transform:translateY(16px) scale(.99);transition:opacity .7s ease,transform .7s ease;pointer-events:none;
}
.review-slide.on{opacity:1;transform:none;pointer-events:auto}
.review-quote{font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(1.3rem,3vw,1.9rem);line-height:1.45;color:var(--espresso)}
.review-author{display:flex;flex-direction:column;gap:2px}
.review-author .name{font-weight:500;letter-spacing:.05em}
.review-author .src{font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--espresso-soft)}
.review-dots{display:flex;justify-content:center;gap:9px;margin-top:40px}
.review-dots button{width:8px;height:8px;border-radius:50%;border:none;background:rgba(58,35,23,.22);cursor:pointer;padding:0;transition:.3s}
.review-dots button.on{background:var(--terracotta);width:26px;border-radius:6px}
.gquote{font-family:var(--serif);font-size:6rem;line-height:.5;color:var(--terracotta);opacity:.5}

/* ============================================================
   IMAGE SLOTS → real photos
   Drop your own JPG/PNG into /img using the same filenames to
   swap any placeholder. Images fill their sized container.
   ============================================================ */
.slot{display:block;width:100%;height:100%;object-fit:cover;background:var(--sand-soft)}

/* ============================================================
   MOBILE
   ============================================================ */
@media (max-width:920px){
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  body{font-size:17px}
  .nav-links,.nav-cta{display:none}
  .burger{display:flex}
  .footer-grid{grid-template-columns:1fr;gap:36px}
  .social-float a{width:50px;height:50px}
}
