:root{
  --brand:#6B2A5B;
  --brand-deep:#4A1E40;
  --brand-soft:#8E4A7E;
  --accent:#C9A227;
  --accent-soft:#E2C25A;
  --accent-ink:#7A5E12;
  --cream:#FAF6EF;
  --cream-2:#F3EADC;
  --ink:#2A2233;
  --muted:#6B6473;
  --line:#E7DDC9;
  --white:#ffffff;
  --radius:14px;
  --shadow:0 10px 30px rgba(74,30,64,.10);
  --shadow-sm:0 4px 14px rgba(74,30,64,.08);
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--ink);background:var(--cream);line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;font-weight:700;font-optical-sizing:auto;line-height:1.18;margin:0 0 .4em;color:var(--brand-deep);letter-spacing:-.01em}
h1{font-size:clamp(2.2rem,5vw,3.4rem)}
h2{font-size:clamp(1.7rem,3.5vw,2.4rem)}
h3{font-size:1.25rem}
p{margin:0 0 1em}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}
.wrap{max-width:1120px;margin:0 auto;padding:0 24px}
.section{padding:72px 0}
.section.tight{padding:48px 0}
.eyebrow{font-family:'Inter';font-weight:600;letter-spacing:.14em;text-transform:uppercase;font-size:.78rem;color:var(--accent-ink);margin-bottom:10px}
.center{text-align:center}
.lede{font-size:1.12rem;color:var(--muted);max-width:680px;margin:0 auto 28px}
.muted{color:var(--muted)}

/* Colorize: brass section-header underline motif (animate: draws in on reveal) */
.section h2::after{content:"";display:block;width:54px;height:3px;background:var(--accent);border-radius:3px;margin:14px 0 0}
.section .center h2::after{margin-left:auto;margin-right:auto}
.stats h2::after{background:var(--accent-soft)}
html.js .section h2::after{width:0;transition:width .55s var(--ease) .12s}
html.js .reveal.in h2::after,html.js .section h2.in::after{width:54px}

/* Header */
.skip{position:absolute;left:-9999px;top:0;background:var(--brand);color:#fff;padding:10px 18px;font-weight:600;border-radius:0 0 8px 0;z-index:100}
.skip:focus{left:0;outline:3px solid var(--accent-soft)}
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--accent),var(--accent-soft));z-index:60;will-change:width}
header.site{position:sticky;top:0;z-index:50;background:rgba(250,246,239,.92);backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--line);transition:box-shadow .3s var(--ease)}
header.site.scrolled{box-shadow:0 6px 24px rgba(74,30,64,.10)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:14px 0;position:relative}
.brand{display:flex;align-items:center;gap:12px;font-family:'Fraunces',Georgia,serif;font-weight:700;color:var(--brand-deep);font-size:1.3rem;letter-spacing:-.01em}
.brand .mark{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--brand),var(--brand-deep));display:grid;place-items:center;color:var(--accent-soft);font-family:'Fraunces',Georgia,serif;font-size:1.1rem;box-shadow:var(--shadow-sm);transition:transform .4s var(--ease)}
.brand:hover .mark{transform:rotate(-8deg) scale(1.05)}
.brand small{display:block;font-family:'Inter';font-weight:500;font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.menu{display:flex;align-items:center;gap:26px}
.menu a{position:relative;color:var(--ink);font-weight:500;font-size:.95rem;transition:color .2s}
.menu a::after{content:"";position:absolute;left:0;bottom:-4px;height:2px;width:100%;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .25s var(--ease)}
.menu a:hover{color:var(--brand)}
.menu a:hover::after,.menu a:focus-visible::after{transform:scaleX(1)}
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;border-radius:999px;font-weight:600;font-size:.95rem;cursor:pointer;border:1px solid transparent;transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s}
.btn:active{transform:translateY(0) scale(.97);transition-duration:.12s}
.btn-primary{background:var(--brand);color:var(--cream)}
.btn-primary:hover{background:var(--brand-deep);text-decoration:none;color:#fff;transform:translateY(-2px);box-shadow:var(--shadow)}
.btn-gold{background:var(--accent);color:#3a2a00;box-shadow:0 6px 18px rgba(201,162,39,.35)}
.btn-gold:hover{background:#b8941f;text-decoration:none;color:#3a2a00;transform:translateY(-2px);box-shadow:0 10px 24px rgba(201,162,39,.45)}
.btn-ghost{background:transparent;color:var(--brand);border:1px solid var(--brand-soft)}
.btn-ghost:hover{background:var(--brand);color:#fff;text-decoration:none}
.nav-toggle{display:none;background:none;border:1px solid var(--line);border-radius:10px;padding:8px 10px;cursor:pointer}

/* Hero */
.hero{position:relative;background:radial-gradient(1200px 500px at 80% -10%, rgba(201,162,39,.18), transparent 60%),linear-gradient(135deg,#4A1E40 0%, #6B2A5B 55%, #7d3a6c 100%);color:#fff;padding:96px 0 84px;overflow:hidden}
.hero::after{content:"";position:absolute;inset:0;background:radial-gradient(600px 300px at 12% 110%, rgba(255,255,255,.06), transparent 60%);pointer-events:none}
.hero h1{color:#fff}
.hero-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none;opacity:.55}
.hero .wrap{position:relative;z-index:1}
.hero .tag{font-style:italic;color:var(--accent-soft);font-size:1.15rem;margin-bottom:18px}
.hero p.lead{color:rgba(255,255,255,.86);font-size:1.1rem;max-width:580px;margin-bottom:28px}
.hero .ctas{display:flex;gap:14px;flex-wrap:wrap}
.hero .badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.22);padding:8px 14px;border-radius:999px;font-size:.82rem;color:#fff;margin-bottom:22px}
.hero .badge b{color:var(--accent-soft)}

/* Cards */
.grid{display:grid;gap:22px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--accent-soft)}
.card .num{font-family:'Fraunces',Georgia,serif;font-size:1.5rem;color:var(--accent-ink);font-weight:700}
.card h3{margin-top:6px}
.card a.more{font-weight:600;color:var(--brand);font-size:.9rem}
.card .tag-mini{display:inline-block;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);background:var(--cream-2);padding:3px 8px;border-radius:999px;margin-top:8px}

.highlights .card{display:flex;flex-direction:column;gap:6px}
.highlights .ico{width:44px;height:44px;border-radius:12px;background:var(--cream-2);display:grid;place-items:center;color:var(--brand);font-size:1.3rem;margin-bottom:8px;transition:transform .4s var(--ease)}
.highlights .card:hover .ico{transform:scale(1.12) rotate(-4deg)}

/* Stats */
.stats{background:var(--brand-deep);color:#fff;position:relative;overflow:hidden}
.stats::before{content:"";position:absolute;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(201,162,39,.16),transparent 70%);top:-120px;right:-80px}
.stats h2{color:#fff;position:relative}
.stats .num{font-family:'Fraunces',Georgia,serif;font-size:clamp(2.2rem,4vw,3rem);color:var(--accent-soft);line-height:1}
.stats .label{font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-top:8px}
.stats .desc{color:rgba(255,255,255,.8);margin-top:10px;font-size:.92rem}
.stats .grid-3{gap:36px}
.stats .note{color:rgba(255,255,255,.7);font-size:.9rem;margin-top:30px;position:relative}

/* Courses */
.course{display:flex;flex-direction:column;gap:8px}
.course .ico{font-size:1.4rem;transition:transform .4s var(--ease)}
.course:hover .ico{transform:translateY(-4px) scale(1.1)}
.course .format{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-ink);font-weight:600}

/* Tiers */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.tier{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-sm);position:relative;transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s}
.tier:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.tier.featured{border:2px solid var(--accent);box-shadow:var(--shadow);background:linear-gradient(160deg,rgba(201,162,39,.09),rgba(201,162,39,.02) 55%,#fff)}
.tier.featured:hover{transform:translateY(-7px) scale(1.01)}
.tier .tier-tag{position:absolute;top:-12px;right:22px;background:var(--accent);color:#3a2a00;font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:4px 10px;border-radius:999px}
.tier h3{color:var(--brand-deep)}
.tier .price{font-family:'Fraunces',Georgia,serif;font-size:1.7rem;color:var(--brand);margin:6px 0}
.tier .price small{font-family:'Inter';font-size:.85rem;color:var(--muted)}
.tier ul{padding-left:18px;margin:14px 0 20px;color:var(--ink)}
.tier li{margin-bottom:6px}

/* Steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;counter-reset:step}
.step{position:relative;padding:26px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.step:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.step::before{counter-increment:step;content:counter(step,decimal-leading-zero);display:block;font-family:'Fraunces',Georgia,serif;font-size:1.6rem;color:var(--accent-ink);font-weight:700;margin-bottom:8px}
.step h3{font-size:1.05rem}
.step p{font-size:.92rem;color:var(--muted);margin:0}

/* FAQ */
.faq{max-width:820px;margin:0 auto}
details.q{background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px 20px;margin-bottom:12px;box-shadow:var(--shadow-sm);transition:border-color .3s,box-shadow .3s}
details.q[open]{border-color:var(--accent-soft);box-shadow:var(--shadow)}
details.q summary{cursor:pointer;font-weight:600;color:var(--brand-deep);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px}
details.q summary::-webkit-details-marker{display:none}
details.q summary::after{content:"+";color:var(--accent-ink);font-size:1.3rem;font-weight:700;transition:transform .3s var(--ease)}
details.q[open] summary::after{transform:rotate(45deg)}
details.q .a{padding-top:12px;color:var(--muted);border-top:1px solid var(--line);margin-top:12px;animation:fadeDown .4s var(--ease)}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:start}
.info-row{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--line)}
.info-row .ico{flex:0 0 38px;height:38px;border-radius:10px;background:var(--cream-2);display:grid;place-items:center;color:var(--brand);font-size:1.1rem}
.info-row .k{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.info-row .v{color:var(--ink);font-weight:500}
.map-cta{background:linear-gradient(135deg,var(--brand),var(--brand-deep));color:#fff;border-radius:var(--radius);padding:30px;box-shadow:var(--shadow)}
.map-cta h3{color:#fff}

/* Footer */
footer.site{background:var(--brand-deep);color:rgba(255,255,255,.82);padding:54px 0 30px}
footer.site .fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:32px}
footer.site h4{color:#fff;font-family:'Inter';font-weight:600;letter-spacing:.1em;text-transform:uppercase;font-size:.8rem;margin-bottom:14px}
footer.site a{color:rgba(255,255,255,.82);transition:color .2s}
footer.site a:hover{color:var(--accent-soft)}
footer .brand{color:#fff}
footer .copy{border-top:1px solid rgba(255,255,255,.16);margin-top:34px;padding-top:18px;font-size:.84rem;color:rgba(255,255,255,.6);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* Banner */
.banner{position:relative;background:radial-gradient(900px 360px at 85% -10%, rgba(201,162,39,.16), transparent 60%),linear-gradient(135deg,#4A1E40,#6B2A5B);color:#fff;padding:64px 0 48px;overflow:hidden}
.banner h1{color:#fff;margin-bottom:8px}
.banner p{color:rgba(255,255,255,.82);max-width:640px;margin:0}
.crumbs{font-size:.82rem;color:rgba(255,255,255,.7);margin-bottom:14px}
.crumbs a{color:rgba(255,255,255,.7)}
.crumbs a:hover{color:var(--accent-soft)}

/* Timeline */
.timeline{position:relative;margin-top:30px;padding-left:24px;border-left:2px solid var(--accent-soft)}
.timeline .ev{padding:0 0 26px 22px;position:relative}
.timeline .ev::before{content:"";position:absolute;left:-31px;top:6px;width:14px;height:14px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px var(--cream);transition:box-shadow .3s,transform .3s var(--ease)}
.timeline .ev:hover::before{transform:scale(1.25);box-shadow:0 0 0 4px var(--cream),0 0 0 8px rgba(201,162,39,.25)}
.timeline .yr{font-family:'Fraunces',Georgia,serif;font-weight:700;color:var(--brand);font-size:1.05rem}
.timeline .ev h3{margin:2px 0 4px}

/* ===== MOTION ===== */
@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes fadeDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}

/* Hero entrance */
.hero .badge,.hero .tag,.hero h1,.hero p.lead,.hero .ctas{opacity:0;transform:translateY(24px);animation:fadeUp .8s var(--ease) forwards}
.hero .badge{animation-delay:.05s}
.hero .tag{animation-delay:.15s}
.hero h1{animation-delay:.25s}
.hero p.lead{animation-delay:.4s}
.hero .ctas{animation-delay:.55s}
/* quieter: removed infinite CTA pulse; static brass shadow remains on .btn-gold */

/* Scroll reveal */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.s-grid>*{opacity:0;transform:translateY(16px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal.s-grid.in>*{opacity:1;transform:none}
.reveal.s-grid.in>*:nth-child(1){transition-delay:.05s}
.reveal.s-grid.in>*:nth-child(2){transition-delay:.14s}
.reveal.s-grid.in>*:nth-child(3){transition-delay:.23s}
.reveal.s-grid.in>*:nth-child(4){transition-delay:.32s}
.reveal.s-grid.in>*:nth-child(5){transition-delay:.41s}
.reveal.s-grid.in>*:nth-child(6){transition-delay:.50s}
.reveal.s-grid.in>*:nth-child(7){transition-delay:.59s}
.reveal.s-grid.in>*:nth-child(8){transition-delay:.68s}
.reveal.s-grid.in>*:nth-child(9){transition-delay:.77s}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1!important;transform:none!important}
  .hero .badge,.hero .tag,.hero h1,.hero p.lead,.hero .ctas{opacity:1!important;transform:none!important;animation:none!important}
}

/* A11y: focus + skip link */
:focus-visible{outline:2px solid var(--brand);outline-offset:3px;border-radius:4px}
.btn:focus-visible,a:focus-visible,details.q summary:focus-visible{outline:2px solid var(--brand);outline-offset:3px}

/* Responsive */
@media (max-width:880px){
  .menu{display:none;position:absolute;top:100%;left:0;right:0;background:var(--cream);flex-direction:column;gap:0;padding:10px 18px;border-bottom:1px solid var(--line);box-shadow:var(--shadow)}
  .menu.open{display:flex}
  .menu a{padding:12px 0;border-bottom:1px solid var(--line);width:100%}
  .nav-toggle{display:block}
  .grid-3,.grid-2,.grid-4,.tiers,.steps,.contact-grid,footer .fgrid{grid-template-columns:1fr}
  .hero{padding:72px 0 60px}
  .section{padding:52px 0}
}

/* Harden: text-overflow protection */
.card,.tier,.step,.info-row .v,.course h3,.timeline .ev{min-width:0;overflow-wrap:anywhere}
.grid-3,.grid-2,.grid-4,.tiers,.steps,.contact-grid{min-width:0}

/* Harden: print */
@media print{
  header.site,footer.site,.nav-toggle,.btn,.hero .ctas,.skip{display:none!important}
  .reveal,.reveal.s-grid>*,.hero .badge,.hero .tag,.hero h1,.hero p.lead{opacity:1!important;transform:none!important;animation:none!important}
  body{background:#fff!important;color:#000!important}
  .hero,.banner,.stats{background:#fff!important;color:#000!important}
  .hero h1,.banner h1,.stats h2,.stats .num,.stats .label,.stats .desc,.stats .note{color:#000!important}
  .section{padding:18px 0}
  a{color:#000!important;text-decoration:underline}
}