/* =========================================================================
   FORUM — Boutique Hotel & Spa, old-town Alcúdia
   Concept: "Pollentia — the slow hour." The hotel sits on the Roman city of
   Pollentia; the name Forum is the classical hook. A quiet, warm, sensory
   adults-only spa expressed through classical restraint — fine hairline rules
   and a recurring FRIEZE DATUM (a laurel + tower glyph drawn from the real
   logo) set on a thin engraved line, like a Roman cornice cenefa. Never kitsch.
   Display: Cormorant Garamond. UI/body: Jost. Both self-hosted.
   Palette: limewash bone, charcoal ink, warm clay/antique-gold, sage whisper.
   ========================================================================= */

/* ----------------------------- fonts (self-hosted) ----------------------------- */
@font-face{font-family:'Cormorant Garamond';src:url('assets/fonts/CormorantGaramond-400.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Cormorant Garamond';src:url('assets/fonts/CormorantGaramond-400i.woff2') format('woff2');font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:'Cormorant Garamond';src:url('assets/fonts/CormorantGaramond-500.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Cormorant Garamond';src:url('assets/fonts/CormorantGaramond-500i.woff2') format('woff2');font-weight:500;font-style:italic;font-display:swap}
@font-face{font-family:'Cormorant Garamond';src:url('assets/fonts/CormorantGaramond-600.woff2') format('woff2');font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:'Jost';src:url('assets/fonts/Jost-400.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Jost';src:url('assets/fonts/Jost-500.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Jost';src:url('assets/fonts/Jost-600.woff2') format('woff2');font-weight:600;font-style:normal;font-display:swap}

:root{
  /* — ink & warm neutrals — */
  --ink:#2b2724;          /* charcoal, warm-black */
  --ink-2:#3a3531;
  --paper:#f4efe7;        /* limewash / bone page */
  --paper-2:#efe8dc;      /* a touch deeper */
  --sand:#e7dcc9;         /* warm stone band */
  --line:#e0d6c5;         /* hairline on paper */
  --line-2:#d2c5af;       /* slightly stronger rule */
  --muted:#7a7065;        /* warm grey ink for secondary text */

  /* — accents — */
  --clay:#a9744f;         /* warm dusk-stone clay / antique terracotta */
  --gold:#b08a4f;         /* antique-gold — rare glint */
  --sage:#7d8a72;         /* eucalyptus whisper (spa) */
  --sage-soft:#9caa90;

  --white:#ffffff;

  --measure:64ch;
  --pad:clamp(1.15rem, 5vw, 6rem);
  --maxw:1280px;
  --r:2px;                /* edges: nearly square, classical */

  --serif:'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --sans:'Jost', system-ui, -apple-system, 'Segoe UI', sans-serif;

  --t-slow:1100ms cubic-bezier(.16,.84,.34,1);
  --t:520ms cubic-bezier(.16,.84,.34,1);
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  font-size:clamp(1rem,.97rem + .18vw,1.075rem);
  line-height:1.7;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit}
h1,h2,h3{margin:0;font-weight:500;font-family:var(--serif);
  word-break:keep-all;overflow-wrap:normal;hyphens:none;letter-spacing:.004em}
p{margin:0}
em{font-style:italic}
::selection{background:var(--clay);color:var(--paper)}
:focus-visible{outline:2px solid var(--clay);outline-offset:3px}

.skip{position:absolute;left:-9999px;top:0;background:var(--ink);color:#fff;
  padding:.7em 1.1em;z-index:200;border-radius:0 0 var(--r) 0;font-size:.9rem}
.skip:focus{left:0}

/* ---------- the FRIEZE motif (signature) — laurel + tower on a hairline ---------- */
.frieze{position:relative;display:flex;align-items:center;justify-content:center;
  flex:1 1 auto;min-width:0;height:13px;color:var(--line-2)}
.frieze::before,.frieze::after{content:"";height:1px;background:currentColor;
  flex:1 1 auto;min-width:14px;opacity:.85}
.frieze__glyph{flex:0 0 auto;display:block;width:44px;height:26px;margin:0 .85rem;color:inherit}
.frieze__glyph svg{display:block;width:44px;height:26px}
.frieze__leaf{fill:none;stroke:currentColor;stroke-width:1.1;stroke-linecap:round}
.frieze__tower{fill:currentColor}
.frieze--ink{color:var(--clay)}
.frieze--light{color:rgba(255,255,255,.78)}

.divider{max-width:var(--maxw);margin-inline:auto;padding:clamp(2.2rem,6vw,4rem) var(--pad)}

/* ---------- kicker (section label — NO numbers, classical spaced caps) ---------- */
.kicker{display:flex;align-items:center;gap:.7rem;margin:0 0 1.15rem;
  font-family:var(--sans);font-size:.72rem;font-weight:500;letter-spacing:.34em;
  text-transform:uppercase;color:var(--clay)}
.kicker::before{content:"";width:26px;height:1px;background:currentColor;flex:0 0 auto;opacity:.9}
.kicker--sage{color:var(--sage)}
.kicker--light{color:rgba(255,255,255,.82)}
.kicker--light::before{background:rgba(255,255,255,.7)}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:var(--sans);font-weight:500;font-size:.8rem;letter-spacing:.13em;
  text-transform:uppercase;text-decoration:none;cursor:pointer;border:1px solid transparent;
  padding:.95em 1.6em;border-radius:var(--r);min-height:46px;line-height:1.1;
  transition:background var(--t),color var(--t),border-color var(--t),transform var(--t)}
.btn--solid{background:var(--ink);color:var(--paper)}
.btn--solid:hover{background:var(--clay);transform:translateY(-2px)}
.btn--line{background:transparent;color:var(--ink);border-color:var(--line-2)}
.btn--line:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.btn--ghost{background:rgba(20,18,16,.16);color:#fff;border-color:rgba(255,255,255,.55);
  backdrop-filter:blur(2px)}
.btn--ghost:hover{background:rgba(255,255,255,.16);border-color:#fff}
.btn--lg{padding:1.05em 1.9em;font-size:.84rem}
.btn--xl{padding:1.15em 2.15em;font-size:.86rem}

.link-arrow{display:inline-block;font-family:var(--sans);font-weight:500;font-size:.82rem;
  letter-spacing:.06em;text-transform:uppercase;text-decoration:none;color:var(--clay);
  border-bottom:1px solid currentColor;padding-bottom:2px;transition:color var(--t)}
.link-arrow:hover{color:var(--ink)}

/* ============================= HEADER ============================= */
.nav{position:fixed;inset:0 0 auto 0;z-index:100;display:flex;align-items:center;
  gap:1.5rem;padding:.85rem var(--pad);transition:background var(--t),box-shadow var(--t),
  border-color var(--t);border-bottom:1px solid transparent}
.nav__brand{display:flex;align-items:center;gap:.65rem;text-decoration:none;flex:0 0 auto;margin-right:auto}
.nav__mark{width:34px;height:34px;flex:0 0 auto;transition:filter var(--t)}
.nav__word{display:flex;flex-direction:column;line-height:1}
.nav__name{font-family:var(--serif);font-weight:600;font-size:1.5rem;letter-spacing:.02em}
.nav__sub{font-family:var(--sans);font-size:.6rem;letter-spacing:.26em;text-transform:uppercase;
  margin-top:.28em;opacity:.8}
.nav__links{display:flex;gap:1.7rem;align-items:center}
.nav__links a{font-family:var(--sans);font-size:.82rem;letter-spacing:.05em;text-decoration:none;
  padding:.3em 0;position:relative;transition:color var(--t)}
.nav__links a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;
  background:currentColor;transition:width var(--t)}
.nav__links a:hover::after{width:100%}
.nav__right{display:flex;align-items:center;gap:1.15rem;flex:0 0 auto}
.lang{display:flex;align-items:center;gap:.35rem}
.lang__btn{background:none;border:0;cursor:pointer;font-family:var(--sans);font-size:.78rem;
  letter-spacing:.08em;color:inherit;opacity:.55;padding:.45em .55em;min-height:44px;min-width:38px;
  transition:opacity var(--t)}
.lang__btn.is-active{opacity:1;font-weight:600}
.lang__btn:hover{opacity:.85}
.lang__sep{opacity:.4;font-size:.7rem}

/* header over hero (light text) vs solid (scrolled) */
.nav[data-theme="onhero"]{color:#fff}
.nav[data-theme="onhero"] .nav__mark{filter:brightness(0) invert(1)}
.nav[data-theme="solid"]{background:rgba(244,239,231,.94);color:var(--ink);
  border-color:var(--line);box-shadow:0 1px 0 rgba(43,39,36,.04),0 8px 30px -22px rgba(43,39,36,.5);
  backdrop-filter:saturate(1.05) blur(8px)}
@supports not (backdrop-filter:blur(1px)){.nav[data-theme="solid"]{background:var(--paper)}}

/* ============================= HERO ============================= */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;
  justify-content:flex-end;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:center 62%}
.hero__scrim{position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(180deg,rgba(24,20,17,.42) 0%,rgba(24,20,17,.05) 26%,rgba(24,20,17,0) 46%),
    linear-gradient(0deg,rgba(24,18,14,.82) 0%,rgba(24,18,14,.5) 24%,rgba(24,18,14,.12) 50%,rgba(24,18,14,0) 72%)}
.hero__inner{position:relative;width:100%;max-width:var(--maxw);margin-inline:auto;
  padding:0 var(--pad) clamp(1.4rem,3.5vw,2.4rem);color:#fff}
.hero__eyebrow{font-family:var(--sans);font-size:.74rem;font-weight:500;letter-spacing:.3em;
  text-transform:uppercase;color:rgba(255,255,255,.9);margin:0 0 1.1rem;
  display:flex;align-items:center;gap:.7rem}
.hero__eyebrow::before{content:"";width:30px;height:1px;background:rgba(255,255,255,.75)}
.hero__title{font-weight:500;line-height:.97;letter-spacing:0;
  font-size:clamp(3.1rem,11.5vw,8.2rem);text-shadow:0 2px 30px rgba(20,14,10,.32);
  max-width:15ch}
.hero__title .hero__l1,.hero__title .hero__l2,.hero__title .hero__l3{display:block}
.hero__l2{color:#fff}
.hero__l2 em{font-style:italic;color:#f0c9a6}
.hero__l3{color:rgba(255,255,255,.92)}
.hero__sub{font-family:var(--sans);font-size:clamp(1rem,1.5vw,1.16rem);line-height:1.62;
  max-width:46ch;margin:1.5rem 0 2rem;color:rgba(255,255,255,.94);font-weight:400}
.hero__cta{display:flex;flex-wrap:wrap;gap:.85rem}

.hero__frieze{position:relative;width:100%;max-width:var(--maxw);margin-inline:auto;
  padding:clamp(1.4rem,3vw,2rem) var(--pad) 1.1rem;display:flex;align-items:center;gap:1.1rem;
  color:#fff}
.hero__datum{flex:0 0 auto;font-family:var(--sans);font-size:.68rem;letter-spacing:.22em;
  text-transform:uppercase;color:rgba(255,255,255,.82);white-space:nowrap}
.hero__datum--r{text-align:right}

.hero__scroll{position:absolute;left:50%;top:clamp(74vh,84svh,90vh);transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:.45rem;text-decoration:none;
  color:rgba(255,255,255,.9);font-family:var(--sans);font-size:.64rem;letter-spacing:.26em;
  text-transform:uppercase}
.hero__scroll svg{width:16px;height:28px;overflow:visible}
.scroll-line{fill:none;stroke:rgba(255,255,255,.85);stroke-width:1.3;stroke-linecap:round;
  animation:scrollpulse 2.4s var(--t-slow) infinite}
@keyframes scrollpulse{0%,100%{opacity:.45;transform:translateY(0)}50%{opacity:1;transform:translateY(3px)}}

/* ============================= shared section frame ============================= */
.welcome,.building,.rooms,.spa,.book{max-width:var(--maxw);margin-inline:auto;
  padding-inline:var(--pad)}
.welcome{padding-block:clamp(4.5rem,9vw,8rem)}
.building{padding-block:clamp(1rem,3vw,2rem) clamp(4rem,8vw,7rem)}
.rooms{padding-block:clamp(3rem,6vw,5rem)}
.spa{padding-block:clamp(3rem,6vw,5rem)}
.book{padding-block:clamp(4.5rem,9vw,8rem)}

/* ============================= WELCOME ============================= */
.welcome{display:grid;grid-template-columns:minmax(0,1.04fr) minmax(0,.96fr);
  grid-template-areas:"copy fig" "ledger fig";gap:clamp(2rem,4vw,4rem) clamp(2.2rem,5vw,5rem);
  align-items:start}
.welcome__copy{grid-area:copy}
.welcome__fig{grid-area:fig;margin:0;position:relative;align-self:stretch}
.welcome__title{font-size:clamp(2.1rem,4.6vw,3.5rem);line-height:1.06;margin:0 0 1.5rem;max-width:18ch}
.welcome__title em{color:var(--clay);font-style:italic}
.welcome__lead{font-size:clamp(1.08rem,1.5vw,1.22rem);line-height:1.6;max-width:var(--measure);
  margin:0 0 1.25rem}
.welcome__p{color:var(--muted);max-width:var(--measure)}
.welcome__fig img{width:100%;height:100%;min-height:340px;object-fit:cover;border-radius:var(--r);
  filter:saturate(1.02)}
figure figcaption{display:flex;flex-direction:column;gap:.1rem;margin-top:.7rem;
  font-family:var(--sans);font-size:.78rem;color:var(--muted)}
figure .tag{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--clay);
  font-weight:500}

/* ledger */
.ledger{grid-area:ledger;margin:0;border-top:1px solid var(--line)}
.ledger__row{display:grid;grid-template-columns:minmax(0,9.5rem) minmax(0,1fr);gap:1rem;
  padding:.85rem 0;border-bottom:1px solid var(--line);align-items:baseline}
.ledger__k{font-family:var(--sans);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--muted)}
.ledger__v{font-family:var(--serif);font-size:1.18rem;line-height:1.3;color:var(--ink)}

/* ============================= BUILDING ============================= */
.building{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,.92fr);
  gap:clamp(2rem,5vw,4.5rem);align-items:center}
.building__media{margin:0;position:relative}
.building__media img{width:100%;border-radius:var(--r);filter:saturate(1.02);aspect-ratio:16/9;object-fit:cover}
.building__media::after{content:"";position:absolute;inset:0;border-radius:var(--r);
  box-shadow:inset 0 0 0 1px rgba(43,39,36,.06);pointer-events:none}
.building__title{font-size:clamp(2rem,4.2vw,3.2rem);line-height:1.07;margin:0 0 1.4rem;max-width:16ch}
.building__title em{color:var(--clay);font-style:italic}
.building__p{max-width:var(--measure);margin:0 0 1.1rem}
.building__p--soft{color:var(--muted)}
.building__inset{margin:1.8rem 0 0;max-width:28rem}
.building__inset img{width:100%;border-radius:var(--r)}

/* ============================= ROOMS ============================= */
.rooms__head{max-width:var(--maxw);margin:0 auto clamp(2.2rem,4vw,3rem)}
.rooms__title{font-size:clamp(2.1rem,4.6vw,3.4rem);line-height:1.06;margin:0 0 1.2rem;max-width:16ch}
.rooms__title em{color:var(--clay);font-style:italic}
.rooms__lede{max-width:60ch;color:var(--muted);font-size:1.06rem}
.cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(1.2rem,2.2vw,1.8rem)}
.card{display:flex;flex-direction:column;background:var(--white);border:1px solid var(--line);
  border-radius:var(--r);overflow:hidden;transition:transform var(--t),box-shadow var(--t),
  border-color var(--t)}
.card:hover{transform:translateY(-4px);box-shadow:0 24px 48px -34px rgba(43,39,36,.5);
  border-color:var(--line-2)}
.card__media{position:relative;aspect-ratio:4/3;overflow:hidden}
.card__media img{width:100%;height:100%;object-fit:cover;transition:transform var(--t-slow)}
.card:hover .card__media img{transform:scale(1.045)}
.card__body{padding:1.5rem 1.5rem 1.7rem;display:flex;flex-direction:column;gap:.7rem;flex:1 1 auto}
.card__name{font-size:1.6rem;line-height:1.1;color:var(--ink)}
.card__txt{font-size:.95rem;line-height:1.6;color:var(--muted);flex:1 1 auto}
.card__meta{list-style:none;margin:.2rem 0 0;padding:.85rem 0 0;border-top:1px solid var(--line);
  display:flex;flex-wrap:wrap;gap:.45rem}
.card__meta li{font-family:var(--sans);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--ink);background:var(--paper-2);border:1px solid var(--line);border-radius:100px;
  padding:.42em .85em}
.rooms__note{display:flex;flex-wrap:wrap;align-items:baseline;gap:.6rem 1.4rem;
  margin:clamp(2rem,3.5vw,2.8rem) 0 0;padding-top:1.6rem;border-top:1px solid var(--line);
  color:var(--muted);max-width:78ch}
.rooms__note > span{flex:1 1 28ch}

/* ============================= SPA ============================= */
.spa{background:linear-gradient(180deg,var(--paper) 0%,#eef0e8 100%);max-width:none;
  padding-inline:0;position:relative}
.spa::before,.spa::after{content:"";position:absolute;left:0;right:0;height:1px;background:var(--line)}
.spa::before{top:0}.spa::after{bottom:0}
.spa__grid{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad);
  display:grid;grid-template-columns:minmax(0,.95fr) minmax(0,1.05fr);
  gap:clamp(2rem,5vw,4.5rem);align-items:center}
.spa__title{font-size:clamp(2rem,4.4vw,3.3rem);line-height:1.07;margin:0 0 1.4rem;max-width:15ch}
.spa__title em{color:var(--sage);font-style:italic}
.spa__p{max-width:var(--measure);margin:0 0 1.1rem}
.spa__p--soft{color:var(--muted)}
.spa__list{list-style:none;margin:1.6rem 0 0;padding:0;display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));gap:.55rem 1.4rem;max-width:30rem}
.spa__list li{font-family:var(--sans);font-size:.92rem;padding:.55rem 0;
  border-bottom:1px solid var(--line);display:flex;align-items:center;gap:.6rem}
.spa__list li::before{content:"";width:6px;height:6px;border:1px solid var(--sage);border-radius:50%;
  flex:0 0 auto}
.spa__figs{display:grid;gap:clamp(1rem,1.8vw,1.4rem)}
.spa__fig{margin:0;position:relative;overflow:hidden;border-radius:var(--r)}
.spa__fig img{width:100%;display:block;filter:saturate(1.03)}
.spa__fig--hero img{aspect-ratio:16/9;object-fit:cover}
.spa__fig figcaption{position:absolute;left:0;bottom:0;margin:0;padding:.7rem .9rem;
  background:linear-gradient(0deg,rgba(20,18,16,.6),transparent)}
.spa__fig .tag{color:#fff;opacity:.95}

/* ============================= SETTING (full-bleed) ============================= */
.setting{position:relative;min-height:78svh;display:flex;align-items:center;overflow:hidden;
  isolation:isolate}
.setting__media{position:absolute;inset:0;z-index:-2}
.setting__media img{width:100%;height:100%;object-fit:cover;object-position:center 58%}
.setting__scrim{position:absolute;inset:0;z-index:-1;
  background:linear-gradient(90deg,rgba(22,16,12,.82) 0%,rgba(22,16,12,.55) 42%,rgba(22,16,12,.12) 72%,rgba(22,16,12,0) 100%)}
.setting__inner{width:100%;max-width:var(--maxw);margin-inline:auto;padding:clamp(3.5rem,7vw,6rem) var(--pad)}
.setting__panel{max-width:42rem;color:#fff}
.setting__title{font-size:clamp(2.1rem,5vw,3.6rem);line-height:1.05;margin:0 0 1.4rem;max-width:14ch}
.setting__title em{color:#f0c9a6;font-style:italic}
.setting__p{font-size:clamp(1rem,1.5vw,1.15rem);line-height:1.62;max-width:50ch;
  color:rgba(255,255,255,.94);margin:0 0 1.9rem}
.dist{margin:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0;
  border-top:1px solid rgba(255,255,255,.28)}
.dist__row{display:flex;flex-direction:column;gap:.18rem;padding:.95rem 1.2rem .95rem 0;
  border-bottom:1px solid rgba(255,255,255,.2)}
.dist__row dt{font-family:var(--sans);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(255,255,255,.7)}
.dist__row dd{margin:0;font-family:var(--serif);font-size:1.22rem;color:#fff}

/* ============================= BOOK ============================= */
.book{text-align:center}
.book__inner{max-width:60ch;margin-inline:auto}
.book__kick{justify-content:center}
.book__title{font-size:clamp(2.4rem,6vw,4.4rem);line-height:1.03;margin:0 0 1.3rem}
.book__title em{color:var(--clay);font-style:italic}
.book__txt{font-size:1.1rem;line-height:1.62;color:var(--muted);margin:0 auto 2.1rem;max-width:52ch}
.book__cta{display:flex;flex-wrap:wrap;gap:.85rem;justify-content:center;margin-bottom:2rem}
.book__contact{display:flex;flex-wrap:wrap;gap:.5rem .9rem;align-items:center;justify-content:center;
  font-family:var(--sans);font-size:.92rem;color:var(--ink)}
.book__contact a{text-decoration:none;border-bottom:1px solid var(--line-2);padding-bottom:1px;
  transition:color var(--t),border-color var(--t)}
.book__contact a:hover{color:var(--clay);border-color:var(--clay)}
.book__dot{opacity:.4}
.book__where{color:var(--muted)}

/* ============================= FOOTER ============================= */
.foot{background:var(--ink);color:rgba(255,255,255,.82);padding:clamp(3rem,6vw,4.5rem) var(--pad) 2rem}
.foot__grid{max-width:var(--maxw);margin:0 auto;display:grid;
  grid-template-columns:minmax(0,1.4fr) minmax(0,1fr) minmax(0,1fr);gap:clamp(2rem,4vw,3.5rem)}
.foot__mark{width:46px;height:46px;filter:brightness(0) invert(1);opacity:.92;margin-bottom:.6rem}
.foot__name{font-family:var(--serif);font-weight:600;font-size:1.7rem;color:#fff;margin:0 0 .4rem;
  letter-spacing:.02em}
.foot__place{font-size:.86rem;line-height:1.55;max-width:34ch;color:rgba(255,255,255,.66)}
.foot__h{font-family:var(--sans);font-size:.72rem;font-weight:600;letter-spacing:.2em;
  text-transform:uppercase;color:#fff;margin:0 0 .9rem}
.foot__col p{font-size:.9rem;line-height:1.5;margin:0 0 .5rem;color:rgba(255,255,255,.72)}
.foot__col a{text-decoration:none;border-bottom:1px solid rgba(255,255,255,.25);padding-bottom:1px;
  transition:color var(--t),border-color var(--t)}
.foot__col a:hover{color:#fff;border-color:rgba(255,255,255,.6)}
.foot__book{margin-top:.7rem;color:#fff;border-color:rgba(255,255,255,.4)}
.foot__book:hover{background:#fff;color:var(--ink);border-color:#fff}
.foot__base{max-width:var(--maxw);margin:2.4rem auto 0;padding-top:1.4rem;
  border-top:1px solid rgba(255,255,255,.14);display:flex;flex-wrap:wrap;gap:.5rem 1.5rem;
  justify-content:space-between;align-items:center}
.foot__rights,.foot__sign{font-size:.8rem;color:rgba(255,255,255,.55);margin:0}
.foot__sign{font-family:var(--serif);font-style:italic;font-size:1rem;color:rgba(255,255,255,.7)}

/* ============================= reveal-on-scroll ============================= */
.reveal{opacity:0;transform:translateY(22px);transition:opacity var(--t-slow),transform var(--t-slow)}
.reveal.in{opacity:1;transform:none}
html.no-js .reveal{opacity:1;transform:none}

/* ============================= RESPONSIVE ============================= */
@media (max-width:1080px){
  .nav__links{gap:1.25rem}
  .nav__links a{font-size:.78rem}
}

@media (max-width:980px){
  .nav__links{display:none}
  .welcome{grid-template-columns:minmax(0,1fr);grid-template-areas:"copy" "fig" "ledger";
    gap:2.2rem}
  .welcome__fig img{min-height:0;aspect-ratio:16/10}
  .building{grid-template-columns:minmax(0,1fr);gap:2rem}
  .building__media{order:-1}
  .building__inset{max-width:none}
  .spa__grid{grid-template-columns:minmax(0,1fr);gap:2.2rem}
  .spa__copy{order:-1}
  .cards{grid-template-columns:repeat(2,minmax(0,1fr))}
}

@media (max-width:680px){
  :root{--pad:1.25rem}
  .nav{gap:.8rem;padding-block:.7rem}
  .nav__sub{display:none}
  .nav__name{font-size:1.32rem}
  .nav__book{display:none}
  .nav__right{gap:.5rem}
  .hero{justify-content:flex-end}
  .hero__title{font-size:clamp(2.9rem,15vw,4.6rem)}
  .hero__sub{font-size:1rem}
  .hero__cta{gap:.6rem}
  .hero__cta .btn{flex:1 1 auto}
  .hero__frieze{gap:.5rem;padding-bottom:1rem}
  .hero__datum{display:none}
  .hero__scroll{display:none}
  .cards{grid-template-columns:minmax(0,1fr)}
  /* comfortable tap targets for inline links on touch */
  .link-arrow{min-height:44px;display:inline-flex;align-items:center}
  .rooms__note{gap:.4rem .8rem}
  .book__contact{gap:.2rem .9rem;line-height:1.2}
  .book__contact a{min-height:44px;display:inline-flex;align-items:center}
  .foot__col p{margin-bottom:.15rem}
  .foot__col a:not(.btn){min-height:44px;display:inline-flex;align-items:center}
  .foot__book{min-height:46px}
  .spa__list{grid-template-columns:repeat(2,minmax(0,1fr));gap:.4rem 1rem}
  .dist{grid-template-columns:minmax(0,1fr)}
  .foot__grid{grid-template-columns:minmax(0,1fr);gap:2rem}
  .ledger__row{grid-template-columns:minmax(0,7.5rem) minmax(0,1fr);gap:.8rem}
}

@media (max-width:380px){
  .hero__title{font-size:clamp(2.6rem,15vw,3.4rem)}
  .ledger__row{grid-template-columns:minmax(0,1fr);gap:.15rem}
  .ledger__k{padding-top:.2rem}
}

/* ============================= reduced-motion + print ============================= */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1!important;transform:none!important}
}
@media print{
  .nav,.hero__scroll,.hero__cta,.book__cta{display:none}
  .reveal{opacity:1!important;transform:none!important}
  *{color:#000!important;background:#fff!important}
}
