@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700;800;900&family=Playfair+Display:wght@600;700;800;900&display=swap');

:root{
  --bg:#fff8ec;
  --card:#ffffff;
  --text:#23332d;
  --deep:#163327;
  --sage:#2f6b4f;
  --sage-2:#1f3d2b;
  --mint:#fbf1e3;
  --line:#e8dfd0;

  --gold:#f2c56d;
  --gold-2:#ffd98c;

  --shadow:0 18px 44px rgba(0,0,0,.14);
  --shadow-soft:0 12px 26px rgba(0,0,0,.10);
  --radius-xl:22px;
  --radius-lg:18px;
  --max:1160px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--text);
  background:
    radial-gradient(1200px 760px at 10% -10%, rgba(47,107,79,.16), transparent 55%),
    radial-gradient(1100px 700px at 110% 10%, rgba(243,210,139,.20), transparent 55%),
    linear-gradient(180deg, #fff8ec 0%, #fbf1e3 52%, #ffffff 100%);
  line-height:1.65;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
a:hover{opacity:.98}
.container{width:min(var(--max),calc(100% - 44px));margin:0 auto}
.skip-link{position:absolute;left:-999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{left:16px;top:16px;width:auto;height:auto;padding:10px 12px;background:var(--card);border-radius:12px;border:1px solid rgba(0,0,0,.12);z-index:9999}

.site-header{
  position:sticky;top:0;z-index:1000;
  background:rgba(255,255,255,.92);
  border-bottom:1px solid var(--line);
  backdrop-filter:blur(12px) saturate(150%);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:18px 0;gap:18px}
.brand{display:flex;align-items:center;gap:14px;min-width:0}
.brand-logo{width:72px;height:72px;border-radius:999px;box-shadow:0 12px 26px rgba(0,0,0,.12);border:1px solid rgba(0,0,0,.08)}
.brand-name{font-family:Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;font-weight:700;letter-spacing:-.25px;color:var(--deep);font-size:22px;line-height:1.05}
.brand-tagline{font-size:13px;color:rgba(35,51,45,.72);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.nav{display:flex;align-items:center;gap:14px;position:relative}
.nav-links{display:flex;align-items:center;gap:18px;list-style:none;margin:0;padding:0}
.nav-links a{font-weight:800;color:var(--text);font-size:15px;padding:10px 12px;border-radius:12px}
.nav-links a[aria-current="page"]{background:rgba(230,242,239,.75)}
.nav-links a:hover{background:rgba(230,242,239,.75)}
.nav-cta{display:flex;align-items:center;gap:10px}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:13px 18px;border-radius:999px;border:1px solid var(--line);
  background:#fff;font-weight:800;color:var(--deep);
  box-shadow:0 10px 22px rgba(0,0,0,.06)
}
.btn-sm{padding:10px 14px;font-size:13px;box-shadow:none}
.btn-primary{
  background:linear-gradient(135deg, var(--deep), var(--sage));
  color:#fff;border-color:transparent;
  box-shadow:0 12px 26px rgba(31,61,43,.22)
}
.btn-gold{background:linear-gradient(180deg,var(--gold-2),var(--gold));color:#2b2214;border:1px solid rgba(146,98,17,.22);box-shadow:0 14px 34px rgba(242,197,109,.34)}
.btn-ghost{background:rgba(255,255,255,.80)}

.badge{font-size:12px;font-weight:800;padding:7px 10px;border-radius:999px;background:var(--mint);border:1px solid rgba(215,231,225,.9);color:var(--deep)}
.pill{font-size:12px;font-weight:800;padding:7px 10px;border-radius:999px;background:rgba(243,210,139,.22);border:1px solid rgba(243,210,139,.35);color:var(--deep)}

.nav-toggle{display:none;width:48px;height:48px;border-radius:12px;border:1px solid var(--line);background:#fff}
.burger{width:18px;height:2px;background:var(--deep);position:relative;margin:0 auto;display:block}
.burger:before,.burger:after{content:"";position:absolute;left:0;width:18px;height:2px;background:var(--deep)}
.burger:before{top:-6px}.burger:after{top:6px}

.hero{padding:38px 0 18px}
.hero-shell{position:relative;border-radius:var(--radius-xl);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);background:#fff}
.hero-media{position:absolute;inset:0;z-index:0}
.hero-media img{width:100%;height:100%;object-fit:cover;object-position:center 28%;filter:saturate(1.06) contrast(1.02)}
.hero-scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(90deg, rgba(20,30,24,.78) 0%, rgba(20,30,24,.52) 46%, rgba(20,30,24,.12) 100%)}
.hero-overlay{position:relative;z-index:2;display:grid;grid-template-columns:1.15fr .85fr;gap:28px;align-items:end;padding:46px;min-height:520px}
.hero-title{
  margin:12px 0 10px;
  font-family:"Playfair Display", serif;
  font-size:clamp(32px,3.8vw,54px);
  line-height:1.03;letter-spacing:-.8px;color:#fff
}
.hero-sub{margin:0;max-width:62ch;color:rgba(255,255,255,.92);font-size:16px}
.hero-actions{margin-top:18px;display:flex;flex-wrap:wrap;gap:12px}
.hero-panel{background:rgba(255,255,255,.92);border:1px solid rgba(255,255,255,.26);border-radius:18px;padding:16px;box-shadow:0 16px 34px rgba(0,0,0,.12)}
.hero-panel h3{margin:0 0 8px;color:var(--deep);font-family:"Playfair Display", serif;font-size:18px}
.hero-panel p{margin:0;color:rgba(35,51,45,.82);font-size:13px}
.panel-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}
.panel-grid .btn{width:100%}
.panel-note{margin-top:12px;border-radius:14px;padding:10px 12px;background:rgba(230,242,239,.75);border:1px solid rgba(215,231,225,.9);font-size:12px;color:rgba(35,51,45,.85)}

.section{padding:28px 0}
.section-head{display:flex;justify-content:space-between;align-items:flex-end;gap:14px;flex-wrap:wrap;margin-bottom:14px}
.h1{margin:0;font-size:34px;letter-spacing:-.5px;color:var(--deep);font-family:"Playfair Display", serif}
.h2{margin:0;font-size:24px;letter-spacing:-.3px;color:var(--deep);font-family:"Playfair Display", serif}
.sub{margin:6px 0 0;max-width:82ch;color:rgba(35,51,45,.74);font-size:14px}
.small{font-size:13px;opacity:.82}

.freeflow{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:16px;align-items:stretch}
.card{
  background:rgba(255,255,255,.94);
  border:1px solid var(--line);
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow-soft);
  padding:16px;
  transform:translateY(14px);opacity:0;
  transition:transform .70s ease, opacity .70s ease
}
.card.reveal{transform:translateY(0);opacity:1}
.card h3{margin:0 0 8px;color:var(--sage);font-size:16px;font-weight:900}
.card p{margin:0;color:rgba(35,51,45,.84);font-size:14px}
.meta{margin-top:12px;display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.card.span-4{grid-column:span 4}.card.span-5{grid-column:span 5}.card.span-6{grid-column:span 6}.card.span-7{grid-column:span 7}.card.span-8{grid-column:span 8}

.card.media{padding:0;color:#fff;background:linear-gradient(135deg, rgba(22,51,39,.28), rgba(243,210,139,.18)),url("../img/pasture-wide.jpg");background-size:cover;background-position:center}
.card.media .inner{padding:18px;min-height:240px;display:flex;flex-direction:column;justify-content:flex-end;background:linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,.38))}
.card.media h3,.card.media p{color:#fff}
.card.media .pill{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.18);color:#fff}

.split{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start}
.box{
  background:rgba(255,255,255,.94);
  border:1px solid var(--line);
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow-soft);
  padding:18px;
  transform:translateY(14px);opacity:0;
  transition:transform .70s ease, opacity .70s ease
}
.box.reveal{transform:translateY(0);opacity:1}
.kv{display:grid;gap:10px;margin:0}
.kv div{display:flex;gap:10px;align-items:flex-start}
.kv strong{min-width:140px;color:var(--deep)}
.notice{border-radius:var(--radius-xl);padding:14px;border:1px solid rgba(243,210,139,.55);background:rgba(243,210,139,.16);color:rgba(35,51,45,.88)}
.hr{height:1px;background:var(--line);margin:14px 0}

.about-photo{width:100%;height:100%;object-fit:cover;object-position:center 30%;border-radius:18px;border:1px solid var(--line);display:block}

.stats{display:grid;grid-template-columns:repeat(12,1fr);gap:14px;margin-top:16px}
.stat{grid-column:span 4;border-radius:var(--radius-xl);border:1px solid var(--line);background:rgba(255,255,255,.92);box-shadow:var(--shadow-soft);padding:16px;transform:translateY(14px);opacity:0;transition:transform .70s ease, opacity .70s ease}
.stat.reveal{transform:translateY(0);opacity:1}
.stat .num{font-size:28px;font-weight:950;letter-spacing:-.6px;color:var(--deep);font-family:"Playfair Display", serif}
.stat .lbl{color:rgba(35,51,45,.86);font-weight:800;margin-top:4px}
.stat .hint{color:rgba(35,51,45,.70);font-size:13px;margin-top:6px}

.gallery{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}
.tile{grid-column:span 4;border-radius:var(--radius-xl);overflow:hidden;border:1px solid var(--line);background:rgba(255,255,255,.92);box-shadow:var(--shadow-soft);transform:translateY(14px);opacity:0;transition:transform .70s ease, opacity .70s ease}
.tile.reveal{transform:translateY(0);opacity:1}
.tile img{width:100%;height:240px;object-fit:cover;object-position:center 30%}
.tile .body{padding:14px}
.tile h4{margin:0 0 6px;color:var(--deep);font-family:"Playfair Display", serif}
.tile p{margin:0;color:rgba(35,51,45,.86);font-size:14px}

.form{display:grid;gap:12px}
.field{display:grid;gap:6px}
.field label{font-weight:900;color:var(--deep);font-size:13px}
.field input,.field textarea{padding:12px 12px;border-radius:14px;border:1px solid var(--line);background:#fff;font:inherit}
.field textarea{min-height:120px;resize:vertical}

.site-footer{margin-top:26px;padding:28px 0 18px;background:linear-gradient(180deg,#ffffff,var(--mint));border-top:1px solid var(--line)}
.footer-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:18px}
.footer-title{margin:0 0 10px;color:var(--deep);font-family:"Playfair Display", serif}
.footer-links{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.footer-links a{color:var(--deep);font-weight:800}
.footer-badges{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.stone-line{height:2px;margin:18px 0 12px;background:linear-gradient(90deg,transparent,rgba(217,209,196,.95),rgba(231,225,215,.95),rgba(217,209,196,.95),transparent)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}

.to-top{position:fixed;right:18px;bottom:18px;width:52px;height:52px;border-radius:999px;border:1px solid var(--line);background:rgba(255,255,255,.94);box-shadow:0 18px 34px rgba(0,0,0,.14);cursor:pointer;opacity:0;transform:translateY(10px);transition:opacity .25s ease, transform .25s ease}
.to-top.show{opacity:1;transform:translateY(0)}
.to-top span{font-size:18px;font-weight:950;color:var(--deep)}

@media (max-width:980px){
  .hero-overlay{position:relative;z-index:2;display:grid;grid-template-columns:1.15fr .85fr;gap:28px;align-items:end;padding:46px;min-height:520px}
  .split{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .tile{grid-column:span 6}
  .stat{grid-column:span 6}
  .card.span-8,.card.span-7,.card.span-6,.card.span-5,.card.span-4{grid-column:span 6}
}
@media (max-width:680px){
  .brand-tagline{display:none}
  .nav-toggle{display:inline-flex;align-items:center;justify-content:center}
  .nav-links{
    position:absolute;right:0;top:64px;width:min(360px,calc(100vw - 24px));
    display:none;flex-direction:column;align-items:stretch;gap:10px;padding:14px;
    background:rgba(255,255,255,.98);border:1px solid var(--line);
    border-radius:18px;box-shadow:var(--shadow)
  }
  .nav-links.open{display:flex}
  .nav-cta{display:none}
  .tile{grid-column:span 12}
  .stat{grid-column:span 12}
  .card.span-8,.card.span-7,.card.span-6,.card.span-5,.card.span-4{grid-column:span 12}
  .about-photo{width:100%;height:100%;object-fit:cover;object-position:center 30%;border-radius:18px;border:1px solid var(--line);display:block}
}

}

.section p{line-height:1.75;margin:0 0 14px}

@media (max-width: 960px){.hero-overlay{grid-template-columns:1fr;align-items:start;min-height:520px}}

[class*='span-']{grid-column:span 12}
.span-1{grid-column:span 1}
.span-2{grid-column:span 2}
.span-3{grid-column:span 3}
.span-4{grid-column:span 4}
.span-5{grid-column:span 5}
.span-6{grid-column:span 6}
.span-7{grid-column:span 7}
.span-8{grid-column:span 8}
.span-9{grid-column:span 9}
.span-10{grid-column:span 10}
.span-11{grid-column:span 11}
.span-12{grid-column:span 12}

@media (max-width: 860px){.freeflow{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:16px;align-items:stretch}.span-1,.span-2,.span-3,.span-4,.span-5,.span-6,.span-7,.span-8,.span-9,.span-10,.span-11,.span-12{grid-column:span 1}}

.card{height:100%}
.card.media{min-height:220px}
.card.media .inner{height:100%;display:flex;flex-direction:column;justify-content:space-between}

.card.image-card{padding:0;overflow:hidden;display:flex;flex-direction:column;border-radius:18px}
.card.image-card img{width:100%;height:100%;flex:1;object-fit:cover;display:block;border-radius:18px}

.btn-primary{background:linear-gradient(180deg,var(--gold-2),var(--gold));color:#2b2214;border:1px solid rgba(146,98,17,.22);box-shadow:0 14px 34px rgba(242,197,109,.34)}

.freeflow > *{align-self:stretch}
.card{display:flex;flex-direction:column}

.pair-card{min-height:420px}
@media (max-width: 960px){.pair-card{min-height:unset}}


/* --- Mobile fixes (freeflow cards) --- */
@media (max-width: 680px){
  .freeflow{
    grid-template-columns: 1fr !important;
  }
  .freeflow > *{
    grid-column: 1 / -1 !important;
  }
}
