/* ============================================================================
   FINCA SON JORBO — "The Almanac of Five"
   Concept: the finca read as an almanac of its own five apartments
   (Estrella/star · Luna/moon · Mar/sea · Sol/sun · Tierra/earth), riding a fine
   engraved "ephemeris" hairline that the finca's own logo already hints at.
   Lane: Gilda Display + Inter · deep bottle-green + cream · teal accent (logo).
   ============================================================================ */

:root{
  /* palette — derived from the photos (ivy, stone, terracotta, sky) + logo teal */
  --ink:#1f3d34;          /* bottle/forest green — dominant */
  --ink-2:#16302a;        /* deeper green for dark fields */
  --ink-soft:#3a544b;     /* muted green text on cream */
  --teal:#3f7a72;         /* the logo's green — live accent */
  --teal-lo:#cfe0db;      /* pale teal wash */
  --cream:#f4efe4;        /* warm cream — page */
  --cream-2:#ece4d4;      /* slightly deeper cream panels */
  --paper:#fbf8f1;        /* lightest paper */
  --gold:#cdb27f;         /* faint engraved-gold for the hairline/glyphs */
  --gold-deep:#b8895a;    /* terracotta glint (pots, roof tiles) — rare */
  --line:rgba(31,61,52,.18);
  --line-soft:rgba(31,61,52,.10);

  --pad:clamp(20px,5vw,80px);
  --maxw:1240px;
  --r:3px;                /* near-square, classical edges */

  --f-display:"Gilda Display",Georgia,"Times New Roman",serif;
  --f-body:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;

  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;background:var(--cream);color:var(--ink);
  font-family:var(--f-body);font-size:17px;line-height:1.65;
  font-weight:400;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3{margin:0;font-weight:400;font-family:var(--f-display);
  /* LEARNINGS: never shatter big display type vertically */
  word-break:keep-all;overflow-wrap:normal;hyphens:none;}
p{margin:0}
ol,ul{margin:0;padding:0;list-style:none}
::selection{background:var(--teal);color:var(--paper)}

.skip{position:absolute;left:-999px;top:0;background:var(--ink);color:var(--paper);
  padding:.7em 1.1em;border-radius:var(--r);z-index:200}
.skip:focus{left:12px;top:12px}

/* ---------- the ephemeris GLYPH system (pure CSS, crisp at any size) -------- */
.glyph{position:relative;display:inline-block;width:1em;height:1em;
  color:var(--gold);flex:none;vertical-align:middle}
.glyph::before,.glyph::after{content:"";position:absolute;left:50%;top:50%}
/* STAR — four-point tick */
.glyph--star::before{width:1em;height:1em;transform:translate(-50%,-50%);
  background:
    linear-gradient(currentColor,currentColor) center/1.6px 100% no-repeat,
    linear-gradient(currentColor,currentColor) center/100% 1.6px no-repeat;}
.glyph--star::after{width:.72em;height:.72em;transform:translate(-50%,-50%) rotate(45deg);
  background:
    linear-gradient(currentColor,currentColor) center/1.2px 100% no-repeat,
    linear-gradient(currentColor,currentColor) center/100% 1.2px no-repeat;}
/* MOON — crescent via overlapping ring */
.glyph--moon::before{width:.92em;height:.92em;border-radius:50%;
  transform:translate(-50%,-50%);box-shadow:inset 0 0 0 1.6px currentColor;}
.glyph--moon::after{width:.78em;height:.78em;border-radius:50%;
  transform:translate(-32%,-58%);background:var(--field,var(--cream));}
/* SEA — two stacked waves */
.glyph--sea::before{width:1em;height:.5em;left:50%;top:42%;transform:translate(-50%,-50%);
  border-bottom:0;border-radius:50%/100%;
  box-shadow:0 0 0 0 transparent;}
.glyph--sea::before{
  background:
    radial-gradient(circle at 25% 0,transparent 60%,currentColor 61%,currentColor 67%,transparent 68%) 0 0/.5em .5em no-repeat,
    radial-gradient(circle at 75% 0,transparent 60%,currentColor 61%,currentColor 67%,transparent 68%) .5em 0/.5em .5em no-repeat;}
.glyph--sea::after{
  width:1em;height:.5em;left:50%;top:66%;transform:translate(-50%,-50%);
  background:
    radial-gradient(circle at 25% 0,transparent 60%,currentColor 61%,currentColor 67%,transparent 68%) 0 0/.5em .5em no-repeat,
    radial-gradient(circle at 75% 0,transparent 60%,currentColor 61%,currentColor 67%,transparent 68%) .5em 0/.5em .5em no-repeat;}
/* SUN — disc + rays */
.glyph--sun::before{width:.5em;height:.5em;border-radius:50%;transform:translate(-50%,-50%);
  box-shadow:inset 0 0 0 1.6px currentColor;}
.glyph--sun::after{width:1em;height:1em;transform:translate(-50%,-50%);border-radius:50%;
  background:
    conic-gradient(from 0deg,
     currentColor 0 6deg,transparent 6deg 84deg,
     currentColor 84deg 96deg,transparent 96deg 174deg,
     currentColor 174deg 186deg,transparent 186deg 264deg,
     currentColor 264deg 276deg,transparent 276deg 354deg,
     currentColor 354deg 360deg);
  -webkit-mask:radial-gradient(circle,transparent 38%,#000 39% 50%,transparent 51%);
          mask:radial-gradient(circle,transparent 38%,#000 39% 50%,transparent 51%);}
/* EARTH — horizon line through a circle */
.glyph--earth::before{width:.92em;height:.92em;border-radius:50%;transform:translate(-50%,-50%);
  box-shadow:inset 0 0 0 1.6px currentColor;}
.glyph--earth::after{width:1em;height:1.6px;transform:translate(-50%,-50%);background:currentColor;}

/* ============================ HEADER ============================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;gap:18px;
  padding:14px var(--pad);
  background:rgba(244,239,228,.82);backdrop-filter:saturate(1.4) blur(12px);
  border-bottom:1px solid var(--line-soft);
  transition:transform .4s var(--ease),background .3s,box-shadow .3s;
}
.nav.is-hidden{transform:translateY(-102%)}
.nav.is-scrolled{box-shadow:0 8px 30px -20px rgba(22,48,42,.5)}
.nav__brand{display:flex;align-items:center;flex:none}
.nav__logo{height:40px;width:auto}
.nav__links{display:flex;gap:26px;margin-left:auto;font-size:.84rem;
  letter-spacing:.04em;text-transform:uppercase;color:var(--ink-soft)}
.nav__links a{position:relative;padding:4px 0;transition:color .2s}
.nav__links a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:1.5px;
  background:var(--teal);transition:right .35s var(--ease)}
.nav__links a:hover{color:var(--ink)}
.nav__links a:hover::after{right:0}
.nav__right{display:flex;align-items:center;gap:16px;margin-left:26px}
.lang{display:flex;align-items:center;gap:7px;font-size:.8rem;letter-spacing:.05em}
.lang__btn{background:none;border:0;cursor:pointer;color:var(--ink-soft);
  font:inherit;letter-spacing:.05em;padding:6px 5px;min-height:44px;
  display:inline-flex;align-items:center;transition:color .2s}
.lang__btn.is-active{color:var(--ink);font-weight:600}
.lang__btn:hover{color:var(--teal)}
.lang__sep{color:var(--line);font-size:.7rem}

/* ============================ BUTTONS ============================ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:var(--f-body);font-size:.82rem;font-weight:600;letter-spacing:.06em;
  text-transform:uppercase;padding:.92em 1.5em;border-radius:var(--r);
  border:1.5px solid transparent;cursor:pointer;
  transition:background .25s var(--ease),color .25s,border-color .25s,transform .2s;
  min-height:44px;white-space:nowrap}
.btn--solid{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.btn--solid:hover{background:var(--teal);border-color:var(--teal);transform:translateY(-2px)}
.btn--line{background:transparent;color:var(--ink);border-color:var(--line)}
.btn--line:hover{border-color:var(--ink);background:var(--ink);color:var(--cream)}
.btn--ghost{background:transparent;color:var(--cream);border-color:rgba(244,239,228,.5)}
.btn--ghost:hover{background:var(--cream);color:var(--ink);border-color:var(--cream)}
.btn--lg{padding:1.05em 1.9em;font-size:.86rem}
.btn--xl{padding:1.15em 2.3em;font-size:.9rem}
.nav__book{padding:.72em 1.15em;font-size:.76rem;min-height:44px}

/* ============================ HERO ============================ */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;
  justify-content:flex-end;overflow:hidden;isolation:isolate;
  padding:0 var(--pad) clamp(28px,5vh,56px);--field:var(--ink)}
.hero__media{position:absolute;inset:0;z-index:-2}
.hero__media img{width:100%;height:100%;object-fit:cover;object-position:50% 52%;
  filter:saturate(1.05) contrast(1.03)}
.hero__scrim{position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(180deg,rgba(22,48,42,.5) 0%,rgba(22,48,42,.08) 22%,rgba(22,48,42,.14) 50%,rgba(22,48,42,.8) 100%),
    radial-gradient(135% 92% at 8% 100%,rgba(22,48,42,.62),transparent 58%)}
.hero__inner{position:relative;max-width:var(--maxw);width:100%;margin:0 auto;
  color:var(--cream);padding-bottom:clamp(18px,4vh,40px)}
.hero__eyebrow{font-size:.8rem;letter-spacing:.22em;text-transform:uppercase;
  color:#e6cf9b;margin-bottom:.9em;display:flex;align-items:center;gap:.8em;font-weight:600;
  text-shadow:0 1px 16px rgba(16,48,42,.85)}
.hero__eyebrow::before{content:"";width:34px;height:1.5px;background:var(--gold);display:inline-block}
.hero__title{font-size:clamp(2.9rem,9.2vw,7rem);line-height:.99;letter-spacing:-.012em;
  text-shadow:0 2px 40px rgba(16,48,42,.4)}
.hero__line{display:block}
.hero__line--accent{font-style:italic;color:var(--paper)}
.hero__sub{max-width:46ch;margin-top:1.1em;font-size:clamp(1rem,1.6vw,1.18rem);
  line-height:1.6;color:rgba(244,239,228,.92)}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:1.8em}

/* THE REGISTER — signature moment */
.register{position:relative;max-width:var(--maxw);width:100%;margin:0 auto;
  z-index:1;color:var(--cream)}
.register__rule{display:block;height:1.5px;width:100%;
  background:linear-gradient(90deg,transparent,var(--gold) 8%,var(--gold) 92%,transparent);
  opacity:.9}
.register__row{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));
  gap:8px;padding-top:14px}
.reg{display:flex;align-items:center;gap:.55em;min-width:0;position:relative}
.reg::before{content:"";position:absolute;top:-14px;left:0;width:1.5px;height:8px;
  background:var(--gold);transform:translateY(-100%)}
.reg__glyph{font-size:1.05rem;color:var(--gold)}
.reg__name{font-family:var(--f-display);font-size:clamp(.84rem,1.5vw,1.12rem);
  letter-spacing:.02em;color:var(--cream);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.hero__scroll{position:absolute;right:var(--pad);bottom:clamp(28px,5vh,56px);
  display:flex;flex-direction:column;align-items:center;gap:7px;
  font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(244,239,228,.85);
  z-index:2}
.hero__scroll svg{width:16px;height:26px}
.scroll-line{stroke:rgba(244,239,228,.85);stroke-width:1.6;fill:none;stroke-linecap:round;stroke-linejoin:round}
.scroll-dot{animation:nudge 1.8s var(--ease) infinite}
@keyframes nudge{0%,100%{transform:translateY(0);opacity:.5}50%{transform:translateY(4px);opacity:1}}
@media (prefers-reduced-motion:reduce){.scroll-dot{animation:none}}

/* ============================ shared section bits ============================ */
.kicker{display:flex;align-items:center;gap:.7em;font-size:.78rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink-soft);font-weight:600;margin-bottom:1.2em}
.kicker--light{color:rgba(244,239,228,.78)}
.kicker__no{font-family:var(--f-display);font-size:1.05rem;letter-spacing:0;color:var(--teal);
  font-weight:400}
.kicker--light .kicker__no{color:var(--gold)}
.rule{display:block;height:1.5px;width:100%;
  background:linear-gradient(90deg,transparent,var(--line) 10%,var(--line) 90%,transparent)}

/* ============================ FINCA (story) ============================ */
.finca{max-width:var(--maxw);margin:0 auto;padding:clamp(64px,11vh,150px) var(--pad) clamp(40px,7vh,90px);
  display:grid;grid-template-columns:minmax(0,1.55fr) minmax(0,1fr);gap:clamp(34px,6vw,90px);
  align-items:end}
.finca__title{font-size:clamp(1.9rem,3.6vw,3.3rem);line-height:1.06;letter-spacing:-.01em;
  margin-bottom:.7em;max-width:18ch}
.finca__intro{font-size:clamp(1.08rem,1.7vw,1.32rem);line-height:1.55;color:var(--ink);
  margin-bottom:1.1em}
.finca__p{color:var(--ink-soft);margin-bottom:1em;max-width:60ch}
.measures{border-top:1.5px solid var(--line);padding-top:1.4em}
.measure{padding:.9em 0;border-bottom:1px solid var(--line-soft);
  display:grid;grid-template-columns:minmax(0,auto) minmax(0,1.6fr);gap:1.2em;align-items:baseline}
.measure__k{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--teal);font-weight:600}
.measure__v{font-family:var(--f-display);font-size:1.02rem;line-height:1.35;color:var(--ink)}
.measure__v b{font-style:normal}

/* ============================ THE FIVE (constellation, dark field) ============================ */
.five{background:var(--ink-2);color:var(--cream);padding:clamp(64px,11vh,140px) var(--pad);
  --field:var(--ink-2);position:relative;overflow:hidden}
.five::before{content:"";position:absolute;inset:0;opacity:.5;pointer-events:none;
  background:radial-gradient(80% 60% at 85% 0,rgba(63,122,114,.22),transparent 60%)}
.five__head{max-width:var(--maxw);margin:0 auto 2.6em;position:relative}
.five__title{font-size:clamp(1.85rem,3.5vw,3.15rem);line-height:1.07;max-width:20ch;
  margin-bottom:.6em;color:var(--paper)}
.five__lede{max-width:60ch;color:rgba(244,239,228,.82);font-size:1.05rem}
.bodies{max-width:var(--maxw);margin:0 auto;display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));gap:0;position:relative;
  border-top:1.5px solid rgba(205,178,127,.35)}
.body{position:relative;min-width:0}
.body + .body{border-left:1px solid rgba(244,239,228,.13)}
.body__hit{display:flex;flex-direction:column;gap:.5em;height:100%;
  padding:1.7em 1.25em 1.6em;transition:background .3s var(--ease)}
.body__hit:hover{background:rgba(244,239,228,.05)}
.body__glyph{font-size:1.7rem;color:var(--gold);margin-bottom:.35em;
  transition:transform .5s var(--ease),color .3s}
.body__hit:hover .body__glyph{transform:translateY(-3px) rotate(8deg);color:var(--paper)}
.body__es{font-family:var(--f-display);font-size:1.5rem;line-height:1;color:var(--paper)}
.body__en{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);
  margin-bottom:.5em}
.body__txt{font-size:.92rem;line-height:1.55;color:rgba(244,239,228,.78);flex:1}
.body__meta{font-size:.72rem;letter-spacing:.03em;color:rgba(244,239,228,.6);
  padding-top:.9em;margin-top:.6em;border-top:1px solid rgba(244,239,228,.13)}
.five__note{max-width:var(--maxw);margin:2.4em auto 0;display:flex;flex-wrap:wrap;
  align-items:center;gap:.6em 1.4em;color:rgba(244,239,228,.78);font-size:.96rem}
.link-tick{color:var(--paper);font-weight:600;letter-spacing:.04em;
  display:inline-flex;align-items:center;gap:.5em;
  min-height:44px;padding-bottom:2px;
  box-shadow:inset 0 -1.5px 0 0 var(--gold);
  transition:gap .25s var(--ease),box-shadow .25s}
.link-tick::after{content:"→";color:var(--gold);transition:transform .25s var(--ease)}
.link-tick:hover{box-shadow:inset 0 -1.5px 0 0 var(--paper)}
.link-tick:hover::after{transform:translateX(4px)}

/* ============================ THE TABLE (feature, split) ============================ */
.table{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);
  align-items:stretch;background:var(--cream-2)}
.table__media{position:relative;min-height:clamp(320px,52vh,640px)}
.table__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.table__panel{padding:clamp(44px,7vw,92px) var(--pad);display:flex;flex-direction:column;
  justify-content:center;max-width:660px}
.table__title{font-size:clamp(1.8rem,3.2vw,3rem);line-height:1.08;margin-bottom:.7em;max-width:16ch}
.table__p{color:var(--ink-soft);margin-bottom:1em;max-width:54ch}
.ticks{margin-top:.7em;display:flex;flex-direction:column;gap:.7em}
.tick{position:relative;padding-left:1.7em;font-size:.96rem;color:var(--ink)}
.tick::before{content:"";position:absolute;left:0;top:.55em;width:.85em;height:.85em;
  border:1.5px solid var(--teal);border-radius:50%}
.tick::after{content:"";position:absolute;left:.28em;top:.78em;width:.3em;height:.3em;
  background:var(--teal);border-radius:50%}

/* ============================ GROUNDS (gallery) ============================ */
.grounds{max-width:var(--maxw);margin:0 auto;padding:clamp(56px,9vh,120px) var(--pad)}
.rule--top{margin-bottom:clamp(40px,6vh,72px)}
.grounds__head{max-width:760px;margin-bottom:2.4em}
.grounds__title{font-size:clamp(1.8rem,3.3vw,3rem);line-height:1.07;margin-bottom:.6em;max-width:18ch}
.grounds__lede{color:var(--ink-soft);font-size:1.05rem;max-width:56ch}
.plates{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));
  grid-auto-rows:clamp(150px,21vw,250px);gap:clamp(10px,1.1vw,16px)}
.plate{position:relative;overflow:hidden;border-radius:var(--r);margin:0;background:var(--cream-2)}
.plate img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.plate:hover img{transform:scale(1.05)}
.plate__tag{position:absolute;left:12px;bottom:11px;display:flex;align-items:center;gap:.5em;
  color:var(--cream);font-size:.76rem;letter-spacing:.04em;
  text-shadow:0 1px 14px rgba(16,48,42,.8);z-index:1}
.plate__gl{font-size:.95rem;color:var(--gold)}
.plate::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 55%,rgba(16,48,42,.6));pointer-events:none}
.plate--a{grid-column:span 3;grid-row:span 2}
.plate--b{grid-column:span 3;grid-row:span 1}
.plate--c{grid-column:span 2;grid-row:span 1}
.plate--d{grid-column:span 1;grid-row:span 1}
.plate--e{grid-column:span 2;grid-row:span 1}
.plate--f{grid-column:span 4;grid-row:span 1}

/* ============================ SETTING (full-bleed) ============================ */
.setting{position:relative;overflow:hidden;isolation:isolate;--field:var(--ink-2);
  min-height:clamp(540px,82vh,820px);display:flex;align-items:center}
.setting__media{position:absolute;inset:0;z-index:-2}
.setting__media img{width:100%;height:100%;object-fit:cover;object-position:50% 56%}
.setting__scrim{position:absolute;inset:0;z-index:-1;
  background:linear-gradient(90deg,rgba(16,48,42,.9) 0%,rgba(16,48,42,.72) 38%,rgba(16,48,42,.18) 72%,transparent 100%)}
.setting__inner{max-width:var(--maxw);width:100%;margin:0 auto;padding:0 var(--pad)}
.setting__panel{max-width:560px;color:var(--cream)}
.setting__title{font-size:clamp(1.85rem,3.4vw,3.1rem);line-height:1.07;margin-bottom:.7em;
  color:var(--paper);max-width:18ch}
.setting__p{color:rgba(244,239,228,.86);margin-bottom:1em;max-width:52ch}
.dist{margin-top:1.6em;border-top:1.5px solid rgba(205,178,127,.4);padding-top:.4em;max-width:430px}
.dist__row{display:flex;align-items:baseline;justify-content:space-between;gap:1.2em;
  padding:.72em 0;border-bottom:1px solid rgba(244,239,228,.16)}
.dist__row dt{font-size:.94rem;color:rgba(244,239,228,.84)}
.dist__row dd{font-family:var(--f-display);font-size:1.04rem;color:var(--gold);text-align:right;
  white-space:nowrap}

/* ============================ GREEN NOTE ============================ */
.green{max-width:760px;margin:0 auto;padding:clamp(60px,10vh,128px) var(--pad);text-align:center}
.green__glyph{font-size:2.2rem;color:var(--gold);margin-bottom:.6em}
.green__title{font-size:clamp(1.7rem,3vw,2.7rem);line-height:1.1;margin-bottom:.6em;color:var(--ink)}
.green__p{color:var(--ink-soft);font-size:1.06rem;line-height:1.65;max-width:58ch;margin:0 auto}

/* ============================ BOOK ============================ */
.book{background:var(--ink);color:var(--cream);padding:clamp(64px,11vh,140px) var(--pad);
  text-align:center;--field:var(--ink);position:relative;overflow:hidden}
.book__inner{max-width:760px;margin:0 auto;position:relative}
.book__register{display:flex;justify-content:center;gap:1.4em;margin-bottom:1.6em;font-size:1.4rem;color:var(--gold);opacity:.9}
.book__kick{justify-content:center}
.book__title{font-size:clamp(2.1rem,4.4vw,3.7rem);line-height:1.03;margin-bottom:.5em;color:var(--paper)}
.book__txt{max-width:52ch;margin:0 auto 1.8em;color:rgba(244,239,228,.84);font-size:1.06rem}
.book__cta{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}
.book__contact{margin-top:2em;display:flex;flex-wrap:wrap;align-items:center;justify-content:center;
  gap:.5em 1em;font-size:.92rem;color:rgba(244,239,228,.78)}
.book__contact a{border-bottom:1px solid rgba(205,178,127,.5);padding-bottom:1px;transition:color .2s,border-color .2s}
.book__contact a:hover{color:var(--paper);border-color:var(--paper)}
.book__dot{color:rgba(244,239,228,.4)}
.book__rating{display:inline-flex;align-items:center;gap:.45em;margin-left:.3em}
.book__rating .star{color:var(--gold)}
.book__rating b{font-style:normal;color:var(--paper)}

/* ============================ FOOTER ============================ */
.foot{background:var(--ink-2);color:rgba(244,239,228,.72);padding:clamp(48px,8vh,84px) var(--pad) 2em;
  --field:var(--ink-2)}
.foot__grid{max-width:var(--maxw);margin:0 auto;display:grid;
  grid-template-columns:minmax(0,1.5fr) minmax(0,1fr) minmax(0,1fr);gap:clamp(28px,5vw,72px);
  padding-bottom:2.4em;border-bottom:1px solid rgba(244,239,228,.14)}
.foot__logo{height:54px;width:auto;margin-bottom:1em;
  /* the logo is teal-on-cream; sit it on a soft cream chip so it reads on dark */
  background:var(--cream);padding:10px 14px;border-radius:var(--r)}
.foot__place{font-size:.9rem;letter-spacing:.02em;color:rgba(244,239,228,.66)}
.foot__h{font-family:var(--f-body);font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--gold);font-weight:600;margin-bottom:1em}
.foot__col p{font-size:.92rem;margin-bottom:.5em;line-height:1.5}
.foot__col a{transition:color .2s}
.foot__col a:hover{color:var(--paper)}
.foot__rate{color:var(--gold)!important}
.foot__book{margin-top:.7em;color:var(--cream);border-color:rgba(244,239,228,.35)}
.foot__book:hover{background:var(--cream);color:var(--ink);border-color:var(--cream)}
.foot__base{max-width:var(--maxw);margin:1.8em auto 0;display:flex;flex-wrap:wrap;gap:.6em 1.4em;
  justify-content:space-between;align-items:center;font-size:.82rem;color:rgba(244,239,228,.55)}
.foot__sign{font-family:var(--f-display);font-style:italic;color:var(--gold);letter-spacing:.02em}

/* ============================ REVEAL (motion) ============================ */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.is-in{opacity:1;transform:none}
.reveal--d1{transition-delay:.08s}
.reveal--d2{transition-delay:.16s}
.reveal--d3{transition-delay:.24s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1!important;transform:none!important;transition:none!important}
}

/* ============================================================================
   RESPONSIVE
   ============================================================================ */
@media (max-width:1080px){
  .nav__links{display:none}
  .nav__right{margin-left:auto}
  .plates{grid-auto-rows:clamp(140px,24vw,210px)}
}

@media (max-width:880px){
  .finca{grid-template-columns:minmax(0,1fr);gap:30px;align-items:start}
  .table{grid-template-columns:minmax(0,1fr)}
  .table__media{min-height:clamp(280px,46vh,440px);order:-1}
  .setting__scrim{background:linear-gradient(180deg,rgba(16,48,42,.32) 0%,rgba(16,48,42,.5) 45%,rgba(16,48,42,.9) 100%)}
  .setting{min-height:auto;padding:clamp(56px,10vh,96px) 0}
  /* THE FIVE -> 2-up cards on tablet */
  .bodies{grid-template-columns:repeat(2,minmax(0,1fr));border-top:0;gap:0}
  .body{border:1px solid rgba(244,239,228,.13)}
  .body + .body{border-left:1px solid rgba(244,239,228,.13)}
  .body:nth-child(odd){border-right:0}
  /* GROUNDS -> simpler 2-col mosaic */
  .plates{grid-template-columns:repeat(2,minmax(0,1fr));grid-auto-rows:clamp(150px,34vw,220px)}
  .plate--a,.plate--b,.plate--c,.plate--d,.plate--e,.plate--f{grid-column:span 1;grid-row:span 1}
  .plate--a{grid-column:span 2;grid-row:span 1}
}

@media (max-width:560px){
  body{font-size:16px}
  .nav{padding:11px var(--pad);gap:10px}
  .nav__logo{height:34px}
  .nav__book{display:none}              /* dates live in the hero + book section on phone */
  .nav__right{margin-left:auto;gap:10px}
  .hero{padding-bottom:26px}
  .hero__inner{padding-bottom:18px}
  .hero__title{font-size:clamp(2.7rem,13vw,4.2rem)}
  .hero__sub{font-size:1rem}
  .hero__cta .btn{flex:1 1 auto}
  .hero__scroll{display:none}
  /* THE REGISTER on phone — keep the rule, list 5 names cleanly w/ glyphs */
  .register__row{grid-template-columns:1fr 1fr;gap:7px 14px;padding-top:12px}
  .reg::before{display:none}
  .reg:nth-child(5){grid-column:1 / -1}
  .reg__name{font-size:.98rem}
  /* THE FIVE -> single column on phone */
  .bodies{grid-template-columns:minmax(0,1fr)}
  .body{border:0;border-bottom:1px solid rgba(244,239,228,.14)}
  .body + .body{border-left:0}
  .body__hit{padding:1.5em 0 1.4em}
  .body__es{font-size:1.7rem}
  .body__txt{font-size:.96rem}
  /* GROUNDS -> single column stack */
  .plates{grid-template-columns:minmax(0,1fr);grid-auto-rows:auto}
  .plate{aspect-ratio:3/2}
  .plate--a,.plate--f{aspect-ratio:16/10}
  .measure{grid-template-columns:minmax(0,1fr);gap:.2em}
  .dist__row dd{font-size:1rem}
  .book__register{gap:1em;font-size:1.2rem}
  .foot__grid{grid-template-columns:minmax(0,1fr);gap:30px}
  .foot__base{flex-direction:column;align-items:flex-start;gap:.4em}
  /* comfortable tap area for inline text links on phones */
  .foot__col p a,.book__contact a{display:inline-flex;align-items:center;min-height:44px}
  .book__contact{gap:.3em .9em}
}

@media (max-width:380px){
  .hero__title{font-size:clamp(2.4rem,13.5vw,3.4rem)}
  .register__row .reg__name{font-size:.92rem}
}
