/* ============================================================
   Bennoc Petit-Hotel — styles.css
   Concept: "El Clastre · MCCXXXII" — eight centuries read around a
   Moorish courtyard. Olive + pale stone, garnet as the rare glint.
   Display: Prata (Didone). Body: Inter. Self-hosted.
   Signature: the year-line — an engraved stone rule carrying the
   house's dates (1232 · 2014 · 15), riding the foot of the hero.
   ============================================================ */

/* ---------------- self-hosted fonts ---------------- */
@font-face{
  font-family:"Prata";font-style:normal;font-weight:400;font-display:swap;
  src:url("assets/fonts/prata-latin.woff2") format("woff2");
}
@font-face{
  font-family:"InterBennoc";font-style:normal;font-weight:400 700;font-display:swap;
  src:url("assets/fonts/inter-latin.woff2") format("woff2");
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face{
  font-family:"InterBennoc";font-style:normal;font-weight:400 700;font-display:swap;
  src:url("assets/fonts/inter-latin-ext.woff2") format("woff2");
  unicode-range:U+0100-02AF,U+0304,U+0308,U+0329,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}

/* ---------------- tokens ---------------- */
:root{
  /* palette — olive + pale stone, garnet glint */
  --stone-00:#fbf9f3;     /* lightest paper-stone */
  --stone-05:#f4efe4;     /* pale stone (page) */
  --stone-10:#ece5d5;     /* stone band */
  --stone-20:#ddd3bd;     /* stone line */
  --olive-90:#2f3325;     /* near-black olive (ink) */
  --olive-70:#454b35;     /* deep olive */
  --olive-55:#5d6646;     /* olive */
  --olive-40:#7c855f;     /* light olive (muted text) */
  --garnet:#7a2230;       /* the seal — rare accent */
  --garnet-bright:#94303f;
  --ink:var(--olive-90);
  --muted:#6f7556;
  --line:var(--stone-20);

  --bg:var(--stone-05);

  --serif:"Prata",Georgia,"Times New Roman",serif;
  --sans:"InterBennoc",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;

  --pad:clamp(1.15rem,5vw,4.5rem);
  --maxw:1240px;
  --r:3px;

  --shadow:0 1px 2px rgba(47,51,37,.05), 0 14px 38px -16px rgba(47,51,37,.22);
  --shadow-lift:0 2px 6px rgba(47,51,37,.07), 0 26px 60px -22px rgba(47,51,37,.3);

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

/* ---------------- reset ---------------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family:var(--sans);font-size:clamp(1rem,.97rem + .2vw,1.085rem);
  line-height:1.68;font-weight:400;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
h1,h2,h3{margin:0;font-weight:400;font-family:var(--serif);letter-spacing:.004em;
  word-break:keep-all;overflow-wrap:normal;hyphens:none}
p{margin:0}
::selection{background:var(--garnet);color:#fff}
:focus-visible{outline:2px solid var(--garnet);outline-offset:3px;border-radius:2px}

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

/* ---------------- brand mark ---------------- */
.brand{display:inline-flex;align-items:center;gap:.62rem;min-height:44px}
.brand__seal{
  display:grid;place-items:center;width:38px;height:38px;flex:none;
  background:var(--garnet);color:#f3ead9;border-radius:50%;
  font-family:var(--serif);font-size:1.34rem;line-height:1;padding-bottom:.06em;
  box-shadow:inset 0 0 0 1.5px rgba(243,234,217,.32);
}
.brand__type{display:flex;flex-direction:column;line-height:1.05}
.brand__name{font-family:var(--serif);font-size:1.42rem;letter-spacing:.02em;color:var(--ink)}
.brand__sub{font-size:.6rem;text-transform:uppercase;letter-spacing:.26em;color:var(--muted);margin-top:.18em}
.nav.is-solid .brand__name{color:var(--ink)}

/* ---------------- header ---------------- */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:.7rem var(--pad);
  background:transparent;transition:background .45s var(--ease),box-shadow .45s var(--ease),padding .45s var(--ease);
}
.nav::after{content:"";position:absolute;inset:0;z-index:-1;opacity:0;
  background:linear-gradient(180deg,rgba(0,0,0,.34),rgba(0,0,0,0));transition:opacity .45s var(--ease)}
/* over the dark hero, lift the brand to light */
.nav:not(.is-solid) .brand__name{color:#fdfbf4}
.nav:not(.is-solid) .brand__sub{color:rgba(253,251,244,.78)}
.nav:not(.is-solid)::after{opacity:1}
.nav:not(.is-solid) .nav__links a{color:rgba(253,251,244,.9)}
.nav:not(.is-solid) .nav__links a::after{background:#fdfbf4}
.nav:not(.is-solid) .lang__btn{color:rgba(253,251,244,.78)}
.nav:not(.is-solid) .lang__btn.is-active{color:#fff}
.nav:not(.is-solid) .lang__sep{color:rgba(253,251,244,.5)}

.nav.is-solid{background:rgba(250,247,240,.93);backdrop-filter:saturate(140%) blur(10px);
  box-shadow:0 1px 0 var(--line);padding-top:.5rem;padding-bottom:.5rem}

.nav__links{display:flex;gap:1.65rem;font-size:.78rem;text-transform:uppercase;letter-spacing:.14em}
.nav__links a{position:relative;color:var(--olive-70);padding:.3em 0}
.nav__links a::after{content:"";position:absolute;left:0;right:100%;bottom:-.05em;height:1px;
  background:var(--garnet);transition:right .4s var(--ease)}
.nav__links a:hover::after{right:0}

.nav__right{display:flex;align-items:center;gap:1rem}
.lang{display:flex;align-items:center;gap:.34rem;font-size:.72rem;letter-spacing:.1em}
.lang__btn{background:none;border:0;cursor:pointer;font:inherit;color:var(--olive-40);
  display:inline-flex;align-items:center;padding:.4em .35em;letter-spacing:.12em;transition:color .25s;
  min-height:44px;min-width:30px;justify-content:center}
.lang__btn.is-active{color:var(--garnet);font-weight:600}
.lang__sep{color:var(--line)}

/* ---------------- buttons ---------------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:var(--sans);font-size:.8rem;font-weight:600;letter-spacing:.13em;text-transform:uppercase;
  padding:.92em 1.5em;border-radius:var(--r);cursor:pointer;min-height:46px;
  transition:transform .25s var(--ease),background .3s,color .3s,box-shadow .3s,border-color .3s;white-space:nowrap}
.btn--solid{background:var(--garnet);color:#fdf7ee;box-shadow:0 10px 26px -12px rgba(122,34,48,.7)}
.btn--solid:hover{background:var(--garnet-bright);transform:translateY(-2px)}
.btn--line{background:transparent;color:var(--ink);border:1px solid var(--olive-55)}
.btn--line:hover{background:var(--olive-90);color:#fdf7ee;border-color:var(--olive-90);transform:translateY(-2px)}
.btn--ghost{background:rgba(253,251,244,.08);color:#fdfbf4;border:1px solid rgba(253,251,244,.6);backdrop-filter:blur(2px)}
.btn--ghost:hover{background:#fdfbf4;color:var(--olive-90);transform:translateY(-2px)}
.btn--lg{font-size:.83rem;padding:1.05em 1.85em;min-height:52px}
.btn--xl{font-size:.86rem;padding:1.15em 2.15em;min-height:56px}
.nav__book{font-size:.74rem;padding:.7em 1.25em;min-height:40px}
.nav:not(.is-solid) .nav__book{border-color:rgba(253,251,244,.6);color:#fdfbf4}
.nav:not(.is-solid) .nav__book:hover{background:#fdfbf4;color:var(--olive-90)}

/* ---------------- kicker / section heads ---------------- */
.kicker{display:flex;align-items:center;gap:.7rem;margin:0 0 1.15rem;
  font-size:.72rem;text-transform:uppercase;letter-spacing:.24em;color:var(--muted)}
.kicker__no{font-family:var(--serif);font-size:1.16rem;letter-spacing:.04em;color:var(--garnet);
  line-height:1;text-transform:none}
.kicker--light{color:rgba(253,251,244,.82)}
.kicker--light .kicker__no{color:#e9c9a0}

/* ============================================================
   HERO — full-bleed 100svh
   ============================================================ */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;
  justify-content:flex-end;isolation:isolate;overflow:hidden;color:#fdfbf4}
.hero__media{position:absolute;inset:0;z-index:-2}
.hero__media img{width:100%;height:100%;object-fit:cover;object-position:50% 58%}
.hero__scrim{position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(180deg,rgba(28,30,20,.42) 0%,rgba(28,30,20,0) 26%),
    linear-gradient(0deg,rgba(24,26,17,.86) 0%,rgba(24,26,17,.5) 26%,rgba(24,26,17,.08) 52%,rgba(24,26,17,0) 70%)}

.hero__inner{position:relative;max-width:var(--maxw);width:100%;margin:0 auto;
  padding:0 var(--pad);padding-bottom:clamp(7.5rem,16vh,11rem)}
.hero__eyebrow{display:flex;align-items:baseline;gap:.6rem;flex-wrap:wrap;
  margin:0 0 1rem;font-size:.74rem;text-transform:uppercase;letter-spacing:.28em;color:rgba(253,251,244,.82)}
.hero__est{color:rgba(253,251,244,.7)}
.hero__year{font-family:var(--serif);font-size:1.04rem;letter-spacing:.14em;color:#e9c9a0;text-transform:none}
.hero__title{font-size:clamp(2.7rem,8.4vw,6.2rem);line-height:1.02;letter-spacing:0;
  text-shadow:0 2px 30px rgba(20,20,12,.4);max-width:15ch}
.hero__line{display:block}
.hero__line--accent{font-style:italic;color:#f0d7b4}
.hero__sub{max-width:46ch;margin:1.5rem 0 0;font-size:clamp(1.02rem,1rem + .35vw,1.22rem);
  line-height:1.62;color:rgba(253,251,244,.94)}
.hero__cta{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:2.1rem}

/* the year-line (signature) */
.yearline{position:relative}
.yearline--hero{position:absolute;left:var(--pad);right:var(--pad);bottom:clamp(2.4rem,5.5vh,3.4rem);
  z-index:1;display:flex;align-items:flex-end;gap:1.5rem;padding-top:1.1rem}
.yearline__rule{position:absolute;left:0;right:0;bottom:0;height:1px;
  background:linear-gradient(90deg,rgba(233,201,160,0),rgba(233,201,160,.85) 12%,rgba(233,201,160,.85) 88%,rgba(233,201,160,0))}
.yearline--hero::before,.yearline--hero::after{content:"";position:absolute;bottom:-3px;width:5px;height:5px;border-radius:50%;
  background:#e9c9a0;box-shadow:0 0 0 3px rgba(233,201,160,.18)}
.yearline--hero::before{left:0}
.yearline--hero::after{right:0}
.yearline__mark{position:relative;display:flex;flex-direction:column;line-height:1.1;padding-bottom:.85rem}
.yearline__mark b{font-family:var(--serif);font-size:1.32rem;font-weight:400;color:#fdfbf4;letter-spacing:.02em}
.yearline__mark span{font-size:.6rem;text-transform:uppercase;letter-spacing:.2em;color:rgba(253,251,244,.72);margin-top:.18em}
.yearline__mark::after{content:"";position:absolute;left:0;bottom:0;width:1px;height:.62rem;background:rgba(233,201,160,.7)}
.yearline__here{margin-left:auto;padding-bottom:.85rem;align-self:flex-end;
  font-size:.62rem;text-transform:uppercase;letter-spacing:.24em;color:#e9c9a0;position:relative}
.yearline__here::after{content:"";position:absolute;right:0;bottom:0;width:1px;height:.62rem;background:#e9c9a0}

.hero__scroll{position:absolute;right:var(--pad);bottom:clamp(7.5rem,16vh,11rem);z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
  font-size:.62rem;text-transform:uppercase;letter-spacing:.2em;color:rgba(253,251,244,.85)}
.hero__scroll svg{width:16px;height:26px}
.hero__scroll .scroll-line{stroke:rgba(253,251,244,.85);stroke-width:1.5;fill:none;stroke-linecap:round;stroke-linejoin:round}
.hero__scroll:hover svg{animation:nudge 1s var(--ease) infinite}
@keyframes nudge{0%,100%{transform:translateY(0)}50%{transform:translateY(4px)}}

/* ============================================================
   THE HOUSE
   ============================================================ */
.casa{max-width:var(--maxw);margin:0 auto;padding:clamp(4.5rem,10vw,8rem) var(--pad) clamp(3.5rem,7vw,5.5rem);
  display:grid;grid-template-columns:minmax(0,1.55fr) minmax(0,1fr);gap:clamp(2rem,6vw,5.5rem);align-items:start}
.casa__title{font-size:clamp(1.85rem,1.4rem + 2.2vw,3.25rem);line-height:1.08;max-width:18ch;margin-bottom:1.3rem}
.casa__intro{font-size:clamp(1.08rem,1.02rem + .4vw,1.28rem);line-height:1.6;color:var(--olive-70);margin-bottom:1.3rem}
.casa__intro::first-letter{font-family:var(--serif);font-size:1.05em;color:var(--garnet)}
.casa__p{margin-bottom:1.05rem;color:#4c5240;max-width:60ch}
.casa__p--soft{color:var(--muted)}

.facts{margin:.4rem 0 0;display:flex;flex-direction:column;border-top:1px solid var(--line)}
.fact{display:grid;grid-template-columns:minmax(0,1fr);gap:.2rem;padding:1.05rem 0;border-bottom:1px solid var(--line)}
.fact__k{font-size:.68rem;text-transform:uppercase;letter-spacing:.2em;color:var(--garnet)}
.fact__v{font-family:var(--serif);font-size:1.12rem;line-height:1.35;color:var(--olive-70)}
.fact__v b{font-weight:400;color:var(--ink)}

/* ============================================================
   THE CLASTRE — signature section (dark olive)
   ============================================================ */
.clastre{background:var(--olive-90);color:#f1ede0;position:relative;
  padding:clamp(4.5rem,9vw,7.5rem) var(--pad) clamp(4rem,8vw,6.5rem)}
.clastre::before{content:"";position:absolute;left:var(--pad);right:var(--pad);top:0;height:1px;
  background:linear-gradient(90deg,rgba(233,201,160,0),rgba(233,201,160,.6),rgba(233,201,160,0))}
.clastre__head{max-width:var(--maxw);margin:0 auto 2.6rem}
.clastre__title{font-size:clamp(1.85rem,1.4rem + 2.3vw,3.35rem);line-height:1.06;max-width:16ch;color:#fdfbf4}
.clastre__lede{max-width:54ch;margin-top:1.1rem;color:rgba(241,237,224,.82);font-size:clamp(1.02rem,1rem + .3vw,1.18rem)}

.clastre__grid{max-width:var(--maxw);margin:0 auto;display:grid;
  grid-template-columns:minmax(0,1.7fr) minmax(0,1fr);grid-template-rows:auto auto;gap:1rem}
.clastre__fig{position:relative;margin:0;overflow:hidden;border-radius:var(--r);background:#23271b}
.clastre__fig--lead{grid-row:1 / span 2}
.clastre__fig img{width:100%;height:100%;object-fit:cover;transition:transform 1.3s var(--ease)}
.clastre__fig:hover img{transform:scale(1.045)}
.clastre__fig figcaption{position:absolute;left:0;right:0;bottom:0;display:flex;flex-direction:column;gap:.2rem;
  padding:2.1rem 1.15rem .95rem;
  background:linear-gradient(0deg,rgba(16,18,11,.9) 0%,rgba(16,18,11,.55) 45%,rgba(16,18,11,0) 100%);
  font-size:.92rem;color:#fdfbf4}
.clastre__fig figcaption .tag{font-size:.6rem;text-transform:uppercase;letter-spacing:.22em;color:#e9c9a0}
.clastre__fig--lead figcaption{font-size:1.02rem}
.clastre__note{max-width:var(--maxw);margin:2rem auto 0;font-family:var(--serif);font-style:italic;
  font-size:clamp(1.15rem,1rem + .9vw,1.6rem);line-height:1.42;color:#e9c9a0;max-width:34ch}

/* ============================================================
   ROOMS
   ============================================================ */
.rooms{max-width:var(--maxw);margin:0 auto;padding:clamp(4.5rem,9vw,7.5rem) var(--pad) clamp(3rem,6vw,4.5rem)}
.rooms__head{max-width:62ch;margin-bottom:clamp(2.2rem,4.5vw,3.4rem)}
.rooms__title{font-size:clamp(1.8rem,1.35rem + 2.2vw,3.15rem);line-height:1.08;max-width:20ch;margin-bottom:1.1rem}
.rooms__lede{color:var(--olive-70);font-size:clamp(1.02rem,1rem + .3vw,1.18rem)}

.rlist{display:flex;flex-direction:column;gap:clamp(1.5rem,3.5vw,2.6rem)}
.room{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,1fr);gap:clamp(1.2rem,3vw,2.6rem);align-items:center}
.room--flip .room__media{order:2}
.room__media{position:relative;overflow:hidden;border-radius:var(--r);background:var(--stone-10);box-shadow:var(--shadow)}
.room__media img{width:100%;aspect-ratio:16/10;object-fit:cover;transition:transform 1.2s var(--ease)}
.room:hover .room__media img{transform:scale(1.04)}
.room__no{position:absolute;top:.85rem;left:.85rem;z-index:2;
  background:rgba(47,51,37,.82);color:#f3ead9;font-family:var(--serif);font-size:.8rem;letter-spacing:.04em;
  padding:.32em .7em;border-radius:2px;backdrop-filter:blur(2px)}
.room__name{font-size:clamp(1.5rem,1.2rem + 1.2vw,2.2rem);line-height:1.1;margin-bottom:.7rem}
.room__txt{color:#4c5240;margin-bottom:1.1rem;max-width:46ch}
.room__meta{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:.5rem}
.room__meta li{font-size:.74rem;text-transform:uppercase;letter-spacing:.1em;color:var(--olive-55);
  border:1px solid var(--line);border-radius:100px;padding:.42em .85em}

.rooms__bottom{display:flex;flex-wrap:wrap;align-items:baseline;gap:.4rem 1.1rem;
  margin-top:clamp(2.2rem,5vw,3.4rem);padding-top:1.5rem;border-top:1px solid var(--line);
  color:var(--muted);font-size:.96rem;max-width:70ch}
.link-tick{color:var(--garnet);font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;
  display:inline-flex;align-items:center;gap:.45em;white-space:nowrap}
.link-tick::after{content:"→";transition:transform .3s var(--ease)}
.link-tick:hover::after{transform:translateX(4px)}

/* ============================================================
   SPA & TABLE
   ============================================================ */
.spa{background:var(--stone-10);border-top:1px solid var(--line);
  padding:clamp(4.5rem,9vw,7.5rem) var(--pad) clamp(4rem,8vw,6rem)}
.spa__head{max-width:var(--maxw);margin:0 auto clamp(2rem,4vw,3rem)}
.spa__title{font-size:clamp(1.8rem,1.4rem + 2vw,3rem);line-height:1.08;max-width:20ch}
.spa__split{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:clamp(1.2rem,3vw,2.2rem)}
.card{background:var(--stone-00);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  display:flex;flex-direction:column;box-shadow:var(--shadow);transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lift)}
.card__media{margin:0;overflow:hidden;background:var(--stone-20)}
.card__media img{width:100%;aspect-ratio:16/10;object-fit:cover;transition:transform 1.2s var(--ease)}
.card:hover .card__media img{transform:scale(1.05)}
.card__body{padding:clamp(1.3rem,2.5vw,2rem);display:flex;flex-direction:column;flex:1}
.card__name{font-size:clamp(1.4rem,1.15rem + 1vw,1.95rem);line-height:1.12;margin-bottom:.6rem}
.card__txt{color:#4c5240;margin-bottom:1rem;flex:1}
.card__meta{list-style:none;margin:0;padding:.9rem 0 0;border-top:1px solid var(--line);
  display:flex;flex-direction:column;gap:.35rem}
.card__meta li{position:relative;padding-left:1rem;font-size:.86rem;color:var(--olive-55)}
.card__meta li::before{content:"";position:absolute;left:0;top:.62em;width:5px;height:5px;border-radius:50%;background:var(--garnet)}

.amen{max-width:var(--maxw);margin:clamp(2.4rem,5vw,3.6rem) auto 0}
.amen__rule{display:block;height:1px;background:var(--line);margin-bottom:1.4rem}
.amen__list{list-style:none;margin:0;padding:0;display:grid;
  grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.8rem 1.6rem}
.amen__list li{position:relative;padding-left:1.35rem;font-size:.92rem;color:var(--olive-70)}
.amen__list li::before{content:"";position:absolute;left:0;top:.5em;width:8px;height:8px;border:1px solid var(--garnet);
  border-radius:50%}

/* ============================================================
   GALLERY — the grounds (dark olive, editorial mosaic)
   ============================================================ */
.gallery{background:var(--olive-70);color:#f1ede0;padding:clamp(4.5rem,9vw,7.5rem) var(--pad) clamp(4.5rem,9vw,7rem)}
.gallery__head{max-width:var(--maxw);margin:0 auto 2.4rem}
.gallery__title{font-size:clamp(1.8rem,1.4rem + 2vw,3rem);line-height:1.08;max-width:18ch;color:#fdfbf4}
.plates{max-width:var(--maxw);margin:0 auto;display:grid;
  grid-template-columns:repeat(6,minmax(0,1fr));grid-auto-rows:11.5vw;gap:.85rem}
.plate{position:relative;margin:0;overflow:hidden;border-radius:var(--r);background:#3a4030}
.plate img{width:100%;height:100%;object-fit:cover;transition:transform 1.3s var(--ease)}
.plate:hover img{transform:scale(1.05)}
.plate__tag{position:absolute;left:0;bottom:0;right:0;padding:1.2rem .95rem .8rem;
  background:linear-gradient(0deg,rgba(20,22,14,.8),rgba(20,22,14,0));
  font-size:.74rem;text-transform:uppercase;letter-spacing:.14em;color:#fdfbf4;
  opacity:0;transform:translateY(6px);transition:opacity .4s var(--ease),transform .4s var(--ease)}
.plate:hover .plate__tag{opacity:1;transform:none}
.plate--a{grid-column:span 3;grid-row:span 2}
.plate--b{grid-column:span 3;grid-row:span 2}
.plate--c{grid-column:span 2;grid-row:span 2}
.plate--d{grid-column:span 2;grid-row:span 2}
.plate--e{grid-column:span 2;grid-row:span 2}
.plate--f{grid-column:span 6;grid-row:span 2}

/* ============================================================
   SETTING — full-bleed photo panel
   ============================================================ */
.setting{position:relative;isolation:isolate;color:#fdfbf4;
  display:flex;align-items:center;min-height:min(86svh,720px);overflow:hidden}
.setting__media{position:absolute;inset:0;z-index:-2}
.setting__media img{width:100%;height:100%;object-fit:cover;object-position:50% 55%}
.setting__scrim{position:absolute;inset:0;z-index:-1;
  background:linear-gradient(100deg,rgba(24,26,17,.9) 0%,rgba(24,26,17,.66) 42%,rgba(24,26,17,.18) 78%,rgba(24,26,17,0) 100%)}
.setting__inner{max-width:var(--maxw);width:100%;margin:0 auto;padding:clamp(3.5rem,8vw,6rem) var(--pad)}
.setting__panel{max-width:38rem}
.setting__title{font-size:clamp(1.85rem,1.4rem + 2.3vw,3.2rem);line-height:1.08;max-width:18ch;margin-bottom:1.1rem}
.setting__p{color:rgba(253,251,244,.92);margin-bottom:1rem;max-width:50ch}
.dist{margin:1.8rem 0 0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.1rem 2rem;
  border-top:1px solid rgba(253,251,244,.26)}
.dist__row{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;
  padding:.72rem 0;border-bottom:1px solid rgba(253,251,244,.18)}
.dist__row dt{font-size:.74rem;text-transform:uppercase;letter-spacing:.13em;color:rgba(253,251,244,.78)}
.dist__row dd{margin:0;font-family:var(--serif);font-size:1.04rem;color:#f0d7b4}

/* ============================================================
   BOOK
   ============================================================ */
.book{background:var(--stone-05);padding:clamp(4.5rem,9vw,7.5rem) var(--pad)}
.book__inner{max-width:760px;margin:0 auto;text-align:center;position:relative}
.yearline--book{display:flex;flex-direction:column;align-items:center;gap:.9rem;margin-bottom:2rem;height:auto}
.yearline--book .yearline__rule{position:static;width:clamp(120px,40%,220px);height:1px;
  background:linear-gradient(90deg,rgba(122,34,48,0),rgba(122,34,48,.55),rgba(122,34,48,0))}
.yearline__seal{font-family:var(--serif);font-size:1.05rem;letter-spacing:.34em;color:var(--garnet)}
.book__kick{justify-content:center}
.book__title{font-size:clamp(2rem,1.5rem + 2.4vw,3.5rem);line-height:1.06;margin-bottom:1.2rem}
.book__txt{color:var(--olive-70);max-width:52ch;margin:0 auto 2rem;font-size:clamp(1.04rem,1rem + .35vw,1.22rem)}
.book__cta{display:flex;flex-wrap:wrap;gap:.8rem;justify-content:center}
.book__contact{margin-top:2.1rem;display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.5rem .9rem;
  font-size:.92rem;color:var(--muted)}
.book__contact a{border-bottom:1px solid var(--line);padding-bottom:1px;transition:border-color .3s,color .3s}
.book__contact a:hover{color:var(--garnet);border-color:var(--garnet)}
.book__dot{color:var(--line)}
.book__rating{display:inline-flex;align-items:center;gap:.4em;width:100%;justify-content:center;margin-top:.3rem;color:var(--olive-70)}
.book__rating b{color:var(--ink)}
.star{color:#c69a3e}

/* ============================================================
   FOOTER
   ============================================================ */
.foot{background:var(--olive-90);color:rgba(241,237,224,.82);padding:clamp(3.2rem,6vw,4.5rem) var(--pad) 2rem}
.foot__grid{max-width:var(--maxw);margin:0 auto;display:grid;
  grid-template-columns:1.4fr 1fr 1fr;gap:2.4rem}
.brand__seal--foot{width:42px;height:42px;font-size:1.5rem;margin-bottom:.9rem}
.foot__name{font-family:var(--serif);font-size:1.4rem;color:#fdfbf4;margin-bottom:.4rem}
.foot__place{font-size:.86rem;line-height:1.6;color:rgba(241,237,224,.66);max-width:30ch}
.foot__h{font-family:var(--sans);font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.2em;
  color:#e9c9a0;margin:0 0 .8rem}
.foot__col p{font-size:.92rem;margin-bottom:.5rem;line-height:1.55}
.foot__col a{border-bottom:1px solid transparent;transition:border-color .3s,color .3s}
.foot__col a:hover{color:#fdfbf4;border-color:rgba(233,201,160,.5)}
.foot__rate{color:rgba(241,237,224,.66)}
.foot__book{margin-top:.5rem;color:#f1ede0;border-color:rgba(241,237,224,.4)}
.foot__book:hover{background:#f1ede0;color:var(--olive-90);border-color:#f1ede0}
.foot__base{max-width:var(--maxw);margin:2.6rem auto 0;padding-top:1.4rem;border-top:1px solid rgba(241,237,224,.16);
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:.6rem;
  font-size:.78rem;color:rgba(241,237,224,.55)}
.foot__sign{font-family:var(--serif);font-style:italic;color:rgba(233,201,160,.8)}

/* ============================================================
   MOTION (reveal)
   ============================================================ */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.is-in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  *{animation:none !important;transition:none !important;scroll-behavior:auto !important}
  .reveal{opacity:1;transform:none}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .nav__links{display:none}
}
@media (max-width:900px){
  .casa{grid-template-columns:minmax(0,1fr);gap:2.4rem}
  .clastre__grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}
  .clastre__fig--lead{grid-row:1 / span 2}
  .plates{grid-auto-rows:20vw}
}
@media (max-width:680px){
  :root{--pad:1.15rem}
  .nav{padding:.55rem var(--pad)}
  .brand__seal{width:34px;height:34px;font-size:1.2rem}
  .brand__name{font-size:1.24rem}
  .brand__sub{font-size:.54rem;letter-spacing:.2em}
  .nav__book{display:none}                 /* CTA repeats in hero + sticky sections; keep header clean on phone */

  .hero{justify-content:flex-end}
  .hero__media img{object-position:50% 60%}
  .hero__inner{padding-bottom:8.5rem}
  .hero__title{font-size:clamp(2.5rem,11vw,3.7rem);max-width:14ch}
  .hero__sub{font-size:1.06rem;max-width:34ch}
  .hero__cta .btn{flex:1 1 auto}
  .hero__scroll{display:none}
  /* year-line: keep two marks + rule, hide the rest so it never crowds at 390 */
  .yearline--hero{gap:1.1rem;bottom:2rem}
  .yearline__mark b{font-size:1.12rem}
  .yearline__mark--c{display:none}
  .yearline__here{display:none}

  .casa__intro{font-size:1.1rem}
  .fact__v{font-size:1.05rem}

  .clastre__grid{grid-template-columns:minmax(0,1fr);grid-auto-rows:auto}
  .clastre__fig--lead{grid-row:auto}
  .clastre__fig img{aspect-ratio:16/10}
  .clastre__note{max-width:none}

  .room{grid-template-columns:minmax(0,1fr);gap:1.1rem}
  .room--flip .room__media{order:0}
  .room__media img{aspect-ratio:16/10}

  .spa__split{grid-template-columns:minmax(0,1fr)}

  .plates{grid-template-columns:repeat(2,minmax(0,1fr));grid-auto-rows:42vw;gap:.6rem}
  .plate--a,.plate--b,.plate--c,.plate--d,.plate--e{grid-column:span 1;grid-row:span 1}
  .plate--f{grid-column:span 2;grid-row:span 1}
  .plate__tag{opacity:1;transform:none;font-size:.66rem;padding:.9rem .7rem .65rem}

  .setting{min-height:auto}
  .setting__scrim{background:linear-gradient(0deg,rgba(24,26,17,.92) 8%,rgba(24,26,17,.62) 55%,rgba(24,26,17,.32) 100%)}
  .setting__inner{padding-top:5rem;padding-bottom:4rem}
  .dist{grid-template-columns:minmax(0,1fr)}

  .book__cta .btn{flex:1 1 auto}
  .book__contact{flex-direction:column;gap:.4rem}
  .book__dot{display:none}
  /* give inline contact + tick links a comfortable tap height on phones */
  .book__contact a{display:inline-flex;align-items:center;min-height:44px;padding:0 .2em}
  .book__rating{min-height:36px}
  .rooms__bottom{flex-direction:column;align-items:flex-start;gap:.2rem}
  .link-tick{min-height:44px;display:inline-flex;align-items:center}
  .foot__col p a{display:inline-flex;align-items:center;min-height:40px}

  .foot__grid{grid-template-columns:minmax(0,1fr);gap:2rem}
}
@media (max-width:380px){
  .hero__title{font-size:2.35rem}
}
