/* ============================================================
   Newhall House & Estate — "Luxe Estate" v2.1
   Foundation: Miti Navi authoritative tokens (refs/miti-navi-*)
   × Apollo Workspace (espresso display ink, giant wordmark)
   LOCKED: Italiana = the NEWHALL logo/wordmark font.
   Fonts: Italiana · Cormorant Garamond (display, ≥46px ideally)
   · IBM Plex Mono (ALL functional UI + body, tracked)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Italiana&family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,300;1,400&family=Mulish:wght@300;400;600;700&family=IBM+Plex+Mono:wght@400&family=Caveat:wght@400;500&display=swap');

:root{
  /* Miti Navi authoritative */
  --linen:#e6dece;      /* page canvas — exact          */
  --deep-ink:#000e13;   /* dark sections, image insets  */
  --carbon:#232323;     /* body text, hairlines         */
  --ash:#6E6252;        /* muted — darkened for readability */
  --ash-lt:#A89C86;     /* muted on dark sections       */
  --apricot:#ffdead;    /* SOLE chromatic accent — 1px underlines */
  --obsidian:#000000;
  /* Apollo half of the mixture */
  --espresso:#33261a;   /* display ink + wordmark       */
  --brown:#2E2216;      /* section brown = loading screen */
  --cream:#f7f2e5;
  --sand-2:#EDE6D6;     /* raised surface (subtle)      */
  --line:#c9c0ab;       /* hairlines on linen           */
  --line-soft:#d8d0bc;
  /* aliases kept for existing markup */
  --sand:var(--linen);
  --night:var(--deep-ink);
  --night-2:#0a1a21;
  --ink:var(--carbon);
  --umber:var(--carbon);
  --taupe:var(--ash);
  --bronze:#8C6A3F;
  --mono:'IBM Plex Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  --disp:'Cormorant Garamond',Georgia,serif;
  --wordmark:'Italiana',serif;
  --wrap:1200px;
  --ease:cubic-bezier(.22,1,.36,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
:root{--sans:'Mulish',system-ui,-apple-system,sans-serif}
body{
  margin:0;background:var(--linen);color:var(--carbon);
  font-family:var(--sans);font-weight:400;font-size:17px;line-height:1.85;
  letter-spacing:.01em;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
body.pre-lock{overflow:hidden;height:100vh}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

h1,h2,h3,h4,.disp{font-family:var(--disp);font-weight:300;line-height:.94;margin:0;
  color:var(--espresso);letter-spacing:0}
h1{font-size:clamp(3.2rem,9vw,8.125rem);line-height:.92}   /* → 130px display */
h2{font-size:clamp(2.4rem,5vw,4.5rem);line-height:.94;margin-bottom:28px}      /* → 72px heading-lg */
h3{font-size:clamp(1.55rem,2.6vw,2.15rem);font-weight:400;line-height:1.1}
p{margin:0 0 1.3rem}

.wrap{max-width:var(--wrap);margin:0 auto;padding:0 32px}
.eyebrow{font-family:var(--sans);font-weight:600;font-size:13px;letter-spacing:4px;
  text-transform:uppercase;color:var(--ash);display:inline-block;margin-bottom:24px}
.lede{font-size:clamp(1.3rem,2.1vw,1.625rem);font-weight:300;color:var(--carbon);line-height:1.35;
  font-family:var(--disp);font-style:italic;letter-spacing:0}
.muted{color:var(--ash)}
section{position:relative}
.pad{padding:clamp(64px,9vw,120px) 0}

/* ---------- links : the apricot underline (Miti signature) ---------- */
.ulink{font-family:var(--sans);font-weight:600;font-size:13px;letter-spacing:2px;text-transform:uppercase;
  color:var(--deep-ink);padding-bottom:5px;border-bottom:1px solid var(--apricot);
  transition:color .3s}
.ulink:hover{color:var(--obsidian)}

/* ---------- buttons : square mono; hover reveals apricot rule ---------- */
.btn{display:inline-flex;align-items:center;gap:12px;font-family:var(--sans);
  font-size:13px;font-weight:600;letter-spacing:2px;text-transform:uppercase;
  padding:16px 30px;border:1px solid var(--deep-ink);border-radius:0;cursor:pointer;
  background:transparent;color:var(--deep-ink);transition:all .35s var(--ease);
  box-shadow:inset 0 0 0 0 transparent;position:relative}
.btn svg{width:14px;height:14px;transition:transform .35s var(--ease)}
.btn:hover svg{transform:translateX(5px)}
.btn:hover{background:var(--deep-ink);color:var(--linen);border-color:var(--deep-ink)}
.btn-solid,.btn-clay{background:var(--deep-ink);color:var(--linen);border-color:var(--deep-ink)}
.btn-solid:hover,.btn-clay:hover{background:transparent;color:var(--deep-ink)}
.btn-ghost{border-color:currentColor}
.btn-light{color:var(--linen);border-color:rgba(230,222,206,.55)}
.btn-light:hover{background:var(--linen);color:var(--deep-ink);border-color:var(--linen)}

/* ---------- preloader : deep-ink curtain, wipes up (Miti body:after) ---------- */
#preloader{position:fixed;top:0;left:0;right:0;height:100vh;z-index:9999;background:#4E3B28;
  display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden;
  transition:height 1.2s cubic-bezier(.82,0,.36,1) .25s,visibility 0s linear 1.6s}
#preloader.done{height:0;visibility:hidden}
.pl-shield{width:100px;height:auto;margin-bottom:28px;opacity:0;
  transform:scale(.86) translateY(8px);animation:shieldIn 1.1s var(--ease) .15s forwards}
@keyframes shieldIn{to{opacity:1;transform:none}}
.pl-word{font-family:var(--wordmark);font-size:42px;letter-spacing:.4em;color:var(--linen);
  padding-left:.4em;opacity:0;animation:fadeUp 1s ease .7s forwards}
.pl-rule{width:0;height:1px;background:var(--apricot);margin:20px 0;
  animation:ruleGrow .9s var(--ease) 1.05s forwards}
.pl-sub{font-family:var(--sans);font-weight:400;font-size:13px;letter-spacing:3px;
  text-transform:uppercase;color:#E3D8C4;opacity:0;animation:fadeUp .9s ease 1.3s forwards}
@keyframes ruleGrow{to{width:180px}}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

/* ---------- header : 3-cluster split nav, centered wordmark (Miti) ---------- */
.site-head{position:fixed;top:0;left:0;right:0;z-index:900;
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:20px;
  padding:22px clamp(20px,4vw,52px);transition:all .45s var(--ease);background:transparent}
.site-head.scrolled{background:rgba(230,222,206,.95);backdrop-filter:blur(12px);
  padding:14px clamp(20px,4vw,52px);border-bottom:1px solid var(--line)}
.brand{font-family:var(--wordmark);font-weight:400;font-size:26px;letter-spacing:.3em;
  color:var(--deep-ink);display:flex;align-items:baseline;gap:14px;justify-content:center}
.brand-sub{font-family:var(--sans);font-weight:600;font-size:10px;letter-spacing:4px;
  text-transform:uppercase;color:var(--ash)}
.nav{display:flex;align-items:center;gap:26px}
.nav.nav-l{grid-column:1;justify-content:flex-start;grid-row:1}
.nav.nav-r{grid-column:3;justify-content:flex-end;grid-row:1}
.nav a.nl{font-family:var(--mono);font-weight:400;font-size:12px;letter-spacing:1px;
  text-transform:uppercase;color:var(--deep-ink);position:relative;padding:4px 0 6px}
.nav a.nl::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;
  background:var(--apricot);transition:width .35s var(--ease)}
.nav a.nl:hover::after,.nav a.nl.active::after{width:100%}
.nav .btn{padding:10px 18px;font-size:11px}
.burger{display:none;background:none;border:0;cursor:pointer;padding:8px;flex-direction:column;gap:5px;
  grid-column:3;justify-self:end}
.burger span{width:26px;height:1.5px;background:var(--deep-ink);transition:.3s}

/* ---------- side tab : vertical right-edge marker (Miti) ---------- */
.brand-wrap{grid-column:2;display:flex;justify-content:center;padding-top:8px}
.side-tab{position:fixed;top:0;left:50%;transform:translateX(-50%);z-index:960;white-space:nowrap;
  background:var(--line);color:#5A5142;padding:3px 12px 4px;
  font-family:var(--mono);font-size:7.5px;letter-spacing:1.5px;text-transform:uppercase}
@media(max-width:960px){.side-tab{font-size:7px;letter-spacing:1px}}

/* ---------- hero : full-screen image cropped into the arch (Miti intro) ---------- */
.hero{position:relative;background:var(--linen);padding:0}
.hero-banner{position:relative;height:100svh;min-height:600px;overflow:hidden;background:var(--deep-ink)}
.banner-img{position:absolute;inset:0}
.banner-img img{width:100%;height:100%;object-fit:cover;object-position:center 58%;
  transform:scale(1.45);transition:.6s cubic-bezier(.82,0,.36,1)}
body.loaded .banner-img img{transform:scale(1.18);transition:transform 4s cubic-bezier(.82,0,.36,1)}
.banner-mask{position:absolute;top:clamp(84px,12vh,124px);bottom:0;left:50%;
  width:min(1320px,calc(100vw - 2*clamp(16px,3vw,44px)));
  border-radius:999px 999px 0 0;pointer-events:none;
  box-shadow:0 0 0 200vmax var(--linen);
  transform:translateX(-50%) scale(2.6);transform-origin:50% 58%;
  transition:.6s cubic-bezier(.82,0,.36,1)}
body.loaded .banner-mask{transform:translateX(-50%) scale(1);transition:transform 3s cubic-bezier(.82,0,.36,1)}
.hero-inner{position:relative;max-width:var(--wrap);margin:0 auto;width:100%;text-align:center;
  padding:clamp(36px,5vw,64px) 32px clamp(56px,7vw,90px)}
.hero h1{color:var(--espresso);margin:0 auto}
.hw{color:rgba(51,38,26,.09);transition:color .45s ease}
.hw.on{color:var(--espresso)}
.hero .eyebrow{color:var(--ash)}
.hero p.sub{color:var(--carbon);font-family:var(--disp);font-style:italic;font-weight:300;
  font-size:clamp(1.3rem,2.2vw,1.65rem);max-width:44ch;margin:28px auto 38px;line-height:1.4;letter-spacing:0}
.hero-cta{display:flex;gap:28px;flex-wrap:wrap;align-items:center;justify-content:center}
.hero .reveal-h{opacity:0;transform:translateY(28px)}
body.loaded .hero .reveal-h{opacity:1;transform:none;transition:opacity 1.1s ease .15s,transform 1.2s var(--ease) .15s}
body.loaded .hero .reveal-h.d2{transition-delay:.35s}
body.loaded .hero .reveal-h.d3{transition-delay:.55s}
body.loaded .hero .reveal-h.d4{transition-delay:.72s}
.scroll-cue{display:none}

/* ---------- facts strip ---------- */
.facts{background:var(--linen);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.facts .wrap{display:grid;grid-template-columns:repeat(6,1fr);gap:0;padding-top:0;padding-bottom:0}
.fact{text-align:center;padding:38px 10px;border-left:1px solid var(--line)}
.fact:first-child{border-left:0}
.fact .n{font-family:var(--disp);font-weight:300;font-size:clamp(1.9rem,3vw,2.875rem);color:var(--espresso);line-height:.94}
.fact .l{font-family:var(--sans);font-size:12px;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--ash);margin-top:12px}

/* ---------- generic two-col ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,5.5vw,88px);align-items:center}
.split.wide-img{grid-template-columns:1.1fr .9fr}
.split .media{border-radius:0;overflow:hidden;position:relative;background:var(--deep-ink)}
.split .media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/5;
  transition:transform 1.4s var(--ease),opacity .5s}
.split .media:hover img{transform:scale(1.03)}
.split.landscape .media img{aspect-ratio:3/2}
.split .media.elong img{aspect-ratio:3/4}
.hero-banner.fullpic{height:100svh;min-height:600px;background:var(--linen)}
.fullpic .banner-mask{display:none}
.fullpic .banner-img{transition:top 2.4s cubic-bezier(.82,0,.36,1) .35s,bottom 2.4s cubic-bezier(.82,0,.36,1) .35s,left 2.4s cubic-bezier(.82,0,.36,1) .35s,width 2.4s cubic-bezier(.82,0,.36,1) .35s,transform 2.4s cubic-bezier(.82,0,.36,1) .35s,box-shadow 1s ease 2.5s}
.fullpic .banner-img::after{content:"";position:absolute;inset:0;pointer-events:none;opacity:0;
  transition:opacity 1s ease 2.5s;
  border:clamp(6px,0.7vw,9px) solid;
  border-image:linear-gradient(160deg,#6e4f22 0%,#a8813d 22%,#d8b96b 38%,#8a6428 55%,#c19a4c 75%,#6e4f22 100%) 1;
  outline:1px solid rgba(56,40,20,.65);
  box-shadow:inset 0 0 0 clamp(4px,.5vw,6px) #efe8d6,
             inset 0 0 0 calc(clamp(4px,.5vw,6px) + 1px) rgba(94,68,30,.8),
             inset 0 1px 3px rgba(46,34,22,.22)}
.fullpic .banner-img img{transform:scale(1.18);transition:transform 4s cubic-bezier(.82,0,.36,1)}
body.loaded .fullpic .banner-img{top:clamp(112px,15vh,150px);bottom:clamp(28px,5vh,54px);left:50%;right:auto;width:min(calc((100svh - 190px)*1.787),calc(100vw - 128px),1240px);transform:translateX(-50%);box-shadow:0 22px 52px -26px rgba(46,34,22,.5)}
body.loaded .fullpic .banner-img::after{opacity:1}
body.loaded .fullpic .banner-img img{transform:scale(1)}
.split .media.natural{background:transparent}
.split .media.natural img{aspect-ratio:auto;height:auto;object-fit:unset}
.ilist{list-style:none;margin:26px 0 0;padding:0;columns:2;column-gap:32px}
.ilist li{padding:10px 0;position:relative;font-family:var(--sans);font-size:15.5px;
  letter-spacing:.02em;color:var(--carbon);break-inside:avoid;border-bottom:1px solid var(--line-soft)}

/* ---------- section heading + short hairline rule (Miti) ---------- */
.shead{max-width:700px;margin-bottom:clamp(38px,5.5vw,66px)}
.shead.center{margin-left:auto;margin-right:auto;text-align:center}
.shead.center h2::after{content:"";display:block;width:60px;height:1px;background:var(--carbon);
  margin:30px auto 0}

/* ---------- exclusive hire ---------- */
.hire{background:var(--linen);border-top:1px solid var(--line)}
.packages{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:14px;
  border:1px solid var(--carbon)}
.pkg{background:var(--linen);border-left:1px solid var(--carbon);padding:40px 32px;
  transition:background .4s var(--ease)}
.pkg:first-child{border-left:0}
.pkg:hover{background:var(--sand-2)}
.pkg .pk-l{font-family:var(--sans);font-size:11.5px;letter-spacing:2px;text-transform:uppercase;color:var(--ash)}
.pkg .pk-n{font-family:var(--disp);font-weight:300;font-size:3.5rem;color:var(--espresso);margin:14px 0 2px;line-height:.9}
.pkg .pk-s{font-family:var(--sans);font-size:13px;letter-spacing:1px;color:var(--ash);margin-bottom:20px;text-transform:uppercase}
.pkg .pk-d{font-size:16px;letter-spacing:.01em;line-height:1.8;color:var(--carbon);border-top:1px solid var(--line-soft);padding-top:18px}
.dining{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:30px;border:1px solid var(--carbon)}
.dine{text-align:center;padding:28px 12px;border-left:1px solid var(--carbon);background:var(--linen)}
.dine:first-child{border-left:0}
.dine .dn{font-family:var(--disp);font-weight:300;font-size:2.6rem;color:var(--espresso);line-height:.9}
.dine .dl{font-family:var(--sans);font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--ash);margin-top:10px}

/* ---------- gallery ---------- */
.gal{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:210px;gap:10px;margin-top:14px}
.gal figure{margin:0;overflow:hidden;border-radius:0;cursor:pointer;position:relative;background:var(--deep-ink)}
.gal img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.gal figure:hover img{transform:scale(1.05)}
.gal .tall{grid-row:span 2}
.gal .wide{grid-column:span 2}
.gal figcaption{position:absolute;left:0;bottom:0;right:0;padding:16px;font-family:var(--sans);
  font-size:11.5px;letter-spacing:2px;text-transform:uppercase;color:var(--linen);
  background:linear-gradient(0deg,rgba(0,14,19,.78),transparent);opacity:0;transition:opacity .35s}
.gal figure:hover figcaption{opacity:1}

/* ---------- experiences : deep ink ---------- */
.experiences{background:var(--cream);color:var(--carbon);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.experiences h2,.experiences .disp{color:var(--espresso)}
.experiences .eyebrow{color:var(--ash)}
.experiences .lede{color:var(--carbon)}
.xgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);
  border:1px solid var(--line);margin-top:10px}
.x{background:var(--cream);padding:30px 24px;transition:background .4s}
.x:hover{background:var(--sand-2)}
.x .xi{width:26px;height:26px;color:var(--apricot);margin-bottom:16px}
.x .xi svg{width:100%;height:100%;stroke:var(--espresso);stroke-width:1.1;fill:none}
.x .xt{font-family:var(--disp);font-weight:400;font-size:1.5rem;color:var(--espresso);line-height:1.06;letter-spacing:0}
.x .xs{font-family:var(--sans);font-size:11.5px;letter-spacing:1px;text-transform:uppercase;color:var(--ash);margin-top:8px}

/* ---------- golf / access ---------- */
.golf{background:var(--linen)}
.golf .course{display:flex;justify-content:space-between;align-items:baseline;gap:16px;
  padding:18px 0;border-bottom:1px solid var(--line)}
.golf .course .c-name{font-family:var(--disp);font-weight:400;font-size:1.5rem;color:var(--espresso);letter-spacing:0}
.golf .course .c-note{font-size:15px;letter-spacing:.01em;color:var(--ash)}
.golf .course .c-dist{font-family:var(--sans);font-weight:400;font-size:12px;letter-spacing:1px;color:var(--carbon);
  border-bottom:1px solid var(--apricot);padding-bottom:3px;white-space:nowrap}
.badge{display:inline-block;font-family:var(--sans);font-size:9px;font-weight:400;letter-spacing:1px;
  text-transform:uppercase;color:var(--carbon);border:1px solid var(--carbon);border-radius:0;
  padding:3px 9px;margin-left:10px;vertical-align:2px}

/* ---------- wellness ---------- */
.wellness{background:var(--linen);border-top:1px solid var(--line)}
.tag-soon{display:inline-block;font-family:var(--sans);font-size:11.5px;font-weight:600;letter-spacing:2px;
  text-transform:uppercase;color:var(--carbon);border-bottom:1px solid var(--apricot);
  padding:0 0 5px;margin-bottom:22px}

/* ---------- story ---------- */
.story{background:var(--cream);color:var(--carbon);border-top:1px solid var(--line)}
.story h2,.story .disp{color:var(--espresso)}
.story .eyebrow{color:var(--ash)}
.story p{color:var(--carbon)}
.pullquote{font-family:var(--disp);font-style:italic;font-weight:300;font-size:clamp(1.5rem,3vw,2.4rem);
  color:var(--espresso);line-height:1.3;max-width:24ch;border-left:2px solid var(--apricot);padding-left:28px;letter-spacing:0}

/* ---------- timeline (index short) ---------- */
.tl{margin-top:clamp(44px,6vw,76px);max-width:820px;margin-left:auto;margin-right:auto}
.tl-item{display:grid;grid-template-columns:130px 1fr;gap:30px;padding:24px 0;
  border-top:1px solid var(--line-soft);align-items:baseline}
.tl-year{font-family:var(--disp);font-weight:300;font-size:clamp(1.7rem,2.7vw,2.3rem);color:var(--espresso);line-height:.9}
.tl-body h4{font-family:var(--disp);font-weight:400;font-size:1.35rem;color:var(--espresso);margin:0 0 4px;letter-spacing:0}
.tl-body p{margin:0;color:var(--carbon);font-size:15px;letter-spacing:.01em;line-height:1.7}
@media(max-width:720px){.tl-item{grid-template-columns:64px 1fr;gap:14px}.tl-year{font-size:1.3rem}}

/* ---------- claim ---------- */
.claim{display:inline-flex;align-items:center;gap:12px;font-family:var(--sans);font-weight:700;
  font-size:13px;letter-spacing:2.5px;text-transform:uppercase;color:var(--espresso);
  border:1.5px solid var(--espresso);padding:14px 24px;margin-bottom:28px;background:var(--sand-2)}
.claim svg{width:14px;height:14px;stroke:var(--carbon);fill:none;stroke-width:1.2}

/* ---------- watercolour band : dark image inset (Miti window) ---------- */
.wc-band{background:var(--linen);padding:clamp(56px,8vw,100px) 0}
.wc-band figure{max-width:960px;margin:0 auto;padding:0 24px}
.wc-band figure img{width:100%;display:block;border-radius:0}
.wc-band figure{position:relative}
.wc-band figure::before{content:"";display:block}
.wc-band figure > img{background:var(--deep-ink);padding:clamp(14px,2.4vw,24px);
  box-sizing:border-box}
.wc-band figcaption{text-align:center;font-family:var(--sans);font-size:12px;letter-spacing:2px;
  text-transform:uppercase;color:var(--ash);margin-top:18px}

/* ---------- custodians & trustees ---------- */
.custodians{background:var(--linen);border-top:1px solid var(--line)}
.letter{font-family:'Caveat',cursive;font-weight:400;font-size:clamp(1.55rem,2.5vw,2rem);
  line-height:1.5;color:var(--ink);margin:0 0 30px;padding:0;letter-spacing:.01em}
.letter p{margin:0 0 1.1em}
.cust-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;max-width:640px;margin:34px auto}
.cust-row img{width:100%;border-radius:0;display:block}
.cust-sign{text-align:center;font-family:var(--disp);font-weight:400;font-size:1.6rem;color:var(--espresso);letter-spacing:0}
.cust-sign span{display:block;font-family:var(--sans);font-size:12px;letter-spacing:3px;
  text-transform:uppercase;color:var(--ash);margin-top:8px}
.stages{list-style:none;margin:26px auto 0;padding:0;max-width:660px;border:1px solid var(--carbon)}
.stages li{padding:16px 22px;border-top:1px solid var(--line);font-family:var(--sans);
  font-size:14px;letter-spacing:1px;color:var(--carbon);background:var(--linen)}
.stages li:first-child{border-top:0}
.trustees{display:grid;grid-template-columns:repeat(2,minmax(0,270px));gap:22px;justify-content:center;margin-top:30px}
.trustees figure{margin:0;text-align:center}
.trustees img{width:100%;aspect-ratio:1/1.08;object-fit:cover;border-radius:0;display:block}
.trustees figcaption{font-family:var(--disp);font-weight:400;font-size:1.25rem;color:var(--espresso);margin-top:14px;letter-spacing:0}
@media(max-width:720px){.cust-row,.trustees{grid-template-columns:1fr}}

/* ---------- enquire ---------- */
.enquire{background:var(--linen)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{display:flex;flex-direction:column;gap:8px}
.field.full{grid-column:1/-1}
.field label{font-family:var(--sans);font-size:12px;font-weight:600;letter-spacing:2px;
  text-transform:uppercase;color:var(--ash)}
.field input,.field select,.field textarea{font-family:var(--sans);font-size:13px;letter-spacing:.5px;
  color:var(--carbon);background:transparent;border:1px solid var(--line);border-radius:0;
  padding:14px 16px;transition:border-color .3s;width:100%}
.field textarea{resize:vertical;min-height:120px}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--deep-ink)}
.form-note{font-family:var(--sans);font-size:12.5px;letter-spacing:.5px;color:var(--ash);margin-top:4px}
.form-ok{background:var(--sand-2);color:var(--espresso);border:1px solid var(--line);border-radius:0;padding:30px 32px;
  display:none;font-family:var(--disp);font-weight:300;font-size:1.5rem;letter-spacing:0}
.form-ok.show{display:block;animation:fadeUp .5s ease}
.contact-card{background:var(--sand-2);color:var(--carbon);border:1px solid var(--line);border-radius:0;padding:42px 36px;height:100%}
.contact-card h3{color:var(--espresso);margin-bottom:24px;font-weight:300}
.contact-card .row{display:flex;gap:14px;align-items:flex-start;padding:12px 0;
  border-bottom:1px solid var(--line);font-family:var(--sans);font-size:15px;
  letter-spacing:.02em;color:var(--carbon);line-height:1.6}
.contact-card .row svg{width:16px;height:16px;stroke:var(--espresso);fill:none;stroke-width:1.3;flex:none;margin-top:3px}
.contact-card a:hover{color:var(--espresso)}

/* ---------- footer + giant NEWHALL wordmark (Italiana — locked) ---------- */
.foot{background:var(--linen);color:var(--carbon);padding:0}
.foot-office{text-align:center;padding:4px 0 52px}
.foot-office ul{list-style:none;margin:0;padding:0;display:flex;gap:10px 0;justify-content:center;flex-wrap:wrap;align-items:baseline}
.foot-office li{font-family:var(--sans);font-size:15px}
.foot-office li:not(:first-child)::before{content:"\00B7";margin:0 16px;color:var(--ash)}
.foot-office a{padding-bottom:4px;border-bottom:1px solid var(--apricot)}
.foot .fbrand{font-family:var(--wordmark);font-size:28px;letter-spacing:.28em;color:var(--espresso)}
.foot .fcrest{width:60px;margin-bottom:18px;opacity:.95}
.foot h4{font-family:var(--sans);font-weight:700;font-size:12px;letter-spacing:3px;text-transform:uppercase;
  color:var(--ash);margin-bottom:18px}
.foot ul{list-style:none;margin:0;padding:0}
.foot li{padding:7px 0;font-family:var(--sans);font-size:15px;letter-spacing:.02em}
.foot li a{padding-bottom:3px;border-bottom:1px solid transparent;transition:border-color .3s}
.foot li a:hover{color:var(--deep-ink);border-bottom-color:var(--apricot)}
.foot p{font-size:12px;letter-spacing:.8px;line-height:1.7}
.foot .fbot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;padding:26px 0;
  font-family:var(--sans);font-size:12px;letter-spacing:1px;text-transform:uppercase;color:var(--ash)}
.foot-wordmark{overflow:hidden;padding:0 0 clamp(30px,4vw,56px);margin-top:calc(-1*clamp(20px,4vw,64px));user-select:none}
.foot-wordmark span{display:block;font-family:var(--wordmark);font-weight:400;
  font-size:clamp(60px,15.5vw,280px);line-height:.9;letter-spacing:.02em;text-align:center;
  color:var(--espresso);white-space:nowrap;transform:translateY(22%);will-change:transform}

/* ---------- sub-hero (timeline) ---------- */
.sub-hero{padding:clamp(140px,19vh,200px) 0 clamp(44px,6vw,72px);background:var(--linen);
  border-bottom:1px solid var(--line);text-align:center}
.sub-hero h1{color:var(--espresso)}

/* ---------- timeline page ---------- */
.era{font-family:var(--disp);font-weight:300;font-size:clamp(2.1rem,4vw,3.2rem);color:var(--espresso);text-align:center;
  margin:clamp(52px,8vw,96px) auto 8px;padding-top:clamp(34px,5.5vw,60px);border-top:1px solid var(--line);
  max-width:760px;line-height:1;letter-spacing:0}
.era-sub{text-align:center;color:var(--ash);font-family:var(--sans);font-size:12.5px;letter-spacing:4px;
  text-transform:uppercase;font-weight:400;margin-bottom:48px}
.yrs{max-width:760px;margin:0 auto}
.yr{display:block;padding:38px 0 12px;border-top:1px solid var(--line-soft)}
.yr:first-child{border-top:0}
.yr-y{font-family:var(--disp);font-weight:300;font-size:2.75rem;color:var(--espresso);line-height:.9;margin-bottom:18px}
.yr-c h3{font-family:var(--disp);font-weight:400;font-size:1.55rem;color:var(--espresso);margin:0 0 10px}
.yr-c p{font-size:17px;letter-spacing:.01em;line-height:1.85;color:var(--carbon);margin:0 0 1.2rem}
.yr-c figure{margin:26px 0 24px}
.yr-c figure img{width:auto;max-width:min(100%,500px);max-height:420px;margin:0 auto;border-radius:0;display:block}
.yr-c figcaption{font-family:var(--sans);font-size:12px;letter-spacing:2px;text-transform:uppercase;
  color:var(--ash);margin-top:12px;text-align:center}
.fig-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:24px 0 12px}
.fig-row figure{margin:0}
@media(max-width:720px){.fig-row{grid-template-columns:1fr}}
.lineage{max-width:760px;margin:0 auto}
.lineage p{font-size:17px;letter-spacing:.01em;line-height:1.85;color:var(--carbon);margin:0 0 1.25rem}
.lineage h3{font-family:var(--disp);font-weight:400;font-size:1.55rem;color:var(--espresso);margin:36px 0 12px}
.refs{max-width:760px;margin:44px auto 0;font-family:var(--sans);font-size:13px;letter-spacing:.02em;line-height:1.7;color:var(--ash)}

/* ---------- photo choreography on scroll (Miti / locomotive feel) ---------- */
.yr-c figure,.fig-row figure,.wc-band figure,.lineage figure,.cust-row,.trustees figure{overflow:hidden}
.media img,figure img,.cust-row img{transition:transform 1.6s cubic-bezier(.82,0,.36,1)}
.reveal:not(.in) .media img,
.reveal:not(.in) figure img,
.reveal:not(.in) .cust-row img,
figure.reveal:not(.in) img{transform:scale(1.12)}
img[data-speed]{transition:none!important;will-change:transform;transform:scale(1.12)}

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

/* ---------- masked line reveals (Miti Navi: .82,0,.36,1) ---------- */
.sl{display:block;overflow:hidden;padding:5px 0;margin:-7px 0}
.sl .sli{display:block;transform:translateY(38px) scale(.94);
  transition:transform 1s cubic-bezier(.82,0,.36,1)}
.sl:nth-child(2) .sli{transition-delay:.2s}
.sl:nth-child(3) .sli{transition-delay:.4s}
.sl:nth-child(4) .sli{transition-delay:.6s}
.sl:nth-child(5) .sli{transition-delay:.8s}
.reveal.in .sli{transform:translate(0) scale(1)}
body.loaded .hero .sli{transform:translate(0) scale(1)}
.hero h1 .sl .sli{transition-duration:1.15s}
body.loaded .hero h1 .sl:nth-child(1) .sli{transition-delay:1s}
body.loaded .hero h1 .sl:nth-child(2) .sli{transition-delay:1.18s}

/* growing rule under centered headings (Miti h4:after) */
.shead.center h2::after{width:0;transition:width 1s cubic-bezier(.82,0,.36,1) .5s}
.shead.center.reveal.in h2::after,.reveal.in .shead.center h2::after{width:60px}

/* preloader out-choreography (Miti logo-loader exit, then curtain wipes) */
#preloader.done .pl-shield{animation:none;transform:scale(.8);opacity:0;
  transition:transform .6s cubic-bezier(.82,0,.36,1),opacity .6s cubic-bezier(.82,0,.36,1)}
#preloader.done .pl-word,#preloader.done .pl-rule,#preloader.done .pl-sub{animation:none;opacity:0;
  transition:opacity .4s ease}

/* header drops in after the curtain (Miti: top 1.6s bezier 1.2s) */
body:not(.loaded) .site-head{transform:translateY(-110%)}
body.loaded .site-head{transform:none;transition:transform 1.6s cubic-bezier(.82,0,.36,1) 1.2s,
  background .45s var(--ease),padding .45s var(--ease),border-color .45s var(--ease)}

/* ---------- lightbox ---------- */
#lightbox{position:fixed;inset:0;z-index:1200;background:rgba(0,14,19,.96);
  display:none;align-items:center;justify-content:center;padding:40px;cursor:zoom-out}
#lightbox.show{display:flex}
#lightbox img{max-width:92vw;max-height:88vh;border-radius:0}
#lightbox .lx-close{position:absolute;top:24px;right:30px;color:#fff;font-size:34px;font-family:var(--disp);cursor:pointer;line-height:1}

/* ---------- responsive ---------- */
@media(max-width:960px){
  .facts .wrap{grid-template-columns:repeat(3,1fr)}
  .fact:nth-child(4){border-left:0}
  .packages,.xgrid{grid-template-columns:repeat(2,1fr)}
  .pkg:nth-child(odd){border-left:0}
  .dining{grid-template-columns:repeat(2,1fr)}
  .dine:nth-child(odd){border-left:0}
  .foot .fgrid{grid-template-columns:1fr 1fr}
  .nav.nav-l,.nav.nav-r{display:none}
  .site-head{grid-template-columns:auto 1fr auto}
  .brand{grid-column:1;text-align:left;padding-left:0}
  .burger{display:flex;grid-column:3}
}
@media(max-width:720px){
  body{font-size:13px;letter-spacing:1px}
  .nav-mobile{position:fixed;inset:0 0 0 auto;width:min(84vw,340px);background:#4E3B28;
    display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:24px;padding:44px;
    transform:translateX(100%);transition:transform .45s var(--ease);z-index:950}
  .nav-mobile.open{transform:none}
  .nav-mobile a{font-family:var(--mono);font-size:14px;letter-spacing:2px;text-transform:uppercase;
    color:var(--linen);padding-bottom:5px;border-bottom:1px solid transparent}
  .nav-mobile a:hover{border-bottom-color:var(--apricot)}
  .burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .burger.open span:nth-child(2){opacity:0}
  .burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .burger.open span{background:var(--linen)}
  .split,.split.wide-img{grid-template-columns:1fr;gap:28px}
  .packages,.xgrid,.dining,.form-grid,.foot .fgrid{grid-template-columns:1fr}
  .pkg{border-left:0;border-top:1px solid var(--carbon)}
  .pkg:first-child{border-top:0}
  .dine{border-left:0;border-top:1px solid var(--carbon)}
  .facts .wrap{grid-template-columns:repeat(2,1fr)}
  .fact{border-left:0;border-top:1px solid var(--line-soft)}
  .ilist{columns:1}
  .gal{grid-template-columns:repeat(2,1fr)}
  .golf .course{flex-wrap:wrap}
  .banner-mask{border-radius:420px 420px 0 0}
}
@media(min-width:961px){.nav-mobile{display:none}}

/* ---------- reduced motion ---------- */
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
  #preloader{display:none}
  body.pre-lock{overflow:auto;height:auto}
}

/* ---------- contact : blown-up house (live /contact) ---------- */
.contact-blow{padding:0;background:var(--linen)}
.contact-blow img{width:100%;height:auto;display:block}
.contact-blow figcaption{text-align:center;font-family:var(--sans);font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--ash);padding:18px 20px 0}

/* ---------- timeline figures (full-width, live order) ---------- */
.lineage figure{margin:30px 0}
.lineage figure img{width:auto;max-width:min(100%,500px);max-height:420px;margin:0 auto;display:block}
.lineage::after,.yr-c::after{content:"";display:block;clear:both}
.fr{float:right;width:min(280px,42%);margin:6px 0 20px 28px}
.fr img{width:100%!important;max-width:100%!important;max-height:none!important}
.lineage figcaption{font-family:var(--sans);font-size:12px;letter-spacing:2px;text-transform:uppercase;
  color:var(--ash);margin-top:12px;text-align:center}

/* ---------- killone 4-image grid (clickable) ---------- */
.killone-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin:30px 0}
.killone-grid figure{margin:0!important;cursor:pointer;overflow:hidden}
.killone-grid img{width:100%!important;max-width:none!important;max-height:none!important;aspect-ratio:4/3;object-fit:cover;display:block;transition:transform .9s cubic-bezier(.82,0,.36,1)}
.killone-grid figure:hover img{transform:scale(1.05)}

/* one-line heading + wide timeline figure + golf county labels */
@media(min-width:721px){.one-line{white-space:nowrap;font-size:clamp(1.9rem,4.4vw,3.7rem)}}
.wide-fig img{width:100%!important;max-width:100%!important;max-height:none!important}
.golf-county{font-family:var(--sans);font-weight:700;font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--ash);margin:26px 0 4px}
.golf-county:first-child{margin-top:0}

/* mobile menu scrim */
.scrim{position:fixed;inset:0;background:rgba(28,20,12,.38);opacity:0;pointer-events:none;transition:opacity .4s ease;z-index:940}
.scrim.open{opacity:1;pointer-events:auto}

/* golf: scrollable course panel */
.course-scroll{max-height:540px;overflow-y:auto;border:1px solid var(--line);background:var(--cream);
  padding:10px 22px 22px;scrollbar-width:thin;scrollbar-color:var(--line) transparent;
  -webkit-mask-image:linear-gradient(180deg,#000 88%,transparent);mask-image:linear-gradient(180deg,#000 88%,transparent)}
.course-scroll::-webkit-scrollbar{width:4px}
.course-scroll::-webkit-scrollbar-thumb{background:var(--line)}
.course-scroll::-webkit-scrollbar-thumb:hover{background:var(--ash)}
.course-scroll .course:last-child{border-bottom:0;margin-bottom:26px}
