*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --purple:#3C3489;--purple-light:#EEEDFE;--purple-mid:#7F77DD;--purple-dark:#26215C;
  --gold:#C9A356;--gold-light:#F5E9CC;--gold-pale:#FBF5E8;
  --ivory:#FDFAF2;--ivory-dark:#F3EDDF;
  --text:#2A2040;--text-mid:#5A5080;--text-light:#8A80A8;
  --border:rgba(60,52,137,0.15);
}
html{scroll-behavior:smooth}
body{font-family:'Jost',sans-serif;background:var(--ivory);color:var(--text);font-weight:300;line-height:1.75;min-height:100vh}

/* ── NAV ── */
header{background:var(--purple-dark);border-bottom:1px solid rgba(201,163,86,0.3);position:sticky;top:0;z-index:100}
.nav-inner{max-width:1100px;margin:0 auto;padding:0 2rem;display:flex;align-items:center;justify-content:space-between;height:68px;gap:1rem}
.logo{font-family:'Playfair Display',serif;font-size:1.2rem;color:var(--gold-light);text-decoration:none;letter-spacing:0.03em;display:flex;align-items:center;gap:0.6rem;white-space:nowrap}
.logo-crest{width:32px;height:32px;border:1.5px solid var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0;line-height:1;padding-bottom:3px;padding-left:1px}
nav{display:flex;gap:0.15rem;flex-wrap:wrap}
nav a{font-size:0.76rem;letter-spacing:0.1em;text-transform:uppercase;color:rgba(253,250,242,0.65);text-decoration:none;padding:0.4rem 0.85rem;border-radius:4px;transition:all 0.2s;font-weight:400}
nav a:hover,nav a.active{color:var(--gold-light);background:rgba(201,163,86,0.15)}

/* ── MOBILE NAV ── */
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:0.5rem;flex-shrink:0}
.nav-toggle span{display:block;width:24px;height:1px;background:var(--gold-light);transition:transform 0.3s,opacity 0.3s}
.nav-toggle.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
@media(max-width:768px){
  .nav-toggle{display:flex}
  nav{display:none;position:absolute;top:68px;left:0;right:0;background:var(--purple-dark);border-bottom:1px solid rgba(201,163,86,0.3);flex-direction:column;gap:0;padding:0.5rem 0}
  nav.open{display:flex}
  nav a{padding:0.9rem 2rem;width:100%;border-bottom:1px solid rgba(201,163,86,0.1);border-radius:0}
  nav a:last-child{border-bottom:none}
}

/* ── HERO ── */
.hero{background:var(--purple-dark);padding:6rem 2rem 5rem;text-align:center;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 50%,rgba(127,119,221,0.25) 0%,transparent 70%);pointer-events:none}
.hero-ornament{color:var(--gold);font-size:1.1rem;letter-spacing:0.4em;margin-bottom:1.5rem;opacity:0.8}
.hero h1{font-family:'Playfair Display',serif;font-size:clamp(2.2rem,5vw,4rem);font-weight:400;color:var(--ivory);line-height:1.15;margin-bottom:0.5rem}
.hero h1 em{color:var(--gold);font-style:italic}
.hero-sub{font-family:'Cormorant Garamond',serif;font-size:1.25rem;color:rgba(253,250,242,0.6);letter-spacing:0.08em;margin-bottom:2.5rem;font-weight:300}
.hero-divider{width:80px;height:1px;background:linear-gradient(to right,transparent,var(--gold),transparent);margin:0 auto 2.5rem}
.hero-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.btn-primary{background:var(--gold);color:var(--purple-dark);padding:0.75rem 2rem;border:none;border-radius:3px;font-family:'Jost',sans-serif;font-size:0.78rem;font-weight:500;letter-spacing:0.12em;text-transform:uppercase;cursor:pointer;transition:all 0.2s;text-decoration:none;display:inline-block}
.btn-primary:hover{background:#e0b863;transform:translateY(-1px)}
.btn-outline{border:1px solid rgba(201,163,86,0.5);color:var(--gold-light);padding:0.75rem 2rem;border-radius:3px;font-family:'Jost',sans-serif;font-size:0.78rem;letter-spacing:0.12em;text-transform:uppercase;cursor:pointer;transition:all 0.2s;text-decoration:none;background:transparent;display:inline-block}
.btn-outline:hover{background:rgba(201,163,86,0.1);border-color:var(--gold)}

/* ── LAYOUT ── */
.section{max-width:1100px;margin:0 auto;padding:5rem 2rem}
.section-label{font-size:0.72rem;letter-spacing:0.25em;text-transform:uppercase;color:var(--gold);margin-bottom:0.75rem;font-weight:500}
.section-title{font-family:'Playfair Display',serif;font-size:clamp(1.8rem,3.5vw,2.5rem);font-weight:400;color:var(--purple-dark);line-height:1.2;margin-bottom:1.25rem}
.section-title em{font-style:italic;color:var(--purple)}
.divider{width:60px;height:2px;background:var(--gold);margin:0 0 2rem}

/* ── STATS BAR ── */
.stats-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));border:1px solid var(--border);border-radius:8px;overflow:hidden;margin-top:4rem}
.stat{text-align:center;padding:1.75rem 1rem;border-right:1px solid var(--border)}
.stat:last-child{border-right:none}
.stat-num{display:block;font-family:'Playfair Display',serif;font-size:2.2rem;font-weight:600;color:var(--purple);line-height:1}
.stat-label{font-size:0.75rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--text-light);display:block;margin-top:0.4rem}

/* ── ABOUT ── */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
@media(max-width:700px){.about-grid{grid-template-columns:1fr;gap:2rem}}
.about-text p{color:var(--text-mid);margin-bottom:1rem;font-size:0.97rem}
.about-pillars{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:2rem}
.pillar{background:var(--purple-light);border:1px solid rgba(83,74,183,0.15);border-radius:6px;padding:1.25rem;border-left:3px solid var(--purple-mid)}
.pillar-name{font-weight:500;font-size:0.88rem;color:var(--purple-dark);margin-bottom:0.3rem;letter-spacing:0.03em}
.pillar-desc{font-size:0.82rem;color:var(--text-mid);line-height:1.5}
.levels-card{background:var(--purple-dark);border-radius:8px;padding:2rem;color:var(--ivory)}
.levels-card h3{font-family:'Playfair Display',serif;font-size:1.3rem;font-weight:400;color:var(--gold-light);margin-bottom:1.25rem}
.level-row{display:flex;justify-content:space-between;align-items:center;padding:0.6rem 0;border-bottom:1px solid rgba(201,163,86,0.15);font-size:0.88rem}
.level-row:last-child{border-bottom:none}
.level-name{color:rgba(253,250,242,0.85)}
.level-age{font-size:0.75rem;color:rgba(253,250,242,0.5);margin-right:auto;padding-left:0.75rem}
.level-badge{font-size:0.7rem;letter-spacing:0.1em;text-transform:uppercase;padding:0.2rem 0.6rem;border-radius:3px;font-weight:500}
.badge-intro{background:rgba(93,202,165,0.2);color:#5DCAA5}
.badge-mid{background:rgba(127,119,221,0.25);color:#AFA9EC}
.badge-adv{background:rgba(201,163,86,0.2);color:var(--gold)}
.badge-elite{background:rgba(212,83,126,0.2);color:#ED93B1}

/* ── EVENTS ── */
.events-grid{display:grid;gap:1.25rem}
.event-card{background:var(--ivory);border:1px solid var(--border);border-radius:8px;padding:1.5rem 1.75rem;display:grid;grid-template-columns:auto 1fr auto;gap:1.5rem;align-items:center;transition:border-color 0.2s,box-shadow 0.2s}
.event-card:hover{border-color:rgba(127,119,221,0.4);box-shadow:0 4px 20px rgba(60,52,137,0.08)}
.event-card.is-closed{opacity:0.55}
.event-date{text-align:center;background:var(--purple-dark);border-radius:6px;padding:0.75rem 1rem;min-width:64px}
.event-card.is-closed .event-date{background:#3a3a4a}
.event-month{font-size:0.68rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--gold);font-weight:500}
.event-day{font-family:'Playfair Display',serif;font-size:1.8rem;font-weight:600;color:var(--ivory);line-height:1}
.event-name{font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:400;color:var(--purple-dark);margin-bottom:0.3rem}
.event-meta{font-size:0.82rem;color:var(--text-light);display:flex;gap:1rem;flex-wrap:wrap}
.event-status{font-size:0.72rem;letter-spacing:0.1em;text-transform:uppercase;padding:0.3rem 0.8rem;border-radius:3px;font-weight:500;white-space:nowrap}
.status-open{background:rgba(93,202,165,0.15);color:#0F6E56;border:1px solid rgba(93,202,165,0.3)}
.status-upcoming{background:var(--purple-light);color:var(--purple);border:1px solid rgba(127,119,221,0.3)}
.status-closed{background:var(--ivory-dark);color:var(--text-light);border:1px solid var(--border)}
@media(max-width:600px){.event-card{grid-template-columns:auto 1fr}.event-status{grid-column:span 2}}
/* ── RULES ── */

.rules-section{margin-top:.5rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(500px,1fr));gap:1.25rem}
.rules-block{background:var(--ivory);border:1px solid var(--border);border-radius:8px;padding:1.75rem; margin-top: .5rem;}
.rules-block h4{font-family:'Playfair Display',serif;font-size:1.05rem;font-weight:400;color:var(--ivory);background:var(--purple-dark);margin:-1.75rem -1.75rem 1.25rem;padding:0.75rem 1.25rem;border-radius:8px 8px 0 0; border-bottom: 3px solid var(--gold);}
.rules-block p{font-size:0.9rem;color:var(--text-mid);line-height:1.7;margin-bottom:0.5rem}
.rules-block p:last-child{margin-bottom:0}
.rules-block ul{list-style:none;padding:0;margin:0}
.rules-block ol {margin-left: 30px; }
.rules-block ul li {font-size:0.9rem;color:var(--text-mid);line-height:1.7;padding-left:1.25rem;position:relative}
.rules-block ol li {font-size:0.9rem;color:var(--text-mid);line-height:1.7;padding-left:.25rem;position:relative}
.rules-block ul li::before{content:'—';position:absolute;left:0;color:var(--gold)}
/* ── STANDINGS ── */
.standings-tabs{display:flex;gap:0.5rem;margin-bottom:0.75rem;border-bottom:1px solid var(--border);flex-wrap:wrap}
.standings-tab{font-size:0.78rem;letter-spacing:0.1em;text-transform:uppercase;padding:0.6rem 1.2rem;color:var(--text-light);border-bottom:2px solid transparent;margin-bottom:-1px;transition:all 0.2s;background:none;border-top:none;border-left:none;border-right:none;font-family:'Jost',sans-serif;font-weight:500;cursor:pointer;text-decoration:none;display:inline-block}
.standings-tab:hover{color:var(--purple-mid)}
.standings-tab.active{color:var(--purple);border-bottom-color:var(--purple)}
.standings-levels{font-size:0.8rem;color:var(--text-light);margin-bottom:1.75rem;letter-spacing:0.02em}
.standings-table{width:100%;border-collapse:collapse}
.standings-table th{font-size:0.72rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--text-light);font-weight:500;padding:0.7rem 1rem;text-align:left;border-bottom:1px solid var(--border)}
.standings-table td{padding:0.85rem 1rem;border-bottom:1px solid rgba(60,52,137,0.06);font-size:0.9rem}
.standings-table tr:last-child td{border-bottom:none}
.standings-table tr:hover td{background:var(--purple-light)}
.rank-num{font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:600;color:var(--text-light)}
.rank-1{color:var(--gold)}
.rank-2{color:#A0A0A0}
.rank-3{color:#B87333}
.horse-name{font-size:0.83rem;color:var(--text-light);font-style:italic}
.score-pts{font-family:'Playfair Display',serif;font-size:1.05rem;font-weight:600;color:var(--purple)}
.no-entries{text-align:center;color:var(--text-light);padding:2.5rem 1rem;font-size:0.9rem;font-style:italic}
/* ── LEVEL DESCRIPTIONS ── */
.level-descriptions{margin-top:4rem}
.level-descriptions h3{font-family:'Playfair Display',serif;font-size:1.6rem;font-weight:400;color:var(--purple-dark);margin-bottom:0.5rem}
.level-descriptions h3 em{font-style:italic;color:var(--purple)}
.level-desc-divider{width:60px;height:2px;background:var(--gold);margin:0 0 2.5rem}
.level-desc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem}
.level-desc-card{background:var(--ivory);border:1px solid var(--border);border-radius:8px;padding:1.5rem;border-top:3px solid transparent;transition:box-shadow 0.2s}
.level-desc-card:hover{box-shadow:0 4px 20px rgba(60,52,137,0.08)}
.level-desc-card.tier-beginner{border-top-color:#5DCAA5}
.level-desc-card.tier-intermediate{border-top-color:var(--purple-mid)}
.level-desc-card.tier-advanced{border-top-color:var(--gold)}
.level-desc-card.tier-fei{border-top-color:#ED93B1}
.level-desc-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:0.75rem;gap:0.5rem}
.level-desc-name{font-family:'Playfair Display',serif;font-size:1.05rem;font-weight:400;color:var(--purple-dark)}
.level-desc-age{font-size:0.75rem;color:var(--text-light);white-space:nowrap;padding-top:0.2rem}
.level-desc-text{font-size:0.88rem;color:var(--text-mid);line-height:1.6;margin-bottom:1rem}
.level-desc-movements{display:flex;flex-wrap:wrap;gap:0.4rem}
.movement-tag{font-size:0.72rem;background:var(--purple-light);color:var(--purple);padding:0.2rem 0.6rem;border-radius:3px;letter-spacing:0.02em}

/*--- Buttons --- */
a.btn {
  color: var(--purple-dark);
  background: var(--gold);
  border: 1px solid var(--gold);
  padding: 0.35rem 0.9rem;
  text-decoration: none;
  border-radius: 3px;
  font-family: 'Jost', sans-serif;
  font-size: 0.76rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  transition: all 0.2s;
  display: inline-block;
}
a.btn:hover {
  background: #e0b863;
  border-color: #e0b863;
  transform: translateY(-1px);
}
/* ── FOOTER ── */
footer{background:var(--purple-dark);border-top:1px solid rgba(201,163,86,0.2);padding:3rem 2rem;text-align:center}
.footer-logo{font-family:'Playfair Display',serif;font-size:1.4rem;color:var(--gold-light);margin-bottom:0.4rem}
.footer-tag{font-size:0.8rem;color:rgba(253,250,242,0.4);letter-spacing:0.08em}
.footer-tag a {color: var(--gold);}
.footer-tag a:hover {color: var(--purple-light); }
.footer-links{display:flex;gap:1.5rem;justify-content:center;margin-top:1.5rem;flex-wrap:wrap}
.footer-links a{font-size:0.76rem;color:rgba(253,250,242,0.45);text-decoration:none;letter-spacing:0.1em;text-transform:uppercase;transition:color 0.2s}
.footer-links a:hover{color:var(--gold)}