/* ============================================================
   HOSTAL ATLANTA — "A few minutes from the sand"
   Concept: a distance ledger / walk-line from the door to the beach.
   Type: Tenor Sans (display) + Inter (body). Palette: terracotta on cream.
   ============================================================ */

/* ---------- fonts (self-hosted) ---------- */
@font-face{
  font-family:"Tenor Sans"; font-style:normal; font-weight:400; font-display:swap;
  src:url("assets/fonts/tenor-sans-latin-400.woff2") format("woff2");
}
@font-face{
  font-family:"InterVar"; font-style:normal; font-weight:100 900; font-display:swap;
  src:url("assets/fonts/inter-latin.woff2") format("woff2");
}

/* ---------- tokens ---------- */
:root{
  /* palette — terracotta + cream, pulled from the building's real plinth & light */
  --cream:    #F7EFE4;   /* page */
  --cream-2:  #F1E6D6;   /* alt band */
  --paper:    #FBF6EE;   /* card */
  --terra:    #B65A3C;   /* primary terracotta */
  --terra-d:  #984427;   /* deeper, hovers */
  --terra-ink:#5A2A1B;   /* warm near-black ink */
  --sand:     #E7B98A;   /* warm accent */
  --apricot:  #F2C9A0;   /* soft accent (the walk-line) */
  --sky:      #2F6E86;   /* a single cool trace from the Mediterranean sky */
  --ink:      #33271F;   /* body text */
  --ink-soft: #6B5848;   /* secondary text */
  --line:     #D9C7B0;   /* hairlines on cream */
  --white:    #FFFDF9;

  --maxw: 1240px;
  --pad:  clamp(20px, 5.2vw, 88px);
  --gut:  clamp(26px, 4.6vw, 70px);

  --fast: .22s; --med: .5s; --slow: .9s;
  --ease: cubic-bezier(.22,.61,.36,1);

  --r:   14px;   /* soft, grounded edges — a friendly hostal */
  --r-sm: 9px;
}

*{ 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:"InterVar", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  font-size:17px; line-height:1.6; letter-spacing:.005em;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; }
h1,h2,h3{ font-family:"Tenor Sans", "Times New Roman", serif; font-weight:400; letter-spacing:.01em; }
a{ color:inherit; }

.skip{ position:absolute; left:-9999px; top:0; background:var(--terra); color:var(--white);
  padding:10px 16px; border-radius:0 0 var(--r-sm) 0; z-index:200; }
.skip:focus{ left:0; }

/* ---------- buttons ---------- */
.btn{
  --bg:var(--terra); --fg:var(--white); --bd:var(--terra);
  display:inline-flex; align-items:center; justify-content:center; gap:.5em;
  font-family:"InterVar",sans-serif; font-weight:600; font-size:.96rem; letter-spacing:.02em;
  min-height:48px; padding:.72em 1.5em; border:1.5px solid var(--bd); border-radius:999px;
  background:var(--bg); color:var(--fg); cursor:pointer; text-decoration:none;
  transition:transform var(--fast) var(--ease), background var(--fast) var(--ease),
             color var(--fast) var(--ease), border-color var(--fast) var(--ease), box-shadow var(--fast) var(--ease);
  white-space:nowrap;
}
.btn--solid{ box-shadow:0 8px 22px -12px rgba(152,68,39,.6); }
.btn--solid:hover{ background:var(--terra-d); border-color:var(--terra-d); transform:translateY(-2px); box-shadow:0 12px 26px -12px rgba(152,68,39,.7); }
.btn--ghost{ --bg:transparent; --fg:var(--terra-ink); --bd:var(--terra); }
.btn--ghost:hover{ background:var(--terra); color:var(--white); transform:translateY(-2px); }
.btn--lg{ min-height:54px; padding:.85em 1.8em; font-size:1.02rem; }
.btn--xl{ min-height:58px; padding:.95em 2.1em; font-size:1.06rem; }
.btn:focus-visible{ outline:3px solid var(--sky); outline-offset:3px; }

.link-tick{ font-weight:600; color:var(--terra-d); text-decoration:none; white-space:nowrap;
  border-bottom:1.5px solid var(--sand); padding-bottom:1px; transition:border-color var(--fast), color var(--fast); }
.link-tick::before{ content:"→ "; color:var(--terra); }
.link-tick:hover{ color:var(--terra); border-color:var(--terra); }

/* ---------- wordmark ---------- */
.wordmark{ display:inline-flex; align-items:baseline; gap:.34em; line-height:1; }
.wordmark__a{
  font-family:"Tenor Sans",serif; font-size:1.42em; color:var(--white);
  background:var(--terra); width:1.42em; height:1.42em; border-radius:8px;
  display:inline-flex; align-items:center; justify-content:center; transform:translateY(.12em);
  box-shadow:0 4px 12px -6px rgba(152,68,39,.7);
}
.wordmark__name{ font-family:"Tenor Sans",serif; font-size:1.32em; letter-spacing:.06em; color:var(--terra-ink); }
.nav__brand{ display:inline-flex; flex-direction:column; justify-content:center; gap:.18em; text-decoration:none; min-height:44px; }
.wordmark__sub{ font-size:.62rem; letter-spacing:.28em; text-transform:uppercase; color:var(--ink-soft); padding-left:.2em; }

/* ---------- header ---------- */
.nav{
  position:sticky; top:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between; gap:var(--gut);
  padding:12px var(--pad); background:rgba(247,239,228,.86);
  backdrop-filter:saturate(1.4) blur(12px); border-bottom:1px solid var(--line);
}
.nav__links{ display:flex; gap:clamp(14px,1.8vw,30px); margin-left:auto; }
.nav__links a{ text-decoration:none; font-size:.92rem; font-weight:500; color:var(--terra-ink); letter-spacing:.01em;
  padding:.4em 0; position:relative; transition:color var(--fast); }
.nav__links a::after{ content:""; position:absolute; left:0; right:100%; bottom:-2px; height:2px;
  background:var(--terra); transition:right var(--med) var(--ease); }
.nav__links a:hover{ color:var(--terra); }
.nav__links a:hover::after{ right:0; }
.nav__right{ display:flex; align-items:center; gap:clamp(10px,1.4vw,18px); }
.nav__book{ min-height:42px; padding:.55em 1.15em; font-size:.9rem; }

.lang{ display:inline-flex; align-items:center; gap:.18em; }
.lang__btn{ background:none; border:0; cursor:pointer; font:inherit; font-size:.82rem; font-weight:600;
  color:var(--ink-soft); padding:.5em .5em; min-height:44px; min-width:40px; border-radius:8px;
  transition:color var(--fast), background var(--fast); letter-spacing:.04em; }
.lang__btn:hover{ color:var(--terra); }
.lang__btn.is-active{ color:var(--white); background:var(--terra); }
.lang__btn:focus-visible{ outline:2px solid var(--sky); outline-offset:2px; }
.lang__sep{ color:var(--line); font-size:.78rem; }

/* ---------- kicker ---------- */
.kicker{ display:flex; align-items:center; gap:.7em; font-family:"InterVar",sans-serif;
  font-size:.74rem; font-weight:600; letter-spacing:.22em; text-transform:uppercase; color:var(--terra-d); margin:0 0 1.1em; }
.kicker__no{ font-family:"Tenor Sans",serif; font-size:.95rem; letter-spacing:.04em; color:var(--white);
  background:var(--terra); width:2em; height:2em; border-radius:7px; display:inline-flex; align-items:center; justify-content:center; }
.kicker--light{ color:var(--apricot); }
.kicker--light .kicker__no{ background:var(--apricot); color:var(--terra-ink); }

/* =========================================================
   HERO — full-bleed photographic statement (100svh)
   ========================================================= */
.hero{ position:relative; min-height:100svh; min-height:100dvh; display:flex; flex-direction:column;
  justify-content:flex-end; padding:0 var(--pad) clamp(96px,16vh,150px); overflow:hidden; isolation:isolate; }
.hero__media{ position:absolute; inset:0; z-index:-2; }
.hero__media img{ width:100%; height:100%; object-fit:cover; object-position:50% 42%;
  filter:saturate(1.06) contrast(1.03); }
.hero__scrim{ position:absolute; inset:0; z-index:-1;
  background:
    linear-gradient(to top, rgba(45,22,12,.82) 0%, rgba(45,22,12,.42) 34%, rgba(45,22,12,.06) 60%, rgba(45,22,12,.16) 100%),
    linear-gradient(to right, rgba(45,22,12,.34), rgba(45,22,12,0) 56%); }

.hero__inner{ position:relative; max-width:min(760px,94%); z-index:1; color:var(--white);
  opacity:0; transform:translateY(20px); animation:rise .9s var(--ease) .12s forwards; }
.hero__eyebrow{ font-size:.8rem; font-weight:600; letter-spacing:.26em; text-transform:uppercase;
  color:var(--apricot); margin:0 0 .9em; }
.hero__title{ font-size:clamp(2.7rem, 8.4vw, 6rem); line-height:1.02; margin:0; color:var(--white);
  text-shadow:0 2px 30px rgba(45,22,12,.4); word-break:keep-all; overflow-wrap:normal; hyphens:none; }
.hero__line{ display:block; }
.hero__line--accent{ color:var(--apricot); font-style:normal; }
.hero__sub{ font-size:clamp(1.04rem,2.1vw,1.26rem); line-height:1.55; max-width:50ch; margin:1.1em 0 0;
  color:rgba(255,253,249,.94); }
.hero__cta{ display:flex; flex-wrap:wrap; gap:.8em; margin-top:1.8em; }
.hero__cta .btn--ghost{ --fg:var(--white); --bd:rgba(255,253,249,.7); }
.hero__cta .btn--ghost:hover{ --bg:var(--white); --fg:var(--terra-ink); --bd:var(--white); }

/* the WALK-LINE — signature moment */
.walkline{ position:absolute; left:var(--pad); right:var(--pad); bottom:clamp(40px,8vh,64px); z-index:1;
  display:flex; align-items:center; gap:clamp(10px,1.6vw,18px); color:var(--white);
  opacity:0; animation:fade .8s var(--ease) .7s forwards; }
.walkline__from{ font-size:.78rem; font-weight:600; letter-spacing:.16em; text-transform:uppercase; white-space:nowrap; color:rgba(255,253,249,.92); }
.walkline__to{ font-size:.84rem; letter-spacing:.06em; white-space:nowrap; color:rgba(255,253,249,.96); }
.walkline__to b{ color:var(--apricot); font-weight:700; }
.walkline__track{ position:relative; flex:1 1 auto; min-width:30px; height:2px; }
.walkline__dash{ position:absolute; inset:0; top:50%; transform:translateY(-50%); height:0;
  border-top:2px dashed rgba(242,201,160,.85); }
.walkline__foot{ position:absolute; top:50%; left:0; width:16px; height:22px; transform:translate(0,-50%);
  animation:stroll 5.5s var(--ease) infinite; }
.walkline__foot svg{ width:100%; height:100%; fill:var(--apricot); filter:drop-shadow(0 2px 3px rgba(45,22,12,.45)); }
@keyframes stroll{ 0%{ left:2%; } 46%{ left:calc(100% - 16px); } 54%{ left:calc(100% - 16px); } 100%{ left:2%; } }

.hero__scroll{ position:absolute; right:var(--pad); bottom:clamp(40px,8vh,64px); z-index:2;
  display:none; flex-direction:column; align-items:center; gap:6px; text-decoration:none;
  color:rgba(255,253,249,.9); font-size:.66rem; letter-spacing:.22em; text-transform:uppercase; }
.hero__scroll svg{ width:16px; height:26px; }
.scroll-line{ stroke:var(--apricot); stroke-width:2; fill:none; stroke-linecap:round; }
.scroll-dot{ animation:bob 1.8s var(--ease) infinite; }
@keyframes bob{ 0%,100%{ transform:translateY(0); opacity:1;} 50%{ transform:translateY(4px); opacity:.5;} }

/* =========================================================
   THE WALK — distance ledger (the concept, made content)
   ========================================================= */
.walk{ max-width:var(--maxw); margin-inline:auto; padding:clamp(64px,11vw,140px) var(--pad) clamp(48px,8vw,96px); }
.walk__head{ max-width:64ch; }
.walk__title{ font-size:clamp(2rem,5.2vw,3.5rem); color:var(--terra-ink); margin:.1em 0 .5em; max-width:18ch; line-height:1.08; }
.walk__lede{ color:var(--ink-soft); font-size:clamp(1.04rem,2vw,1.22rem); max-width:56ch; margin:0; }

.ledger{ list-style:none; margin:clamp(40px,6vw,68px) 0 0; padding:0;
  border-top:1.5px solid var(--line); }
.ledger__row{ display:flex; align-items:baseline; gap:clamp(12px,2vw,22px);
  padding:clamp(15px,2.2vw,22px) 0; border-bottom:1px solid var(--line); position:relative; }
.ledger__place{ font-family:"Tenor Sans",serif; font-size:clamp(1.16rem,2.7vw,1.7rem); color:var(--ink);
  letter-spacing:.01em; flex:0 1 auto; min-width:0; }
.ledger__rule{ flex:1 1 auto; min-width:18px; align-self:center; height:0;
  border-top:2px dotted var(--sand); transform:translateY(2px); }
.ledger__dist{ flex:0 0 auto; display:inline-flex; align-items:baseline; gap:.5em; }
.ledger__dist b{ font-family:"Tenor Sans",serif; font-size:clamp(1.16rem,2.7vw,1.7rem); color:var(--terra-d); }
.ledger__unit{ font-size:.74rem; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-soft); }
.ledger__row::before{ content:""; position:absolute; left:0; bottom:-1px; width:0; height:2px;
  background:var(--terra); transition:width var(--slow) var(--ease); }
.ledger__row.in::before{ width:100%; }

/* =========================================================
   THE HOSTAL
   ========================================================= */
.stay{ background:var(--cream-2); padding:clamp(64px,11vw,140px) var(--pad);
  display:grid; grid-template-columns:minmax(0,1fr); gap:clamp(36px,5vw,72px); }
.stay__copy{ max-width:60ch; }
.stay__title{ font-size:clamp(1.9rem,4.8vw,3.2rem); color:var(--terra-ink); margin:.1em 0 .6em; max-width:20ch; line-height:1.1; }
.stay__intro{ color:var(--ink); font-size:clamp(1.04rem,1.9vw,1.2rem); margin:0 0 1.05em; }
.stay__p{ color:var(--ink-soft); margin:0 0 1.4em; max-width:56ch; }

.facts{ display:grid; grid-template-columns:minmax(0,1fr) minmax(0,1fr); gap:1px;
  background:var(--line); border:1px solid var(--line); border-radius:var(--r); overflow:hidden; margin:0; }
.fact{ background:var(--paper); padding:clamp(16px,2.2vw,24px); }
.fact__k{ font-size:.72rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--terra-d); margin:0 0 .4em; }
.fact__v{ margin:0; color:var(--ink); font-size:.98rem; line-height:1.45; }
.fact__v b{ font-family:"Tenor Sans",serif; font-size:1.3em; color:var(--terra-ink); }

.stay__fig{ margin:0; position:relative; border-radius:var(--r); overflow:hidden;
  box-shadow:0 30px 60px -34px rgba(90,42,27,.5); }
.stay__fig img{ width:100%; height:100%; object-fit:cover; aspect-ratio:4/3; }
.stay__cap{ position:absolute; left:0; bottom:0; right:0; display:flex; align-items:baseline; gap:.6em;
  padding:clamp(14px,2vw,20px); color:var(--white);
  background:linear-gradient(to top, rgba(45,22,12,.8), rgba(45,22,12,0)); }
.stay__cap-tag{ font-size:.68rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--apricot); }
.stay__cap span:last-child{ font-size:.9rem; }

/* =========================================================
   ROOMS / PRICE — dark terracotta band for contrast
   ========================================================= */
.rooms{ background:var(--terra-ink); color:var(--white); padding:clamp(66px,11vw,144px) var(--pad); }
.rooms__head{ max-width:var(--maxw); margin:0 auto clamp(40px,6vw,64px); }
.rooms__title{ font-size:clamp(1.9rem,5vw,3.3rem); color:var(--white); margin:.1em 0 .5em; max-width:20ch; line-height:1.08; }
.rooms__lede{ color:rgba(255,253,249,.82); max-width:58ch; font-size:clamp(1.02rem,1.9vw,1.18rem); margin:0; }

.cards{ max-width:var(--maxw); margin-inline:auto;
  display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:clamp(16px,2vw,26px); }
.card{ position:relative; background:rgba(251,246,238,.06); border:1px solid rgba(251,246,238,.18);
  border-radius:var(--r); padding:clamp(24px,3vw,34px); display:flex; flex-direction:column;
  transition:transform var(--med) var(--ease), background var(--med) var(--ease), border-color var(--med) var(--ease); }
.card:hover{ transform:translateY(-5px); background:rgba(251,246,238,.1); border-color:rgba(242,201,160,.5); }
.card__no{ font-family:"Tenor Sans",serif; font-size:.86rem; letter-spacing:.1em; color:var(--apricot); }
.card__name{ font-size:clamp(1.4rem,2.6vw,1.78rem); color:var(--white); margin:.5em 0 .5em; }
.card__txt{ color:rgba(255,253,249,.8); font-size:.96rem; margin:0 0 1.3em; flex:1 1 auto; }
.card__meta{ list-style:none; margin:0 0 1.3em; padding:0; display:flex; flex-wrap:wrap; gap:.5em; }
.card__meta li{ font-size:.76rem; letter-spacing:.04em; color:var(--apricot);
  border:1px solid rgba(242,201,160,.4); border-radius:999px; padding:.34em .8em; }
.card__price{ margin:0; padding-top:1.1em; border-top:1px solid rgba(251,246,238,.18);
  display:flex; align-items:baseline; gap:.4em; color:var(--white); }
.card__from{ font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,253,249,.66); }
.card__price b{ font-family:"Tenor Sans",serif; font-size:2rem; color:var(--apricot); }
.card__per{ font-size:.82rem; color:rgba(255,253,249,.7); }
.card--feature{ background:rgba(242,201,160,.12); border-color:rgba(242,201,160,.55); }
.card__flag{ position:absolute; top:-12px; right:18px; background:var(--apricot); color:var(--terra-ink);
  font-size:.68rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; padding:.4em .85em; border-radius:999px; }

.rooms__note{ max-width:var(--maxw); margin:clamp(34px,5vw,54px) auto 0; padding-top:1.5em;
  border-top:1px solid rgba(251,246,238,.2); color:rgba(255,253,249,.8); font-size:.98rem;
  display:flex; flex-wrap:wrap; align-items:baseline; gap:.5em 1.2em; }
.rooms__note .link-tick{ color:var(--apricot); border-color:rgba(242,201,160,.5); }
.rooms__note .link-tick::before{ color:var(--apricot); }
.rooms__note .link-tick:hover{ color:var(--white); border-color:var(--white); }

/* =========================================================
   AROUND
   ========================================================= */
.around{ padding:clamp(64px,11vw,140px) var(--pad); }
.around__inner{ max-width:var(--maxw); margin-inline:auto;
  display:grid; grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr); gap:clamp(34px,5vw,72px); align-items:start; }
.around__title{ font-size:clamp(1.9rem,4.8vw,3.1rem); color:var(--terra-ink); margin:.1em 0 .55em; max-width:16ch; line-height:1.1; }
.around__p{ color:var(--ink-soft); margin:0 0 1.2em; max-width:54ch; font-size:clamp(1rem,1.8vw,1.13rem); }
.chips{ list-style:none; margin:.4em 0 0; padding:0; display:flex; flex-wrap:wrap; gap:.7em; align-content:flex-start; }
.chip{ font-family:"InterVar",sans-serif; font-size:.92rem; font-weight:500; color:var(--terra-ink);
  background:var(--paper); border:1px solid var(--line); border-radius:999px; padding:.62em 1.15em;
  transition:transform var(--fast) var(--ease), background var(--fast), color var(--fast), border-color var(--fast); }
.chip::before{ content:"·"; color:var(--terra); font-weight:700; margin-right:.5em; }
.chip:hover{ transform:translateY(-2px); background:var(--terra); color:var(--white); border-color:var(--terra); }
.chip:hover::before{ color:var(--apricot); }

/* =========================================================
   BOOK
   ========================================================= */
.book{ background:var(--cream-2); padding:clamp(70px,12vw,152px) var(--pad); }
.book__inner{ max-width:760px; margin-inline:auto; text-align:center; }
.walkline--book{ position:static; max-width:340px; margin:0 auto clamp(26px,4vw,38px); color:var(--terra-ink); opacity:1; animation:none; }
.walkline--book .walkline__from{ color:var(--terra-d); }
.walkline--book .walkline__to{ color:var(--ink-soft); }
.walkline--book .walkline__dash{ border-top-color:var(--sand); }
.walkline--book .walkline__foot{ animation:none; left:calc(50% - 8px); }
.walkline--book .walkline__foot svg{ fill:var(--terra); filter:none; }
.book__kick{ justify-content:center; }
.book__title{ font-size:clamp(2.1rem,5.6vw,3.6rem); color:var(--terra-ink); margin:0 0 .5em; line-height:1.06; }
.book__txt{ color:var(--ink-soft); max-width:52ch; margin:0 auto 2em; font-size:clamp(1.02rem,1.9vw,1.16rem); }
.book__cta{ display:flex; flex-wrap:wrap; gap:.8em; justify-content:center; }
.book__contact{ display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:.5em 1em;
  margin:clamp(28px,4vw,44px) auto 0; padding-top:1.4em; border-top:1px solid var(--line); max-width:560px; }
.book__contact a{ color:var(--terra-d); text-decoration:none; font-weight:600; border-bottom:1.5px solid var(--sand); padding-bottom:1px; }
.book__contact a:hover{ color:var(--terra); border-color:var(--terra); }
.book__dot{ color:var(--line); }
.book__rating{ display:inline-flex; align-items:center; gap:.4em; color:var(--ink-soft); font-size:.94rem; flex-basis:100%; justify-content:center; margin-top:.3em; }
.book__rating b{ color:var(--terra-ink); font-family:"Tenor Sans",serif; font-size:1.1em; }
.star{ color:var(--sand); }
.book__pay{ margin:1.4em 0 0; font-size:.84rem; letter-spacing:.04em; color:var(--ink-soft); }

/* =========================================================
   FOOTER
   ========================================================= */
.foot{ background:var(--terra-ink); color:rgba(255,253,249,.82); padding:clamp(56px,9vw,96px) var(--pad) clamp(28px,4vw,40px); }
.foot__grid{ max-width:var(--maxw); margin-inline:auto;
  display:grid; grid-template-columns:minmax(0,1.4fr) minmax(0,1fr) minmax(0,1fr); gap:clamp(30px,5vw,60px); }
.wordmark--foot .wordmark__a{ background:var(--apricot); color:var(--terra-ink); box-shadow:none; }
.wordmark--foot .wordmark__name{ color:var(--white); }
.foot__place{ margin:1em 0 .4em; font-size:.92rem; color:rgba(255,253,249,.78); }
.foot__line{ margin:0; font-family:"Tenor Sans",serif; font-size:1.05rem; color:var(--apricot); letter-spacing:.01em; }
.foot__h{ font-family:"InterVar",sans-serif; font-size:.74rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--apricot); margin:0 0 .8em; }
.foot__col p{ margin:0 0 .5em; font-size:.94rem; color:rgba(255,253,249,.8); }
.foot__col a{ color:rgba(255,253,249,.92); text-decoration:none; border-bottom:1px solid rgba(242,201,160,.4); transition:border-color var(--fast); }
.foot__col a:hover{ border-color:var(--apricot); }
.foot__book{ --fg:var(--apricot); --bd:rgba(242,201,160,.6); margin-top:.6em; min-height:44px; }
.foot__book:hover{ --bg:var(--apricot); --fg:var(--terra-ink); --bd:var(--apricot); }
.foot__base{ max-width:var(--maxw); margin:clamp(40px,6vw,64px) auto 0; padding-top:1.4em;
  border-top:1px solid rgba(251,246,238,.16); display:flex; flex-wrap:wrap; justify-content:space-between; gap:.6em;
  font-size:.84rem; color:rgba(255,253,249,.6); }
.foot__sign{ margin:0; font-style:normal; color:var(--apricot); }
.foot__rights{ margin:0; }

/* =========================================================
   MOTION — reveal on scroll (mobile-first; reduced-motion safe)
   ========================================================= */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity var(--slow) var(--ease), transform var(--slow) var(--ease); will-change:opacity,transform; }
.reveal.in{ opacity:1; transform:none; }
.reveal--d1{ transition-delay:.07s; }
.reveal--d2{ transition-delay:.14s; }
.reveal--d3{ transition-delay:.21s; }
@keyframes rise{ to{ opacity:1; transform:none; } }
@keyframes fade{ to{ opacity:1; } }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1 !important; transform:none !important; }
  .hero__inner,.walkline{ opacity:1 !important; transform:none !important; animation:none !important; }
  .walkline__foot,.scroll-dot,.ledger__row::before{ animation:none !important; }
  .ledger__row.in::before{ transition:none; }
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (min-width:760px){
  .stay{ grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr); align-items:center; }
  .hero__scroll{ display:flex; }
}
@media (min-width:1000px){
  .stay{ gap:clamp(48px,5vw,84px); }
}

/* ---- tablet / phone ---- */
@media (max-width:880px){
  .nav__links{ display:none; }
  .around__inner{ grid-template-columns:minmax(0,1fr); gap:clamp(28px,5vw,40px); }
}
@media (max-width:680px){
  body{ font-size:16px; }
  .nav{ padding:10px var(--pad); gap:12px; }
  .wordmark__sub{ display:none; }
  .nav__book{ display:none; }                 /* primary CTA lives in hero + sticky book; keep header clean */
  .hero{ padding-bottom:clamp(120px,22vh,170px); }
  .hero__media img{ object-position:50% 38%; }
  .hero__eyebrow{ font-size:.66rem; letter-spacing:.16em; margin-bottom:1.05em; }
  .hero__title{ font-size:clamp(2.6rem,11.6vw,3.7rem); }
  .hero__cta{ gap:.6em; }
  .hero__cta .btn{ flex:1 1 auto; }
  .walkline{ bottom:clamp(34px,7vh,52px); gap:10px; }
  .walkline__from{ font-size:.7rem; letter-spacing:.12em; }
  .walkline__to{ font-size:.78rem; }
  .cards{ grid-template-columns:minmax(0,1fr); }
  .card__flag{ right:14px; }
  .facts{ grid-template-columns:minmax(0,1fr); }
  .ledger__place{ font-size:1.1rem; }
  .ledger__dist b{ font-size:1.1rem; }
  .foot__grid{ grid-template-columns:minmax(0,1fr); gap:clamp(26px,7vw,38px); }
  .foot__base{ flex-direction:column; }
  /* give inline contact + index links a comfortable touch area on phones */
  .book__contact a, .foot__col a, .rooms__note .link-tick{ display:inline-block; padding-block:.5em; }
  .book__contact{ gap:.2em 1em; }
}
@media (max-width:380px){
  .ledger__unit{ display:none; }              /* tighten the ledger row on the very narrowest screens */
  .ledger__row{ gap:10px; }
}
