/* =====================================================================
   PAAU ACADEMY — Design System
   Editorial / architectural · academic navy + champagne gold
   ===================================================================== */

:root {
  /* Palette */
  --navy:        #0B1E3A;
  --navy-800:    #0F274A;
  --navy-900:    #071528;
  --gold:        #C6A15B;
  --gold-soft:   #D8BD86;
  --gold-deep:   #A9843F;
  --white:       #FFFFFF;
  --porcelain:   #EDF0F4;   /* cool porcelain-grey section tint */
  --porcelain-2: #E4E9EF;
  --paper:       #F7F8FA;
  --ink:         #0B1E3A;
  --muted:       #55637A;
  --muted-light: #9AA6BB;
  --line:        rgba(11,30,58,.12);
  --line-light:  rgba(255,255,255,.14);

  /* Type */
  --display: "Fraunces", Georgia, "Times New Roman", serif;
  --body:    "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;

  /* Rhythm */
  --wrap: 1240px;
  --gutter: clamp(1.25rem, 4vw, 3.5rem);
  --section: clamp(4.5rem, 10vw, 9rem);
  --radius: 4px;
  --ease: cubic-bezier(.22,.61,.36,1);
  --shadow: 0 24px 60px -28px rgba(7,21,40,.45);
  --shadow-sm: 0 10px 30px -18px rgba(7,21,40,.4);
}

/* ---------- Reset ---------- */
*,*::before,*::after { box-sizing: border-box; }
* { margin: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *,*::before,*::after { animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; }
}
body {
  font-family: var(--body);
  color: var(--ink);
  background: var(--white);
  line-height: 1.65;
  font-size: 17px;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }
ul { list-style: none; padding: 0; }
::selection { background: var(--gold); color: var(--navy); }

/* ---------- Typography ---------- */
h1,h2,h3,h4 { font-family: var(--display); font-weight: 500; line-height: 1.05; letter-spacing: -.015em; color: var(--navy); }
.h-display { font-size: clamp(2.9rem, 7vw, 6rem); font-weight: 400; }
h2 { font-size: clamp(2rem, 4.6vw, 3.35rem); }
h3 { font-size: clamp(1.3rem, 2.4vw, 1.7rem); }
p { color: var(--muted); }
.lead { font-size: clamp(1.1rem, 1.6vw, 1.35rem); color: var(--navy-800); line-height: 1.55; }
.serif-italic { font-family: var(--display); font-style: italic; font-weight: 400; }

.eyebrow {
  display: inline-flex; align-items: center; gap: .7rem;
  font-family: var(--body); font-size: .72rem; font-weight: 600;
  letter-spacing: .28em; text-transform: uppercase; color: var(--gold-deep);
}
.eyebrow::before { content:""; width: 34px; height: 1px; background: var(--gold); display:inline-block; }
.eyebrow.light { color: var(--gold-soft); }
.eyebrow.center { justify-content: center; }

/* ---------- Layout ---------- */
.wrap { width: 100%; max-width: var(--wrap); margin-inline: auto; padding-inline: var(--gutter); }
.section { padding-block: var(--section); }
.tint { background: var(--porcelain); }
.dark { background: var(--navy); color: #E7ECF4; }
.dark h1,.dark h2,.dark h3 { color: #fff; }
.dark p { color: #A9B6CC; }

.grid { display: grid; gap: clamp(1.5rem, 3vw, 2.75rem); }
.section-head { max-width: 720px; margin-bottom: clamp(2.5rem, 5vw, 4rem); }
.section-head.center { margin-inline: auto; text-align: center; }
.section-head p { margin-top: 1.1rem; }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .6rem;
  padding: 1rem 1.9rem; font-size: .82rem; font-weight: 600;
  letter-spacing: .12em; text-transform: uppercase;
  border-radius: var(--radius); border: 1px solid transparent;
  transition: transform .5s var(--ease), background .3s, color .3s, box-shadow .5s, border-color .3s;
  will-change: transform;
}
.btn svg { width: 15px; height: 15px; transition: transform .45s var(--ease); }
.btn:hover svg { transform: translateX(4px); }
.btn-gold { background: var(--gold); color: var(--navy); box-shadow: 0 12px 30px -14px rgba(198,161,91,.7); }
.btn-gold:hover { background: var(--gold-soft); transform: translateY(-2px); }
.btn-navy { background: var(--navy); color: #fff; }
.btn-navy:hover { background: var(--navy-800); transform: translateY(-2px); }
.btn-outline { border-color: var(--line); color: var(--navy); background: transparent; }
.btn-outline:hover { border-color: var(--navy); transform: translateY(-2px); }
.btn-ghost-light { border-color: var(--line-light); color: #fff; }
.btn-ghost-light:hover { background: rgba(255,255,255,.08); border-color: var(--gold); }
.link-arrow { display:inline-flex; align-items:center; gap:.5rem; font-weight:600; font-size:.9rem; color: var(--gold-deep); letter-spacing:.02em; }
.link-arrow svg { width:15px;height:15px; transition: transform .4s var(--ease); }
.link-arrow:hover svg { transform: translateX(5px); }

/* =====================================================================
   HEADER / NAV
   ===================================================================== */
.site-header {
  position: fixed; inset: 0 0 auto 0; z-index: 100;
  transition: background .4s var(--ease), box-shadow .4s, backdrop-filter .4s;
}
.site-header .bar { display: flex; align-items: center; justify-content: space-between; height: 84px; }
.site-header.scrolled { background: rgba(255,255,255,.86); backdrop-filter: saturate(180%) blur(16px); box-shadow: 0 1px 0 var(--line); }
.brand { display: flex; align-items: center; gap: .8rem; font-family: var(--display); font-weight: 600; font-size: 1.35rem; letter-spacing: -.01em; color: #fff; }
.brand .mark { width: 38px; height: 38px; flex: none; }
.brand small { display:block; font-family: var(--body); font-size:.58rem; font-weight:600; letter-spacing:.34em; text-transform:uppercase; color: var(--gold-soft); margin-top: 2px; }
.site-header.scrolled .brand { color: var(--navy); }
.site-header.scrolled .brand small { color: var(--gold-deep); }

.nav { display: flex; align-items: center; gap: 2.3rem; }
.nav a { position: relative; font-size: .84rem; font-weight: 500; letter-spacing: .02em; color: rgba(255,255,255,.85); padding: .3rem 0; }
.nav a::after { content:""; position:absolute; left:0; bottom:-2px; height:1.5px; width:0; background: var(--gold); transition: width .4s var(--ease); }
.nav a:hover::after, .nav a[aria-current="page"]::after { width: 100%; }
.nav a[aria-current="page"] { color: #fff; }
.site-header.scrolled .nav a { color: var(--muted); }
.site-header.scrolled .nav a[aria-current="page"] { color: var(--navy); }
.nav-cta { display:flex; align-items:center; gap: 1.1rem; }
.nav .btn { padding: .72rem 1.3rem; }

.burger { display:none; width: 46px; height: 46px; border:1px solid var(--line-light); border-radius: var(--radius); background: transparent; position: relative; }
.burger span { position:absolute; left: 12px; right: 12px; height: 1.5px; background: #fff; transition: .35s var(--ease); }
.burger span:nth-child(1){ top: 17px; } .burger span:nth-child(2){ top: 22px; } .burger span:nth-child(3){ top: 27px; }
.site-header.scrolled .burger { border-color: var(--line); } .site-header.scrolled .burger span { background: var(--navy); }
body.nav-open .burger span:nth-child(1){ top:22px; transform: rotate(45deg); }
body.nav-open .burger span:nth-child(2){ opacity:0; }
body.nav-open .burger span:nth-child(3){ top:22px; transform: rotate(-45deg); }

/* mobile nav */
.mobile-nav { position: fixed; inset: 0; z-index: 90; background: var(--navy); padding: 120px var(--gutter) 3rem; display:flex; flex-direction:column; gap: .4rem; transform: translateY(-100%); transition: transform .6s var(--ease); visibility:hidden; }
body.nav-open .mobile-nav { transform: translateY(0); visibility:visible; }
.mobile-nav a { font-family: var(--display); font-size: 2rem; color:#fff; padding: .55rem 0; border-bottom: 1px solid var(--line-light); }
.mobile-nav a:hover { color: var(--gold-soft); }
.mobile-nav .btn { margin-top: 1.8rem; }
.mobile-contact { margin-top: auto; color: var(--muted-light); font-size:.9rem; display:flex; flex-direction:column; gap:.4rem; }
.mobile-contact a { color: var(--gold-soft); }

/* =====================================================================
   HERO
   ===================================================================== */
.hero { position: relative; min-height: 100svh; display: flex; align-items: center; background: radial-gradient(120% 100% at 80% 0%, #12294c 0%, var(--navy) 45%, var(--navy-900) 100%); color: #fff; overflow: hidden; }
#hero-canvas { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 1; opacity: .9; }
.hero-veil { position:absolute; inset:0; z-index:2; background: linear-gradient(90deg, rgba(7,21,40,.85) 0%, rgba(7,21,40,.35) 55%, rgba(7,21,40,.15) 100%); }
.hero .wrap { position: relative; z-index: 3; padding-top: 120px; padding-bottom: 60px; }
.hero-inner { max-width: 880px; }
.hero h1 { color:#fff; margin: 1.6rem 0 1.5rem; }
.hero h1 em { font-style: italic; color: var(--gold-soft); }
.hero .lead { color: #C5D0E2; max-width: 620px; }
.hero-actions { display:flex; flex-wrap:wrap; gap: 1rem; margin-top: 2.4rem; }
.hero-meta { display:flex; flex-wrap:wrap; gap: 2.5rem; margin-top: 3.6rem; padding-top: 2.2rem; border-top: 1px solid var(--line-light); }
.hero-meta .stat b { font-family: var(--display); font-size: 2.1rem; font-weight:500; color:#fff; display:block; line-height:1; }
.hero-meta .stat span { font-size: .78rem; letter-spacing:.12em; text-transform:uppercase; color: var(--muted-light); margin-top:.5rem; display:block; }
.hero-scroll { position:absolute; bottom: 2rem; left: 50%; transform: translateX(-50%); z-index:3; font-size:.68rem; letter-spacing:.3em; text-transform:uppercase; color: var(--muted-light); display:flex; flex-direction:column; align-items:center; gap:.7rem; }
.hero-scroll .line { width:1px; height: 46px; background: linear-gradient(var(--gold), transparent); animation: drop 2.2s var(--ease) infinite; }
@keyframes drop { 0%{transform:scaleY(0);transform-origin:top} 40%{transform:scaleY(1);transform-origin:top} 60%{transform:scaleY(1);transform-origin:bottom} 100%{transform:scaleY(0);transform-origin:bottom} }

/* marquee trust bar */
.trustbar { background: var(--navy-900); color: #8DA0BE; border-top: 1px solid var(--line-light); overflow:hidden; }
.trustbar .track { display:flex; gap: 4rem; align-items:center; padding: 1.15rem 0; white-space:nowrap; animation: marquee 32s linear infinite; }
.trustbar:hover .track { animation-play-state: paused; }
.trustbar span { font-family: var(--display); font-size: 1.15rem; letter-spacing:.02em; opacity:.8; display:inline-flex; align-items:center; gap:4rem; }
.trustbar span::after { content:"◆"; color: var(--gold); font-size:.6rem; }
@keyframes marquee { to { transform: translateX(-50%); } }

/* =====================================================================
   REVEAL ANIMATIONS
   ===================================================================== */
[data-reveal] { opacity: 0; transform: translateY(28px); transition: opacity .9s var(--ease), transform .9s var(--ease); }
[data-reveal].in { opacity: 1; transform: none; }
[data-reveal][data-delay="1"]{ transition-delay:.09s;} [data-reveal][data-delay="2"]{ transition-delay:.18s;}
[data-reveal][data-delay="3"]{ transition-delay:.27s;} [data-reveal][data-delay="4"]{ transition-delay:.36s;}
[data-reveal][data-delay="5"]{ transition-delay:.45s;}

/* =====================================================================
   INTRO / STATEMENT
   ===================================================================== */
.statement { display:grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem,5vw,5rem); align-items:center; }
.statement .big { font-family: var(--display); font-size: clamp(1.7rem, 3vw, 2.5rem); line-height: 1.25; color: var(--navy); font-weight:400; }
.statement .big em { font-style: italic; color: var(--gold-deep); }
.statement .aside p { margin-bottom: 1.2rem; }

.figure-frame { position: relative; }
.figure-frame img { border-radius: var(--radius); box-shadow: var(--shadow); aspect-ratio: 4/5; object-fit: cover; background: linear-gradient(135deg, var(--navy-800), var(--navy)); }
.figure-frame::before { content:""; position:absolute; inset: -16px -16px 16px 16px; border:1px solid var(--gold); border-radius: var(--radius); z-index:-1; }
.figure-badge { position:absolute; bottom: -22px; left: -22px; background: var(--navy); color:#fff; padding: 1.1rem 1.4rem; border-radius: var(--radius); box-shadow: var(--shadow-sm); }
.figure-badge b { font-family: var(--display); font-size: 1.9rem; display:block; line-height:1; color: var(--gold-soft); }
.figure-badge span { font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:#A9B6CC; }

/* =====================================================================
   PILLARS
   ===================================================================== */
.pillars { grid-template-columns: repeat(3, 1fr); }
.pillar { padding: 2.2rem 2rem; background: #fff; border: 1px solid var(--line); border-radius: var(--radius); transition: transform .5s var(--ease), box-shadow .5s, border-color .4s; position:relative; overflow:hidden; }
.tint .pillar { background:#fff; }
.pillar::after { content:""; position:absolute; top:0; left:0; width:100%; height:3px; background: var(--gold); transform: scaleX(0); transform-origin:left; transition: transform .5s var(--ease); }
.pillar:hover { transform: translateY(-6px); box-shadow: var(--shadow); border-color: transparent; }
.pillar:hover::after { transform: scaleX(1); }
.pillar .num { font-family: var(--display); font-size: 1rem; color: var(--gold-deep); letter-spacing:.1em; }
.pillar h3 { margin: 1rem 0 .7rem; }
.pillar p { font-size: .96rem; }

/* =====================================================================
   COURSE CARDS
   ===================================================================== */
.courses { grid-template-columns: repeat(3, 1fr); }
.course { display:flex; flex-direction:column; background:#fff; border:1px solid var(--line); border-radius: var(--radius); overflow:hidden; transition: transform .5s var(--ease), box-shadow .5s; }
.course:hover { transform: translateY(-6px); box-shadow: var(--shadow); }
.course .media { position:relative; aspect-ratio: 16/11; overflow:hidden; background: linear-gradient(135deg,var(--navy-800),var(--navy)); }
.course .media img { width:100%; height:100%; object-fit:cover; transition: transform 1.1s var(--ease); }
.course:hover .media img { transform: scale(1.06); }
.course .tag { position:absolute; top: 1rem; left: 1rem; background: rgba(7,21,40,.82); backdrop-filter: blur(6px); color: var(--gold-soft); font-size:.66rem; letter-spacing:.14em; text-transform:uppercase; font-weight:600; padding:.4rem .7rem; border-radius: 2px; }
.course .body { padding: 1.7rem 1.6rem 1.9rem; display:flex; flex-direction:column; flex:1; }
.course h3 { font-size: 1.28rem; }
.course .desc { font-size:.94rem; margin:.8rem 0 1.2rem; flex:1; }
.course .meta-row { display:flex; flex-wrap:wrap; gap:.5rem; margin-bottom:1.3rem; }
.course .chip { font-size:.72rem; font-weight:600; letter-spacing:.03em; color: var(--navy-800); background: var(--porcelain); padding:.35rem .65rem; border-radius: 2px; }
.course .price-row { display:flex; align-items:baseline; justify-content:space-between; gap:1rem; margin-bottom:1.2rem; padding-top:1.1rem; border-top:1px solid var(--line); }
.course .price { font-family: var(--display); font-size: 1.7rem; color: var(--navy); font-weight:500; }
.course .price .was { font-family: var(--body); font-size:.85rem; color: var(--muted-light); text-decoration: line-through; margin-left:.5rem; font-weight:500; }
.course .price small { display:block; font-family: var(--body); font-size:.7rem; color: var(--muted); letter-spacing:.06em; text-transform:uppercase; margin-top:.2rem; }
.course .btn { width:100%; }

/* =====================================================================
   FEATURE SPLIT
   ===================================================================== */
.split { display:grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem,5vw,5rem); align-items:center; }
.split.rev .split-media { order: 2; }
.split-media img { border-radius: var(--radius); box-shadow: var(--shadow); aspect-ratio: 5/4; object-fit: cover; background: linear-gradient(135deg,var(--navy-800),var(--navy)); }
.split ul.checks { margin-top: 1.8rem; display:grid; gap: 1rem; }
ul.checks li { display:flex; gap: .9rem; align-items:flex-start; font-size:1rem; color: var(--navy-800); }
ul.checks li svg { flex:none; width: 22px; height:22px; margin-top:2px; color: var(--gold-deep); }
.dark ul.checks li { color:#D3DCEA; }

/* stat band */
.statband { grid-template-columns: repeat(4,1fr); text-align:center; }
.statband .s b { font-family: var(--display); font-size: clamp(2.4rem,5vw,3.6rem); color: var(--gold-soft); display:block; line-height:1; font-weight:500; }
.statband .s span { font-size:.78rem; letter-spacing:.14em; text-transform:uppercase; color:#9DACC6; margin-top:.8rem; display:block; }

/* =====================================================================
   FACULTY
   ===================================================================== */
.faculty { grid-template-columns: repeat(3,1fr); }
.person { background:#fff; border:1px solid var(--line); border-radius: var(--radius); padding: 1.8rem 1.7rem; transition: transform .5s var(--ease), box-shadow .5s; }
.person:hover { transform: translateY(-5px); box-shadow: var(--shadow-sm); }
.person .avatar { width:58px; height:58px; border-radius:50%; background: linear-gradient(135deg,var(--navy),var(--navy-800)); color: var(--gold-soft); display:flex; align-items:center; justify-content:center; font-family: var(--display); font-size:1.3rem; margin-bottom:1.1rem; border:1px solid var(--gold); }
.person h3 { font-size:1.15rem; }
.person .role { font-size:.82rem; color: var(--gold-deep); font-weight:600; letter-spacing:.03em; margin-top:.35rem; }

/* =====================================================================
   TESTIMONIAL
   ===================================================================== */
.quote-wrap { max-width: 900px; margin-inline:auto; text-align:center; }
.quote-wrap .mark { font-family: var(--display); font-size: 6rem; line-height:.5; color: var(--gold); opacity:.5; }
.quote-wrap blockquote { font-family: var(--display); font-size: clamp(1.6rem,3.6vw,2.6rem); line-height:1.3; color:#fff; font-weight:400; margin:1.5rem 0; }
.quote-wrap cite { font-style:normal; font-size:.95rem; letter-spacing:.05em; color: var(--gold-soft); }
.rating { display:inline-flex; align-items:center; gap:.5rem; margin-top:2.4rem; padding:.8rem 1.4rem; border:1px solid var(--line-light); border-radius: 100px; }
.rating .stars { color: var(--gold); letter-spacing:2px; }
.rating b { color:#fff; font-family: var(--display); }
.rating span { color:#9DACC6; font-size:.86rem; }

/* =====================================================================
   FAQ
   ===================================================================== */
.faq { max-width: 860px; margin-inline:auto; }
.faq-item { border-bottom: 1px solid var(--line); }
.faq-q { width:100%; text-align:left; background:none; border:none; padding: 1.5rem 3rem 1.5rem 0; font-family: var(--display); font-size: clamp(1.1rem,2vw,1.35rem); color: var(--navy); position:relative; display:flex; }
.faq-q .ico { position:absolute; right:0; top:50%; transform: translateY(-50%); width:26px; height:26px; }
.faq-q .ico::before,.faq-q .ico::after { content:""; position:absolute; background: var(--gold-deep); transition:.4s var(--ease); }
.faq-q .ico::before { top:12px; left:3px; right:3px; height:2px; }
.faq-q .ico::after { left:12px; top:3px; bottom:3px; width:2px; }
.faq-item.open .faq-q .ico::after { transform: rotate(90deg); opacity:0; }
.faq-a { max-height:0; overflow:hidden; transition: max-height .5s var(--ease); }
.faq-a p { padding: 0 3rem 1.6rem 0; font-size:1rem; }
.faq-item.open .faq-a { max-height: 400px; }

/* =====================================================================
   CTA BANNER
   ===================================================================== */
.cta-band { position:relative; overflow:hidden; background: linear-gradient(120% 120% at 100% 0%, #12294c, var(--navy) 55%, var(--navy-900)); color:#fff; border-radius: var(--radius); padding: clamp(3rem,7vw,5.5rem) clamp(2rem,6vw,5rem); }
.cta-band::before { content:""; position:absolute; inset:0; background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60'%3E%3Cpath d='M60 0H0v60' fill='none' stroke='%23C6A15B' stroke-opacity='.08'/%3E%3C/svg%3E"); }
.cta-band .inner { position:relative; z-index:1; max-width: 680px; }
.cta-band h2 { color:#fff; }
.cta-band p { color:#B7C3D8; margin:1.1rem 0 2rem; }
.cta-actions { display:flex; flex-wrap:wrap; gap:1rem; }

/* =====================================================================
   FOOTER
   ===================================================================== */
.site-footer { background: var(--navy-900); color: #93A2BD; padding-top: clamp(3.5rem,7vw,5.5rem); }
.footer-grid { display:grid; grid-template-columns: 1.6fr 1fr 1fr 1.3fr; gap: 2.5rem; padding-bottom: 3.5rem; border-bottom:1px solid var(--line-light); }
.footer-brand .brand { color:#fff; margin-bottom:1.2rem; }
.footer-brand p { font-size:.92rem; color:#8093B0; max-width: 300px; }
.footer-social { display:flex; gap:.7rem; margin-top:1.4rem; }
.footer-social a { width:40px; height:40px; border:1px solid var(--line-light); border-radius:var(--radius); display:flex; align-items:center; justify-content:center; color:#93A2BD; transition:.35s var(--ease); }
.footer-social a:hover { background: var(--gold); color: var(--navy); border-color: var(--gold); transform: translateY(-3px); }
.footer-social svg { width:17px; height:17px; }
.site-footer h4 { color:#fff; font-family: var(--body); font-size:.76rem; letter-spacing:.18em; text-transform:uppercase; margin-bottom:1.3rem; }
.footer-links li { margin-bottom:.7rem; }
.footer-links a { font-size:.92rem; color:#93A2BD; transition: color .3s, padding-left .3s; }
.footer-links a:hover { color: var(--gold-soft); padding-left:4px; }
.footer-contact li { font-size:.92rem; margin-bottom:.9rem; display:flex; gap:.7rem; align-items:flex-start; }
.footer-contact svg { width:16px;height:16px;flex:none;color:var(--gold);margin-top:3px; }
.footer-contact a:hover { color: var(--gold-soft); }
.footer-bottom { display:flex; flex-wrap:wrap; justify-content:space-between; gap:1rem; align-items:center; padding: 1.8rem 0; font-size:.82rem; color:#6E7F9C; }
.footer-bottom nav { display:flex; gap:1.6rem; flex-wrap:wrap; }
.footer-bottom a:hover { color: var(--gold-soft); }
.hwg-note { font-size:.78rem; color:#5E6E8A; padding: 1.4rem 0 2.4rem; border-top:1px solid rgba(255,255,255,.06); max-width: 900px; }

/* =====================================================================
   PAGE HERO (interior pages)
   ===================================================================== */
.page-hero { position:relative; padding: 160px 0 clamp(3.5rem,7vw,5.5rem); background: radial-gradient(120% 130% at 85% 0%, #12294c, var(--navy) 50%, var(--navy-900)); color:#fff; overflow:hidden; }
.page-hero::after { content:""; position:absolute; inset:0; background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60'%3E%3Cpath d='M60 0H0v60' fill='none' stroke='%23C6A15B' stroke-opacity='.07'/%3E%3C/svg%3E"); }
.page-hero .wrap { position:relative; z-index:1; }
.page-hero h1 { color:#fff; font-size: clamp(2.6rem,6vw,4.6rem); margin:1.3rem 0 1.2rem; }
.page-hero .lead { color:#C5D0E2; max-width: 640px; }
.crumbs { font-size:.82rem; color:#8DA0BE; letter-spacing:.04em; }
.crumbs a:hover { color: var(--gold-soft); }

/* =====================================================================
   CONTACT
   ===================================================================== */
.contact-grid { display:grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem,5vw,4.5rem); align-items:start; }
.form-field { margin-bottom: 1.3rem; }
.form-field label { display:block; font-size:.76rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color: var(--navy-800); margin-bottom:.5rem; }
.form-field input,.form-field select,.form-field textarea { width:100%; padding: .95rem 1.1rem; border:1px solid var(--line); border-radius: var(--radius); font-family: inherit; font-size:1rem; color: var(--navy); background:#fff; transition: border-color .3s, box-shadow .3s; }
.form-field input:focus,.form-field select:focus,.form-field textarea:focus { outline:none; border-color: var(--gold); box-shadow: 0 0 0 3px rgba(198,161,91,.15); }
.form-field textarea { resize: vertical; min-height: 130px; }
.form-note { font-size:.82rem; color: var(--muted); margin-top:.6rem; }
.info-card { background:#fff; border:1px solid var(--line); border-radius: var(--radius); padding: 2rem 1.9rem; margin-bottom: 1.3rem; }
.info-card h3 { font-size:1.15rem; margin-bottom:1rem; }
.info-row { display:flex; gap:.9rem; align-items:flex-start; margin-bottom:1rem; font-size:.98rem; color: var(--navy-800); }
.info-row svg { width:20px;height:20px;color:var(--gold-deep);flex:none;margin-top:2px; }
.info-row a:hover { color: var(--gold-deep); }
.map-embed { border-radius: var(--radius); overflow:hidden; border:1px solid var(--line); box-shadow: var(--shadow-sm); }
.map-embed iframe { display:block; width:100%; height:300px; border:0; filter: grayscale(.25) contrast(1.03); }

/* =====================================================================
   LEGAL PAGES
   ===================================================================== */
.legal { max-width: 820px; }
.legal h2 { font-size: clamp(1.5rem,3vw,2rem); margin: 2.6rem 0 1rem; }
.legal h3 { font-size:1.2rem; margin: 1.8rem 0 .7rem; }
.legal p, .legal li { color: var(--muted); margin-bottom: 1rem; font-size: 1rem; }
.legal ul { list-style: disc; padding-left: 1.3rem; }
.legal ul li { margin-bottom:.5rem; }
.legal a { color: var(--gold-deep); text-decoration: underline; text-underline-offset: 3px; }
.legal strong { color: var(--navy); }
.placeholder { background: rgba(198,161,91,.14); border:1px dashed var(--gold-deep); color: var(--gold-deep); padding: .1rem .4rem; border-radius: 2px; font-weight:600; font-size:.92em; }
.legal .updated { font-size:.85rem; color: var(--muted-light); }

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width: 1000px) {
  .courses,.pillars,.faculty { grid-template-columns: repeat(2,1fr); }
  .statband { grid-template-columns: repeat(2,1fr); row-gap: 2.5rem; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap:2.2rem; }
}
@media (max-width: 780px) {
  .nav, .nav-cta .btn { display:none; }
  .burger { display:block; }
  .statement, .split, .split.rev, .contact-grid { grid-template-columns: 1fr; }
  .split.rev .split-media { order: 0; }
  .figure-frame { max-width: 440px; margin-inline:auto; }
  .hero-meta { gap: 1.6rem 2rem; }
}
@media (max-width: 560px) {
  body { font-size: 16px; }
  .courses,.pillars,.faculty { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; }
  .hero-meta .stat b { font-size: 1.7rem; }
  .figure-badge { left: 0; }
}

/* =====================================================================
   ELEVATION LAYER — brand identity, seal, timeline, refinements
   Additive rules; declared last so they take precedence.
   ===================================================================== */

/* ---------- Fonts ---------- */
:root {
  --rounded: "Baloo 2", var(--body);
  --thin:    "Josefin Sans", var(--body);
}

/* ---------- Brand lockup (header) ---------- */
.brand { gap: 0; }
.brand .mark { display: none; }               /* retire old placeholder P */
.brand-mark { height: 46px; width: auto; display: block; color: #fff; overflow: visible; }
.wm-paau     { font-family: var(--rounded); font-weight: 800; font-size: 42px; letter-spacing: -1.5px; fill: currentColor; }
.wm-ring     { fill: none; stroke: var(--gold); stroke-width: 3.4px; }
.wm-academy  { font-family: var(--thin); font-weight: 300; font-size: 12px; letter-spacing: 5.4px; fill: currentColor; fill-opacity: .78; }
.site-header .brand-mark { color: #fff; }
.site-header.scrolled .brand-mark { color: var(--navy); }

/* ---------- Seal / badge (shared) ---------- */
.seal-text  { font-family: var(--thin); font-weight: 300; letter-spacing: 3px; fill: currentColor; text-transform: uppercase; }
.seal-mark  { font-family: var(--rounded); font-weight: 800; fill: currentColor; }

/* footer full lockup + stamp */
.brand-footer { display: flex; align-items: center; gap: 1.6rem; color: #EAF0F8; }
.brand-mark-lg { height: 58px; }
.brand-seal { width: 92px; height: 92px; flex: none; color: #C7D3E6; opacity: .92; }
.brand-seal .seal-text { font-size: 9.2px; letter-spacing: 1.6px; }
.brand-seal .wm-ring { stroke: var(--gold); stroke-width: 2.6px; }
.brand-seal .seal-mark { font-size: 30px; fill: var(--gold-soft); }

/* ---------- Hero rotating seal ---------- */
.hero-seal {
  position: absolute; z-index: 3; top: clamp(96px, 15vh, 170px); right: clamp(1rem, 5vw, 4rem);
  width: clamp(150px, 20vw, 244px); aspect-ratio: 1; color: var(--gold);
  filter: drop-shadow(0 12px 40px rgba(7,21,40,.5));
}
.hero-seal svg { width: 100%; height: 100%; overflow: visible; }
.hero-seal .seal-text { font-size: 13px; letter-spacing: 4px; fill: var(--gold-soft); }
.hero-seal .seal-mark { font-size: 62px; fill: #fff; }
.seal-spin { transform-origin: 120px 120px; animation: sealspin 24s linear infinite; }
.hero-seal:hover .seal-spin { animation-play-state: paused; }
@keyframes sealspin { to { transform: rotate(360deg); } }
@media (prefers-reduced-motion: reduce) { .seal-spin { animation: none; } }
@media (max-width: 900px) { .hero-seal { display: none; } }

/* ---------- Editorial refinements ---------- */
.h-display { letter-spacing: -.028em; }
.hero h1 em, .statement .big em, .cta-band h2 { font-style: italic; }
.eyebrow::before { transition: width .5s var(--ease); }

/* gold hairline that sweeps course cards on hover */
.course { position: relative; }
.course::before { content:""; position:absolute; inset:0 0 auto 0; height:2px; background: linear-gradient(90deg, var(--gold), var(--gold-soft)); transform: scaleX(0); transform-origin: left; transition: transform .55s var(--ease); z-index: 4; }
.course:hover::before { transform: scaleX(1); }
.course .price { letter-spacing: -.01em; }
.course .price small { color: var(--gold-deep); }

/* gold numeral treatment for service prices */
.course .price { color: var(--navy); }
.tint .course:hover, .course:hover { box-shadow: 0 30px 70px -34px rgba(7,21,40,.5); }

/* magnetic primary buttons — JS sets transform; keep it smooth */
.btn-gold.is-magnetic { transition: transform .35s cubic-bezier(.33,1,.68,1), background .3s, box-shadow .5s; }

/* focus-visible polish */
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible {
  outline: 2px solid var(--gold); outline-offset: 3px; border-radius: 3px;
}
.btn:focus-visible { outline-offset: 4px; }

/* ---------- Timeline (about) ---------- */
.timeline { max-width: 780px; margin: 0 auto; position: relative; padding-left: 0; }
.timeline::before { content:""; position:absolute; left: 92px; top: 8px; bottom: 8px; width: 1px; background: linear-gradient(var(--gold), rgba(198,161,91,.15)); }
.timeline li { position: relative; display: grid; grid-template-columns: 92px 1fr; gap: 2rem; padding: 1.4rem 0 2rem; }
.timeline .t-year { font-family: var(--display); font-size: 1.15rem; color: var(--gold-deep); font-weight: 500; text-align: right; padding-right: 1.4rem; letter-spacing: -.01em; }
.timeline .t-body { position: relative; padding-left: 1.6rem; }
.timeline .t-body::before { content:""; position:absolute; left: -6px; top: 6px; width: 11px; height: 11px; border-radius: 50%; background: var(--gold); box-shadow: 0 0 0 5px rgba(198,161,91,.16); }
.timeline .t-body h3 { font-size: 1.25rem; margin-bottom: .5rem; }
.timeline .t-body p { font-size: .98rem; }
@media (max-width: 560px) {
  .timeline::before { left: 5px; }
  .timeline li { grid-template-columns: 1fr; gap: .3rem; padding-left: 1.6rem; }
  .timeline .t-year { text-align: left; padding-right: 0; }
  .timeline .t-body { padding-left: 0; }
  .timeline .t-body::before { left: -1.6rem; }
}

/* ---------- Print-friendly legal pages ---------- */
@media print {
  .site-header, .mobile-nav, .site-footer, .page-hero::after, .hero-seal { display: none !important; }
  body { color: #000; font-size: 12pt; }
  .page-hero { background: none; color: #000; padding: 1rem 0; }
  .page-hero h1, .page-hero .lead, .crumbs { color: #000; }
  .legal a { color: #000; }
  .placeholder { border-color: #999; color: #333; }
}
