/* ============================================================
   THE MERYAN HOUSE HOTEL — homepage
   Aesthetic: refined English country-house heritage
   Parchment & forest green · Cormorant Garamond / EB Garamond / Jost
   ============================================================ */

:root{
  /* palette */
  --parchment:#f4efe1;
  --parchment-2:#ece2cd;
  --parchment-3:#e4d9c0;
  --ink:#262318;
  --ink-2:#4d4838;
  --sage:#b1cf86;          /* brand */
  --sage-2:#c9dcab;
  --sage-deep:#88a85c;
  --forest:#33422a;
  --forest-2:#28341f;
  --forest-deep:#1a2414;
  --gold:#a9854c;
  --gold-2:#c2a268;
  --line:rgba(38,35,24,.16);
  --line-soft:rgba(38,35,24,.10);

  /* type */
  --serif:'Cormorant Garamond',Georgia,'Times New Roman',serif;
  --body:'EB Garamond',Georgia,serif;
  --label:'Jost','Century Gothic',sans-serif;

  /* metrics */
  --wrap:1200px;
  --gutter:clamp(20px,5vw,64px);
  --radius:3px;
  --ease:cubic-bezier(.2,.7,.2,1);

  /* paper grain */
  --grain:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/%3E%3C/svg%3E");
}

/* ---------- reset / base ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--body);
  background:var(--parchment);
  color:var(--ink);
  font-size:clamp(1.02rem,.55vw + .9rem,1.18rem);
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
em{font-style:italic}

.wrap{width:100%;max-width:var(--wrap);margin-inline:auto;padding-inline:var(--gutter)}

.skip-link{position:absolute;left:-999px;top:0;background:var(--forest);color:var(--parchment);padding:.6em 1em;z-index:200}
.skip-link:focus{left:8px;top:8px}

:focus-visible{outline:2px solid var(--gold);outline-offset:3px}

/* ---------- shared type ---------- */
.eyebrow{
  font-family:var(--label);
  font-weight:400;
  font-size:.72rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--ink-2);
}
.eyebrow--gold{color:var(--gold)}
.eyebrow--sage{color:var(--sage-2)}

.section-title{
  font-family:var(--serif);
  font-weight:400;
  line-height:1.04;
  letter-spacing:.005em;
  font-size:clamp(2.1rem,4.4vw,3.6rem);
  color:var(--ink);
}
.section-title--light{color:var(--parchment)}

.section-head{margin-bottom:clamp(2rem,4vw,3.4rem)}
.section-head .eyebrow{margin-bottom:.9rem}
.section-head--center{text-align:center}
.section-head--center .eyebrow{display:block}

/* decorative rule w/ fleur-de-lis */
.rule--fleur{
  display:flex;align-items:center;justify-content:center;gap:1rem;
  margin:2.4rem auto 0;max-width:340px;color:var(--gold);
}
.rule--fleur::before,.rule--fleur::after{content:"";height:1px;flex:1;background:linear-gradient(90deg,transparent,var(--gold))}
.rule--fleur::after{background:linear-gradient(90deg,var(--gold),transparent)}
.rule--fleur{position:relative}
.rule--fleur > span,.rule--fleur::content{}
.rule--fleur{}
.rule--fleur:after{}
.rule--fleur span{}
/* center glyph */
.rule--fleur{}
.rule--fleur::marker{}
.rule--fleur{}
.rule--fleur{}
.rule--fleur > *{}
.rule--fleur{}
.rule--fleur{}
.rule--fleur{}
.rule--fleur{}
.rule--fleur{}
.rule--fleur{}
.rule--fleur{}
.rule--fleur{}
.rule--light{color:var(--sage)}
.rule--light.rule--fleur::before{background:linear-gradient(90deg,transparent,var(--sage))}
.rule--light.rule--fleur::after{background:linear-gradient(90deg,var(--sage),transparent)}
.rule--fleur i{font-style:normal}

/* use a glyph via the element's own content */
.rule--fleur{}
.rule--fleur::first-line{}

/* ---------- buttons ---------- */
.btn{
  display:inline-block;
  font-family:var(--label);
  font-weight:400;
  font-size:.78rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  padding:1.05em 2.1em;
  border:1px solid transparent;
  border-radius:var(--radius);
  cursor:pointer;
  transition:background .4s var(--ease),color .4s var(--ease),border-color .4s var(--ease),transform .4s var(--ease);
}
.btn--solid{background:var(--forest);color:var(--parchment);border-color:var(--forest)}
.btn--solid:hover{background:var(--gold);border-color:var(--gold);color:#fff;transform:translateY(-2px)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--gold)}
.btn--ghost:hover{background:var(--gold);color:#fff;transform:translateY(-2px)}
.btn--on-dark{background:var(--sage);color:var(--forest-deep);border-color:var(--sage)}
.btn--on-dark:hover{background:var(--parchment);border-color:var(--parchment);color:var(--forest-deep)}

.link-underline{
  font-family:var(--label);font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--gold);position:relative;display:inline-block;padding-bottom:3px;
}
.link-underline::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:100%;
  background:currentColor;transform:scaleX(.001);transform-origin:left;transition:transform .45s var(--ease)}
.link-underline:hover::after{transform:scaleX(1)}
.link-underline--light{color:var(--sage-2)}

/* ---------- utility bar ---------- */
.utility{background:var(--forest-deep);color:var(--parchment-2)}
.utility__inner{display:flex;justify-content:space-between;align-items:center;gap:1rem;
  min-height:42px;font-family:var(--label);font-size:.72rem;letter-spacing:.12em}
.utility__tag{text-transform:uppercase;opacity:.78}
.utility__links{display:flex;align-items:center;gap:.85rem;flex-wrap:wrap}
.utility__links a{opacity:.85;transition:color .3s,opacity .3s}
.utility__links a:hover{color:var(--sage);opacity:1}
.utility .dot{opacity:.4}

/* ---------- header ---------- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(244,239,225,.86);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line-soft);
  transition:background .4s,box-shadow .4s,padding .4s}
.site-header.is-scrolled{background:rgba(244,239,225,.97);box-shadow:0 10px 30px -22px rgba(26,36,20,.6)}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;min-height:84px}
.site-header.is-scrolled .site-header__inner{min-height:70px}

.brand{display:flex;flex-direction:column;line-height:1;color:var(--ink)}
.brand__the{font-family:var(--serif);font-style:italic;font-size:.92rem;color:var(--gold);margin-bottom:1px}
.brand__name{font-family:var(--serif);font-weight:500;font-size:1.5rem;letter-spacing:.06em;text-transform:uppercase}
.brand__sub{font-family:var(--label);font-size:.6rem;letter-spacing:.34em;text-transform:uppercase;color:var(--ink-2);margin-top:4px}

.primary-nav{display:flex;gap:clamp(.9rem,2vw,1.9rem)}
.primary-nav a{font-family:var(--label);font-size:.78rem;letter-spacing:.13em;text-transform:uppercase;
  color:var(--ink);position:relative;padding:.4em 0;transition:color .3s}
.primary-nav a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:100%;background:var(--gold);
  transform:scaleX(.001);transform-origin:center;transition:transform .4s var(--ease)}
.primary-nav a:hover{color:var(--gold)}
.primary-nav a:hover::after{transform:scaleX(1)}

.site-header__cta{display:flex;align-items:center;gap:1rem}
.site-header__cta .btn{padding:.75em 1.5em}

.nav-toggle{display:none;width:44px;height:40px;background:none;border:0;cursor:pointer;flex-direction:column;justify-content:center;gap:5px}
.nav-toggle span{display:block;height:1.5px;width:26px;background:var(--ink);transition:transform .35s var(--ease),opacity .25s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* ---------- hero ---------- */
.hero{position:relative;background:var(--forest-deep);color:var(--parchment);overflow:hidden;
  padding:clamp(3rem,7vw,6rem) 0 clamp(3.5rem,7vw,6rem)}
.hero::before{content:"";position:absolute;inset:0;
  background:
    radial-gradient(120% 90% at 18% 12%,rgba(136,168,92,.22),transparent 55%),
    radial-gradient(120% 100% at 100% 100%,rgba(20,28,15,.9),transparent 60%),
    linear-gradient(160deg,#2c3a23,#19220f);
  z-index:0}
.hero::after{content:"";position:absolute;inset:clamp(12px,2vw,22px);
  border:1px solid rgba(194,162,104,.34);pointer-events:none;z-index:2}
.hero__grain{position:absolute;inset:0;background-image:var(--grain);background-size:180px;
  opacity:.06;mix-blend-mode:overlay;z-index:1;pointer-events:none}
.hero__flourish{position:absolute;font-style:normal;color:rgba(194,162,104,.18);z-index:2;
  font-family:var(--serif);font-size:clamp(60px,9vw,120px);line-height:1}
.hero__flourish--tl{top:clamp(18px,3vw,34px);left:clamp(18px,3vw,34px)}
.hero__flourish--tl::before{content:"\269C"}
.hero__flourish--br{bottom:clamp(18px,3vw,34px);right:clamp(18px,3vw,34px)}
.hero__flourish--br::before{content:"\269C"}

.hero__inner{position:relative;z-index:3;display:grid;grid-template-columns:1.05fr .95fr;
  gap:clamp(2rem,5vw,5rem);align-items:center}
.hero__copy{max-width:36ch}
.hero .eyebrow{color:var(--gold-2);margin-bottom:1.4rem;display:block}
.hero__title{font-family:var(--serif);font-weight:300;line-height:1;letter-spacing:.005em;
  font-size:clamp(3rem,7.5vw,6rem);margin-bottom:1.6rem}
.hero__title span{display:block}
.hero__title-em{color:var(--sage)}
.hero__title-em em{font-weight:400}
.hero__lede{font-size:clamp(1.1rem,1.4vw,1.35rem);color:rgba(244,239,225,.86);margin-bottom:2.2rem}
.hero__actions{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:2rem}
.hero .btn--solid{background:var(--sage);border-color:var(--sage);color:var(--forest-deep)}
.hero .btn--solid:hover{background:var(--gold-2);border-color:var(--gold-2);color:var(--forest-deep)}
.hero .btn--ghost{color:var(--parchment);border-color:rgba(244,239,225,.5)}
.hero .btn--ghost:hover{background:var(--parchment);color:var(--forest-deep);border-color:var(--parchment)}
.hero__note{font-family:var(--label);font-size:.74rem;letter-spacing:.28em;text-transform:uppercase;color:rgba(244,239,225,.6)}

.hero__crest{display:flex;justify-content:center}
.crest-plate{background:#f6f1e3;padding:clamp(14px,1.6vw,22px);border-radius:2px;
  box-shadow:0 40px 70px -30px rgba(0,0,0,.7),0 0 0 1px rgba(194,162,104,.5),0 0 0 6px rgba(246,241,227,.06);
  position:relative;max-width:440px}
.crest-plate::after{content:"";position:absolute;inset:8px;border:1px solid rgba(169,133,76,.4);pointer-events:none}
.crest-plate img{border-radius:1px}

.hero__scroll{position:absolute;left:50%;bottom:clamp(14px,2vw,26px);transform:translateX(-50%);
  z-index:4;display:flex;flex-direction:column;align-items:center;gap:8px;
  font-family:var(--label);font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(244,239,225,.65)}
.hero__scroll-line{width:1px;height:40px;background:linear-gradient(var(--gold-2),transparent);animation:drip 2.4s var(--ease) infinite}
@keyframes drip{0%{transform:scaleY(0);transform-origin:top}40%{transform:scaleY(1);transform-origin:top}
  60%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ---------- welcome ---------- */
.welcome{padding:clamp(4rem,9vw,7.5rem) 0;text-align:center}
.welcome__inner{max-width:760px;margin-inline:auto}
.welcome .eyebrow{display:block;margin-bottom:1.6rem}
.welcome__lead{font-family:var(--serif);font-weight:300;font-size:clamp(1.5rem,3.2vw,2.4rem);
  line-height:1.34;color:var(--ink)}

/* ---------- three ways ---------- */
.ways{padding:clamp(3rem,7vw,6rem) 0 clamp(4rem,9vw,7rem);background:var(--parchment-2)}
.ways__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.2rem,2.4vw,2rem)}
.card{background:var(--parchment);border:1px solid var(--line-soft);padding:clamp(2rem,3vw,2.8rem);
  border-radius:var(--radius);position:relative;transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .5s}
.card::before{content:"";position:absolute;left:0;top:0;width:100%;height:3px;
  background:linear-gradient(90deg,var(--gold),var(--sage));transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.card:hover{transform:translateY(-6px);box-shadow:0 30px 50px -34px rgba(26,36,20,.55);border-color:transparent}
.card:hover::before{transform:scaleX(1)}
.card--feature{background:var(--forest);color:var(--parchment)}
.card--feature .card__title{color:var(--parchment)}
.card--feature .card__text{color:rgba(244,239,225,.82)}
.card__icon{display:block;font-size:1.4rem;color:var(--gold);margin-bottom:1.1rem}
.card--feature .card__icon{color:var(--sage)}
.card__title{font-family:var(--serif);font-weight:500;font-size:2rem;margin-bottom:.7rem;letter-spacing:.01em}
.card__text{color:var(--ink-2);margin-bottom:1.6rem}

/* ---------- restaurant ---------- */
.restaurant{padding:clamp(4rem,9vw,7.5rem) 0}
.restaurant__inner{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.restaurant__media{position:relative}
.restaurant__stamp{position:absolute;right:-14px;bottom:-14px;background:var(--forest-deep);color:var(--parchment);
  display:flex;flex-direction:column;gap:2px;padding:.9rem 1.2rem;border-radius:2px;
  font-family:var(--label);font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;
  box-shadow:0 22px 40px -26px rgba(0,0,0,.7)}
.restaurant__stamp span{opacity:.85}
.restaurant__lead{color:var(--ink-2);margin:.4rem 0 1.8rem;max-width:46ch}
.restaurant__copy .section-title{margin-bottom:.3rem}
.restaurant__copy .eyebrow{display:block;margin-bottom:1rem}
.menu-teaser{list-style:none;margin:0 0 2rem;border-top:1px solid var(--line)}
.menu-teaser li{display:flex;align-items:baseline;gap:.6rem;padding:.85rem 0;border-bottom:1px solid var(--line)}
.menu-teaser__name{font-family:var(--serif);font-size:1.28rem}
.menu-teaser__dots{flex:1;border-bottom:1px dotted var(--line);transform:translateY(-4px)}
.menu-teaser__price{font-family:var(--label);font-size:.9rem;letter-spacing:.06em;color:var(--gold)}
.restaurant__actions{display:flex;gap:1rem;flex-wrap:wrap}

/* placeholders */
.ph{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);
  background:
    repeating-linear-gradient(45deg,rgba(136,168,92,.08) 0 14px,transparent 14px 28px),
    linear-gradient(150deg,var(--parchment-3),var(--sage-2));
  display:flex;align-items:center;justify-content:center;min-height:340px}
.ph::before{content:"\269C";position:absolute;font-family:var(--serif);font-size:3rem;color:rgba(169,133,76,.45)}
.ph__label{position:relative;font-family:var(--label);font-size:.68rem;letter-spacing:.26em;text-transform:uppercase;
  color:var(--ink-2);background:rgba(244,239,225,.75);padding:.5em 1em;border-radius:40px;margin-top:4.4rem}
.ph--food{min-height:440px}
.ph__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:2;display:block}
.gallery-cta{padding:clamp(4rem,9vw,7rem) 0;text-align:center}
.gallery-cta__inner{max-width:640px;margin-inline:auto}
.gallery-cta .eyebrow{display:block;margin-bottom:1rem}
.gallery-cta .section-title{margin-bottom:1rem}
.gallery-cta__text{color:var(--ink-2);margin-bottom:2rem}

/* ---------- funeral functions ---------- */
.gather-detail{position:relative;background:var(--forest);color:var(--parchment);overflow:hidden;
  padding:clamp(4rem,9vw,7rem) 0}
.gather-detail__grain{position:absolute;inset:0;background-image:var(--grain);background-size:180px;opacity:.05;mix-blend-mode:overlay}
.gather-detail__inner{position:relative;max-width:780px;text-align:center;margin-inline:auto}
.gather-detail .eyebrow{display:block;margin-bottom:1.2rem}
.gather-detail__lead{color:rgba(244,239,225,.84);font-size:1.18rem;margin:1.4rem auto 2.4rem;max-width:60ch}
.gather-detail__row{display:flex;align-items:center;justify-content:center;gap:1.6rem;flex-wrap:wrap}
.pricepill{display:flex;align-items:center;gap:.8rem;border:1px solid rgba(194,162,104,.5);
  padding:.7rem 1.3rem;border-radius:50px}
.pricepill__fig{font-family:var(--serif);font-size:2rem;color:var(--sage)}
.pricepill__lbl{font-family:var(--label);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(244,239,225,.75);text-align:left;max-width:18ch}

/* ---------- virtual tour ---------- */
.tour{padding:clamp(4rem,9vw,7rem) 0;background:var(--parchment-2)}
.tour__viewer{position:relative;aspect-ratio:16/9;border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--line);background:#11160c;padding:10px;
  box-shadow:0 40px 70px -40px rgba(26,36,20,.6)}
.tour__viewer::after{content:"";position:absolute;inset:10px;border:1px solid rgba(169,133,76,.45);pointer-events:none;z-index:6}
.tour__pano{position:absolute;inset:10px;border-radius:2px;display:none}
.tour__viewer.is-embedded .tour__pano{display:block}
.tour__viewer.is-embedded .tour__preview{display:none}
.tour__preview{position:absolute;inset:10px;border-radius:2px;overflow:hidden;display:block;cursor:pointer}
.tour__preview img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.tour__preview:hover img{transform:scale(1.05)}
.tour__poster{position:absolute;inset:0;
  background:radial-gradient(120% 120% at 30% 18%,rgba(136,168,92,.20),transparent 55%),linear-gradient(160deg,#2c3a23,#141c0d)}
.tour__poster::before{content:"\269C";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-size:clamp(3rem,7vw,5rem);color:rgba(194,162,104,.22)}
.tour__preview::before{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(transparent 38%,rgba(17,22,12,.6))}
.tour__badge{position:absolute;top:16px;right:16px;z-index:2;font-family:var(--label);font-size:.7rem;
  letter-spacing:.18em;color:var(--parchment);border:1px solid rgba(244,239,225,.55);
  padding:.35em .75em;border-radius:40px;background:rgba(17,22,12,.32);backdrop-filter:blur(4px)}
.tour__cue{position:absolute;left:50%;bottom:24px;transform:translateX(-50%);z-index:2;
  display:inline-flex;align-items:center;gap:.7em;font-family:var(--label);font-size:.78rem;
  letter-spacing:.18em;text-transform:uppercase;color:var(--parchment)}
.tour__cue-icon{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;
  border-radius:50%;background:var(--sage);color:var(--forest-deep);font-size:.72rem;padding-left:3px;
  transition:transform .35s var(--ease)}
.tour__preview:hover .tour__cue-icon{transform:scale(1.12)}
.tour__rooms{display:flex;flex-wrap:wrap;justify-content:center;gap:.7rem;margin-top:1.5rem}
.tour__room{font-family:var(--label);font-size:.75rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-2);background:var(--parchment);border:1px solid var(--line);
  padding:.72em 1.5em;border-radius:40px;cursor:pointer;transition:background .35s var(--ease),color .35s var(--ease),border-color .35s var(--ease)}
.tour__room:hover{border-color:var(--gold);color:var(--gold)}
.tour__room.is-active{background:var(--forest);border-color:var(--forest);color:var(--parchment)}
.tour__note{text-align:center;margin-top:1.1rem;font-style:italic;color:var(--ink-2);font-size:.92rem}

/* ---------- gallery ---------- */
.gallery{padding:clamp(4rem,9vw,7rem) 0}
.gallery__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(.7rem,1.4vw,1.1rem)}
.gallery .ph{min-height:300px}
.gallery .ph--g1{grid-row:span 2;min-height:620px}
.gallery__foot{margin-top:2.4rem;text-align:center}

/* ---------- transfers ---------- */
.transfers{padding:clamp(3.5rem,7vw,6rem) 0;background:var(--forest-deep);color:var(--parchment)}
.transfers__inner{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.transfers__copy .eyebrow{display:block;margin-bottom:1rem;color:var(--gold-2)}
.transfers__copy .section-title{color:var(--parchment);margin-bottom:1rem}
.transfers__copy p{color:rgba(244,239,225,.82);margin-bottom:1.8rem;max-width:44ch}
.transfers .btn--ghost{color:var(--parchment);border-color:rgba(194,162,104,.6)}
.transfers .btn--ghost:hover{background:var(--gold);border-color:var(--gold);color:#fff}
.transfers__list{list-style:none;display:grid;gap:.2rem}
.transfers__list li{display:flex;justify-content:space-between;align-items:baseline;
  padding:1rem .2rem;border-bottom:1px solid rgba(244,239,225,.16);
  font-family:var(--serif);font-size:1.5rem}
.transfers__from{font-family:var(--label);font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--sage)}

/* ---------- reviews ---------- */
.reviews{padding:clamp(4rem,9vw,7rem) 0;text-align:center}
.reviews__grid{display:flex;justify-content:center;gap:clamp(1.4rem,4vw,4rem);flex-wrap:wrap}
.score{display:flex;flex-direction:column;gap:.4rem;padding:1.5rem 2rem;min-width:170px;
  border:1px solid var(--line);border-radius:var(--radius);background:var(--parchment-2)}
.score__fig{font-family:var(--serif);font-size:2.4rem;color:var(--forest);letter-spacing:.04em}
.score__src{font-family:var(--label);font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-2)}
.reviews__note{margin-top:2rem;color:var(--ink-2);font-style:italic}

/* ---------- about ---------- */
.about{position:relative;background:var(--forest-2);color:var(--parchment);text-align:center;
  padding:clamp(4rem,9vw,7rem) 0;background-image:var(--grain),linear-gradient(var(--forest-2),var(--forest-2));
  background-size:180px,auto;background-blend-mode:overlay}
.about__inner{max-width:760px;margin-inline:auto}
.about .eyebrow{display:block;margin-bottom:1.2rem}
.about__text{color:rgba(244,239,225,.84);font-size:1.2rem;margin:1.4rem auto 2rem;max-width:58ch}

/* ---------- footer ---------- */
.site-footer{background:var(--forest-deep);color:var(--parchment-2);padding:clamp(3.5rem,7vw,5.5rem) 0 2rem}
.site-footer__inner{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2.4rem}
.site-footer__brand .brand--footer{color:var(--parchment)}
.brand--footer .brand__name{font-size:1.7rem}
.brand--footer .brand__sub{color:var(--sage)}
.site-footer__estd{font-family:var(--label);font-size:.7rem;letter-spacing:.26em;text-transform:uppercase;color:rgba(244,239,225,.5);margin-top:1rem}
.site-footer__col h3{font-family:var(--label);font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;
  color:var(--sage);margin-bottom:1.1rem;font-weight:500}
.site-footer__col address{font-style:normal;line-height:1.9;color:rgba(244,239,225,.8)}
.site-footer__col a{display:block;color:rgba(244,239,225,.82);padding:.2rem 0;transition:color .3s}
.site-footer__col a:hover{color:var(--sage)}
.site-footer__base{margin-top:3rem;text-align:center}
.site-footer__base p{margin-top:1.7rem;font-family:var(--label);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(244,239,225,.5)}

/* fleur-de-lis divider glyph (shared) */
.rule--fleur{display:flex;align-items:center;justify-content:center;gap:1.1rem}
.rule--fleur::before,.rule--fleur::after{content:"";height:1px;flex:1;max-width:120px}
.rule--fleur::before{background:linear-gradient(90deg,transparent,currentColor)}
.rule--fleur::after{background:linear-gradient(90deg,currentColor,transparent)}
.welcome .rule--fleur{color:var(--gold)}
.rule--fleur{position:relative}
.rule--fleur{}
.rule--fleur span{display:none}

/* ---------- reveal animations ---------- */
.js [data-rise]{opacity:0;transform:translateY(20px);transition:opacity .85s var(--ease),transform .85s var(--ease)}
body.is-loaded [data-rise]{opacity:1;transform:none}
.js .reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media(max-width:1000px){
  .hero__inner{grid-template-columns:1fr;gap:2.5rem}
  .hero__copy{max-width:none;order:2}
  .hero__crest{order:1}
  .crest-plate{max-width:340px}
  .restaurant__inner,.transfers__inner{grid-template-columns:1fr}
  .restaurant__media{order:2}
  .gallery__grid{grid-template-columns:repeat(2,1fr)}
  .gallery .ph--g1{grid-row:auto;min-height:300px}
  .site-footer__inner{grid-template-columns:1fr 1fr;gap:2rem}
}
@media(max-width:760px){
  .utility__tag{display:none}
  .utility__inner{justify-content:center}
  .primary-nav{position:fixed;inset:0 0 0 auto;width:min(82vw,340px);background:var(--parchment);
    flex-direction:column;justify-content:flex-start;gap:0;padding:6rem 2rem 2rem;
    transform:translateX(100%);transition:transform .45s var(--ease);
    box-shadow:-30px 0 60px -30px rgba(26,36,20,.6);z-index:90}
  .primary-nav.is-open{transform:none}
  .primary-nav a{padding:1.1rem 0;border-bottom:1px solid var(--line-soft);width:100%;font-size:.9rem}
  .nav-toggle{display:flex;z-index:95}
  .ways__grid{grid-template-columns:1fr}
  .site-header__cta .btn--solid{display:none}
  .gallery__grid{grid-template-columns:1fr}
  .site-footer__inner{grid-template-columns:1fr}
  .gather-detail__row{flex-direction:column}
}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto!important}
  [data-rise],.reveal{opacity:1!important;transform:none!important;transition:none!important}
  .hero__scroll-line{display:none}
}

/* ---------- fleur-de-lis divider (final, overrides drafts above) ---------- */
.rule--fleur{position:relative;display:block;height:1px;max-width:340px;margin:2.6rem auto 0;
  background:linear-gradient(90deg,transparent,currentColor 18%,currentColor 82%,transparent);
  color:var(--gold);overflow:visible}
.rule--fleur::after{content:none;background:none}
.rule--fleur::before{content:"\269C";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  font-family:var(--serif);font-size:1.35rem;line-height:1;color:currentColor;
  background:var(--parchment);padding:0 15px}
.rule--light.rule--fleur{color:var(--sage)}
.site-footer__base .rule--fleur::before{background:var(--forest-deep)}

/* ============================================================
   RESTAURANT PAGE
   ============================================================ */
.rhero{position:relative;background:var(--forest-deep);color:var(--parchment);overflow:hidden;
  text-align:center;padding:clamp(3.5rem,8vw,6rem) 0}
.rhero::before{content:"";position:absolute;inset:0;
  background:radial-gradient(120% 90% at 50% 0,rgba(136,168,92,.22),transparent 55%),linear-gradient(160deg,#2c3a23,#19220f)}
.rhero::after{content:"";position:absolute;inset:clamp(12px,2vw,20px);border:1px solid rgba(194,162,104,.34);pointer-events:none}
.rhero__grain{position:absolute;inset:0;background-image:var(--grain);background-size:180px;opacity:.06;mix-blend-mode:overlay}
.rhero__inner{position:relative;z-index:2;max-width:720px;margin-inline:auto}
.rhero .eyebrow{display:block;margin-bottom:1.1rem;color:var(--gold-2)}
.rhero__title{font-family:var(--serif);font-weight:300;font-size:clamp(2.8rem,7vw,5.2rem);line-height:1;margin-bottom:1.3rem}
.rhero__lede{color:rgba(244,239,225,.85);font-size:clamp(1.05rem,1.4vw,1.3rem);margin-bottom:2rem}
.rhero__actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.rhero .btn--solid{background:var(--sage);border-color:var(--sage);color:var(--forest-deep)}
.rhero .btn--solid:hover{background:var(--gold-2);border-color:var(--gold-2)}
.rhero .btn--ghost{color:var(--parchment);border-color:rgba(244,239,225,.5)}
.rhero .btn--ghost:hover{background:var(--parchment);color:var(--forest-deep);border-color:var(--parchment)}

.howto{padding:clamp(3.5rem,7vw,5.5rem) 0;background:var(--parchment)}
.howto__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(1rem,2vw,1.6rem)}
.howto__item{text-align:center;padding:1.6rem 1.2rem;border:1px solid var(--line-soft);border-radius:var(--radius);background:var(--parchment-2)}
.howto__ic{color:var(--gold);font-size:1rem}
.howto__item h3{font-family:var(--serif);font-weight:500;font-size:1.5rem;margin:.5rem 0 .4rem}
.howto__item p{color:var(--ink-2);font-size:.96rem}

.menu-section{padding:clamp(3rem,6vw,5rem) 0 clamp(5rem,9vw,7rem);background:var(--parchment-2)}
.menu-tools{position:sticky;top:0;z-index:50;background:var(--parchment-2);
  padding:1rem 0 .8rem;margin-bottom:1.5rem;border-bottom:1px solid var(--line)}
.menu-search input{width:100%;font-family:var(--body);font-size:1.05rem;color:var(--ink);
  background:var(--parchment);border:1px solid var(--line);border-radius:40px;
  padding:.85em 1.4em;margin-bottom:.9rem}
.menu-search input:focus{outline:none;border-color:var(--gold)}
.menu-nav{display:flex;gap:.5rem;overflow-x:auto;scrollbar-width:thin;padding-bottom:.3rem;scroll-behavior:smooth}
.menu-nav__chip{flex:0 0 auto;font-family:var(--label);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-2);background:var(--parchment);border:1px solid var(--line);
  padding:.55em 1.1em;border-radius:40px;transition:all .3s var(--ease)}
.menu-nav__chip:hover{border-color:var(--gold);color:var(--gold)}
.menu-nav__chip.is-active{background:var(--forest);border-color:var(--forest);color:var(--parchment)}

.menu-cat{padding-top:clamp(1.5rem,3vw,2.5rem);scroll-margin-top:150px}
.menu-cat__head{display:flex;align-items:baseline;gap:1rem;flex-wrap:wrap;margin-bottom:1.2rem;
  padding-bottom:.6rem;border-bottom:2px solid var(--forest)}
.menu-cat__title{font-family:var(--serif);font-weight:500;font-size:clamp(1.8rem,3.2vw,2.5rem);color:var(--forest)}
.menu-cat__note{font-family:var(--label);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold)}
.menu-cat__items{display:grid;grid-template-columns:1fr 1fr;gap:0 clamp(2rem,4vw,4rem)}
.dish{display:flex;align-items:baseline;gap:1rem;padding:.95rem 0;border-bottom:1px solid var(--line-soft)}
.dish__info{flex:1}
.dish__name{font-family:var(--serif);font-weight:500;font-size:1.3rem;line-height:1.15;color:var(--ink)}
.dish__desc{font-size:.92rem;color:var(--ink-2);margin-top:2px}
.dish__buy{display:flex;align-items:center;gap:.9rem;flex:0 0 auto}
.dish__price{font-family:var(--label);font-size:.92rem;letter-spacing:.04em;color:var(--gold);white-space:nowrap}
.dish__add{font-family:var(--label);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--forest);background:transparent;border:1px solid var(--forest);border-radius:40px;
  padding:.5em 1.1em;cursor:pointer;transition:all .3s var(--ease)}
.dish__add:hover{background:var(--forest);color:var(--parchment)}
.dish__add.is-added{background:var(--sage);border-color:var(--sage);color:var(--forest-deep)}
.menu-empty{text-align:center;color:var(--ink-2);font-style:italic;padding:2rem 0}

/* basket FAB */
.basket-fab{position:fixed;right:clamp(16px,2.5vw,28px);bottom:clamp(16px,2.5vw,28px);z-index:80;
  display:inline-flex;align-items:center;gap:.6rem;cursor:pointer;
  font-family:var(--label);font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--parchment);background:var(--forest);border:1px solid var(--forest-deep);
  padding:.9em 1.3em;border-radius:50px;box-shadow:0 20px 40px -18px rgba(26,36,20,.8);
  transition:transform .35s var(--ease),background .35s}
.basket-fab:hover{transform:translateY(-3px);background:var(--forest-2)}
.basket-fab__icon{font-size:1.1rem}
.basket-fab__count{display:inline-grid;place-items:center;min-width:22px;height:22px;padding:0 5px;
  background:var(--sage);color:var(--forest-deep);border-radius:40px;font-size:.72rem}
.basket-fab__total{font-variant-numeric:tabular-nums}
.basket-fab:not(.has-items) .basket-fab__total{display:none}

/* basket panel */
.basket-overlay{position:fixed;inset:0;background:rgba(20,26,14,.5);z-index:119;backdrop-filter:blur(2px)}
.basket{position:fixed;top:0;right:0;height:100%;width:min(430px,100%);z-index:120;
  background:var(--parchment);box-shadow:-30px 0 70px -30px rgba(26,36,20,.7);
  transform:translateX(100%);transition:transform .45s var(--ease);
  display:block;overflow-y:auto;-webkit-overflow-scrolling:touch}
.basket.is-open{transform:none}
.basket__head{position:sticky;top:0;z-index:3;display:flex;align-items:center;justify-content:space-between;
  padding:1.4rem clamp(1.2rem,3vw,2rem);background:var(--forest);color:var(--parchment)}
.basket__head h2{font-family:var(--serif);font-weight:500;font-size:1.7rem}
.basket__close{background:none;border:0;color:var(--parchment);font-size:2rem;line-height:1;cursor:pointer;padding:0 .2em}
.basket__close:hover{color:var(--sage)}
.basket__body{padding:clamp(1.2rem,3vw,1.8rem)}
.basket__empty{color:var(--ink-2);font-style:italic;text-align:center;margin-top:2rem}
.basket__items{list-style:none}
.bitem{padding:.9rem 0;border-bottom:1px solid var(--line-soft)}
.bitem__top{display:flex;justify-content:space-between;gap:1rem}
.bitem__name{font-family:var(--serif);font-size:1.18rem}
.bitem__price{font-family:var(--label);font-size:.9rem;color:var(--gold)}
.bitem__qty{display:flex;align-items:center;gap:.5rem;margin-top:.5rem}
.qbtn{width:30px;height:30px;border:1px solid var(--line);background:var(--parchment-2);border-radius:50%;
  cursor:pointer;font-size:1rem;line-height:1;color:var(--ink)}
.qbtn:hover{border-color:var(--gold);color:var(--gold)}
.qval{min-width:24px;text-align:center;font-family:var(--label)}
.bitem__rm{margin-left:auto;background:none;border:0;color:var(--ink-2);font-family:var(--label);
  font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;text-decoration:underline}
.bitem__rm:hover{color:#8a2e22}
.basket__order{padding:clamp(1.2rem,3vw,1.8rem);border-top:1px solid var(--line);background:var(--parchment-2)}
.basket__totals{display:flex;justify-content:space-between;font-family:var(--serif);font-size:1.4rem;margin-bottom:1.2rem}
.basket__field{margin-bottom:.9rem}
.basket__field legend,.basket__field label{display:block;font-family:var(--label);font-size:.68rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--ink-2);margin-bottom:.5rem}
.basket__field input{width:100%;font-family:var(--body);font-size:1rem;color:var(--ink);
  background:var(--parchment);border:1px solid var(--line);border-radius:var(--radius);padding:.7em .9em}
.basket__field input:focus{outline:none;border-color:var(--gold)}
.basket__opts{display:flex;flex-wrap:wrap;gap:.5rem}
.basket__opts label{display:inline-flex;align-items:center;gap:.4em;margin:0;cursor:pointer;
  border:1px solid var(--line);border-radius:40px;padding:.5em .9em;letter-spacing:.04em;text-transform:none;
  font-family:var(--body);font-size:.92rem;color:var(--ink)}
.basket__opts input{accent-color:var(--forest)}
.basket__row{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}
.basket__submit{width:100%;text-align:center;margin-top:.6rem}
.basket__call{width:100%;text-align:center;margin-top:.6rem}
.basket__pay-note{font-size:.82rem;color:var(--ink-2);font-style:italic;margin-top:.9rem;line-height:1.5}

@media(max-width:760px){
  .howto__grid{grid-template-columns:1fr 1fr}
  .menu-cat__items{grid-template-columns:1fr}
  .basket{width:100%}
  .basket-fab{left:16px;right:16px;justify-content:center}
}

/* ============================================================
   SHARED INTERIOR PAGES — page hero, prose, provide, livestream,
   fares, enquiry forms (funeral.html + transfers.html)
   ============================================================ */
.phero{position:relative;overflow:hidden;padding:clamp(3.5rem,8vw,6rem) 0;text-align:center}
.phero__inner{position:relative;z-index:2;max-width:780px;margin-inline:auto}
.phero .eyebrow{display:block;margin-bottom:1.1rem}
.phero__title{font-family:var(--serif);font-weight:300;font-size:clamp(2.5rem,6vw,4.6rem);line-height:1.05;margin-bottom:1.4rem;color:var(--ink)}
.phero__lede{font-size:clamp(1.05rem,1.4vw,1.3rem);margin-bottom:2rem;color:var(--ink-2)}
.phero__actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.phero__grain{position:absolute;inset:0;background-image:var(--grain);background-size:180px;opacity:.06;mix-blend-mode:overlay}
.phero--calm{background:var(--parchment)}
.phero--calm::before{content:"";position:absolute;inset:0;background:radial-gradient(100% 80% at 50% 0,rgba(177,207,134,.20),transparent 62%)}
.phero--dark{background:var(--forest-deep);color:var(--parchment)}
.phero--dark::before{content:"";position:absolute;inset:0;background:radial-gradient(120% 90% at 50% 0,rgba(136,168,92,.22),transparent 55%),linear-gradient(160deg,#2c3a23,#19220f)}
.phero--dark::after{content:"";position:absolute;inset:clamp(12px,2vw,20px);border:1px solid rgba(194,162,104,.34);pointer-events:none}
.phero__title--light{color:var(--parchment)}
.phero__lede--light{color:rgba(244,239,225,.85)}
.phero--dark .btn--solid{background:var(--sage);border-color:var(--sage);color:var(--forest-deep)}
.phero--dark .btn--solid:hover{background:var(--gold-2);border-color:var(--gold-2)}
.phero--dark .btn--ghost{color:var(--parchment);border-color:rgba(244,239,225,.5)}
.phero--dark .btn--ghost:hover{background:var(--parchment);color:var(--forest-deep);border-color:var(--parchment)}

.prose{padding:clamp(3.5rem,8vw,6rem) 0;text-align:center}
.prose__inner{max-width:760px;margin-inline:auto}
.prose__lead{font-family:var(--serif);font-weight:300;font-size:clamp(1.4rem,2.8vw,2.1rem);line-height:1.42;color:var(--ink)}

.provide{padding:clamp(2rem,5vw,4rem) 0 clamp(3.5rem,8vw,6rem)}
.provide__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.2rem,2.4vw,2rem)}

.livestream{position:relative;overflow:hidden;background:var(--forest);color:var(--parchment);padding:clamp(3.5rem,8vw,6rem) 0}
.livestream__grain{position:absolute;inset:0;background-image:var(--grain);background-size:180px;opacity:.05;mix-blend-mode:overlay}
.livestream__inner{position:relative;display:grid;grid-template-columns:1.2fr .8fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.livestream .eyebrow{display:block;margin-bottom:1rem}
.livestream__lead{color:rgba(244,239,225,.85);font-size:1.15rem;margin:1.2rem 0 1.4rem}
.livestream__points{list-style:none;display:grid;gap:.6rem}
.livestream__points li{position:relative;padding-left:1.6rem;color:rgba(244,239,225,.9)}
.livestream__points li::before{content:"\269C";position:absolute;left:0;color:var(--sage)}
.livestream__card{background:rgba(244,239,225,.06);border:1px solid rgba(194,162,104,.4);border-radius:var(--radius);padding:clamp(1.6rem,3vw,2.4rem);text-align:center}
.livestream__card-label{font-family:var(--label);font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--sage)}
.livestream__price{font-family:var(--serif);font-weight:300;font-size:4.5rem;line-height:1;color:var(--parchment);margin:.3rem 0}
.livestream__price span{font-size:2rem;vertical-align:super}
.livestream__card-sub{font-size:.9rem;color:rgba(244,239,225,.75);margin-bottom:1.5rem}
.livestream__note{font-size:.82rem;color:rgba(244,239,225,.6);font-style:italic;margin-top:1rem}

.fares{padding:clamp(3.5rem,8vw,6rem) 0;background:var(--parchment-2)}
.fares__list{list-style:none;max-width:680px;margin:0 auto;border-top:1px solid var(--line)}
.fares__list li{display:flex;align-items:baseline;gap:1rem;padding:1.05rem .2rem;border-bottom:1px solid var(--line)}
.fares__place{font-family:var(--serif);font-size:1.6rem;color:var(--ink)}
.fares__dots{flex:1;border-bottom:1px dotted var(--line);transform:translateY(-5px)}
.fares__price{font-family:var(--label);font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);white-space:nowrap}
.fares__foot{max-width:680px;margin:1.6rem auto 0;text-align:center;color:var(--ink-2);font-size:.95rem;font-style:italic}

.enquire{padding:clamp(3.5rem,8vw,6rem) 0}
.enquire--dark{background:var(--forest-deep);color:var(--parchment)}
.enquire__inner{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2rem,5vw,4.5rem);align-items:start}
.enquire__intro .eyebrow{display:block;margin-bottom:1rem}
.enquire__intro .section-title{margin-bottom:1rem}
.enquire__intro p{color:var(--ink-2)}
.enquire--dark .enquire__intro p,.enquire__p-light{color:rgba(244,239,225,.82)}
.inline-link{color:var(--gold);border-bottom:1px solid currentColor}
.inline-link--light{color:var(--sage)}

.form__row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form__field{margin-bottom:1rem}
.form__field label{display:block;font-family:var(--label);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-2);margin-bottom:.45rem}
.form__field input,.form__field select,.form__field textarea{width:100%;font-family:var(--body);font-size:1rem;color:var(--ink);background:var(--parchment);border:1px solid var(--line);border-radius:var(--radius);padding:.75em .9em}
.form__field textarea{resize:vertical}
.form__field input:focus,.form__field select:focus,.form__field textarea:focus{outline:none;border-color:var(--gold)}
.form__submit{margin-top:.6rem}
.form__note{margin-top:1rem;font-size:.9rem;color:var(--ink-2);font-style:italic;min-height:1.2em}
.form--dark .form__field label{color:rgba(244,239,225,.7)}
.form--dark .form__field input,.form--dark .form__field select,.form--dark .form__field textarea{background:rgba(244,239,225,.07);border-color:rgba(244,239,225,.25);color:var(--parchment)}
.form--dark .form__field input::placeholder,.form--dark .form__field textarea::placeholder{color:rgba(244,239,225,.4)}
.form__note--light{color:rgba(244,239,225,.65)}

@media(max-width:900px){
  .provide__grid{grid-template-columns:1fr}
  .livestream__inner,.enquire__inner{grid-template-columns:1fr}
}
@media(max-width:760px){
  .form__row{grid-template-columns:1fr}
}

/* ============================================================
   ROOMS · GALLERY · ABOUT · CONTACT
   ============================================================ */
/* rooms */
.rooms-sec{padding:clamp(3rem,6vw,5rem) 0 clamp(3.5rem,8vw,6rem)}
.rooms-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.2rem,2.4vw,2rem)}
.roomcard{background:var(--parchment);border:1px solid var(--line-soft);border-radius:var(--radius);overflow:hidden;
  transition:transform .5s var(--ease),box-shadow .5s var(--ease)}
.roomcard:hover{transform:translateY(-6px);box-shadow:0 30px 50px -34px rgba(26,36,20,.5)}
.roomcard__img{min-height:230px;border:0;border-radius:0}
.roomcard__body{padding:clamp(1.4rem,2.2vw,1.9rem)}
.roomcard__title{font-family:var(--serif);font-weight:500;font-size:1.7rem;margin-bottom:.5rem}
.roomcard__text{color:var(--ink-2);margin-bottom:1.2rem}
.amenities{list-style:none;display:flex;flex-wrap:wrap;justify-content:center;gap:.6rem 2rem;margin-top:clamp(2rem,4vw,3rem)}
.amenities li{position:relative;padding-left:1.5rem;font-family:var(--label);font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-2)}
.amenities li::before{content:"\269C";position:absolute;left:0;color:var(--gold)}

/* check-in / check-out */
.checkin{position:relative;overflow:hidden;background:var(--forest);color:var(--parchment);padding:clamp(3.5rem,8vw,6rem) 0}
.checkin__grain{position:absolute;inset:0;background-image:var(--grain);background-size:180px;opacity:.05;mix-blend-mode:overlay}
.checkin__grid{position:relative;display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.2rem,2.4vw,2rem)}
.checkin__card{border:1px solid rgba(194,162,104,.35);border-radius:var(--radius);padding:clamp(1.6rem,2.6vw,2.2rem);text-align:center}
.checkin__card h3{font-family:var(--label);font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--sage);margin-bottom:1rem}
.checkin__time{font-family:var(--serif);font-size:clamp(1.8rem,3vw,2.4rem);color:var(--parchment);margin-bottom:.8rem}
.checkin__detail{color:rgba(244,239,225,.82);font-size:.96rem}
.checkin__fee{display:block;margin-top:.7rem;font-family:var(--label);font-size:.82rem;letter-spacing:.12em;color:var(--gold-2)}

/* stats (about) */
.stats{position:relative;overflow:hidden;background:var(--forest-deep);color:var(--parchment);padding:clamp(3rem,6vw,4.5rem) 0}
.stats__grain{position:absolute;inset:0;background-image:var(--grain);background-size:180px;opacity:.05;mix-blend-mode:overlay}
.stats__grid{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;text-align:center}
.stat{display:flex;flex-direction:column;gap:.5rem}
.stat__fig{font-family:var(--serif);font-weight:300;font-size:clamp(2.2rem,4vw,3.2rem);color:var(--sage);line-height:1}
.stat__lbl{font-family:var(--label);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(244,239,225,.7)}

/* split (about) */
.split{padding:clamp(3.5rem,8vw,6rem) 0}
.split__inner{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.split__media{min-height:420px}
.split__copy .eyebrow{display:block;margin-bottom:1rem}
.split__copy .section-title{margin-bottom:1.2rem}
.split__copy p{color:var(--ink-2);margin-bottom:1.1rem}

/* group band (about) */
.group-band{position:relative;overflow:hidden;background:var(--forest);color:var(--parchment);text-align:center;padding:clamp(3.5rem,8vw,6rem) 0}
.group-band__grain{position:absolute;inset:0;background-image:var(--grain);background-size:180px;opacity:.05;mix-blend-mode:overlay}
.group-band__inner{position:relative;max-width:760px;margin-inline:auto}
.group-band .eyebrow{display:block;margin-bottom:1rem}
.group-band__lead{color:rgba(244,239,225,.85);font-size:1.15rem;margin:1.3rem auto 1.8rem}
.group-band__tags{display:flex;justify-content:center;gap:.7rem;flex-wrap:wrap;margin-bottom:2rem}
.group-band__tags span{font-family:var(--label);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--sage);border:1px solid rgba(194,162,104,.4);border-radius:40px;padding:.5em 1.1em}
.group-band__cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.group-band .btn--ghost{color:var(--parchment);border-color:rgba(244,239,225,.5)}
.group-band .btn--ghost:hover{background:var(--parchment);color:var(--forest-deep);border-color:var(--parchment)}

/* gallery */
.gallery-filter{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem;margin-bottom:2rem}
.gallery-filter__chip{font-family:var(--label);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-2);background:var(--parchment);border:1px solid var(--line);padding:.55em 1.2em;border-radius:40px;cursor:pointer;transition:all .3s var(--ease)}
.gallery-filter__chip:hover{border-color:var(--gold);color:var(--gold)}
.gallery-filter__chip.is-active{background:var(--forest);border-color:var(--forest);color:var(--parchment)}
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));grid-auto-rows:200px;gap:clamp(.7rem,1.2vw,1rem)}
.gtile{min-height:0!important;height:100%}
.gtile--tall{grid-row:span 2}
.gallery-grid .ph__label{margin-top:0;position:absolute;bottom:14px}

/* contact */
.contact-main{padding:clamp(3rem,6vw,5rem) 0}
.contact-main__inner{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(2rem,5vw,4rem);align-items:stretch}
.contact-details__h{font-family:var(--serif);font-weight:500;font-size:clamp(1.8rem,3vw,2.4rem);margin-bottom:1.8rem;color:var(--ink)}
.contact-block{margin-bottom:1.6rem;padding-bottom:1.6rem;border-bottom:1px solid var(--line-soft)}
.contact-block:last-child{border-bottom:0}
.contact-block__lbl{font-family:var(--label);font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:.5rem}
.contact-block address{font-style:normal;font-size:1.15rem;line-height:1.6;color:var(--ink)}
.contact-big{font-family:var(--serif);font-size:1.5rem;color:var(--ink);border-bottom:1px solid var(--line)}
.contact-big:hover{color:var(--gold);border-color:var(--gold)}
.contact-map{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);min-height:380px;box-shadow:0 30px 50px -38px rgba(26,36,20,.5)}
.contact-map iframe{width:100%;height:100%;min-height:380px;border:0;display:block;filter:grayscale(.2) sepia(.08)}

@media(max-width:900px){
  .rooms-grid{grid-template-columns:1fr}
  .checkin__grid{grid-template-columns:1fr}
  .stats__grid{grid-template-columns:1fr 1fr}
  .split__inner,.contact-main__inner{grid-template-columns:1fr}
  .split__media{min-height:300px}
}
