/* ============================================================
   SOLARIS FARM — Home Page
   Aesthetic: refined equestrian luxury / editorial
   ============================================================ */

:root{
  --green:        #05573B;
  --green-700:    #044a32;
  --green-900:    #033423;
  --green-950:    #022318;
  --gold:         #c0a062;
  --cream:        #f6f2e9;
  --sage:         #ecefe8;
  --paper:        #fbfaf5;
  --ink:          #25271f;
  --muted:        #6f7268;
  --line:         #d9d5c8;
  --white-90:     rgba(255,255,255,.9);

  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans:  'Jost', system-ui, sans-serif;

  --ease: cubic-bezier(.22,.61,.36,1);
}

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

/* ---------- Shared type ---------- */
.eyebrow{
  font-family:var(--sans);
  font-size:.7rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--green);
  font-weight:500;
  display:inline-flex;
  align-items:center;
  gap:.85em;
}
.eyebrow::before{
  content:"";
  width:34px; height:1px;
  background:var(--gold);
}
.eyebrow.center::after{
  content:"";
  width:34px; height:1px;
  background:var(--gold);
}
.eyebrow.center{ justify-content:center; }

h1,h2,h3,h4{ font-family:var(--serif); font-weight:600; line-height:1.08; letter-spacing:.01em; }
.section-title{
  font-size:clamp(2rem,4.4vw,3.4rem);
  color:var(--green-900);
  font-weight:600;
}
p{ color:var(--muted); }

.wrap{ width:min(1180px,92vw); margin-inline:auto; }
section{ position:relative; }

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--green); --fg:#fff; --bd:var(--green);
  display:inline-flex; align-items:center; gap:.6em;
  font-family:var(--sans); font-size:.74rem; font-weight:500;
  letter-spacing:.18em; text-transform:uppercase;
  padding:.95em 1.8em;
  background:var(--bg); color:var(--fg);
  border:1px solid var(--bd);
  cursor:pointer; position:relative; overflow:hidden; isolation:isolate;
  transition:color .4s var(--ease), border-color .4s var(--ease);
}
.btn::after{
  content:""; position:absolute; inset:0; z-index:-1;
  background:var(--green-900);
  transform:scaleX(0); transform-origin:left;
  transition:transform .45s var(--ease);
}
.btn:hover::after{ transform:scaleX(1); }
.btn.ghost{ --bg:transparent; --fg:#fff; --bd:rgba(255,255,255,.55); }
.btn.ghost::after{ background:#fff; }
.btn.ghost:hover{ color:var(--green-900); }
.btn.light{ --bg:var(--cream); --fg:var(--green-900); --bd:var(--cream); }
.btn.light::after{ background:var(--green); }
.btn.light:hover{ color:#fff; border-color:var(--green); }
.btn .arr{ transition:transform .35s var(--ease); }
.btn:hover .arr{ transform:translateX(4px); }

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:100;
  padding:1.4rem 0;
  transition:background .5s var(--ease), padding .5s var(--ease), box-shadow .5s var(--ease);
}
.site-header.scrolled{
  background:var(--green);
  padding:.7rem 0;
  box-shadow:0 8px 30px rgba(0,0,0,.18);
}
.nav{ display:flex; align-items:center; justify-content:space-between; }
.brand{ display:flex; align-items:center; gap:.7rem; color:#fff; }
.brand-logo{ height:54px; width:auto; transition:height .5s var(--ease); }
.site-header.scrolled .brand-logo{ height:42px; }
.brand svg{ width:30px; height:30px; }
.brand-text{ line-height:1; }
.brand-text .b1{ font-family:var(--serif); font-size:1.4rem; font-weight:600; letter-spacing:.08em; }
.brand-text .b2{ font-family:var(--serif); font-style:italic; font-size:1rem; letter-spacing:.02em; margin-top:-2px; opacity:.92; }

.nav-links{ display:flex; gap:1.35rem; list-style:none; }
.nav-links a{
  color:rgba(255,255,255,.9); font-size:.72rem; letter-spacing:.14em;
  text-transform:uppercase; font-weight:400; position:relative; padding:.2rem 0;
}
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:-2px; height:1px; width:0;
  background:var(--gold); transition:width .35s var(--ease);
}
.nav-links a:hover{ color:#fff; }
.nav-links a:hover::after{ width:100%; }

.nav-cta{
  border:1px solid rgba(255,255,255,.6); color:#fff;
  font-size:.7rem; letter-spacing:.18em; text-transform:uppercase;
  padding:.7em 1.4em; transition:background .35s var(--ease), color .35s var(--ease);
}
.nav-cta:hover{ background:#fff; color:var(--green-900); }

.menu-toggle{ display:none; background:none; border:none; cursor:pointer; flex-direction:column; gap:5px; }
.menu-toggle span{ width:26px; height:2px; background:#fff; transition:.3s; }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  min-height:100vh; min-height:100svh; display:grid; place-items:center;
  text-align:center; color:#fff; position:relative; isolation:isolate;
  padding:7rem 1.2rem 5rem;
}
.hero .hero-bg{
  position:absolute; inset:0; z-index:-2;
  background-size:cover; background-position:center 60%;
  animation:heroZoom 18s ease-out forwards;
}
@keyframes heroZoom{ from{ transform:scale(1.08); } to{ transform:scale(1); } }
.hero::after{ /* readability scrim */
  content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(180deg,rgba(8,28,18,.35),rgba(8,28,18,.15) 45%,rgba(8,28,18,.55));
}
.hero-inner{ max-width:760px; }
.hero .sup{
  font-family:var(--serif); font-style:italic; font-size:clamp(1.1rem,2.4vw,1.6rem);
  letter-spacing:.04em; margin-bottom:.6rem; color:rgba(255,255,255,.92);
}
.hero h1{
  font-size:clamp(3rem,9vw,6.6rem); font-weight:600; letter-spacing:.08em;
  text-transform:uppercase; line-height:.98; margin-bottom:2rem;
  text-shadow:0 4px 30px rgba(0,0,0,.3);
}
.hero-btns{ display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }
.scroll-hint{
  position:absolute; bottom:2rem; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:.4rem;
  font-size:.62rem; letter-spacing:.3em; text-transform:uppercase; opacity:.8;
}
.scroll-hint .mouse{ width:1px; height:34px; background:rgba(255,255,255,.6); position:relative; overflow:hidden; }
.scroll-hint .mouse::after{
  content:""; position:absolute; top:0; left:0; width:100%; height:40%;
  background:#fff; animation:scrolldot 2s var(--ease) infinite;
}
@keyframes scrolldot{ 0%{transform:translateY(-100%)} 60%,100%{transform:translateY(260%)} }

/* hero load animation */
.hero .reveal-up{ opacity:0; transform:translateY(26px); animation:heroUp 1s var(--ease) forwards; }
.hero .sup{ animation-delay:.2s; }
.hero h1{ animation-delay:.4s; }
.hero-btns{ animation-delay:.7s; }
.scroll-hint{ animation-delay:1s; }
@keyframes heroUp{ to{ opacity:1; transform:none; } }

/* ============================================================
   LEGACY
   ============================================================ */
.legacy{ background:var(--cream); padding:7rem 0 6rem; text-align:center; overflow:hidden; }
.legacy .starburst{
  position:absolute; top:5%; left:-40px; width:230px; height:230px; opacity:.06; z-index:0;
  color:var(--green); animation:spin 90s linear infinite;
}
@keyframes spin{ to{ transform:rotate(360deg); } }
.legacy .wrap{ position:relative; z-index:1; max-width:760px; }
.legacy .divider{ width:60px; height:1px; background:var(--line); margin:0 auto 1.4rem; }
.legacy .eyebrow{ margin-bottom:1.2rem; }
.legacy h2{ font-size:clamp(1.9rem,4vw,2.9rem); color:var(--green-900); margin-bottom:1.6rem; }
.legacy p{ font-size:1.02rem; max-width:620px; margin:0 auto 1rem; }
.legacy .horse-mark{ width:104px; height:auto; margin:2.6rem auto 0; }

/* ============================================================
   TRAINING
   ============================================================ */
.training{ background:var(--paper); padding:6rem 0; }
.training .grid{ display:grid; grid-template-columns:1fr 1fr; gap:4.5rem; align-items:center; }
.training-media{ position:relative; }
.training-media .ph{ aspect-ratio:4/5; }
.training-photo{ width:100%; height:auto; display:block; box-shadow:0 30px 60px -28px rgba(3,52,35,.45); }
.quote-card{
  position:absolute; right:-30px; bottom:-40px; width:62%;
  background:var(--green); color:#fff; padding:2rem 1.8rem;
  box-shadow:0 30px 60px -20px rgba(3,52,35,.5);
}
.quote-card p{ font-family:var(--serif); font-style:italic; font-size:1.15rem; color:#fff; line-height:1.4; }
.quote-card .who{ font-family:var(--sans); font-style:normal; font-size:.66rem; letter-spacing:.22em; text-transform:uppercase; color:rgba(255,255,255,.7); margin-top:1rem; display:block; }

.training-body .eyebrow{ margin-bottom:1.1rem; }
.training-body h2{ font-size:clamp(1.8rem,3.6vw,2.7rem); color:var(--green-900); margin-bottom:1.4rem; }
.training-body p{ margin-bottom:1rem; font-size:.97rem; }
.features{ display:grid; grid-template-columns:1fr 1fr; gap:1.6rem; margin:2rem 0; }
.feature .ico{ width:34px; height:34px; object-fit:contain; color:var(--green); margin-bottom:.7rem; }
.feature h4{ font-family:var(--sans); font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--green-900); margin-bottom:.5rem; font-weight:600; }
.feature p{ font-size:.86rem; margin:0; }

/* ============================================================
   HORSES FOR SALE
   ============================================================ */
.horses{ background:var(--sage); padding:6rem 0; }
.horses-head{ display:flex; justify-content:space-between; align-items:flex-end; gap:2rem; margin-bottom:3rem; flex-wrap:wrap; }
.horses-head .eyebrow{ margin-bottom:.9rem; }
.horses-head h2{ margin-bottom:.5rem; }
.horses-head .sub{ font-size:.92rem; }
.carousel-nav{ display:flex; gap:.7rem; }
.cbtn{
  width:44px; height:44px; border-radius:50%; border:1px solid var(--line);
  background:transparent; color:var(--green); cursor:pointer; display:grid; place-items:center;
  transition:.35s var(--ease);
}
.cbtn:hover{ background:var(--green); color:#fff; border-color:var(--green); }

.horse-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.6rem; }
.horse-card{
  background:var(--paper); border:1px solid var(--line);
  transition:transform .5s var(--ease), box-shadow .5s var(--ease);
}
.horse-card:hover{ transform:translateY(-8px); box-shadow:0 30px 50px -24px rgba(3,52,35,.35); }
.horse-card .media{ position:relative; }
.horse-card .media .ph{ aspect-ratio:5/4; border:none; }
.badge{
  position:absolute; top:.8rem; right:.8rem;
  background:var(--green); color:#fff; font-size:.58rem; letter-spacing:.18em;
  text-transform:uppercase; padding:.4em .9em; font-weight:500;
}
.horse-card .body{ padding:1.4rem 1.4rem 1.6rem; }
.horse-card h3{ font-family:var(--serif); font-size:1.45rem; letter-spacing:.06em; text-transform:uppercase; color:var(--green-900); }
.horse-card .lineage{ font-family:var(--serif); font-style:italic; font-size:.92rem; color:var(--green); margin:.3rem 0 .8rem; }
.horse-card .desc{ font-size:.84rem; margin-bottom:1.2rem; }
.horse-card .inquire{
  display:block; text-align:center; border:1px solid var(--green); color:var(--green);
  font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; padding:.8em; font-weight:500;
  transition:.35s var(--ease);
}
.horse-card .inquire:hover{ background:var(--green); color:#fff; }

/* ============================================================
   VISIT
   ============================================================ */
.visit{ background:var(--cream); padding:6.5rem 0; }
.visit .grid{ display:grid; grid-template-columns:1fr 1.1fr; gap:4rem; align-items:center; }
.visit .eyebrow{ margin-bottom:1.2rem; }
.visit h2{ font-size:clamp(2rem,4.4vw,3.2rem); color:var(--green-900); margin-bottom:1.4rem; }
.visit h2 em{ font-style:normal; color:var(--green); }
.visit p{ font-size:.97rem; margin-bottom:1.8rem; max-width:440px; }
.visit-media{ position:relative; }
.visit-media .vimg{ display:block; width:100%; height:auto; }   /* scale proportionally, no cropping */
.visit-media .m1{ width:66%; position:relative; z-index:2; box-shadow:20px 20px 50px -22px rgba(3,52,35,.45); }
.visit-media .m2{ width:58%; margin:-20% 0 0 auto; position:relative; z-index:1; box-shadow:-20px 20px 50px -20px rgba(3,52,35,.4); }

/* ============================================================
   GALLERY
   ============================================================ */
.gallery{ background:var(--cream); padding:2rem 0 6rem; text-align:center; }
.gallery h2{ font-size:clamp(1.9rem,4.4vw,3rem); color:var(--green-900); text-transform:uppercase; letter-spacing:.04em; margin-bottom:2.6rem; }
.gallery-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; }
.gallery-grid .ph{ aspect-ratio:1/1; border:none; transition:transform .6s var(--ease); }
.gallery-grid .gimg{ width:100%; aspect-ratio:1/1; object-fit:cover; display:block; transition:transform .6s var(--ease); }
.gallery-grid .cell{ overflow:hidden; }
.gallery-grid .cell:hover .ph, .gallery-grid .cell:hover .gimg{ transform:scale(1.06); }
.gallery-view{
  background:var(--green); color:#fff; display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:1rem; aspect-ratio:1/1;
  font-size:.7rem; letter-spacing:.22em; text-transform:uppercase;
  transition:background .4s var(--ease);
}
.gallery-view:hover{ background:var(--green-900); }
.gallery-view svg{ width:26px; height:26px; }

/* ============================================================
   SOCIAL
   ============================================================ */
.social{ background:var(--cream); padding:4rem 0; text-align:center; }
.social h3{ font-family:var(--serif); font-size:clamp(1.3rem,2.6vw,1.8rem); color:var(--green-900); letter-spacing:.03em; margin-bottom:1.6rem; }
.social-links{ display:flex; justify-content:center; gap:3rem; }
.social-links a{ display:flex; flex-direction:column; align-items:center; gap:.5rem; color:var(--green); }
.social-links .ic{ width:44px; height:44px; border-radius:50%; background:var(--green); color:#fff; display:grid; place-items:center; transition:transform .35s var(--ease); }
.social-links a:hover .ic{ transform:translateY(-5px); }
.social-links span{ font-size:.62rem; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); }
.social-links svg{ width:20px; height:20px; }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:var(--green-900); color:rgba(255,255,255,.8); padding:5rem 0 0; }
.footer .grid{ display:grid; grid-template-columns:1.2fr 1fr; gap:5rem; }
.footer h4{ font-family:var(--serif); font-size:1.7rem; color:#fff; letter-spacing:.04em; margin-bottom:.4rem; }
.footer .form-intro{ font-size:.86rem; margin-bottom:1.6rem; max-width:420px; }
.contact-form{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.contact-form .full{ grid-column:1/-1; }
.contact-form input, .contact-form textarea{
  width:100%; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.14);
  color:#fff; padding:.85em 1em; font-family:var(--sans); font-size:.85rem;
  transition:border-color .3s var(--ease), background .3s var(--ease);
}
.contact-form input::placeholder, .contact-form textarea::placeholder{ color:rgba(255,255,255,.45); letter-spacing:.05em; }
.contact-form input:focus, .contact-form textarea:focus{ outline:none; border-color:#fff; background:rgba(255,255,255,.1); }
.contact-form textarea{ min-height:120px; resize:vertical; }
.contact-form .btn{ grid-column:1/-1; justify-self:start; --bg:#fff; --bd:#fff; --fg:var(--green-900); }
.contact-form .btn::after{ background:var(--green); }
.contact-form .btn:hover{ color:#fff; }

.foot-brand{ display:flex; align-items:center; gap:.7rem; color:#fff; margin-bottom:1rem; }
.foot-logo{ height:60px; width:auto; }
.foot-brand svg{ width:28px; height:28px; }
.foot-brand .b1{ font-family:var(--serif); font-size:1.3rem; letter-spacing:.08em; }
.foot-brand .b2{ font-family:var(--serif); font-style:italic; font-size:.9rem; }
.foot-tag{ font-size:.85rem; max-width:330px; margin-bottom:1.4rem; }
.foot-social{ display:flex; gap:1rem; margin-bottom:2rem; }
.foot-social a{ width:34px; height:34px; border:1px solid rgba(255,255,255,.22); border-radius:50%; display:grid; place-items:center; color:rgba(255,255,255,.7); transition:.3s var(--ease); }
.foot-social a:hover{ background:#fff; border-color:#fff; color:var(--green-900); }
.foot-social svg{ width:15px; height:15px; }

.foot-cols{ display:grid; grid-template-columns:1fr 1fr; gap:2rem; }
.foot-cols h5{ font-family:var(--sans); font-size:.68rem; letter-spacing:.22em; text-transform:uppercase; color:#fff; margin-bottom:1rem; font-weight:500; }
.foot-cols ul{ list-style:none; display:grid; gap:.5rem; }
.foot-cols li{ font-size:.85rem; }
.foot-cols a:hover{ color:#fff; }
.foot-cols .row{ display:flex; gap:.6rem; align-items:flex-start; font-size:.82rem; }
.foot-cols .row svg{ width:15px; height:15px; margin-top:3px; color:#fff; flex-shrink:0; }

.foot-bottom{ border-top:1px solid rgba(255,255,255,.1); margin-top:3.5rem; padding:1.4rem 0; }
.foot-bottom .wrap{ display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; }
.foot-bottom, .foot-bottom a{ font-size:.72rem; letter-spacing:.06em; color:rgba(255,255,255,.5); }
.foot-bottom .legal{ display:flex; gap:1.6rem; }

/* ============================================================
   IMAGE PLACEHOLDERS
   ============================================================ */
.ph{
  position:relative; background:
    repeating-linear-gradient(45deg, rgba(5,87,59,.04) 0 12px, rgba(5,87,59,.07) 12px 24px),
    var(--sage);
  border:1px dashed rgba(5,87,59,.3);
  display:grid; place-items:center; color:var(--green); width:100%; min-height:80px;
}
.ph span{
  font-family:var(--sans); font-size:.6rem; letter-spacing:.2em; text-transform:uppercase;
  color:rgba(5,87,59,.55); text-align:center; padding:.5rem; pointer-events:none;
}
.ph::before{
  content:""; width:30px; height:30px; margin-bottom:.4rem;
  background:var(--green); opacity:.18;
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M21 19V5a2 2 0 0 0-2-2H5a2 2 0 0 0-2 2v14a2 2 0 0 0 2 2h14a2 2 0 0 0 2-2M8.5 13.5l2.5 3l3.5-4.5l4.5 6H5z'/%3E%3C/svg%3E") center/contain no-repeat;
          mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M21 19V5a2 2 0 0 0-2-2H5a2 2 0 0 0-2 2v14a2 2 0 0 0 2 2h14a2 2 0 0 0 2-2M8.5 13.5l2.5 3l3.5-4.5l4.5 6H5z'/%3E%3C/svg%3E") center/contain no-repeat;
}
.ph.tall span, .hero .ph span{ font-size:.7rem; }
.hero .ph{ background:linear-gradient(135deg,#16412f,#0c2a1e); }
.hero .ph::before{ background:#fff; opacity:.25; }
.hero .ph span{ color:rgba(255,255,255,.5); }

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.reveal{ opacity:0; transform:translateY(34px); transition:opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.1s; }
.reveal.d2{ transition-delay:.2s; }
.reveal.d3{ transition-delay:.3s; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1080px){
  .nav-links, .nav-cta{ display:none; }
  .menu-toggle{ display:flex; }
  .nav-links.open{
    display:flex; position:absolute; top:100%; left:0; right:0;
    flex-direction:column; gap:0; background:var(--green-900); padding:1rem 6vw 1.5rem;
  }
  .nav-links.open li{ padding:.7rem 0; border-bottom:1px solid rgba(255,255,255,.1); }
  .nav-links.open a{ font-size:.82rem; }
}
@media(max-width:980px){
  .hero{ min-height:70svh; }
  .training .grid, .visit .grid, .footer .grid{ grid-template-columns:1fr; gap:3rem; }
  .training-media, .visit-media{ max-width:460px; margin-inline:auto; }
  .quote-card{ position:static; width:auto; margin-top:-1px; }
  .training-media .ph{ aspect-ratio:16/10; }
  .horse-grid{ grid-template-columns:repeat(2,1fr); }
  .gallery-grid{ grid-template-columns:repeat(2,1fr); }
  .legacy{ padding:4.5rem 0; }
  .training, .horses, .visit, .philosophy, .trainer{ padding:4.5rem 0; }
  .team{ padding:4.5rem 0; }
  .footer{ padding:3.5rem 0 0; }
  /* Mobile footer: drop redundant Explore menu (hamburger covers it) + center everything */
  .foot-cols{ grid-template-columns:1fr; }
  .foot-cols > div:last-child{ display:none; }
  .footer .grid{ text-align:center; }
  .footer .form-intro{ margin-inline:auto; }
  .contact-form{ justify-items:center; }
  .contact-form .btn{ justify-self:center; }
  .foot-brand{ justify-content:center; }
  .foot-logo{ margin-inline:auto; }
  .foot-tag{ margin-inline:auto; }
  .foot-social{ justify-content:center; }
  .foot-cols h5, .foot-cols ul{ text-align:center; }
  .foot-cols .row{ justify-content:center; }
  .foot-bottom .wrap{ justify-content:center; text-align:center; }
}
@media(max-width:680px){
  .hero{ min-height:62svh; padding-top:6.5rem; padding-bottom:4rem; }
  .training-media, .visit-media{ max-width:75%; }
  .features{ grid-template-columns:1fr; }
  .gallery-grid{ grid-template-columns:1fr 1fr; }
  .team-grid{ grid-template-columns:1fr; gap:2.5rem; }
  .contact-form{ grid-template-columns:1fr; }
  .social-links{ gap:1.8rem; }
}
@media(max-width:560px){
  .hero{ padding:6rem 1.1rem 4rem; }
  .visit-media .m1, .visit-media .m2{ width:100%; margin:0; }
  .visit-media .m2{ margin-top:1rem; }
  .foot-bottom .wrap{ flex-direction:column; gap:.5rem; align-items:center; }
}
/* ============================================================
   ABOUT PAGE
   ============================================================ */
/* Hero — green heritage wash */
.hero.about::after{
  background:linear-gradient(180deg, rgba(5,87,59,.45), rgba(5,87,59,.30) 45%, rgba(3,52,35,.7));
}
.hero.about .hero-inner{ max-width:840px; }
.hero.about h1{ font-size:clamp(2.6rem,7vw,5.4rem); margin-bottom:1.4rem; }
.hero-sub{
  font-size:clamp(.95rem,1.6vw,1.12rem); line-height:1.7; color:rgba(255,255,255,.92);
  max-width:600px; margin:0 auto 2rem;
}

/* Philosophy */
.philosophy{ background:var(--sage); padding:6.5rem 0; }
.philosophy .grid{ display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; }
.philosophy .eyebrow{ margin-bottom:1.2rem; }
.philosophy h2{ font-size:clamp(1.9rem,3.8vw,2.8rem); color:var(--green-900); line-height:1.1; margin-bottom:1.6rem; }
.philosophy h2 em{ color:var(--green); font-style:italic; }
.philosophy p{ font-size:.98rem; margin-bottom:1rem; max-width:460px; }

/* Tilted framed photo */
.framed{ position:relative; }
.framed::before{
  content:""; position:absolute; inset:-18px -12px -22px 14px; z-index:0;
  background:radial-gradient(ellipse at center, rgba(5,87,59,.30), transparent 70%);
  filter:blur(8px);
}
.framed img, .framed .ph{
  position:relative; z-index:1; width:100%; display:block;
  border:10px solid #fff; box-shadow:0 34px 70px -28px rgba(3,52,35,.55);
  transform:rotate(2.2deg); transition:transform .6s var(--ease);
}
.framed:hover img, .framed:hover .ph{ transform:rotate(0deg); }
.framed.left img, .framed.left .ph{ transform:rotate(-2deg); border-width:8px; }
.framed.left:hover img, .framed.left:hover .ph{ transform:rotate(0deg); }
.framed .ph{ aspect-ratio:4/5; }

/* Head Trainer & Owner */
.trainer{ background:var(--paper); padding:6.5rem 0; }
.trainer .grid{ display:grid; grid-template-columns:minmax(0,300px) 1fr; gap:4.5rem; align-items:center; }
.trainer .framed{ max-width:300px; }
.eyebrow.mark{ display:flex; align-items:center; gap:.7em; }
.eyebrow.mark::before{ display:none; }
.eyebrow.mark svg{ width:22px; height:22px; color:var(--gold); }
.trainer h2{ font-size:clamp(2rem,4vw,2.9rem); color:var(--green); margin:.8rem 0 1.4rem; }
.trainer .bio p{ font-size:.94rem; margin-bottom:.9rem; }

/* ============================================================
   TEAM
   ============================================================ */
.team{ background:var(--green); color:#fff; padding:5.5rem 0; }
.team-grid{ display:grid; grid-template-columns:repeat(2,minmax(0,380px)); justify-content:center; gap:3.5rem; text-align:center; }
.team-card .avatar{
  width:160px; height:160px; border-radius:50%; margin:0 auto 1.4rem; overflow:hidden;
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.18);
  display:grid; place-items:center; color:rgba(255,255,255,.4);
  transition:transform .5s var(--ease), background .5s var(--ease);
}
.team-card:hover .avatar{ transform:translateY(-6px); background:rgba(255,255,255,.13); }
.team-card .avatar svg{ width:46px; height:46px; }
.team-card .avatar img{ width:100%; height:100%; object-fit:cover; }
.team-card h3{ font-family:var(--serif); font-size:1.5rem; letter-spacing:.05em; }
.team-card p{ color:rgba(255,255,255,.74); font-size:.86rem; line-height:1.6; letter-spacing:.01em; margin:.6rem auto 0; max-width:340px; }

@media(max-width:980px){
  .philosophy .grid, .trainer .grid{ grid-template-columns:1fr; gap:3rem; }
  .framed img, .framed .ph, .framed.left img, .framed.left .ph{ transform:none; }
  .trainer .framed{ margin:0 auto; }
  .philosophy .framed{ max-width:460px; margin:0 auto; }
}
@media(max-width:680px){
  .team-grid{ grid-template-columns:1fr; gap:2.5rem; }
  .philosophy .framed{ max-width:75%; }
}

/* ============================================================
   TRAINING PAGE
   ============================================================ */
/* Hero */
.hero.training::after{
  background:linear-gradient(180deg, rgba(8,28,18,.34), rgba(8,28,18,.2) 45%, rgba(3,52,35,.55));
}
.hero .kicker{
  font-family:var(--sans); font-size:.7rem; letter-spacing:.34em; text-transform:uppercase;
  color:rgba(255,255,255,.85); margin-bottom:1.1rem;
}
.hero.training h1{
  font-family:var(--serif); font-style:italic; font-weight:500; text-transform:none;
  letter-spacing:.01em; font-size:clamp(2.4rem,6.4vw,4.8rem); margin-bottom:1.3rem;
}

/* Philosophy + value cards */
.tphilo{ background:var(--paper); padding:6.5rem 0; }
.tphilo-head{ display:grid; grid-template-columns:.8fr 1.2fr; gap:4rem; align-items:start; margin-bottom:3.6rem; }
.tphilo-head h2{ font-family:var(--serif); font-style:italic; font-size:clamp(1.8rem,3.6vw,2.7rem); color:var(--green); }
.tphilo-head h2::after{ content:""; display:block; width:54px; height:2px; background:var(--green); margin-top:1.1rem; }
.tphilo-head p{ font-size:.97rem; margin-bottom:1rem; }
.value-cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.6rem; }
.value-card{ background:#fff; border:1px solid var(--line); padding:2.2rem 1.9rem; }
.value-card .vico{ width:54px; height:54px; border-radius:50%; background:var(--sage); display:grid; place-items:center; color:var(--green); margin-bottom:1.3rem; }
.value-card .vico svg{ width:24px; height:24px; }
.value-card .vico img{ width:26px; height:26px; object-fit:contain; }
.value-card h3{ font-family:var(--serif); font-size:1.4rem; color:var(--green-900); margin-bottom:.7rem; letter-spacing:.02em; }
.value-card p{ font-size:.86rem; line-height:1.6; }

/* Programs */
.programs{ background:var(--paper); padding:1rem 0 6.5rem; text-align:center; }
.programs .eyebrow{ margin-bottom:1rem; }
.programs h2{ font-family:var(--serif); font-style:italic; font-size:clamp(2rem,4.2vw,3rem); color:var(--green); margin-bottom:1.6rem; }
.programs .intro{ max-width:780px; margin:0 auto 3.2rem; }
.programs .intro p{ font-size:.97rem; margin-bottom:1rem; }
.program-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.8rem; text-align:left; }
.program-card{ background:#fff; border:1px solid rgba(5,87,59,.4); display:flex; flex-direction:column; }
.program-card .media img, .program-card .media .ph{ width:100%; aspect-ratio:4/3; object-fit:cover; object-position:center top; display:block; border:none; }
.program-card .pc-body{ padding:1.8rem 1.7rem 2rem; }
.program-card .eyebrow{ font-size:.6rem; letter-spacing:.2em; margin-bottom:.9rem; }
.program-card h3{ font-family:var(--serif); font-size:1.5rem; color:var(--green); margin-bottom:.9rem; letter-spacing:.02em; }
.program-card p{ font-size:.86rem; line-height:1.65; }

/* Facilities */
.facilities{ background:var(--sage); padding:6.5rem 0; }
.facilities .grid{ display:grid; grid-template-columns:1fr 1.05fr; gap:4.5rem; align-items:center; }
.facilities h2{ font-family:var(--serif); font-style:italic; font-size:clamp(1.9rem,3.8vw,2.7rem); color:var(--green); margin-bottom:1.4rem; }
.facilities p{ font-size:.96rem; margin-bottom:1rem; }
.facility-list{ list-style:none; margin:1.7rem 0 2rem; display:grid; gap:.9rem; }
.facility-list li{ display:flex; align-items:flex-start; gap:.7rem; font-size:.92rem; color:var(--ink); }
.facility-list svg{ width:19px; height:19px; color:var(--green); flex-shrink:0; margin-top:2px; }
.facility-media{ position:relative; }
.facility-media .fimg{ display:block; width:100%; height:auto; }
.facility-media .f1{ width:62%; position:relative; z-index:2; box-shadow:20px 20px 50px -22px rgba(3,52,35,.45); }
.facility-media .f2{ width:56%; margin:-24% 0 0 auto; position:relative; z-index:1; box-shadow:-18px 18px 46px -20px rgba(3,52,35,.4); }

/* CTA band */
.cta-band{ background:var(--green); color:#fff; text-align:center; padding:5.5rem 0 4.5rem; }
.cta-band h2{ font-family:var(--serif); font-style:italic; font-size:clamp(2rem,4.4vw,3rem); color:#fff; margin-bottom:1.2rem; }
.cta-band p{ color:rgba(255,255,255,.85); max-width:580px; margin:0 auto 2rem; font-size:.98rem; }

/* Training page responsive */
@media(max-width:980px){
  .tphilo-head, .facilities .grid{ grid-template-columns:1fr; gap:3rem; }
  .program-grid{ grid-template-columns:1fr; max-width:460px; margin-inline:auto; }
  .facility-media{ max-width:460px; margin-inline:auto; }
}
@media(max-width:680px){
  .value-cards{ grid-template-columns:1fr; }
  .horse-grid{ grid-template-columns:1fr; max-width:380px; margin-inline:auto; }
  .horse-grid.list .horse-card{ flex-direction:column; }
  .horse-grid.list .horse-card .media{ width:100%; max-width:none; }
  .horse-grid.list .horse-card .media img{ aspect-ratio:5/4; }
  .sold-head{ flex-direction:column; align-items:center; text-align:center; }
  .program-grid{ max-width:380px; }
  .program-card .media img, .program-card .media .ph{ aspect-ratio:16/10; }
  .facility-media{ max-width:300px; }
}


/* ============================================================
   HORSES SOLD PAGE
   ============================================================ */
.hero.sales::after{ background:linear-gradient(180deg, rgba(5,87,59,.6), rgba(3,52,35,.72)); }
.hero.sales .hero-bg{ background-position:center 25%; }
.hero.sales h1{ font-size:clamp(2.6rem,7vw,5.4rem); margin-bottom:1.2rem; }
.scroll-chevron{ position:absolute; bottom:2rem; left:50%; transform:translateX(-50%); color:#fff; opacity:.85; animation:bob 2.2s var(--ease) infinite; }
.scroll-chevron svg{ width:28px; height:28px; }
@keyframes bob{ 0%,100%{ transform:translate(-50%,0); } 50%{ transform:translate(-50%,9px); } }

.sales-intro{ background:var(--paper); padding:5.5rem 0; text-align:center; }
.sales-intro .eyebrow{ justify-content:center; }
.sales-intro .rule{ width:60px; height:2px; background:var(--green); margin:1.1rem auto 1.8rem; }
.sales-intro p{ max-width:780px; margin:0 auto .9rem; font-size:.99rem; }

.sold{ background:var(--paper); padding:1rem 0 6rem; }
.sold-head{ display:flex; justify-content:space-between; align-items:flex-end; gap:1.5rem; flex-wrap:wrap; border-bottom:1px solid var(--line); padding-bottom:1.4rem; margin-bottom:2.8rem; }
.sold-head h2{ font-family:var(--serif); font-size:clamp(1.5rem,3vw,2rem); color:var(--green); text-transform:uppercase; letter-spacing:.03em; }
.sold-head .sub{ font-size:.66rem; letter-spacing:.22em; text-transform:uppercase; color:var(--green); margin-top:.55rem; }
.view-toggle{ display:flex; gap:.5rem; }
.vt{ width:36px; height:36px; border:1px solid var(--line); background:transparent; color:var(--green); display:grid; place-items:center; cursor:pointer; transition:.3s var(--ease); }
.vt svg{ width:17px; height:17px; }
.vt.active, .vt:hover{ background:var(--green); color:#fff; border-color:var(--green); }

/* reuse .horse-grid / .horse-card; extend for sold layout */
.horse-card{ display:flex; flex-direction:column; }
.horse-card .media img{ width:100%; aspect-ratio:5/4; object-fit:cover; object-position:center top; display:block; }
.horse-card .body{ display:flex; flex-direction:column; flex:1; }
.horse-card .lineage{ margin:.2rem 0 .1rem; }
.horse-card .meta{ font-family:var(--serif); font-style:italic; font-size:.84rem; color:var(--green); margin-bottom:.9rem; }
.horse-card .desc{ margin-bottom:1.3rem; }
.horse-card .sold-tag{ margin-top:auto; border-top:1px solid var(--line); text-align:center; padding:.95em 0 .15em; color:var(--green); font-size:.66rem; letter-spacing:.22em; text-transform:uppercase; font-weight:600; }

/* list view */
.horse-grid.list{ grid-template-columns:1fr; gap:1.2rem; }
.horse-grid.list .horse-card{ flex-direction:row; }
.horse-grid.list .horse-card .media{ width:38%; max-width:340px; flex-shrink:0; }
.horse-grid.list .horse-card .media img{ aspect-ratio:5/4; height:auto; }
.horse-grid.list .horse-card .body{ justify-content:center; padding-left:1.8rem; }

/* sales CTA band (uppercase heading + multiple buttons) */
.cta-band.sales h2{ font-style:normal; text-transform:uppercase; letter-spacing:.05em; }
.cta-actions{ display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; margin-top:.5rem; }
/* ============================================================
   VISIT PAGE
   ============================================================ */
.hero.visit{ min-height:66svh; }
.hero.visit::after{ background:linear-gradient(180deg, rgba(8,28,18,.3), rgba(8,28,18,.12) 45%, rgba(8,28,18,.45)); }
.hero.visit h1{ font-family:var(--serif); font-style:italic; font-weight:500; text-transform:none; letter-spacing:.01em; font-size:clamp(2.6rem,7vw,5rem); margin-bottom:1.2rem; }

/* A Thoughtful Environment */
.env{ background:var(--paper); padding:6rem 0; }
.env .grid{ display:grid; grid-template-columns:1fr 1fr; gap:4.5rem; align-items:center; }
.env h2{ font-family:var(--serif); font-size:clamp(1.9rem,3.8vw,2.7rem); color:var(--green); line-height:1.12; }
.env h2 em{ font-style:italic; }
.env .rule{ width:54px; height:2px; background:var(--green); margin:1.2rem 0 1.6rem; }
.env p{ font-size:.97rem; margin-bottom:1rem; }
.env .btn{ margin-top:.8rem; }
.env-media{ position:relative; }
.env-media img, .env-media .ph{ width:100%; aspect-ratio:4/5; object-fit:cover; object-position:center; display:block; box-shadow:0 30px 60px -28px rgba(3,52,35,.45); }
.env-media .quote-card{ right:auto; left:-26px; bottom:-34px; width:60%; }

/* Finding Your Way (location card) */
.finding{ background:var(--paper); padding:5rem 0 6rem; text-align:center; }
.finding .eyebrow{ justify-content:center; margin-bottom:1rem; }
.finding h2{ font-family:var(--serif); font-style:italic; font-size:clamp(1.9rem,3.8vw,2.6rem); color:var(--green); }
.finding .rule{ width:54px; height:2px; background:var(--green); margin:1rem auto 2.6rem; }
.loc-card{ display:grid; grid-template-columns:1.4fr 1fr; background:var(--sage); border:1px solid var(--line); overflow:hidden; text-align:left; }
.loc-map{
  position:relative; min-height:340px; overflow:hidden;
  background:
    radial-gradient(circle at 70% 35%, rgba(120,170,210,.5) 0 26px, transparent 27px),
    radial-gradient(circle at 22% 72%, rgba(120,170,210,.45) 0 34px, transparent 35px),
    repeating-linear-gradient(58deg, transparent 0 46px, rgba(255,255,255,.6) 46px 49px),
    repeating-linear-gradient(150deg, transparent 0 70px, rgba(255,255,255,.5) 70px 72px),
    linear-gradient(135deg,#e3ecd9,#d6e6cf);
}
.loc-map iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; display:block; z-index:1; }
.loc-map .map-link{ position:absolute; inset:0; z-index:2; }
.loc-map .pin-pill{
  position:absolute; top:42%; left:50%; transform:translate(-50%,-50%); z-index:3; pointer-events:none;
  background:var(--green-900); color:#fff; display:inline-flex; align-items:center; gap:.55rem;
  padding:.7em 1.3em; border-radius:999px; font-family:var(--serif); font-size:1.1rem; letter-spacing:.02em; box-shadow:0 12px 28px -10px rgba(0,0,0,.55);
}
.loc-map .pin-pill svg{ width:17px; height:17px; }
.loc-info{ padding:2.4rem 2.2rem; display:flex; flex-direction:column; justify-content:center; }
.loc-info .h{ display:inline-flex; align-self:flex-start; align-items:center; gap:.55rem; color:var(--green); font-family:var(--serif); font-size:1.7rem; border-bottom:2px solid var(--green); padding-bottom:.35rem; margin-bottom:1.5rem; }
.loc-info .h svg{ width:22px; height:22px; }
.loc-info address{ font-style:normal; font-family:var(--serif); font-size:1.25rem; color:var(--ink); border-left:2px solid var(--green); padding-left:1.1rem; margin-bottom:1.9rem; line-height:1.5; }
.loc-info .btn{ width:100%; justify-content:center; padding:1.05em 1.8em; }

/* Curated Recommendations */
.recs{ background:var(--sage); padding:6rem 0; text-align:center; }
.recs h2{ font-family:var(--serif); font-size:clamp(1.9rem,3.8vw,2.7rem); color:var(--green); margin-bottom:1rem; }
.recs .intro{ max-width:680px; margin:0 auto 3rem; font-size:.96rem; }
.rec-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.8rem; text-align:left; }
.rec-card{ background:#fff; border:1px solid var(--line); display:flex; flex-direction:column; }
.rec-card .media{ position:relative; }
.rec-card .media img, .rec-card .media .ph{ width:100%; aspect-ratio:16/10; object-fit:cover; display:block; border:none; }
.rec-card .badge{ left:.8rem; right:auto; }
.rec-card .rec-body{ padding:1.6rem 1.6rem 1.9rem; }
.rec-card h3{ font-family:var(--serif); font-style:italic; font-size:1.4rem; color:var(--green); padding-bottom:.7rem; border-bottom:1px solid var(--line); margin-bottom:1.1rem; }
.rec-list{ list-style:none; display:grid; gap:1rem; }
.rec-list strong{ display:block; font-family:var(--sans); font-size:.9rem; color:var(--green-900); font-weight:600; margin-bottom:.15rem; }
.rec-list span{ font-size:.82rem; color:var(--muted); line-height:1.5; }

/* Plan Your Visit CTA */
.cta-band .cta-ico{ width:54px; height:54px; border-radius:50%; border:1px solid rgba(255,255,255,.4); display:grid; place-items:center; margin:0 auto 1.4rem; color:#fff; }
.cta-band .cta-ico svg{ width:22px; height:22px; }
.cta-band .btn.ghost{ --fg:#fff; }

@media(max-width:980px){
  .env .grid{ grid-template-columns:1fr; gap:3rem; }
  .env-media{ max-width:420px; margin-inline:auto; }
  .loc-card{ grid-template-columns:1fr; }
  .loc-map{ min-height:240px; }
  .rec-grid{ grid-template-columns:1fr; max-width:420px; margin-inline:auto; }
}
@media(max-width:680px){
  .env-media{ max-width:78%; }
}

/* Accessible visually-hidden labels */
.sr-only{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }
/* Current page indicator in nav */
.nav-links a[aria-current="page"]{ color:#fff; }
.nav-links a[aria-current="page"]::after{ width:100%; }

/* Netlify form: honeypot + inline success */
.hidden-field{ display:none; }
.form-success{ display:flex; flex-direction:column; align-items:center; gap:.85rem; text-align:center; color:#fff; border:1px solid rgba(255,255,255,.3); background:rgba(255,255,255,.06); padding:2.2rem 1.6rem; }
.form-success[hidden]{ display:none; }
.form-success svg{ width:42px; height:42px; color:#fff; }
.form-success p{ font-size:.95rem; color:rgba(255,255,255,.9); max-width:360px; line-height:1.6; }

/* ============================================================
   LEGAL PAGES (Privacy / Terms)
   ============================================================ */
.legal-hero{ background:var(--green); color:#fff; text-align:center; padding:9rem 1.2rem 3.5rem; }
.legal-hero h1{ font-family:var(--serif); font-size:clamp(2.2rem,5vw,3.4rem); margin-bottom:.6rem; }
.legal-hero .updated{ font-size:.68rem; letter-spacing:.22em; text-transform:uppercase; color:rgba(255,255,255,.8); }
.legal-body{ background:var(--paper); padding:4rem 0 5rem; }
.legal-body .wrap{ max-width:780px; }
.legal-body .intro{ font-size:1rem; color:var(--ink); margin-bottom:1.5rem; line-height:1.75; }
.legal-body h2{ font-family:var(--serif); font-size:1.5rem; color:var(--green); margin:2.3rem 0 .8rem; }
.legal-body p{ font-size:.95rem; line-height:1.75; margin-bottom:1rem; color:var(--ink); }
.legal-body ul{ margin:0 0 1rem 1.3rem; }
.legal-body li{ font-size:.95rem; line-height:1.7; margin-bottom:.45rem; color:var(--ink); }
.legal-body a{ color:var(--green); text-decoration:underline; }

/* Hide hero scroll cue on phones (short heroes -> avoid overlap with hero content) */
@media(max-width:680px){
  .scroll-hint, .scroll-chevron{ display:none; }
}
