:root{
  --bg:#f5f2ea;
  --bg-soft:#fbf8f1;
  --text:#163725;
  --text-soft:#4b5c53;
  --primary:#1b4d35;
  --secondary:#8ea63b;
  --gold:#b88a22;
  --line:rgba(22,55,37,.12);
  --shadow:0 20px 50px rgba(12,29,20,.12);
  --radius:22px;
  --radius-sm:16px;
  --container:min(1180px, calc(100% - 40px));
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--text);
  background:linear-gradient(180deg,#f8f5ee 0%, #f2eee4 100%);
  line-height:1.65;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button{font:inherit}
.container{width:var(--container);margin:0 auto}

.site-header{
  position:sticky;
  top:0;
  z-index:40;
  backdrop-filter:blur(14px);
  background:rgba(248,245,238,.78);
  border-bottom:1px solid rgba(22,55,37,.08);
}
.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  min-height:78px;
}
.brand img{height:46px;width:auto}
.menu{
  display:flex;
  align-items:center;
  gap:22px;
  font-size:.96rem;
  color:var(--text-soft);
}
.menu a{
  position:relative;
  padding:8px 0;
}
.menu a::after{
  content:"";
  position:absolute;
  left:0;bottom:0;
  width:100%;height:2px;
  background:var(--gold);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .28s ease;
}
.menu a:hover::after{transform:scaleX(1)}

.hero{
  position:relative;
  min-height:92vh;
  display:grid;
  align-items:end;
  overflow:hidden;
}
.hero-media,
.hero-media img,
.hero-overlay{
  position:absolute;
  inset:0;
}
.hero-media img{
  width:100%;
  height:100%;
  object-fit:cover;
  transform:scale(1.03);
}
.hero-overlay{
  background:
    linear-gradient(180deg, rgba(9,24,17,.18) 0%, rgba(9,24,17,.15) 32%, rgba(9,24,17,.62) 100%),
    linear-gradient(90deg, rgba(9,24,17,.40) 0%, rgba(9,24,17,.18) 48%, rgba(9,24,17,.12) 100%);
}
.hero-content{
  position:relative;
  z-index:1;
  color:#fff;
  padding:140px 0 80px;
  max-width:760px;
}
.eyebrow,
.section-label{
  display:inline-flex;
  align-items:center;
  gap:10px;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-size:.74rem;
  font-weight:700;
}
.eyebrow{color:rgba(255,255,255,.82);margin:0 0 18px}
.section-label{color:var(--secondary);margin-bottom:12px}
.hero h1{
  font-family:Georgia,"Times New Roman",serif;
  font-size:clamp(3.3rem,6vw,6rem);
  line-height:.96;
  margin:0 0 18px;
  letter-spacing:-.02em;
}
.lead{
  font-size:clamp(1.06rem,2vw,1.3rem);
  max-width:680px;
  color:rgba(255,255,255,.9);
  margin:0 0 34px;
}
.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
}
.button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:48px;
  padding:0 20px;
  border-radius:999px;
  transition:transform .2s ease, background .2s ease, border-color .2s ease;
  font-weight:600;
}
.button:hover{transform:translateY(-1px)}
.button-primary{
  background:#fff;
  color:var(--primary);
}
.button-secondary{
  border:1px solid rgba(255,255,255,.35);
  color:#fff;
  background:rgba(255,255,255,.08);
}

.section{padding:96px 0}
.intro{background:var(--bg-soft)}
.grid-two,
.grid-media,
.split-layout{
  display:grid;
  gap:38px;
}
.grid-two{grid-template-columns:1.2fr .8fr;align-items:center}
.grid-media{grid-template-columns:1fr 1fr;align-items:center}
.grid-media.reverse{grid-template-columns:1fr 1fr}
.quote-card{
  padding:36px;
  border-radius:var(--radius);
  background:linear-gradient(180deg, rgba(255,255,255,.8) 0%, rgba(244,240,231,.95) 100%);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
}
.quote-card p{
  margin:0;
  font-family:Georgia,"Times New Roman",serif;
  font-size:1.55rem;
  line-height:1.4;
}
h2{
  font-family:Georgia,"Times New Roman",serif;
  font-size:clamp(2rem,4vw,3.3rem);
  line-height:1.05;
  margin:0 0 20px;
  letter-spacing:-.02em;
}
h3{
  margin:0 0 12px;
  font-size:1.16rem;
}
p{margin:0 0 14px;color:var(--text-soft)}
.stats{padding-top:0}
.stats-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}
.stat-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  padding:26px 24px;
  box-shadow:var(--shadow);
}
.stat-number{
  display:block;
  font-size:1.9rem;
  line-height:1;
  margin-bottom:10px;
  color:var(--primary);
  font-weight:800;
}
.stat-label{color:var(--text-soft)}

.media-frame{
  border-radius:28px;
  overflow:hidden;
  box-shadow:var(--shadow);
  background:#e9e1d2;
}
.media-frame img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.framed{
  padding:14px;
  background:#fff;
  border:1px solid var(--line);
}
.feature-list{
  list-style:none;
  padding:0;
  margin:20px 0 0;
  display:grid;
  gap:12px;
}
.feature-list li{
  position:relative;
  padding-left:22px;
  color:var(--text-soft);
}
.feature-list li::before{
  content:"";
  position:absolute;
  left:0;top:.7em;
  width:10px;height:10px;
  border-radius:999px;
  background:linear-gradient(135deg,var(--secondary),var(--gold));
}

.olive-grid{
  background:linear-gradient(180deg, #fff 0%, #f7f3ea 100%);
}
.cards-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:18px;
  margin-top:28px;
}
.cards-grid.three{grid-template-columns:repeat(3,1fr)}
.info-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  padding:28px;
  box-shadow:var(--shadow);
}
.info-card.soft{
  background:linear-gradient(180deg, rgba(255,255,255,.92) 0%, rgba(248,244,235,.98) 100%);
}

.split-image{
  background:var(--bg-soft);
}
.split-layout{
  grid-template-columns:1.05fr .95fr;
  align-items:center;
}
.image-stack{
  position:relative;
  min-height:620px;
}
.stack-main,
.stack-secondary{
  margin:0;
  border-radius:28px;
  overflow:hidden;
  box-shadow:var(--shadow);
}
.stack-main{
  width:74%;
  background:#ddd1ba;
}
.stack-main img{
  width:100%;height:620px;object-fit:cover;
}
.stack-secondary{
  position:absolute;
  right:0;bottom:42px;
  width:46%;
  border:10px solid rgba(255,255,255,.92);
  background:#fff;
}
.stack-secondary img{
  width:100%;height:260px;object-fit:cover;
}
.text-panel{
  background:#fff;
  border:1px solid var(--line);
  border-radius:28px;
  padding:34px;
  box-shadow:var(--shadow);
}
.mini-facts{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:14px;
  margin-top:24px;
}
.mini-facts div{
  background:linear-gradient(180deg, rgba(245,242,234,.9) 0%, rgba(255,255,255,.98) 100%);
  border:1px solid var(--line);
  border-radius:16px;
  padding:18px 16px;
}
.mini-facts strong{
  display:block;
  font-size:1.05rem;
  color:var(--primary);
  margin-bottom:4px;
}
.mini-facts span{
  color:var(--text-soft);
  font-size:.94rem;
}

.environment .media-frame img{min-height:520px}
.tags{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:22px;
}
.tags span{
  padding:10px 14px;
  border-radius:999px;
  background:#f0eadb;
  color:var(--primary);
  font-size:.9rem;
  border:1px solid rgba(27,77,53,.08);
}

.gallery{
  background:linear-gradient(180deg,#fff 0%, #f8f5ed 100%);
}
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
  margin-top:28px;
}
.gallery-item{
  padding:0;
  border:0;
  background:none;
  border-radius:18px;
  overflow:hidden;
  cursor:pointer;
  box-shadow:var(--shadow);
}
.gallery-item img{
  width:100%;
  height:100%;
  aspect-ratio:1 / .86;
  object-fit:cover;
  transition:transform .45s ease, filter .25s ease;
}
.gallery-item:hover img{
  transform:scale(1.04);
  filter:saturate(1.03);
}
.gallery-item.wide{
  grid-column:span 2;
  grid-row:span 2;
}
.gallery-item.wide img{
  aspect-ratio:1.45 / 1;
}

.closing{
  padding-top:88px;
}
.closing-card{
  display:grid;
  grid-template-columns:280px 1fr;
  gap:26px;
  align-items:center;
  padding:34px;
  background:linear-gradient(135deg, rgba(255,255,255,.95) 0%, rgba(243,239,228,.98) 100%);
  border:1px solid var(--line);
  border-radius:30px;
  box-shadow:var(--shadow);
}
.closing-logo{
  width:100%;
  max-width:240px;
}

.site-footer{
  padding:26px 0 40px;
}
.footer-inner{
  display:flex;
  justify-content:space-between;
  gap:20px;
  padding-top:20px;
  border-top:1px solid var(--line);
}
.footer-inner p{
  margin:0;
  font-size:.95rem;
}

.lightbox{
  position:fixed;
  inset:0;
  background:rgba(5,10,8,.88);
  display:grid;
  place-items:center;
  padding:30px;
  opacity:0;
  visibility:hidden;
  transition:opacity .2s ease, visibility .2s ease;
  z-index:70;
}
.lightbox.is-open{
  opacity:1;
  visibility:visible;
}
.lightbox img{
  max-width:min(1200px, 92vw);
  max-height:88vh;
  border-radius:20px;
  box-shadow:0 30px 80px rgba(0,0,0,.45);
}
.lightbox-close{
  position:absolute;
  top:24px;right:24px;
  width:48px;height:48px;
  border-radius:999px;
  border:0;
  background:rgba(255,255,255,.12);
  color:#fff;
  font-size:2rem;
  line-height:1;
  cursor:pointer;
}

@media (max-width: 1080px){
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .grid-two,.grid-media,.split-layout,.closing-card{grid-template-columns:1fr}
  .cards-grid.three{grid-template-columns:1fr}
  .image-stack{min-height:unset}
  .stack-main{width:100%}
  .stack-main img{height:520px}
  .stack-secondary{
    position:relative;
    width:62%;
    margin-top:-70px;
    margin-left:auto;
    bottom:auto;right:auto;
  }
}
@media (max-width: 820px){
  .menu{display:none}
  .section{padding:80px 0}
  .cards-grid,.gallery-grid,.mini-facts{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr}
  .gallery-item.wide{grid-column:auto;grid-row:auto}
  .stack-main img{height:420px}
  .stack-secondary{width:72%;margin-top:-54px}
  .closing-logo{max-width:220px}
  .footer-inner{flex-direction:column}
}
@media (max-width: 560px){
  .hero-content{padding-top:120px;padding-bottom:60px}
  .brand img{height:38px}
  .stack-secondary{width:82%}
  .text-panel,.quote-card,.info-card,.closing-card{padding:24px}
}
