/* ============================================================
   MAANJ — Martial Arts Dojang. Redesign design system.
   Three switchable directions via [data-theme] on <html>:
     iron    — Athletic bold. Charcoal + martial red. Condensed display.
     dojang  — Premium dark + brass gold. Editorial serif display.
     openmat — Warm, light, family-friendly. Deep slate + clay accent.
   ============================================================ */

/* ---- Tokens: shared defaults ---- */
:root{
  --ink:#0d0d0f;
  --dark-bg:#121215;
  --dark-bg-2:#1a1a1f;
  --paper:#f7f5f1;
  --surface:#ffffff;
  --text:#16161a;
  --muted:#5d5d68;
  --muted-dark:#a7a7b2;
  --line:#e6e3dc;
  --line-dark:#2c2c34;
  --accent:#d62828;
  --accent-2:#b21d1d;
  --accent-ink:#ffffff;
  --on-dark:#f4f2ee;
  --radius:6px;
  --radius-lg:12px;
  --radius-pill:999px;
  --shadow:0 18px 40px -22px rgba(0,0,0,.35);
  --shadow-soft:0 10px 30px -18px rgba(0,0,0,.25);
  --font-display:'Oswald',sans-serif;
  --font-body:'Manrope',system-ui,sans-serif;
  --font-mono:'Space Mono',monospace;
  --disp-transform:uppercase;
  --disp-weight:600;
  --disp-tracking:-0.01em;
  --disp-line:0.98;
  --maxw:1200px;
}

/* ===== IRON (default) — athletic, charcoal + red ===== */
[data-theme="iron"]{
  --ink:#0d0d0f; --dark-bg:#131316; --dark-bg-2:#1c1c21;
  --paper:#f6f4f0; --surface:#ffffff; --text:#16161a;
  --muted:#5d5d68; --muted-dark:#a3a3ad; --line:#e5e2db; --line-dark:#2b2b33;
  --accent:#d62828; --accent-2:#a81d1d; --accent-ink:#ffffff; --on-dark:#f4f2ee;
  --radius:5px; --radius-lg:10px;
  --font-display:'Oswald',sans-serif; --font-body:'Manrope',system-ui,sans-serif;
  --disp-transform:uppercase; --disp-weight:600; --disp-tracking:0.005em; --disp-line:0.96;
}

/* ===== DOJANG — premium dark + brass gold, serif display ===== */
[data-theme="dojang"]{
  --ink:#0c0b0a; --dark-bg:#141210; --dark-bg-2:#1f1c18;
  --paper:#f5f1e8; --surface:#fbf8f1; --text:#1a1713;
  --muted:#6b6457; --muted-dark:#b3a890; --line:#e4ddcd; --line-dark:#322d24;
  --accent:#c39a4e; --accent-2:#a67f34; --accent-ink:#1a1610; --on-dark:#f3ecdd;
  --radius:3px; --radius-lg:6px;
  --font-display:'DM Serif Display',Georgia,serif; --font-body:'Manrope',system-ui,sans-serif;
  --disp-transform:none; --disp-weight:400; --disp-tracking:-0.015em; --disp-line:1.02;
}

/* ===== OPENMAT — warm, light, family friendly ===== */
[data-theme="openmat"]{
  --ink:#1d2a34; --dark-bg:#20303b; --dark-bg-2:#2a4150;
  --paper:#fbf7f0; --surface:#ffffff; --text:#21303a;
  --muted:#5f7079; --muted-dark:#b7c6cd; --line:#ece4d7; --line-dark:#33485620;
  --accent:#c4502e; --accent-2:#a53f22; --accent-ink:#ffffff; --on-dark:#f3efe7;
  --radius:12px; --radius-lg:20px;
  --font-display:'Plus Jakarta Sans',system-ui,sans-serif; --font-body:'Manrope',system-ui,sans-serif;
  --disp-transform:none; --disp-weight:800; --disp-tracking:-0.02em; --disp-line:1.04;
}

/* ---- Reset / base ---- */
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  font-family:var(--font-body);
  background:var(--paper);
  color:var(--text);
  -webkit-font-smoothing:antialiased;
  line-height:1.6;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;}
::selection{background:var(--accent);color:var(--accent-ink);}

h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:var(--disp-weight);
  text-transform:var(--disp-transform);
  letter-spacing:var(--disp-tracking);
  line-height:var(--disp-line);
  margin:0;
  text-wrap:balance;
}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}
.eyebrow{
  font-family:var(--font-body);
  font-weight:700;
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--accent);
}
.eyebrow.on-dark{color:var(--accent);}
[data-theme="dojang"] .eyebrow{color:var(--accent-2);}
.muted{color:var(--muted);}
.lead{font-size:clamp(17px,1.4vw,20px);color:var(--muted);line-height:1.55;}

/* ---- Buttons ---- */
.btn{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--font-body);font-weight:700;
  border:none;border-radius:var(--radius);
  padding:15px 26px;font-size:15px;letter-spacing:.01em;
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease;
  white-space:nowrap;
}
.btn svg{width:18px;height:18px;}
.btn-primary{background:var(--accent);color:var(--accent-ink);box-shadow:0 8px 22px -10px color-mix(in oklab,var(--accent) 70%,transparent);}
.btn-primary:hover{transform:translateY(-2px);background:var(--accent-2);}
.btn-lg{padding:18px 34px;font-size:17px;}
.btn-ghost-dark{background:transparent;color:var(--on-dark);border:1.5px solid color-mix(in oklab,var(--on-dark) 30%,transparent);}
.btn-ghost-dark:hover{border-color:var(--on-dark);background:color-mix(in oklab,var(--on-dark) 8%,transparent);}
.btn-ghost{background:transparent;color:var(--text);border:1.5px solid var(--line);}
.btn-ghost:hover{border-color:var(--text);}
[data-theme="iron"] .btn,[data-theme="iron"] .btn-primary{text-transform:uppercase;font-weight:700;letter-spacing:.04em;font-size:14px;}

/* ---- Sections ---- */
.section{padding:88px 0;}
.section-sm{padding:60px 0;}
.dark-section{background:var(--dark-bg);color:var(--on-dark);}
.dark-section h1,.dark-section h2,.dark-section h3{color:var(--on-dark);}
.dark-section .muted{color:var(--muted-dark);}
.section-head{max-width:720px;margin-bottom:42px;}
.section-head h2{font-size:clamp(30px,3.6vw,46px);margin:14px 0 0;}

/* ---- Stars ---- */
.stars{display:inline-flex;gap:2px;color:var(--accent);}
[data-theme="dojang"] .stars{color:var(--accent);}
.stars svg{width:16px;height:16px;fill:currentColor;stroke:none;}

/* ---- Icon chip ---- */
.chip{
  display:inline-flex;align-items:center;justify-content:center;
  width:52px;height:52px;border-radius:var(--radius-lg);
  background:color-mix(in oklab,var(--accent) 12%,var(--surface));
  color:var(--accent);
}
.dark-section .chip{background:color-mix(in oklab,var(--accent) 22%,transparent);}
.chip svg{width:26px;height:26px;}

/* ---- Placeholder image ---- */
.ph{
  position:relative;overflow:hidden;border-radius:var(--radius-lg);
  background:
    repeating-linear-gradient(135deg, color-mix(in oklab,var(--ink) 7%,var(--paper)) 0 12px, color-mix(in oklab,var(--ink) 4%,var(--paper)) 12px 24px);
  border:1px solid var(--line);
  display:flex;align-items:flex-end;
  color:var(--muted);
}
.dark-section .ph,.ph.on-dark{
  background:
    repeating-linear-gradient(135deg, color-mix(in oklab,#fff 8%,var(--dark-bg-2)) 0 12px, color-mix(in oklab,#fff 4%,var(--dark-bg-2)) 12px 24px);
  border-color:var(--line-dark);color:var(--muted-dark);
}
.ph.has-img{background:#0c0c0e;}
.ph.has-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;}
.ph .ph-label{
  font-family:var(--font-mono);font-size:11px;letter-spacing:.04em;
  background:color-mix(in oklab,var(--ink) 80%,transparent);color:#fff;
  padding:5px 9px;border-radius:5px;margin:12px;text-transform:none;
}

/* ---- User-fillable image slot (programs without a stock photo yet) ---- */
image-slot.ph-slot{display:block;}
.prog-card .pc-media .ph-slot,
.pp-hero .pp-media .ph-slot,
.finder-media .ph-slot{position:absolute;inset:0;border-radius:0;}
/* Match the striped-placeholder look so empty slots read as "add a photo" */
.ph-slot::part(frame){
  background:
    repeating-linear-gradient(135deg, color-mix(in oklab,var(--ink) 7%,var(--paper)) 0 12px, color-mix(in oklab,var(--ink) 4%,var(--paper)) 12px 24px);
}
.ph-slot.on-dark::part(frame){
  background:
    repeating-linear-gradient(135deg, color-mix(in oklab,#fff 8%,var(--dark-bg-2)) 0 12px, color-mix(in oklab,#fff 4%,var(--dark-bg-2)) 12px 24px);
}
.ph-slot::part(empty){color:var(--muted);}
.ph-slot.on-dark::part(empty){color:var(--muted-dark);}

/* ---- Hangul / brand watermark accent ---- */
.hangul{font-family:var(--font-body);font-weight:800;}

/* ===================== NAV ===================== */
.nav{position:sticky;top:0;z-index:60;background:var(--ink);color:var(--on-dark);}
[data-theme="openmat"] .nav{background:var(--dark-bg);}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:70px;}
.logo{display:flex;align-items:center;gap:11px;font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:20px;color:#fff;}
[data-theme="dojang"] .logo{text-transform:none;letter-spacing:0;font-size:24px;}
.logo-mark{
  width:38px;height:38px;border-radius:var(--radius);background:var(--accent);color:var(--accent-ink);
  display:grid;place-items:center;font-weight:700;font-size:18px;font-family:var(--font-display);
}
.logo-mark .han{font-family:var(--font-body);font-weight:800;font-size:17px;}
.nav-links{display:flex;align-items:center;gap:28px;}
.nav-links a, .nav-link{font-size:14px;font-weight:600;color:var(--muted-dark);transition:color .15s;background:none;border:none;padding:0;position:relative;}
.nav-links a:hover,.nav-link:hover{color:#fff;}
.nav-cta-row{display:flex;align-items:center;gap:18px;}
.nav-phone{display:inline-flex;align-items:center;gap:7px;font-size:14px;font-weight:700;color:#fff;}
.nav-phone svg{width:16px;height:16px;color:var(--accent);}
.nav-btn{background:var(--accent);color:var(--accent-ink);font-weight:700;font-size:14px;padding:11px 18px;border-radius:var(--radius);border:none;transition:background .2s,transform .15s;}
.nav-btn:hover{background:var(--accent-2);transform:translateY(-1px);}
[data-theme="iron"] .nav-btn,[data-theme="iron"] .nav-links a,[data-theme="iron"] .nav-link{text-transform:uppercase;letter-spacing:.05em;font-size:13px;}

/* dropdown */
.dd{position:relative;}
.dd-panel{
  position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(6px);
  background:var(--surface);color:var(--text);border-radius:var(--radius-lg);
  box-shadow:0 24px 50px -16px rgba(0,0,0,.4);border:1px solid var(--line);
  padding:8px;min-width:300px;opacity:0;visibility:hidden;transition:.18s;z-index:70;
}
.dd:hover .dd-panel,.dd-panel.open{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);}
.dd-item{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:var(--radius);transition:background .15s;}
.dd-item:hover{background:color-mix(in oklab,var(--accent) 9%,var(--surface));}
.dd-item .chip{width:38px;height:38px;border-radius:var(--radius);}
.dd-item .chip svg{width:19px;height:19px;}
.dd-item .di-t{font-weight:700;font-size:14px;color:var(--text);font-family:var(--font-body);text-transform:none;letter-spacing:0;}
.dd-item .di-s{font-size:12px;color:var(--muted);}
.nav-caret{width:14px;height:14px;display:inline-block;vertical-align:middle;margin-left:3px;}

/* hamburger */
.hamburger{display:none;background:none;border:none;color:#fff;padding:6px;}
.hamburger svg{width:26px;height:26px;}

/* mobile menu */
.mmenu{position:fixed;inset:0;z-index:90;background:var(--ink);color:var(--on-dark);display:flex;flex-direction:column;padding:24px 28px;}
.mmenu a,.mmenu button{font-family:var(--font-display);text-transform:var(--disp-transform);font-size:22px;color:var(--on-dark);padding:14px 0;border-bottom:1px solid var(--line-dark);text-align:left;background:none;border-left:none;border-right:none;border-top:none;}

/* ===================== STICKY MOBILE CTA ===================== */
.sticky-cta{display:none;position:fixed;bottom:0;left:0;right:0;z-index:80;background:var(--ink);border-top:1px solid var(--line-dark);}
.sticky-cta a{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:16px;font-weight:700;font-size:15px;color:#fff;min-height:58px;}
.sticky-cta a svg{width:18px;height:18px;}
.sticky-cta a.call{border-right:1px solid var(--line-dark);}
.sticky-cta a.book{background:var(--accent);color:var(--accent-ink);}

/* ===================== HERO ===================== */
.hero{position:relative;background:var(--ink);color:var(--on-dark);overflow:hidden;}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center;padding:84px 0 96px;}
.hero-watermark{
  position:absolute;right:-2%;top:50%;transform:translateY(-50%);
  font-family:var(--font-body);font-weight:800;font-size:min(40vw,560px);line-height:.8;
  color:color-mix(in oklab,#fff 4%,transparent);pointer-events:none;user-select:none;z-index:0;
}
.hero-grid>*{position:relative;z-index:1;}
.hero-badge{
  display:inline-flex;align-items:center;gap:10px;padding:8px 14px;border-radius:var(--radius-pill);
  background:color-mix(in oklab,#fff 8%,transparent);border:1px solid var(--line-dark);
  font-size:12.5px;font-weight:700;letter-spacing:.02em;color:var(--on-dark);margin-bottom:24px;
}
.hero h1{font-size:clamp(34px,4.6vw,66px);color:#fff;margin-bottom:32px;line-height:1.08;padding-bottom:2px;text-wrap:normal;}
[data-theme="iron"] .hero h1{line-height:1.06;}
.hero h1 .em{color:var(--accent);}
[data-theme="dojang"] .hero h1 .em{font-style:italic;color:var(--accent);}
.hero-sub{font-size:clamp(16px,1.4vw,19px);color:var(--muted-dark);max-width:540px;margin-bottom:30px;line-height:1.55;}
.hero-cta-row{display:flex;align-items:center;gap:18px;flex-wrap:wrap;}
.hero-note{font-size:13px;color:var(--muted-dark);}
.hero-instr{display:flex;align-items:center;gap:13px;margin-top:30px;padding-top:26px;border-top:1px solid var(--line-dark);}
.hero-instr .av{width:46px;height:46px;border-radius:50%;background:var(--dark-bg-2);display:grid;place-items:center;font-weight:700;font-family:var(--font-display);color:var(--accent);border:1px solid var(--line-dark);}
.hero-instr .t{font-size:13.5px;color:var(--muted-dark);line-height:1.4;}
.hero-instr .t b{color:#fff;}
.hero-media{position:relative;aspect-ratio:4/5;}
.hero-media .ph{position:absolute;inset:0;border-radius:var(--radius-lg);}
.hero-statcard{
  position:absolute;bottom:-22px;left:-22px;background:var(--surface);color:var(--text);
  border-radius:var(--radius-lg);padding:18px 22px;box-shadow:var(--shadow);border:1px solid var(--line);
}
.hero-statcard .n{font-family:var(--font-display);font-weight:700;font-size:34px;line-height:1;color:var(--accent);}
.hero-statcard .l{font-size:12px;color:var(--muted);font-weight:600;}

/* hero stat strip below */
.hero-strip{border-top:1px solid var(--line-dark);background:var(--ink);}
.hero-strip-inner{display:grid;grid-template-columns:repeat(4,1fr);}
.hero-strip-cell{padding:26px 24px;border-right:1px solid var(--line-dark);}
.hero-strip-cell:last-child{border-right:none;}
.hero-strip-cell .n{font-family:var(--font-display);font-weight:700;font-size:30px;color:#fff;line-height:1;}
.hero-strip-cell .l{font-size:12.5px;color:var(--muted-dark);margin-top:7px;font-weight:600;letter-spacing:.02em;}

/* ===================== BENEFIT ROW ===================== */
.benefits{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.benefit{padding:6px 0;}
.benefit .chip{margin-bottom:18px;}
.benefit h3{font-size:23px;margin-bottom:9px;}
.benefit p{color:var(--muted);font-size:15.5px;margin:0;}

/* ===================== PROGRAM CARDS ===================== */
.prog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.prog-card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);
  overflow:hidden;transition:transform .2s ease,box-shadow .2s ease,border-color .2s;
  display:flex;flex-direction:column;cursor:pointer;
}
.prog-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:color-mix(in oklab,var(--accent) 40%,var(--line));}
.prog-card .pc-media{aspect-ratio:16/11;position:relative;border-radius:0;border:none;}
.prog-card .pc-media .ph{position:absolute;inset:0;border-radius:0;border:none;}
.pc-age{position:absolute;top:12px;left:12px;z-index:2;background:var(--ink);color:#fff;font-size:11px;font-weight:700;letter-spacing:.04em;padding:5px 10px;border-radius:var(--radius-pill);font-family:var(--font-body);}
.prog-card .pc-body{padding:22px;flex:1;display:flex;flex-direction:column;}
.prog-card h3{font-size:21px;margin-bottom:8px;}
.prog-card p{color:var(--muted);font-size:14.5px;margin:0 0 16px;flex:1;}
.pc-link{display:inline-flex;align-items:center;gap:7px;color:var(--accent);font-weight:700;font-size:14px;font-family:var(--font-body);text-transform:none;letter-spacing:0;}
.pc-link svg{width:16px;height:16px;transition:transform .2s;}
.prog-card:hover .pc-link svg{transform:translateX(4px);}

/* ===================== MASTER RAY BAND ===================== */
.ray-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:54px;align-items:center;}
.ray-media{aspect-ratio:4/5;position:relative;}
.ray-media .ph{position:absolute;inset:0;}
.ray-badges{display:flex;gap:10px;flex-wrap:wrap;margin:22px 0 26px;}
.ray-badge{display:inline-flex;align-items:center;gap:8px;padding:9px 13px;border-radius:var(--radius);background:color-mix(in oklab,#fff 6%,transparent);border:1px solid var(--line-dark);font-size:13px;font-weight:600;color:var(--on-dark);}
.ray-badge svg{width:15px;height:15px;color:var(--accent);}
.ray-list{list-style:none;padding:0;margin:0 0 28px;display:grid;gap:12px;}
.ray-list li{display:flex;gap:12px;align-items:flex-start;color:var(--muted-dark);font-size:15px;}
.ray-list li svg{width:19px;height:19px;color:var(--accent);flex-shrink:0;margin-top:2px;}

/* ===================== REVIEWS ===================== */
.rev-top{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-bottom:34px;}
.rev-rating{display:flex;align-items:center;gap:14px;margin-top:8px;}
.rev-rating .big{font-family:var(--font-display);font-weight:700;font-size:40px;line-height:1;color:var(--text);}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.rev-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:24px;}
.rev-card .stars{margin-bottom:13px;}
.rev-card p{font-size:15px;color:var(--text);line-height:1.55;margin:0 0 16px;}
.rev-author{display:flex;align-items:center;gap:11px;}
.rev-author .av{width:38px;height:38px;border-radius:50%;background:color-mix(in oklab,var(--accent) 14%,var(--surface));color:var(--accent);display:grid;place-items:center;font-weight:700;font-family:var(--font-display);font-size:15px;}
.rev-author .nm{font-weight:700;font-size:14px;}
.rev-author .src{font-size:12px;color:var(--muted);}

/* ===================== HOW IT WORKS ===================== */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.step{position:relative;padding:30px 26px;border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--surface);}
.step .num{font-family:var(--font-display);font-weight:700;font-size:54px;line-height:1;color:color-mix(in oklab,var(--accent) 35%,var(--line));margin-bottom:14px;}
.step h3{font-size:20px;margin-bottom:9px;}
.step p{color:var(--muted);font-size:15px;margin:0;}

/* ===================== FAQ ===================== */
.faq{max-width:820px;}
.faq-item{border-bottom:1px solid var(--line);}
.faq-q{display:flex;align-items:center;justify-content:space-between;gap:16px;width:100%;background:none;border:none;padding:22px 0;text-align:left;font-family:var(--font-body);font-weight:700;font-size:17.5px;color:var(--text);}
.faq-q .ic{width:26px;height:26px;flex-shrink:0;border-radius:50%;border:1.5px solid var(--line);display:grid;place-items:center;transition:.2s;}
.faq-q .ic svg{width:15px;height:15px;transition:transform .25s;}
.faq-item.open .faq-q .ic{background:var(--accent);border-color:var(--accent);color:var(--accent-ink);}
.faq-item.open .faq-q .ic svg{transform:rotate(45deg);}
.faq-a{overflow:hidden;max-height:0;transition:max-height .3s ease;}
.faq-a p{padding:0 0 22px;margin:0;color:var(--muted);font-size:15.5px;max-width:90%;}

/* ===================== LOCATION ===================== */
.loc-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line);}
.loc-info{padding:44px;background:var(--surface);}
.loc-info h3{font-size:28px;margin-bottom:22px;}
.loc-row{display:flex;gap:14px;align-items:flex-start;padding:15px 0;border-top:1px solid var(--line);}
.loc-row:first-of-type{border-top:none;}
.loc-row svg{width:20px;height:20px;color:var(--accent);flex-shrink:0;margin-top:2px;}
.loc-row .lt{font-weight:700;font-size:15px;}
.loc-row .ls{font-size:14px;color:var(--muted);}
.loc-map{position:relative;min-height:380px;background:var(--dark-bg-2);}
.loc-map .ph{position:absolute;inset:0;border-radius:0;border:none;}

/* ===================== FINAL CTA ===================== */
.finalcta{text-align:center;padding:96px 0;background:var(--ink);color:#fff;position:relative;overflow:hidden;}
.finalcta h2{font-size:clamp(34px,4.4vw,60px);color:#fff;margin-bottom:18px;}
.finalcta p{color:var(--muted-dark);max-width:560px;margin:0 auto 32px;font-size:17px;}
.finalcta .row{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}

/* ===================== FOOTER ===================== */
.footer{background:var(--ink);color:var(--muted-dark);padding:62px 0 28px;border-top:1px solid var(--line-dark);}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:36px;margin-bottom:44px;}
.footer h4{color:#fff;font-family:var(--font-body);text-transform:uppercase;letter-spacing:.1em;font-size:12px;margin-bottom:18px;font-weight:700;}
.footer-links{display:flex;flex-direction:column;gap:11px;}
.footer-links a{font-size:14px;color:var(--muted-dark);}
.footer-links a:hover{color:#fff;}
.footer-brand p{font-size:14px;max-width:300px;line-height:1.6;}
.footer-social{display:flex;gap:10px;margin-top:18px;}
.footer-social a{width:38px;height:38px;border-radius:var(--radius);border:1px solid var(--line-dark);display:grid;place-items:center;color:var(--muted-dark);transition:.2s;}
.footer-social a:hover{color:#fff;border-color:var(--accent);background:var(--accent);}
.footer-social svg{width:17px;height:17px;}
.footer-bottom{border-top:1px solid var(--line-dark);padding-top:24px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:13px;}

/* ===================== PROGRAM PAGE ===================== */
.breadcrumb{font-size:13px;color:var(--muted);padding:18px 0;}
.breadcrumb a:hover{color:var(--accent);}
.pp-hero{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center;padding:46px 0 64px;}
.pp-hero h1{font-size:clamp(32px,4.2vw,56px);margin-bottom:18px;}
.pp-hero .pp-media{aspect-ratio:4/5;position:relative;}
.pp-hero .pp-media .ph{position:absolute;inset:0;}
.pp-section{padding:56px 0;}
.gain-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px 32px;max-width:760px;}
.gain-grid li{display:flex;gap:12px;align-items:flex-start;list-style:none;font-size:16px;}
.gain-grid li svg{width:20px;height:20px;color:var(--accent);flex-shrink:0;margin-top:3px;}
.gain-grid{padding:0;margin:0;}

/* ===================== FREE CLASS / FORM ===================== */
.fc-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:54px;align-items:start;}
.fc-points{list-style:none;padding:0;margin:24px 0 0;display:grid;gap:16px;}
.fc-points li{display:flex;gap:13px;align-items:flex-start;color:var(--muted-dark);font-size:16px;}
.fc-points li svg{width:22px;height:22px;color:var(--accent);flex-shrink:0;margin-top:2px;}
.form-card{background:var(--surface);border-radius:var(--radius-lg);padding:34px;box-shadow:var(--shadow);border:1px solid var(--line);color:var(--text);}
.form-card h3{font-size:25px;margin-bottom:6px;color:var(--text);}
.field{margin-bottom:16px;}
.field label{display:block;font-size:13px;font-weight:700;margin-bottom:7px;color:var(--text);}
.field input,.field select{
  width:100%;padding:13px 14px;border:1.5px solid var(--line);border-radius:var(--radius);
  font-family:var(--font-body);font-size:15px;background:var(--paper);color:var(--text);transition:border-color .15s;
}
.field input:focus,.field select:focus{outline:none;border-color:var(--accent);}
.field.err input,.field.err select{border-color:var(--accent);background:color-mix(in oklab,var(--accent) 7%,var(--surface));}
.field .msg{font-size:12px;color:var(--accent);margin-top:6px;font-weight:600;}
.form-note{font-size:12.5px;color:var(--muted);text-align:center;margin-top:14px;}
.thanks{text-align:center;padding:40px 10px;}
.thanks .big-check{width:74px;height:74px;border-radius:50%;background:color-mix(in oklab,var(--accent) 14%,var(--surface));color:var(--accent);display:grid;place-items:center;margin:0 auto 22px;}
.thanks .big-check svg{width:38px;height:38px;}

/* ===================== generic page hero (light) ===================== */
.page-hero{padding:64px 0 30px;}
.page-hero h1{font-size:clamp(34px,4.4vw,58px);margin-bottom:16px;}

/* schedule table */
.sched{width:100%;border-collapse:collapse;background:var(--surface);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line);}
.sched th{background:var(--ink);color:#fff;font-family:var(--font-display);text-transform:var(--disp-transform);font-weight:var(--disp-weight);text-align:left;padding:14px 18px;font-size:15px;}
.sched td{padding:14px 18px;border-top:1px solid var(--line);font-size:14.5px;}
.sched tr:hover td{background:color-mix(in oklab,var(--accent) 5%,var(--surface));}
.sched .prog{font-weight:700;}
.sched .age{color:var(--muted);font-size:13px;}

/* ===================== RESPONSIVE ===================== */
@media (max-width:980px){
  .hero-grid,.ray-grid,.loc-grid,.pp-hero,.fc-grid{grid-template-columns:1fr;gap:36px;}
  .hero-media,.ray-media,.pp-hero .pp-media{max-width:440px;}
  .prog-grid,.rev-grid,.steps,.benefits{grid-template-columns:repeat(2,1fr);}
  .hero-strip-inner{grid-template-columns:repeat(2,1fr);}
  .hero-strip-cell:nth-child(2){border-right:none;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px;}
  .gain-grid{grid-template-columns:1fr;}
}
@media (max-width:1024px){
  .nav-links{display:none;}
  .hamburger{display:block;}
}
@media (max-width:680px){
  .wrap{padding:0 20px;}
  .section{padding:60px 0;}
  .nav-phone{display:none;}
  .sticky-cta{display:flex;}
  body{padding-bottom:58px;}
  .prog-grid,.rev-grid,.steps,.benefits,.hero-strip-inner{grid-template-columns:1fr;}
  .hero-strip-cell{border-right:none;border-bottom:1px solid var(--line-dark);}
  .hero-statcard{left:0;bottom:-18px;}
  .loc-info,.form-card{padding:26px;}
  .nav-btn{padding:9px 13px;font-size:13px;}
}

/* ============================================================
   GOD MODE LAYER — cinematic hero, creed marquee, program finder,
   animated counters, scroll reveal, dramatized reviews.
   ============================================================ */

/* ---- scroll reveal: disabled (content always visible) ---- */
.reveal{}

/* ===================== MISSION ===================== */
.mission{background:var(--dark-bg);color:var(--on-dark);padding:98px 0;border-top:1px solid var(--line-dark);}
.mission-head{max-width:940px;margin-bottom:46px;}
.mission-head h2{font-size:clamp(32px,4.6vw,64px);color:#fff;line-height:1.0;}
.mission-head h2 .em{color:var(--accent);}
[data-theme="dojang"] .mission-head h2 .em{font-style:italic;}
.mission-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;}
.mission-lead p{font-size:clamp(18px,1.7vw,23px);color:#fff;line-height:1.5;margin:0 0 24px;font-weight:500;}
.mission-vals{display:flex;flex-wrap:wrap;gap:10px;}
.mission-chip{font-family:var(--font-mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);
  border:1px solid color-mix(in oklab,var(--accent) 45%,transparent);border-radius:var(--radius-pill);padding:8px 15px;}
.mission-body p{color:var(--muted-dark);font-size:16.5px;line-height:1.65;margin:0 0 18px;}
.mission-body p:last-child{margin-bottom:0;}
.mission-foot{display:flex;align-items:center;gap:22px;margin-top:50px;font-family:var(--font-display);
  text-transform:var(--disp-transform);font-weight:var(--disp-weight);font-size:clamp(20px,2.3vw,32px);color:#fff;letter-spacing:var(--disp-tracking);line-height:1.1;}
.mission-rule{height:2px;width:64px;background:var(--accent);flex-shrink:0;}
@media (max-width:880px){.mission-grid{grid-template-columns:1fr;gap:28px;}.mission{padding:64px 0;}.mission-foot{gap:16px;}.mission-rule{width:40px;}}

/* ===================== CINEMATIC HERO ===================== */
.xh{position:relative;background:#0b0b0d;color:#fff;overflow:hidden;}
.xh-photo{position:absolute;top:0;right:0;bottom:0;width:60%;z-index:0;}
.xh-photo img{width:100%;height:100%;object-fit:cover;object-position:center 22%;display:block;}
/* scrim: fade the photo's left edge into black so copy stays legible */
.xh-photo::after{content:"";position:absolute;inset:0;background:
  linear-gradient(90deg,#0b0b0d 4%,rgba(11,11,13,.86) 26%,rgba(11,11,13,.25) 52%,rgba(11,11,13,0) 74%),
  linear-gradient(0deg,#0b0b0d 1%,rgba(11,11,13,0) 26%);}
.xh-vlabel{position:absolute;left:18px;top:50%;transform:translateY(-50%) rotate(180deg);writing-mode:vertical-rl;
  font-family:var(--font-mono);font-size:11px;letter-spacing:.42em;text-transform:uppercase;color:color-mix(in oklab,#fff 32%,transparent);z-index:2;}
.xh-inner{position:relative;z-index:3;padding:88px 0 56px;max-width:760px;}
[data-theme="dojang"] .xh-inner{max-width:800px;}
.xh-kicker{display:inline-flex;align-items:center;gap:11px;font-family:var(--font-mono);font-size:12px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--muted-dark);margin-bottom:26px;}
.xh-kicker .pulse{width:9px;height:9px;border-radius:50%;background:var(--accent);position:relative;flex-shrink:0;}
.xh-kicker .pulse::after{content:"";position:absolute;inset:-5px;border-radius:50%;border:1.5px solid var(--accent);opacity:.55;animation:xhpulse 2s ease-out infinite;}
@keyframes xhpulse{0%{transform:scale(.6);opacity:.7}100%{transform:scale(1.7);opacity:0}}
.xh h1{font-size:clamp(40px,6.6vw,92px);line-height:.94;color:#fff;margin:0 0 26px;letter-spacing:-.012em;text-wrap:balance;}
.xh h1 .em{color:var(--accent);}
[data-theme="dojang"] .xh h1 .em{font-style:italic;}
.xh h1 .belt{display:inline-block;position:relative;}
.xh-lead{font-size:clamp(16px,1.45vw,20px);color:var(--muted-dark);max-width:540px;line-height:1.55;margin:0 0 34px;}
.xh-cta{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:38px;}
.xh-trust{display:flex;align-items:center;gap:16px;flex-wrap:wrap;}
.xh-trust .ava{display:flex;}
.xh-trust .ava span{width:38px;height:38px;border-radius:50%;border:2px solid #0b0b0d;margin-left:-12px;display:grid;place-items:center;
  font-family:var(--font-display);font-weight:700;font-size:14px;color:#fff;background:var(--dark-bg-2);}
.xh-trust .ava span:first-child{margin-left:0;}
.xh-trust .tt{font-size:13.5px;color:var(--muted-dark);line-height:1.35;}
.xh-trust .tt b{color:#fff;}
.xh-trust .stars{vertical-align:-2px;}

/* counter strip pinned to hero bottom */
.xh-stats{position:relative;z-index:3;border-top:1px solid var(--line-dark);}
.xh-stats-inner{display:grid;grid-template-columns:repeat(4,1fr);}
.xh-stat{padding:24px 26px;border-right:1px solid var(--line-dark);}
.xh-stat:last-child{border-right:none;}
.xh-stat .n{font-family:var(--font-display);font-weight:700;font-size:clamp(28px,3vw,40px);color:#fff;line-height:1;letter-spacing:-.01em;}
[data-theme="iron"] .xh-stat .n{text-transform:uppercase;}
.xh-stat .n .u{color:var(--accent);}
.xh-stat .l{font-size:12.5px;color:var(--muted-dark);margin-top:9px;font-weight:600;letter-spacing:.02em;}

/* ===================== CREED MARQUEE ===================== */
.creed{background:var(--accent);color:var(--accent-ink);overflow:hidden;position:relative;border-top:1px solid color-mix(in oklab,#000 18%,var(--accent));}
.creed-track{display:inline-flex;align-items:center;white-space:nowrap;padding:16px 0;animation:creedscroll 32s linear infinite;will-change:transform;}
.creed:hover .creed-track{animation-play-state:paused;}
.creed-item{display:inline-flex;align-items:center;font-family:var(--font-display);font-weight:600;text-transform:uppercase;
  letter-spacing:.06em;font-size:clamp(16px,1.6vw,21px);}
[data-theme="dojang"] .creed-item{font-family:var(--font-body);font-weight:800;letter-spacing:.04em;}
.creed-dot{width:7px;height:7px;margin:0 30px;transform:rotate(45deg);background:color-mix(in oklab,var(--accent-ink) 78%,transparent);flex-shrink:0;}
@keyframes creedscroll{0%{transform:translateX(0)}100%{transform:translateX(-33.333%)}}
@media (prefers-reduced-motion:reduce){.creed-track{animation:none;}}

/* ===================== PROGRAM FINDER ===================== */
.finder{background:var(--ink);color:#fff;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line-dark);}
.finder-top{padding:34px 34px 0;}
.finder-tabs{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px;}
.finder-tab{display:flex;flex-direction:column;gap:3px;padding:12px 16px;border-radius:var(--radius);border:1.5px solid var(--line-dark);
  background:transparent;color:var(--muted-dark);text-align:left;transition:.16s;min-width:128px;white-space:nowrap;}
.finder-tab:hover{border-color:color-mix(in oklab,#fff 28%,transparent);color:#fff;}
.finder-tab.on{background:var(--accent);border-color:var(--accent);color:var(--accent-ink);}
.finder-tab .ft{font-family:var(--font-display);font-weight:700;font-size:16px;line-height:1.15;text-transform:uppercase;letter-spacing:.01em;white-space:nowrap;}
[data-theme="dojang"] .finder-tab .ft{font-family:var(--font-body);text-transform:none;}
.finder-tab .fs{font-size:11.5px;font-weight:600;opacity:.78;text-transform:none;letter-spacing:0;white-space:nowrap;}
.finder-body{display:grid;grid-template-columns:.95fr 1.05fr;gap:0;margin-top:30px;border-top:1px solid var(--line-dark);}
.finder-media{position:relative;min-height:300px;background:#0c0c0e;}
.finder-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.finder-media .ph{position:absolute;inset:0;border-radius:0;border:none;}
.finder-info{padding:38px;display:flex;flex-direction:column;justify-content:center;}
.finder-info .fi-age{font-family:var(--font-mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:12px;}
.finder-info h3{font-size:clamp(26px,2.6vw,34px);color:#fff;margin-bottom:14px;}
.finder-info p{color:var(--muted-dark);font-size:16px;line-height:1.55;margin:0 0 14px;}
.finder-info .fi-who{font-size:14.5px;color:var(--muted-dark);background:color-mix(in oklab,#fff 5%,transparent);
  border-left:2px solid var(--accent);padding:12px 16px;border-radius:0 var(--radius) var(--radius) 0;margin-bottom:24px;}
.finder-cta{display:flex;gap:13px;flex-wrap:wrap;}

/* ===================== RATING BANNER ===================== */
.ratebanner{display:flex;align-items:center;gap:34px;flex-wrap:wrap;background:var(--ink);color:#fff;
  border-radius:var(--radius-lg);padding:30px 38px;margin-bottom:38px;}
.ratebanner .rb-score{display:flex;align-items:baseline;gap:4px;}
.ratebanner .rb-score .big{font-family:var(--font-display);font-weight:700;font-size:62px;line-height:.9;color:#fff;}
.ratebanner .rb-score .out{font-size:20px;color:var(--muted-dark);font-weight:600;}
.ratebanner .rb-mid{flex:1;min-width:200px;}
.ratebanner .rb-mid .stars{margin-bottom:7px;}
.ratebanner .rb-mid .stars svg{width:21px;height:21px;}
.ratebanner .rb-mid .t{font-size:15px;color:var(--muted-dark);}
.ratebanner .rb-mid .t b{color:#fff;}
.ratebanner .rb-g{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--muted-dark);font-weight:600;
  border:1px solid var(--line-dark);border-radius:var(--radius-pill);padding:9px 15px;}
.ratebanner .rb-g .gdot{display:inline-flex;gap:2px;}
.ratebanner .rb-g .gdot i{width:8px;height:8px;border-radius:50%;}

/* ===================== GOD-MODE RESPONSIVE ===================== */
@media (max-width:980px){
  .xh-photo{width:100%;opacity:.5;}
  .xh-photo::after{background:linear-gradient(90deg,#0b0b0d 8%,rgba(11,11,13,.7) 60%,rgba(11,11,13,.5) 100%),linear-gradient(0deg,#0b0b0d 2%,rgba(11,11,13,0) 40%);}
  .xh-inner{max-width:none;padding:64px 0 44px;}
  .xh-vlabel{display:none;}
  .xh-stats-inner{grid-template-columns:repeat(2,1fr);}
  .xh-stat:nth-child(2){border-right:none;}
  .xh-stat:nth-child(1),.xh-stat:nth-child(2){border-bottom:1px solid var(--line-dark);}
  .finder-body{grid-template-columns:1fr;}
  .finder-media{min-height:220px;}
}
@media (max-width:680px){
  .xh-stats-inner{grid-template-columns:1fr;}
  .xh-stat{border-right:none;border-bottom:1px solid var(--line-dark);}
  .xh-stat:last-child{border-bottom:none;}
  .xh-cta{gap:12px;}
  .xh-cta .btn{width:100%;justify-content:center;}
  .finder-tab{flex:1;min-width:calc(50% - 5px);}
  .ratebanner{padding:24px;gap:20px;}
  .ratebanner .rb-score .big{font-size:48px;}
  .finder-info{padding:26px;}
}
