:root{
  --espresso:#241a12;      /* deep saddle brown */
  --leather:#8a5a33;       /* worked leather */
  --oat:#f0e9dc;           /* page ground */
  --oat-deep:#e4d9c6;      /* alt sections */
  --pine:#3c5536;          /* pine green panels */
  --leaf:#6da33f;          /* vivid leaf green accent */
  --line:rgba(36,26,18,.18);
  --radius:14px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
}
body{
  font-family:"Albert Sans",system-ui,sans-serif;
  background:var(--oat);color:var(--espresso);
  line-height:1.6;font-size:1.0625rem;
}
h1,h2,h3{font-family:"Hepta Slab",serif;line-height:1.12}
a{color:inherit}
img{max-width:100%;display:block}
.wrap{max-width:1100px;margin:0 auto;padding:0 24px}

.eyebrow{
  display:inline-flex;align-items:center;gap:.6em;
  font-size:.78rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  color:var(--pine);
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--leaf)}

.rail{border:0;height:10px;margin:0;background:
  linear-gradient(var(--line),var(--line)) 0 1px/100% 2px no-repeat,
  linear-gradient(var(--line),var(--line)) 0 7px/100% 2px no-repeat;}

/* ---- header ---- */
header.site{
  position:sticky;top:0;z-index:50;
  background:rgba(240,233,220,.92);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 24px;max-width:1180px;margin:0 auto}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.brandmark{
  width:50px;height:50px;border-radius:50%;
  border:2.5px solid var(--leather);
  display:grid;place-items:center;
  font-family:"Dancing Script",cursive;font-weight:700;font-size:1.5rem;
  color:var(--leather);
  background:radial-gradient(circle at 32% 28%, rgba(255,255,255,.5), transparent 60%);
  padding-bottom:4px;
}
.brandname{font-family:"Hepta Slab",serif;font-weight:700;font-size:1rem;letter-spacing:.02em;line-height:1.2}
.brandname small{display:block;font-family:"Albert Sans",sans-serif;font-weight:500;font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--pine)}
nav.main ul{display:flex;gap:2px;list-style:none;flex-wrap:wrap}
nav.main a{
  text-decoration:none;font-weight:500;font-size:.9rem;
  padding:8px 11px;border-radius:999px;transition:background .2s,color .2s;white-space:nowrap;
}
nav.main a:hover{background:var(--oat-deep)}
nav.main a[aria-current="page"]{background:var(--espresso);color:var(--oat)}
.nav-toggle{display:none}

/* ---- heroes ---- */
.hero{background:var(--espresso);color:var(--oat);position:relative;overflow:hidden}
.hero .wrap{padding:84px 24px 0;position:relative;z-index:2}
.hero.compact .wrap{padding:64px 24px 56px}
.hero .eyebrow{color:var(--leaf)}
.hero .eyebrow::before{background:var(--leaf)}
.hero h1{font-size:clamp(2.2rem,5.5vw,3.9rem);font-weight:800;max-width:16ch;margin:.4em 0 .45em;letter-spacing:-.01em}
.hero h1 em{font-style:normal;color:var(--leaf)}
.hero p{max-width:54ch;color:rgba(240,233,220,.84);font-size:1.1rem}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin:32px 0 0}
.hero.photo{background:linear-gradient(rgba(36,26,18,.78),rgba(36,26,18,.62)),var(--hero-img) center/cover no-repeat}
.hero.photo .wrap{padding:120px 24px 110px}
.horizon{display:block;width:100%;margin-top:48px}

.btn{display:inline-block;text-decoration:none;font-weight:600;font-size:.98rem;padding:13px 26px;border-radius:999px;transition:transform .15s,background .2s}
.btn:hover{transform:translateY(-2px)}
.btn-green{background:var(--leaf);color:#fff}
.btn-green:hover{background:#7cb44c}
.btn-ghost{border:1.5px solid rgba(240,233,220,.45);color:var(--oat)}
.btn-ghost:hover{border-color:var(--oat)}
.btn-brown{background:var(--leather);color:var(--oat)}
.btn-brown:hover{background:#9c6a3f}

/* ---- sections ---- */
.section{padding:84px 0}
.section.tight{padding:64px 0}
.section-head{max-width:62ch;margin-bottom:44px}
.section-head h2{font-size:clamp(1.8rem,3.6vw,2.6rem);font-weight:700;margin:.35em 0 .4em}
.section-head p{color:rgba(36,26,18,.75)}
.alt{background:var(--oat-deep)}

/* ---- cards & grids ---- */
.amenities{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.amenity{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px 22px;display:flex;gap:16px;align-items:flex-start;transition:transform .18s,box-shadow .18s}
.amenity:hover{transform:translateY(-3px);box-shadow:0 10px 24px rgba(36,26,18,.08)}
.amenity svg{flex:0 0 auto;width:34px;height:34px;stroke:var(--pine);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;margin-top:2px}
.amenity h3{font-size:1.02rem;font-weight:700;margin-bottom:3px}
.amenity p{font-size:.92rem;color:rgba(36,26,18,.7);line-height:1.5}

.plans{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.plan{border-radius:var(--radius);padding:36px 32px;display:flex;flex-direction:column;gap:18px}
.plan.partial{background:#fff;border:1px solid var(--line)}
.plan.full{background:var(--pine);color:var(--oat)}
.plan-tag{align-self:flex-start;font-size:.72rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;padding:6px 13px;border-radius:999px}
.plan.partial .plan-tag{background:var(--oat);color:var(--leather)}
.plan.full .plan-tag{background:rgba(240,233,220,.15);color:#a6cd7d}
.plan h3{font-size:1.6rem;font-weight:700}
.plan ul{list-style:none;display:flex;flex-direction:column;gap:11px;font-size:.97rem}
.plan li{display:flex;gap:11px;align-items:flex-start}
.plan li::before{content:"";flex:0 0 auto;width:18px;height:18px;margin-top:3px;background:var(--leaf);
  -webkit-mask:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="black" stroke-width="3" stroke-linecap="round" stroke-linejoin="round"><polyline points="20 6 9 17 4 12"/></svg>') center/contain no-repeat;
  mask:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="black" stroke-width="3" stroke-linecap="round" stroke-linejoin="round"><polyline points="20 6 9 17 4 12"/></svg>') center/contain no-repeat}
.plan.partial li::before{background:var(--pine)}
.plan.full li::before{background:#a6cd7d}
.plan-note{font-size:.88rem;opacity:.78;margin-top:auto}
.plan .btn{align-self:flex-start;margin-top:8px}

.duo{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.duo-card{border-radius:var(--radius);padding:36px 32px;border:1px solid var(--line);background:#fff;display:flex;flex-direction:column;gap:14px}
.duo-card.dark{background:var(--espresso);color:var(--oat);border-color:transparent}
.duo-card h3{font-size:1.45rem;font-weight:700}
.duo-card p{font-size:.98rem;line-height:1.65}
.duo-card.dark p{color:rgba(240,233,220,.82)}
.duo-card .eyebrow{color:var(--leather)}
.duo-card.dark .eyebrow{color:var(--leaf)}
.duo-card.dark .eyebrow::before{background:var(--leaf)}
.phone{font-family:"Hepta Slab",serif;font-weight:700;font-size:1.4rem;text-decoration:none;color:var(--leaf);letter-spacing:.01em}
.phone:hover{text-decoration:underline}
.textlink{font-weight:600;color:var(--leather);text-decoration:none;border-bottom:2px solid var(--oat-deep);transition:border-color .2s}
.textlink:hover{border-color:var(--leather)}

/* ---- photo strips & figures ---- */
.photo-strip{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.photo-strip figure{border-radius:12px;overflow:hidden;border:1px solid var(--line);background:#fff;margin:0}
.photo-strip img{width:100%;height:170px;object-fit:cover;transition:transform .3s}
.photo-strip figure:hover img{transform:scale(1.04)}
.photo-strip figcaption{font-size:.8rem;padding:8px 12px;color:rgba(36,26,18,.7)}

.split{display:grid;grid-template-columns:1.05fr .95fr;gap:44px;align-items:center}
.split .frame{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);box-shadow:0 16px 36px rgba(36,26,18,.12)}
.split .frame img{width:100%;height:100%;object-fit:cover}

/* ---- family / event cards ---- */
.cards3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.cards2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:transform .18s,box-shadow .18s}
.card:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(36,26,18,.1)}
.card img{width:100%;height:200px;object-fit:cover}
.card img.contain{object-fit:contain;background:#fff;padding:18px;height:160px}
.card .pad{padding:22px 22px 26px;display:flex;flex-direction:column;gap:10px;flex:1}
.card h3{font-size:1.18rem;font-weight:700}
.card p{font-size:.94rem;color:rgba(36,26,18,.72);line-height:1.6}
.card .textlink{margin-top:auto;align-self:flex-start}
.badge{align-self:flex-start;font-size:.7rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;background:var(--oat);color:var(--pine);padding:5px 11px;border-radius:999px}

/* ---- gallery ---- */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.gallery-grid button{border:1px solid var(--line);border-radius:12px;overflow:hidden;padding:0;background:#fff;cursor:pointer;display:block}
.gallery-grid img{width:100%;height:200px;object-fit:cover;transition:transform .3s}
.gallery-grid button:hover img{transform:scale(1.05)}
.lightbox{position:fixed;inset:0;background:rgba(20,14,9,.93);display:none;align-items:center;justify-content:center;z-index:100;padding:24px;gap:8px}
.lightbox.open{display:flex}
.lb-stage{margin:0;display:flex;flex-direction:column;align-items:center;gap:14px;max-width:min(1000px,86vw)}
.lb-stage img{max-width:100%;max-height:80vh;border-radius:10px;object-fit:contain;background:#241a12}
.lb-stage figcaption{color:rgba(240,233,220,.85);font-size:.88rem;letter-spacing:.02em;text-align:center}
.lb-nav{flex:0 0 auto;width:52px;height:52px;border-radius:50%;border:1.5px solid rgba(240,233,220,.4);background:rgba(36,26,18,.55);color:var(--oat);font-size:1.9rem;line-height:1;cursor:pointer;display:grid;place-items:center;transition:background .2s,border-color .2s;padding-bottom:4px}
.lb-nav:hover{background:var(--leaf);border-color:var(--leaf);color:#fff}
.lb-close{position:absolute;top:18px;right:20px;width:44px;height:44px;border-radius:50%;border:1.5px solid rgba(240,233,220,.4);background:rgba(36,26,18,.55);color:var(--oat);font-size:1.7rem;line-height:1;cursor:pointer;display:grid;place-items:center;transition:background .2s,border-color .2s;z-index:2}
.lb-close:hover{background:var(--leather);border-color:var(--leather)}

/* ---- CTA band ---- */
.cta-band{background:var(--pine);color:var(--oat);text-align:center}
.cta-band .wrap{padding:76px 24px}
.cta-band h2{font-size:clamp(1.9rem,3.8vw,2.7rem);font-weight:800;max-width:24ch;margin:0 auto .5em}
.cta-band p{max-width:50ch;margin:0 auto 30px;color:rgba(240,233,220,.85)}

/* ---- contact ---- */
.contact-list{list-style:none;display:flex;flex-direction:column;gap:18px;font-size:1.05rem}
.contact-list li{display:flex;gap:14px;align-items:flex-start}
.contact-list svg{flex:0 0 auto;width:26px;height:26px;stroke:var(--pine);fill:none;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round;margin-top:3px}
.contact-list a{color:var(--leather);font-weight:600;text-decoration:none}
.contact-list a:hover{text-decoration:underline}

/* ---- footer ---- */
footer.site{background:var(--espresso);color:rgba(240,233,220,.75);font-size:.92rem}
.foot{display:flex;justify-content:space-between;gap:32px;flex-wrap:wrap;padding:56px 24px 28px;max-width:1100px;margin:0 auto}
.foot .brandmark{border-color:var(--leaf);color:var(--leaf)}
.foot nav ul{flex-direction:column;gap:6px;display:flex;list-style:none}
.foot nav a{padding:2px 0;border-radius:0;color:rgba(240,233,220,.75);text-decoration:none;font-size:.92rem}
.foot nav a:hover{color:var(--oat)}
.foot-col h4{font-family:"Hepta Slab",serif;color:var(--oat);font-size:.95rem;margin-bottom:12px;letter-spacing:.04em}
.foot-bottom{border-top:1px solid rgba(240,233,220,.12);padding:18px 24px;text-align:center;font-size:.8rem;color:rgba(240,233,220,.45)}

a:focus-visible,button:focus-visible{outline:3px solid var(--leaf);outline-offset:3px;border-radius:6px}

@media (max-width:980px){
  nav.main ul{display:none}
  .nav-toggle{display:block;background:none;border:1.5px solid var(--line);border-radius:10px;padding:8px 12px;font:600 .9rem "Albert Sans",sans-serif;color:var(--espresso);cursor:pointer}
  nav.main.open ul{display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:var(--oat);border-bottom:1px solid var(--line);padding:12px 24px 18px}
  .photo-strip{grid-template-columns:repeat(3,1fr)}
  .gallery-grid{grid-template-columns:repeat(3,1fr)}
  .cards3{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .amenities{grid-template-columns:repeat(2,1fr)}
  .plans,.duo,.split,.cards2{grid-template-columns:1fr}
  .photo-strip{grid-template-columns:repeat(2,1fr)}
  /* when split stacks, put the image first then the text */
  .split .frame{order:-1}
  .split .frame img{max-height:420px}
}
@media (max-width:540px){
  .amenities,.cards3,.photo-strip{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .section{padding:56px 0}
  .section.tight{padding:44px 0}
  .wrap{padding:0 20px}

  /* center hero + section copy on phones */
  .hero .wrap,.hero.photo .wrap{padding:56px 20px 0;text-align:center}
  .hero.photo .wrap{padding:72px 20px 64px}
  .hero.compact .wrap{padding:52px 20px 44px}
  .hero h1,.hero p{margin-left:auto;margin-right:auto;max-width:24ch}
  .hero .eyebrow{justify-content:center}
  .hero-cta{justify-content:center}

  .section-head{margin-left:auto;margin-right:auto;text-align:center}
  .section-head .eyebrow{justify-content:center}

  /* stacked split column reads centered too */
  .split{gap:30px;text-align:center}
  .split .eyebrow{justify-content:center}
  .split .hero-cta{justify-content:center}

  .duo-card,.plan{text-align:left}

  .btn{width:100%;text-align:center}
  .hero-cta .btn,.section-head .btn{width:auto}
  .hero-cta{flex-direction:column;align-items:center;width:100%}
  .hero-cta .btn{width:100%;max-width:320px}

  /* compact lightbox controls so they fit narrow screens */
  .lightbox{padding:16px;gap:4px}
  .lb-nav{width:42px;height:42px;font-size:1.5rem}
  .lb-stage{max-width:calc(100vw - 100px)}
  .lb-stage img{max-height:74vh}
  .lb-close{top:12px;right:14px;width:40px;height:40px}
}
