:root{
  --navy:#13216A;
  --navy-deep:#0D1747;
  --navy-ink:#0A1136;
  --gold:#D4A937;
  --gold-bright:#F0D078;
  --gold-soft:#E8C97E;
  --gold-ink:#6B5600;
  --royal:#2444B0;
  --terra:#B4552D;
  --parchment:#FAF8F4;
  --parchment-deep:#F0EADC;
  --ink:#23211B;
  --white:#FFFFFF;
  --display:"Didot","Bodoni 72","Bodoni MT",Georgia,serif;
  --heading:"Palatino Linotype",Palatino,"Book Antiqua",Georgia,serif;
  --body:Georgia,"Times New Roman",serif;
  --shadow-lg:0 30px 60px -18px rgba(10,17,54,.45);
  --shadow-md:0 16px 40px -16px rgba(10,17,54,.30);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-padding-top:90px}
@media (prefers-reduced-motion:no-preference){html{scroll-behavior:smooth}}
body{background:var(--parchment);color:var(--ink);font-family:var(--body);font-size:17px;line-height:1.7}
@media (min-width:900px){body{font-size:19px}}
img{max-width:100%;height:auto;display:block}
a{color:var(--navy)}
a:focus-visible,button:focus-visible,input:focus-visible{outline:3px solid var(--gold);outline-offset:3px}
.nav-toggle:focus-visible ~ .glass-nav .nav-burger{outline:3px solid var(--gold-soft);outline-offset:3px}
p{max-width:64ch}
.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}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--navy);color:var(--white);padding:14px 22px;font-family:var(--heading);z-index:200;text-decoration:none}
.skip-link:focus{left:0}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}

/* ---------- Reveal system (JS-gated; page fully visible without JS) ---------- */
.js .reveal{opacity:0;transform:translateY(26px);transition:opacity .8s ease,transform .8s ease}
.js .reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.js .reveal{opacity:1;transform:none;transition:none}}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:54px;padding:14px 34px;font-family:var(--heading);font-size:15px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;text-decoration:none;text-align:center;cursor:pointer;border:0;border-radius:8px;transition:transform .25s ease,box-shadow .25s ease,background .25s ease,color .25s ease}
.btn:hover{transform:translateY(-2px)}
.btn-gold{background:linear-gradient(160deg,#F4D97C,var(--gold) 55%,#B08428);color:var(--navy-deep);box-shadow:0 12px 28px -10px rgba(212,169,55,.6)}
.btn-gold:hover{box-shadow:0 18px 36px -10px rgba(212,169,55,.75)}
.btn-ghost{border:1px solid var(--gold-soft);color:var(--white);background:rgba(255,255,255,.04)}
.btn-ghost:hover{background:rgba(255,255,255,.1)}
.btn-navy{background:var(--navy);color:var(--white);box-shadow:var(--shadow-md)}
.btn-navy:hover{background:var(--navy-deep)}
.btn-line{border:1px solid var(--gold);color:var(--navy);background:transparent}
.btn-line:hover{background:var(--parchment-deep)}

/* ---------- Fixed glass nav ---------- */
.glass-nav{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .35s ease,box-shadow .35s ease;background:linear-gradient(rgba(10,17,54,.55),rgba(10,17,54,.0));backdrop-filter:blur(0px)}
.glass-nav.scrolled{background:rgba(10,17,54,.88);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:0 10px 30px -12px rgba(0,0,0,.5)}
.nav-row{display:flex;align-items:center;justify-content:space-between;gap:20px;min-height:76px}
.nav-logo-link{display:inline-flex;align-items:center;padding:8px 0}
.nav-logo{width:188px;height:auto}
@media (min-width:900px){.nav-logo{width:210px}}
.nav-links{display:none}
@media (min-width:1020px){
  .nav-links{display:flex;gap:6px;list-style:none;align-items:center}
  .nav-links a{font-family:var(--heading);font-size:14px;letter-spacing:.1em;text-transform:uppercase;color:var(--white);text-decoration:none;padding:14px 12px;border-bottom:2px solid transparent;transition:border-color .25s ease,color .25s ease}
  .nav-links a:hover{border-bottom-color:var(--gold);color:var(--gold-soft)}
  .nav-apply{display:inline-flex}
}
.nav-apply{display:none;min-height:46px;padding:10px 22px;font-size:13px}
.nav-burger{display:inline-flex;flex-direction:column;justify-content:center;gap:5px;width:52px;height:52px;padding:14px;cursor:pointer;border:1px solid rgba(232,201,126,.5);border-radius:12px}
@media (min-width:1020px){.nav-burger{display:none}}
.nav-burger span{display:block;height:2px;background:var(--white)}
.nav-toggle{position:absolute;opacity:0}
.nav-overlay{display:none;position:fixed;inset:0;z-index:120;background:linear-gradient(170deg,var(--navy-deep),var(--navy));overflow-y:auto;padding:110px 28px 60px}
.nav-toggle:checked ~ .nav-overlay{display:block}
.overlay-list{list-style:none;max-width:520px;margin:0 auto;text-align:center}
.overlay-list a{display:block;padding:16px 0;min-height:52px;color:var(--white);font-family:var(--display);font-size:27px;text-decoration:none;border-bottom:1px solid rgba(201,185,140,.22)}
.overlay-list a:hover{color:var(--gold-soft)}
.overlay-ctas{max-width:520px;margin:34px auto 0;display:flex;flex-direction:column;gap:14px}
.overlay-ctas .btn{width:100%}
.overlay-close{position:absolute;top:18px;right:24px;width:52px;height:52px;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(232,201,126,.5);border-radius:50%;color:var(--white);font-size:20px;cursor:pointer}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:flex-end;background:radial-gradient(120% 90% at 50% 0%,#2A4ABF 0%,#1A2D8A 38%,var(--navy) 62%,var(--navy-deep) 100%);color:var(--white);overflow:hidden}
.hero-rays{position:absolute;inset:-20% -10% auto;height:120%;background:conic-gradient(from 180deg at 50% -8%,transparent 0 8deg,rgba(240,208,120,.09) 8deg 9deg,transparent 9deg 17deg,rgba(240,208,120,.09) 17deg 18deg,transparent 18deg 26deg,rgba(240,208,120,.09) 26deg 27deg,transparent 27deg 35deg,rgba(240,208,120,.09) 35deg 36deg,transparent 36deg 44deg,rgba(240,208,120,.09) 44deg 45deg,transparent 45deg 360deg);pointer-events:none}
.hero-top{position:relative;z-index:2;text-align:center;padding:140px 24px 44px;flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center}
.hero-kicker{font-family:var(--heading);font-size:14px;letter-spacing:.42em;text-transform:uppercase;color:var(--gold-soft)}
.hero-name{font-family:var(--display);font-weight:400;font-size:clamp(2.6rem,6vw,3.6rem);line-height:1.06;margin:18px auto 12px;color:var(--white);text-wrap:balance}
.hero-name em{font-style:italic;color:var(--gold-soft)}
.hero-triad{font-family:var(--heading);font-size:15px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-soft);margin:0 auto 30px;max-width:none}
.triad-gem{color:var(--gold);padding:0 .7em}
.hero-lede{margin:0 auto 34px;max-width:58ch;font-size:1.06em;color:#E9E6DC}
.hero-badge{display:inline-flex;align-items:center;gap:12px;border:1px solid rgba(232,201,126,.55);border-radius:999px;padding:12px 30px;font-family:var(--heading);font-size:13px;letter-spacing:.26em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:34px;white-space:nowrap}
@media (max-width:560px){.hero-badge{font-size:10.5px;letter-spacing:.16em;padding:10px 18px;gap:9px}}
.badge-dot{flex:0 0 9px;width:9px;height:9px;border-radius:50%;background:var(--gold-soft);box-shadow:0 0 0 0 rgba(201,185,140,.7);animation:pulse 2.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(201,185,140,.55)}70%{box-shadow:0 0 0 12px rgba(201,185,140,0)}100%{box-shadow:0 0 0 0 rgba(201,185,140,0)}}
@media (prefers-reduced-motion:reduce){.badge-dot{animation:none}}
.hero-ctas{display:flex;gap:18px;flex-wrap:wrap;justify-content:center}
.hero-art{position:relative;z-index:1;margin-top:30px}
.hero-art img{width:100%;height:clamp(220px,34vh,380px);object-fit:cover;object-position:center 18%;filter:saturate(1.1) contrast(1.05)}
.hero-art::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,var(--navy-deep) 0%,rgba(13,23,71,.16) 26%,rgba(13,23,71,0) 55%,rgba(13,23,71,.4) 100%);z-index:2;pointer-events:none}
.hero-art::after{content:"";position:absolute;left:0;right:0;top:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold) 30%,var(--gold) 70%,transparent);z-index:3}
.art-credit{position:absolute;right:18px;bottom:12px;z-index:4;font-family:var(--heading);font-style:italic;font-size:12.5px;color:#D8D3C4;letter-spacing:.06em;max-width:none}

/* ---------- Section scaffolding ---------- */
.band{position:relative;padding:110px 0;overflow:hidden}
@media (min-width:900px){.band{padding:140px 0}}
.band-light{background:var(--parchment)}
.band-shade{background:linear-gradient(180deg,#F8FAFF 0%,#EAF0FB 100%)}
.band-navy{background:linear-gradient(165deg,var(--navy) 0%,var(--navy-deep) 80%);color:var(--white)}
.ghost-num{position:absolute;top:30px;left:-10px;font-family:var(--display);font-size:clamp(10rem,22vw,18rem);line-height:1;color:var(--navy);opacity:.05;pointer-events:none;user-select:none;z-index:0}
.band-navy .ghost-num{color:var(--gold-soft);opacity:.07}
.band > .wrap{position:relative;z-index:1}
.eyebrow{font-family:var(--heading);font-size:13px;letter-spacing:.4em;text-transform:uppercase;color:var(--gold-ink);display:block;margin-bottom:16px}
.band-navy .eyebrow{color:var(--gold-soft)}
.headline{font-family:var(--display);font-weight:400;font-size:clamp(1.9rem,3.6vw,2.75rem);line-height:1.15;color:var(--navy);max-width:22ch;text-wrap:balance}
.band-navy .headline{color:var(--white)}
.headline em{font-style:italic;color:var(--gold-ink)}
.band-navy .headline em{color:var(--gold-soft)}
.head-rule{width:72px;height:2px;border:0;background:linear-gradient(90deg,var(--gold),transparent);margin:26px 0 0}
.center .headline,.center p{margin-left:auto;margin-right:auto}
.center{text-align:center}
.center .head-rule{margin:26px auto 0;background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.section-head{margin-bottom:54px}
.lede{font-size:1.04em;color:var(--ink);margin-top:26px}
.band-navy .lede{color:#E9E6DC}

/* ---------- Credo ---------- */
.credo-cols{display:grid;gap:48px;margin-top:14px}
@media (min-width:980px){.credo-cols{grid-template-columns:minmax(0,7fr) minmax(0,4fr);gap:80px}}
.dropcap::first-letter{font-family:var(--display);font-size:4.1em;float:left;line-height:.82;padding:6px 14px 0 0;color:var(--gold)}
.credo-main p{margin-bottom:1.2em}
.inline-link{color:var(--navy);font-family:var(--heading);font-style:italic;text-decoration:underline;text-decoration-color:var(--gold);text-underline-offset:4px}
.pull{position:relative;padding:18px 0 18px 30px;border-left:2px solid var(--gold);margin-bottom:34px}
.pull p{font-family:var(--heading);font-style:italic;font-size:1.02em;color:var(--navy);max-width:none}
.pull-cite{display:block;margin-top:12px;font-family:var(--heading);font-style:normal;font-size:12.5px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-ink)}
.trinity{display:grid;gap:0;margin-top:80px;border-top:1px solid rgba(176,138,46,.4)}
@media (min-width:760px){.trinity{grid-template-columns:1fr 1fr 1fr}}
.trin{padding:38px 30px 8px;position:relative}
@media (min-width:760px){.trin + .trin{border-left:1px solid rgba(176,138,46,.25)}}
.trin::before{content:"";position:absolute;top:-1px;left:30px;width:46px;height:3px;background:var(--gold);transition:width .4s ease}
.trin:hover::before{width:96px}
.trin-name{font-family:var(--display);font-weight:400;font-size:26px;color:var(--navy)}
.trin-latin{font-family:var(--heading);font-style:italic;color:var(--gold-ink);font-size:16px;margin:2px 0 16px}
.trin p{font-size:.97em}

/* ---------- Three Roads (navy) ---------- */
.roadfinder{max-width:880px;margin:0 auto 70px}
.roadfinder-title{font-family:var(--heading);font-size:13px;letter-spacing:.4em;text-transform:uppercase;color:var(--gold-soft);text-align:center;margin-bottom:20px}
.rf-list{list-style:none}
.rf-list li{display:flex;flex-wrap:wrap;gap:6px 14px;padding:16px 0;border-top:1px solid rgba(201,185,140,.18)}
.rf-q{font-family:var(--heading);font-weight:700;color:var(--white)}
.rf-a{color:#E9E6DC}
.rf-a a{color:var(--gold-soft);font-family:var(--heading);text-decoration:underline;text-decoration-color:rgba(201,185,140,.6);text-underline-offset:4px;display:inline-block;padding:8px 2px}
.road-cards{display:grid;gap:30px}
@media (min-width:980px){.road-cards{grid-template-columns:1fr 1fr 1fr}}
.rcard{background:var(--parchment);color:var(--ink);padding:42px 34px 34px;display:flex;flex-direction:column;position:relative;border-radius:18px;overflow:hidden;box-shadow:var(--shadow-lg);transition:transform .35s ease,box-shadow .35s ease}
.rcard:hover{transform:translateY(-10px);box-shadow:0 44px 80px -20px rgba(0,0,0,.55)}
.rcard::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--gold),var(--gold-bright))}
#card-national.rcard::before{background:linear-gradient(90deg,var(--royal),#5F7BE0)}
#card-flex.rcard::before{background:linear-gradient(90deg,var(--terra),#D98A5B)}
.rcard-kicker{font-family:var(--heading);font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-ink)}
.rcard-title{font-family:var(--display);font-weight:400;font-size:30px;color:var(--navy);margin:8px 0 2px}
.rcard-tag{font-family:var(--heading);font-style:italic;color:var(--gold-ink);font-size:15.5px;margin-bottom:20px}
.rcard-body{flex:1}
.rcard-body p{font-size:.97em;margin-bottom:1em;max-width:none}
.rcard-note{font-size:.97em;font-style:italic;color:var(--gold-ink);margin:4px 0 22px;max-width:none}
.rcard .btn{width:100%}
.partners-line{text-align:center;font-family:var(--heading);font-style:italic;font-size:16px;color:#E9E6DC;margin:54px auto 0;max-width:none}
.partners-line a{color:var(--gold-soft);display:inline-block;padding:8px 2px}

/* ---------- Ledger ---------- */
.ledger-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;box-shadow:var(--shadow-md);background:var(--white);border-radius:18px}
.ledger{width:100%;min-width:820px;border-collapse:collapse}
.ledger caption{text-align:left;font-family:var(--heading);font-style:italic;font-size:14.5px;color:var(--gold-ink);padding:16px 20px;background:var(--white)}
.ledger thead th{font-family:var(--heading);font-size:14px;letter-spacing:.18em;text-transform:uppercase;color:var(--white);background:var(--navy);padding:20px 22px;text-align:left}
.ledger tbody th{font-family:var(--heading);font-size:12.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-ink);background:var(--parchment);padding:20px 22px;text-align:left;vertical-align:top;position:sticky;left:0;min-width:118px}
.ledger td{padding:20px 22px;font-size:.97em;vertical-align:top;border-top:1px solid var(--parchment-deep);text-align:left}
.ledger tbody tr:nth-child(even) td{background:#FCFBF7}
.ledger-note{font-family:var(--heading);font-style:italic;font-size:15px;color:var(--gold-ink);text-align:center;margin:24px auto 0;max-width:none}

/* ---------- Interlude ---------- */
.interlude{position:relative;background:linear-gradient(150deg,#1A2D8A 0%,var(--navy-deep) 70%);color:var(--white);padding:130px 0;text-align:center;overflow:hidden}
.big-quote-mark{position:absolute;top:-40px;left:50%;transform:translateX(-50%);font-family:var(--display);font-size:24rem;line-height:1;color:var(--gold-soft);opacity:.08;pointer-events:none;user-select:none}
.interlude-quote{position:relative;font-family:var(--display);font-style:italic;font-weight:400;font-size:clamp(1.6rem,3.4vw,2.4rem);line-height:1.4;max-width:26ch;margin:0 auto;color:var(--white)}
.interlude-attr{position:relative;font-family:var(--heading);font-size:14px;letter-spacing:.42em;text-transform:uppercase;color:var(--gold-soft);margin:30px auto 0;max-width:none}

/* ---------- Scholar's hours ---------- */
.hours-cols{display:grid;gap:56px;margin-top:10px}
@media (min-width:980px){.hours-cols{grid-template-columns:minmax(0,7fr) minmax(0,4fr);gap:80px}}
.timeline{list-style:none;position:relative;padding-left:34px}
.timeline::before{content:"";position:absolute;left:8px;top:8px;bottom:8px;width:2px;background:linear-gradient(var(--gold),rgba(176,138,46,.15))}
.timeline li{position:relative;padding:0 0 34px}
.timeline li::before{content:"";position:absolute;left:-32px;top:7px;width:14px;height:14px;border-radius:50%;background:var(--parchment);border:3px solid var(--gold)}
.tl-label{font-family:var(--heading);font-size:13px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-ink);display:block;margin-bottom:6px}
.timeline p{max-width:none}
.hours-notes .pull{margin-bottom:30px}
.models{display:grid;gap:30px;margin-top:70px}
@media (min-width:820px){.models{grid-template-columns:1fr 1fr}}
.model{padding:40px 36px;border-radius:18px;box-shadow:var(--shadow-md)}
.model-live{background:linear-gradient(160deg,#1A2D8A,var(--navy));color:var(--white)}
.model-live .model-name{color:var(--gold-soft)}
.model-live p{color:#E9E6DC}
.model-flex{background:var(--white)}
.model-flex .model-name{color:var(--gold-ink)}
.model-name{font-family:var(--heading);font-size:14px;letter-spacing:.3em;text-transform:uppercase;margin-bottom:16px}
.model p{font-size:.97em;margin-bottom:1em;max-width:none}

/* ---------- Results (navy) ---------- */
.stat-row{display:grid;grid-template-columns:1fr 1fr;gap:50px 30px;max-width:980px;margin:0 auto 70px}
@media (min-width:900px){.stat-row{grid-template-columns:repeat(4,1fr)}}
.stat{text-align:center}
.stat-num{font-family:var(--display);font-size:clamp(3.2rem,6vw,4.6rem);line-height:1;color:var(--gold-soft);font-variant-numeric:lining-nums}
.stat-num sup{font-size:.45em;color:var(--gold-soft)}
.stat-rule{width:44px;height:2px;border:0;background:var(--gold);margin:18px auto}
.stat-label{font-size:15.5px;line-height:1.5;color:#E9E6DC;max-width:21ch;margin:0 auto}
.results-copy{text-align:center;margin:0 auto 18px;color:#E9E6DC}
.results-credit{font-family:var(--heading);font-style:italic;font-size:14px;color:var(--gold-soft);text-align:center;margin:0 auto 50px;max-width:none}
.laurels{display:flex;flex-direction:column;gap:16px;align-items:center;justify-content:center;border-top:1px solid rgba(201,185,140,.3);padding-top:40px;max-width:820px;margin:0 auto}
@media (min-width:760px){.laurels{flex-direction:row;gap:60px}}
.laurel{font-family:var(--heading);font-size:14px;letter-spacing:.22em;text-transform:uppercase;color:var(--white);text-align:center;max-width:none}
.laurel a{color:var(--gold-soft);text-decoration:underline;text-decoration-color:rgba(201,185,140,.6);text-underline-offset:4px;display:inline-block;padding:13px 0}
.stem-line{text-align:center;font-style:italic;font-size:.97em;color:#E9E6DC;margin:40px auto 0}

/* ---------- Trivium ---------- */
.trivium-svg{width:100%;max-width:840px;height:auto;display:block;margin:10px auto 60px}
.phase-cols{display:grid;gap:44px}
@media (min-width:820px){.phase-cols{grid-template-columns:1fr 1fr 1fr}}
.phase{position:relative;padding:30px 0 0}
.phase::before{content:attr(data-letter);position:absolute;top:-34px;left:-6px;font-family:var(--display);font-size:7.5rem;line-height:1;color:var(--navy);opacity:.06;pointer-events:none}
.phase-name{font-family:var(--heading);font-size:15px;letter-spacing:.24em;text-transform:uppercase;color:var(--navy);border-top:2px solid var(--gold);display:inline-block;padding-top:14px;margin-bottom:14px}
.phase p{font-size:.97em;max-width:none}

/* ---------- Virtues (navy) ---------- */
.virtues-flow{font-family:var(--display);font-style:italic;font-weight:400;color:var(--gold-soft);font-size:clamp(1.7rem,3.6vw,2.7rem);line-height:1.75;max-width:24ch;margin:40px auto;text-wrap:balance}
@media (min-width:900px){.virtues-flow{max-width:34ch}}
.v-gem{color:var(--white);font-style:normal;font-size:.55em;vertical-align:.35em;padding:0 .55em}
.virtues-coda{font-style:italic;color:#E9E6DC;max-width:56ch;margin:0 auto}

/* ---------- Voices ---------- */
.letters-grid{display:grid;gap:44px;margin:10px 0 60px}
@media (min-width:980px){.letters-grid{grid-template-columns:1fr 1fr 1fr}}
.letter{position:relative;background:var(--white);padding:46px 36px 36px;border-radius:18px;box-shadow:var(--shadow-md)}
.letter::before{content:"\201C";position:absolute;top:-26px;left:24px;font-family:var(--display);font-size:6rem;line-height:1;color:var(--gold)}
.letter p{font-style:italic;font-size:.97em;max-width:none}
.letter-name{display:block;margin-top:22px;font-family:var(--heading);font-size:13px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-ink)}
.sped-card{background:var(--navy);color:var(--white);max-width:720px;margin:0 auto 50px;padding:36px 40px;border-radius:18px;box-shadow:var(--shadow-md)}
.sped-card p{font-style:italic;max-width:none;color:#E9E6DC}
.sped-cite{display:block;margin-top:14px;font-family:var(--heading);font-size:12.5px;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-soft)}
.films{display:flex;gap:18px;justify-content:center;flex-wrap:wrap}
.film-link{display:inline-flex;align-items:center;gap:12px;border:1px solid var(--gold);border-radius:999px;padding:14px 30px;min-height:50px;font-family:var(--heading);font-size:14px;letter-spacing:.16em;text-transform:uppercase;color:var(--navy);text-decoration:none;transition:background .25s ease}
.film-link:hover{background:var(--parchment-deep)}
.film-glyph{width:0;height:0;border-left:10px solid var(--gold);border-top:6px solid transparent;border-bottom:6px solid transparent}

/* ---------- Beyond ---------- */
.beyond-cols{display:grid;gap:44px;margin-top:10px}
@media (min-width:760px){.beyond-cols{grid-template-columns:1fr 1fr}}
@media (min-width:1040px){.beyond-cols{grid-template-columns:repeat(4,1fr)}}
.bey{border-top:2px solid var(--gold);padding-top:22px}
.bey-icon{width:34px;height:34px;margin-bottom:14px}
.bey-icon path,.bey-icon circle{stroke:var(--gold);stroke-width:1.6;fill:none}
.bey:nth-child(2) .bey-icon path,.bey:nth-child(2) .bey-icon circle{stroke:var(--royal)}
.bey:nth-child(3) .bey-icon path{stroke:var(--terra)}
.bey-name{font-family:var(--heading);font-size:14px;letter-spacing:.26em;text-transform:uppercase;color:var(--navy);margin-bottom:12px}
.bey p{font-size:.97em;max-width:none}
.more-line{text-align:center;font-family:var(--heading);font-style:italic;font-size:16px;color:var(--gold-ink);margin:60px auto 0;max-width:none}
.more-line a{color:var(--navy);display:inline-block;padding:12px 2px}

/* ---------- Begin (navy finale) ---------- */
.doors-grid{display:grid;gap:30px;margin:10px 0 64px}
@media (min-width:980px){.doors-grid{grid-template-columns:1fr 1fr 1fr}}
.gdoor{background:rgba(255,255,255,.045);border:1px solid rgba(232,201,126,.28);border-radius:20px;padding:40px 34px;display:flex;flex-direction:column;backdrop-filter:blur(6px);transition:border-color .3s ease,background .3s ease}
.gdoor:hover{border-color:rgba(201,185,140,.7);background:rgba(255,255,255,.07)}
.gdoor-kicker{font-family:var(--heading);font-size:12px;letter-spacing:.34em;text-transform:uppercase;color:var(--gold-soft);text-align:center}
.gdoor-title{font-family:var(--display);font-weight:400;font-size:27px;color:var(--white);text-align:center;margin:8px 0 22px}
.gdoor-body{flex:1}
.gdoor-body p{font-size:.97em;color:#E9E6DC;margin-bottom:1em;max-width:none}
.gdoor-urgency{font-family:var(--heading);font-style:italic;color:var(--gold-soft);font-size:.97em;text-align:center;margin:0 auto 1em;max-width:none}
.gdoor-ctas{display:flex;flex-direction:column;gap:14px;margin-top:auto}
.gdoor-ctas .btn{width:100%}
.gform{display:flex;flex-direction:column;gap:16px}
.gfield{display:flex;flex-direction:column;gap:7px}
.gfield label{font-family:var(--heading);font-size:12.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-soft)}
.gfield input{font-family:var(--body);font-size:16px;min-height:50px;padding:10px 16px;border:1px solid rgba(232,201,126,.4);border-radius:10px;background:rgba(10,17,54,.5);color:var(--white);width:100%}
.gfield input::placeholder{color:#9FA3BC}
.hp{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.form-success{display:none;font-family:var(--heading);font-style:italic;color:var(--gold-soft);text-align:center;margin:0 auto 14px;max-width:none}
.form-success.shown{display:block}
.contact-seal{max-width:760px;margin:0 auto;text-align:center;border-top:1px solid rgba(201,185,140,.3);padding-top:50px}
.seal-lead{font-family:var(--heading);font-size:14px;letter-spacing:.4em;text-transform:uppercase;color:var(--gold-soft);margin:0 auto 18px;max-width:none}
.seal-line{color:#E9E6DC;margin:0 auto .4em;max-width:none}
.seal-line a{color:var(--white);text-decoration:underline;text-decoration-color:rgba(201,185,140,.6);text-underline-offset:4px;display:inline-block;padding:12px 3px}
.seal-close{font-family:var(--display);font-style:italic;font-size:1.25em;color:var(--gold-soft);margin:14px auto 0;max-width:none}

/* ---------- Footer ---------- */
.site-footer{background:var(--navy-ink);color:var(--white);padding:80px 0 44px}
.foot-grid{display:grid;gap:48px;margin-bottom:54px}
.foot-col{min-width:0}
.count{font-variant-numeric:lining-nums}
@media (min-width:760px){.foot-grid{grid-template-columns:1fr 1fr}}
@media (min-width:1040px){.foot-grid{grid-template-columns:repeat(4,1fr)}}
.foot-logo{width:200px;height:auto;margin-bottom:20px}
.foot-head{font-family:var(--heading);font-size:14px;letter-spacing:.26em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:18px;border-bottom:1px solid rgba(201,185,140,.25);padding-bottom:12px}
.foot-links{list-style:none}
.foot-links a{display:inline-block;color:#E4E1D6;text-decoration:none;font-size:16px;padding:9px 0;min-height:44px;border-bottom:1px solid transparent}
.foot-links a:hover{color:var(--gold-soft)}
.foot-addr{font-style:normal;font-size:15.5px;color:#BFC3D6;margin-top:16px;line-height:1.65}
.foot-contact a{color:var(--white);text-decoration:underline;text-decoration-color:rgba(201,185,140,.5);text-underline-offset:4px;display:inline-block;padding:11px 0}
.foot-social{display:flex;gap:16px;margin-top:22px}
.foot-contact a.soc{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;padding:0;border-radius:50%;background:var(--gold-soft);transition:background .25s ease,transform .25s ease}
.soc:hover{background:var(--gold-bright);transform:translateY(-2px)}
.soc svg{width:21px;height:21px;fill:#0D1747}
.foot-legal{border-top:1px solid rgba(201,185,140,.22);padding-top:26px;text-align:center;font-size:15px;color:#BFC3D6}
.foot-legal p{margin:0 auto;max-width:none}

/* ---------- Page layer (subpages) ---------- */
.page-hero{position:relative;min-height:clamp(480px,58vh,640px);display:flex;align-items:flex-end;color:var(--white);overflow:hidden;background:var(--navy-deep)}
.hero-bg{position:absolute;inset:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 30%;display:block;animation:heroKB 7s ease-out forwards;filter:saturate(1.05)}
@keyframes heroKB{from{transform:scale(1.09)}to{transform:scale(1)}}
@media (prefers-reduced-motion:reduce){.hero-bg img{animation:none}}
.page-hero::after{content:'';position:absolute;inset:0;background:linear-gradient(8deg,rgba(13,23,71,.94) 0%,rgba(13,23,71,.62) 34%,rgba(13,23,71,.12) 62%,rgba(13,23,71,.38) 100%);pointer-events:none}
.hero-frame{position:absolute;inset:20px;border:1px solid rgba(232,201,126,.38);pointer-events:none;z-index:2}
.page-hero .wrap{position:relative;z-index:3;padding-top:140px;padding-bottom:58px}
.crumb{font-family:var(--heading);font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:16px;max-width:none}
.crumb a{color:var(--white);text-decoration:none}
.crumb a:hover{color:var(--gold-soft)}
.crumb-sep{color:var(--gold);padding:0 .6em}
.page-title{font-family:var(--display);font-weight:400;font-size:clamp(2.5rem,5.6vw,4.3rem);line-height:1.04;color:var(--white);margin:0;max-width:17ch;text-wrap:balance;text-shadow:0 2px 24px rgba(13,23,71,.55)}
.hero-rule{width:96px;height:3px;border:0;background:linear-gradient(90deg,var(--gold-bright),rgba(212,169,55,0));margin:26px 0 0}
.page-lede{margin:20px 0 0;max-width:58ch;color:#EDEAE0;font-size:1.06em;text-shadow:0 1px 14px rgba(13,23,71,.6)}
.page-hero .btn{margin-top:28px}
@media (max-width:900px){.page-hero{min-height:430px}.page-hero .wrap{padding-top:120px;padding-bottom:44px}.hero-frame{inset:12px}}
.prose{max-width:760px;margin:0 auto}
.prose h2{font-family:var(--display);font-weight:400;font-size:clamp(1.5rem,2.8vw,2rem);color:var(--navy);margin:2.2em 0 .6em;text-wrap:balance}
.prose h2:first-child{margin-top:0}
.prose h3{font-family:var(--heading);font-size:16px;letter-spacing:.18em;text-transform:uppercase;color:var(--navy);margin:2em 0 .6em}
.prose p{margin-bottom:1.15em;max-width:none}
.prose ul,.prose ol{margin:0 0 1.3em 1.4em}
.prose li{margin-bottom:.55em}
.prose a:not(.btn){color:var(--navy);text-decoration:underline;text-decoration-color:var(--gold);text-underline-offset:3px}
.prose .lead{font-size:1.06em;color:var(--ink)}
.rule-gold{width:72px;height:2px;border:0;background:linear-gradient(90deg,var(--gold),transparent);margin:2.4em 0}
.callout{background:var(--white);border-left:3px solid var(--gold);border-radius:0 14px 14px 0;box-shadow:var(--shadow-md);padding:26px 30px;margin:2em 0}
.callout p{max-width:none}
.callout-navy{background:linear-gradient(160deg,#1A2D8A,var(--navy));color:var(--white);border-left-color:var(--gold-soft)}
.callout-navy p{color:#E9E6DC}
.doc-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;box-shadow:var(--shadow-md);background:var(--white);border-radius:18px;margin:2em 0}
.doc-table{width:100%;border-collapse:collapse;min-width:560px}
.doc-table thead th{font-family:var(--heading);font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--white);background:var(--navy);padding:16px 20px;text-align:left}
.doc-table td,.doc-table tbody th{padding:15px 20px;font-size:.97em;border-top:1px solid var(--parchment-deep);text-align:left;vertical-align:top}
.doc-table tbody tr:nth-child(even) td{background:#FCFBF7}
details.faq{background:var(--white);border-radius:14px;box-shadow:var(--shadow-md);margin-bottom:16px;overflow:hidden}
details.faq summary{cursor:pointer;font-family:var(--heading);font-weight:700;color:var(--navy);padding:20px 26px;list-style:none;position:relative;min-height:44px}
details.faq summary::-webkit-details-marker{display:none}
details.faq summary::after{content:"+";position:absolute;right:24px;top:50%;transform:translateY(-50%);color:var(--gold);font-size:24px;font-family:var(--display)}
details.faq[open] summary::after{content:"\2212"}
details.faq .faq-body{padding:0 26px 22px}
details.faq .faq-body p{max-width:none;margin-bottom:.9em}
.btn-row{display:flex;gap:16px;flex-wrap:wrap;margin:1.6em 0}
.two-col{display:grid;gap:34px;margin:2em 0}
@media (min-width:860px){.two-col{grid-template-columns:1fr 1fr}}
.dl-card{display:flex;align-items:center;justify-content:space-between;gap:14px;background:var(--white);border-radius:14px;box-shadow:var(--shadow-md);padding:18px 24px;margin-bottom:14px;text-decoration:none;color:var(--navy);font-family:var(--heading);transition:transform .25s ease}
.dl-card:hover{transform:translateY(-3px)}
.dl-tag{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-ink);flex:none}

/* ---------- Mega menu (desktop) ---------- */
.has-mega .mega{display:none;position:absolute;left:0;right:0;top:100%;background:rgba(10,17,54,.96);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid rgba(232,201,126,.35);border-bottom:1px solid rgba(232,201,126,.25);box-shadow:0 30px 60px -20px rgba(0,0,0,.6);padding:36px 0 40px}
.has-mega:hover .mega,.has-mega:focus-within .mega{display:block}
.mega-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.mega-grid-3{grid-template-columns:repeat(3,1fr)}
.mega-card{display:block;text-decoration:none;border-radius:14px;overflow:hidden;background:rgba(255,255,255,.05);border:1px solid rgba(232,201,126,.18);transition:transform .25s ease,border-color .25s ease}
.mega-card:hover{transform:translateY(-5px);border-color:rgba(232,201,126,.6)}
.mega-card img{width:100%;height:118px;object-fit:cover;display:block}
.mega-label{display:block;font-family:var(--heading);font-size:14px;letter-spacing:.12em;text-transform:uppercase;color:var(--white);padding:14px 16px 4px}
.mega-tag{display:block;font-size:13.5px;color:#C9CCDF;padding:0 16px 16px;line-height:1.45;max-width:none}
.mega-links{display:flex;gap:26px;justify-content:center;margin-top:28px;flex-wrap:wrap}
.mega-links a{color:var(--gold-soft);font-family:var(--heading);font-size:13px;letter-spacing:.14em;text-transform:uppercase;text-decoration:none;padding:10px 2px;border-bottom:1px solid transparent}
.mega-links a:hover{border-bottom-color:var(--gold)}
@media (max-width:1019px){.has-mega .mega{display:none !important}}
.photo-card{margin:0;border-radius:18px;overflow:hidden;box-shadow:var(--shadow-md)}
.photo-card img{width:100%;height:300px;object-fit:cover;display:block}
.btn-row-center{justify-content:center}
.band-light .gdoor{background:var(--white);border:1px solid rgba(176,138,46,.35)}
.band-light .gdoor-title{color:var(--navy)}
.band-light .gdoor-kicker{color:var(--gold-ink)}
.band-light .gdoor-body p{color:var(--ink)}
.band-light .gfield label{color:var(--gold-ink)}
.band-light .gfield input{background:var(--white);color:var(--ink);border:1px solid rgba(176,138,46,.45)}
.band-light .form-success{color:var(--gold-ink)}
.video-card{position:relative;border-radius:18px;overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:16/9;background:var(--navy-deep);cursor:pointer;border:0;padding:0;display:block;width:100%}
.video-card img{width:100%;height:100%;object-fit:cover;opacity:.9}
.vplay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.vplay span{width:74px;height:74px;border-radius:50%;background:rgba(13,23,71,.78);border:2px solid var(--gold-soft);display:flex;align-items:center;justify-content:center;transition:transform .25s ease}
.video-card:hover .vplay span{transform:scale(1.08)}
.vplay i{display:block;width:0;height:0;border-left:22px solid var(--gold-bright);border-top:13px solid transparent;border-bottom:13px solid transparent;margin-left:6px}
.video-card iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.video-title{font-family:var(--heading);font-size:14px;letter-spacing:.18em;text-transform:uppercase;color:var(--navy);text-align:center;margin:14px auto 0;max-width:none}

.rcard-img{margin:-42px -34px 24px;height:175px;overflow:hidden}
.rcard-img img{width:100%;height:100%;object-fit:cover;display:block}
.photo-wide{margin:54px 0}
.photo-wide img{height:360px}
.video-solo{max-width:780px;margin:64px auto 0}
.interlude-athens{background:linear-gradient(rgba(13,23,71,.86),rgba(20,32,96,.88)),url('/assets/img/SchoolOfAthens-dark.jpg') center/cover no-repeat}

.trin-art{margin:-38px -30px 20px;height:175px;overflow:hidden}
.trin-art img{width:100%;height:100%;object-fit:cover;object-position:center 22%;display:block}

/* Face-safe crops — per-image object-position; filename match follows the photo everywhere it appears */
.mega-card img{object-position:center 28%}
img[src*="Family-enjoying"]{object-position:center top}
img[src*="girlsmilingwith3Dpen"]{object-position:center 10%}
img[src*="girl-looking-at-camera"]{object-position:center 18%}
img[src*="art-pearl"]{object-position:center 38%}
img[src*="Boy-engaged-with-online-class"]{object-position:center 25%}
img[src*="girl-smiling-while-online"]{object-position:center 20%}
img[src*="mom-patting"]{object-position:center 22%}
img[src*="Teacher-giving-a-thumbs-up"]{object-position:center 25%}
img[src*="girl-playing-guitar"]{object-position:center 25%}
img[src*="Boy-sharing-his-anvil"]{object-position:center 25%}
img[src*="girl-with-teepee"]{object-position:center 25%}
img[src*="Scholars-studying-outside"]{object-position:center 30%}
img[src*="teacher-with-phonogram-card"]{object-position:center 25%}
img[src*="girl-reading-book600"]{object-position:center 18%}
img[src*="student-showing-her-artwork"]{object-position:center 20%}
img[src*="boywithhis-family"]{object-position:center 25%}
img[src*="headmaster-reading"]{object-position:center 22%}
img[src*="parents-and-girl-learning"]{object-position:center 22%}
img[src*="boywithmominbackground"]{object-position:center 22%}
img[src*="Girl-painting-with-her-virtual-class"]{object-position:center 22%}
img[src*="md-duran-girlcapandgown"]{object-position:center 20%}
img[src*="Corinne-and-books"]{object-position:center 25%}
img[src*="Boy-creating-science"]{object-position:center 25%}
img[src*="Boy-with-glasses600"]{object-position:center 25%}
img[src*="girl-riding-her-horse"]{object-position:center 30%}
img[src*="art-school-of-athens-full"]{object-position:center 42%}
.art-line{font-family:var(--heading);font-style:italic;font-size:13px;color:var(--gold-ink);text-align:center;margin:26px auto 0;max-width:none}
.trivium-duo{align-items:center;margin-bottom:54px}
.trivium-duo .section-head{margin-bottom:0}
.art-portrait img{height:440px;object-position:center 12%}

/* ===== Landing pages (/go/*) ===== */
.l-bar{position:sticky;top:0;z-index:50;background:rgba(10,17,54,.96);backdrop-filter:blur(10px);padding:14px 0}
.l-bar .wrap{display:flex;align-items:center;justify-content:space-between}
.l-bar img{height:40px;width:auto;display:block}
.l-call{font-family:var(--heading);letter-spacing:.12em;color:var(--gold-soft);text-decoration:none;font-size:15px;padding:10px 0}
.l-call strong{color:var(--white);font-weight:600}
.l-hero{position:relative;display:flex;align-items:center;min-height:640px;color:var(--white);overflow:hidden;background:var(--navy-deep);padding:56px 0}
.l-hero .hero-bg img{animation:heroKB 9s ease-out forwards}
.l-hero::after{content:'';position:absolute;inset:0;background:linear-gradient(100deg,rgba(13,23,71,.95) 28%,rgba(13,23,71,.72) 52%,rgba(13,23,71,.3) 100%);pointer-events:none}
.l-hero .wrap{position:relative;z-index:3;display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.l-eyebrow{display:inline-block;font-family:var(--heading);font-size:12.5px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-soft);border:1px solid rgba(232,201,126,.5);border-radius:999px;padding:9px 20px;margin-bottom:22px;white-space:nowrap}
.l-title{font-family:var(--display);font-weight:400;font-size:clamp(2.2rem,4.4vw,3.4rem);line-height:1.07;margin:0 0 18px;max-width:18ch;text-wrap:balance}
.l-sub{color:#EDEAE0;font-size:1.06em;max-width:50ch;margin:0 0 26px}
.l-checks{list-style:none;margin:0;padding:0}
.l-checks li{position:relative;padding:7px 0 7px 34px;font-size:1.02em;color:#F2EFE6}
.l-checks li::before{content:'\2714';position:absolute;left:0;top:7px;color:var(--gold-bright);font-size:18px}
.l-form{background:var(--paper,#FAF8F1);border-radius:20px;box-shadow:0 36px 70px -28px rgba(0,0,0,.55);padding:34px 32px;color:#2E2C26}
.l-form h2{font-family:var(--display);font-weight:400;font-size:1.55rem;color:var(--navy);margin:0 0 6px;max-width:none}
.l-form .l-formsub{font-size:14.5px;color:#6B675C;margin:0 0 18px}
.l-form .gfield{margin-bottom:14px}
.l-form label{display:block;font-family:var(--heading);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-ink);margin-bottom:6px}
.l-form input,.l-form select{width:100%;padding:13px 14px;border:1px solid #D8D2C0;border-radius:10px;background:#fff;font:inherit;font-size:16px;color:#2E2C26}
.l-form input:focus,.l-form select:focus{outline:2px solid var(--gold);outline-offset:1px}
.l-form .btn{width:100%;justify-content:center;margin-top:6px}
.l-fine{font-size:12.5px;color:#8A8578;margin:12px 0 0;text-align:center}
.l-form .form-success{display:none;background:#EAF5EA;border:1px solid #BCDCBC;color:#235C23;border-radius:10px;padding:14px 16px;margin-bottom:14px;font-size:15px}
.sent .l-form .form-success{display:block}
.l-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:14px}
.l-step{background:#fff;border:1px solid rgba(180,160,90,.25);border-radius:18px;padding:30px 28px;box-shadow:var(--shadow-md,0 14px 34px -18px rgba(13,23,71,.25))}
.l-step .n{font-family:var(--display);font-size:2.4rem;color:var(--gold);line-height:1}
.l-step h3{font-family:var(--display);font-weight:400;font-size:1.25rem;color:var(--navy);margin:12px 0 8px}
.l-step p{font-size:15.5px;color:#4C4A40;margin:0}
.l-foot{background:var(--navy-deep);color:#BFC3D6;padding:34px 0;text-align:center;font-size:14.5px}
.l-foot a{color:var(--gold-soft);text-decoration:none}
.l-stickycall{display:none}
@media (max-width:920px){.l-hero{min-height:0;padding:40px 0 56px}.l-hero .wrap{grid-template-columns:1fr;gap:36px}.l-steps{grid-template-columns:1fr}.l-eyebrow{white-space:normal}
.l-stickycall{display:flex;position:fixed;left:14px;right:14px;bottom:14px;z-index:60;justify-content:center}.l-stickycall .btn{width:100%;justify-content:center;box-shadow:0 14px 30px -10px rgba(0,0,0,.5)}}
.l-urgency{margin:22px 0 0;color:var(--gold-bright);font-size:1.02em}
.l-consent{margin-top:4px}
.l-check-label{display:flex;gap:10px;align-items:flex-start;font-family:var(--body);font-size:12.5px;line-height:1.55;color:#6B675C;text-transform:none;letter-spacing:0}
.l-check-label input{width:auto;margin-top:3px;flex:0 0 auto}
.l-check-label a{color:var(--gold-ink)}
.l-rays{position:absolute;inset:-20% -10% auto;height:130%;background:conic-gradient(from 180deg at 70% -8%,transparent 0 8deg,rgba(240,208,120,.07) 8deg 9deg,transparent 9deg 17deg,rgba(240,208,120,.07) 17deg 18deg,transparent 18deg 26deg,rgba(240,208,120,.07) 26deg 27deg,transparent 27deg 360deg);pointer-events:none;z-index:2}
.l-title em{font-style:italic;color:var(--gold-soft)}
.l-chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}
.l-chip{font-family:var(--heading);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-soft);border:1px solid rgba(232,201,126,.45);border-radius:999px;padding:8px 16px;background:rgba(13,23,71,.35)}
.l-sms{margin:16px 0 0;color:#EDEAE0;font-size:1em}
.l-sms a{color:var(--gold-soft)}
.l-spec{max-width:880px;margin:0 auto;background:linear-gradient(160deg,var(--navy) 0%,var(--navy-deep) 100%);border-radius:22px;box-shadow:var(--shadow-lg);overflow:hidden;border:1px solid rgba(232,201,126,.3)}
.l-spec-row{display:grid;grid-template-columns:220px 1fr;gap:18px;padding:22px 34px;border-bottom:1px solid rgba(232,201,126,.18)}
.l-spec-row:last-child{border-bottom:0}
.l-spec-label{font-family:var(--heading);font-size:12.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-soft);padding-top:3px}
.l-spec-val{color:#EDEAE0;font-size:1.02em}
@media (max-width:700px){.l-spec-row{grid-template-columns:1fr;gap:6px;padding:18px 22px}}

/* ===== Course Store ===== */
.s-toolbar{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-bottom:38px}
.s-cats{display:flex;gap:10px;flex-wrap:wrap}
.s-cat{font-family:var(--heading);font-size:13px;letter-spacing:.14em;text-transform:uppercase;text-decoration:none;color:var(--navy);border:1px solid rgba(180,160,90,.4);border-radius:999px;padding:10px 18px;transition:background .25s ease,color .25s ease}
.s-cat:hover{background:var(--parchment-deep)}
.s-cat.on{background:var(--navy);color:var(--white);border-color:var(--navy)}
.s-cat-n{color:var(--gold-ink)}
.s-cat.on .s-cat-n{color:var(--gold-soft)}
.s-cartlink{min-height:46px;padding:10px 22px;font-size:13px}
.s-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(255px,1fr));gap:26px}
.s-card{display:flex;flex-direction:column;background:#fff;border:1px solid rgba(180,160,90,.25);border-radius:18px;overflow:hidden;text-decoration:none;color:inherit;box-shadow:var(--shadow-md);border-top:4px solid var(--gold);transition:transform .25s ease,box-shadow .25s ease}
.s-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.s-card.cat-creditrecovery{border-top-color:var(--royal)}
.s-card.cat-remainingbalance{border-top-color:var(--terra)}
.s-img{height:160px;overflow:hidden;background:var(--parchment-deep)}
.s-img img{width:100%;height:100%;object-fit:cover}
.s-body{display:flex;flex-direction:column;gap:10px;padding:20px 22px 22px;flex:1}
.s-cat-tag{font-family:var(--heading);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-ink)}
.s-name{font-family:var(--display);font-weight:400;font-size:1.18rem;line-height:1.25;color:var(--navy);margin:0}
.s-foot{display:flex;align-items:center;justify-content:space-between;margin-top:auto}
.s-price{font-family:var(--display);font-size:1.3rem;color:var(--navy)}
.s-go{font-family:var(--heading);font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-ink)}
.s-back{display:flex;justify-content:space-between;align-items:center;margin-bottom:26px;max-width:none}
.s-back a:first-child{font-family:var(--heading);text-decoration:none;color:var(--gold-ink)}
.s-detail{display:grid;grid-template-columns:1fr 1.1fr;gap:50px;align-items:start}
.s-detail-img img{height:380px;object-fit:cover;object-position:center 30%}
.s-detail-name{font-family:var(--display);font-weight:400;font-size:2rem;color:var(--navy);margin:8px 0 6px}
.s-detail-price{font-family:var(--display);font-size:1.7rem;color:var(--gold-ink);margin:0 0 18px}
.s-desc p{margin-bottom:10px;font-size:16.5px;color:#4C4A40}
.s-buy{display:flex;gap:14px;align-items:center;margin:22px 0 14px}
.s-qty{width:84px;padding:13px 12px;border:1px solid #D8D2C0;border-radius:10px;font:inherit;font-size:16px;text-align:center;background:#fff}
.s-cart{max-width:860px}
.s-row{display:grid;grid-template-columns:84px 1fr 90px 110px;gap:18px;align-items:center;padding:18px 0;border-bottom:1px solid rgba(180,160,90,.25)}
.s-thumb{width:84px;height:62px;object-fit:cover;border-radius:10px}
.s-row-info{display:flex;flex-direction:column;gap:6px}
.s-row-name{font-family:var(--display);font-size:1.1rem;color:var(--navy);text-decoration:none}
.s-row-price{text-align:right;font-family:var(--display);font-size:1.15rem;color:var(--navy)}
.s-cart-foot{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-top:26px}
.s-total{font-family:var(--display);font-size:1.5rem;color:var(--navy)}
.s-checkout{display:grid;grid-template-columns:1.05fr .95fr;gap:46px;align-items:start;max-width:1020px}
.s-checkout-form{box-shadow:var(--shadow-md)}
.s-summary{background:linear-gradient(160deg,var(--navy),var(--navy-deep));border-radius:20px;padding:30px 30px;color:#EDEAE0;box-shadow:var(--shadow-lg)}
.s-summary h2{font-family:var(--display);font-weight:400;font-size:1.4rem;color:var(--white);margin:0 0 18px}
.s-sum-row{display:flex;justify-content:space-between;gap:18px;padding:10px 0;border-bottom:1px solid rgba(232,201,126,.2);font-size:15.5px}
.s-sum-total{border-bottom:0;font-family:var(--display);font-size:1.25rem;color:var(--gold-soft);margin-top:6px}
.s-notice{background:#EAF5EA;border:1px solid #BCDCBC;color:#235C23;border-radius:12px;padding:14px 18px;max-width:860px;margin-bottom:20px}
.s-error{background:#FBECEA;border:1px solid #E8B9B2;color:#7C2D24;border-radius:12px;padding:14px 18px;max-width:860px;margin-bottom:20px}
.s-testbanner{background:#FFF7E0;border:1px solid #E8D48A;color:#6B5600;border-radius:12px;padding:12px 18px;font-family:var(--heading);letter-spacing:.08em;font-size:14px;max-width:860px;margin-bottom:20px}
.s-confirm .s-summary{max-width:560px;margin:24px 0}
@media (max-width:860px){.s-detail{grid-template-columns:1fr}.s-checkout{grid-template-columns:1fr}.s-row{grid-template-columns:64px 1fr 70px 90px;gap:10px}.s-thumb{width:64px;height:48px}}
.form-card{max-width:720px;margin:0 auto}
.l-form .form-success.shown{display:block}
.s-access{background:linear-gradient(160deg,var(--navy),var(--navy-deep));border-radius:20px;padding:34px 34px;color:#EDEAE0;box-shadow:var(--shadow-lg);margin:28px 0;border:1px solid rgba(232,201,126,.35)}
.s-access h3{font-family:var(--display);font-weight:400;font-size:1.5rem;color:var(--gold-soft);margin:0 0 10px}
.s-access p{color:#EDEAE0}
.s-access-kv{display:grid;grid-template-columns:190px 1fr;gap:10px 18px;margin:18px 0 24px}
.s-access-kv dt{font-family:var(--heading);font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-soft);padding-top:3px}
.s-access-kv dd{margin:0;color:#fff;word-break:break-all}
.s-access-kv code{background:rgba(255,255,255,.1);border:1px solid rgba(232,201,126,.3);border-radius:8px;padding:3px 10px;font-size:15px}
.s-access-kv a{color:var(--gold-soft)}
.s-access-note{font-size:13px;color:#BFC3D6}
@media (max-width:640px){.s-access-kv{grid-template-columns:1fr;gap:2px 0}.s-access-kv dd{margin-bottom:10px}}
