:root{
  --img-hero:url("assets/hero.jpg");
  --img-portrait:url("assets/portrait.jpg");
  --img-portrait-sq:url("assets/portrait-sq.jpg");
  --img-yard:url("assets/yard.jpg");
  --img-string:url("assets/string.jpg");
  --img-owners:url("assets/owners.jpg");
  --img-night:url("assets/night.jpg");
  --img-race:url("assets/race.jpg");
  --img-green:url("assets/green.jpg");

  --navy:#1e2b51;
  --navy-2:#172240;
  --navy-deep:#0f1830;
  --paper:#f5f2ea;
  --paper-2:#ebe6d9;
  --white:#ffffff;
  --ink:#1e2b51;
  --ink-soft:#586079;
  --gold:#a3914f;
  --gold-lt:#c4b074;
  --gold-dk:#7e6a34;
  --line:#ddd6c6;
  --line-d:rgba(255,255,255,.16);

  --maxw:1240px;
  --gutter:clamp(20px,5vw,72px);
  --serif:"Playfair Display",Georgia,"Times New Roman",serif;
  --sans:"Hanken Grotesk",ui-sans-serif,system-ui,-apple-system,sans-serif;
  --shadow:0 30px 60px -34px rgba(15,24,48,.5);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--sans);
  font-size:17px;line-height:1.72;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
a{color:inherit}
::selection{background:var(--gold);color:#1a1206}

.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter);width:100%}
.sec{padding-block:clamp(60px,8.5vw,116px)}
.sec--navy{background:var(--navy);color:#eef1f6}
.sec--paper2{background:var(--paper-2)}

.eyebrow{font-weight:600;font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-dk);
  display:inline-flex;align-items:center;gap:.7em;margin:0 0 16px}
.eyebrow::before{content:"";width:24px;height:1px;background:var(--gold)}
.sec--navy .eyebrow{color:var(--gold-lt)}
.sec--navy .eyebrow::before{background:var(--gold-lt)}

.h-sec{font-family:var(--serif);font-weight:700;line-height:1.04;letter-spacing:-.01em;
  font-size:clamp(2.1rem,4.6vw,3.5rem);margin:0;color:var(--ink)}
.sec--navy .h-sec{color:#fff}
.h-sec em{font-style:italic;font-weight:500;color:var(--gold-dk)}
.sec--navy .h-sec em{color:var(--gold-lt)}
.lead{font-size:clamp(1.08rem,1.6vw,1.24rem);color:var(--ink-soft);line-height:1.62;max-width:54ch;margin:14px 0 0}
.sec--navy .lead{color:#c6cbd9}

/* ============================== HEADER / NAV ============================== */
.top-strip{background:var(--navy-deep);color:#aeb6c9;font-size:12px;letter-spacing:.04em}
.top-strip .row{max-width:var(--maxw);margin-inline:auto;padding:8px var(--gutter);display:flex;justify-content:space-between;align-items:center;gap:16px}
.top-strip a{color:#c7cedd;text-decoration:none}
.top-strip a:hover{color:#fff}
.top-strip .r{display:flex;gap:18px;align-items:center}
.top-strip .ig{display:inline-flex;align-items:center;gap:7px}

.nav{position:sticky;top:0;z-index:60;background:var(--white);border-bottom:1px solid var(--line);
  transition:box-shadow .3s}
.nav.scrolled{box-shadow:0 6px 22px -14px rgba(15,24,48,.4)}
.nav .row{max-width:var(--maxw);margin-inline:auto;padding:14px var(--gutter);display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:inline-flex;align-items:center;gap:13px;text-decoration:none;color:var(--navy)}
.brand .mark{width:40px;height:40px;flex:0 0 auto}
.brand .wm{font-family:var(--serif);font-weight:700;font-size:19px;letter-spacing:.02em;line-height:1;color:var(--navy)}
.brand .wm small{display:block;font-family:var(--sans);font-weight:600;font-size:9.5px;letter-spacing:.28em;color:var(--gold-dk);margin-top:5px}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a{text-decoration:none;color:var(--navy);font-size:13.5px;font-weight:600;letter-spacing:.04em;
  text-transform:uppercase;position:relative;padding:6px 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--gold);transition:width .28s}
.nav-links a:hover::after{width:100%}
.nav-cta{text-decoration:none;background:var(--navy);color:#fff;font-size:12.5px;font-weight:600;letter-spacing:.08em;
  text-transform:uppercase;padding:11px 20px;border-radius:2px;transition:background .25s}
.nav-cta:hover{background:var(--gold-dk)}
.burger{display:none;background:none;border:0;cursor:pointer;padding:8px;width:44px;height:44px}
.burger span{display:block;width:23px;height:2px;background:var(--navy);margin:5px auto;transition:.3s}
.burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ============================== HERO ============================== */
.hero{position:relative;height:92svh;min-height:560px;display:flex;align-items:flex-end;color:#fff;overflow:hidden}
.hero-img{position:absolute;inset:0;background-image:var(--img-hero);background-size:cover;background-position:center 32%;transform:scale(1.04);
  animation:heroZoom 14s ease-out forwards}
@keyframes heroZoom{to{transform:scale(1)}}
.hero::after{content:"";position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(15,24,48,.42) 0%,rgba(15,24,48,.12) 34%,rgba(15,24,48,.5) 78%,rgba(15,24,48,.82) 100%)}
.hero .wrap{position:relative;z-index:2;padding-bottom:clamp(48px,8vw,104px)}
.hero .welcome{font-weight:600;font-size:13px;letter-spacing:.36em;text-transform:uppercase;color:var(--gold-lt);
  margin:0 0 14px;opacity:0;animation:up .9s ease .2s forwards}
.hero h1{font-family:var(--serif);font-weight:700;margin:0;line-height:.98;letter-spacing:-.015em;
  font-size:clamp(3rem,9vw,7rem);text-shadow:0 2px 30px rgba(0,0,0,.3);opacity:0;animation:up 1s ease .32s forwards}
.hero .tag{font-size:clamp(1.05rem,1.7vw,1.4rem);color:#e7e9f0;margin:22px 0 0;max-width:40ch;font-weight:400;
  text-shadow:0 1px 14px rgba(0,0,0,.4);opacity:0;animation:up 1s ease .46s forwards}
.gold-rule{width:64px;height:2px;background:var(--gold-lt);margin:26px 0 0;opacity:0;animation:up 1s ease .56s forwards}
@keyframes up{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}
.scroll-cue{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);z-index:2;color:#fff;
  font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;text-align:center;opacity:.85}
.scroll-cue span{display:block;width:1px;height:34px;background:rgba(255,255,255,.6);margin:8px auto 0;animation:cue 1.8s ease-in-out infinite}
@keyframes cue{0%,100%{transform:scaleY(.4);transform-origin:top;opacity:.4}50%{transform:scaleY(1);opacity:1}}

/* ============================== WELCOME / TRAINER ============================== */
.welcome-grid{display:grid;grid-template-columns:1.25fr .85fr;gap:clamp(34px,5.5vw,76px);align-items:center}
.welcome-copy p{margin:0 0 18px;color:#42485c;line-height:1.78}
.welcome-copy p:first-of-type{font-family:var(--serif);font-size:clamp(1.3rem,2.2vw,1.7rem);font-style:italic;
  font-weight:500;line-height:1.42;color:var(--navy)}
.welcome-copy .em{color:var(--navy);font-weight:600}
.signoff{display:flex;align-items:center;gap:14px;margin-top:26px;padding-top:22px;border-top:1px solid var(--line)}
.signoff .nm{font-family:var(--serif);font-size:1.5rem;font-weight:700;color:var(--navy);line-height:1}
.signoff .rl{font-size:12px;letter-spacing:.06em;color:var(--ink-soft);text-transform:uppercase;font-weight:600}
.portrait{position:relative}
.portrait .ph{aspect-ratio:4/5;background-image:var(--img-portrait);background-size:cover;background-position:center 22%;
  border-radius:3px;box-shadow:var(--shadow)}
.portrait .cap{position:absolute;left:18px;bottom:18px;right:18px;background:rgba(15,24,48,.82);backdrop-filter:blur(3px);
  color:#fff;padding:12px 16px;border-left:3px solid var(--gold-lt);border-radius:2px}
.portrait .cap b{font-family:var(--serif);font-size:1.12rem;display:block;line-height:1.1}
.portrait .cap span{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:#c0c7d8}

/* ============================== FACT STRIP ============================== */
.facts{background:var(--navy);color:#fff;border-block:1px solid var(--navy-deep)}
.facts .row{max-width:var(--maxw);margin-inline:auto;padding:clamp(26px,3.6vw,42px) var(--gutter);
  display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.facts .cell{padding:6px 26px;position:relative}
.facts .cell+.cell::before{content:"";position:absolute;left:0;top:4px;bottom:4px;width:1px;background:var(--line-d)}
.facts .big{font-family:var(--serif);font-weight:700;font-size:clamp(1.7rem,2.8vw,2.5rem);line-height:1;color:#fff}
.facts .big em{font-style:italic;color:var(--gold-lt);font-weight:600}
.facts .lab{font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:#aeb6c9;margin-top:9px;line-height:1.4}

/* ============================== DISCOVER CARDS ============================== */
.disc-head{text-align:center;margin-bottom:42px}
.disc-head .lead{margin-inline:auto}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{position:relative;display:block;text-decoration:none;color:#fff;border-radius:3px;overflow:hidden;aspect-ratio:3/3.5;box-shadow:var(--shadow)}
.card .img{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .6s ease}
.card:hover .img{transform:scale(1.06)}
.card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,24,48,.05) 30%,rgba(15,24,48,.45) 60%,rgba(15,24,48,.9) 100%)}
.card .body{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:26px}
.card .k{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-lt);font-weight:600}
.card h3{font-family:var(--serif);font-weight:700;font-size:1.7rem;margin:7px 0 6px;line-height:1.05}
.card p{margin:0;font-size:.95rem;color:#d6dae6;line-height:1.5}
.card .go{display:inline-flex;align-items:center;gap:8px;margin-top:14px;font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#fff}
.card .go::after{content:"→";transition:transform .25s}
.card:hover .go::after{transform:translateX(5px)}
.c-yard .img{background-image:var(--img-yard)}
.c-string .img{background-image:var(--img-string)}
.c-own .img{background-image:var(--img-owners)}

/* ============================== PADRAIG DAWN ============================== */
.flag-shell{display:grid;grid-template-columns:.9fr 1.1fr;gap:0;border-radius:4px;overflow:hidden;box-shadow:var(--shadow);background:var(--navy);color:#eef1f6;margin-top:30px}
.flag-left{position:relative;background:linear-gradient(160deg,#22315a,#0f1830);min-height:320px}
.flag-left .inner{position:relative;z-index:1;padding:clamp(28px,3.6vw,46px);height:100%;display:flex;flex-direction:column;justify-content:space-between;gap:28px}
.flag-left::after{content:"";position:absolute;inset:0;background:radial-gradient(70% 55% at 72% 16%,rgba(200,166,87,.16),transparent 62%)}
.flag-form .lab{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-lt);font-weight:600}
.flag-form .fig{font-family:var(--serif);font-weight:700;font-size:clamp(4.6rem,11vw,8.4rem);line-height:.82;color:#fff;margin-top:6px}
.flag-form .sub{font-size:.92rem;color:#bcc3d4;margin-top:8px;max-width:26ch}
.flag-silks{display:flex;align-items:center;gap:14px}
.silks-cap{width:52px;height:62px;flex:0 0 auto;filter:drop-shadow(0 6px 12px rgba(0,0,0,.4))}
.flag-silks b{font-family:var(--serif);font-size:1.12rem;display:block;line-height:1.1}
.flag-silks span{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:#aeb6c9}
.flag-right{padding:clamp(28px,3.6vw,52px)}
.flag-right .k{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-lt);font-weight:600}
.flag-right h3{font-family:var(--serif);font-weight:700;font-size:clamp(1.9rem,3.6vw,2.9rem);line-height:1.04;margin:12px 0 6px}
.flag-right h3 em{font-style:italic;color:var(--gold-lt)}
.flag-right .ped{font-family:var(--serif);font-style:italic;font-size:1.1rem;color:#cdd3e0;margin:0 0 20px}
.flag-right p{color:#cfd4e0;line-height:1.74;margin:0 0 16px;font-size:1.01rem}
.flag-right .owners{font-size:.95rem;color:#aeb6c9}
.flag-right .owners b{color:#fff}
.runs{display:flex;flex-wrap:wrap;gap:10px;margin:20px 0}
.runs .run{border:1px solid var(--line-d);border-radius:2px;padding:9px 15px;display:flex;flex-direction:column;gap:2px;min-width:118px}
.runs .run .pos{font-family:var(--serif);font-weight:700;font-size:1.45rem;line-height:1;color:var(--gold-lt)}
.runs .run .ev{font-size:10.5px;letter-spacing:.05em;text-transform:uppercase;color:#9aa2b8}

/* ============================== THE YARD ============================== */
.yard-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(34px,5.5vw,72px);align-items:center}
.yard-copy p{color:#42485c;line-height:1.78;margin:0 0 18px;max-width:54ch}
.yard-copy .em{color:var(--navy);font-weight:600}
.yard-photo{aspect-ratio:5/4;background-image:var(--img-yard);background-size:cover;background-position:center;border-radius:3px;box-shadow:var(--shadow)}
.roll{margin-top:26px;border-top:2px solid var(--gold)}
.roll .cap{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-dk);font-weight:600;margin:14px 0 6px}
.roll .ri{display:flex;justify-content:space-between;align-items:baseline;gap:16px;padding:11px 0;border-bottom:1px solid var(--line)}
.roll .ri .nm{font-family:var(--serif);font-style:italic;font-weight:600;font-size:1.4rem;color:var(--navy)}
.roll .ri .yr{font-family:var(--serif);font-weight:700;font-size:1.25rem;color:var(--gold-dk)}

/* ============================== TRAINING RECORD ============================== */
.rec-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,70px);align-items:start;margin-top:10px}
.rec-hero{display:flex;flex-direction:column;gap:0}
.rec-hero .num{font-family:var(--serif);font-weight:700;font-size:clamp(5rem,13vw,10rem);line-height:.84;color:#fff}
.rec-hero .num em{font-style:italic;color:var(--gold-lt)}
.rec-hero .cap{font-size:1.05rem;color:#c6cbd9;margin-top:14px;max-width:34ch;line-height:1.55}
.rec-list{display:grid;gap:0}
.rec-row{display:grid;grid-template-columns:1fr auto;gap:18px;align-items:baseline;padding:15px 0;border-bottom:1px solid var(--line-d)}
.rec-row:first-child{border-top:1px solid var(--line-d)}
.rec-row .t{font-size:.96rem;color:#c6cbd9}
.rec-row .t b{color:#fff;font-weight:600}
.rec-row .v{font-family:var(--serif);font-weight:700;font-size:1.5rem;color:var(--gold-lt);white-space:nowrap}
.rec-note{font-size:.82rem;color:#9aa2b8;margin-top:18px;grid-column:1/-1}

/* ============================== THE STRING ============================== */
.string-head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap;margin-bottom:36px}
.horses{display:grid;grid-template-columns:repeat(auto-fill,minmax(286px,1fr));gap:18px}
.hcard{position:relative;background:var(--white);border:1px solid var(--line);border-radius:3px;display:grid;grid-template-columns:13px 1fr;overflow:hidden;transition:transform .25s,box-shadow .25s,border-color .25s}
.hcard:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--paper-2)}
.hcard .band{width:13px;height:100%}
.hcard .body{padding:20px 22px 22px}
.hcard .top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.hcard h4{font-family:var(--serif);font-weight:700;font-size:1.4rem;line-height:1.05;margin:0;color:var(--navy)}
.hcard .tag{font-size:9px;letter-spacing:.1em;text-transform:uppercase;font-weight:700;padding:4px 8px;border-radius:2px;white-space:nowrap;margin-top:3px}
.hcard .tag.vip{background:var(--navy);color:var(--gold-lt)}
.hcard .tag.ret{background:var(--paper-2);color:var(--ink-soft)}
.hcard .meta{font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-dk);font-weight:600;margin:6px 0 11px}
.hcard p{margin:0;color:var(--ink-soft);font-size:.93rem;line-height:1.55}
.hcard .ped{margin-top:12px;padding-top:11px;border-top:1px solid var(--line);font-family:var(--serif);font-style:italic;font-size:.98rem;color:var(--navy)}
.string-note{margin-top:30px;font-size:.95rem;color:var(--ink-soft);max-width:62ch}
.string-note b{color:var(--navy);font-weight:600}

/* ============================== NEWS ============================== */
.news-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:36px}
.news-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:22px}
.ncard{display:block;text-decoration:none;color:var(--ink);background:var(--white);border:1px solid var(--line);border-radius:3px;overflow:hidden;transition:transform .25s,box-shadow .25s}
.ncard:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.ncard .thumb{aspect-ratio:16/10;background-size:cover;background-position:center;position:relative}
.ncard .thumb::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(15,24,48,.25))}
.ncard .src{position:absolute;left:12px;top:12px;z-index:2;background:var(--navy);color:#fff;font-size:10px;letter-spacing:.08em;text-transform:uppercase;font-weight:600;padding:5px 10px;border-radius:2px}
.ncard .nb{padding:18px 20px 20px}
.ncard h4{font-family:var(--serif);font-weight:600;font-size:1.2rem;line-height:1.22;margin:0 0 12px;color:var(--navy)}
.ncard .more{font-size:11.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--gold-dk);display:inline-flex;gap:7px}
.ncard .more::after{content:"↗"}
.n1 .thumb{background-image:var(--img-night)}
.n2 .thumb{background-image:var(--img-race)}
.n3 .thumb{background-image:var(--img-string)}
.n4 .thumb{background-image:var(--img-owners)}
.n5 .thumb{background-image:var(--img-hero)}

/* ============================== CONTACT ============================== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,5.5vw,72px);align-items:start;margin-top:8px}
.contact-grid .h-sec{font-size:clamp(2rem,4vw,3rem)}
.icards{margin-top:28px;border-top:1px solid var(--line-d)}
.icard{padding:18px 0;border-bottom:1px solid var(--line-d)}
.icard .k{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-lt);font-weight:600;margin-bottom:7px}
.icard .v{font-family:var(--serif);font-size:1.28rem;color:#fff;line-height:1.3}
.icard .v a{color:#fff;text-decoration:none;border-bottom:1px solid var(--gold)}
.icard .v a:hover{color:var(--gold-lt)}
.icard .v small{display:block;font-family:var(--sans);font-size:.82rem;color:#9aa2b8;margin-top:5px;letter-spacing:.02em}
.enq{background:rgba(255,255,255,.045);border:1px solid var(--line-d);border-radius:3px;padding:clamp(24px,3vw,34px)}
.fr{margin-bottom:17px}
.fr label{display:block;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:#aeb6c9;font-weight:600;margin-bottom:7px}
.fr input,.fr textarea{width:100%;background:rgba(15,24,48,.5);border:1px solid var(--line-d);border-radius:2px;color:#fff;font-family:var(--sans);font-size:1rem;padding:12px 14px;transition:border-color .2s}
.fr textarea{min-height:116px;resize:vertical}
.fr input::placeholder,.fr textarea::placeholder{color:#828aa0}
.fr input:focus,.fr textarea:focus{outline:none;border-color:var(--gold-lt)}
.two{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.enq button{width:100%;background:var(--gold);color:#1a1206;border:0;border-radius:2px;cursor:pointer;font-family:var(--sans);font-weight:700;font-size:13px;letter-spacing:.1em;text-transform:uppercase;padding:15px;transition:background .2s,transform .2s}
.enq button:hover{background:var(--gold-lt);transform:translateY(-2px)}
.hint{font-size:.82rem;color:#9aa2b8;margin:13px 0 0;text-align:center}

/* ============================== FOOTER ============================== */
.foot{background:var(--navy-deep);color:#aeb6c9;padding:clamp(46px,6vw,72px) 0 28px}
.foot-top{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;align-items:flex-start}
.foot-brand{display:flex;gap:15px;align-items:flex-start;max-width:400px}
.foot-brand .mark{width:48px;height:48px;flex:0 0 auto}
.foot-brand b{font-family:var(--serif);font-size:1.5rem;font-weight:700;color:#fff;display:block;line-height:1}
.foot-brand p{margin:9px 0 0;font-size:.9rem;line-height:1.6;color:#8b93a8}
.foot-cols{display:flex;gap:56px;flex-wrap:wrap}
.foot-cols h5{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-lt);margin:0 0 13px;font-weight:600}
.foot-cols a{display:block;text-decoration:none;color:#aeb6c9;font-size:.92rem;padding:5px 0;transition:color .2s}
.foot-cols a:hover{color:#fff}
.foot-base{border-top:1px solid var(--line-d);margin-top:42px;padding-top:22px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:.82rem;color:#828aa0}
.foot-base a{color:#9aa2b8}
.addr{font-size:.86rem;color:#8b93a8;margin-top:18px;line-height:1.6}

/* reveal */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .8s ease,transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1!important;transform:none!important;transition:none}
  .hero-img{animation:none;transform:none}
  .hero .welcome,.hero h1,.hero .tag,.gold-rule{animation:none;opacity:1}
  .scroll-cue span{animation:none}
}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:2px}

/* ============================== RESPONSIVE ============================== */
@media (max-width:1000px){
  .welcome-grid,.yard-grid,.flag-shell,.contact-grid,.rec-grid{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr}
  .card{aspect-ratio:16/10}
  .facts .row{grid-template-columns:1fr 1fr;gap:20px 0}
  .facts .cell:nth-child(odd)::before{display:none}
  .portrait{max-width:440px;margin-inline:auto}
  .rec-hero .num{font-size:clamp(4.5rem,18vw,7rem)}
}
@media (max-width:640px){
  body{font-size:16px}
  .top-strip{display:none}
  .nav-links,.nav-cta{display:none}
  .burger{display:block}
  .nav.open .nav-links{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;background:var(--white);padding:8px var(--gutter) 18px;border-bottom:1px solid var(--line);box-shadow:var(--shadow)}
  .nav.open .nav-links a{padding:14px 0;border-bottom:1px solid var(--line);width:100%;font-size:14px}
  .nav.open .nav-links a::after{display:none}
  .facts .row{grid-template-columns:1fr;gap:0}
  .facts .cell{padding:15px 0;border-top:1px solid var(--line-d)}
  .facts .cell:first-child{border-top:0}
  .facts .cell+.cell::before{display:none}
  .two{grid-template-columns:1fr}
  .roll .ri .nm{font-size:1.2rem}
}

/* ====================== MULTI-PAGE ADDITIONS ====================== */
.nav-links a.active{color:var(--gold-dk)}
.nav-links a.active::after{width:100%}
.center{text-align:center}
.center .lead{margin-inline:auto}

/* sub-page banner */
.banner{position:relative;min-height:clamp(320px,46vh,440px);display:flex;align-items:flex-end;color:#fff;overflow:hidden;padding-block:clamp(98px,14vh,140px) clamp(34px,5vw,56px)}
.banner-img{position:absolute;inset:0;background-size:cover;background-position:center 30%}
.banner::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,24,48,.52) 0%,rgba(15,24,48,.2) 40%,rgba(15,24,48,.72) 100%)}
.banner .wrap{position:relative;z-index:2}
.crumb{font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:#c9cfdd;margin:0 0 14px;font-weight:600}
.crumb a{color:var(--gold-lt);text-decoration:none}
.crumb a:hover{text-decoration:underline}
.banner h1{font-family:var(--serif);font-weight:700;font-size:clamp(2.4rem,6vw,4.4rem);line-height:1;margin:0;letter-spacing:-.015em;text-shadow:0 2px 24px rgba(0,0,0,.3)}
.banner-sub{font-size:clamp(1.02rem,1.6vw,1.25rem);color:#e9ebf2;margin:16px 0 0;max-width:52ch;text-shadow:0 1px 12px rgba(0,0,0,.4)}
.b-about .banner-img{background-image:var(--img-string);background-position:center 22%}
.b-yard .banner-img{background-image:var(--img-hero)}
.b-string .banner-img{background-image:var(--img-race)}
.b-news .banner-img{background-image:var(--img-night)}
.b-contact .banner-img{background-image:var(--img-owners)}

/* read-more link on light */
.readmore{display:inline-flex;align-items:center;gap:9px;margin-top:8px;font-weight:600;font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--gold-dk);text-decoration:none}
.readmore::after{content:"→";transition:transform .25s}
.readmore:hover::after{transform:translateX(5px)}

/* career ladder */
.ladder{margin-top:30px;border-top:1px solid var(--line)}
.rung{display:grid;grid-template-columns:130px 1fr;gap:22px;padding:18px 0;border-bottom:1px solid var(--line)}
.rung .yr{font-weight:600;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-dk);padding-top:4px}
.rung h4{margin:0 0 4px;font-family:var(--serif);font-weight:700;font-size:1.3rem;line-height:1.1;color:var(--navy)}
.rung p{margin:0;font-size:.96rem;color:var(--ink-soft);line-height:1.55}

/* mentors */
.mentors{margin-top:30px;border-top:1px solid var(--line)}
.mentors .m{display:flex;justify-content:space-between;gap:16px;align-items:baseline;padding:13px 0;border-bottom:1px solid var(--line)}
.mentors .m b{font-family:var(--serif);font-weight:700;font-size:1.2rem;color:var(--navy)}
.mentors .m span{font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);text-align:right}

/* milestones timeline (light) */
.timeline{margin-top:34px;position:relative;padding-left:32px}
.timeline::before{content:"";position:absolute;left:6px;top:6px;bottom:6px;width:1px;background:var(--line)}
.event{position:relative;padding:0 0 30px}
.event::before{content:"";position:absolute;left:-32px;top:6px;width:14px;height:14px;border-radius:50%;background:var(--paper);border:1.6px solid var(--line)}
.event.star::before{background:var(--gold);border-color:var(--gold)}
.event .when{font-weight:600;font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-dk)}
.event h4{font-family:var(--serif);font-weight:700;font-size:1.4rem;line-height:1.1;margin:5px 0 5px;color:var(--navy)}
.event p{margin:0;color:var(--ink-soft);font-size:.98rem;line-height:1.6;max-width:60ch}

/* photo gallery */
.gallery{display:grid;grid-template-columns:repeat(12,1fr);gap:14px;margin-top:30px}
.gallery .g{background-size:cover;background-position:center;border-radius:3px;min-height:200px;box-shadow:var(--shadow)}
.gallery .wide{grid-column:span 8}
.gallery .tall{grid-column:span 4;min-height:430px}
.gallery .half{grid-column:span 6}
.gallery .third{grid-column:span 4}
@media(max-width:760px){.gallery .g{grid-column:span 12!important;min-height:230px}}

/* light info list (contact) */
.linfo{margin-top:6px;border-top:1px solid var(--line)}
.linfo .li{padding:18px 0;border-bottom:1px solid var(--line)}
.linfo .li .k{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-dk);font-weight:600;margin-bottom:6px}
.linfo .li .v{font-family:var(--serif);font-size:1.3rem;color:var(--navy);line-height:1.3}
.linfo .li .v a{color:var(--navy);border-bottom:1px solid var(--gold);text-decoration:none}
.linfo .li .v a:hover{color:var(--gold-dk)}
.linfo .li .v small{display:block;font-family:var(--sans);font-size:.85rem;color:var(--ink-soft);margin-top:4px}

/* find-us map block */
.find{margin-top:8px;border:1px solid var(--line);border-radius:3px;overflow:hidden;background:var(--white);box-shadow:var(--shadow)}
.find .map{aspect-ratio:16/9;background-image:var(--img-hero);background-size:cover;background-position:center 32%;position:relative}
.find .map::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(15,24,48,.4),transparent 55%)}
.find .pin{position:absolute;z-index:2;left:20px;bottom:16px;color:#fff;font-family:var(--serif);font-size:1.2rem;display:flex;align-items:center;gap:9px}
.find .fb{padding:18px 22px;display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap}
.find .fb .t{font-size:.92rem;color:var(--ink-soft)}
.find .fb .t b{color:var(--navy)}

/* cta strip */
.cta-strip{background:var(--navy);color:#fff;text-align:center}
.cta-strip .wrap{padding-block:clamp(48px,7vw,86px)}
.cta-strip h2{font-family:var(--serif);font-weight:700;font-size:clamp(1.9rem,4vw,3rem);margin:0 0 12px;line-height:1.08;color:#fff}
.cta-strip p{color:#c6cbd9;max-width:48ch;margin:0 auto 26px}
.cta-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.btn-gold{display:inline-flex;align-items:center;gap:10px;background:var(--gold);color:#1a1206;text-decoration:none;font-weight:700;font-size:13px;letter-spacing:.1em;text-transform:uppercase;padding:15px 30px;border-radius:2px;transition:background .2s,transform .2s}
.btn-gold:hover{background:var(--gold-lt);transform:translateY(-2px)}
.btn-ghost-d{display:inline-flex;align-items:center;gap:10px;background:transparent;border:1px solid var(--line-d);color:#fff;text-decoration:none;font-weight:600;font-size:13px;letter-spacing:.08em;text-transform:uppercase;padding:14px 28px;border-radius:2px;transition:border-color .2s,color .2s}
.btn-ghost-d:hover{border-color:var(--gold-lt);color:var(--gold-lt)}

/* home welcome teaser image already via .portrait */
.teaser-img{aspect-ratio:4/5;background-size:cover;background-position:center 22%;border-radius:3px;box-shadow:var(--shadow)}
