/* ============================================================
   Delicia de Mi Tierra — Home
   "La Paleta de la Tierra" · Cocina con alma · Raíces que inspiran
   ============================================================ */

:root{
  /* La Paleta de la Tierra */
  --olive:#5f6a30;      --olive-deep:#3f4a22;  --olive-soft:#828b53;
  --terra:#c0573c;      --terra-deep:#a4462e;
  --coffee:#2e2117;     --ink:#1a130c;
  --gold:#e0a52e;       --gold-soft:#d8b771;
  --cream:#f3edde;      --cream-2:#f8f3e7;  --card:#fbf7ef;  --paper:#ece3d1;

  --text:#2e2117;
  --muted:rgba(46,33,23,.64);
  --line:rgba(46,33,23,.14);
  --on-dark:#f4ecdb;
  --muted-dark:rgba(244,236,219,.72);

  --serif:'Fraunces',Georgia,'Times New Roman',serif;
  --sans:'Mulish',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --script:'Dancing Script','Brush Script MT',cursive;

  --hh:clamp(62px,7.5vh,84px);
  --shell:min(1200px,92vw);
  --r-lg:22px; --r-md:16px; --r-sm:10px;
  --shadow:0 18px 40px -22px rgba(36,24,14,.55);
  --shadow-soft:0 10px 30px -18px rgba(36,24,14,.4);
  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{-webkit-text-size-adjust:100%;scroll-padding-top:calc(var(--hh) + 14px)}
html.anim{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  font-size:clamp(15.5px,.4rem + .7vw,18px);
  line-height:1.62;
  color:var(--text);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  position:relative;
}
/* artisan paper grain ("mantel limpio · papel artesanal") */
body::after{
  content:"";position:fixed;inset:0;z-index:9000;pointer-events:none;opacity:.05;
  mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
img{display:block;max-width:100%;height:auto}
a{color:inherit}
button{font:inherit;color:inherit;cursor:pointer;border:0;background:none}
:focus-visible{outline:2.5px solid var(--terra);outline-offset:3px;border-radius:4px}
::selection{background:var(--gold);color:var(--coffee)}

h1,h2,h3,h4{font-family:var(--serif);font-weight:400;line-height:1.06;letter-spacing:-.012em;color:var(--coffee);text-wrap:balance}
em{font-style:italic}

.shell{width:var(--shell);margin-inline:auto}
.skip-link{position:fixed;left:12px;top:-60px;z-index:10000;background:var(--coffee);color:var(--cream);padding:.7em 1.1em;border-radius:8px;transition:top .2s}
.skip-link:focus{top:12px}

/* ---------- kickers / shared bits ---------- */
.kicker{display:inline-flex;align-items:center;gap:.55em;font-family:var(--sans);font-weight:700;
  font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--olive)}
.kicker--light{color:var(--gold-soft)}
.kicker__ico{width:1.15em;height:1.15em;flex:none}
.kicker__ico use{stroke:currentColor}

.stars{display:inline-flex;gap:.12em;color:var(--gold)}
.stars svg{width:1.05em;height:1.05em}
.stars--lg svg{width:1.4em;height:1.4em}

.link-arrow{display:inline-flex;align-items:center;gap:.45em;color:var(--terra);font-weight:700;
  text-decoration:none;font-size:.9rem;letter-spacing:.01em}
.link-arrow svg{width:1.15em;height:1.15em;transition:transform .35s var(--ease)}
.link-arrow:hover svg{transform:translateX(5px)}
.link-arrow--lg{font-size:1rem}

.price{font-family:var(--sans);font-size:.86rem;color:var(--muted);letter-spacing:.01em}
.price strong{font-family:var(--serif);font-size:1.15rem;color:var(--coffee);font-weight:500}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  padding:.92em 1.5em;border-radius:999px;font-family:var(--sans);font-weight:700;
  font-size:.92rem;letter-spacing:.012em;text-decoration:none;white-space:nowrap;
  transition:transform .3s var(--ease),background .3s var(--ease),color .3s var(--ease),box-shadow .3s var(--ease)}
.btn svg{width:1.15em;height:1.15em}
.btn--sm{padding:.62em 1.05em;font-size:.84rem}
.btn--solid{background:var(--terra);color:#fdf6ee;box-shadow:0 12px 26px -14px rgba(164,70,46,.9)}
.btn--solid:hover{background:var(--terra-deep);transform:translateY(-2px)}
.btn--ghost{border:1.6px solid var(--coffee);color:var(--coffee)}
.btn--ghost:hover{background:var(--coffee);color:var(--cream);transform:translateY(-2px)}
.btn--ghost-light{border:1.6px solid rgba(244,236,219,.7);color:var(--on-dark)}
.btn--ghost-light:hover{background:var(--on-dark);color:var(--coffee)}
.btn--wa{background:#3b7d4a;color:#f3fff4;box-shadow:0 12px 26px -14px rgba(35,90,50,.9)}
.btn--wa:hover{background:#326b3f;transform:translateY(-2px)}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{position:fixed;top:0;left:0;width:100%;z-index:100;--nav-fg:#f4ecdb;
  transition:background .4s var(--ease),box-shadow .4s var(--ease),backdrop-filter .4s var(--ease)}
.site-header.is-solid{background:rgba(243,237,222,.88);backdrop-filter:blur(12px) saturate(1.1);
  box-shadow:0 1px 0 var(--line),0 10px 30px -24px rgba(36,24,14,.6);--nav-fg:var(--coffee)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1.2rem;height:var(--hh)}

.brand{display:inline-flex;align-items:center;gap:.6rem;text-decoration:none;color:var(--nav-fg)}
.brand__mark{display:grid;place-items:center;width:2.3rem;height:2.3rem;border-radius:50%;
  border:1.5px solid currentColor;color:var(--gold)}
.brand__mark svg{width:1.25rem;height:1.25rem}
.site-header:not(.is-solid) .brand__mark{color:var(--gold)}
.brand__txt{display:flex;flex-direction:column;line-height:1}
.brand__name{font-family:var(--serif);font-size:1.42rem;color:var(--nav-fg);letter-spacing:.01em}
.brand__sub{font-family:var(--sans);font-size:.6rem;font-weight:600;letter-spacing:.32em;
  text-transform:uppercase;color:var(--gold-soft);margin-top:.18em;white-space:nowrap}
.site-header.is-solid .brand__sub{color:var(--olive)}

.nav-links{display:flex;align-items:center;gap:1.7rem}
.nav-links a{position:relative;color:var(--nav-fg);text-decoration:none;font-weight:600;
  font-size:.9rem;letter-spacing:.015em;padding:.3em 0;opacity:.92;transition:opacity .25s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;height:1.5px;width:0;
  background:var(--terra);transition:width .3s var(--ease)}
.nav-links a:hover{opacity:1}
.nav-links a:hover::after{width:100%}

.nav-end{display:flex;align-items:center;gap:.7rem}
.nav-wa{display:grid;place-items:center;width:2.3rem;height:2.3rem;border-radius:50%;color:var(--nav-fg);
  border:1.5px solid color-mix(in srgb,currentColor 35%,transparent);transition:background .25s,color .25s,transform .25s}
.nav-wa svg{width:1.2rem;height:1.2rem}
.nav-wa:hover{background:#3b7d4a;color:#fff;border-color:transparent;transform:translateY(-1px)}

.menu-toggle{display:none;place-items:center;width:2.4rem;height:2.4rem;border-radius:10px;color:var(--nav-fg)}
.menu-toggle svg{width:1.5rem;height:1.5rem}

/* mobile menu */
.mobile-menu{position:fixed;inset:0;z-index:200;background:linear-gradient(160deg,#241a11,#3a2c1d);
  color:var(--on-dark);padding:calc(var(--hh) + 1rem) 8vw 3rem;display:flex;flex-direction:column;
  overflow-y:auto;overscroll-behavior:contain;visibility:hidden;
  transform:translateY(-101%);transition:transform .5s var(--ease),visibility 0s linear .5s}
.mobile-menu[hidden]{display:flex}
.mobile-menu.is-open{visibility:visible;transform:translateY(0);transition:transform .5s var(--ease)}
.menu-toggle--close{position:absolute;top:calc(var(--hh)/2 - 1.2rem);right:7vw;color:var(--on-dark);display:grid}
.mobile-menu__nav{display:flex;flex-direction:column;gap:.2rem;margin-top:auto;margin-bottom:auto}
.mobile-menu__nav a{display:flex;align-items:baseline;gap:1rem;text-decoration:none;color:var(--on-dark);
  font-family:var(--serif);font-size:clamp(1.7rem,8vw,2.6rem);padding:.35em 0;border-bottom:1px solid rgba(244,236,219,.12)}
.mobile-menu__nav a span{font-family:var(--sans);font-size:.8rem;font-weight:700;color:var(--gold);letter-spacing:.1em}
.mobile-menu__cta{margin-top:1.5rem;align-self:flex-start}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden;
  background:var(--coffee);color:var(--on-dark);padding-top:var(--hh)}
.hero__bg{position:absolute;inset:0;background-size:cover;background-position:center 40%;transform:scale(1.05)}
.hero__canvas{position:absolute;inset:0;z-index:1}
.hero__canvas canvas{width:100%!important;height:100%!important;display:block}
.hero__veil{position:absolute;inset:0;z-index:2;
  background:
    linear-gradient(100deg,rgba(20,13,7,.82) 0%,rgba(20,13,7,.5) 38%,rgba(20,13,7,.12) 66%,rgba(20,13,7,.36) 100%),
    linear-gradient(to top,rgba(20,13,7,.7),transparent 32%)}
.hero__inner{position:relative;z-index:3;display:grid;grid-template-columns:1.08fr .92fr;
  align-items:center;gap:3rem;width:var(--shell);padding-block:clamp(2rem,7vh,5rem)}
.hero__copy{max-width:42rem}
.hero__title{font-size:clamp(2.5rem,2rem + 4.6vw,5.4rem);color:#fbf3e6;margin:.5em 0 .55em;
  text-shadow:0 2px 30px rgba(20,13,7,.4)}
.hero__title .line{display:block}
.hero__title em{font-style:italic;color:var(--gold);font-family:var(--serif)}
.hero__lead{font-size:clamp(1rem,.9rem + .4vw,1.18rem);color:var(--muted-dark);max-width:46ch}
.hero__actions{display:flex;flex-wrap:wrap;gap:.85rem;margin-top:1.8rem}
.hero__proof{display:flex;align-items:center;gap:.7rem;margin-top:1.9rem;flex-wrap:wrap}
.hero__proof-txt{font-size:.9rem;color:var(--muted-dark)}
.hero__proof-txt strong{color:var(--on-dark)}

.hero__dish{position:relative;justify-self:center;width:min(30rem,40vw)}
.hero__dish img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:50% 50% 48% 48%/54% 54% 46% 46%;
  box-shadow:0 40px 70px -30px rgba(15,9,4,.8);border:1px solid rgba(244,236,219,.18)}
.hero__dish-arch{position:absolute;inset:-5% -5% auto -5%;height:60%;border-radius:50% 50% 0 0;
  border:1.5px solid rgba(224,165,46,.5);border-bottom:0;z-index:-1}
.hero__dish-tag{position:absolute;left:-1.2rem;bottom:1.6rem;display:inline-flex;align-items:center;gap:.4em;
  background:var(--cream);color:var(--coffee);padding:.5em .9em;border-radius:999px;font-size:.78rem;
  font-weight:700;box-shadow:var(--shadow);letter-spacing:.02em}
.hero__dish-tag svg{width:1.05em;height:1.05em;color:var(--olive)}

.hero__scroll{position:absolute;left:50%;bottom:1.4rem;transform:translateX(-50%);z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--muted-dark);
  text-decoration:none;font-size:.68rem;letter-spacing:.28em;text-transform:uppercase}
.hero__scroll-line{width:1.5px;height:2.6rem;background:linear-gradient(var(--gold),transparent)}
html.anim .hero__scroll-line{animation:scrollpulse 2.1s var(--ease) infinite}
@keyframes scrollpulse{0%,100%{transform:scaleY(.4);transform-origin:top;opacity:.5}50%{transform:scaleY(1);opacity:1}}

/* ============================================================
   INTRO / MANIFESTO + QUICKNAV
   ============================================================ */
.intro{padding:clamp(4.5rem,11vh,8rem) 0 clamp(3rem,6vh,4.5rem);position:relative}
.intro__grid{display:grid;grid-template-columns:1fr;gap:1.1rem;max-width:60rem;text-align:center;
  justify-items:center;margin-inline:auto}
.intro__statement{font-size:clamp(2rem,1.4rem + 3vw,3.7rem)}
.intro__statement .line{display:block}
.intro__statement em{color:var(--terra)}
.intro__text{color:var(--muted);max-width:54ch;font-size:1.05rem}

.quicknav{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:clamp(2.5rem,5vh,3.5rem)}
.quicknav__item{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.5rem;
  text-decoration:none;color:var(--coffee);padding:1.6rem 1rem;border-radius:var(--r-md);
  background:var(--card);border:1px solid var(--line);transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s}
.quicknav__item:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:transparent}
.quicknav__ico{display:grid;place-items:center;width:3rem;height:3rem;border-radius:50%;
  background:rgba(95,106,48,.1);color:var(--olive)}
.quicknav__ico svg{width:1.5rem;height:1.5rem}
.quicknav__item:hover .quicknav__ico{background:var(--olive);color:var(--cream-2)}
.quicknav__label{font-family:var(--serif);font-size:1.3rem}
.quicknav__sub{font-size:.76rem;color:var(--muted);letter-spacing:.02em}

/* ============================================================
   WORLDS (3 conjuntos: Día · Noche · Alma de México)
   ============================================================ */
.world{position:relative}
.world--day{background:var(--cream)}
.world--night{background:linear-gradient(180deg,#241a11,#2e2117 55%,#241a11);color:var(--on-dark)}
.world--alma{background:var(--cream-2);padding:clamp(4.5rem,10vh,7rem) 0}

.world__banner{position:relative;height:clamp(20rem,46vh,30rem);overflow:hidden;display:flex;align-items:flex-end}
.world__banner--tall{height:clamp(24rem,58vh,38rem);align-items:center}
.world__banner-img{position:absolute;inset:-14% 0;background-size:cover;background-position:center;will-change:transform}
.world--day .world__banner::after{content:"";position:absolute;inset:0;
  background:linear-gradient(to top,rgba(243,237,222,.97),rgba(243,237,222,.55) 48%,rgba(243,237,222,.12))}
.world--night .world__banner::after{content:"";position:absolute;inset:0;
  background:linear-gradient(to top,rgba(20,13,7,.9),rgba(20,13,7,.55) 55%,rgba(20,13,7,.45))}
.world__banner-grain{position:absolute;inset:0;z-index:1;background-image:url('../assets/tex/embers.png');
  background-size:cover;mix-blend-mode:screen;opacity:.4;pointer-events:none}
.world__banner .shell{position:relative;z-index:2;padding-bottom:2.2rem}
.world__banner--tall .shell{padding-bottom:0}

.world__head{max-width:46rem}
.world__head--center{margin-inline:auto;text-align:center}
.world__head--split{display:grid;grid-template-columns:1.25fr 1fr;gap:2rem;align-items:end;margin-bottom:2.6rem;max-width:none}
.world__index span{color:var(--gold);margin-right:.5em;font-variant-numeric:tabular-nums}
.world__title{font-size:clamp(1.9rem,1.3rem + 2.8vw,3.3rem);margin:.4em 0 .55em}
.world__desc{color:var(--muted);max-width:54ch;font-size:1.05rem}
.world__head--center .world__desc{margin-inline:auto}
.world__desc--light{color:var(--muted-dark)}
.world--night .world__title{color:#fbf3e6;text-shadow:0 2px 24px rgba(20,13,7,.65)}
.world--night .kicker__ico use{stroke:currentColor}
.world__body{padding:clamp(2.5rem,6vh,4.5rem) 0 clamp(3.5rem,8vh,6rem)}

/* mosaics */
.mosaic{display:grid;gap:1rem;margin-top:1rem}
.mosaic--day{grid-template-columns:repeat(12,1fr);grid-auto-rows:11rem}
.mosaic--day .m-a{grid-column:span 5;grid-row:span 2}
.mosaic--day .m-b{grid-column:span 7}
.mosaic--day .m-c{grid-column:span 3}
.mosaic--day .m-d{grid-column:span 4}
.mosaic--night{grid-template-columns:repeat(4,1fr);grid-auto-rows:13rem;margin-top:2.6rem}
.mosaic__cell{overflow:hidden;border-radius:var(--r-md);box-shadow:var(--shadow-soft);margin:0;background:var(--paper)}
.mosaic__cell img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.mosaic__cell:hover img{transform:scale(1.07)}

/* experience cards */
.xcards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:.5rem}
.xcards--night{grid-template-columns:repeat(4,1fr);margin-top:0;margin-bottom:0}
.xcard{display:flex;flex-direction:column;gap:.7rem;padding:1.6rem;border-radius:var(--r-md);
  background:var(--card);border:1px solid var(--line);box-shadow:var(--shadow-soft);
  transition:transform .35s var(--ease),box-shadow .35s var(--ease)}
.xcard:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.xcard__head{display:flex;align-items:center;gap:.7rem}
.xcard__ico{width:1.9rem;height:1.9rem;color:var(--terra);flex:none}
.xcard__head h3{font-size:1.28rem}
.xcard p{color:var(--muted);font-size:.94rem;flex:1}
.xcard__foot{display:flex;align-items:center;justify-content:space-between;gap:.6rem;
  margin-top:.3rem;padding-top:.9rem;border-top:1px solid var(--line)}
.xcard--dark{background:rgba(255,247,235,.045);border-color:rgba(244,236,219,.14);color:var(--on-dark)}
.xcard--dark h3{color:#fbf3e6}
.xcard--dark p{color:var(--muted-dark)}
.xcard--dark .xcard__ico{color:var(--gold)}
.xcard--dark .xcard__foot{border-top-color:rgba(244,236,219,.16)}
.xcard--dark .price{color:var(--muted-dark)}
.xcard--dark .price strong{color:#fbf3e6}

.world__extra{display:flex;align-items:center;gap:1.2rem;margin-top:1.6rem;padding:1.15rem 1.5rem;border-radius:var(--r-md);
  background:linear-gradient(100deg,rgba(192,87,60,.18),rgba(224,165,46,.08));border:1px solid rgba(224,165,46,.28);
  text-decoration:none;color:var(--on-dark);transition:transform .3s var(--ease),background .3s}
.world__extra:hover{transform:translateY(-3px);background:linear-gradient(100deg,rgba(192,87,60,.28),rgba(224,165,46,.13))}
.world__extra-ico{display:grid;place-items:center;width:2.6rem;height:2.6rem;border-radius:50%;background:var(--terra);color:#fff;flex:none}
.world__extra-ico svg{width:1.3rem}
.world__extra-txt{flex:1;font-size:.97rem;color:var(--muted-dark)}
.world__extra-txt strong{color:#fbf3e6;font-family:var(--serif);font-size:1.12rem;font-weight:500}
.world__extra-price{display:inline-flex;align-items:center;gap:.4em;color:var(--gold);font-weight:700;white-space:nowrap}
.world__extra-price svg{width:1.1em}

/* Alma de México */
.alma__grid{display:grid;grid-template-columns:1.35fr 1fr;gap:1.4rem}
.alma__feature{display:flex;flex-direction:column;background:var(--coffee);color:var(--on-dark);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow)}
.alma__feature-media{position:relative;aspect-ratio:16/10;overflow:hidden}
.alma__feature-media img{width:100%;height:100%;object-fit:cover}
.alma__feature-ico{position:absolute;left:1.2rem;top:1.2rem;display:grid;place-items:center;width:3rem;height:3rem;border-radius:50%;background:rgba(20,13,7,.55);color:var(--gold);backdrop-filter:blur(3px)}
.alma__feature-ico svg{width:1.6rem}
.alma__feature-body{padding:1.8rem;display:flex;flex-direction:column;gap:.6rem;flex:1}
.alma__feature-body h3{color:#fbf3e6;font-size:1.7rem}
.alma__feature-body p{color:var(--muted-dark)}
.alma__feature .xcard__foot{border-top-color:rgba(244,236,219,.16);margin-top:auto}
.alma__feature .price{color:var(--muted-dark)}
.alma__feature .price strong{color:#fbf3e6}
.ticks{list-style:none;display:flex;flex-direction:column;gap:.3rem;margin:.2rem 0 .4rem;padding:0}
.ticks li{position:relative;padding-left:1.3em;color:var(--muted-dark);font-size:.9rem}
.ticks li::before{content:"";position:absolute;left:0;top:.55em;width:.5em;height:.5em;border-radius:50%;background:var(--gold)}
.alma__side{display:grid;grid-template-rows:1fr 1fr;gap:1.4rem}
.alma__card{display:flex;flex-direction:column;gap:.55rem;padding:1.6rem;border-radius:var(--r-lg);background:var(--card);border:1px solid var(--line);box-shadow:var(--shadow-soft)}
.alma__card-ico{display:grid;place-items:center;width:2.6rem;height:2.6rem;border-radius:50%;background:rgba(192,87,60,.12);color:var(--terra)}
.alma__card-ico svg{width:1.35rem}
.alma__card h3{font-size:1.32rem}
.alma__card p{color:var(--muted);font-size:.92rem;flex:1}

/* ============================================================
   CHEF BARBARA
   ============================================================ */
.chef{padding:clamp(4.5rem,10vh,7.5rem) 0;background:linear-gradient(180deg,var(--cream),var(--paper));position:relative;overflow:hidden}
.chef__grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.chef__frame{position:relative;margin:0;max-width:26rem}
.chef__frame img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:46% 46% var(--r-lg) var(--r-lg)/40% 40% var(--r-lg) var(--r-lg);box-shadow:var(--shadow)}
.chef__arch{position:absolute;inset:-1.3rem -1.3rem 2.2rem -1.3rem;border:1.5px solid var(--gold);border-bottom:0;border-radius:50% 50% 0 0/48% 48% 0 0;z-index:0}
.chef__frame img{position:relative;z-index:1}
.chef__sig{position:absolute;right:-.3rem;bottom:-1.2rem;z-index:2;font-family:var(--script);font-size:clamp(3rem,7vw,5rem);color:var(--coffee);line-height:.8;text-shadow:0 3px 0 var(--cream),0 0 18px rgba(243,237,222,.7)}
.chef__body{max-width:38rem}
.chef__name{font-size:clamp(2.2rem,1.6rem + 3vw,3.6rem);margin:.3em 0 .4em}
.chef__lead{font-size:1.15rem;color:var(--text)}
.chef__body>p{color:var(--muted);margin-top:.85rem}
.chef__meta{display:flex;gap:2.2rem;margin:1.7rem 0 1.4rem;flex-wrap:wrap}
.chef__meta div{display:flex;flex-direction:column}
.chef__meta strong{font-family:var(--serif);font-size:1.9rem;color:var(--olive);font-weight:500;line-height:1}
.chef__meta span{font-size:.8rem;color:var(--muted);letter-spacing:.02em;margin-top:.2em}

/* ============================================================
   REVIEWS
   ============================================================ */
.reviews{padding:clamp(4rem,9vh,6.5rem) 0;background:var(--coffee);color:var(--on-dark);position:relative;overflow:hidden}
.reviews .kicker{color:var(--gold-soft)}
.reviews__head{text-align:center;max-width:42rem;margin-inline:auto}
.reviews__title{color:#fbf3e6;font-size:clamp(1.9rem,1.3rem + 3vw,3.2rem);margin:.3em 0 .55em}
.reviews__score{display:inline-flex;align-items:center;gap:.6rem;color:var(--muted-dark);flex-wrap:wrap;justify-content:center}
.reviews__score strong{color:#fbf3e6}
.reviews__viewport{margin-top:clamp(2.2rem,5vh,3.4rem)}
.reviews__track{display:flex;gap:1.4rem;overflow-x:auto;scroll-snap-type:x mandatory;padding:.3rem .2rem 1rem;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.reviews__track::-webkit-scrollbar{display:none}
.review{flex:0 0 86%;scroll-snap-align:center;background:rgba(255,247,235,.05);border:1px solid rgba(244,236,219,.14);
  border-radius:var(--r-lg);padding:2rem 1.8rem;display:flex;flex-direction:column;gap:1rem}
.review__q{width:2.2rem;height:2.2rem;color:var(--gold);opacity:.85;flex:none}
.review p{font-family:var(--serif);font-size:1.16rem;line-height:1.5;color:#f3e9d8;flex:1}
.review footer{display:flex;flex-direction:column;gap:.45rem}
.review cite{font-style:normal;font-weight:700;color:var(--gold-soft);font-size:.92rem;letter-spacing:.02em}
.reviews__nav{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1.6rem}
.reviews__btn{display:grid;place-items:center;width:2.8rem;height:2.8rem;border-radius:50%;border:1.5px solid rgba(244,236,219,.3);color:var(--on-dark);transition:background .25s,color .25s,border-color .25s}
.reviews__btn svg{width:1.2rem}
.reviews__btn:hover{background:var(--gold);color:var(--coffee);border-color:transparent}
.reviews__dots{display:flex;gap:.5rem}
.reviews__dots button{width:.55rem;height:.55rem;border-radius:50%;background:rgba(244,236,219,.3);transition:background .25s,transform .25s}
.reviews__dots button[aria-current="true"]{background:var(--gold);transform:scale(1.35)}

/* ============================================================
   CTA / RESERVAR
   ============================================================ */
.cta{position:relative;overflow:hidden;color:var(--on-dark)}
.cta__bg{position:absolute;inset:0;z-index:0}
.cta__bg-img{position:absolute;inset:-14% 0;background-size:cover;background-position:center;will-change:transform}
.cta::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(110deg,rgba(164,70,46,.93),rgba(40,28,18,.9))}
.cta__inner{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center;padding:clamp(4rem,9vh,6.5rem) 0}
.cta__title{color:#fff7ee;font-size:clamp(2rem,1.4rem + 3vw,3.5rem);margin:.3em 0 .5em}
.cta__lead{color:rgba(255,247,238,.88);max-width:42ch;margin-bottom:1.6rem}
.form{background:var(--card);color:var(--text);border-radius:var(--r-lg);padding:1.8rem;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:.85rem}
.form__title{font-size:1.5rem;margin-bottom:.2rem}
.field{display:flex;flex-direction:column;gap:.32rem}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
.field label{font-size:.74rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.field input,.field select,.field textarea{font:inherit;font-size:.95rem;padding:.7em .85em;border-radius:var(--r-sm);border:1.5px solid var(--line);background:#fff;color:var(--text);transition:border-color .2s;width:100%}
.field textarea{resize:vertical;min-height:3rem}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--terra);outline:none}
.form__submit{margin-top:.4rem;width:100%}
.form__note{font-size:.76rem;color:var(--muted);text-align:center}
.form__ok{display:none;align-items:center;gap:.5em;color:var(--olive);font-weight:700;font-size:.9rem;justify-content:center}
.form.is-sent .form__ok{display:flex}

/* ============================================================
   FOOTER + FAB
   ============================================================ */
.site-footer{background:#211810;color:var(--on-dark);padding:clamp(3.5rem,7vh,5rem) 0 2rem;position:relative}
.foot__top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.4fr;gap:2rem}
.brand--foot{color:var(--on-dark)}
.brand--foot .brand__name{color:var(--on-dark)}
.foot__tag{font-family:var(--serif);font-size:1.2rem;color:#f3e9d8;margin-top:1rem;max-width:24ch;line-height:1.3}
.foot__sig{font-family:var(--script);font-size:1.45rem;color:var(--gold);margin-top:.5rem}
.foot__col h4{font-family:var(--sans);font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.16em;color:var(--gold-soft);margin-bottom:1rem}
.foot__col a{display:flex;align-items:center;gap:.5em;text-decoration:none;color:var(--muted-dark);padding:.32em 0;transition:color .2s}
.foot__col a:hover{color:var(--on-dark)}
.foot__col svg{width:1.1em;height:1.1em;color:var(--gold-soft);flex:none}
.foot__loc{display:flex;align-items:center;gap:.5em;color:var(--muted-dark);font-size:.85rem;margin-top:.7rem}
.foot__loc svg{width:1.1em;height:1.1em;color:var(--gold-soft)}
.foot__bottom{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-top:2.6rem;padding-top:1.5rem;border-top:1px solid rgba(244,236,219,.14);color:var(--muted-dark);font-size:.82rem}

.wa-fab{position:fixed;right:1.1rem;bottom:1.1rem;z-index:90;display:inline-flex;align-items:center;gap:.5em;
  background:#3b7d4a;color:#fff;padding:.72em 1.15em;border-radius:999px;text-decoration:none;font-weight:700;font-size:.9rem;
  box-shadow:0 14px 30px -12px rgba(20,60,30,.85);transition:transform .3s var(--ease),box-shadow .3s}
.wa-fab svg{width:1.4em;height:1.4em}
.wa-fab:hover{transform:translateY(-3px) scale(1.03)}

/* ============================================================
   MOTION GATING (only when html.anim — reduced-motion safe)
   ============================================================ */
html.anim [data-reveal]:not([data-reveal-stagger]){opacity:0;transform:translateY(30px)}
html.anim [data-reveal-stagger] .line{opacity:0;transform:translateY(42%)}
html.anim [data-reveal-fab]{opacity:0;transform:scale(.6) translateY(12px)}
html.anim .hero__dish{opacity:0;transform:translateY(40px) scale(.96)}
@media (prefers-reduced-motion:reduce){.hero__bg{transform:scale(1.02)}}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1040px){
  .alma__grid{grid-template-columns:1fr}
  .alma__side{grid-template-rows:none;grid-template-columns:1fr 1fr}
  .cta__inner{grid-template-columns:1fr;gap:2.2rem}
  .chef__grid{grid-template-columns:1fr;gap:3.5rem;justify-items:start}
  .chef__frame{max-width:22rem}
}
@media(max-width:900px){
  .nav-links{display:none}
  .menu-toggle{display:grid}
  .hero__inner{grid-template-columns:1fr;gap:0}
  .hero__dish{display:none}
  .hero{min-height:auto;padding-block:calc(var(--hh) + 3rem) 4rem}
  .quicknav{grid-template-columns:repeat(2,1fr)}
  .xcards,.xcards--night,.mosaic--night{grid-template-columns:repeat(2,1fr)}
  .world__head--split{grid-template-columns:1fr;gap:1rem}
  .foot__top{grid-template-columns:1fr 1fr;gap:1.6rem 2rem}
  .foot__brand{grid-column:1/-1}
}
@media(max-width:680px){
  .mosaic--day{grid-template-columns:1fr 1fr;grid-auto-rows:9.5rem}
  .mosaic--day .mosaic__cell{grid-column:auto!important;grid-row:auto!important}
  .xcards,.xcards--night,.alma__side{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
  .review{flex-basis:90%}
  .world__extra{flex-direction:column;align-items:flex-start;gap:.8rem}
  .foot__top{grid-template-columns:1fr}
  .hero__actions .btn{flex:1 1 auto}
}
@media(min-width:721px){.review{flex-basis:46%}}
@media(min-width:1040px){.review{flex-basis:calc((100% - 2.8rem)/3)}}
@media(max-width:520px){
  .wa-fab span{display:none}
  .wa-fab{padding:.85em;border-radius:50%}
  :root{--shell:90vw}
}

/* ============================================================
   INNER PAGES (Experiencias) — shared building blocks
   ============================================================ */
.isec{padding:clamp(3.5rem,8vh,6rem) 0}
.isec--tight{padding:clamp(2.5rem,5vh,4rem) 0}
.section-head{max-width:46rem}
.section-head--center{margin-inline:auto;text-align:center}
.section-head h2{font-size:clamp(1.8rem,1.3rem + 2.6vw,3.1rem);margin:.35em 0 0}
.section-note{color:var(--muted);margin-top:.6rem;max-width:54ch}
.section-head--center .section-note{margin-inline:auto}

/* page hero (split) */
.phero{position:relative;background:linear-gradient(180deg,var(--cream-2),var(--cream));padding-top:var(--hh);overflow:hidden}
.phero__inner{width:var(--shell);margin-inline:auto;display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4rem);align-items:center;padding-block:clamp(2.5rem,7vh,5rem)}
.phero__copy{max-width:40rem}
.phero__title{font-size:clamp(2.3rem,1.7rem + 3.2vw,4.3rem);margin:.45em 0 .5em}
.phero__title .line{display:block}
.phero__title em{color:var(--terra);font-style:italic}
.phero__lead{color:var(--muted);font-size:1.08rem;max-width:46ch}
.phero__actions{display:flex;flex-wrap:wrap;gap:.85rem;margin-top:1.8rem}
.phero__media{position:relative;justify-self:center;width:min(30rem,100%)}
.phero__media>img{position:relative;z-index:1;width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:48% 48% 46% 46%/52% 52% 48% 48%;box-shadow:var(--shadow);border:1px solid rgba(46,33,23,.08)}
.phero__arch{position:absolute;inset:-4% -4% auto -4%;height:58%;border:1.5px solid var(--gold);border-bottom:0;border-radius:50% 50% 0 0;z-index:0}
.phero__card{position:absolute;right:-1rem;bottom:1.4rem;z-index:2;max-width:14.5rem;background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);padding:1rem 1.1rem;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:.45rem}
.phero__card-ico{display:grid;place-items:center;width:2.1rem;height:2.1rem;border-radius:50%;background:rgba(95,106,48,.12);color:var(--olive)}
.phero__card-ico svg{width:1.2rem;height:1.2rem}
.phero__card p{font-size:.86rem;color:var(--text);line-height:1.4}
.phero__card small{display:flex;align-items:center;gap:.35em;font-size:.74rem;color:var(--olive);font-weight:700}
.phero__card small svg{width:1em;height:1em}
.phero__pills{width:var(--shell);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;padding-bottom:clamp(2rem,4vh,3rem)}
.phero__pill{display:flex;align-items:center;gap:.6rem;padding:.85rem 1rem;background:var(--card);border:1px solid var(--line);border-radius:var(--r-sm);font-size:.88rem;font-weight:600;color:var(--coffee)}
.phero__pill svg{width:1.25rem;height:1.25rem;color:var(--olive);flex:none}

/* feature rows */
.band{background:var(--cream);text-align:center}
.band__title{font-size:clamp(1.5rem,1.1rem + 1.8vw,2.3rem);max-width:30ch;margin:0 auto clamp(2rem,4vh,3rem)}
.band__title svg{width:1em;height:1em;color:var(--olive);vertical-align:-.08em}
.features{display:grid;gap:1.6rem 1rem}
.features--5{grid-template-columns:repeat(5,1fr)}
.features--6{grid-template-columns:repeat(6,1fr)}
.feature{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.6rem}
.feature__ico{display:grid;place-items:center;width:3.2rem;height:3.2rem;border-radius:50%;background:rgba(95,106,48,.1);color:var(--olive)}
.feature__ico svg{width:1.6rem;height:1.6rem}
.feature h3{font-family:var(--serif);font-size:1.06rem;font-weight:500}
.feature p{font-size:.82rem;color:var(--muted);max-width:22ch}
.features--terra .feature__ico{background:rgba(192,87,60,.12);color:var(--terra)}

/* package / category cards */
.pkg-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1.1rem;margin-top:2.4rem}
.pkg{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-soft);transition:transform .35s var(--ease),box-shadow .35s}
.pkg:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.pkg__media{aspect-ratio:4/3;overflow:hidden}
.pkg__media img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.pkg:hover .pkg__media img{transform:scale(1.07)}
.pkg__body{padding:1.2rem;display:flex;flex-direction:column;gap:.55rem;flex:1}
.pkg__body h3{font-size:1.2rem}
.pkg__list{list-style:none;display:flex;flex-direction:column;gap:.32rem;padding:0;margin:0;flex:1}
.pkg__list li{position:relative;padding-left:1em;font-size:.84rem;color:var(--muted)}
.pkg__list li::before{content:"";position:absolute;left:0;top:.62em;width:.34em;height:.34em;border-radius:50%;background:var(--terra)}
.pkg__tag{margin-top:.5rem;font-family:var(--sans);font-size:.72rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--olive)}
.pkg__tag strong{font-family:var(--serif);font-size:1.02rem;color:var(--coffee);font-weight:500;letter-spacing:0}

/* pricing tiers */
.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem;margin-top:2.2rem}
.tier{text-align:center;padding:2rem 1.3rem;border-radius:var(--r-md);background:var(--card);border:1px solid var(--line);box-shadow:var(--shadow-soft)}
.tier--feat{background:var(--coffee);color:var(--on-dark);border-color:transparent}
.tier__opts{font-family:var(--sans);font-weight:700;letter-spacing:.12em;text-transform:uppercase;font-size:.76rem;color:var(--olive)}
.tier--feat .tier__opts{color:var(--gold)}
.tier__price{font-family:var(--serif);font-size:clamp(1.9rem,1.4rem + 1.6vw,2.7rem);margin:.15em 0 .1em}
.tier__price small{font-size:.46em;color:var(--muted);font-family:var(--sans);font-weight:600}
.tier--feat .tier__price{color:#fbf3e6}
.tier--feat .tier__price small{color:var(--muted-dark)}
.tier p{font-size:.84rem;color:var(--muted)}
.tier--feat p{color:var(--muted-dark)}
.pricing-note{text-align:center;color:var(--muted);font-size:.84rem;margin-top:1.2rem}

/* favourites mosaic */
.favs{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:13rem;gap:1rem;margin-top:2.4rem}
.fav{position:relative;overflow:hidden;border-radius:var(--r-md);box-shadow:var(--shadow-soft);margin:0;background:var(--paper)}
.fav--big{grid-column:span 2;grid-row:span 2}
.fav img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.fav:hover img{transform:scale(1.06)}
.fav figcaption{position:absolute;left:.9rem;bottom:.9rem;background:rgba(20,13,7,.6);color:#fff;padding:.35em .85em;border-radius:999px;font-size:.78rem;font-weight:600;backdrop-filter:blur(3px)}

/* occasions split */
.occasions{position:relative;overflow:hidden;background:linear-gradient(180deg,var(--cream),var(--paper))}
.occasions__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.occasions__media img{width:100%;aspect-ratio:5/4;object-fit:cover;border-radius:var(--r-lg);box-shadow:var(--shadow)}
.occasions__body h2{font-size:clamp(1.8rem,1.3rem + 2.4vw,3rem);margin-bottom:.4em}
.occasions__body p{color:var(--muted)}
.occ-list{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:.7rem 1.2rem;padding:0;margin-top:1.3rem}
.occ-list li{display:flex;align-items:center;gap:.6em;font-size:.92rem;color:var(--text)}
.occ-list svg{width:1.2em;height:1.2em;color:var(--olive);flex:none}
.occasions__leaf{position:absolute;right:-3%;top:-6%;width:15rem;opacity:.13;pointer-events:none;z-index:0}

/* contact CTA (olive band) */
.ccta{background:linear-gradient(120deg,var(--olive-deep),var(--olive));color:var(--on-dark);overflow:hidden;position:relative}
.ccta__inner{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.ccta__media img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:var(--r-lg);box-shadow:var(--shadow)}
.ccta .kicker{color:var(--gold-soft)}
.ccta__title{color:#fff7ee;font-size:clamp(1.9rem,1.4rem + 2.6vw,3.2rem);margin:.3em 0 .4em}
.ccta__lead{color:rgba(255,247,238,.88);max-width:46ch;margin-bottom:1.4rem}
.contact-chips{display:flex;flex-wrap:wrap;gap:.8rem}
.chip{display:inline-flex;align-items:center;gap:.5em;background:rgba(255,247,238,.1);border:1px solid rgba(255,247,238,.24);color:#fff;padding:.62em 1.05em;border-radius:999px;font-size:.86rem;font-weight:600;text-decoration:none;transition:background .25s,transform .25s}
.chip:hover{background:rgba(255,247,238,.2);transform:translateY(-2px)}
.chip svg{width:1.2em;height:1.2em;color:var(--gold)}

/* inner-page responsive */
@media(max-width:1040px){
  .phero__inner{grid-template-columns:1fr;gap:2.5rem}
  .phero__media{max-width:25rem}
  .pkg-grid{grid-template-columns:repeat(3,1fr)}
  .features--5,.features--6{grid-template-columns:repeat(3,1fr)}
  .occasions__grid,.ccta__inner{grid-template-columns:1fr}
  .pricing{grid-template-columns:1fr}
}
@media(max-width:900px){
  .phero__pills{grid-template-columns:repeat(2,1fr)}
  .favs{grid-template-columns:repeat(2,1fr);grid-auto-rows:12rem}
  .fav--big{grid-column:span 2;grid-row:span 1}
}
@media(max-width:680px){
  .pkg-grid{grid-template-columns:1fr 1fr}
  .features--5,.features--6{grid-template-columns:repeat(2,1fr)}
  .occ-list{grid-template-columns:1fr}
  .phero__card{position:static;right:auto;bottom:auto;max-width:none;margin-top:1.2rem}
  .phero__media{max-width:22rem}
}
@media(max-width:480px){
  .pkg-grid{grid-template-columns:1fr}
  .favs{grid-template-columns:1fr;grid-auto-rows:12rem}
  .fav--big{grid-column:span 1;grid-row:span 1}
}

