/* ==========================================================================
   Усадьба «Нижние Дубровки» — стили
   Палитра, типографика и компоненты — по утверждённому дизайн-референсу.
   ========================================================================== */
:root{
  --ink:#131A15;          /* near-black forest, dark sections + text-on-light shadow */
  --pine:#1F3A2C;
  --sage:#95A088;         /* overgrowth on stone */
  --sage-dim:#5C6654;     /* muted captions (darkened for AA contrast on light) */
  --parchment:#ECE4D3;    /* lime plaster */
  --parchment-2:#F5EFE2;
  --brass:#B58A46;        /* remaining gilding — accent */
  --brass-2:#C9A867;
  --brick:#97543B;        /* brick under fallen plaster */
  --text-dark:#1B241D;
  --text-light:#E7E0CF;
  --muted-light:rgba(231,224,207,.76);  /* ↑ for AA on pine/ink */
  --muted-dark:rgba(27,36,29,.74);       /* ↑ for AA on parchment */
  --line-dark:rgba(20,28,21,.16);
  --line-light:rgba(236,228,211,.18);
  --serif:'Lora', Georgia, 'Times New Roman', serif;
  --sans:'Inter', system-ui, -apple-system, sans-serif;
  --maxw:1180px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  background:var(--parchment);
  color:var(--text-dark);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* keyboard focus — visible everywhere */
:focus-visible{outline:2px solid var(--brass-2);outline-offset:3px;border-radius:2px}

.skip-link{
  position:absolute;left:-9999px;top:0;z-index:300;
  background:var(--brass);color:var(--ink);padding:12px 18px;font-weight:600;border-radius:0 0 4px 0;
}
.skip-link:focus{left:0}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.eyebrow{
  font-family:var(--sans);
  font-size:.72rem;font-weight:600;
  letter-spacing:.28em;text-transform:uppercase;
  color:var(--brass);
}
.serif{font-family:var(--serif)}

/* ---------- photo blocks (now real <img> + overlay) ---------- */
.photo{
  position:relative;overflow:hidden;
  background:
    radial-gradient(120% 90% at 30% 10%, rgba(149,160,136,.55), transparent 60%),
    linear-gradient(160deg,#2c3a30 0%, #45503f 45%, #6d6450 100%);
  display:flex;align-items:flex-end;
}
.ph-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.photo::after{
  content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,transparent 48%,rgba(15,20,16,.5));
  pointer-events:none;
}
.photo .tag{
  position:relative;z-index:2;
  font-family:var(--sans);font-size:.74rem;letter-spacing:.06em;
  color:rgba(231,224,207,.9);
  padding:12px 14px;font-weight:500;
}

/* ---------- nav ---------- */
header.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  transition:background .4s var(--ease), box-shadow .4s var(--ease), border-color .4s;
  border-bottom:1px solid transparent;
}
header.nav .bar{
  max-width:var(--maxw);margin:0 auto;padding:18px 28px;
  display:flex;align-items:center;justify-content:space-between;
  transition:padding .4s var(--ease);
}
.brandmark{display:flex;align-items:center;gap:12px;color:var(--text-light);transition:color .4s}
.brandmark .mono{
  width:34px;height:34px;border:1px solid currentColor;border-radius:50%;
  display:grid;place-items:center;font-family:var(--serif);font-size:1rem;
  letter-spacing:-.04em;flex:none;
}
.brandmark .bn{font-family:var(--serif);font-size:1.06rem;font-weight:600;letter-spacing:.01em;line-height:1.05}
.brandmark .bn small{display:block;font-family:var(--sans);font-size:.6rem;font-weight:500;
  letter-spacing:.22em;text-transform:uppercase;opacity:.72;margin-top:2px}
nav.links{display:flex;align-items:center;gap:24px}
nav.links a{font-size:.84rem;font-weight:500;color:var(--text-light);opacity:.92;transition:opacity .25s,color .4s;white-space:nowrap}
nav.links a:hover{opacity:1}
.nav-cta{
  font-size:.82rem;font-weight:600;color:var(--text-light);
  border:1px solid var(--line-light);border-radius:999px;padding:9px 20px;
  transition:background .3s,border-color .3s,color .3s;
}
.nav-cta:hover{background:var(--brass);border-color:var(--brass);color:var(--ink)}

header.nav.solid{background:rgba(243,238,228,.94);backdrop-filter:blur(10px);border-color:var(--line-dark)}
header.nav.solid .bar{padding:12px 28px}
header.nav.solid .brandmark{color:var(--text-dark)}
header.nav.solid nav.links a{color:var(--text-dark);opacity:.88}
header.nav.solid .nav-cta{color:var(--text-dark);border-color:var(--line-dark)}
header.nav.solid .nav-cta:hover{color:var(--ink)}

/* switch to burger before the links crowd the CTA button */
@media(max-width:1040px){
  nav.links{display:none}
  .nav-cta{display:none}
  .burger{display:block}
}
.burger{display:none;background:none;border:0;cursor:pointer;width:34px;height:30px;position:relative;z-index:130}
.burger span{position:absolute;left:5px;right:5px;height:2px;background:var(--text-light);transition:.3s var(--ease)}
header.nav.solid .burger span{background:var(--text-dark)}
.burger span:nth-child(1){top:7px}.burger span:nth-child(2){top:14px}.burger span:nth-child(3){top:21px}
body.menu-open .burger span:nth-child(1){top:14px;transform:rotate(45deg)}
body.menu-open .burger span:nth-child(2){opacity:0}
body.menu-open .burger span:nth-child(3){top:14px;transform:rotate(-45deg)}
body.menu-open .burger span{background:var(--text-light)}

/* mobile menu panel */
.mobile-menu{
  position:fixed;inset:0;z-index:120;background:rgba(15,20,16,.97);backdrop-filter:blur(6px);
  display:flex;flex-direction:column;justify-content:center;gap:6px;padding:0 32px;
  opacity:0;visibility:hidden;transition:opacity .35s var(--ease),visibility .35s;
}
body.menu-open .mobile-menu{opacity:1;visibility:visible}
.mobile-menu a{
  font-family:var(--serif);font-size:1.5rem;color:var(--text-light);padding:12px 0;
  border-bottom:1px solid var(--line-light);transition:color .25s,padding-left .25s var(--ease);
}
.mobile-menu a:hover,.mobile-menu a:focus-visible{color:var(--brass-2);padding-left:8px}
.mobile-menu .mm-cta{font-family:var(--sans);font-size:1rem;font-weight:600;color:var(--brass-2);border-bottom:0;margin-top:18px}

/* ---------- HERO (seasonal signature) ---------- */
.hero{
  position:relative;min-height:clamp(600px,82svh,860px);display:flex;align-items:flex-end;
  /* keep the full-bleed photo height, but push the text block up by moving all
     vertical breathing room to the foot (was symmetric section padding) */
  padding:0 0 clamp(128px,18vw,256px);
  background:radial-gradient(140% 100% at 50% -10%, #2a3a2d 0%, #1b271f 45%, #10160f 100%);
  overflow:hidden;
}
.hero-seasons{position:absolute;inset:0;z-index:0}
.hero-slide{
  position:absolute;inset:0;opacity:0;transition:opacity 1.2s var(--ease);
}
.hero-slide img{width:100%;height:100%;object-fit:cover;display:block}
.hero-slide.is-active{opacity:1}
/* legibility scrim (dark at the foot for text contrast) */
.hero-scrim{
  position:absolute;inset:0;z-index:2;pointer-events:none;
  background:
    linear-gradient(180deg, rgba(11,15,11,.52) 0%, rgba(11,15,11,.20) 28%, rgba(11,15,11,.30) 50%, rgba(8,11,8,.70) 80%, rgba(8,11,8,.94) 100%),
    linear-gradient(75deg, rgba(8,11,8,.64) 0%, rgba(8,11,8,.30) 46%, transparent 70%);
}
.hero .vignette{position:absolute;inset:0;z-index:3;pointer-events:none;
  box-shadow:inset 0 -120px 160px rgba(8,11,8,.55), inset 0 60px 120px rgba(8,11,8,.32)}
.hero .inner{position:relative;z-index:4;width:100%;max-width:var(--maxw);margin:0 auto;padding:110px 28px 6vh}
.hero .kicker{display:flex;align-items:center;gap:14px;margin-bottom:22px;flex-wrap:wrap}
.hero .kicker .rule{height:1px;width:42px;background:var(--brass);flex:none}
.hero .kicker span:not(.rule){color:var(--text-light);font-size:.78rem;letter-spacing:.24em;text-transform:uppercase;font-weight:500;opacity:.92}
.hero h1{
  font-family:var(--serif);color:var(--text-light);font-weight:600;
  font-size:clamp(2.9rem,8vw,6.4rem);line-height:.98;letter-spacing:0;
  font-kerning:normal;text-rendering:optimizeLegibility;font-feature-settings:"kern" 1;
  text-wrap:balance;text-shadow:0 2px 30px rgba(8,11,8,.5);
}
.hero h1 em{font-style:italic;font-weight:400;color:var(--brass-2);letter-spacing:.005em}
.hero .lede{
  margin-top:26px;max-width:560px;color:var(--text-light);
  font-size:clamp(1rem,1.5vw,1.18rem);font-family:var(--serif);font-style:italic;line-height:1.55;
  text-shadow:0 1px 16px rgba(8,11,8,.6);
}
.hero .facts{
  margin-top:38px;display:grid;grid-template-columns:repeat(4,1fr);gap:0;max-width:840px;
}
.hero .facts div{padding:18px 22px 4px 0}
.hero .facts .n{font-family:var(--serif);font-size:clamp(1.4rem,2.4vw,2rem);color:var(--text-light);font-weight:500;line-height:1}
.hero .facts .l{margin-top:8px;color:var(--brass-2);font-size:.92rem;letter-spacing:.04em}

/* ---------- generic section ---------- */
section{padding:clamp(64px,9vw,128px) 0}
.sec-head{max-width:720px;margin-bottom:54px}
.sec-head .eyebrow{display:inline-flex;align-items:center;gap:12px;margin-bottom:18px}
.sec-head .eyebrow::before{content:"";width:26px;height:1px;background:var(--brass)}
.sec-head h2{font-family:var(--serif);font-weight:600;font-size:clamp(1.9rem,4vw,3rem);
  line-height:1.05;letter-spacing:-.01em}
.sec-head p{margin-top:18px;color:var(--muted-dark);font-size:1.04rem;max-width:600px}

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

/* ---------- intro (transitional dark) ---------- */
.intro{background:var(--ink);color:var(--text-light)}
.intro .grid{display:grid;grid-template-columns:1.1fr 1fr;gap:64px;align-items:center}
.intro h2{font-family:var(--serif);color:var(--text-light)}
.intro .lead-serif{font-family:var(--serif);font-size:clamp(1.3rem,2.4vw,1.7rem);line-height:1.45;
  font-weight:400;color:var(--text-light)}
.intro .lead-serif .dc{font-size:2.4em;float:left;line-height:.7;font-weight:600;color:var(--brass-2);
  margin:.05em .12em -.1em 0}
.intro p.body{margin-top:22px;color:var(--muted-light);font-size:1.02rem}
.intro .points{margin-top:34px;display:grid;gap:2px;border-top:1px solid var(--line-light)}
.intro .points li{list-style:none;display:flex;gap:18px;padding:18px 0;border-bottom:1px solid var(--line-light)}
.intro .points .ix{font-family:var(--serif);color:var(--brass-2);font-size:1.05rem;flex:none;width:30px}
.intro .points b{font-weight:600;color:var(--text-light);font-size:.98rem;display:block}
.intro .points small{color:var(--muted-light);font-size:.86rem}

/* ---------- history timeline ---------- */
.timeline{position:relative;max-width:760px;margin:0 auto}
.timeline::before{content:"";position:absolute;left:11px;top:6px;bottom:6px;width:1px;background:var(--line-dark)}
.tl-item{position:relative;padding:0 0 40px 52px}
.tl-item:last-child{padding-bottom:0}
.tl-item .dot{position:absolute;left:4px;top:6px;width:15px;height:15px;border-radius:50%;
  background:var(--parchment);border:2px solid var(--brass)}
.tl-item .yr{font-family:var(--serif);font-size:1.5rem;font-weight:600;color:var(--pine);line-height:1}
.tl-item .yr small{font-family:var(--sans);font-size:.72rem;font-weight:600;letter-spacing:.16em;
  text-transform:uppercase;color:var(--sage-dim);display:block;margin-top:6px}
.tl-item p{margin-top:10px;color:var(--muted-dark);font-size:.98rem;max-width:520px}
.tl-note{margin-top:28px;font-size:.82rem;color:var(--sage-dim);font-style:italic;text-align:center}

/* ---------- SIGNATURE: estate plan ---------- */
.plan{background:var(--parchment-2)}
.plan-stage{display:grid;grid-template-columns:1.45fr 1fr;gap:48px;align-items:stretch}
.plan-map{
  position:relative;border:1px solid var(--line-dark);border-radius:3px;
  background:
    repeating-linear-gradient(0deg,transparent,transparent 23px,rgba(20,28,21,.035) 24px),
    repeating-linear-gradient(90deg,transparent,transparent 23px,rgba(20,28,21,.035) 24px),
    var(--parchment);
  overflow:hidden;min-height:440px;
}
.plan-map svg{display:block;width:100%;height:100%}
.hot{cursor:pointer}
.hot circle.bg{fill:var(--parchment);stroke:var(--brass);stroke-width:1.5;transition:fill .25s, r .25s}
.hot text{font-family:var(--serif);font-size:13px;fill:var(--pine);text-anchor:middle;dominant-baseline:central;font-weight:600;pointer-events:none}
.hot:hover circle.bg, .hot.active circle.bg{fill:var(--brass)}
.hot:hover text, .hot.active text{fill:var(--ink)}
.hot:focus{outline:none}
.hot:focus-visible circle.bg{fill:var(--brass);stroke:var(--ink);stroke-width:2.5}
.plan-caption{font-family:var(--sans);font-size:11px;fill:var(--sage-dim);letter-spacing:.12em;text-transform:uppercase}
.plan-info{display:flex;flex-direction:column;justify-content:center}
.plan-info .num{font-family:var(--serif);font-size:.95rem;color:var(--brass);letter-spacing:.1em;margin-bottom:10px}
.plan-info h3{font-family:var(--serif);font-size:1.7rem;font-weight:600;line-height:1.1;color:var(--text-dark);transition:opacity .3s}
.plan-info p{margin-top:14px;color:var(--muted-dark);font-size:.98rem;transition:opacity .3s}
.plan-info .meta{margin-top:20px;display:flex;gap:10px;flex-wrap:wrap}
.plan-info .meta span{font-size:.74rem;letter-spacing:.04em;color:var(--pine);
  border:1px solid var(--line-dark);border-radius:999px;padding:6px 13px;background:var(--parchment)}
.plan-hint{margin-top:26px;font-size:.8rem;color:var(--sage-dim);font-style:italic}

/* ---------- before / after (seasons & light) ---------- */
.ba{background:var(--ink);color:var(--text-light)}
.ba .sec-head h2{color:var(--text-light)}
.ba .sec-head p{color:var(--muted-light)}
.ba-stage{position:relative;aspect-ratio:16/8;border-radius:3px;overflow:hidden;user-select:none;
  border:1px solid var(--line-light);touch-action:pan-y}
.ba-layer{position:absolute;inset:0}
.ba-after{z-index:1}
.ba-after .photo{position:absolute;inset:0}
.ba-before{z-index:2;width:50%;border-right:2px solid var(--brass);overflow:hidden}
.ba-before .photo{position:absolute;inset:0;width:var(--ba-w,100%);height:100%}
.ba-label{position:absolute;top:18px;z-index:4;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  font-weight:600;padding:7px 14px;border-radius:999px;background:rgba(15,20,16,.66);backdrop-filter:blur(4px)}
.ba-label.l{left:18px;color:var(--sage)}
.ba-label.r{right:18px;color:var(--brass-2)}
.ba-handle{position:absolute;top:0;bottom:0;left:50%;width:44px;transform:translateX(-50%);z-index:5;
  cursor:ew-resize;display:grid;place-items:center;border:0;background:none}
.ba-handle .knob{width:44px;height:44px;border-radius:50%;background:var(--brass);
  display:grid;place-items:center;box-shadow:0 6px 18px rgba(0,0,0,.4);color:var(--ink);font-size:1rem}
.ba-handle:focus-visible .knob{outline:2px solid var(--text-light);outline-offset:2px}
.ba-note{margin-top:18px;color:var(--muted-light);font-size:.84rem;text-align:center;font-style:italic}

/* ---------- gallery ---------- */
.gal-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:200px;gap:14px}
.gtile{position:relative;overflow:hidden;border-radius:3px;cursor:pointer;border:0;background:none;padding:0;width:100%}
.gtile .photo{position:absolute;inset:0}
.gtile .ph-img{transition:transform .6s var(--ease)}
.gtile:hover .ph-img{transform:scale(1.05)}
.gtile:nth-child(1){grid-column:span 2;grid-row:span 2}
.gtile.gtile-wide{grid-column:span 2}
.gtile .ov{position:absolute;inset:0;z-index:3;display:grid;place-items:center;opacity:0;transition:.3s;
  background:rgba(15,20,16,.4)}
.gtile:hover .ov,.gtile:focus-visible .ov{opacity:1}
.gtile .ov span{color:var(--text-light);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;
  border:1px solid var(--line-light);padding:8px 16px;border-radius:999px}

/* lightbox */
.lb{position:fixed;inset:0;z-index:200;background:rgba(10,14,11,.94);display:none;
  align-items:center;justify-content:center;padding:5vw}
.lb.open{display:flex}
.lb .frame{position:relative;width:min(1040px,92vw);aspect-ratio:16/10;border-radius:3px;overflow:hidden}
.lb .frame .photo{position:absolute;inset:0}
.lb .cap{position:absolute;left:0;right:0;bottom:0;z-index:4;padding:22px;color:var(--text-light);
  font-family:var(--serif);font-style:italic;font-size:1.05rem;background:linear-gradient(transparent,rgba(10,14,11,.8))}
.lb button{position:absolute;background:rgba(15,20,16,.4);border:1px solid var(--line-light);color:var(--text-light);
  width:48px;height:48px;border-radius:50%;cursor:pointer;font-size:1.2rem;display:grid;place-items:center;transition:.25s}
.lb button:hover{background:var(--brass);color:var(--ink);border-color:var(--brass)}
.lb .prev{left:2vw;top:50%;transform:translateY(-50%)}
.lb .next{right:2vw;top:50%;transform:translateY(-50%)}
.lb .close{top:3vh;right:2vw}

/* ---------- potential scenarios ---------- */
#potential{background:var(--parchment-2)}
.pot-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;border:1px solid var(--line-dark);
  border-radius:3px;overflow:hidden}
.pcell{padding:38px 34px;background:var(--parchment);transition:background .35s}
.pcell:hover{background:var(--parchment-2)}
.pcell .pn{font-family:var(--serif);font-size:.9rem;color:var(--brass);letter-spacing:.14em}
.pcell h3{font-family:var(--serif);font-size:1.55rem;font-weight:600;margin-top:12px}
.pcell p{margin-top:12px;color:var(--muted-dark);font-size:.95rem;max-width:420px}
.pcell .roi{margin-top:18px;font-size:.78rem;color:var(--pine);font-weight:600;letter-spacing:.03em;
  display:inline-flex;align-items:center;gap:8px}
.pcell .roi::before{content:"";width:18px;height:1px;background:var(--brass)}

/* ---------- specs ---------- */
.specs{background:var(--ink);color:var(--text-light)}
.specs .sec-head h2{color:var(--text-light)}
.specs .sec-head p{color:var(--muted-light)}
.spec-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 64px}
.srow{display:flex;justify-content:space-between;gap:20px;align-items:baseline;
  padding:16px 0;border-bottom:1px solid var(--line-light)}
.srow .k{color:var(--muted-light);font-size:.9rem}
.srow .v{color:var(--brass-2);font-family:var(--serif);font-size:1.05rem;font-weight:500;text-align:right}
.heritage{margin-top:38px;border:1px solid var(--brass);border-radius:3px;padding:24px 26px;
  display:flex;gap:20px;align-items:flex-start;background:rgba(181,138,70,.1)}
.heritage .ic{font-family:var(--serif);font-size:1.6rem;color:var(--brass-2);flex:none;line-height:1}
.heritage b{display:block;font-size:1rem;color:var(--text-light);margin-bottom:6px}
.heritage p{color:var(--muted-light);font-size:.9rem}

/* ---------- location ---------- */
.loc-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.loc-map{aspect-ratio:5/4;border:1px solid var(--line-dark);border-radius:3px;position:relative;overflow:hidden;
  background:
    radial-gradient(60% 50% at 60% 40%, rgba(149,160,136,.25), transparent 70%),
    linear-gradient(160deg,#dfe3d6,#e9e2d2)}
.loc-map svg{position:absolute;inset:0;width:100%;height:100%}
/* full-width interactive map below the grid */
.loc-embed{position:relative;margin-top:36px;height:clamp(320px,40vw,460px);
  border:1px solid var(--line-dark);border-radius:3px;overflow:hidden;background:var(--parchment-2)}
.loc-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0;filter:saturate(.92)}
.loc-embed .map-cap{position:absolute;left:10px;top:8px;z-index:2;font-size:.66rem;letter-spacing:.08em;
  text-transform:uppercase;color:var(--sage-dim);background:rgba(245,239,226,.82);padding:4px 9px;border-radius:999px;pointer-events:none}
.dist{display:grid;gap:2px;border-top:1px solid var(--line-dark);margin-top:8px}
.dist .drow{display:flex;justify-content:space-between;padding:15px 0;border-bottom:1px solid var(--line-dark)}
.dist .drow .p{font-size:.96rem;font-weight:500}
.dist .drow .km{font-family:var(--serif);font-size:1.05rem;color:var(--pine);font-weight:600}
.loc-grid .lead{font-family:var(--serif);font-size:1.2rem;line-height:1.5;margin-bottom:8px}

/* ---------- contact / CTA ---------- */
.cta{background:var(--ink);color:var(--text-light);position:relative;overflow:hidden}
.cta .mist{position:absolute;inset:0;opacity:.4;z-index:0;pointer-events:none;
  background:radial-gradient(50% 40% at 50% 0%, rgba(149,160,136,.2), transparent 70%)}
.cta .inner{position:relative;z-index:1;display:grid;grid-template-columns:1.1fr 1fr;gap:64px;align-items:center}
.cta h2{font-family:var(--serif);font-size:clamp(2rem,4vw,3.2rem);font-weight:600;line-height:1.05;color:var(--text-light)}
.cta h2 em{font-style:italic;color:var(--brass-2)}
.cta .price{margin-top:26px;display:flex;align-items:baseline;gap:14px;flex-wrap:wrap}
.cta .price .amt{font-family:var(--serif);font-size:clamp(2rem,4vw,2.8rem);color:var(--text-light);font-weight:600}
.cta .price .by{color:var(--muted-light);font-size:.92rem}
.cta .sub{margin-top:16px;color:var(--muted-light);font-size:.98rem;max-width:430px}
/* ----- contact card (replaces lead form) ----- */
.cta .contact-card{background:rgba(231,224,207,.05);border:1px solid var(--line-light);border-radius:4px;padding:30px}
.cta .contact-card h3{font-family:var(--serif);font-size:1.3rem;font-weight:600;margin-bottom:6px;color:var(--text-light)}
.cta .cc-lead{color:var(--muted-light);font-size:.86rem;line-height:1.55;margin-bottom:22px}
.cc-actions{display:flex;flex-direction:column;gap:12px}
.cc-btn{display:flex;align-items:center;gap:14px;padding:13px 16px;border:1px solid var(--line-light);border-radius:3px;
  background:rgba(15,20,16,.4);color:var(--text-light);text-decoration:none;transition:border-color .25s,background .25s,transform .25s}
.cc-btn:hover{border-color:var(--brass);background:rgba(15,20,16,.6);transform:translateX(3px)}
.cc-btn:focus-visible{outline:2px solid var(--brass);outline-offset:2px}
.cc-ic{flex:none;width:42px;height:42px;display:grid;place-items:center;border-radius:50%;
  background:rgba(192,160,98,.16);color:var(--brass-2);font-size:1.05rem}
.cc-tx{display:flex;flex-direction:column;line-height:1.3;min-width:0}
.cc-tx b{font-weight:600;font-size:.98rem}
.cc-tx small{color:var(--muted-light);font-size:.8rem;overflow:hidden;text-overflow:ellipsis}
.cc-primary{background:var(--brass);border-color:var(--brass);color:var(--ink)}
.cc-primary:hover{background:var(--brass-2);border-color:var(--brass-2);transform:translateX(3px)}
.cc-primary .cc-ic{background:rgba(15,20,16,.18);color:var(--ink)}
.cc-primary .cc-tx small{color:rgba(15,20,16,.72)}

/* ---------- detailed history (expandable) ---------- */
.fullhist{background:var(--ink);color:var(--text-light)}
.fullhist .sec-head h2{color:var(--text-light)}
.fullhist .sec-head p{color:var(--muted-light)}
.fh-body{max-width:820px}
.fh-lead{font-family:var(--serif);font-size:clamp(1.15rem,2vw,1.45rem);line-height:1.5;color:var(--text-light)}
.hist-toggle{margin-top:28px;display:inline-flex;align-items:center;gap:10px;
  font-family:var(--sans);font-size:.9rem;font-weight:600;letter-spacing:.02em;
  color:var(--ink);background:var(--brass);border:0;border-radius:999px;padding:13px 26px;cursor:pointer;transition:background .25s}
.hist-toggle:hover{background:var(--brass-2)}
.hist-toggle .ht-ic{font-size:1.05rem;transition:transform .3s var(--ease)}
.hist-toggle[aria-expanded="true"] .ht-ic{transform:rotate(180deg)}
.full-history[hidden]{display:none}
.full-history{margin-top:32px;border-top:1px solid var(--line-light);padding-top:6px;animation:fhIn .5s var(--ease)}
@keyframes fhIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}
.full-history h3{font-family:var(--serif);font-size:1.3rem;font-weight:600;color:var(--brass-2);margin:32px 0 10px}
.full-history h3:first-child{margin-top:18px}
.full-history p{color:var(--muted-light);font-size:1rem;line-height:1.72;margin-bottom:14px;max-width:760px}
.full-history em{color:var(--text-light);font-style:italic;font-weight:500}
.full-history .fh-src{font-size:.82rem;color:var(--sage);font-style:italic;margin-top:26px;border-top:1px solid var(--line-light);padding-top:18px}

/* ---------- footer ---------- */
footer.ft{background:#0E140F;color:var(--muted-light);padding:54px 0 40px}
footer.ft .ft-top{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;
  padding-bottom:30px;border-bottom:1px solid var(--line-light)}
footer.ft .brandmark{color:var(--text-light)}
footer.ft .fcol h4{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brass);margin-bottom:14px;font-weight:600}
footer.ft .fcol a,footer.ft .fcol p{display:block;font-size:.9rem;margin-bottom:8px;color:var(--muted-light)}
footer.ft .fcol a:hover{color:var(--text-light)}
footer.ft .fcols{display:flex;gap:64px;flex-wrap:wrap}
footer.ft .ft-bot{padding-top:24px;display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;font-size:.78rem}
footer.ft .ft-note{margin-top:14px;font-size:.72rem;color:rgba(231,224,207,.45);max-width:680px;line-height:1.5}

/* ---------- responsive ---------- */
@media(max-width:880px){
  .hero .inner{padding:104px 28px 6vh}
  .hero .facts{grid-template-columns:1fr 1fr;gap:0 8px}
  .intro .grid,.cta .inner,.loc-grid{grid-template-columns:1fr;gap:40px}
  .plan-stage{grid-template-columns:1fr;gap:28px}
  .incl-grid,.gal-grid,.pot-grid,.spec-grid{grid-template-columns:1fr}
  .gal-grid{grid-auto-rows:220px}
  .gtile:nth-child(1),.gtile.gtile-wide{grid-column:span 1;grid-row:span 1}
  .ba-stage{aspect-ratio:4/3}
  .cta .contact-card{padding:24px}
  .pcell{padding:30px 26px}
}
@media(max-width:420px){
  .wrap{padding:0 16px}
  .hero .inner{padding:96px 16px 6vh}
  .hero .facts .n{font-size:1.3rem}
  .season-switch button{padding:8px 13px;font-size:.76rem}
  .pcell{padding:26px 20px}
  .cta .contact-card{padding:20px}
  footer.ft .fcols{gap:32px}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
  .hero-slide{transition:none}
  html{scroll-behavior:auto}
}
