/* The Production Academy — website UI kit styles. Tokens come from colors_and_type.css */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font-body);color:var(--color-ink);background:var(--neutral-0);-webkit-font-smoothing:antialiased}
.tpa-wrap{max-width:var(--container-max);margin:0 auto;padding:0 var(--gutter)}
img{max-width:100%}
a{color:inherit;text-decoration:none}

/* ---------- buttons ---------- */
.tpa-btn{font-family:var(--font-body);font-weight:600;font-size:15px;letter-spacing:.02em;border:none;border-radius:var(--radius-pill);padding:14px 28px;cursor:pointer;text-decoration:none;transition:transform .15s ease,box-shadow .2s ease,background .2s ease,color .2s ease;display:inline-flex;align-items:center;gap:9px;line-height:1}
.tpa-btn--full{width:100%;justify-content:center}
.tpa-btn--primary{background:var(--ink-900);color:#fff}
.tpa-btn--primary:hover{background:var(--ink-700);box-shadow:var(--shadow-md)}
.tpa-btn--accent{background:var(--pink-300);color:var(--ink-900)}
.tpa-btn--accent:hover{background:var(--pink-400);box-shadow:var(--shadow-pink)}
.tpa-btn--outline{background:transparent;color:var(--ink-900);border:1.5px solid var(--ink-900)}
.tpa-btn--outline:hover{background:var(--ink-900);color:#fff}
.tpa-btn--ghost{background:transparent;color:var(--ink-900);padding-left:8px;padding-right:8px}
.tpa-btn--ghost:hover{color:var(--pink-600)}
.tpa-btn--light{background:#fff;color:var(--ink-900)}
.tpa-btn--light:hover{box-shadow:var(--shadow-md)}
.tpa-btn:active{transform:scale(.97)}

/* ---------- badges ---------- */
.tpa-badge{font-weight:700;font-size:12px;letter-spacing:.07em;text-transform:uppercase;padding:6px 13px;border-radius:var(--radius-pill);display:inline-flex;align-items:center;gap:6px;line-height:1}
.tpa-badge--pink{background:var(--pink-100);color:var(--pink-700)}
.tpa-badge--ink{background:var(--ink-900);color:#fff}
.tpa-badge--pink-invert{background:rgba(252,187,232,.16);color:var(--pink-300)}
.tpa-badge--out{background:transparent;color:var(--ink-900);border:1.5px solid var(--color-line-strong)}
.tpa-badge--feature{background:var(--pink-300);color:var(--ink-900);box-shadow:var(--shadow-pink);padding:6px 15px 6px 11px;letter-spacing:.1em}
.tpa-badge--feature svg{margin-top:-1px}

.tpa-eyebrow{font-family:var(--font-body);font-weight:700;font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-900);background:var(--pink-300);display:inline-block;padding:5px 12px 4px;border-radius:var(--radius-pill);line-height:1.45}

/* ---------- photo placeholder ---------- */
.tpa-photo{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;overflow:hidden}
.tpa-photo__cap{font-size:12px;letter-spacing:.04em}

/* ---------- display headings ---------- */
.tpa-display{font-family:var(--font-display);text-transform:uppercase;line-height:.9;letter-spacing:.01em;margin:0}
.tpa-script{font-family:var(--font-script);text-transform:none;line-height:.8;color:var(--pink-300)}

/* ---------- nav ---------- */
.tpa-nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--color-line)}
.tpa-nav__in{display:flex;align-items:center;justify-content:space-between;height:72px}
.tpa-logo{display:flex;flex-direction:column;line-height:.82;cursor:pointer;color:var(--ink-900);text-decoration:none}
.tpa-logo b{font-family:var(--font-display);font-size:15px;letter-spacing:.04em}
.tpa-logo .l2{display:flex;align-items:center;gap:4px;font-family:var(--font-display);font-size:22px;letter-spacing:.02em}
.tpa-nav__links{display:flex;gap:26px;align-items:center}
.tpa-nav__links .tpa-nav__item>a{font-size:15px;font-weight:500;white-space:nowrap;color:var(--color-ink);text-decoration:none;transition:color .15s}
.tpa-nav__links .tpa-nav__item>a:hover{color:var(--pink-600)}
.tpa-nav__login{display:inline-flex;align-items:center;gap:6px;white-space:nowrap;border:1.5px solid var(--ink-900);padding:9px 16px;font-weight:600;font-size:14px;text-decoration:none;color:var(--ink-900)!important;transition:background .15s,color .15s}
.tpa-nav__login:hover{background:var(--ink-900);color:#fff!important}
.tpa-nav__login svg{flex:0 0 auto}
@media(max-width:1024px){.tpa-nav__links{display:none}}

/* ---------- hero ---------- */
.tpa-hero{background:var(--black);color:#fff;position:relative;overflow:hidden}
.tpa-hero__in{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;padding:72px var(--gutter) 80px}
.tpa-hero h1{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(3.4rem,7vw,6.4rem);line-height:.86;margin:0;letter-spacing:.01em}
.tpa-hero .tpa-script{font-size:clamp(2.6rem,5vw,4.2rem);margin:-6px 0 0}
.tpa-hero p{color:rgba(255,255,255,.72);font-size:18px;line-height:1.55;max-width:430px;margin:22px 0 30px}
.tpa-hero__cta{display:flex;gap:14px;flex-wrap:wrap}
.tpa-hero__photo{position:relative}
.tpa-hero__chip{position:absolute;left:-16px;bottom:24px;background:#fff;color:var(--ink-900);border-radius:var(--radius-md);padding:12px 16px;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:10px}
.tpa-hero__chip b{font-family:var(--font-display);font-size:26px;line-height:.8}
.tpa-hero__chip span{font-size:12px;color:var(--color-ink-soft);line-height:1.2}
@media(max-width:860px){.tpa-hero__in{grid-template-columns:1fr;gap:34px;padding:48px var(--gutter) 56px}.tpa-hero__photo{order:-1}}

/* ---------- marquee strip ---------- */
.tpa-strip{background:var(--pink-300);color:var(--ink-900);overflow:hidden;white-space:nowrap;padding:12px 0}
.tpa-strip__track{display:inline-flex;gap:42px;align-items:center;animation:tpa-marq 22s linear infinite}
.tpa-strip span{font-family:var(--font-display);font-size:22px;letter-spacing:.04em;text-transform:uppercase;display:inline-flex;align-items:center;gap:42px}
@keyframes tpa-marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- section ---------- */
.tpa-sec{padding:86px 0}
.tpa-sec--alt{background:var(--neutral-50)}
.tpa-sec__head{max-width:640px;margin-bottom:44px}
.tpa-sec__head h2{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(2.4rem,4.2vw,3.6rem);line-height:.92;margin:12px 0 0}

/* ---------- program cards ---------- */
.tpa-progs{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:860px){.tpa-progs{grid-template-columns:1fr}}
.tpa-prog{background:#fff;border:1px solid var(--color-line);border-radius:var(--radius-lg);overflow:hidden;transition:transform .2s ease,box-shadow .2s ease;cursor:pointer;display:flex;flex-direction:column}
.tpa-prog:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.tpa-prog__body{padding:20px 22px 24px}
.tpa-prog__body h3{font-family:var(--font-display);text-transform:uppercase;font-size:26px;line-height:.95;margin:12px 0 8px}
.tpa-prog__body p{font-size:14.5px;line-height:1.5;color:var(--color-ink-soft);margin:0 0 16px}
.tpa-prog__meta{display:flex;align-items:center;gap:7px;font-size:13px;color:var(--color-ink-faint);font-weight:600}

/* ---------- belong / values ---------- */
.tpa-num{font-family:var(--font-display);font-size:18px;letter-spacing:.14em;color:var(--pink-500);display:block;margin-bottom:12px;-webkit-text-stroke:0}
.tpa-num{color:var(--ink-900)}
.tpa-belong{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--color-line);border-radius:var(--radius-lg);overflow:hidden;background:#fff}
.tpa-val{padding:34px 30px;border-right:1px solid var(--color-line)}
.tpa-val:last-child{border-right:none}
.tpa-val__ic{width:48px;height:48px;border-radius:var(--radius-md);background:var(--pink-100);color:var(--pink-700);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.tpa-val h3{font-family:var(--font-display);text-transform:uppercase;font-size:30px;margin:0 0 8px;line-height:.9}
.tpa-val p{font-size:15px;line-height:1.55;color:var(--color-ink-soft);margin:0}
@media(max-width:860px){.tpa-belong{grid-template-columns:1fr}.tpa-val{border-right:none;border-bottom:1px solid var(--color-line)}.tpa-val:last-child{border-bottom:none}}

/* ---------- showcase / quote ---------- */
.tpa-quote{background:var(--black);color:#fff;border-radius:var(--radius-xl);padding:64px 56px;display:grid;grid-template-columns:1fr auto;gap:48px;align-items:center}
.tpa-quote blockquote{margin:0;font-family:var(--font-display);text-transform:uppercase;font-size:clamp(2rem,3.4vw,3rem);line-height:1.02}
.tpa-quote blockquote .tpa-script{display:block;text-transform:none;font-size:clamp(2.4rem,4vw,3.4rem);margin-top:6px}
.tpa-quote__by{margin-top:22px;font-size:15px;color:rgba(255,255,255,.6)}
.tpa-stats{display:flex;gap:34px}
.tpa-stat b{font-family:var(--font-display);font-size:58px;line-height:.8;display:block;color:var(--pink-300)}
.tpa-stat span{font-size:13px;color:rgba(255,255,255,.65);letter-spacing:.04em}
@media(max-width:860px){.tpa-quote{grid-template-columns:1fr;padding:40px 30px;gap:30px}.tpa-stats{gap:24px}}

/* ---------- cta band ---------- */
.tpa-ctaband{background:var(--pink-300);color:var(--ink-900);border-radius:var(--radius-xl);padding:60px;text-align:center}
.tpa-ctaband h2{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(2.6rem,5vw,4.4rem);line-height:.9;margin:0}
.tpa-ctaband .tpa-script{color:var(--ink-900);font-size:clamp(2.2rem,4vw,3.4rem);text-transform:none}
.tpa-ctaband p{font-size:17px;margin:16px auto 28px;max-width:440px;color:rgba(10,10,11,.7)}

/* ---------- footer ---------- */
.tpa-foot{background:var(--black);color:#fff;padding:64px 0 36px}
.tpa-foot__top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px;padding-bottom:42px;border-bottom:1px solid rgba(255,255,255,.12)}
.tpa-foot h4{font-family:var(--font-body);font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.5);margin:0 0 16px;font-weight:700}
.tpa-foot a{display:block;color:rgba(255,255,255,.82);text-decoration:none;font-size:15px;margin-bottom:11px;transition:color .15s}
.tpa-foot a:hover{color:var(--pink-300)}
.tpa-foot__brand img{width:150px;height:auto;margin-bottom:14px}
.tpa-foot__brand p{color:rgba(255,255,255,.6);font-size:14px;line-height:1.55;max-width:240px;margin:0}
.tpa-foot__bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;font-size:13px;color:rgba(255,255,255,.5)}
.tpa-foot__social{display:flex;gap:14px}
.tpa-foot__social a{display:inline-flex;color:#fff;margin:0;transition:color .15s}
.tpa-foot__social a:hover{color:var(--pink-300)}

/* ============ real images ============ */
.tpa-img{overflow:hidden;background:var(--neutral-100);position:relative}
.tpa-img img{width:100%;height:100%;object-fit:cover;display:block}

/* ============ nav dropdown / burger / drawer ============ */
.tpa-nav__item{position:relative;display:flex;align-items:center}
.tpa-nav__item>a{display:inline-flex;align-items:center}
.tpa-nav__links a.is-active{color:var(--pink-600)}
.tpa-nav__menu{position:absolute;top:100%;left:-14px;padding-top:14px;background:transparent;min-width:210px;opacity:0;visibility:hidden;transform:translateY(6px);transition:all .16s ease;z-index:60}
.tpa-nav__item.has-menu:hover .tpa-nav__menu{opacity:1;visibility:visible;transform:none}
.tpa-nav__menu>a{display:flex;align-items:center;background:#fff;border:1px solid var(--color-line);border-bottom:none;padding:13px 16px;font-size:14px;font-weight:500}
.tpa-nav__menu>a:first-child{border-top:3px solid var(--pink-300)}
.tpa-nav__menu>a:last-child{border-bottom:1px solid var(--color-line)}
.tpa-nav__menu>a:hover{background:var(--pink-50);color:var(--pink-700)}
.tpa-nav__menu>a.is-cta{background:var(--pink-300);color:var(--ink-900);font-weight:700}
.tpa-nav__menu>a.is-cta:hover{background:var(--pink-400)}
.tpa-nav__burger{display:none;background:none;border:none;cursor:pointer;color:var(--ink-900)}
.tpa-nav__drawer{display:none}
@media(max-width:1024px){
  .tpa-nav__burger{display:flex}
  .tpa-nav__drawer{display:flex;flex-direction:column;background:#fff;border-top:1px solid var(--color-line)}
  .tpa-nav__drawer a{padding:16px var(--gutter);border-bottom:1px solid var(--color-line);font-weight:600;color:var(--ink-900);text-decoration:none}
  .tpa-nav__drawer a.drawer-cta{background:var(--ink-900);color:#fff}
  .tpa-nav__drawer .drawer-head{padding:14px var(--gutter) 6px;font-family:var(--font-body);font-weight:700;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--color-ink-faint)}
}

/* ============ chat widget ============ */
.tpa-chat{position:fixed;right:22px;bottom:22px;z-index:200;display:flex;flex-direction:column;align-items:flex-end;gap:14px}
.tpa-chat__launch{width:60px;height:60px;background:var(--ink-900);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);transition:background .18s,transform .15s}
.tpa-chat__launch:hover{background:var(--pink-300);color:var(--ink-900)}
.tpa-chat__launch:active{transform:scale(.95)}
.tpa-chat__panel{width:340px;max-width:calc(100vw - 44px);background:#fff;box-shadow:var(--shadow-lg);border:1px solid var(--color-line);overflow:hidden;animation:tpa-rise .2s ease}
.tpa-chat__head{display:flex;align-items:center;gap:12px;padding:16px;background:var(--black);color:#fff}
.tpa-chat__avatar{width:40px;height:40px;background:var(--pink-300);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.tpa-chat__avatar svg path{fill:var(--ink-900)}
.tpa-chat__head strong{display:block;font-size:14px}
.tpa-chat__head span{font-size:12px;color:rgba(255,255,255,.6)}
.tpa-chat__close{margin-left:auto;background:none;border:none;color:#fff;cursor:pointer;align-self:flex-start}
.tpa-chat__body{padding:18px 16px;background:var(--neutral-50)}
.tpa-chat__bubble{background:#fff;border:1px solid var(--color-line);padding:13px 15px;font-size:14px;line-height:1.5;color:var(--color-ink)}
.tpa-chat__actions{display:flex;flex-direction:column;gap:8px;padding:0 16px 14px;background:var(--neutral-50)}
.tpa-chat__btn{text-align:center;padding:12px;font-weight:600;font-size:14px;text-decoration:none;background:var(--ink-900);color:#fff}
.tpa-chat__btn.ghost{background:#fff;color:var(--ink-900);border:1.5px solid var(--ink-900)}
.tpa-chat__btn:hover{opacity:.9}
.tpa-chat__note{text-align:center;font-size:11px;color:var(--color-ink-faint);padding:10px;letter-spacing:.03em}

/* ============ page hero (inner pages) ============ */
.tpa-phero{background:var(--black);color:#fff;padding:70px 0 64px}
.tpa-phero__in{display:flex;flex-direction:column;gap:14px}
.tpa-phero .tpa-eyebrow{color:var(--pink-300);background:none;padding:0;border-radius:0}
.tpa-phero h1{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(3rem,6vw,5.5rem);line-height:.88;margin:0}
.tpa-phero .tpa-script{font-size:clamp(2.2rem,4vw,3.4rem);margin:-4px 0 0}
.tpa-phero p{color:rgba(255,255,255,.72);font-size:18px;line-height:1.55;max-width:560px;margin:10px 0 0}
.tpa-crumbs{font-size:13px;color:rgba(255,255,255,.5);margin-bottom:6px;letter-spacing:.04em}
.tpa-crumbs a{color:rgba(255,255,255,.5);text-decoration:none}
.tpa-crumbs a:hover{color:var(--pink-300)}

/* ============ class list rows ============ */
.tpa-classrow{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,1fr);gap:0;border:1px solid var(--color-line);margin-bottom:22px;background:#fff}
.tpa-classrow:nth-child(even){direction:rtl}
.tpa-classrow:nth-child(even)>*{direction:ltr}
.tpa-classrow .tpa-img{height:100%;min-height:300px}
.tpa-classrow__body{padding:36px 40px;display:flex;flex-direction:column;justify-content:center}
.tpa-classrow__body h3{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(2rem,3vw,2.8rem);line-height:.94;margin:14px 0 10px}
.tpa-classrow__body p{font-size:15.5px;line-height:1.6;color:var(--color-ink-soft);margin:0 0 18px}
.tpa-classrow__meta{display:flex;gap:18px;flex-wrap:wrap;margin-bottom:22px}
.tpa-classrow__meta span{display:flex;align-items:center;gap:7px;font-size:13.5px;font-weight:600;color:var(--color-ink-soft)}
@media(max-width:760px){.tpa-classrow{grid-template-columns:1fr}.tpa-classrow:nth-child(even){direction:ltr}.tpa-classrow .tpa-img{min-height:240px}.tpa-classrow__body{padding:28px 24px}}
.tpa-classrow__ph{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;background:var(--ink-900);color:rgba(255,255,255,.5);min-height:300px}
.tpa-classrow__ph span{font-size:12px;letter-spacing:.1em;text-transform:uppercase}
.tpa-classrow.is-lead .tpa-classrow__body{background:var(--pink-50)}
.tpa-genres{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.tpa-genre{font-size:13px;font-weight:600;color:var(--ink-900);background:#fff;border:1px solid var(--color-line-strong);padding:7px 15px;border-radius:var(--radius-pill);transition:border-color .15s,color .15s}
.tpa-genre:hover{border-color:var(--ink-900)}
.tpa-classrow.is-lead .tpa-genre{background:#fff}
.tpa-classrow.is-lead .tpa-genre:hover{border-color:var(--pink-400);color:var(--pink-700)}

/* ============ browse by age, bands ============ */
.tpa-agelist{display:flex;flex-direction:column;margin-top:34px;border-top:1px solid var(--color-line)}
.tpa-ageband{display:grid;grid-template-columns:minmax(0,300px) 1fr;gap:32px;padding:30px 0;border-bottom:1px solid var(--color-line);align-items:start}
.tpa-ageband__head h3{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(2rem,3vw,2.8rem);line-height:.9;margin:0 0 4px}
.tpa-ageband__range{display:inline-block;font-weight:700;font-size:12.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-900);background:var(--pink-300);padding:5px 12px 4px;border-radius:var(--radius-pill);margin-bottom:12px}
.tpa-ageband__head p{font-size:14.5px;line-height:1.55;color:var(--color-ink-soft);margin:0 0 18px}
.tpa-ageband__classes{display:flex;flex-wrap:wrap;gap:8px;align-content:flex-start;padding-top:4px}
@media(max-width:760px){.tpa-ageband{grid-template-columns:1fr;gap:18px}}

/* ============ gallery ============ */
.tpa-gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.tpa-gallery .tpa-img:first-child{grid-row:span 2;grid-column:span 2}
@media(max-width:760px){.tpa-gallery{grid-template-columns:repeat(2,1fr)}.tpa-gallery .tpa-img:first-child{grid-row:auto;grid-column:span 2}}

/* ============ team / pathways cards ============ */
.tpa-cardgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:860px){.tpa-cardgrid{grid-template-columns:1fr}}
.tpa-feature{background:#fff;border:1px solid var(--color-line)}
.tpa-feature__body{padding:22px 24px 26px}
.tpa-feature__body h3{font-family:var(--font-display);text-transform:uppercase;font-size:24px;line-height:.95;margin:0 0 8px}
.tpa-feature__body p{font-size:14.5px;line-height:1.55;color:var(--color-ink-soft);margin:0}

/* ============ contact ============ */
.tpa-contact{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
@media(max-width:860px){.tpa-contact{grid-template-columns:1fr;gap:32px}}
.tpa-contact__list{display:flex;flex-direction:column;gap:4px}
.tpa-cline{display:flex;gap:16px;align-items:flex-start;padding:18px 0;border-bottom:1px solid var(--color-line)}
.tpa-cline__ic{width:44px;height:44px;flex:0 0 auto;background:var(--pink-100);color:var(--pink-700);display:flex;align-items:center;justify-content:center}
.tpa-cline h4{font-family:var(--font-body);font-weight:700;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--color-ink-soft);margin:2px 0 5px}
.tpa-cline a,.tpa-cline p{font-size:16px;color:var(--color-ink);text-decoration:none;margin:0;font-weight:500}
.tpa-cline a:hover{color:var(--pink-600)}
.tpa-form{background:var(--neutral-50);border:1px solid var(--color-line);padding:30px}
.tpa-form h3{font-family:var(--font-display);text-transform:uppercase;font-size:28px;margin:0 0 18px}
.tpa-form .tpa-field{margin-bottom:14px}
.tpa-map{margin-top:14px;border:1px solid var(--color-line)}
.tpa-map .tpa-img{filter:grayscale(1) contrast(1.05)}

/* ============ pathway ladder ============ */
.tpa-ladder{display:grid;gap:0;border-top:1px solid var(--color-line)}
.tpa-ladder__step{display:grid;grid-template-columns:auto 1fr;gap:26px;align-items:start;padding:26px 0;border-bottom:1px solid var(--color-line)}
.tpa-ladder__n{font-family:var(--font-display);font-size:clamp(2.4rem,4vw,3.4rem);line-height:.8;color:var(--pink-400)}
.tpa-ladder__step h3{font-family:var(--font-display);text-transform:uppercase;font-size:24px;margin:6px 0 6px;line-height:.95}
.tpa-ladder__step p{font-size:15.5px;line-height:1.55;color:var(--color-ink-soft);margin:0;max-width:620px}

/* ============ pillars (4-up) ============ */
.tpa-pillars{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--color-line);background:#fff}
.tpa-pillars .tpa-val{border-right:1px solid var(--color-line)}
.tpa-pillars .tpa-val:last-child{border-right:none}
@media(max-width:860px){.tpa-pillars{grid-template-columns:1fr 1fr}.tpa-pillars .tpa-val{border-bottom:1px solid var(--color-line)}.tpa-pillars .tpa-val:nth-child(even){border-right:none}}
@media(max-width:520px){.tpa-pillars{grid-template-columns:1fr}.tpa-pillars .tpa-val{border-right:none}}

/* ============ testimonials ============ */
.tpa-tgrid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:760px){.tpa-tgrid{grid-template-columns:1fr}}
.tpa-tcard{margin:0;background:#fff;border:1px solid var(--color-line);padding:30px}
.tpa-tcard blockquote{margin:16px 0 18px;font-size:20px;line-height:1.45;color:var(--color-ink);font-weight:500;text-wrap:pretty}
.tpa-tcard figcaption{font-weight:700;font-size:14px;color:var(--color-ink)}
.tpa-tcard figcaption span{font-weight:400;color:var(--color-ink-faint)}

/* ============ disciplines, artistic image tiles ============ */
.tpa-tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.tpa-tile{position:relative;display:flex;flex-direction:column;justify-content:flex-end;min-height:300px;padding:22px;text-decoration:none;color:#fff;overflow:hidden;background-color:var(--ink-900);background-size:cover;background-position:center;isolation:isolate}
.tpa-tile::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,11,.15) 0%,rgba(10,10,11,.45) 48%,rgba(10,10,11,.88) 100%);z-index:0;transition:background .25s ease}
.tpa-tile::after{content:"";position:absolute;inset:0;background:var(--pink-300);opacity:0;mix-blend-mode:multiply;z-index:0;transition:opacity .25s ease}
.tpa-tile:hover::after{opacity:.32}
.tpa-tile:hover::before{background:linear-gradient(180deg,rgba(10,10,11,.1) 0%,rgba(10,10,11,.4) 45%,rgba(10,10,11,.9) 100%)}
.tpa-tile>*{position:relative;z-index:1}
.tpa-tile__n{position:absolute;top:18px;left:22px;font-family:var(--font-display);font-size:20px;letter-spacing:.12em;color:var(--pink-300);z-index:1}
.tpa-tile__foot{display:flex;flex-direction:column;gap:6px}
.tpa-tile__foot h3{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(2rem,3vw,2.9rem);line-height:.9;margin:0;color:#fff;text-shadow:0 2px 18px rgba(0,0,0,.45)}
.tpa-tile__more{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.85)}
.tpa-tile__more i{font-style:normal;transition:transform .2s ease}
.tpa-tile:hover .tpa-tile__more i{transform:translateX(5px)}
@media(max-width:860px){.tpa-tiles{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.tpa-tiles{grid-template-columns:1fr}.tpa-tile{min-height:240px}}

/* ============ disciplines — typographic grid (no icons) ============ */
.tpa-teach{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--color-line);border-left:1px solid var(--color-line)}
.tpa-teach__card{border-right:1px solid var(--color-line);border-bottom:1px solid var(--color-line);padding:30px 28px 36px;transition:background .2s ease,color .2s ease}
.tpa-teach__card:hover{background:var(--ink-900)}
.tpa-teach__n{font-family:var(--font-display);font-size:15px;letter-spacing:.12em;color:var(--pink-500)}
.tpa-teach__card h3{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(2rem,2.6vw,2.6rem);line-height:.9;margin:12px 0 9px;color:var(--ink-900);transition:color .2s ease}
.tpa-teach__card p{font-size:14.5px;line-height:1.5;color:var(--color-ink-soft);margin:0;transition:color .2s ease}
.tpa-teach__card:hover h3{color:#fff}
.tpa-teach__card:hover p{color:rgba(255,255,255,.7)}
.tpa-teach__card:hover .tpa-teach__n{color:var(--pink-300)}
@media(max-width:860px){.tpa-teach{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.tpa-teach{grid-template-columns:1fr}}

/* ============ team grid ============ */
.tpa-teamgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:860px){.tpa-teamgrid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.tpa-teamgrid{grid-template-columns:1fr}}
.tpa-team{background:#fff;border:1px solid var(--color-line)}
.tpa-team__photo{aspect-ratio:5 / 6;overflow:hidden;background:#efece9;position:relative}
.tpa-team__photo img{width:100%;height:100%;object-fit:cover;display:block;transform-origin:top center}
.tpa-team__body{padding:20px 22px 24px}
.tpa-team__body h3{font-family:var(--font-display);text-transform:uppercase;font-size:26px;line-height:.95;margin:6px 0 12px}
.tpa-team__body p{font-size:14px;line-height:1.55;color:var(--color-ink-soft);margin:0}
.tpa-team__ph{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;background:var(--ink-900)}
.tpa-team__ph span{font-family:var(--font-display);font-size:64px;line-height:.8;color:var(--pink-300);letter-spacing:.04em}
.tpa-team__ph em{font-style:normal;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.45)}

/* ============ 4-up card grid ============ */
.tpa-cardgrid--4{grid-template-columns:repeat(4,1fr)}
@media(max-width:980px){.tpa-cardgrid--4{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.tpa-cardgrid--4{grid-template-columns:1fr}}
.tpa-cardgrid--3{grid-template-columns:repeat(3,1fr)}
@media(max-width:860px){.tpa-cardgrid--3{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.tpa-cardgrid--3{grid-template-columns:1fr}}

/* ============ events ============ */
.tpa-events{display:flex;flex-direction:column;border-top:1px solid var(--color-line)}
.tpa-event{display:grid;grid-template-columns:auto 1fr auto;gap:28px;align-items:center;padding:24px 4px;border-bottom:1px solid var(--color-line)}
.tpa-event__date{width:84px;text-align:center;background:var(--pink-100);padding:12px 0;flex:0 0 auto}
.tpa-event__date .m{display:block;font-family:var(--font-display);font-size:18px;letter-spacing:.08em;color:var(--pink-700)}
.tpa-event__date .d{display:block;font-family:var(--font-display);font-size:38px;line-height:.8;color:var(--ink-900)}
.tpa-event__body h3{font-family:var(--font-display);text-transform:uppercase;font-size:26px;line-height:.96;margin:10px 0 6px}
.tpa-event__where{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--color-ink-faint);font-weight:600;margin-bottom:8px}
.tpa-event__body p{font-size:14.5px;line-height:1.55;color:var(--color-ink-soft);margin:0;max-width:560px}
.tpa-event__cta{flex:0 0 auto}
@media(max-width:760px){.tpa-event{grid-template-columns:auto 1fr;gap:18px}.tpa-event__cta{grid-column:1 / -1;justify-self:start}}

/* ============ timetable ============ */
.tpa-tt__bar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;margin-bottom:24px}
.tpa-tt{border-top:2px solid var(--ink-900)}
.tpa-tt__day{border-bottom:1px solid var(--color-line);padding:22px 0}
.tpa-tt__day h3{font-family:var(--font-display);text-transform:uppercase;font-size:30px;margin:0 0 10px;line-height:.9}
.tpa-tt__row{display:grid;grid-template-columns:120px 1fr auto auto;gap:20px;align-items:center;padding:13px 0;border-top:1px solid var(--color-line)}
.tpa-tt__time{font-weight:700;font-size:14px;font-variant-numeric:tabular-nums}
.tpa-tt__name{font-family:var(--font-display);text-transform:uppercase;font-size:22px;line-height:.95;display:flex;flex-direction:column;gap:3px}
.tpa-tt__name em{font-style:normal;font-family:var(--font-body);font-weight:500;font-size:12px;letter-spacing:.03em;text-transform:none;color:var(--color-ink-faint)}
.tpa-tt__star{color:var(--pink-500);font-style:normal;margin-left:7px;font-size:15px}
.tpa-tt__cta{padding:9px 24px;font-size:14px}

/* ============ productions ============ */
.tpa-prodlist{display:flex;flex-direction:column;gap:0}
.tpa-prod{display:grid;grid-template-columns:1.1fr 1fr;gap:0;border:1px solid var(--color-line);border-bottom:none}
.tpa-prod:last-child{border-bottom:1px solid var(--color-line)}
.tpa-prod:nth-child(even){direction:rtl}
.tpa-prod:nth-child(even)>*{direction:ltr}
.tpa-prod__media{min-height:340px}
.tpa-prod__media .tpa-img{height:100%}
.tpa-prod__ph{height:100%;min-height:340px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;background:var(--ink-900);color:rgba(255,255,255,.5)}
.tpa-prod__ph span{font-size:12px;letter-spacing:.1em;text-transform:uppercase}
.tpa-prod__body{padding:44px 46px;display:flex;flex-direction:column;justify-content:center}
.tpa-prod__body h2{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(2.4rem,3.6vw,3.4rem);line-height:.92;margin:14px 0 12px}
.tpa-prod__body p{font-size:16px;line-height:1.6;color:var(--color-ink-soft);margin:0 0 22px;max-width:460px}
.tpa-prod__body .tpa-btn{align-self:flex-start}
@media(max-width:760px){.tpa-prod{grid-template-columns:1fr}.tpa-prod:nth-child(even){direction:ltr}.tpa-prod__media,.tpa-prod__ph{min-height:240px}.tpa-prod__body{padding:32px 26px}}
@media(max-width:760px){
  .tpa-tt__row{grid-template-columns:1fr auto;gap:6px 14px}
  .tpa-tt__time{grid-column:1;grid-row:1;font-size:13px;align-self:center}
  .tpa-tt__age{grid-column:2;grid-row:1;justify-self:end}
  .tpa-tt__name{grid-column:1 / -1;grid-row:2}
  .tpa-tt__cta{grid-column:1 / -1;grid-row:3;justify-self:start;margin-top:6px}
}
.tpa-foot__social i{color:#fff}
@media(max-width:860px){.tpa-foot__top{grid-template-columns:1fr 1fr}}

/* ---------- modal ---------- */
.tpa-modal__scrim{position:fixed;inset:0;background:rgba(10,10,11,.6);backdrop-filter:blur(3px);z-index:100;display:flex;align-items:center;justify-content:center;padding:24px;animation:tpa-fade .2s ease}
.tpa-modal{background:#fff;border-radius:var(--radius-xl);width:100%;max-width:460px;padding:32px;position:relative;box-shadow:var(--shadow-lg);animation:tpa-rise .25s ease}
.tpa-modal__x{position:absolute;top:18px;right:18px;background:var(--neutral-100);border:none;border-radius:0;width:36px;height:36px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--color-ink)}
.tpa-modal__x:hover{background:var(--neutral-200)}
.tpa-modal h3{font-family:var(--font-display);text-transform:uppercase;font-size:34px;line-height:.92;margin:6px 0 4px}
.tpa-modal .tpa-script{font-size:30px}
.tpa-modal p{color:var(--color-ink-soft);font-size:15px;margin:6px 0 22px;line-height:1.5}
.tpa-field{margin-bottom:16px}
.tpa-field label{display:block;font-weight:700;font-size:12px;letter-spacing:.05em;text-transform:uppercase;color:var(--color-ink-soft);margin-bottom:7px}
.tpa-field input,.tpa-field select{width:100%;font-family:var(--font-body);font-size:15px;padding:12px 14px;border:1px solid var(--color-line-strong);border-radius:var(--radius-md);background:#fff;outline:none;transition:border .15s,box-shadow .15s}
.tpa-field input:focus,.tpa-field select:focus{border-color:var(--pink-500);box-shadow:0 0 0 3px var(--pink-100)}
.tpa-steps{display:flex;gap:6px;margin-bottom:20px}
.tpa-steps i{height:5px;border-radius:0;flex:1;background:var(--neutral-200)}
.tpa-steps i.on{background:var(--pink-400)}
.tpa-done{text-align:center;padding:14px 0}
.tpa-done__check{width:64px;height:64px;border-radius:0;background:var(--color-success-bg);color:var(--color-success);display:flex;align-items:center;justify-content:center;margin:0 auto 18px}
@keyframes tpa-fade{from{opacity:0}to{opacity:1}}
@keyframes tpa-rise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}

/* ============ party with tpa ============ */
.tpa-pkggrid{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start}
@media(max-width:760px){.tpa-pkggrid{grid-template-columns:1fr}}
.tpa-pkg{background:#fff;border:1px solid var(--color-line);display:flex;flex-direction:column}
.tpa-pkg.is-vip{border:1.5px solid var(--pink-300);box-shadow:var(--shadow-pink)}
.tpa-pkg__head{padding:30px 32px 24px;border-bottom:1px solid var(--color-line)}
.tpa-pkg__name{font-family:var(--font-display);text-transform:uppercase;font-size:30px;line-height:.95;margin:14px 0 16px}
.tpa-pkg__price{display:flex;align-items:baseline;gap:10px}
.tpa-pkg__price b{font-family:var(--font-display);font-size:54px;line-height:.8;color:var(--ink-900)}
.tpa-pkg__price span{font-size:14px;font-weight:600;color:var(--pink-700);letter-spacing:.03em}
.tpa-pkg__list{list-style:none;margin:0;padding:24px 32px;display:flex;flex-direction:column;gap:14px;flex:1}
.tpa-pkg__list li{display:flex;gap:12px;align-items:flex-start;font-size:15px;line-height:1.5;color:var(--color-ink-soft)}
.tpa-pkg__list li svg{flex:0 0 auto;margin-top:3px}
.tpa-pkg__note{margin:0;padding:0 32px 28px;font-size:13px;color:var(--color-ink-faint);line-height:1.5}
.tpa-runcol{background:#fff;border:1px solid var(--color-line);padding:30px 32px}
.tpa-runcol h3{font-family:var(--font-display);text-transform:uppercase;font-size:24px;line-height:.95;margin:6px 0 16px}
.tpa-runlist{list-style:none;margin:0;padding:0}
.tpa-runlist li{display:flex;gap:18px;padding:14px 0;border-top:1px solid var(--color-line);align-items:baseline}
.tpa-runlist li:first-child{border-top:none}
.tpa-runlist b{font-family:var(--font-display);font-size:19px;letter-spacing:.02em;color:var(--pink-600);min-width:70px}
.tpa-runlist span{font-size:15px;color:var(--color-ink-soft);line-height:1.45}
.tpa-infolist{list-style:none;margin:0;padding:0;border:1px solid var(--color-line);background:#fff}
.tpa-infolist li{display:flex;gap:14px;padding:20px 26px;border-top:1px solid var(--color-line);font-size:15.5px;color:var(--color-ink-soft);line-height:1.5;align-items:flex-start}
.tpa-infolist li:first-child{border-top:none}
.tpa-infolist li svg{flex:0 0 auto;margin-top:2px;color:var(--pink-500)}

/* ============================================================
   READY SET DANCE & READY SET BALLET @ TPA
   Co-branded preschool zone. Uses the official RSD/RSB brand
   fonts (Futura Extra Bold + Gotham Rounded) and palette. Rounded,
   bubbly forms honour the franchise identity within the TPA frame.
   ============================================================ */
@font-face{font-family:'RSD Display';src:url('assets/rsd/FuturaExtraBold.otf') format('opentype');font-weight:800;font-display:swap}
@font-face{font-family:'RSD Body';src:url('assets/rsd/GothamRnd-Book.otf') format('opentype');font-weight:400;font-display:swap}

.rsd{--rsd-blue:#1ba9e0;--rsd-yellow:#ffc20e;--rsd-purple:#7a2f9e;--rsd-pink:#ec0c8c;--rsd-green:#8cc63e;--rsd-sky:#41c6f2;
  --rsd-ink:#2b1545;--rsd-maxw:1200px;
  font-family:'RSD Body',var(--font-body),sans-serif;color:var(--rsd-ink)}
.rsd h1,.rsd h2,.rsd h3,.rsd .rsd-disp{font-family:'RSD Display','Futura',var(--font-display);font-weight:800;text-transform:uppercase;letter-spacing:.005em;line-height:.92}
.rsd .rsd-eyebrow{font-family:'RSD Display';text-transform:uppercase;letter-spacing:.14em;font-size:13px}
.rsd__wrap{max-width:var(--rsd-maxw);margin:0 auto;padding:0 clamp(20px,5vw,48px)}

/* buttons (rounded, bouncy — RSD brand) */
.rsd-btn{font-family:'RSD Display';font-size:clamp(15px,1.5vw,18px);letter-spacing:.03em;text-transform:uppercase;padding:15px 30px;border-radius:999px;background:var(--rsd-yellow);color:var(--rsd-ink);text-decoration:none;display:inline-flex;align-items:center;gap:9px;box-shadow:0 5px 0 #c8930a;transition:transform .12s,box-shadow .12s;border:none;cursor:pointer}
.rsd-btn:hover{transform:translateY(-2px);box-shadow:0 7px 0 #c8930a}
.rsd-btn:active{transform:translateY(3px);box-shadow:0 2px 0 #c8930a}
.rsd-btn--pink{background:var(--rsd-pink);color:#fff;box-shadow:0 5px 0 #a50a64}.rsd-btn--pink:hover{box-shadow:0 7px 0 #a50a64}.rsd-btn--pink:active{box-shadow:0 2px 0 #a50a64}
.rsd-btn--blue{background:var(--rsd-blue);color:#fff;box-shadow:0 5px 0 #1180ab}.rsd-btn--blue:hover{box-shadow:0 7px 0 #1180ab}.rsd-btn--blue:active{box-shadow:0 2px 0 #1180ab}
.rsd-btn--ghost{background:transparent;color:#fff;box-shadow:inset 0 0 0 3px #fff}.rsd-btn--ghost:hover{background:rgba(255,255,255,.14);transform:translateY(-2px)}

/* floating decorative brand icons */
.rsd-float{position:absolute;pointer-events:none;z-index:1;animation:rsd-bob 5s ease-in-out infinite}
.rsd-float img{display:block;width:100%;height:auto;filter:drop-shadow(0 5px 7px rgba(0,0,0,.16))}
@keyframes rsd-bob{0%,100%{transform:translateY(0) rotate(-7deg)}50%{transform:translateY(-14px) rotate(7deg)}}
@media(prefers-reduced-motion:reduce){.rsd-float{animation:none}}

/* ---------- HERO ---------- */
.rsd-hero{position:relative;background:#3a1c6b url('assets/rsd/bg-purple-pink.jpg') center/cover;overflow:hidden;border-bottom:7px solid var(--rsd-yellow)}
.rsd-hero__in{position:relative;z-index:3;max-width:var(--rsd-maxw);margin:0 auto;padding:clamp(40px,6vw,68px) clamp(20px,5vw,48px) 0;text-align:center}
.rsd-hero__logos{display:flex;gap:clamp(18px,3vw,40px);justify-content:center;align-items:center;flex-wrap:wrap}
.rsd-hero__logos img{height:clamp(64px,11vw,128px);width:auto;filter:drop-shadow(0 7px 0 rgba(0,0,0,.16))}
.rsd-hero__plus{font-family:'RSD Display';color:#fff;font-size:clamp(28px,4vw,46px);text-shadow:0 3px 0 rgba(0,0,0,.18)}
.rsd-hero h1{color:#fff;font-size:clamp(1.9rem,4vw,3.4rem);margin:clamp(20px,3vw,30px) 0 0;text-shadow:0 3px 0 rgba(0,0,0,.18)}
.rsd-hero__sub{color:#fff;opacity:.96;font-size:clamp(16px,1.6vw,20px);line-height:1.5;max-width:640px;margin:16px auto 26px;text-wrap:pretty}
.rsd-hero__cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.rsd-hero__mascots{display:flex;justify-content:space-between;align-items:flex-end;max-width:var(--rsd-maxw);margin:clamp(-20px,-2vw,-8px) auto 0;padding:0 clamp(8px,3vw,40px);position:relative;z-index:2;pointer-events:none}
.rsd-hero__mascots img{height:clamp(140px,24vw,290px);width:auto;filter:drop-shadow(0 12px 14px rgba(0,0,0,.22))}
.rsd-hero .rsd-float--a{top:9%;left:5%;width:clamp(40px,6vw,78px)}
.rsd-hero .rsd-float--b{top:16%;right:6%;width:clamp(46px,7vw,92px);animation-delay:-1.6s}
.rsd-hero .rsd-float--c{bottom:30%;left:8%;width:clamp(40px,5vw,70px);animation-delay:-3s}
.rsd-hero .rsd-float--d{bottom:34%;right:7%;width:clamp(40px,5vw,66px);animation-delay:-2.2s}
@media(max-width:620px){.rsd-hero__mascots img{height:120px}}

/* ---------- MARQUEE ---------- */
.rsd-strip{overflow:hidden;white-space:nowrap;background:var(--rsd-ink);padding:12px 0}
.rsd-strip__track{display:inline-flex;align-items:center;animation:tpa-marq 26s linear infinite}
@media(prefers-reduced-motion:reduce){.rsd-strip__track{animation:none}}
.rsd-chip{font-family:'RSD Display';font-size:clamp(16px,2vw,22px);letter-spacing:.06em;text-transform:uppercase;padding:0 26px;display:inline-flex;align-items:center;gap:24px}
.rsd-chip::after{content:"";width:13px;height:13px;border-radius:999px;background:currentColor;opacity:.8}

/* ---------- INTRO ---------- */
.rsd-intro{text-align:center;padding:clamp(48px,7vw,76px) 0 clamp(30px,4vw,44px);background:#fff}
.rsd-intro .rsd-eyebrow{color:var(--rsd-pink)}
.rsd-intro h2{font-size:clamp(1.8rem,3.6vw,2.9rem);margin:12px 0 14px;color:var(--rsd-ink)}
.rsd-intro p{max-width:680px;margin:0 auto;font-size:clamp(16px,1.6vw,18px);line-height:1.6;color:#5b4a6b;text-wrap:pretty}

/* ---------- PROGRAM HALVES ---------- */
.rsd-half{padding:clamp(44px,6vw,72px) 0;position:relative;overflow:hidden}
.rsd-half--dance{background:linear-gradient(180deg,#e9f6fe,#fff)}
.rsd-half--ballet{background:linear-gradient(180deg,#fdeaf6,#fff)}
.rsd-half__in{max-width:var(--rsd-maxw);margin:0 auto;padding:0 clamp(20px,5vw,48px);display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,4vw,56px);align-items:center;position:relative;z-index:2}
.rsd-half--ballet .rsd-half__copy{order:2}
.rsd-half__logo{height:clamp(58px,8vw,98px);width:auto;margin-bottom:20px;filter:drop-shadow(0 5px 0 rgba(0,0,0,.10))}
.rsd-half__copy h2{font-size:clamp(1.7rem,3.2vw,2.6rem);margin:0 0 6px;color:var(--rsd-ink)}
.rsd-half__lede{font-size:clamp(15px,1.6vw,17.5px);line-height:1.6;color:#5b4a6b;margin:0 0 6px;text-wrap:pretty}
.rsd-agepill{display:inline-flex;align-items:center;gap:8px;font-family:'RSD Display';font-size:14px;letter-spacing:.06em;padding:8px 16px;border-radius:999px;color:#fff;margin-bottom:6px}
.rsd-half--dance .rsd-agepill{background:var(--rsd-blue)}
.rsd-half--ballet .rsd-agepill{background:var(--rsd-pink)}
.rsd-feats{list-style:none;margin:18px 0 24px;padding:0;display:flex;flex-direction:column}
.rsd-feats li{display:flex;gap:14px;align-items:flex-start;padding:13px 0;border-top:1px solid rgba(43,21,69,.1);font-size:clamp(14.5px,1.5vw,16px);line-height:1.45;color:var(--rsd-ink)}
.rsd-feats li:first-child{border-top:none}
.rsd-feats img{width:34px;height:34px;object-fit:contain;flex:0 0 auto;margin-top:-2px}
.rsd-half__cta{display:flex;gap:12px;flex-wrap:wrap}
.rsd-half__art{position:relative;display:flex;align-items:flex-end;justify-content:center;min-height:380px}
.rsd-half--ballet .rsd-half__art{order:1}
.rsd-blob{position:absolute;width:min(78%,340px);aspect-ratio:1;border-radius:46% 54% 52% 48%/52% 46% 54% 48%;z-index:1;bottom:9%;left:50%;transform:translateX(-50%)}
.rsd-half--dance .rsd-blob{background:radial-gradient(circle at 50% 40%,#bfe9fb,#7fd2f4)}
.rsd-half--ballet .rsd-blob{background:radial-gradient(circle at 50% 40%,#ffd0ec,#f9a8d8)}
.rsd-half__mascot{position:relative;z-index:2;height:clamp(330px,44vw,500px);width:auto;filter:drop-shadow(0 16px 16px rgba(0,0,0,.18))}
.rsd-half__mascot--2{height:clamp(190px,24vw,280px);align-self:flex-end;margin-left:-10%}
.rsd-half__art .rsd-float{z-index:3;width:clamp(34px,4.6vw,52px)}
.rsd-half--dance .rsd-half__art .rsd-float--a{top:-2%;left:0;right:auto;bottom:auto}
.rsd-half--ballet .rsd-half__art .rsd-float--b{top:-2%;right:0;left:auto;bottom:auto}
@media(max-width:820px){
  .rsd-half__in{grid-template-columns:1fr;gap:8px}
  .rsd-half--ballet .rsd-half__copy{order:1}
  .rsd-half--ballet .rsd-half__art{order:2}
  .rsd-half__art{min-height:300px;order:2}
  .rsd-half__mascot--2{display:none}
}

/* ---------- JOURNEY / LADDER ---------- */
.rsd-journey{background:#2b1545;color:#fff;padding:clamp(50px,7vw,80px) 0}
.rsd-journey__head{text-align:center;max-width:720px;margin:0 auto 38px}
.rsd-journey .rsd-eyebrow{color:var(--rsd-yellow)}
.rsd-journey h2{font-size:clamp(1.7rem,3.4vw,2.7rem);color:#fff;margin:12px 0 14px}
.rsd-journey__head p{color:rgba(255,255,255,.72);font-size:clamp(15px,1.6vw,18px);line-height:1.6;margin:0}
.rsd-rungs{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.rsd-rung{background:rgba(255,255,255,.06);border-radius:18px;padding:22px 18px 24px;border:1px solid rgba(255,255,255,.1)}
.rsd-rung.is-now{background:var(--rsd-yellow);color:var(--rsd-ink);border-color:var(--rsd-yellow)}
.rsd-rung__age{font-family:'RSD Display';font-size:11px;letter-spacing:.1em;color:var(--rsd-yellow)}
.rsd-rung.is-now .rsd-rung__age{color:#a8780a}
.rsd-rung h3{font-size:clamp(17px,2vw,21px);margin:9px 0 8px;color:inherit}
.rsd-rung p{font-size:12.5px;line-height:1.5;margin:0;color:rgba(255,255,255,.62)}
.rsd-rung.is-now p{color:rgba(43,21,69,.72)}
.rsd-journey__cta{text-align:center;margin-top:34px}
@media(max-width:820px){.rsd-rungs{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.rsd-rungs{grid-template-columns:1fr}}

/* ---------- TIMETABLE ---------- */
.rsd-times{background:#fff;padding:clamp(46px,6vw,72px) 0 clamp(30px,4vw,48px)}
.rsd-times .rsd-eyebrow{color:var(--rsd-pink)}
.rsd-times h2{font-size:clamp(1.7rem,3.2vw,2.6rem);margin:12px 0 0;color:var(--rsd-ink)}
.rsd-ttable{display:flex;flex-direction:column;gap:14px;margin-top:30px}
.rsd-trow{display:grid;grid-template-columns:150px 1fr auto auto;gap:24px;align-items:center;background:#fff;border:2px solid var(--rsd-ink);border-radius:20px;padding:18px 22px;border-left-width:10px}
.rsd-trow--dance{border-left-color:var(--rsd-blue)}
.rsd-trow--ballet{border-left-color:var(--rsd-pink)}
.rsd-trow__when{display:flex;flex-direction:column;gap:3px}
.rsd-trow__time{font-family:'RSD Display','Futura',sans-serif;font-size:clamp(17px,1.9vw,21px);letter-spacing:.01em;color:var(--rsd-ink);line-height:1}
.rsd-trow__dur{font-family:'RSD Body',sans-serif;font-size:12.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#8a7a9b}
.rsd-trow__what h3{font-family:'RSD Display','Futura',sans-serif;text-transform:uppercase;font-size:clamp(17px,2vw,21px);margin:0 0 4px;color:var(--rsd-ink);display:flex;align-items:baseline;gap:9px;flex-wrap:wrap}
.rsd-trow__what h3 span{font-size:12px;letter-spacing:.06em;color:#fff;background:var(--rsd-ink);border-radius:999px;padding:3px 10px 2px}
.rsd-trow--dance .rsd-trow__what h3 span{background:var(--rsd-blue)}
.rsd-trow--ballet .rsd-trow__what h3 span{background:var(--rsd-pink)}
.rsd-trow__what p{margin:0;font-size:14px;line-height:1.45;color:#5b4a6b}
.rsd-trow__meta{display:flex;flex-direction:column;gap:5px;align-items:flex-start;text-align:left;min-width:96px}
.rsd-trow__age{font-family:'RSD Body',sans-serif;font-weight:700;font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--rsd-ink);background:#f0e8f7;border-radius:999px;padding:5px 12px}
.rsd-trow__studio{font-size:12.5px;color:#8a7a9b;padding-left:2px}
.rsd-trow__cta{padding:11px 22px;font-size:14px}
.rsd-times__note{text-align:center;color:#8a7a9b;font-size:14px;margin:24px auto 0;max-width:560px;line-height:1.5}
@media(max-width:760px){
  .rsd-trow{grid-template-columns:1fr;gap:12px;border-left-width:2px;border-top-width:10px;border-top-style:solid;text-align:left}
  .rsd-trow--dance{border-top-color:var(--rsd-blue)}
  .rsd-trow--ballet{border-top-color:var(--rsd-pink)}
  .rsd-trow__meta{flex-direction:row;align-items:center;gap:12px}
  .rsd-trow__cta{justify-self:start}
}

/* ---------- MOMENTS ---------- */
.rsd-moments{background:#fff;padding:clamp(46px,6vw,72px) 0}
.rsd-moments__head{text-align:center;margin-bottom:30px}
.rsd-moments .rsd-eyebrow{color:var(--rsd-pink)}
.rsd-moments h2{font-size:clamp(1.7rem,3.2vw,2.6rem);margin:12px 0 0;color:var(--rsd-ink)}
.rsd-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:1fr;gap:14px}
.rsd-grid img{width:100%;height:100%;object-fit:cover;display:block;border-radius:20px;border:4px solid #fff;box-shadow:0 8px 22px rgba(43,21,69,.14)}
.rsd-grid figure{margin:0;aspect-ratio:1;overflow:hidden;border-radius:20px}
.rsd-grid figure.is-wide{grid-column:span 2;grid-row:span 2;aspect-ratio:auto}
@media(max-width:760px){.rsd-grid{grid-template-columns:1fr 1fr}.rsd-grid figure.is-wide{grid-column:span 2;grid-row:auto;aspect-ratio:16/10}}

/* ---------- FINAL CTA ---------- */
.rsd-final{position:relative;background:#3a1c6b url('assets/rsd/bg-pink-sunburst.jpg') center/cover;padding:clamp(56px,8vw,92px) 0;text-align:center;overflow:hidden;border-top:7px solid var(--rsd-yellow)}
.rsd-final__card{position:relative;z-index:2;max-width:680px;margin:0 auto;background:#fff;border-radius:28px;padding:clamp(34px,5vw,52px) clamp(24px,5vw,52px);box-shadow:0 18px 40px rgba(0,0,0,.22)}
.rsd-final__card .rsd-eyebrow{color:var(--rsd-pink)}
.rsd-final h2{font-size:clamp(1.9rem,4vw,3rem);margin:12px 0 12px;color:var(--rsd-ink)}
.rsd-final p{color:#5b4a6b;font-size:clamp(15px,1.6vw,18px);line-height:1.6;margin:0 auto 24px;max-width:480px}
.rsd-final__cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.rsd-final__badge{position:absolute;z-index:3;width:clamp(74px,11vw,120px);top:clamp(-30px,-3vw,-20px);right:clamp(6%,8vw,12%)}
.rsd-final .rsd-float--a{top:14%;left:8%;width:clamp(44px,6vw,80px)}
.rsd-final .rsd-float--b{bottom:14%;right:9%;width:clamp(44px,6vw,84px);animation-delay:-2s}

/* entrance */
@media(prefers-reduced-motion:no-preference){
  .rsd [data-rise]{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease}
  .rsd [data-rise].in{opacity:1;transform:none}
}
