/* ============================================================
   Unity Taekwondo — V2 "Conversion / Punchy"
   Theme B: light + blue accent. Bold sans, tighter, CTA-dense.
   Same class names as v1.css; different visual treatment.
   ============================================================ */
@import url('https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard.css');
:root{
  --ink:#111722; --slate2:#3f4a5a; --mute:#677381;/* darkened for AA: 4.8:1 on white */
  --line:#e3e9f1; --blue:#1f8fd0; --blue2:#3AACE8; --bluebg:#e9f5fd;
  --blue-acc:#166da8; /* accessible blue: 5.5:1 on white, for small label text */
  --navy:#0c1420; --paper:#ffffff; --soft:#f4f8fc; --gold:#f5a623;
  --grad:linear-gradient(135deg,#3AACE8,#1f8fd0);
  --max:1160px; --maxnarrow:840px; --r:18px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Pretendard','Pretendard Variable',-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.serif{font-family:inherit}
h1,h2,h3,.serif-h{font-weight:900;letter-spacing:-1px;line-height:1.05}
.wrap{max-width:var(--max);margin:0 auto;padding:0 22px}
.narrow{max-width:var(--maxnarrow);margin:0 auto;padding:0 22px}
.pad{padding:74px 0}
.pad-sm{padding:52px 0}
.center{text-align:center}
.eyebrow{font-weight:900;letter-spacing:2px;text-transform:uppercase;font-size:.76rem;color:var(--blue-acc)}
.lead{font-size:1.18rem;color:var(--slate2);line-height:1.6}
.muted{color:var(--mute)}

.shead{max-width:700px}
.shead.center{margin:0 auto}
.shead h2{font-size:clamp(1.9rem,4.4vw,2.9rem);margin-top:10px}
.shead p{margin-top:14px;font-size:1.12rem;color:var(--slate2)}

/* Buttons — gradient, punchy */
.btn{display:inline-flex;align-items:center;gap:.5em;border:0;cursor:pointer;font-weight:800;
  font-size:1rem;border-radius:999px;padding:15px 30px;transition:.16s ease;line-height:1.1;letter-spacing:.2px}
.btn-pri{background:var(--grad);color:#fff;box-shadow:0 12px 28px rgba(31,143,208,.38)}
.btn-pri:hover{transform:translateY(-2px);box-shadow:0 18px 36px rgba(31,143,208,.48)}
.btn-line{background:#fff;color:var(--ink);border:2px solid var(--line)}
.btn-line:hover{border-color:var(--blue);color:var(--blue)}
.btn-ghost{background:rgba(255,255,255,.14);color:#fff;border:2px solid rgba(255,255,255,.45)}
.btn-ghost:hover{background:rgba(255,255,255,.26)}
.btn-lg{padding:18px 38px;font-size:1.1rem}

/* Announce bar — accent gradient */
.ann{background:var(--grad);color:#fff;text-align:center;font-size:.92rem;padding:10px 16px;font-weight:700}
.ann b{text-decoration:underline}
.ann a{color:#fff;text-decoration:underline}

/* Nav */
nav.site{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.94);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
nav.site .wrap{display:flex;align-items:center;justify-content:space-between;height:82px}
.brand{display:flex;align-items:center;gap:10px;font-weight:900;font-size:1.05rem;letter-spacing:.3px}
.brand img{height:58px;width:auto}
.navlinks{display:flex;gap:26px;align-items:center}
.navlinks a{color:var(--slate2);font-weight:700;font-size:.92rem}
.navlinks a:hover{color:var(--blue)}
.navlinks a.active{color:var(--blue)}
.navlinks .btn{padding:11px 22px;font-size:.9rem}
.dropdown{position:relative}
.dropdown>a::after{content:" ▾";font-size:.7em;opacity:.6}
.dropmenu{position:absolute;top:120%;left:50%;transform:translateX(-50%) translateY(8px);
  background:#fff;border:1px solid var(--line);border-radius:14px;padding:10px;min-width:230px;
  box-shadow:0 20px 50px rgba(12,20,32,.14);opacity:0;visibility:hidden;transition:.18s}
.dropdown:hover .dropmenu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.dropmenu a{display:block;padding:11px 14px;border-radius:9px;font-size:.92rem;color:var(--ink)}
.dropmenu a small{display:block;color:var(--mute);font-weight:500;font-size:.8rem}
.dropmenu a:hover{background:var(--bluebg);color:var(--blue)}
.navtoggle{display:none;background:none;border:0;font-size:1.6rem;cursor:pointer;color:var(--ink)}
@media(max-width:900px){
  .navlinks{display:none}
  .navtoggle{display:block}
  .navlinks.open{display:flex;position:absolute;top:70px;left:0;right:0;background:#fff;
    flex-direction:column;gap:0;padding:10px 20px 20px;border-bottom:1px solid var(--line);align-items:stretch}
  .navlinks.open a{padding:14px 6px;border-bottom:1px solid var(--line)}
  .navlinks.open .dropmenu{position:static;transform:none;opacity:1;visibility:visible;box-shadow:none;
    border:0;padding:0 0 0 14px;min-width:0}
  .navlinks.open .btn{margin-top:12px;justify-content:center}
}

/* Hero — bold + photographic */
.hero{background:linear-gradient(180deg,var(--soft),#fff);padding:60px 0 0}
.hero .hsplit{display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center}
.hero h1{font-size:clamp(2.6rem,6.2vw,4.4rem);margin-top:12px}
.hero h1 em{font-style:normal;color:var(--blue);background:linear-gradient(transparent 60%,rgba(58,172,232,.25) 0);padding:0 .1em}
.hero .lead{margin:20px 0 28px;max-width:520px}
.hero .cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero .micro{margin-top:20px;color:var(--mute);font-size:.9rem;display:flex;gap:8px 18px;flex-wrap:wrap;font-weight:600}
.hero .micro b{color:var(--ink)}
.hgal{position:relative}
.hgal .main{border-radius:22px;overflow:hidden;box-shadow:0 34px 70px rgba(12,20,32,.22);aspect-ratio:4/3}
.hgal .main img{width:100%;height:100%;object-fit:cover}
.hgal .badge{position:absolute;bottom:-22px;left:-20px;background:var(--grad);color:#fff;border-radius:16px;
  padding:16px 22px;box-shadow:0 18px 44px rgba(31,143,208,.4);display:flex;gap:13px;align-items:center}
.hgal .badge .n{font-size:1.9rem;font-weight:900;line-height:1}
.hgal .badge small{font-weight:700;font-size:.82rem;line-height:1.3;opacity:.95}
@media(max-width:900px){.hero .hsplit{grid-template-columns:1fr;gap:38px}.hgal .badge{left:14px}}

/* Interior page hero */
.phero{background:var(--navy);color:#fff;padding:70px 0 64px;position:relative;overflow:hidden}
.phero .wrap{position:relative;z-index:2}
.phero .crumb{font-size:.85rem;color:#9fb4c9;margin-bottom:12px}
.phero .crumb a:hover{color:#fff}
.phero h1{font-size:clamp(2.2rem,5.4vw,3.6rem)}
.phero h1 em{font-style:normal;color:var(--blue2)}
.phero p{margin-top:14px;font-size:1.15rem;color:#cdd9e6;max-width:620px}
.phero.photo{min-height:60vh;display:flex;align-items:flex-end;background:#000}
.phero.photo img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.55}
.phero.photo::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(12,20,32,.3),rgba(12,20,32,.92))}
.phero.photo .wrap{padding-bottom:56px;padding-top:80px}

/* Trust bar — accent tint */
.tbar{background:var(--navy);color:#fff;margin-top:0}
.tbar .wrap{display:grid;grid-template-columns:repeat(4,1fr)}
.tbar .item{padding:26px 18px;text-align:center;border-right:1px solid rgba(255,255,255,.12)}
.tbar .item:last-child{border-right:0}
.tbar .item .ic{font-size:1.5rem}
.tbar .item b{display:block;margin-top:6px;font-size:1.02rem}
.tbar .item small{color:#9fb4c9;font-size:.84rem}
@media(max-width:720px){.tbar .wrap{grid-template-columns:1fr 1fr}
  .tbar .item:nth-child(1),.tbar .item:nth-child(2){border-bottom:1px solid rgba(255,255,255,.12)}
  .tbar .item:nth-child(2){border-right:0}}

/* Grid + cards — denser, accent top border on hover */
.grid{display:grid;gap:18px}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.g3,.g4{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.g2,.g3,.g4{grid-template-columns:1fr}}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:26px;transition:.16s;
  position:relative;overflow:hidden}
.card::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--grad);
  transform:scaleX(0);transform-origin:left;transition:.25s}
.card:hover{box-shadow:0 16px 38px rgba(12,20,32,.1);transform:translateY(-3px)}
.card:hover::before{transform:scaleX(1)}
.card .ic{width:50px;height:50px;border-radius:14px;background:var(--grad);color:#fff;
  display:grid;place-items:center;font-size:1.45rem;margin-bottom:14px}
.card h3{font-size:1.2rem;margin-bottom:6px;font-weight:800}
.card p{color:var(--slate2);font-size:.98rem}
.card .more{display:inline-block;margin-top:12px;color:var(--blue-acc);font-weight:800;font-size:.92rem}

/* Split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.split.rev .txt{order:2}
.split .ph{border-radius:20px;overflow:hidden;box-shadow:0 24px 50px rgba(12,20,32,.16)}
.split .ph img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/5}
.split.wide .ph img{aspect-ratio:4/3}
.split h2{font-size:clamp(1.8rem,3.8vw,2.6rem)}
.split p{margin-top:14px;color:var(--slate2);font-size:1.08rem}
.split .btn{margin-top:22px}
@media(max-width:880px){.split{grid-template-columns:1fr;gap:32px}.split.rev .txt{order:0}}

/* Checks */
.checks{list-style:none;display:grid;gap:12px;margin-top:20px}
.checks li{display:flex;gap:12px;align-items:flex-start;color:var(--slate2);font-size:1.05rem}
.checks .c{width:26px;height:26px;border-radius:8px;background:var(--grad);color:#fff;
  display:grid;place-items:center;font-size:.85rem;font-weight:800;flex:none}

/* Stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;text-align:center}
.stats>div{position:relative;padding:10px 24px}
.stats>div+div::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:1px;height:58px;background:linear-gradient(to bottom,transparent,var(--line) 16%,var(--line) 84%,transparent)}
.stats .n{font-size:3rem;font-weight:900;line-height:1;letter-spacing:-1.5px;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
.stats small{display:block;margin-top:10px;color:var(--slate2);font-weight:800;font-size:.8rem;letter-spacing:.6px;text-transform:uppercase;line-height:1.4}
@media(max-width:700px){
  .stats{grid-template-columns:1fr 1fr;gap:34px 0}
  .stats>div{padding:6px 16px}
  .stats>div+div::before{display:none}
  .stats .n{font-size:2.6rem}
}

/* Pillars */
.pillar{background:#fff;border:1px solid var(--line);border-radius:16px;padding:24px;margin-bottom:18px;
  border-left:5px solid var(--blue)}
.pillar h3{font-size:1.4rem;font-weight:800}
.pillar .ko{color:var(--blue);font-weight:900;font-size:.9rem;letter-spacing:1px}
.pillar p{margin-top:8px;color:var(--slate2);font-size:1.05rem}

/* Dark */
.dark{background:var(--navy);color:#fff}
.dark .shead h2{color:#fff}
.dark .shead p{color:#aebccd}
.dark .eyebrow{color:var(--blue2)}

/* === Accessibility: WCAG AA contrast fixes === */
/* Accent text on light backgrounds */
.pillar .ko,
.orcall a{color:var(--blue-acc)}
/* Body & list text inside dark navy sections (slate2 was unreadable on navy) */
.dark .split p,
.dark .checks li,
.dark .lead{color:#cdd9e6}
/* The CTA band is navy but not class .dark — give it dark-mode accents */
.ctaband .eyebrow{color:var(--blue2)}
.ctaband .checks li{color:#cdd9e6}

/* Gallery */
.gal{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.gal figure{border-radius:14px;overflow:hidden;aspect-ratio:1/1;position:relative}
.gal img{width:100%;height:100%;object-fit:cover;transition:.45s}
.gal figure:hover img{transform:scale(1.06)}
.gal .big{grid-column:span 2;grid-row:span 2;aspect-ratio:auto}
@media(max-width:760px){.gal{grid-template-columns:1fr 1fr}.gal .big{grid-column:span 2;grid-row:auto}}

/* Reviews */
.rcard{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:30px}
.stars{color:var(--gold);letter-spacing:2px;margin-bottom:12px}
.rcard p{font-size:1.08rem;color:var(--ink);line-height:1.6;font-weight:500}
.rcard .who{margin-top:16px;font-weight:800}
.rcard .who small{display:block;color:var(--mute);font-weight:600}

/* Quote band */
.quoteband{background:var(--navy);color:#fff;text-align:center}
.quoteband blockquote{font-size:clamp(1.5rem,3.6vw,2.3rem);font-weight:800;line-height:1.3;
  max-width:880px;margin:0 auto;letter-spacing:-.5px}
.quoteband cite{display:block;margin-top:20px;font-style:normal;color:var(--blue2);font-weight:800;font-size:1rem}

/* FAQ */
.faq details{background:#fff;border:1px solid var(--line);border-radius:14px;margin-bottom:12px;padding:0 22px}
.faq summary{cursor:pointer;list-style:none;padding:20px 0;font-weight:800;font-size:1.06rem;
  display:flex;justify-content:space-between;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--blue);font-size:1.5rem;font-weight:300;flex:none;line-height:1}
.faq details[open] summary::after{content:"–"}
.faq details p{padding:0 0 20px;color:var(--slate2);font-size:1.02rem}

/* CTA / lead form */
.ctaband{background:var(--navy);color:#fff}
.ctaband .fsplit{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.ctaband h2{font-size:clamp(2rem,4.6vw,3rem)}
.ctaband h2 em{color:var(--blue2);font-style:normal}
.ctaband .lead{color:#aebccd;margin:16px 0 24px}
.ftrust{display:grid;gap:14px}
.ftrust div{display:flex;gap:14px;align-items:center;color:#dfe8f2;font-weight:600}
.ftrust .b{width:38px;height:38px;border-radius:10px;background:rgba(58,172,232,.22);color:var(--blue2);
  display:grid;place-items:center;font-size:1.15rem;flex:none}
@media(max-width:880px){.ctaband .fsplit{grid-template-columns:1fr;gap:34px}}
.leadform{background:#fff;color:var(--ink);border-radius:22px;padding:32px}
.leadform h3{font-size:1.35rem;font-weight:900;margin-bottom:4px}
.leadform .fnote{color:var(--mute);font-size:.9rem;margin-bottom:18px}
.field{margin-bottom:14px}
.field label{display:block;font-weight:800;font-size:.85rem;margin-bottom:6px}
.field label small{color:var(--mute);font-weight:500}
.field input,.field select{width:100%;padding:14px;border:1.5px solid var(--line);border-radius:11px;
  font-size:1rem;font-family:inherit;color:var(--ink);background:#fff}
.field input:focus,.field select:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(58,172,232,.15)}
.leadform .btn{width:100%;justify-content:center;margin-top:4px}
.orcall{text-align:center;margin-top:14px;color:var(--slate2);font-size:.92rem}
.orcall a{font-weight:900;color:var(--blue-acc)}

/* Footer */
footer.site{background:#0a111b;color:#8b97a6;padding:60px 0 34px;font-size:.93rem}
footer.site .fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;margin-bottom:38px}
footer.site h4{color:#fff;font-size:.95rem;margin-bottom:16px;letter-spacing:.5px;text-transform:uppercase;font-weight:800}
footer.site a{display:block;padding:5px 0;color:#aab4c2}
footer.site a:hover{color:var(--blue2)}
footer.site .fbrand img{height:54px;margin-bottom:16px}
footer.site .fbrand p{max-width:300px;line-height:1.6}
footer.site .copy{border-top:1px solid rgba(255,255,255,.1);padding-top:24px;text-align:center;font-size:.85rem}
footer.site .copy b{color:#fff}
@media(max-width:760px){footer.site .fgrid{grid-template-columns:1fr;gap:30px}}

/* Mobile sticky CTA */
.mobcta{position:fixed;left:0;right:0;bottom:0;z-index:60;display:none;background:#fff;
  padding:12px 16px;border-top:1px solid var(--line);box-shadow:0 -6px 20px rgba(0,0,0,.1)}
.mobcta .btn{width:100%;justify-content:center}
@media(max-width:640px){.mobcta{display:block}body{padding-bottom:80px}}

/* Premium SVG icons (replace emoji) */
.ico{width:1.15em;height:1.15em;display:inline-block;vertical-align:-.18em;flex:none;
  fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.ico.fill{fill:currentColor;stroke:none}
.ic .ico{width:26px;height:26px}
.tbar .item .ic{color:var(--blue2)}
.tbar .item .ic .ico{width:26px;height:26px}
.micro .ico{color:var(--blue)}
.ftrust .b .ico{width:18px;height:18px}
.checks .c .ico,.blist .c .ico{width:13px;height:13px;stroke-width:2.4}
.btn .ico{width:1.05em;height:1.05em}
.swatch{width:18px;height:18px;border-radius:50%;display:inline-block;vertical-align:-.22em;
  border:1px solid rgba(0,0,0,.15);flex:none}

/* Video-ready hero overlay */
.hgal .main{position:relative}
.playbtn{position:absolute;inset:0;margin:auto;width:68px;height:68px;border-radius:50%;
  background:rgba(255,255,255,.95);border:0;display:grid;place-items:center;cursor:pointer;
  box-shadow:0 14px 36px rgba(0,0,0,.34);transition:.16s}
.playbtn:hover{transform:scale(1.09)}
.playbtn svg{width:25px;height:25px;fill:var(--blue);margin-left:3px}
.vcap{position:absolute;left:0;right:0;bottom:12px;text-align:center;color:#fff;
  font-size:.78rem;font-weight:800;letter-spacing:.3px;text-shadow:0 1px 8px rgba(0,0,0,.6)}

/* Town pills (service area) */
.pills{display:flex;flex-wrap:wrap;gap:10px}
.pill{display:inline-flex;align-items:center;gap:9px;padding:11px 18px;border-radius:999px;
  border:1px solid var(--line);background:#fff;font-weight:800;font-size:.95rem;color:var(--ink)}
.pill .dot{width:8px;height:8px;border-radius:50%;background:var(--blue);flex:none}
.pill.home{background:var(--grad);color:#fff;border-color:transparent}
.pill.home .dot{background:#fff}

/* In-page jump nav (anchor chips) */
.jumpnav{position:sticky;top:82px;z-index:20;background:rgba(255,255,255,.93);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line)}
.jumpnav .wrap{display:flex;gap:8px;flex-wrap:wrap;padding-top:14px;padding-bottom:14px}
.jumpnav a{font-size:.88rem;font-weight:800;color:var(--slate2);padding:8px 14px;border-radius:999px;
  border:1px solid var(--line)}
.jumpnav a:hover{color:var(--blue);border-color:var(--blue)}

/* Review headline label (above quote) */
.rcard .rlabel{font-size:1.18rem;font-weight:800;color:var(--ink);letter-spacing:-.3px;margin-bottom:10px}

/* Program cards — hover image swap */
.swapcard{display:block;border:1px solid var(--line);border-radius:18px;overflow:hidden;background:#fff;transition:.18s}
.swapcard:hover{box-shadow:0 18px 40px rgba(12,20,32,.13);transform:translateY(-3px)}
.swapcard .imgwrap{position:relative;aspect-ratio:4/3;overflow:hidden;background:#0c1420}
.swapcard .imgwrap img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:opacity .45s ease,transform .6s ease}
.swapcard .imgwrap img.alt{opacity:0}
.swapcard:hover .imgwrap img.base{opacity:0}
.swapcard:hover .imgwrap img.alt{opacity:1;transform:scale(1.05)}
.swapcard .peek{position:absolute;top:12px;right:12px;z-index:2;background:rgba(15,20,32,.72);color:#fff;
  font-size:.72rem;font-weight:700;padding:5px 11px;border-radius:999px;backdrop-filter:blur(4px);transition:.3s}
.swapcard:hover .peek{opacity:0}
.swapcard .body{padding:22px}
.swapcard .age{color:var(--blue-acc);font-weight:800;font-size:.8rem;letter-spacing:.6px;text-transform:uppercase}
.swapcard h3{font-size:1.25rem;font-weight:800;margin:4px 0 0}
.swapcard p{color:var(--slate2);font-size:.97rem;margin:8px 0 0}
.swapcard .more{display:inline-block;margin-top:12px;color:var(--blue-acc);font-weight:800;font-size:.92rem}

/* Hover-to-expand step cards (what to expect / curriculum) */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:860px){.steps{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.steps{grid-template-columns:1fr}}
.stepcard{position:relative;border:1px solid var(--line);border-radius:16px;padding:24px 22px;background:#fff;
  overflow:hidden;transition:.2s}
.stepcard:hover{border-color:var(--blue);box-shadow:0 16px 38px rgba(12,20,32,.11);transform:translateY(-3px)}
.stepcard .num{position:absolute;top:14px;right:20px;font-size:1.7rem;font-weight:900;color:var(--line);transition:.2s}
.stepcard:hover .num{color:var(--blue2)}
.stepcard .sic{width:50px;height:50px;border-radius:14px;background:var(--bluebg);color:var(--blue);
  display:grid;place-items:center;margin-bottom:14px;transition:.2s}
.stepcard .sic .ico{width:26px;height:26px}
.stepcard:hover .sic{background:var(--grad);color:#fff}
.stepcard h3{font-size:1.12rem;font-weight:800}
/* detail always reserves its height (hidden via opacity), hint overlays with 0 height
   -> card height never changes on hover, so rows below stay fixed */
.stepcard .detail{opacity:0;color:var(--slate2);font-size:.97rem;margin-top:10px;
  transition:opacity .3s ease}
.stepcard:hover .detail{opacity:1}
.stepcard .hint{height:0;overflow:visible;margin-top:10px;font-size:.78rem;font-weight:700;color:var(--mute);transition:opacity .2s ease}
.stepcard:hover .hint{opacity:0}
@media(max-width:560px){.stepcard .detail{opacity:1}.stepcard .hint{display:none}}

/* transformation cards — homepage "sound like your child" */
.tcard{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:26px;overflow:hidden;transition:.16s}
.tcard::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--grad);transform:scaleX(0);transform-origin:left;transition:.2s}
.tcard:hover{box-shadow:0 16px 38px rgba(12,20,32,.1);transform:translateY(-3px)}
.tcard:hover::before{transform:scaleX(1)}
.tcard .lbl{font-size:.78rem;font-weight:800;letter-spacing:.6px;text-transform:uppercase;color:var(--blue-acc)}
.tcard .from{margin-top:8px;color:var(--slate2);font-size:1.02rem;font-style:italic;line-height:1.5}
.tcard .to{margin-top:16px;display:flex;gap:10px;align-items:flex-start;font-weight:700;font-size:1.02rem;color:var(--ink)}
.tcard .to .arr{flex:none;width:24px;height:24px;border-radius:7px;background:var(--grad);color:#fff;display:grid;place-items:center;font-size:.85rem;margin-top:1px}

/* proof strip — real photos backing the emotional claims */
.proofstrip{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.proofstrip figure{margin:0;border-radius:16px;overflow:hidden;aspect-ratio:1/1;box-shadow:0 16px 38px rgba(12,20,32,.1)}
.proofstrip img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.proofstrip figure:hover img{transform:scale(1.05)}
.proofcap{margin-top:16px;color:var(--mute);font-size:.92rem;font-weight:700}
@media(max-width:600px){
  .proofstrip{grid-auto-flow:column;grid-template-columns:none;grid-auto-columns:78%;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding-bottom:6px}
  .proofstrip figure{scroll-snap-align:center}
}

/* Utilities */
.bg-soft{background:var(--soft)}
.bg-blue{background:var(--bluebg)}
.mt0{margin-top:0}
.tac{text-align:center}
/* keep Master Nam (far left of this photo) in frame on any crop */
img[src$="master-demo.jpg"]{object-position:left center}
