/* =========================================================
   DALKEITH GREAT HOUSE — faithful to preview styling
   Serif: Cormorant Garamond · Labels: Manrope
   Palette: cream #F8F6F2 · green #24352D · gold #B89A67
   ========================================================= */

:root{
  --paper:#F8F6F2;
  --paper-2:#F1ECE2;
  --ink:#24352D;
  --ink-soft:#54605528;
  --ink-mut:#5c655c;
  --gold:#B89A67;
  --label:#9c885f;
  --line:rgba(36,53,45,.14);
  --line-light:rgba(255,255,255,.28);
  --white:#ffffff;

  --serif:"Cormorant Garamond",Georgia,"Times New Roman",serif;
  --sans:"Manrope",system-ui,-apple-system,sans-serif;

  --maxw:1320px;
  --gut:clamp(22px,5vw,80px);
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--serif);
  font-size:18px;
  line-height:1.5;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--gold);color:#fff}

.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gut)}

/* ---------- typography ---------- */
h1,h2,h3{font-family:var(--serif);font-weight:300;line-height:1.02;letter-spacing:-.012em}
h2{font-size:clamp(2.4rem,5.6vw,4.4rem)}
h2 em,h1 em,.it{font-style:italic;font-weight:300}
p{font-family:var(--serif)}

.eyebrow{
  font-family:var(--sans);
  font-size:10.5px;
  font-weight:500;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--label);
}
.label{
  font-family:var(--sans);font-size:10.5px;font-weight:600;
  letter-spacing:.3em;text-transform:uppercase;color:var(--label);
}

/* centered section header */
.head{text-align:center;margin-bottom:clamp(2.5rem,5vw,4.5rem)}
.head .eyebrow{display:block;margin-bottom:1.4rem}
.head h2{margin:0 auto}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:1em;
  font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.28em;text-transform:uppercase;
  padding:1.25em 2em;border:1px solid var(--ink);background:transparent;color:var(--ink);
  transition:background .45s var(--ease),color .45s var(--ease);cursor:pointer;
}
.btn .arw{font-family:var(--sans);transition:transform .45s var(--ease)}
.btn:hover{background:var(--ink);color:var(--paper)}
.btn:hover .arw{transform:translateX(5px)}
.btn--solid{background:var(--ink);color:var(--paper)}
.btn--solid:hover{background:transparent;color:var(--ink)}
.btn--gold{background:var(--gold);border-color:var(--gold);color:#fff}
.btn--gold:hover{background:transparent;color:var(--gold)}
.btn--light{border-color:rgba(255,255,255,.6);color:#fff;background:rgba(255,255,255,.06)}
.btn--light:hover{background:#fff;color:var(--ink);border-color:#fff}

/* =========================================================
   NAV
   ========================================================= */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:80;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.5rem var(--gut);color:#fff;
  transition:background .5s var(--ease),padding .5s var(--ease),color .5s var(--ease),box-shadow .5s var(--ease);
}
.nav.scrolled{background:rgba(248,246,242,.94);backdrop-filter:blur(12px);color:var(--ink);padding-block:1.05rem;box-shadow:0 1px 0 var(--line)}
.nav__logo{font-family:var(--serif);font-size:1.5rem;font-weight:400;letter-spacing:.005em;white-space:nowrap}
.nav__logo em{font-style:italic}
.nav__links{display:flex;align-items:center;gap:2.4rem}
.nav__links a{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;position:relative;opacity:.9}
.nav__links a:not(.nav__cta)::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:1px;background:currentColor;transition:width .35s var(--ease)}
.nav__links a:not(.nav__cta):hover::after{width:100%}
.nav__cta{display:inline-flex;align-items:center;gap:.8em;background:var(--gold);color:#fff!important;padding:1em 1.5em;letter-spacing:.28em;font-weight:600}
.nav__cta .arw{transition:transform .4s var(--ease)}
.nav__cta:hover .arw{transform:translateX(5px)}
.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px;z-index:90}
.nav__burger span{width:26px;height:1.5px;background:currentColor;transition:.3s var(--ease)}

/* =========================================================
   HERO
   ========================================================= */
.hero{position:relative;height:100svh;min-height:640px;display:flex;align-items:center;justify-content:center;color:#fff;overflow:hidden;text-align:center}
.hero__bg{position:absolute;inset:0;z-index:0}
.hero__bg img{width:100%;height:100%;object-fit:cover;transform:scale(1.06);animation:heroZoom 16s var(--ease) forwards}
@keyframes heroZoom{to{transform:scale(1)}}
.hero__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(26,34,28,.42),rgba(26,34,28,.18)35%,rgba(26,34,28,.55))}
.hero__corner{position:absolute;top:6.2rem;z-index:3;font-family:var(--sans);font-size:10.5px;font-weight:500;letter-spacing:.32em;text-transform:uppercase;color:rgba(255,255,255,.72)}
.hero__corner.l{left:var(--gut)}
.hero__corner.r{right:var(--gut);text-align:right}
.hero__center{position:relative;z-index:2;padding-inline:var(--gut)}
.hero h1{font-size:clamp(3.1rem,12.2vw,12rem);font-weight:300;letter-spacing:-.03em;line-height:.86;text-shadow:0 4px 60px rgba(0,0,0,.22)}
.hero__sub{display:flex;align-items:center;justify-content:center;gap:1.4rem;margin-top:2rem}
.hero__sub i{display:block;width:clamp(40px,8vw,90px);height:1px;background:rgba(255,255,255,.55)}
.hero__sub span{font-style:italic;font-size:clamp(1.05rem,1.9vw,1.45rem);color:rgba(255,255,255,.92)}
.hero__from{position:absolute;left:var(--gut);bottom:2.4rem;z-index:3;text-align:left}
.hero__from .label{color:rgba(255,255,255,.7);display:block;margin-bottom:.5rem}
.hero__from b{font-family:var(--serif);font-style:italic;font-weight:400;font-size:1.7rem;color:#fff}
.hero__from b small{font-size:.95rem;font-style:normal;opacity:.8}
.hero__cta{position:absolute;left:50%;transform:translateX(-50%);bottom:2.2rem;z-index:3}
.hero__scroll{position:absolute;right:var(--gut);bottom:2.4rem;z-index:3;display:flex;flex-direction:column;align-items:center;gap:.8rem}
.hero__scroll span{font-family:var(--sans);font-size:9.5px;font-weight:500;letter-spacing:.32em;text-transform:uppercase;color:rgba(255,255,255,.7)}
.hero__scroll i{width:1px;height:46px;background:linear-gradient(rgba(255,255,255,.7),transparent);animation:scrollline 2.4s var(--ease) infinite}
@keyframes scrollline{0%,100%{transform:scaleY(.35);transform-origin:top;opacity:.4}50%{transform:scaleY(1);transform-origin:top;opacity:1}}

/* =========================================================
   SECTIONS
   ========================================================= */
.sec{padding-block:clamp(5rem,12vh,9.5rem)}

/* ---- Welcome ---- */
.welcome{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,7vw,7rem);align-items:start}
.welcome__lead{margin-top:2.6rem;font-style:italic;font-size:clamp(1.3rem,2.4vw,1.95rem);line-height:1.38;color:var(--ink-mut);max-width:18ch}
.welcome h2{margin-bottom:1.8rem}
.welcome__body p{font-size:1.25rem;line-height:1.62;color:var(--ink-mut)}
.welcome__body p+p{margin-top:1.3rem}
.stats{display:flex;flex-wrap:wrap;gap:3rem;margin-top:2.8rem;padding-top:2.4rem;border-top:1px solid var(--line)}
.stat .label{display:block;color:var(--label);margin-bottom:.55rem}
.stat b{font-family:var(--serif);font-weight:400;font-size:1.45rem}

/* ---- Plate (full-bleed) ---- */
.plate{position:relative;height:92svh;min-height:560px;color:#fff;overflow:hidden;display:flex;align-items:center}
.plate img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.plate::after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,rgba(20,28,22,.55),rgba(20,28,22,.12)55%,rgba(20,28,22,.4))}
.plate__inner{position:relative;z-index:2;width:100%;max-width:var(--maxw);margin:0 auto;padding-inline:var(--gut)}
.plate__tag{position:absolute;top:2.4rem;left:var(--gut);font-family:var(--sans);font-size:10.5px;font-weight:600;letter-spacing:.32em;text-transform:uppercase;color:rgba(255,255,255,.8)}
.plate__caption{position:absolute;right:var(--gut);bottom:2.6rem;max-width:30ch;text-align:right;font-style:italic;font-size:1.2rem;line-height:1.4;color:rgba(255,255,255,.92)}
.plate h2{font-size:clamp(3rem,9vw,7rem);color:rgba(255,255,255,.9);line-height:.9}
.plate__meta{position:absolute;left:var(--gut);bottom:2.6rem;display:flex;gap:2.6rem}
.plate__meta .label{color:rgba(255,255,255,.65);display:block;margin-bottom:.45rem}
.plate__meta b{font-family:var(--serif);font-weight:400;font-size:1.25rem;color:#fff}

/* ---- Numerals ---- */
.num-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--line)}
.num{padding:2.8rem 1.8rem 0;border-right:1px solid var(--line)}
.num:last-child{border-right:0}
.num__rom{font-family:var(--sans);font-size:10.5px;font-weight:600;letter-spacing:.3em;color:var(--gold)}
.num__fig{font-family:var(--serif);font-weight:300;font-size:clamp(3.2rem,6vw,5.2rem);line-height:1;margin:1.5rem 0 .7rem;letter-spacing:-.02em}
.num__fig small{font-size:.42em;font-style:italic;color:var(--gold);letter-spacing:0}
.num__lbl{font-family:var(--sans);font-size:10.5px;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--ink);margin-bottom:1rem}
.num p{font-size:1.1rem;line-height:1.5;color:var(--ink-mut)}

/* ---- Accommodation (staggered diptych) ---- */
.dip{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,6vw,6rem);align-items:start}
.dip__col.b{margin-top:clamp(3rem,10vw,10rem)}
.dip__img{overflow:hidden;margin-bottom:1.8rem}
.dip__col.a .dip__img{aspect-ratio:16/10}
.dip__col.b .dip__img{aspect-ratio:4/5}
.dip__img img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.dip__col:hover .dip__img img{transform:scale(1.05)}
.dip .label{display:block;margin-bottom:1rem}
.dip p{font-size:1.2rem;line-height:1.55;color:var(--ink-mut);max-width:46ch}
.dip__rule{width:48px;height:1px;background:var(--gold);margin:1.8rem 0}
.dip__note{font-style:italic;font-size:1.3rem;color:var(--ink);max-width:30ch}

/* ---- Experiences ---- */
.exp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.6rem,3vw,2.8rem)}
.exp__img{aspect-ratio:3/4;overflow:hidden;margin-bottom:1.6rem}
.exp__img img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.exp-card:hover .exp__img img{transform:scale(1.05)}
.exp__top{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:.9rem}
.exp__rom{font-family:var(--sans);font-size:10.5px;font-weight:600;letter-spacing:.3em;color:var(--gold)}
.exp__time{font-family:var(--sans);font-size:10px;font-weight:500;letter-spacing:.28em;text-transform:uppercase;color:var(--ink-mut)}
.exp-card h3{font-size:1.7rem;margin-bottom:.7rem}
.exp-card p{font-size:1.1rem;line-height:1.5;color:var(--ink-mut)}

/* ---- Events ---- */
.events{background:var(--paper-2)}
.ev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.4rem,2.5vw,2rem)}
.ev-card{position:relative;overflow:hidden;aspect-ratio:4/5;display:flex;align-items:flex-end;color:#fff;cursor:default}
.ev-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.3s var(--ease)}
.ev-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,28,22,.05)40%,rgba(20,28,22,.8))}
.ev-card:hover img{transform:scale(1.06)}
.ev-card__txt{position:relative;z-index:2;padding:2rem}
.ev-card__no{font-family:var(--sans);font-size:10.5px;font-weight:600;letter-spacing:.3em;color:var(--gold);display:block;margin-bottom:.8rem}
.ev-card h3{font-size:1.9rem;margin-bottom:.6rem}
.ev-card p{font-size:1.05rem;line-height:1.45;color:rgba(255,255,255,.85);max-width:34ch}
.ev-card__tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}
.ev-card__tags span{font-family:var(--sans);font-size:9.5px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;border:1px solid rgba(255,255,255,.4);padding:.45em .7em;color:rgba(255,255,255,.92)}
.ev-note{text-align:center;margin-top:3rem;font-style:italic;font-size:1.25rem;color:var(--ink-mut)}
.ev-note a{color:var(--gold);border-bottom:1px solid var(--gold)}

/* ---- Reviews carousel ---- */
.reviews{text-align:center}
.rev-score{font-family:var(--serif);font-weight:300;font-size:clamp(4rem,11vw,8.5rem);line-height:1;color:var(--ink);letter-spacing:-.02em}
.rev-stars{color:var(--gold);letter-spacing:.3em;font-size:1rem;margin-top:.4rem}
.rev-stage{position:relative;max-width:60ch;margin:2.8rem auto 0;min-height:200px}
.rev-slide{position:absolute;inset:0;opacity:0;visibility:hidden;transition:opacity .7s var(--ease)}
.rev-slide.on{opacity:1;visibility:visible;position:relative}
.rev-quote{font-style:italic;font-size:clamp(1.4rem,2.6vw,2.1rem);line-height:1.4;color:var(--ink)}
.rev-quote::before{content:"\201C";display:block;font-size:3rem;color:var(--gold);line-height:.6;margin-bottom:.6rem}
.rev-name{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.3em;text-transform:uppercase;color:var(--ink);margin-top:1.6rem}
.rev-name small{display:block;font-weight:500;letter-spacing:.22em;color:var(--ink-mut);margin-top:.5rem}
.rev-cats{display:flex;flex-wrap:wrap;justify-content:center;gap:2.4rem 3rem;margin-top:3.4rem;padding-top:2.6rem;border-top:1px solid var(--line);max-width:760px;margin-inline:auto}
.rev-cat b{font-family:var(--serif);font-weight:400;font-size:1.6rem;display:block}
.rev-cat .label{display:block;margin-top:.4rem;color:var(--label)}
.rev-dots{display:flex;justify-content:center;gap:.6rem;margin-top:2.6rem}
.rev-dots button{width:26px;height:2px;border:0;background:var(--line);cursor:pointer;padding:0;transition:background .3s}
.rev-dots button.on{background:var(--gold)}

/* ---- Gallery ---- */
.gal-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:210px;gap:14px}
.gal-grid figure{overflow:hidden;position:relative}
.gal-grid img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.gal-grid figure:hover img{transform:scale(1.07)}
.gal-grid .tall{grid-row:span 2}
.gal-grid .wide{grid-column:span 2}

/* ---- Facts ---- */
.facts{background:var(--paper-2)}
.facts-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.fact{padding:2.6rem 1rem;text-align:center;border-right:1px solid var(--line)}
.fact:last-child{border-right:0}
.fact b{font-family:var(--serif);font-weight:300;font-size:clamp(2.2rem,3.5vw,3rem);display:block;margin-bottom:.6rem}
.fact .label{color:var(--ink-mut)}

/* ---- Plan / Book Escape ---- */
.plan{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,6vw,6rem);align-items:center}
.plan__img{aspect-ratio:5/6;overflow:hidden}
.plan__img img{width:100%;height:100%;object-fit:cover}
.plan h2{margin-bottom:1.8rem}
.plan p{font-size:1.25rem;line-height:1.6;color:var(--ink-mut);margin-bottom:2rem;max-width:46ch}
.plan__price{font-family:var(--sans);font-size:10.5px;font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:var(--ink-mut);margin-bottom:2rem}
.plan__price b{font-family:var(--serif);font-style:italic;font-weight:400;font-size:1.5rem;text-transform:none;letter-spacing:0;color:var(--ink);margin-left:.5rem}

/* ---- Final CTA ---- */
.final{position:relative;color:#fff;text-align:center;overflow:hidden}
.final img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.final::after{content:"";position:absolute;inset:0;background:rgba(20,28,22,.58)}
.final__inner{position:relative;z-index:2;padding-block:clamp(6rem,16vh,11rem)}
.final .eyebrow{color:rgba(255,255,255,.7);display:block;margin-bottom:1.6rem}
.final h2{color:#fff;margin-bottom:1.8rem}
.final p{font-size:1.25rem;line-height:1.6;color:rgba(255,255,255,.88);max-width:48ch;margin:0 auto 2.4rem;font-style:italic}

/* ---- Contact ---- */
.contact-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2.6rem}
.contact-col h4{font-family:var(--sans);font-size:10.5px;font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-bottom:1.2rem}
.contact-col p,.contact-col a{font-size:1.1rem;line-height:1.75;color:var(--ink-mut);display:block}
.contact-col a:hover{color:var(--ink)}
.tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.2rem}
.tags span{font-family:var(--sans);font-size:9.5px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;border:1px solid var(--line);padding:.5em .75em;color:var(--ink-mut)}

/* ---- Footer ---- */
.foot{background:var(--ink);color:var(--paper)}
.foot__top{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:2.6rem;padding-block:clamp(3.5rem,7vw,5rem)}
.foot__logo{font-family:var(--serif);font-size:1.7rem}
.foot__logo em{font-style:italic}
.foot__tag{margin-top:1rem;font-style:italic;color:rgba(248,246,242,.7);max-width:32ch;font-size:1.1rem}
.foot__col h5{font-family:var(--sans);font-size:10px;font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-bottom:1.1rem}
.foot__col a{display:block;font-size:1.05rem;color:rgba(248,246,242,.75);padding:.25rem 0}
.foot__col a:hover{color:#fff}
.foot__bar{border-top:1px solid rgba(255,255,255,.14);padding-block:1.6rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:.6rem;font-family:var(--sans);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:rgba(248,246,242,.55)}

/* ---- reveal ---- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.1s}.reveal.d2{transition-delay:.2s}.reveal.d3{transition-delay:.3s}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media(max-width:1000px){
  .welcome{grid-template-columns:1fr;gap:1.5rem}
  .welcome__lead{margin-top:0}
  .num-grid{grid-template-columns:1fr 1fr}
  .num:nth-child(2n){border-right:0}
  .num:nth-child(-n+2){border-bottom:1px solid var(--line)}
  .num:nth-child(n+3){padding-top:2.4rem}
  .dip{grid-template-columns:1fr;gap:3rem}
  .dip__col.b{margin-top:0}
  .exp-grid{grid-template-columns:1fr;max-width:480px;margin:0 auto}
  .ev-grid{grid-template-columns:1fr 1fr}
  .gal-grid{grid-template-columns:repeat(2,1fr)}
  .facts-grid{grid-template-columns:repeat(3,1fr)}
  .fact:nth-child(3n){border-right:0}
  .fact:nth-child(-n+3){border-bottom:1px solid var(--line)}
  .plan{grid-template-columns:1fr;gap:2.5rem}
  .contact-grid{grid-template-columns:1fr 1fr}
  .foot__top{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  body{font-size:17px}
  .nav__links{
    position:fixed;inset:0 0 0 auto;width:min(82vw,330px);
    background:var(--ink);color:var(--paper);flex-direction:column;justify-content:center;align-items:flex-start;
    padding:var(--gut);gap:1.8rem;transform:translateX(100%);transition:transform .5s var(--ease);
  }
  .nav__links.open{transform:none}
  .nav__burger{display:flex}
  .nav.scrolled .nav__burger span,.nav .nav__burger span{background:currentColor}
  .ev-grid{grid-template-columns:1fr;max-width:420px;margin:0 auto}
  .gal-grid{grid-template-columns:1fr 1fr;grid-auto-rows:150px}
  .facts-grid{grid-template-columns:1fr 1fr}
  .fact:nth-child(2n){border-right:0}
  .contact-grid{grid-template-columns:1fr}
  .foot__top{grid-template-columns:1fr}
  .plate__caption{display:none}
  .hero__from b{font-size:1.4rem}
  .plate__meta{gap:1.6rem}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition-duration:.001s!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}
