
:root{
  --ohf-navy:#111b33;
  --ohf-navy-2:#1b2d4f;
  --ohf-green:#173b2c;
  --ohf-green-2:#23523d;
  --ohf-burgundy:#6f2635;
  --ohf-ink:#161a26;
  --ohf-cream:#f7f0e5;
  --ohf-paper:#fffaf2;
  --ohf-gold:#b88c3a;
  --ohf-gold-2:#d9bd7a;
  --ohf-stone:#d7ccbd;
  --ohf-charcoal:#17211c;
  --ohf-muted:#726b60;
  --font-serif: Georgia, "Times New Roman", serif;
  --font-sans: "Inter", "Avenir Next", "Segoe UI", Arial, sans-serif;
  --shadow:0 18px 50px rgba(20,33,24,.18);
  --radius:18px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-sans);
  color:var(--ohf-ink);
  background:
    radial-gradient(circle at top left, rgba(184,140,58,.12), transparent 35%),
    linear-gradient(180deg, #fffaf2, #f2eadc);
  line-height:1.6;
}
body.no-scroll{overflow:hidden}
a{color:inherit}
img{max-width:100%; display:block}
.skip-link{
  position:absolute; left:-999px; top:auto; background:var(--ohf-navy); color:white;
  padding:.75rem 1rem; z-index:10000;
}
.skip-link:focus{left:1rem; top:1rem}

.site-header{
  position:sticky; top:0; z-index:999;
  background:rgba(247,240,229,.94);
  backdrop-filter: blur(14px);
  border-bottom:1px solid rgba(184,140,58,.25);
}
.header-inner{
  max-width:1240px; margin:0 auto; padding:.85rem 1.25rem;
  display:flex; align-items:center; justify-content:space-between; gap:1rem;
}
.brand{
  display:flex; align-items:center; gap:.75rem; text-decoration:none;
}
.brand-mark{
  width:44px; height:44px; border-radius:999px;
  border:1px solid var(--ohf-gold); color:var(--ohf-gold);
  display:grid; place-items:center;
  font-family:var(--font-serif); font-size:1.05rem; letter-spacing:-1px;
  background:var(--ohf-navy);
  box-shadow: inset 0 0 0 3px rgba(255,255,255,.08);
}
.brand-copy strong{
  display:block; font-family:var(--font-serif); font-weight:400; letter-spacing:.12em;
  color:var(--ohf-navy); font-size:.94rem; line-height:1.1;
}
.brand-copy span{
  display:block; font-size:.68rem; letter-spacing:.23em; color:var(--ohf-muted); text-transform:uppercase;
}
.site-nav{display:flex; align-items:center; gap:.15rem; flex-wrap:wrap; justify-content:flex-end}
.site-nav a{
  text-decoration:none; padding:.55rem .68rem; border-radius:999px;
  font-size:.79rem; text-transform:uppercase; letter-spacing:.11em; color:#314238;
}
.site-nav a:hover,.site-nav a.active{background:rgba(27,45,79,.10); color:var(--ohf-navy)}
.menu-toggle{
  display:none; border:1px solid rgba(184,140,58,.5); background:white; color:var(--ohf-navy);
  border-radius:999px; padding:.55rem .8rem; font-weight:700; letter-spacing:.08em;
}

main{min-height:70vh}
.container{width:min(1160px, calc(100% - 2rem)); margin:0 auto}
.wide{width:min(1320px, calc(100% - 2rem)); margin:0 auto}
.section{padding:3.6rem 0}
.section-tight{padding:2.4rem 0}
.eyebrow{
  text-transform:uppercase; letter-spacing:.24em; font-size:.75rem; color:var(--ohf-gold);
  font-weight:700; margin:0 0 .85rem;
}
h1,h2,h3,h4{font-family:var(--font-serif); font-weight:400; line-height:1.08; margin:0 0 1rem}
h1{font-size:clamp(2.05rem, 4.8vw, 4.65rem); letter-spacing:-.035em}
h2{font-size:clamp(1.55rem, 2.8vw, 2.85rem); letter-spacing:-.025em}
h3{font-size:clamp(1.12rem, 1.45vw, 1.55rem)}
.lede{font-size:clamp(1.08rem, 1.7vw, 1.35rem); color:#3f4a42; max-width:760px}
.small{font-size:.92rem; color:var(--ohf-muted)}
.center{text-align:center}
.kicker-line{width:76px; height:1px; background:var(--ohf-gold); margin:1.2rem auto 0}

.hero{
  position:relative; min-height:72vh; display:grid; align-items:end; color:white; overflow:hidden;
  background:linear-gradient(rgba(10,20,15,.25), rgba(10,20,15,.72)), url("../img/placeholders/hero.svg") center/cover;
}
.hero::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(90deg, rgba(12,20,38,.84), rgba(12,20,38,.18) 62%, rgba(12,20,38,.50));
}
.hero .container{position:relative; z-index:1; padding:7rem 0 4.6rem}
.hero .eyebrow{color:var(--ohf-gold-2)}
.hero .lede{color:rgba(255,255,255,.86)}
.hero-actions{display:flex; gap:.9rem; flex-wrap:wrap; margin-top:1.65rem}
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  border-radius:999px; padding:.85rem 1.05rem;
  text-decoration:none; font-size:.78rem; text-transform:uppercase; letter-spacing:.13em;
  font-weight:800; border:1px solid rgba(184,140,58,.58);
}
.btn-primary{background:var(--ohf-gold); color:#18241c}
.btn-secondary{background:rgba(255,255,255,.08); color:white}
.btn-dark{background:var(--ohf-navy); color:white}

.intro-card{
  background:rgba(255,250,242,.85); border:1px solid rgba(184,140,58,.25);
  box-shadow:var(--shadow); border-radius:var(--radius); padding:2rem;
}
.grid{display:grid; gap:1.25rem}
.grid-2{grid-template-columns:repeat(2, minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3, minmax(0,1fr))}
.grid-4{grid-template-columns:repeat(4, minmax(0,1fr))}
.card{
  background:rgba(255,250,242,.86); border:1px solid rgba(184,140,58,.24);
  border-radius:var(--radius); box-shadow:0 8px 24px rgba(20,33,24,.08); overflow:hidden;
}
.card-pad{padding:1.35rem}
.card-img{
  aspect-ratio: 16 / 10; background:#ddd; overflow:hidden;
}
.card-img img{width:100%; height:100%; object-fit:cover}
.card h3 a{text-decoration:none}
.card h3 a:hover{color:var(--ohf-green-2)}
.tag-row{display:flex; gap:.45rem; flex-wrap:wrap; margin:.8rem 0}
.tag{
  display:inline-flex; border:1px solid rgba(184,140,58,.38); color:var(--ohf-navy);
  border-radius:999px; padding:.28rem .55rem; font-size:.7rem; text-transform:uppercase; letter-spacing:.09em;
  background:rgba(184,140,58,.08);
}

.feature-strip{
  background:var(--ohf-navy); color:white; border-block:1px solid rgba(184,140,58,.35);
}
.feature-strip .lede{color:rgba(255,255,255,.82)}
.feature-strip h2,.feature-strip h3{color:white}
.feature-strip .card{background:rgba(255,255,255,.055); border-color:rgba(217,189,122,.22); box-shadow:none}
.feature-strip .small{color:rgba(255,255,255,.72)}

.stat-list{
  display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:.65rem;
}
.stat{
  padding:.75rem; border-radius:14px; background:rgba(27,45,79,.07); border:1px solid rgba(27,45,79,.11)
}
.stat b{display:block; font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ohf-muted)}
.stat span{font-family:var(--font-serif); color:var(--ohf-navy); font-size:1.08rem}

.page-hero{
  padding:4.25rem 0 2.65rem;
  background:
    linear-gradient(135deg, rgba(17,27,51,.96), rgba(17,27,51,.84)),
    url("../img/placeholders/facility.svg") center/cover;
  color:white;
}
.page-hero .lede{color:rgba(255,255,255,.82)}
.breadcrumbs{font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.68); margin-bottom:1rem}
.breadcrumbs a{text-decoration:none}
.breadcrumbs a:hover{color:white}

.facility-list{
  columns:2; column-gap:2rem; padding-left:1.1rem;
}
.facility-list li{break-inside:avoid; margin:.25rem 0 .5rem}
.staff-card{display:grid; grid-template-columns:110px 1fr; gap:1rem; align-items:center}
.staff-photo{width:110px; aspect-ratio:1; border-radius:999px; overflow:hidden; border:2px solid rgba(184,140,58,.5)}
.staff-photo img{width:100%; height:100%; object-fit:cover}

.horse-header{
  display:grid; grid-template-columns:1.05fr .95fr; gap:2rem; align-items:center;
}
.horse-portrait{
  border-radius:var(--radius); overflow:hidden; border:1px solid rgba(184,140,58,.25); box-shadow:var(--shadow)
}
.horse-portrait img{width:100%; aspect-ratio:4/3; object-fit:cover}

.table-wrap{
  overflow:auto; border:1px solid rgba(184,140,58,.22); border-radius:var(--radius); background:white;
}
table{width:100%; border-collapse:collapse; min-width:680px}
th,td{padding:.82rem .95rem; text-align:left; border-bottom:1px solid rgba(20,33,24,.08)}
th{
  background:rgba(27,45,79,.08); font-size:.7rem; text-transform:uppercase; letter-spacing:.13em;
  color:var(--ohf-navy);
}
tr:last-child td{border-bottom:0}
.placing{font-weight:800; color:var(--ohf-navy)}
.result-empty{
  padding:1rem; color:var(--ohf-muted); background:rgba(255,250,242,.85); border-radius:var(--radius);
  border:1px dashed rgba(184,140,58,.42)
}

.site-footer{
  background:#0b1324; color:rgba(255,255,255,.78); padding:3rem 0 1.5rem; margin-top:3rem;
}
.footer-grid{display:grid; grid-template-columns:1.2fr .8fr .8fr; gap:2rem}
.site-footer h3{color:white; font-size:1.4rem}
.site-footer a{color:rgba(255,255,255,.78); text-decoration:none}
.site-footer a:hover{color:white}
.footer-links{display:grid; gap:.45rem}
.footer-bottom{border-top:1px solid rgba(217,189,122,.2); padding-top:1rem; margin-top:2rem; font-size:.82rem; color:rgba(255,255,255,.56)}

.disclaimer{
  background:rgba(184,140,58,.1); border:1px solid rgba(184,140,58,.22);
  border-radius:var(--radius); padding:1rem; color:#5b5143; font-size:.9rem;
}

@media (max-width: 900px){
  .menu-toggle{display:inline-flex}
  .site-nav{
    position:fixed; inset:70px 1rem auto 1rem; display:none; flex-direction:column; align-items:stretch;
    background:var(--ohf-paper); border:1px solid rgba(184,140,58,.28); padding:.8rem; border-radius:18px; box-shadow:var(--shadow)
  }
  .site-nav.open{display:flex}
  .site-nav a{padding:.8rem}
  .grid-2,.grid-3,.grid-4,.horse-header,.footer-grid{grid-template-columns:1fr}
  .facility-list{columns:1}
  .hero{min-height:68vh}
  .staff-card{grid-template-columns:80px 1fr}
  .staff-photo{width:80px}
  .stat-list{grid-template-columns:1fr}
}


/* Navy-and-gold refresh */
.eyebrow{color:var(--ohf-gold)}
.btn-primary{background:linear-gradient(135deg, var(--ohf-gold), #e3ca87); color:#101726}
.card h3 a:hover{color:var(--ohf-burgundy)}
.site-nav a:hover,.site-nav a.active{background:rgba(184,140,58,.12); color:var(--ohf-navy)}
.tag{color:var(--ohf-navy); border-color:rgba(184,140,58,.36); background:rgba(184,140,58,.08)}
.feature-strip{background:linear-gradient(135deg, var(--ohf-navy), var(--ohf-navy-2));}
.brand-mark{background:var(--ohf-navy);}


/* OHF site refinement update: smaller headings, discipline image cards, and facilities carousel */
h1{font-size:clamp(1.75rem, 3.2vw, 3.25rem); letter-spacing:-.025em;}
h2{font-size:clamp(1.35rem, 2.15vw, 2.2rem); letter-spacing:-.018em;}
h3{font-size:clamp(1.02rem, 1.18vw, 1.32rem);}
.page-hero{padding:3.35rem 0 2.2rem;}
.hero .container{padding:6rem 0 3.8rem;}
.lede{font-size:clamp(1rem, 1.35vw, 1.18rem);}
.discipline-card .card-img{aspect-ratio:16/9;}
.discipline-card .btn{margin-top:.45rem;}
.facility-carousel{
  display:flex; gap:1rem; overflow-x:auto; scroll-snap-type:x mandatory; padding:.25rem .15rem 1rem;
  scrollbar-color:var(--ohf-gold) rgba(184,140,58,.12);
}
.facility-carousel .card{min-width:min(330px, 82vw); scroll-snap-align:start; flex:0 0 auto;}
.facility-carousel .card-img{aspect-ratio:16/10;}
.carousel-note{margin-top:.4rem; color:var(--ohf-muted); font-size:.88rem;}
@media (max-width: 900px){
  h1{font-size:clamp(1.65rem, 8vw, 2.55rem);}
  h2{font-size:clamp(1.28rem, 6vw, 1.9rem);}
}
