/* ============================================================
   Pearson's Pastures — guest estate brand (cinematic dark).
   Separate design system from the owner app (css/theme.css).
   Used by estate/index.html and estate/portal.html.
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400&family=Inter:wght@300;400;500;600&display=swap');

:root{
  --bg:#0e0d0b;          /* near-black */
  --bg2:#141210;         /* raised panel */
  --bg3:#1b1813;         /* card */
  --ink:#ede7db;         /* warm ivory */
  --ink2:#cfc7b6;        /* soft ivory */
  --mut:#9b917e;         /* muted warm grey */
  --gold:#c4a35a;        /* brass */
  --gold2:#dcc188;       /* light brass (hover) */
  --line:rgba(237,231,219,.12);
  --line2:rgba(237,231,219,.22);
  --maxw:1180px;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;color:var(--ink);background:var(--bg);
  font:400 17px/1.7 var(--sans);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:var(--gold);text-decoration:none}
a:hover{color:var(--gold2)}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}

/* ---------- type ---------- */
.eyebrow{font:500 .72rem/1 var(--sans);letter-spacing:.34em;text-transform:uppercase;color:var(--gold)}
h1,h2,h3{font-family:var(--serif);font-weight:500;letter-spacing:.4px;margin:0}
h2.display{font-size:clamp(2rem,4.4vw,3.3rem);line-height:1.08;margin:.5rem 0 0}
h3{font-size:1.5rem;font-weight:600}
p{margin:0 0 1rem}
.lede{font-size:1.18rem;color:var(--ink2);font-weight:300;max-width:62ch}
.muted{color:var(--mut)}
.serif-accent{font-family:var(--serif);font-style:italic;color:var(--gold);font-size:1.15em}

/* ---------- nav ---------- */
.nav{position:fixed;inset:0 0 auto 0;z-index:60;display:flex;align-items:center;gap:1.4rem;
  padding:1.05rem 28px;transition:background .3s,border-color .3s,padding .3s;
  border-bottom:1px solid transparent}
.nav.scrolled{background:rgba(14,13,11,.86);backdrop-filter:blur(12px);border-bottom-color:var(--line);padding:.7rem 28px}
.nav .brand{font-family:var(--serif);font-size:1.3rem;font-weight:600;letter-spacing:.5px;color:var(--ink);margin-right:auto;white-space:nowrap;flex-shrink:0}
.nav .brand span{color:var(--gold)}
.nav a.link{color:var(--ink2);font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;font-weight:500}
.nav a.link:hover{color:var(--gold)}
.nav .btn{margin-left:.4rem}
.nav .burger{display:none;background:none;border:0;color:var(--ink);font-size:1.5rem;cursor:pointer;line-height:1}

/* ---------- buttons ---------- */
.btn{display:inline-block;font:500 .78rem/1 var(--sans);letter-spacing:.16em;text-transform:uppercase;
  color:var(--bg);background:var(--gold);padding:.85rem 1.6rem;border-radius:40px;border:1px solid var(--gold);
  cursor:pointer;transition:background .2s,color .2s,transform .2s}
.btn:hover{background:var(--gold2);border-color:var(--gold2);color:var(--bg);transform:translateY(-1px)}
.btn.ghost{background:transparent;color:var(--ink)}
.btn.ghost:hover{background:rgba(196,163,90,.12);color:var(--gold2)}

/* ---------- hero ---------- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;
  background:linear-gradient(90deg,rgba(12,11,9,.82),rgba(12,11,9,.32) 58%,rgba(12,11,9,.12)),
             linear-gradient(180deg,rgba(12,11,9,.5),transparent 26%,rgba(12,11,9,.9)),
             url('assets/photos/i092218.jpg') center 42%/cover no-repeat;}
.hero::after{content:'';position:absolute;inset:0;pointer-events:none;
  box-shadow:inset 0 0 220px 40px rgba(8,7,6,.7)}
.hero .wrap{position:relative;z-index:2;padding-top:6rem;padding-bottom:6rem}
.hero h1{font-size:clamp(2.8rem,7vw,5.6rem);line-height:1.02;font-weight:500;letter-spacing:1px;margin:.6rem 0 .4rem;
  text-shadow:0 2px 40px rgba(0,0,0,.5)}
.hero .sub{font-size:clamp(1.05rem,2vw,1.45rem);color:var(--ink2);font-weight:300;max-width:46ch;margin-bottom:2rem}
.hero .cta-row{display:flex;gap:1rem;flex-wrap:wrap;align-items:center}
.scrollcue{position:absolute;left:50%;bottom:2.2rem;transform:translateX(-50%);z-index:2;
  color:var(--ink2);font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;text-align:center;opacity:.8}
.scrollcue .arr{display:block;margin:.5rem auto 0;width:1px;height:42px;background:linear-gradient(var(--gold),transparent);animation:cue 2s ease-in-out infinite}
@keyframes cue{0%,100%{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

/* ---------- sections ---------- */
section{padding:7rem 0;position:relative}
section.tight{padding:4.5rem 0}
.divider{height:1px;background:linear-gradient(90deg,transparent,var(--line2),transparent);max-width:var(--maxw);margin:0 auto}
.center{text-align:center}
.center .lede{margin-left:auto;margin-right:auto}

/* split story */
.split{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.split.alt .figure{order:-1}
.figure{border-radius:4px;overflow:hidden;border:1px solid var(--line);background:var(--bg2);aspect-ratio:4/3;
  display:flex;align-items:center;justify-content:center}
.figure.tall{aspect-ratio:3/4}
.figure img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .7s ease}
.figure:hover img{transform:scale(1.03)}
/* full-bleed photo band */
.band{position:relative;min-height:64vh;background-size:cover;background-position:center;display:flex;align-items:flex-end;overflow:hidden}
.band::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(12,11,9,.55),transparent 55%),linear-gradient(transparent 45%,rgba(12,11,9,.88))}
.band .cap{position:relative;z-index:2;padding:0 0 3rem}
.band .cap .eyebrow{color:var(--gold2)}
.band .cap h3{font-size:clamp(1.7rem,3.6vw,2.8rem);font-weight:500;color:var(--ink);max-width:18ch;margin-top:.4rem}

/* stat band */
.stats{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:2.4rem 0;margin-top:3rem}
.stat{text-align:center}
.stat .n{font-family:var(--serif);font-size:2.6rem;color:var(--gold);line-height:1}
.stat .l{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--mut);margin-top:.5rem}

/* wings / cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem;margin-top:3rem}
.cards.four{grid-template-columns:repeat(4,1fr)}
.tile{background:var(--bg3);border:1px solid var(--line);border-radius:5px;padding:2rem 1.7rem;transition:border-color .25s,transform .25s}
.tile:hover{border-color:var(--gold);transform:translateY(-3px)}
.tile .k{font:500 .72rem/1 var(--sans);letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}
.tile h3{margin:.6rem 0 .5rem}
.tile p{color:var(--mut);font-size:.96rem;margin:0}
.amenities{display:grid;grid-template-columns:repeat(3,1fr);gap:.2rem 2.4rem;margin-top:2.4rem;list-style:none;padding:0}
.amenities li{padding:.7rem 0;border-bottom:1px solid var(--line);color:var(--ink2);font-size:1rem;display:flex;gap:.6rem}
.amenities li::before{content:'—';color:var(--gold)}

/* gallery + embeds */
.embed{position:relative;width:100%;aspect-ratio:16/9;border:1px solid var(--line);border-radius:5px;overflow:hidden;background:#000}
.embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.videofacade{display:flex;align-items:center;justify-content:center;flex-direction:column;gap:.9rem;text-decoration:none;color:var(--ink);
  background-image:linear-gradient(180deg,rgba(12,11,9,.22),rgba(12,11,9,.72)),url('assets/film-poster.jpg');
  background-size:cover,135%;background-position:center;background-repeat:no-repeat}
.videofacade:hover{color:var(--ink)}
.playbtn{width:66px;height:66px;border-radius:50%;border:1px solid var(--gold);color:var(--gold);
  display:flex;align-items:center;justify-content:center;font-size:1.2rem;padding-left:4px;background:rgba(14,13,11,.4);transition:.2s}
.videofacade:hover .playbtn{background:var(--gold);color:var(--bg);transform:scale(1.06)}
.videofacade .vlabel{font-family:var(--serif);font-size:1.35rem;letter-spacing:.04em}
.embed-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem;margin-top:1rem}
.gallery{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:200px;gap:1rem;margin-top:1.6rem}
.shot{position:relative;border:1px solid var(--line);border-radius:4px;overflow:hidden;
  display:flex;align-items:flex-end;padding:1.1rem;color:var(--ink);font-family:var(--serif);font-size:1.2rem;
  background-size:cover;background-position:center;transition:transform .6s ease,border-color .3s}
.shot:hover{transform:scale(1.02);border-color:var(--gold)}
.shot.tall{grid-row:span 2}
.shot.wide{grid-column:span 2}
.shot::after{content:'';position:absolute;inset:0;background:linear-gradient(transparent 40%,rgba(12,11,9,.82))}
.shot span{position:relative;z-index:2}
.shot .ph{position:absolute;top:.7rem;right:.8rem;z-index:2;font:500 .6rem/1 var(--sans);letter-spacing:.14em;
  text-transform:uppercase;color:var(--mut);border:1px solid var(--line2);border-radius:20px;padding:.25rem .55rem}

/* location list */
.loc{display:grid;grid-template-columns:repeat(2,1fr);gap:.1rem 3rem;margin-top:2rem;list-style:none;padding:0}
.loc li{padding:.85rem 0;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;gap:1rem}
.loc li b{font-weight:500}
.loc li .d{color:var(--mut);font-size:.86rem;text-align:right}

/* inquire / form */
.inquire{background:var(--bg2);border:1px solid var(--line);border-radius:6px;padding:2.6rem}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem;margin-top:1.4rem}
label{display:block;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--mut);margin-bottom:.4rem}
input,textarea,select{width:100%;background:var(--bg);color:var(--ink);border:1px solid var(--line2);
  border-radius:4px;padding:.75rem .85rem;font:inherit;font-size:.98rem}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--gold)}
textarea{min-height:120px;resize:vertical}
.full{grid-column:1/-1}

/* footer */
footer{border-top:1px solid var(--line);padding:3.5rem 0 2.5rem;color:var(--mut);font-size:.9rem}
footer .frow{display:flex;justify-content:space-between;gap:2rem;flex-wrap:wrap;align-items:flex-start}
footer .brand{font-family:var(--serif);font-size:1.4rem;color:var(--ink)}
footer .brand span{color:var(--gold)}
footer a{color:var(--ink2)}
footer .fine{margin-top:2rem;font-size:.78rem;color:var(--mut);opacity:.8}

/* scroll-reveal */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- portal-specific ---------- */
.gate{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;
  background:linear-gradient(180deg,rgba(12,11,9,.74),rgba(12,11,9,.92)),url('assets/photos/i015189.jpg') center/cover}
.gate .box{position:relative;background:rgba(20,18,16,.72);backdrop-filter:blur(14px);
  border:1px solid var(--line2);border-radius:10px;padding:3.2rem 2.8rem;max-width:430px;width:100%;text-align:center;
  box-shadow:0 30px 80px rgba(0,0,0,.55)}
.gate .box::before{content:'';position:absolute;inset:10px;border:1px solid rgba(196,163,90,.28);border-radius:6px;pointer-events:none}
.gate .mark{width:54px;height:54px;margin:0 auto 1rem;display:block}
.gate h1{font-size:2.3rem}
.gate .tag{font-family:var(--serif);font-style:italic;color:var(--gold2);font-size:1.05rem;margin:.2rem 0 .9rem}
.gate .err{color:#e0915a;font-size:.85rem;min-height:1.2em;margin-top:.5rem}
.portal{display:none}
.portal.on{display:block}
.manualgrid{display:flex;gap:1.2rem;align-items:flex-start;padding-top:.6rem}
.manualbody{flex:1;min-width:0}
.manualbody>section>*:first-child{margin-top:0}
.ptabs{position:sticky;top:4.8rem;z-index:40;display:flex;flex-direction:column;gap:.05rem;flex:0 0 calc((100% - 3.6rem) / 4);
  padding:.4rem;background:var(--bg2);border:1px solid var(--line);border-radius:8px}
.ptabs button{display:block;width:100%;text-align:left;white-space:normal;background:none;border:0;color:var(--ink2);
  font:500 .84rem/1.25 var(--sans);letter-spacing:.02em;padding:.5rem .7rem;border-radius:6px;cursor:pointer}
.ptabs button:hover{color:var(--ink);background:rgba(237,231,219,.04)}
.ptabs button.active{color:var(--gold);background:rgba(196,163,90,.12)}
@media(max-width:860px){
  .qref{grid-template-columns:1fr!important}        /* one column — no off-screen clipping */
  .bigticket{display:none}                          /* surface the nav at the top on phones */
  .manualgrid{flex-direction:column;gap:.6rem}
  .ptabs{position:sticky;top:0;z-index:55;flex-direction:row;flex-wrap:nowrap;overflow-x:auto;flex-basis:auto;width:100%;border-radius:8px;-webkit-overflow-scrolling:touch}
  .ptabs button{width:auto;white-space:nowrap;flex:0 0 auto}
  .pcard{padding:1.2rem 1.2rem}
}
.pcard{background:var(--bg3);border:1px solid var(--line);border-radius:6px;padding:1.6rem 1.8rem;margin-bottom:1.4rem}
.pcard h2{font-family:var(--serif);font-size:1.5rem;color:var(--ink);margin:0 0 .6rem}
.pcard h2.g{color:var(--gold)}
.pcard table{width:100%;border-collapse:collapse}
.pcard th,.pcard td{text-align:left;padding:.5rem .2rem;border-bottom:1px solid var(--line);font-size:.95rem;vertical-align:top}
.pcard th{color:var(--mut);font-weight:500;width:38%}
.todo{display:inline-block;background:rgba(196,163,90,.14);border:1px solid var(--gold);color:var(--gold2);
  border-radius:5px;padding:.02rem .5rem;font-size:.82em;font-weight:500}
.qref{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.2rem;margin-bottom:1.4rem}
.qref .pcard .a{font-family:var(--serif);font-size:1.5rem;color:var(--gold);line-height:1.1}
.big{font-family:var(--serif);font-size:1.8rem;color:var(--gold)}
section[data-sec]{display:none;padding:0}
section[data-sec].on{display:block}

/* ---------- schematic figures (site map + floor plans) ---------- */
.schematic{background:linear-gradient(180deg,#13110d,#0f0e0b);border:1px solid var(--line);
  border-radius:8px;padding:1.5rem;margin:.2rem 0 1.4rem;overflow:hidden}
.schematic svg{width:100%;height:auto;display:block}
.schematic figcaption{color:var(--mut);font-size:.76rem;font-style:italic;margin-top:1rem;
  border-top:1px solid var(--line);padding-top:.8rem;line-height:1.5}
.maplegend{display:flex;flex-wrap:wrap;gap:.55rem 1.5rem;margin:1.1rem 0 .2rem;list-style:none;padding:0}
.maplegend li{display:flex;align-items:center;gap:.5rem;color:var(--ink2);font-size:.82rem}
.maplegend i{width:15px;height:15px;border-radius:3px;display:inline-block;flex:0 0 auto}
/* site-map svg classes */
.sitemap .parcel{fill:rgba(196,163,90,.03);stroke:var(--gold);stroke-width:2}
.sitemap .compound{fill:none;stroke:rgba(196,163,90,.4);stroke-width:1;stroke-dasharray:7 6}
.sitemap .blk{fill:rgba(196,163,90,.12);stroke:var(--gold);stroke-width:1.3}
.sitemap .blk.house{fill:rgba(196,163,90,.24)}
.sitemap .water{fill:rgba(96,156,200,.24);stroke:#7fb2dc;stroke-width:1.3}
.sitemap .court{fill:rgba(237,231,219,.05);stroke:rgba(237,231,219,.42);stroke-width:1.1;stroke-dasharray:5 4}
.sitemap .drive{fill:none;stroke:rgba(155,145,126,.6);stroke-width:2.4;stroke-dasharray:2 6;stroke-linecap:round}
.sitemap .tree{fill:rgba(140,170,120,.32)}
.sitemap .t{fill:var(--ink);font:500 11px var(--sans);text-anchor:middle}
.sitemap .t.a{fill:var(--mut);font-weight:400;font-size:9px}
.sitemap .edge{fill:var(--mut);font:400 9.5px var(--sans)}
.sitemap .land{fill:var(--mut);font:italic 400 13px var(--serif)}
.sitemap .north{fill:var(--ink2);font:600 12px var(--sans);text-anchor:middle}
/* floor-plan svg classes */
.plan .out{fill:none;stroke:var(--gold);stroke-width:2}
.plan .rm{fill:rgba(237,231,219,.045);stroke:rgba(237,231,219,.26);stroke-width:1}
.plan .rm.wet{fill:rgba(96,156,200,.12);stroke:rgba(127,178,220,.42)}
.plan .rm.key{fill:rgba(196,163,90,.16);stroke:var(--gold)}
.plan .t{fill:var(--ink);font:500 12px var(--sans);text-anchor:middle}
.plan .t.s{fill:var(--mut);font:400 10px var(--sans);text-anchor:middle}
.levelnote{color:var(--mut);font-size:.85rem;margin:.2rem 0 1rem}

/* ---------- responsive ---------- */
@media(max-width:900px){
  .split{grid-template-columns:1fr;gap:2rem}.split.alt .figure{order:0}
  .stats{grid-template-columns:repeat(2,1fr);gap:2rem 1rem}
  .cards,.cards.four,.amenities,.embed-grid,.gallery,.loc,.form-grid{grid-template-columns:1fr}
  .gallery{grid-auto-rows:200px}.shot.wide{grid-column:auto}.shot.tall{grid-row:auto}
  /* collapse nav to a clean burger + one Guest Login CTA on the right */
  .nav{gap:.8rem}
  .nav .link{display:none}
  .nav a.btn:not(.ghost){display:none}
  .nav a.btn.ghost{display:inline-flex;flex-shrink:0;white-space:nowrap;padding:.55rem 1.1rem;font-size:.72rem}
  .nav .burger{display:block;flex-shrink:0}
  .nav.open{flex-wrap:wrap;background:rgba(14,13,11,.96);backdrop-filter:blur(12px)}
  .nav.open .link{display:block;flex-basis:100%;padding:.55rem 0;text-align:center}
  .nav.open a.btn:not(.ghost){display:block;flex-basis:100%;text-align:center;margin:.5rem 0}
}
@media(max-width:680px){
  body{font-size:16px}
  .nav .brand{font-size:1.12rem}
  section{padding:4.5rem 0}
}
