/* cyrillic-ext */
/* cyrillic */
/* greek-ext */
/* greek */
/* vietnamese */
/* latin-ext */
/* latin */
/* cyrillic-ext */
/* cyrillic */
/* greek-ext */
/* greek */
/* vietnamese */
/* latin-ext */
/* latin */
/* cyrillic-ext */
/* cyrillic */
/* greek-ext */
/* greek */
/* vietnamese */
/* latin-ext */
/* latin */
/* cyrillic-ext */
/* cyrillic */
/* greek-ext */
/* greek */
/* vietnamese */
/* latin-ext */
/* latin */
/**
 * Minified by jsDelivr using clean-css v5.3.3.
 * Original file: /gh/orioncactus/pretendard@1.3.9/dist/web/variable/pretendardvariable-dynamic-subset.css
 *
 * Do NOT use SRI with dynamically generated files! More information: https://www.jsdelivr.com/using-sri-with-dynamic-files
 */
/*# sourceMappingURL=/sm/49af798104dba87a942919357f383e653ce9152ba9bdc9bbfa8ba846a1b04235.map */

:root {
  /* Color - Brand (Laundrygo-inspired: 3-color minimalism) */
  --color-primary:        #CFFF00;   /* Lime Green (from kangaroo logo): point color, max 10% surface area */
  --color-primary-hover:  #B8E600;   /* Darker lime on hover */
  --color-primary-soft:   #F5FFCC;   /* Light lime tint, restricted use */

  --color-ink:            #0A0A0A;   /* Pure black: inverted surfaces + urgency bg */
  --color-paper:          #FFFFFF;   /* Pure white: default bg */

  /* Color - Grayscale */
  --color-black:          #0A0A0A;   /* Ink: strongest emphasis */
  --color-gray-900:       #1A1A1A;   /* Body text */
  --color-gray-700:       #4A4A4A;   /* Secondary body */
  --color-gray-600:       #6B6B6B;   /* Tertiary body */
  --color-gray-500:       #8A8A8A;   /* Caption, placeholder */
  --color-gray-400:       #ABABAB;   /* Muted icons */
  --color-gray-300:       #D1D1D1;   /* Divider lines */
  --color-gray-200:       #E8E8E8;   /* Subtle borders */
  --color-gray-100:       #F2F2F2;   /* Card background */
  --color-gray-50:        #FAFAFA;   /* Lightest off-white, section band */
  --color-white:          #FFFFFF;   /* Default page background */

  /* Color - Semantic Tokens */
  --fg-strong:      var(--color-ink);
  --fg-default:     var(--color-gray-900);
  --fg-muted:       var(--color-gray-700);
  --fg-subtle:      var(--color-gray-500);
  --fg-on-primary:  #0A0A0A;                 /* Black text on lime bg */
  --fg-on-ink:      var(--color-primary);    /* Lime text on ink bg (urgency) */

  --bg-default:     var(--color-paper);
  --bg-band:        var(--color-gray-50);    /* Section band background */
  --bg-card:        var(--color-paper);
  --bg-card-soft:   var(--color-gray-100);
  --bg-ink:         var(--color-ink);        /* Inverted surfaces */

  --border-default: var(--color-gray-200);
  --border-strong:  var(--color-gray-300);

  /* Links: ink only, differentiated by underline. Lime reserved for CTA. */
  --link-color:     var(--color-ink);
  --link-hover:     var(--color-ink);

  /* Success = lime. Urgency = ink surface + lime text. Never red. */
  --success-color:  var(--color-primary);
  --urgent-color:   var(--color-primary);    /* Urgency only: countdown, limited slots */
  --urgent-bg:      var(--color-ink);

  /* Typography */
  --font-ko: 'Pretendard Variable', Pretendard, -apple-system, BlinkMacSystemFont, system-ui, Roboto, 'Helvetica Neue', 'Segoe UI', 'Apple SD Gothic Neo', 'Noto Sans KR', 'Malgun Gothic', '맑은 고딕', sans-serif;
  --font-en: 'Inter', sans-serif;
  --font-num: 'Inter', sans-serif;   /* Numbers & English default to Inter */

  /* Scale */
  --fs-display:  36px;   /* Hero / section leadline */
  --fs-h1:       32px;   /* H1 desktop, scales down on mobile */
  --fs-h1-mobile:28px;
  --fs-h2:       24px;
  --fs-h3:       20px;
  --fs-body:     16px;
  --fs-body-lg:  18px;
  --fs-caption:  14px;
  --fs-micro:    12px;

  /* Line height */
  --lh-tight:    1.25;
  --lh-snug:     1.4;
  --lh-normal:   1.6;
  --lh-relaxed:  1.75;

  /* Weight */
  --fw-regular:  400;
  --fw-medium:   500;
  --fw-semibold: 600;
  --fw-bold:     700;
  --fw-extra:    800;

  /* Letter spacing */
  --ls-tight:   -0.02em;   /* Tight for Korean headlines */
  --ls-normal:  0;
  --ls-wide:    0.04em;    /* Eyebrow, small caps */

  /* Spacing - 4px baseline */
  --space-1:  4px;
  --space-2:  8px;
  --space-3:  12px;
  --space-4:  16px;
  --space-5:  20px;
  --space-6:  24px;
  --space-8:  32px;
  --space-10: 40px;
  --space-12: 48px;
  --space-16: 64px;
  --space-20: 80px;    /* Section min padding */
  --space-24: 96px;    /* Section standard padding */

  /* Radii */
  --radius-sm:    4px;
  --radius-md:    8px;    /* Body, icons, buttons */
  --radius-lg:    12px;   /* Cards (data box, product card) */
  --radius-xl:    16px;
  --radius-full:  9999px;

  /* Shadows - restrained, for depth not drama */
  --shadow-xs:    0 1px 2px rgba(10, 10, 10, 0.04);
  --shadow-sm:    0 1px 3px rgba(10, 10, 10, 0.06), 0 1px 2px rgba(10, 10, 10, 0.04);
  --shadow-md:    0 4px 12px rgba(10, 10, 10, 0.06), 0 2px 4px rgba(10, 10, 10, 0.04);
  --shadow-lg:    0 12px 28px rgba(10, 10, 10, 0.10), 0 4px 8px rgba(10, 10, 10, 0.04);
  --shadow-cta:   0 6px 20px rgba(207, 255, 0, 0.35);    /* Lime glow for primary CTA */
  --shadow-urgent:0 6px 20px rgba(10, 10, 10, 0.30);     /* Ink surface, never red */

  /* Motion */
  --ease-out:     cubic-bezier(0.22, 1, 0.36, 1);
  --ease-in-out:  cubic-bezier(0.65, 0, 0.35, 1);
  --dur-fast:     140ms;
  --dur-base:     220ms;
  --dur-slow:     420ms;

  /* Layout */
  --content-max:     640px;     /* Desktop caps at 640px */
  --content-gutter:  20px;      /* Mobile side gutter */
}

/* Semantic element styles - use by default */

html { -webkit-text-size-adjust: 100%; }

body,
button,
input,
select,
textarea {
  font-family: 'Pretendard Variable', Pretendard, -apple-system, BlinkMacSystemFont, system-ui, Roboto, 'Helvetica Neue', 'Segoe UI', 'Apple SD Gothic Neo', 'Noto Sans KR', 'Malgun Gothic', sans-serif;
}

body {
  font-size: var(--fs-body);
  line-height: var(--lh-normal);
  color: var(--fg-default);
  background: var(--bg-default);
  font-feature-settings: "ss02", "ss06";
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Headings */
h1, .h1 {
  font-weight: var(--fw-bold);
  font-size: var(--fs-h1-mobile);
  line-height: var(--lh-tight);
  letter-spacing: var(--ls-tight);
  color: var(--fg-strong);
  margin: 0;
}
@media (min-width: 768px) {
  h1, .h1 { font-size: var(--fs-h1); }
}

h2, .h2 {
  font-weight: var(--fw-semibold);
  font-size: var(--fs-h2);
  line-height: var(--lh-snug);
  letter-spacing: var(--ls-tight);
  color: var(--fg-strong);
  margin: 0;
}

h3, .h3 {
  font-weight: var(--fw-semibold);
  font-size: var(--fs-h3);
  line-height: var(--lh-snug);
  color: var(--fg-strong);
  margin: 0;
}

p, .body {
  font-size: var(--fs-body);
  font-weight: var(--fw-regular);
  line-height: var(--lh-normal);
  color: var(--fg-default);
  margin: 0;
  text-wrap: pretty;
}

.body-lg {
  font-size: var(--fs-body-lg);
  line-height: var(--lh-relaxed);
}

.caption {
  font-size: var(--fs-caption);
  line-height: var(--lh-snug);
  color: var(--fg-muted);
}

.eyebrow {
  font-family: 'Inter', sans-serif;
  font-size: var(--fs-micro);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  color: var(--color-gray-700);
}

.numeric, .num {
  font-family: 'Inter', sans-serif;
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum";
}

/* Links: ink + underline on hover. Lime is reserved for CTAs. */
a {
  color: var(--link-color);
  text-decoration: none;
  transition: color var(--dur-fast) var(--ease-out);
}
a:hover { color: var(--link-hover); text-decoration: underline; }

/* Dividers */
hr {
  border: 0;
  border-top: 1px solid var(--border-default);
  margin: var(--space-12) 0;
}

/* Selection */
::selection { background: var(--color-primary); color: #0A0A0A; }


/* HPS 랜딩 — 섹션 1~7 */

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }

body {
  background: var(--color-gray-100);
}

/* Page container — mobile-first, capped at 640px */
.page {
  max-width: var(--content-max);
  margin: 0 auto;
  background: var(--bg-default);
  position: relative;
  min-height: 100vh;
  box-shadow: 0 0 0 1px var(--border-default);
}

/* ---------- Countdown Bar (sticky top) ---------- */
.countdown-bar {
  position: sticky;
  top: 0;
  z-index: 30;
  background: var(--color-ink);
  color: var(--color-paper);
  padding: 10px var(--content-gutter);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}
.countdown-bar .label {
  font-size: var(--fs-micro);
  color: var(--color-gray-500);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
  font-weight: var(--fw-medium);
}
.countdown-bar .nums {
  display: flex;
  gap: var(--space-1);
  font-family: var(--font-num);
  font-variant-numeric: tabular-nums;
  font-weight: var(--fw-bold);
}
.countdown-bar .u {
  padding: 4px 8px;
  border-radius: var(--radius-sm);
  background: rgba(207, 255, 0, 0.08);
  color: var(--color-primary);
  font-size: 13px;
  display: inline-flex;
  align-items: baseline;
  gap: 2px;
}
.countdown-bar .u .suffix {
  opacity: 0.55;
  font-weight: var(--fw-medium);
  font-size: 10px;
}

/* ---------- Navigation ---------- */
.nav {
  position: sticky;
  top: 36px;
  z-index: 25;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px var(--content-gutter);
  background: rgba(255, 255, 255, 0.96);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border-default);
}
.nav .brand {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: var(--color-ink);
}
.nav .brand:hover { text-decoration: none; }
.nav .brand-logo {
  width: 32px;
  height: 32px;
  border-radius: var(--radius-full);
  object-fit: cover;
  display: block;
  flex-shrink: 0;
}
.nav .brand-name {
  font-family: var(--font-ko);
  font-weight: var(--fw-bold);
  font-size: 15px;
  color: var(--color-ink);
  letter-spacing: var(--ls-tight);
  white-space: nowrap;
}
.nav .brand-name .sub {
  color: var(--color-gray-500);
  font-weight: var(--fw-medium);
  margin-left: 4px;
}
.nav-cta {
  display: inline-flex;
  align-items: center;
  height: 36px;
  padding: 0 14px;
  border-radius: var(--radius-md);
  background: var(--color-ink);
  color: var(--color-primary);
  border: 0;
  font-family: inherit;
  font-size: 13px;
  font-weight: var(--fw-bold);
  cursor: pointer;
  letter-spacing: var(--ls-tight);
  transition: transform var(--dur-base) var(--ease-out),
              background var(--dur-base) var(--ease-out);
}
.nav-cta:hover {
  background: #000;
  transform: scale(1.02);
}
.nav-cta:active { transform: scale(0.98); }

/* ---------- Sections ---------- */
.section {
  padding: var(--space-20) var(--content-gutter);
}
.section.story {
  padding: var(--space-24) var(--content-gutter);
}
.section.band {
  background: var(--bg-band);
}

/* Eyebrow */
.eyebrow {
  font-family: var(--font-en);
  font-size: var(--fs-micro);
  font-weight: var(--fw-bold);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-gray-700);
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
}
.eyebrow::before {
  content: "";
  width: 20px;
  height: 2px;
  background: var(--color-ink);
}

/* ---------- Section 1 · Hero ---------- */
.hero {
  padding-top: var(--space-16);
  padding-bottom: var(--space-20);
}
.hero .kicker {
  font-family: var(--font-en);
  font-size: var(--fs-micro);
  font-weight: var(--fw-bold);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-ink);
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
}
.hero .kicker::before {
  content: "";
  width: 28px;
  height: 2px;
  background: var(--color-primary);
  display: inline-block;
}
.hero h1 {
  margin-top: var(--space-5);
  font-size: 34px;
  font-weight: var(--fw-extra);
  line-height: 1.2;
  letter-spacing: var(--ls-tight);
  color: var(--color-ink);
  text-wrap: balance;
}
.hero h1 .accent {
  position: relative;
  display: inline-block;
}
.hero h1 .accent::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 2px;
  height: 10px;
  background: var(--color-primary);
  z-index: -1;
  opacity: 0.9;
}
.hero .sub {
  margin-top: var(--space-5);
  font-size: var(--fs-body-lg);
  line-height: var(--lh-relaxed);
  color: var(--color-gray-700);
  text-wrap: pretty;
}
.hero .cta-group {
  margin-top: var(--space-10);
}
.hero .meta {
  margin-top: var(--space-3);
  font-size: var(--fs-caption);
  color: var(--color-gray-600);
  font-weight: var(--fw-medium);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.hero .meta .dot {
  width: 3px;
  height: 3px;
  border-radius: var(--radius-full);
  background: var(--color-gray-400);
}
.hero .meta .tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 3px 8px;
  border-radius: var(--radius-full);
  background: var(--color-ink);
  color: var(--color-primary);
  font-family: var(--font-num);
  font-variant-numeric: tabular-nums;
  font-size: 11px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.02em;
}

/* ---------- Hero teaser (Before/After mini thumbnails) ---------- */
.hero-teaser {
  margin-top: var(--space-8);
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-gray-200);
}
.hero-teaser .ht-thumbs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: stretch;
  gap: var(--space-3);
  position: relative;
}
.hero-teaser .ht-thumb {
  position: relative;
  aspect-ratio: 3 / 4;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--color-gray-100);
}
.hero-teaser .ht-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.hero-teaser .ht-tag {
  position: absolute;
  top: 12px;
  left: 12px;
  padding: 4px 10px;
  background: var(--color-ink);
  color: var(--color-paper);
  font-family: var(--font-en);
  font-size: 10px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.08em;
  border-radius: 3px;
  z-index: 2;
}
.hero-teaser .ht-kg {
  position: absolute;
  bottom: 12px;
  right: 12px;
  padding: 5px 11px;
  background: rgba(10, 10, 10, 0.72);
  color: var(--color-paper);
  border-radius: 3px;
  font-family: var(--font-num);
  font-variant-numeric: tabular-nums;
  font-size: 18px;
  font-weight: var(--fw-extra);
  backdrop-filter: blur(4px);
  line-height: 1;
  z-index: 2;
}
.hero-teaser .ht-kg small {
  font-size: 11px;
  font-weight: var(--fw-bold);
  margin-left: 1px;
  opacity: 0.85;
}
.hero-teaser .ht-arrow {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--color-paper);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-en);
  font-size: 18px;
  font-weight: var(--fw-extra);
  color: var(--color-ink);
  z-index: 3;
  box-shadow: 0 2px 8px rgba(0,0,0,0.12);
}
.hero-teaser .ht-caption {
  margin-top: var(--space-4);
  text-align: center;
  font-size: 13px;
  color: var(--color-gray-600);
  letter-spacing: var(--ls-tight);
}
.hero-teaser .ht-caption strong {
  color: var(--color-ink);
  font-weight: var(--fw-extra);
}

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  width: 100%;
  height: 58px;
  padding: 0 var(--space-6);
  border-radius: var(--radius-md);
  border: 0;
  font-family: inherit;
  font-size: var(--fs-body);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-tight);
  cursor: pointer;
  transition: transform var(--dur-base) var(--ease-out),
              background var(--dur-base) var(--ease-out),
              box-shadow var(--dur-base) var(--ease-out);
}
.btn-primary {
  background: var(--color-primary);
  color: var(--fg-on-primary);
  box-shadow: var(--shadow-sm);
}
.btn-primary:hover {
  background: var(--color-primary-hover);
  transform: scale(1.01);
  box-shadow: var(--shadow-cta);
}
.btn-primary:active { transform: scale(0.985); }
.btn-primary:focus-visible {
  outline: 2px solid var(--color-ink);
  outline-offset: 3px;
}
.btn .arrow {
  font-family: var(--font-en);
  font-weight: var(--fw-bold);
  transition: transform var(--dur-base) var(--ease-out);
}
.btn-primary:hover .arrow { transform: translateX(3px); }

/* ---------- Section 2 · Empathy ---------- */
.empathy h2 {
  margin-top: var(--space-3);
  font-size: 24px;
  font-weight: var(--fw-bold);
  line-height: 1.35;
  letter-spacing: var(--ls-tight);
  color: var(--color-ink);
  text-wrap: balance;
}
.empathy .lead {
  margin-top: var(--space-4);
  color: var(--color-gray-700);
  font-size: var(--fs-body);
  line-height: var(--lh-relaxed);
}
.empathy .monologue-list {
  margin-top: var(--space-8);
  list-style: none;
  padding: 0;
}
.empathy .mono-item {
  padding: var(--space-5) 0;
  border-bottom: 1px solid var(--border-default);
  display: grid;
  grid-template-columns: 36px 1fr;
  gap: var(--space-3);
  align-items: start;
}
.empathy .mono-item:first-child { border-top: 1px solid var(--border-strong); }
.empathy .mono-item .num {
  font-family: var(--font-en);
  font-variant-numeric: tabular-nums;
  font-size: 13px;
  font-weight: var(--fw-bold);
  color: var(--color-gray-500);
  letter-spacing: 0.02em;
  padding-top: 2px;
}
.empathy .mono-item .text {
  font-size: var(--fs-body);
  line-height: var(--lh-relaxed);
  color: var(--color-gray-900);
  text-wrap: pretty;
}
.empathy .closer {
  margin-top: var(--space-10);
  padding-top: var(--space-8);
  border-top: 2px solid var(--color-ink);
}
.empathy .closer p {
  font-size: 20px;
  font-weight: var(--fw-bold);
  color: var(--color-ink);
  line-height: 1.45;
  letter-spacing: var(--ls-tight);
  text-wrap: balance;
}
.empathy .closer .tail {
  margin-top: var(--space-3);
  font-size: var(--fs-caption);
  color: var(--color-gray-600);
  font-weight: var(--fw-regular);
  line-height: var(--lh-relaxed);
}

/* ---------- Section 3 · Expert story ---------- */
.story h2 {
  margin-top: var(--space-3);
  font-size: 26px;
  font-weight: var(--fw-bold);
  line-height: 1.3;
  letter-spacing: var(--ls-tight);
  color: var(--color-ink);
}
.story .intro {
  margin-top: var(--space-6);
  font-size: var(--fs-body-lg);
  line-height: var(--lh-relaxed);
  color: var(--color-gray-900);
}
.story p {
  margin-top: var(--space-5);
  font-size: var(--fs-body);
  line-height: var(--lh-relaxed);
  color: var(--color-gray-700);
}
.story p.emphasis {
  color: var(--color-ink);
  font-weight: var(--fw-semibold);
}
.story .inline-quote {
  margin-top: var(--space-5);
  padding-left: var(--space-4);
  border-left: 2px solid var(--color-gray-300);
  color: var(--color-gray-700);
  font-style: normal;
}
.story .inline-quote p {
  margin-top: var(--space-2);
  color: var(--color-gray-700);
}
.story .inline-quote p:first-child { margin-top: 0; }

.story .transform-chip {
  margin-top: var(--space-8);
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  padding: 10px 16px;
  background: var(--color-ink);
  color: var(--color-paper);
  border-radius: var(--radius-full);
  font-family: var(--font-num);
  font-variant-numeric: tabular-nums;
  font-size: 14px;
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-tight);
}
.story .transform-chip .arrow {
  color: var(--color-primary);
  font-weight: var(--fw-bold);
}
.story .transform-chip .big {
  font-size: 16px;
  font-weight: var(--fw-bold);
}

.story .ba-grid {
  margin-top: var(--space-8);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
}
.story .ba-cell {
  position: relative;
  aspect-ratio: 3 / 4;
  border-radius: var(--radius-lg);
  background: var(--color-gray-100);
  border: 1px dashed var(--border-strong);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: var(--color-gray-500);
  overflow: hidden;
}
.story .ba-cell .tag {
  position: absolute;
  top: 12px;
  left: 12px;
  padding: 4px 10px;
  background: var(--color-ink);
  color: var(--color-paper);
  font-family: var(--font-en);
  font-size: 10px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.08em;
  border-radius: var(--radius-sm);
}
.story .ba-cell .weight {
  font-family: var(--font-num);
  font-variant-numeric: tabular-nums;
  font-size: 28px;
  font-weight: var(--fw-extra);
  color: var(--color-gray-400);
  letter-spacing: var(--ls-tight);
}
.story .ba-cell .filename {
  margin-top: var(--space-2);
  font-family: var(--font-en);
  font-size: 10px;
  letter-spacing: 0.04em;
  color: var(--color-gray-400);
}
.story .ba-cell .ba-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: var(--radius-lg);
  z-index: 0;
}
.story .ba-cell .tag,
.story .ba-cell .weight {
  z-index: 1;
}
.story .ba-cell:has(.ba-img) {
  border: none;
  background: transparent;
}
.story .ba-cell:has(.ba-img) .weight {
  position: absolute;
  bottom: 12px;
  right: 12px;
  background: rgba(10, 10, 10, 0.72);
  color: var(--color-paper);
  padding: 4px 10px;
  border-radius: 3px;
  backdrop-filter: blur(4px);
  font-size: 18px;
}

/* After photo gallery (slider inside ba-cell) */
.ba-cell-gallery {
  overflow: hidden;
}
.ba-cell-gallery .ba-gallery {
  position: absolute;
  inset: 0;
  border-radius: var(--radius-lg);
  overflow: hidden;
  z-index: 0;
}
.ba-cell-gallery .ba-track {
  display: flex;
  width: 100%;
  height: 100%;
  transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
  will-change: transform;
}
.ba-cell-gallery .ba-slide {
  flex: 0 0 100%;
  width: 100%;
  height: 100%;
  position: relative;
}
.ba-cell-gallery .ba-slide .ba-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 0;
}
.ba-cell-gallery .ba-dots {
  position: absolute;
  bottom: 12px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 6px;
  z-index: 2;
  padding: 4px 8px;
  background: rgba(10, 10, 10, 0.55);
  border-radius: 999px;
  backdrop-filter: blur(4px);
}
.ba-cell-gallery .ba-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  border: none;
  padding: 0;
  background: rgba(255, 255, 255, 0.42);
  cursor: pointer;
  transition: background 0.2s, width 0.2s;
}
.ba-cell-gallery .ba-dot.active {
  background: var(--color-paper);
  width: 18px;
  border-radius: 3px;
}
.story .caption-row {
  margin-top: var(--space-3);
  display: flex;
  justify-content: space-between;
  font-family: var(--font-en);
  font-variant-numeric: tabular-nums;
  font-size: var(--fs-micro);
  color: var(--color-gray-500);
  letter-spacing: var(--ls-wide);
}

.story .divider {
  height: 1px;
  background: var(--border-default);
  margin: var(--space-10) 0;
}
.story .realization {
  margin-top: var(--space-6);
  padding: var(--space-5) var(--space-5);
  background: var(--color-ink);
  color: var(--color-paper);
  border-radius: var(--radius-lg);
}
.story .realization p {
  color: var(--color-paper);
  font-size: var(--fs-body-lg);
  font-weight: var(--fw-semibold);
  line-height: 1.55;
  margin: 0;
  letter-spacing: var(--ls-tight);
}
.story .realization p + p {
  margin-top: var(--space-2);
  color: var(--color-primary);
}

/* ---------- Story B안: Hook + Cards + Collapsed ---------- */
.story-hook {
  margin-top: var(--space-8);
}
.story-hook .hook-line {
  font-size: var(--fs-body-lg);
  line-height: var(--lh-relaxed);
  color: var(--color-gray-900);
  margin-top: var(--space-4);
}
.story-hook .hook-line strong {
  color: var(--color-ink);
  font-weight: var(--fw-bold);
}

.story-turn {
  margin-top: var(--space-6);
  padding: var(--space-6) var(--space-5);
  background: var(--color-gray-50);
  border-left: 3px solid var(--color-primary);
  border-radius: var(--radius-md);
}

/* Period range header (2016 — NOW) — 범위감 있게 */
.story-turn .st-period {
  display: inline-flex;
  align-items: baseline;
  gap: 8px;
  padding: 4px 10px;
  background: var(--color-ink);
  border-radius: var(--radius-sm);
  font-family: var(--font-en);
  letter-spacing: var(--ls-tight);
  line-height: 1;
}
.story-turn .st-period .st-from,
.story-turn .st-period .st-to {
  font-size: 16px;
  font-weight: var(--fw-bold);
  color: var(--color-primary);
  font-variant-numeric: tabular-nums;
}
.story-turn .st-period .st-dash {
  font-size: 13px;
  font-weight: var(--fw-bold);
  color: var(--color-gray-400);
}
.story-turn .st-body {
  margin-top: var(--space-4);
  font-size: var(--fs-body);
  line-height: var(--lh-normal);
  color: var(--color-ink);
  font-weight: var(--fw-medium);
}

/* Certification rows — 자격증만 연도와 함께 */
.story-turn .st-certs {
  margin-top: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  background: #fff;
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
}
.story-turn .st-cert {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--fs-caption);
  line-height: var(--lh-snug);
}
.story-turn .st-cert-year {
  flex-shrink: 0;
  font-family: var(--font-en);
  font-size: 11px;
  font-weight: var(--fw-bold);
  color: var(--color-gray-500);
  letter-spacing: var(--ls-wide);
  padding: 2px 6px;
  background: var(--color-gray-100);
  border-radius: var(--radius-sm);
  font-variant-numeric: tabular-nums;
  min-width: 44px;
  text-align: center;
}
.story-turn .st-cert-name {
  color: var(--color-ink);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-tight);
}
.story-turn .st-cert-name em {
  color: var(--color-gray-600);
  font-style: normal;
  font-weight: var(--fw-regular);
  font-size: 12px;
  margin-left: 2px;
}

/* Journey prose — 자격증 외 학습은 산문으로 */
.story-turn .st-journey {
  margin-top: var(--space-4);
  font-size: var(--fs-caption);
  line-height: var(--lh-relaxed);
  color: var(--color-gray-700);
}

.story-turn .st-bridge {
  margin-top: var(--space-5);
  padding-top: var(--space-4);
  border-top: 1px dashed var(--color-gray-300);
  font-size: var(--fs-body);
  line-height: var(--lh-normal);
  color: var(--color-gray-800);
  font-style: italic;
}
.story-turn .st-bridge strong {
  color: var(--color-ink);
  font-weight: var(--fw-bold);
  font-style: normal;
}

/* 3 lesson cards */
.lesson-grid {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-top: var(--space-10);
}
.lesson-card {
  background: #fff;
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  padding: var(--space-6) var(--space-5);
  box-shadow: var(--shadow-xs);
  position: relative;
}
.lesson-card .lesson-n {
  font-family: var(--font-en);
  font-size: 12px;
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  color: var(--color-gray-500);
  display: block;
  margin-bottom: var(--space-2);
}
.lesson-card .lesson-title {
  font-size: var(--fs-h3);
  font-weight: var(--fw-bold);
  color: var(--color-ink);
  letter-spacing: var(--ls-tight);
  margin-bottom: var(--space-3);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--color-gray-200);
}
.lesson-card .lesson-body {
  font-size: var(--fs-body);
  line-height: var(--lh-normal);
  color: var(--color-gray-700);
}
.lesson-card .lesson-body strong {
  color: var(--color-ink);
  font-weight: var(--fw-bold);
}

/* Collapsed details */
.story-details {
  margin-top: var(--space-10);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  background: var(--color-gray-50);
  overflow: hidden;
}
.story-details summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4) var(--space-5);
  font-size: var(--fs-caption);
  font-weight: var(--fw-semibold);
  color: var(--color-gray-700);
  transition: background var(--dur-fast) var(--ease-out);
}
.story-details summary::-webkit-details-marker { display: none; }
.story-details summary:hover {
  background: var(--color-gray-100);
}
.story-details summary .s-icon {
  font-family: var(--font-en);
  font-size: 18px;
  font-weight: var(--fw-regular);
  color: var(--color-gray-500);
  transition: transform var(--dur-base) var(--ease-out);
}
.story-details[open] summary .s-icon {
  transform: rotate(45deg);
}
.story-details[open] summary {
  border-bottom: 1px solid var(--border-default);
}
.story-details .details-body {
  padding: var(--space-5);
  background: #fff;
}
.story-details .details-body p {
  font-size: var(--fs-body);
  line-height: var(--lh-relaxed);
  color: var(--color-gray-800);
  margin-top: var(--space-3);
}
.story-details .details-body p:first-child {
  margin-top: 0;
}
.story-details .details-body .inline-quote {
  margin: var(--space-5) 0;
  padding-left: var(--space-4);
  border-left: 2px solid var(--color-gray-300);
}
.story-details .details-body .inline-quote p {
  font-style: italic;
  color: var(--color-gray-600);
  margin-top: var(--space-2);
}
.story-details .details-body .realization {
  margin: var(--space-6) 0;
  padding: var(--space-4) var(--space-5);
  background: var(--color-ink);
  border-radius: var(--radius-md);
}
.story-details .details-body .realization p {
  color: var(--color-primary);
  font-weight: var(--fw-semibold);
  margin-top: var(--space-1);
}
.story-details .details-body .realization p:first-child {
  margin-top: 0;
}

.story-closer {
  margin-top: var(--space-10);
  text-align: center;
  font-size: var(--fs-h3);
  line-height: var(--lh-snug);
  color: var(--color-ink);
}

/* ---------- Section 4 · Value proof ---------- */
.proof h2 {
  margin-top: var(--space-3);
  font-size: 28px;
  font-weight: var(--fw-extra);
  line-height: 1.25;
  letter-spacing: var(--ls-tight);
  color: var(--color-ink);
  text-wrap: balance;
}
.proof h2 .hl {
  background: linear-gradient(to top, var(--color-primary) 45%, transparent 45%);
  padding: 0 4px;
}

.proof .sub-section {
  margin-top: var(--space-12);
}
.proof .sub-index {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-en);
  font-size: var(--fs-micro);
  font-weight: var(--fw-bold);
  letter-spacing: 0.12em;
  color: var(--color-gray-500);
}
.proof .sub-index .n {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  background: var(--color-ink);
  color: var(--color-primary);
  border-radius: var(--radius-full);
  font-size: 11px;
}
.proof h3 {
  margin-top: var(--space-3);
  font-size: 20px;
  font-weight: var(--fw-bold);
  line-height: 1.35;
  letter-spacing: var(--ls-tight);
  color: var(--color-ink);
}
.proof .sub-copy {
  margin-top: var(--space-4);
  color: var(--color-gray-700);
  font-size: var(--fs-body);
  line-height: var(--lh-relaxed);
}
.proof .my-quote {
  margin-top: var(--space-5);
  padding: var(--space-4) var(--space-5);
  background: var(--color-ink);
  color: var(--color-primary);
  border-radius: var(--radius-md);
  font-size: var(--fs-body);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-tight);
}

/* Beta summary stat strip (10명 · 12주 · 100% 완주) */
.beta-summary {
  display: grid;
  grid-template-columns: 1fr auto 1fr auto 1fr;
  align-items: center;
  gap: var(--space-3);
  margin-top: var(--space-6);
  padding: var(--space-5) var(--space-4);
  background: var(--color-ink);
  border-radius: var(--radius-lg);
  text-align: center;
}
.beta-summary .bs-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  min-width: 0;
}
.beta-summary .bs-num {
  font-family: var(--font-en);
  font-size: 32px;
  font-weight: var(--fw-extra);
  color: var(--color-primary);
  line-height: 1;
  letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
}
.beta-summary .bs-num .bs-suf {
  font-size: 18px;
  font-weight: var(--fw-bold);
  margin-left: 1px;
}
.beta-summary .bs-label {
  font-size: 11px;
  font-weight: var(--fw-medium);
  color: var(--color-gray-400);
  letter-spacing: var(--ls-tight);
}
.beta-summary .bs-sep {
  width: 1px;
  height: 32px;
  background: rgba(255, 255, 255, 0.12);
  margin: 0 auto;
}
@media (min-width: 480px) {
  .beta-summary .bs-num { font-size: 40px; }
  .beta-summary .bs-num .bs-suf { font-size: 22px; }
  .beta-summary .bs-label { font-size: 12px; }
}

/* Beta reconstruction headline (재구성 중심) */
.beta-re-title {
  font-size: var(--fs-h3);
  font-weight: var(--fw-bold);
  color: var(--color-ink);
  letter-spacing: var(--ls-tight);
  line-height: var(--lh-tight);
}
.beta-re-sub {
  margin-top: var(--space-3);
  font-size: var(--fs-body);
  line-height: var(--lh-normal);
  color: var(--color-gray-700);
}
.beta-re-sub strong {
  color: var(--color-ink);
  font-weight: var(--fw-bold);
}

/* Delta semantic variants (up/down) */
.metric-row .delta.up {
  background: var(--color-primary);
  color: var(--color-ink);
}
.metric-row .delta.down {
  background: var(--color-ink);
  color: var(--color-primary);
}

/* Metric card */
.metric-headline {
  margin-top: var(--space-6);
  padding: var(--space-6);
  background: var(--color-paper);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
}
.metric-headline .kg {
  font-family: var(--font-num);
  font-variant-numeric: tabular-nums;
  display: flex;
  align-items: baseline;
  gap: var(--space-2);
}
.metric-headline .kg .num {
  font-size: 44px;
  font-weight: var(--fw-extra);
  color: var(--color-ink);
  letter-spacing: -0.03em;
  line-height: 1;
}
.metric-headline .kg .unit {
  font-size: 16px;
  font-weight: var(--fw-bold);
  color: var(--color-gray-600);
}
.metric-headline .kg-label {
  margin-top: var(--space-2);
  font-size: var(--fs-caption);
  color: var(--color-gray-600);
  font-weight: var(--fw-medium);
}
.metric-headline .but {
  margin-top: var(--space-5);
  padding-top: var(--space-5);
  border-top: 1px solid var(--border-default);
  font-size: var(--fs-body);
  font-weight: var(--fw-semibold);
  color: var(--color-ink);
  letter-spacing: var(--ls-tight);
}

.metric-list {
  margin-top: var(--space-5);
  background: var(--color-paper);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.metric-row {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: baseline;
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--border-default);
  gap: var(--space-3);
}
.metric-row:last-child { border-bottom: 0; }
.metric-row .label {
  font-size: var(--fs-caption);
  color: var(--color-gray-700);
  font-weight: var(--fw-medium);
}
.metric-row .val {
  font-family: var(--font-num);
  font-variant-numeric: tabular-nums;
  font-size: var(--fs-body);
  color: var(--color-gray-500);
  letter-spacing: var(--ls-tight);
  text-align: right;
}
.metric-row .val .arrow {
  margin: 0 4px;
  color: var(--color-gray-400);
}
.metric-row .val .to {
  color: var(--color-ink);
  font-weight: var(--fw-bold);
}
.metric-row .delta {
  display: inline-block;
  margin-left: var(--space-2);
  padding: 2px 8px;
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: var(--color-ink);
  font-family: var(--font-num);
  font-variant-numeric: tabular-nums;
  font-size: 11px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.01em;
  vertical-align: 1px;
}

.proof .interpretation {
  margin-top: var(--space-8);
  font-size: var(--fs-body);
  line-height: var(--lh-relaxed);
  color: var(--color-gray-900);
}
.proof .interpretation strong {
  color: var(--color-ink);
  font-weight: var(--fw-bold);
}

/* InBody placeholders */
.inbody-grid {
  margin-top: var(--space-6);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-2);
}
.inbody-cell {
  aspect-ratio: 4 / 3;
  border-radius: var(--radius-md);
  background: var(--color-gray-100);
  border: 1px dashed var(--border-strong);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: var(--color-gray-500);
  padding: var(--space-3);
  text-align: center;
}
.inbody-cell .idx {
  font-family: var(--font-en);
  font-size: 10px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.08em;
  color: var(--color-gray-400);
}
.inbody-cell .name {
  margin-top: var(--space-2);
  font-size: var(--fs-caption);
  font-weight: var(--fw-medium);
  color: var(--color-gray-700);
  letter-spacing: var(--ls-tight);
}
.inbody-cell .file {
  margin-top: var(--space-1);
  font-family: var(--font-en);
  font-size: 10px;
  color: var(--color-gray-400);
  letter-spacing: 0.02em;
}

/* ---------- Photo gallery (peek carousel) ---------- */
.photo-gallery {
  margin-top: var(--space-8);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  background: #fff;
  overflow: hidden;
}
.pg-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--border-default);
  background: var(--color-gray-50);
}
.pg-label {
  font-family: var(--font-en);
  font-size: 10px;
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  color: var(--color-gray-600);
}
.pg-counter {
  font-family: var(--font-en);
  font-size: 11px;
  font-weight: var(--fw-semibold);
  color: var(--color-gray-700);
  font-variant-numeric: tabular-nums;
}
.pg-counter .current {
  color: var(--color-ink);
}

/* Peek viewport: active slide centered, prev/next peek on sides */
.pg-viewport {
  overflow: hidden;
  position: relative;
  touch-action: pan-y;
  padding: 0;
}
.pg-track {
  display: flex;
  gap: var(--space-3);
  transition: transform 0.4s var(--ease-out);
  will-change: transform;
  /* Pad first/last slide so slide[0] lands centered when offset 0.
     Side padding = (100% - slide_width) / 2.
     For 80% slide width: padding = 10% on each side. */
  padding-left: 10%;
  padding-right: 10%;
}
.pg-slide {
  flex: 0 0 80%;
  min-width: 0;
  padding: var(--space-5) 0;
  transition: opacity 0.3s var(--ease-out), transform 0.3s var(--ease-out);
  opacity: 0.35;
  transform: scale(0.94);
}
.pg-slide.active {
  opacity: 1;
  transform: scale(1);
}
.pg-frame {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  padding: var(--space-3);
  background: #fff;
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  height: 100%;
}
.photo-gallery .pg-slide.active .pg-frame {
  border-color: var(--color-ink);
  box-shadow: var(--shadow-md);
}
/* Actual image inside photo gallery frames (replaces pg-ph placeholder) */
.pg-img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: contain;
  background: var(--color-gray-50);
  border-radius: var(--radius-md);
  border: 1px solid var(--border-default);
  display: block;
}
.pg-caption {
  display: flex;
  flex-direction: column;
  gap: 2px;
  text-align: center;
  padding: 0 var(--space-2);
}
.pg-caption strong {
  font-size: var(--fs-body);
  font-weight: var(--fw-bold);
  color: var(--color-ink);
  letter-spacing: var(--ls-tight);
}
.pg-caption span {
  font-size: 12px;
  color: var(--color-gray-600);
}

.pg-controls {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-3) var(--space-4);
  border-top: 1px solid var(--border-default);
  background: var(--color-gray-50);
}
.pg-btn {
  width: 32px;
  height: 32px;
  border-radius: var(--radius-full);
  border: 1px solid var(--color-gray-300);
  background: #fff;
  color: var(--color-ink);
  font-size: 16px;
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: background var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
}
.pg-btn:hover {
  background: var(--color-ink);
  color: var(--color-primary);
  border-color: var(--color-ink);
}
.pg-dots {
  display: flex;
  align-items: center;
  gap: 8px;
}
.pg-dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  background: var(--color-gray-300);
  border: 0;
  padding: 0;
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease-out);
}
.pg-dot:hover {
  background: var(--color-gray-500);
}
.pg-dot.active {
  width: 20px;
  border-radius: 4px;
  background: var(--color-ink);
}

/* Interview gallery variant: testimonial cards */
.photo-gallery.interview .pg-frame {
  padding: var(--space-5);
  gap: var(--space-3);
}
.interview-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  min-height: 240px;
}
.interview-card .iv-head {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--color-gray-200);
}
.interview-card .iv-avatar {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-full);
  background: var(--color-ink);
  color: var(--color-primary);
  display: grid;
  place-items: center;
  font-family: var(--font-en);
  font-size: 14px;
  font-weight: var(--fw-bold);
  flex-shrink: 0;
}
.interview-card .iv-meta {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1;
  min-width: 0;
}
.interview-card .iv-name {
  font-size: var(--fs-body);
  font-weight: var(--fw-bold);
  color: var(--color-ink);
  letter-spacing: var(--ls-tight);
}
.interview-card .iv-role {
  font-size: 11px;
  color: var(--color-gray-600);
  font-weight: var(--fw-regular);
}
.interview-card .iv-stars {
  display: flex;
  gap: 1px;
  font-size: 13px;
  color: var(--color-ink);
  font-family: var(--font-en);
}
.interview-card .iv-quote {
  margin: 0;
  padding: 0;
  font-size: 13px;
  line-height: var(--lh-relaxed);
  color: var(--color-gray-800);
  font-style: normal;
  flex: 1;
}
.interview-card .iv-quote::before {
  content: "\201C";
  font-family: var(--font-en);
  font-size: 28px;
  font-weight: var(--fw-bold);
  color: var(--color-primary);
  line-height: 0.3;
  vertical-align: -0.25em;
  margin-right: 4px;
}
.interview-card .iv-highlights {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: auto;
  padding-top: var(--space-3);
  border-top: 1px dashed var(--color-gray-200);
}
.interview-card .iv-chip {
  padding: 3px 8px;
  background: var(--color-gray-100);
  border-radius: var(--radius-sm);
  font-size: 10px;
  font-weight: var(--fw-semibold);
  color: var(--color-gray-700);
  letter-spacing: var(--ls-tight);
}
.interview-card .iv-chip.positive {
  background: rgba(207, 255, 0, 0.25);
  color: var(--color-ink);
}

/* Testimonial */
.testimonial {
  margin-top: var(--space-10);
  padding: var(--space-6);
  background: var(--color-paper);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-lg);
}
.testimonial .stars {
  display: flex;
  gap: 2px;
  font-family: var(--font-en);
  color: var(--color-ink);
  font-size: 14px;
  letter-spacing: 1px;
}
.testimonial .name {
  margin-top: var(--space-3);
  font-size: var(--fs-caption);
  color: var(--color-gray-600);
  font-weight: var(--fw-medium);
}
.testimonial .name strong {
  color: var(--color-ink);
  font-weight: var(--fw-bold);
  margin-right: var(--space-2);
}
.testimonial blockquote {
  margin: var(--space-4) 0 0;
  padding: 0;
  font-size: var(--fs-body);
  line-height: 1.7;
  color: var(--color-gray-900);
  text-wrap: pretty;
}

/* Closer */
.proof .closer {
  margin-top: var(--space-16);
  padding-top: var(--space-10);
  border-top: 1px solid var(--border-strong);
}
.proof .closer .head {
  font-size: 22px;
  font-weight: var(--fw-extra);
  color: var(--color-ink);
  line-height: 1.35;
  letter-spacing: var(--ls-tight);
  text-wrap: balance;
}
.proof .closer .sub {
  margin-top: var(--space-4);
  font-size: var(--fs-body);
  line-height: var(--lh-relaxed);
  color: var(--color-gray-700);
}

/* ---------- Fade-in ---------- */
.fadein {
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 0.6s var(--ease-out), transform 0.6s var(--ease-out);
}
.fadein.in {
  opacity: 1;
  transform: translateY(0);
}

/* ---------- Responsive up-scaling ---------- */
@media (min-width: 480px) {
  .hero h1 { font-size: 38px; }
  .story h2 { font-size: 28px; }
  .proof h2 { font-size: 30px; }
}


/* =========================================================
   섹션 5~7
   ========================================================= */

/* ---------- Section 5 · Cause Analysis ---------- */
.cause h2 {
  margin-top: var(--space-3);
  font-size: 28px;
  font-weight: var(--fw-extra);
  line-height: 1.25;
  letter-spacing: var(--ls-tight);
  color: var(--color-ink);
  text-wrap: balance;
}

.cause .problem-stack {
  margin-top: var(--space-10);
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}
.cause .problem {
  padding: var(--space-6);
  background: var(--color-paper);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  border-left: 3px solid var(--color-ink);
}
.cause .problem .p-head {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.cause .problem .p-num {
  flex: 0 0 32px;
  height: 32px;
  border-radius: var(--radius-full);
  background: var(--color-ink);
  color: var(--color-paper);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-num);
  font-variant-numeric: tabular-nums;
  font-size: 14px;
  font-weight: var(--fw-bold);
  position: relative;
}
.cause .problem .p-num::after {
  content: "✕";
  position: absolute;
  top: -3px;
  right: -6px;
  width: 14px;
  height: 14px;
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: var(--color-ink);
  font-family: var(--font-en);
  font-size: 8px;
  font-weight: var(--fw-extra);
  display: flex;
  align-items: center;
  justify-content: center;
}
.cause .problem .p-title {
  font-size: var(--fs-body-lg);
  font-weight: var(--fw-bold);
  color: var(--color-ink);
  letter-spacing: var(--ls-tight);
  line-height: 1.3;
  text-wrap: balance;
}
.cause .problem .thoughts {
  margin-top: var(--space-5);
  padding-left: var(--space-3);
  border-left: 2px solid var(--color-gray-200);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.cause .problem .thoughts q {
  font-size: var(--fs-caption);
  color: var(--color-gray-600);
  font-style: normal;
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-tight);
}
.cause .problem .thoughts q::before { content: "\201C" }
.cause .problem .thoughts q::after  { content: "\201D" }
.cause .problem .p-body {
  margin-top: var(--space-5);
  font-size: var(--fs-body);
  line-height: var(--lh-relaxed);
  color: var(--color-gray-900);
}
.cause .problem .p-body strong {
  color: var(--color-ink);
  font-weight: var(--fw-bold);
}

.cause .insight {
  margin-top: var(--space-12);
  padding: var(--space-8) var(--space-6);
  background: var(--color-ink);
  color: var(--color-paper);
  border-radius: var(--radius-lg);
}
.cause .insight .lead {
  font-size: 20px;
  font-weight: var(--fw-bold);
  color: var(--color-paper);
  line-height: 1.4;
  letter-spacing: var(--ls-tight);
  text-wrap: balance;
}

/* 3 insight cards (계획·과학·회복) */
.cause .insight .insight-3cards {
  margin-top: var(--space-6);
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-2);
}
@media (min-width: 480px) {
  .cause .insight .insight-3cards {
    grid-template-columns: 1fr 1fr 1fr;
  }
}
.cause .insight .ic-card {
  padding: var(--space-4);
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(207, 255, 0, 0.25);
  border-radius: var(--radius-md);
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.cause .insight .ic-card .ic-n {
  font-family: var(--font-en);
  font-size: 10px;
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  color: var(--color-primary);
}
.cause .insight .ic-card .ic-label {
  font-size: 17px;
  font-weight: var(--fw-bold);
  color: #fff;
  letter-spacing: var(--ls-tight);
  line-height: 1.2;
}
.cause .insight .ic-card .ic-sub {
  font-size: 12px;
  color: var(--color-gray-400);
  font-weight: var(--fw-regular);
  line-height: var(--lh-normal);
}

.cause .insight .origin {
  margin-top: var(--space-6);
  padding-top: var(--space-5);
  border-top: 1px solid rgba(255, 255, 255, 0.12);
  font-size: var(--fs-caption);
  color: var(--color-gray-500);
  line-height: var(--lh-relaxed);
}
.cause .insight .origin strong {
  color: var(--color-primary);
  font-weight: var(--fw-bold);
}

/* ---------- Section 6 · Mechanism ---------- */
.mech h2 {
  margin-top: var(--space-3);
  font-size: 28px;
  font-weight: var(--fw-extra);
  line-height: 1.25;
  letter-spacing: var(--ls-tight);
  color: var(--color-ink);
  text-wrap: balance;
}
.mech h2 .hl {
  background: linear-gradient(to top, var(--color-primary) 45%, transparent 45%);
  padding: 0 4px;
}
.mech .intro-copy {
  margin-top: var(--space-6);
  font-size: var(--fs-body-lg);
  line-height: var(--lh-relaxed);
  color: var(--color-gray-700);
}
.mech .intro-copy strong {
  color: var(--color-ink);
  font-weight: var(--fw-bold);
}

/* Sheet preview card — the "vignette" opening the mechanism */
.sheet-vignette {
  margin-top: var(--space-8);
  padding: var(--space-6);
  background: var(--color-ink);
  border-radius: var(--radius-lg);
  color: var(--color-paper);
  position: relative;
  overflow: hidden;
}
.sheet-vignette .sv-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--font-en);
  font-size: 10px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.14em;
  color: var(--color-gray-500);
}
.sheet-vignette .sv-head .dot {
  width: 6px;
  height: 6px;
  border-radius: var(--radius-full);
  background: var(--color-primary);
  display: inline-block;
  margin-right: 8px;
  vertical-align: 1px;
}
.sheet-vignette .sv-row {
  margin-top: var(--space-4);
  display: flex;
  align-items: baseline;
  gap: var(--space-3);
  font-family: var(--font-num);
  font-variant-numeric: tabular-nums;
  font-size: var(--fs-body);
  font-weight: var(--fw-medium);
  color: var(--color-paper);
  letter-spacing: var(--ls-tight);
  flex-wrap: wrap;
}
.sheet-vignette .sv-row .sep {
  color: var(--color-gray-600);
  font-weight: var(--fw-regular);
}
.sheet-vignette .sv-row .rpe {
  color: var(--color-primary);
  font-weight: var(--fw-bold);
}
.sheet-vignette .sv-caption {
  margin-top: var(--space-4);
  padding-top: var(--space-4);
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  font-size: var(--fs-caption);
  color: var(--color-gray-500);
  line-height: var(--lh-relaxed);
}

/* Sheet preview: W1 근비대 상체 full routine with gradient mask toggle */
.sheet-preview {
  margin-top: var(--space-8);
  background: var(--color-ink);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.sheet-preview .sp-head {
  padding: var(--space-4) var(--space-5);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  background: rgba(255, 255, 255, 0.03);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}
.sheet-preview .sp-meta {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--fs-caption);
  font-weight: var(--fw-semibold);
  color: #fff;
  letter-spacing: var(--ls-tight);
}
.sheet-preview .sp-dot {
  width: 6px;
  height: 6px;
  background: var(--color-primary);
  border-radius: var(--radius-full);
  display: inline-block;
}
.sheet-preview .sp-hint {
  font-family: var(--font-en);
  font-size: 10px;
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  color: var(--color-gray-500);
  text-transform: uppercase;
}

/* Readiness card (컨디션 체크 결과) */
.sheet-preview .sp-readiness {
  padding: var(--space-4) var(--space-5);
  background: var(--color-primary);
  color: var(--color-ink);
  border-bottom: 1px solid rgba(10, 10, 10, 0.15);
}
.sheet-preview .sp-r-title {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
  font-size: var(--fs-caption);
  line-height: var(--lh-snug);
  color: var(--color-ink);
}
.sheet-preview .sp-r-emoji {
  font-size: 16px;
  line-height: 1;
}
.sheet-preview .sp-r-title strong {
  color: var(--color-ink);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-tight);
}
.sheet-preview .sp-r-grid {
  margin-top: var(--space-3);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px 12px;
}
.sheet-preview .sp-r-item {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  padding: 5px 10px;
  background: rgba(10, 10, 10, 0.08);
  border-radius: var(--radius-sm);
  font-size: 11px;
}
.sheet-preview .sp-r-k {
  color: var(--color-ink);
  opacity: 0.7;
  font-weight: var(--fw-regular);
}
.sheet-preview .sp-r-v {
  color: var(--color-ink);
  font-weight: var(--fw-bold);
}

/* Body: collapsed by default shows top portion only via max-height + gradient fade */
.sheet-preview .sp-body {
  position: relative;
  max-height: 260px;
  overflow: hidden;
  transition: max-height 0.4s var(--ease-out);
}
.sheet-preview[data-expanded="true"] .sp-body {
  max-height: 1000px;
}

.sheet-preview .sp-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
  color: var(--color-gray-200);
}
.sheet-preview .sp-table thead th {
  padding: var(--space-2) var(--space-2);
  background: rgba(255, 255, 255, 0.04);
  text-align: left;
  font-family: var(--font-ko);
  font-size: 10px;
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-tight);
  color: var(--color-gray-500);
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  white-space: nowrap;
}
.sheet-preview .sp-table thead th:first-child { width: 24px; text-align: center; padding-left: var(--space-3); }
.sheet-preview .sp-table thead th:nth-child(3),
.sheet-preview .sp-table thead th:nth-child(4),
.sheet-preview .sp-table thead th:nth-child(5),
.sheet-preview .sp-table thead th:nth-child(6) { text-align: center; }
.sheet-preview .sp-table thead th:last-child { width: 40px; text-align: center; padding-right: var(--space-3); }

.sheet-preview .sp-table tbody td {
  padding: var(--space-3) var(--space-2);
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  vertical-align: middle;
}
.sheet-preview .sp-table tbody td.idx {
  text-align: center;
  font-family: var(--font-en);
  color: var(--color-gray-500);
  font-weight: var(--fw-semibold);
  padding-left: var(--space-3);
}
.sheet-preview .sp-table tbody td.ex {
  color: #fff;
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-tight);
}
.sheet-preview .sp-table tbody td.ex .muted {
  display: block;
  color: var(--color-gray-500);
  font-weight: var(--fw-regular);
  font-size: 10px;
  margin-top: 2px;
}
.sheet-preview .sp-table tbody td.sets,
.sheet-preview .sp-table tbody td.reps,
.sheet-preview .sp-table tbody td.weight,
.sheet-preview .sp-table tbody td.rest {
  text-align: center;
  font-family: var(--font-en);
  font-weight: var(--fw-semibold);
  color: #fff;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
.sheet-preview .sp-table tbody td.rest {
  color: var(--color-gray-300);
  font-weight: var(--fw-regular);
}
.sheet-preview .sp-table tbody td.rpe {
  text-align: center;
  padding-right: var(--space-3);
}
.sheet-preview .sp-table tbody td.rpe span {
  display: inline-block;
  padding: 2px 6px;
  background: var(--color-primary);
  color: var(--color-ink);
  border-radius: var(--radius-sm);
  font-family: var(--font-en);
  font-size: 10px;
  font-weight: var(--fw-bold);
}
.sheet-preview .sp-table tbody td.rpe .dash {
  background: transparent;
  color: var(--color-gray-600);
  padding: 0;
}

/* Zone 2 footer */
.sheet-preview .sp-zone2 {
  padding: var(--space-4) var(--space-5);
  background: rgba(255, 255, 255, 0.03);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.sheet-preview .sp-z-label {
  font-family: var(--font-en);
  font-size: 10px;
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  color: var(--color-primary);
  text-transform: uppercase;
}
.sheet-preview .sp-z-body {
  font-size: 11px;
  line-height: var(--lh-normal);
  color: var(--color-gray-400);
}

/* Gradient fade overlay when collapsed */
.sheet-preview .sp-fade {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 100px;
  background: linear-gradient(to bottom, rgba(10, 10, 10, 0) 0%, var(--color-ink) 80%);
  pointer-events: none;
  transition: opacity 0.3s var(--ease-out);
}
.sheet-preview[data-expanded="true"] .sp-fade {
  opacity: 0;
}

/* Toggle button */
.sheet-preview .sp-toggle {
  width: 100%;
  padding: var(--space-3) var(--space-5);
  background: rgba(255, 255, 255, 0.04);
  border: 0;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  color: var(--color-primary);
  font-family: var(--font-ko);
  font-size: var(--fs-caption);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-tight);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out);
}
.sheet-preview .sp-toggle:hover {
  background: rgba(207, 255, 0, 0.08);
}
.sheet-preview .sp-toggle .sp-icon {
  display: inline-block;
  margin-left: 4px;
  transition: transform var(--dur-base) var(--ease-out);
}
.sheet-preview .sp-t-close { display: none; }
.sheet-preview[data-expanded="true"] .sp-t-open { display: none; }
.sheet-preview[data-expanded="true"] .sp-t-close { display: inline; }

/* Parts (Part 1/2/3) */
.part {
  margin-top: var(--space-16);
  padding-top: var(--space-10);
  border-top: 1px solid var(--border-strong);
}
.part:first-of-type { border-top: 0; padding-top: 0; margin-top: var(--space-12); }
.part .part-label {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-en);
  font-size: var(--fs-micro);
  font-weight: var(--fw-bold);
  letter-spacing: 0.14em;
  color: var(--color-gray-500);
  text-transform: uppercase;
}
.part .part-label .pn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  background: var(--color-ink);
  color: var(--color-primary);
  border-radius: var(--radius-full);
  font-size: 11px;
}
.part h3 {
  margin-top: var(--space-3);
  font-size: 22px;
  font-weight: var(--fw-bold);
  line-height: 1.3;
  letter-spacing: var(--ls-tight);
  color: var(--color-ink);
  text-wrap: balance;
}
.part .pquestion {
  margin-top: var(--space-5);
  font-size: var(--fs-body);
  font-weight: var(--fw-bold);
  color: var(--color-ink);
  letter-spacing: var(--ls-tight);
}
.part .pquestion::before { content: "“"; color: var(--color-gray-400); }
.part .pquestion::after  { content: "”"; color: var(--color-gray-400); }
.part .panswer {
  margin-top: var(--space-3);
  font-size: var(--fs-body);
  line-height: var(--lh-relaxed);
  color: var(--color-gray-700);
}
.part .panswer strong {
  color: var(--color-ink);
  font-weight: var(--fw-bold);
}
.part .qa-tail {
  margin-top: var(--space-3);
  font-size: var(--fs-caption);
  color: var(--color-gray-500);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-tight);
}
.part .qa-tail::before {
  content: "→ ";
  color: var(--color-ink);
  font-weight: var(--fw-bold);
}
.part .qa-group + .qa-group {
  margin-top: var(--space-6);
  padding-top: var(--space-6);
  border-top: 1px solid var(--border-default);
}

/* Part 1 — Workflow steps */
.workflow {
  margin-top: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.wf-step {
  display: grid;
  grid-template-columns: 36px 1fr;
  gap: var(--space-3);
  padding: var(--space-4);
  background: var(--color-paper);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
}
.wf-step .wf-n {
  width: 28px;
  height: 28px;
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: var(--color-ink);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-num);
  font-variant-numeric: tabular-nums;
  font-weight: var(--fw-extra);
  font-size: 13px;
}
.wf-step .wf-title {
  font-size: var(--fs-body);
  font-weight: var(--fw-bold);
  color: var(--color-ink);
  letter-spacing: var(--ls-tight);
  line-height: 1.3;
}
.wf-step .wf-body {
  margin-top: var(--space-1);
  font-size: var(--fs-caption);
  line-height: var(--lh-relaxed);
  color: var(--color-gray-700);
}
.wf-step .wf-tail {
  margin-top: var(--space-2);
  font-size: var(--fs-micro);
  color: var(--color-gray-500);
  font-weight: var(--fw-medium);
}
.wf-step .wf-tail::before {
  content: "→ ";
  color: var(--color-ink);
  font-weight: var(--fw-bold);
}

/* Exercise table in Part 1 */
.ex-table-wrap {
  margin-top: var(--space-5);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--color-paper);
}
.ex-table-head {
  padding: var(--space-3) var(--space-5);
  background: var(--color-gray-50);
  border-bottom: 1px solid var(--border-default);
  font-family: var(--font-en);
  font-size: 10px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.1em;
  color: var(--color-gray-600);
  text-transform: uppercase;
  display: flex;
  justify-content: space-between;
}
.ex-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--fs-caption);
}
.ex-table thead th {
  font-family: var(--font-en);
  font-size: 10px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.1em;
  color: var(--color-gray-500);
  text-transform: uppercase;
  text-align: left;
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--border-default);
}
.ex-table thead th:last-child { text-align: right; }
.ex-table tbody td {
  padding: 10px var(--space-4);
  border-bottom: 1px solid var(--border-default);
  color: var(--color-gray-900);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-tight);
}
.ex-table tbody tr:last-child td { border-bottom: 0; }
.ex-table tbody td.idx {
  width: 28px;
  font-family: var(--font-num);
  font-variant-numeric: tabular-nums;
  color: var(--color-gray-500);
  font-weight: var(--fw-bold);
}
.ex-table tbody td.ex {
  color: var(--color-ink);
  font-weight: var(--fw-semibold);
}
.ex-table tbody td.ex .muted {
  color: var(--color-gray-500);
  font-weight: var(--fw-regular);
  font-size: var(--fs-micro);
  margin-left: 4px;
}
.ex-table tbody td.sets {
  font-family: var(--font-num);
  font-variant-numeric: tabular-nums;
  text-align: right;
  color: var(--color-ink);
  font-weight: var(--fw-bold);
  white-space: nowrap;
}
.ex-table tbody td.rpe {
  font-family: var(--font-num);
  font-variant-numeric: tabular-nums;
  text-align: right;
  width: 44px;
  white-space: nowrap;
}
.ex-table tbody td.rpe span {
  display: inline-block;
  padding: 2px 6px;
  border-radius: var(--radius-sm);
  background: var(--color-primary);
  color: var(--color-ink);
  font-size: 11px;
  font-weight: var(--fw-bold);
}
.ex-table tbody td.rpe span.dash {
  background: var(--color-gray-100);
  color: var(--color-gray-500);
}

/* RPE ramp */
.rpe-ramp {
  margin-top: var(--space-5);
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: var(--space-2);
}
.rpe-ramp .cyc {
  padding: var(--space-4) var(--space-3);
  background: var(--color-paper);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  text-align: center;
}
.rpe-ramp .cyc .c-label {
  font-family: var(--font-en);
  font-size: 10px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.1em;
  color: var(--color-gray-500);
  text-transform: uppercase;
}
.rpe-ramp .cyc .c-value {
  margin-top: 6px;
  font-family: var(--font-num);
  font-variant-numeric: tabular-nums;
  font-size: 22px;
  font-weight: var(--fw-extra);
  color: var(--color-ink);
  letter-spacing: -0.02em;
}
.rpe-ramp .cyc.c-3 {
  background: var(--color-ink);
  border-color: var(--color-ink);
}
.rpe-ramp .cyc.c-3 .c-label { color: var(--color-gray-500); }
.rpe-ramp .cyc.c-3 .c-value { color: var(--color-primary); }

/* 4-week wave table */
.wave-table-wrap {
  margin-top: var(--space-5);
  overflow-x: auto;
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  -webkit-overflow-scrolling: touch;
}
.wave-table {
  width: 100%;
  min-width: 380px;
  border-collapse: collapse;
  background: var(--color-paper);
  font-size: var(--fs-caption);
}
.wave-table thead th {
  font-family: var(--font-en);
  font-size: 10px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.1em;
  color: var(--color-gray-500);
  text-transform: uppercase;
  text-align: left;
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--border-default);
  background: var(--color-gray-50);
  white-space: nowrap;
}
.wave-table tbody td {
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--border-default);
  color: var(--color-gray-900);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-tight);
  white-space: nowrap;
}
.wave-table tbody tr:last-child td { border-bottom: 0; }
.wave-table tbody td.wk {
  font-family: var(--font-num);
  font-variant-numeric: tabular-nums;
  color: var(--color-gray-500);
  font-weight: var(--fw-bold);
  width: 72px;
}
.wave-table tbody td.stim {
  color: var(--color-ink);
  font-weight: var(--fw-bold);
}
.wave-table tbody tr.deload td.stim { color: var(--color-gray-500); }
.wave-table tbody tr.deload td.stim::before {
  content: "";
  display: inline-block;
  width: 6px;
  height: 6px;
  background: var(--color-primary);
  border-radius: var(--radius-full);
  margin-right: 6px;
  vertical-align: 2px;
}
.wave-table tbody td.load {
  font-family: var(--font-num);
  font-variant-numeric: tabular-nums;
  color: var(--color-gray-700);
  font-weight: var(--fw-semibold);
}

/* Part 3 — recovery callout */
.recovery-callout {
  margin-top: var(--space-5);
  padding: var(--space-5);
  background: var(--color-primary-soft);
  border-radius: var(--radius-md);
  border-left: 3px solid var(--color-primary);
  font-size: var(--fs-caption);
  color: var(--color-ink);
  line-height: var(--lh-relaxed);
}
.recovery-callout strong { font-weight: var(--fw-bold); }

/* Mechanism closer */
.mech .mech-closer {
  margin-top: var(--space-16);
  padding: var(--space-8) var(--space-6);
  background: var(--color-ink);
  color: var(--color-paper);
  border-radius: var(--radius-lg);
}
.mech .mech-closer .mc-lead {
  font-size: 20px;
  font-weight: var(--fw-bold);
  color: var(--color-paper);
  line-height: 1.4;
  letter-spacing: var(--ls-tight);
  text-wrap: balance;
}
.mech .mech-closer .mc-items {
  margin-top: var(--space-5);
  font-size: var(--fs-caption);
  color: var(--color-gray-500);
  line-height: var(--lh-relaxed);
}
.mech .mech-closer .mc-kicker {
  margin-top: var(--space-6);
  padding-top: var(--space-5);
  border-top: 1px solid rgba(255, 255, 255, 0.12);
  font-size: var(--fs-body);
  color: var(--color-primary);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-tight);
}

/* Curriculum block */
.curriculum {
  margin-top: var(--space-16);
  padding-top: var(--space-12);
  border-top: 1px solid var(--border-strong);
}
.curriculum h3 {
  margin-top: var(--space-3);
  font-size: 24px;
  font-weight: var(--fw-bold);
  line-height: 1.3;
  letter-spacing: var(--ls-tight);
  color: var(--color-ink);
}
.curriculum .cu-copy {
  margin-top: var(--space-4);
  color: var(--color-gray-700);
  font-size: var(--fs-body);
  line-height: var(--lh-relaxed);
}
.timeline-ph {
  margin-top: var(--space-6);
  aspect-ratio: 16 / 7;
  border-radius: var(--radius-lg);
  background: var(--color-gray-100);
  border: 1px dashed var(--border-strong);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: var(--color-gray-500);
  gap: var(--space-2);
}
.timeline-ph .t-title {
  font-size: var(--fs-caption);
  font-weight: var(--fw-medium);
  color: var(--color-gray-700);
  letter-spacing: var(--ls-tight);
}
.timeline-ph .t-file {
  font-family: var(--font-en);
  font-size: 10px;
  color: var(--color-gray-400);
  letter-spacing: 0.04em;
}

.cycle-table-wrap {
  margin-top: var(--space-3);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.cycle-table {
  width: 100%;
  min-width: 380px;
  border-collapse: collapse;
  font-size: var(--fs-caption);
}
.cycle-table thead th {
  font-family: var(--font-en);
  font-size: 10px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.1em;
  color: var(--color-gray-500);
  text-transform: uppercase;
  padding: var(--space-2) var(--space-3);
  text-align: left;
  border-bottom: 1px solid var(--border-default);
  white-space: nowrap;
}
.cycle-table tbody td {
  padding: var(--space-3);
  border-bottom: 1px solid var(--border-default);
  color: var(--color-gray-900);
  font-weight: var(--fw-medium);
  vertical-align: top;
  letter-spacing: var(--ls-tight);
}
.cycle-table tbody tr:last-child td { border-bottom: 0; }
.cycle-table td.cy {
  font-family: var(--font-num);
  font-variant-numeric: tabular-nums;
  color: var(--color-ink);
  font-weight: var(--fw-bold);
  width: 90px;
  white-space: nowrap;
}
.cycle-table td.struct {
  font-size: var(--fs-caption);
  color: var(--color-gray-700);
}
.cycle-table td.rpeval {
  font-family: var(--font-num);
  font-variant-numeric: tabular-nums;
  width: 80px;
  white-space: nowrap;
  text-align: right;
}
.cycle-table td.rpeval span {
  display: inline-block;
  padding: 2px 6px;
  border-radius: var(--radius-sm);
  background: var(--color-ink);
  color: var(--color-primary);
  font-weight: var(--fw-bold);
  font-size: 11px;
}

/* Horizontal cycle flow (replaces cycle-table) */
.cycle-flow {
  margin-top: var(--space-4);
  display: flex;
  align-items: stretch;
  gap: 4px;
  overflow-x: auto;
  padding-bottom: 4px;
  -webkit-overflow-scrolling: touch;
}
/* Quote block (curriculum tail) */
.curriculum .cu-quote {
  margin-top: var(--space-8);
  padding: var(--space-6);
  border-left: 3px solid var(--color-primary);
  background: var(--color-gray-50);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  font-size: var(--fs-body);
  line-height: var(--lh-relaxed);
  color: var(--color-gray-900);
  letter-spacing: var(--ls-tight);
}
.curriculum .cu-quote strong {
  color: var(--color-ink);
  font-weight: var(--fw-bold);
}

/* ==== Curriculum v11 — 2-slide simplified gallery ==== */
.cu-gallery {
  position: relative;
  margin-top: var(--space-5);
}
.cu-head-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 4px var(--space-3);
  font-family: var(--font-en);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.1em;
  color: var(--color-gray-500);
}
.cu-head-bar .cu-sep { color: var(--color-gray-300); }
.cu-viewport {
  position: relative;
  overflow: hidden;
  margin: 0 -4px;
}
.cu-track {
  display: flex;
  padding: 0 6%;
  gap: 12px;
  transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
  will-change: transform;
}
.cu-slide {
  flex: 0 0 88%;
  opacity: 0.4;
  transition: opacity 0.3s;
}
.cu-slide.active { opacity: 1; }

.cu-program {
  background: var(--color-paper);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  padding: 20px 18px;
  position: relative;
  overflow: hidden;
}
.cu-program.ink {
  background: var(--color-ink);
  color: var(--color-paper);
  border-color: var(--color-ink);
}
.cu-prog-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 4px;
  flex-wrap: wrap;
  gap: 4px 8px;
}
.cu-prog-name {
  font-size: 16px;
  font-weight: var(--fw-extra);
  letter-spacing: var(--ls-tight);
  color: var(--color-ink);
}
.cu-program.ink .cu-prog-name { color: var(--color-primary); }
.cu-prog-period {
  font-family: var(--font-en);
  font-size: 10px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.08em;
  color: var(--color-gray-500);
}
.cu-program.ink .cu-prog-period { color: var(--color-gray-400); }
.cu-prog-tagline {
  font-size: 12px;
  font-weight: var(--fw-semibold);
  color: var(--color-gray-700);
  margin-bottom: 14px;
}
.cu-program.ink .cu-prog-tagline { color: var(--color-gray-300); }

.cu-terms-row {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-bottom: 12px;
}
.cu-term {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  background: var(--color-primary);
  color: var(--color-ink);
  border-radius: 999px;
  font-size: 10.5px;
  font-weight: var(--fw-extra);
  letter-spacing: var(--ls-tight);
  line-height: 1;
}
.cu-term .en { font-family: var(--font-en); font-weight: var(--fw-extra); }
.cu-term .ko { font-weight: var(--fw-bold); opacity: 0.75; font-size: 10px; }
.cu-term.outlined {
  background: transparent;
  color: var(--color-paper);
  border: 1px solid rgba(255,255,255,0.25);
}
.cu-term.outlined .ko { opacity: 0.7; }

.cu-wave {
  background: var(--color-gray-50);
  border-radius: var(--radius-sm);
  padding: 10px 12px 8px;
  margin-bottom: 14px;
}
.cu-program.ink .cu-wave { background: rgba(255,255,255,0.06); }
.cu-wave svg {
  width: 100%;
  height: 64px;
  display: block;
}
.cu-wave-label {
  display: flex;
  justify-content: space-between;
  font-family: var(--font-en);
  font-size: 9px;
  font-weight: var(--fw-bold);
  color: var(--color-gray-500);
  letter-spacing: 0.04em;
  padding: 0 2px;
  margin-top: 4px;
}
.cu-program.ink .cu-wave-label { color: var(--color-gray-400); }

.cu-prog-body {
  font-size: 12.5px;
  line-height: var(--lh-relaxed);
  color: var(--color-gray-700);
}
.cu-program.ink .cu-prog-body { color: var(--color-gray-200); }
.cu-prog-body strong {
  color: var(--color-ink);
  font-weight: var(--fw-extra);
}
.cu-program.ink .cu-prog-body strong { color: var(--color-paper); }

/* Controls */
.cu-ctrl {
  margin-top: var(--space-4);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-4);
}
.cu-arrow {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--color-paper);
  border: 1px solid var(--color-gray-300);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 16px;
  color: var(--color-gray-700);
  padding: 0;
  line-height: 1;
}
.cu-arrow:hover { background: var(--color-gray-50); }
.cu-dots { display: flex; gap: 5px; }
.cu-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--color-gray-300);
  border: none;
  padding: 0;
  cursor: pointer;
  transition: all 0.2s;
}
.cu-dot.active {
  background: var(--color-ink);
  width: 20px;
  border-radius: 3px;
}

.cu-foot {
  margin-top: var(--space-5);
  padding: 14px 16px;
  background: var(--color-gray-50);
  border-radius: var(--radius-md);
  font-size: 11px;
  line-height: 1.6;
  color: var(--color-gray-700);
  text-align: center;
}
.cu-foot strong {
  color: var(--color-ink);
  font-weight: var(--fw-extra);
}

/* PT vs HPS */
.pthps {
  margin-top: var(--space-16);
  padding-top: var(--space-12);
  border-top: 1px solid var(--border-strong);
}
.pthps h3 {
  margin-top: var(--space-3);
  font-size: 24px;
  font-weight: var(--fw-bold);
  line-height: 1.3;
  letter-spacing: var(--ls-tight);
  color: var(--color-ink);
}
.pthps .intro {
  margin-top: var(--space-5);
  font-size: var(--fs-body);
  line-height: var(--lh-relaxed);
  color: var(--color-gray-700);
}
.pthps .reality {
  margin-top: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.pthps .reality .r-card {
  padding: var(--space-5);
  background: var(--color-paper);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
}
.pthps .reality .r-head {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.pthps .reality .r-n {
  font-family: var(--font-en);
  font-size: 11px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.1em;
  color: var(--color-gray-500);
  padding: 3px 8px;
  border-radius: var(--radius-sm);
  background: var(--color-gray-100);
}
.pthps .reality .r-title {
  font-size: var(--fs-body);
  font-weight: var(--fw-bold);
  color: var(--color-ink);
  letter-spacing: var(--ls-tight);
}
.pthps .reality .r-body {
  margin-top: var(--space-3);
  font-size: var(--fs-caption);
  line-height: var(--lh-relaxed);
  color: var(--color-gray-700);
}

/* PT vs HPS compare */
.compare-grid {
  margin-top: var(--space-6);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-2);
}
.compare-cell {
  padding: var(--space-5);
  border-radius: var(--radius-lg);
}
.compare-cell.pt {
  background: var(--color-paper);
  border: 1px solid var(--border-default);
}
.compare-cell.hps {
  background: var(--color-ink);
  color: var(--color-paper);
}
.compare-cell .c-name {
  font-family: var(--font-en);
  font-size: 11px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.compare-cell.pt .c-name { color: var(--color-gray-500); }
.compare-cell.hps .c-name { color: var(--color-primary); }
.compare-cell .c-price {
  margin-top: var(--space-2);
  font-family: var(--font-num);
  font-variant-numeric: tabular-nums;
  font-size: 18px;
  font-weight: var(--fw-extra);
  letter-spacing: -0.02em;
  line-height: 1.2;
}
.compare-cell.pt .c-price { color: var(--color-ink); }
.compare-cell.hps .c-price { color: var(--color-paper); }
.compare-cell .c-period {
  font-size: 11px;
  font-weight: var(--fw-medium);
}
.compare-cell.pt .c-period { color: var(--color-gray-500); }
.compare-cell.hps .c-period { color: var(--color-gray-500); }
.compare-cell .c-tail {
  margin-top: var(--space-4);
  padding-top: var(--space-3);
  border-top: 1px solid;
  font-size: var(--fs-micro);
  line-height: var(--lh-relaxed);
}
.compare-cell.pt .c-tail {
  border-color: var(--border-default);
  color: var(--color-gray-600);
}
.compare-cell.hps .c-tail {
  border-color: rgba(255, 255, 255, 0.1);
  color: var(--color-gray-500);
}
.compare-cell.hps .c-tail strong { color: var(--color-primary); }

.pthps .philosophy {
  margin-top: var(--space-6);
  font-size: var(--fs-body);
  line-height: var(--lh-relaxed);
  color: var(--color-gray-700);
}
.pthps .philosophy strong {
  color: var(--color-ink);
  font-weight: var(--fw-bold);
}
.pthps .recommend {
  margin-top: var(--space-5);
  padding: var(--space-5);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  background: var(--color-gray-50);
  font-size: var(--fs-caption);
  color: var(--color-gray-900);
  line-height: var(--lh-relaxed);
}
.pthps .recommend strong {
  color: var(--color-ink);
  font-weight: var(--fw-bold);
}

/* Block D transition declaration */
.declare {
  margin-top: var(--space-16);
  padding-top: var(--space-10);
  border-top: 1px solid var(--border-strong);
}
.declare .d-lead {
  font-size: 22px;
  font-weight: var(--fw-extra);
  color: var(--color-ink);
  line-height: 1.3;
  letter-spacing: var(--ls-tight);
  text-wrap: balance;
}
.declare .d-lead strong {
  background: linear-gradient(to top, var(--color-primary) 45%, transparent 45%);
  padding: 0 4px;
  font-weight: var(--fw-extra);
}
.declare .d-sub {
  margin-top: var(--space-4);
  font-size: var(--fs-body);
  color: var(--color-gray-700);
  line-height: var(--lh-relaxed);
}

/* ---------- Wave chart (SVG) ---------- */
.wave-chart {
  margin-top: var(--space-6);
  padding: var(--space-5);
  background: var(--color-gray-50);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border-default);
}
.wave-chart .wc-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-4);
}
.wave-chart .wc-title {
  font-size: var(--fs-caption);
  font-weight: var(--fw-bold);
  color: var(--color-ink);
  letter-spacing: var(--ls-tight);
}
.wave-chart .wc-meta {
  font-family: var(--font-en);
  font-size: 10px;
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-wide);
  color: var(--color-gray-500);
  text-transform: uppercase;
}
.wave-chart .wc-svg {
  width: 100%;
  height: auto;
  display: block;
}
.wave-chart .wc-grid line {
  stroke: var(--color-gray-200);
  stroke-width: 1;
  stroke-dasharray: 2 3;
}
.wave-chart .wc-axis {
  stroke: var(--color-gray-400);
  stroke-width: 1;
}
.wave-chart .wc-cycle-sep {
  stroke: var(--color-gray-300);
  stroke-width: 1;
  stroke-dasharray: 3 2;
}
.wave-chart .wc-ylabel {
  font-family: var(--font-ko);
  font-size: 10px;
  font-weight: 600;
  fill: var(--color-gray-600);
  letter-spacing: -0.02em;
}
.wave-chart .wc-cycle-label {
  font-family: var(--font-en);
  font-size: 9px;
  font-weight: 700;
  fill: var(--color-gray-500);
  letter-spacing: 0.08em;
  text-anchor: middle;
}
.wave-chart .wc-xlabel text {
  font-family: var(--font-en);
  font-size: 9px;
  font-weight: 600;
  fill: var(--color-gray-600);
  text-anchor: middle;
}
.wave-chart .wc-line {
  stroke: var(--color-ink);
  stroke-width: 1.25;
  stroke-linejoin: round;
  stroke-linecap: round;
  opacity: 0.55;
}
.wave-chart .wc-dots circle {
  stroke: #fff;
  stroke-width: 1.5;
}
/* Stimulus-type colors matching legend */
.wave-chart .wc-dots circle.hyp { fill: var(--color-ink); }
.wave-chart .wc-dots circle.str { fill: var(--color-gray-600); }
.wave-chart .wc-dots circle.myo { fill: var(--color-gray-400); stroke: var(--color-gray-600); }
.wave-chart .wc-dots circle.del {
  fill: var(--color-primary);
  stroke: var(--color-ink);
  stroke-width: 1.5;
}
.wave-chart .wc-trend line {
  stroke: var(--color-primary);
  stroke-width: 1.5;
  opacity: 0.7;
}
.wave-chart .wc-trend text {
  font-family: var(--font-en);
  font-size: 14px;
  font-weight: 700;
  fill: var(--color-primary);
}
.wave-chart .wc-legend {
  margin-top: var(--space-4);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3) var(--space-4);
  padding: var(--space-3);
  background: #fff;
  border-radius: var(--radius-md);
}
.wave-chart .wc-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--color-gray-700);
  font-weight: 500;
}
.wave-chart .wc-chip {
  width: 10px;
  height: 10px;
  border-radius: 2px;
  display: inline-block;
}
.wave-chart .wc-chip.hyp { background: var(--color-ink); }
.wave-chart .wc-chip.str { background: var(--color-gray-600); }
.wave-chart .wc-chip.myo { background: var(--color-gray-400); border: 1px solid var(--color-gray-600); }
.wave-chart .wc-chip.del { background: var(--color-primary); border: 1px solid var(--color-ink); }
.wave-chart .wc-caption {
  margin-top: var(--space-3);
  font-size: var(--fs-caption);
  line-height: var(--lh-normal);
  color: var(--color-gray-700);
  text-align: center;
}
.wave-chart .wc-caption strong {
  color: var(--color-ink);
  font-weight: var(--fw-bold);
}

/* ---------- Timeline SVG (HPS / SHUL+ curriculum, same tonality as wave-chart) ---------- */
.timeline-svg {
  width: 100%;
  height: auto;
  display: block;
  background: var(--color-gray-50);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
}
/* Stage progression levels (linear periodization: 전환 -> 축적 -> 피크) */
.timeline-svg .tl-lv1 { fill: var(--color-gray-400); }
/* ---------- Volume band (MV ~ MEV ~ MAV ~ MRV) visualizer ---------- */
.volume-band {
  margin-top: var(--space-5);
  padding: var(--space-5) var(--space-4) var(--space-4);
  background: var(--color-gray-50);
  border-radius: var(--radius-md);
  border: 1px solid var(--border-default);
}
.volume-band .vb-scale {
  position: relative;
  height: 14px;
  /* Full MV-MRV gradient: gray edges (under/over training), lime middle (optimal MEV-MAV) */
  background: linear-gradient(to right,
    var(--color-gray-300) 0%,
    var(--color-gray-200) 20%,
    rgba(207, 255, 0, 0.25) 25%,
    rgba(207, 255, 0, 0.50) 50%,
    rgba(207, 255, 0, 0.25) 75%,
    var(--color-gray-200) 80%,
    var(--color-gray-300) 100%);
  border-radius: var(--radius-full);
  overflow: visible;
}
/* Optimal zone dashed border (MEV 25% to MAV 75%) */
.volume-band .vb-zone {
  position: absolute;
  left: 25%;
  right: 25%;
  top: 0;
  bottom: 0;
  border-left: 2px dashed var(--color-ink);
  border-right: 2px dashed var(--color-ink);
}
.volume-band .vb-tick {
  position: absolute;
  width: 2px;
  height: 20px;
  top: -3px;
  background: var(--color-gray-500);
  transform: translateX(-1px);
}
.volume-band .vb-dot {
  position: absolute;
  /* Center of MEV~MAV = 50% */
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 18px;
  height: 18px;
  background: var(--color-primary);
  border: 2px solid var(--color-ink);
  border-radius: var(--radius-full);
  box-shadow: var(--shadow-sm);
  z-index: 2;
}
.volume-band .vb-labels {
  margin-top: var(--space-5);
  position: relative;
  height: 36px;
}
.volume-band .vb-label {
  position: absolute;
  top: 0;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  gap: 1px;
  align-items: center;
  font-size: 10px;
  color: var(--color-gray-600);
  line-height: 1.2;
  text-align: center;
  white-space: nowrap;
}
/* Leftmost label aligns to left edge */
.volume-band .vb-label[style*="left: 0%"] {
  transform: translateX(0);
  align-items: flex-start;
  text-align: left;
}
/* Rightmost label aligns to right edge */
.volume-band .vb-label[style*="left: 100%"] {
  transform: translateX(-100%);
  align-items: flex-end;
  text-align: right;
}
.volume-band .vb-label strong {
  font-family: var(--font-en);
  font-size: 12px;
  font-weight: var(--fw-bold);
  color: var(--color-ink);
  letter-spacing: 0.02em;
}
/* MEV/MAV highlighted (inner optimal boundaries) */
.volume-band .vb-label.inner strong {
  color: var(--color-ink);
  background: var(--color-primary);
  padding: 1px 4px;
  border-radius: 2px;
  font-size: 11px;
}

/* Legend */
.volume-band .vb-legend {
  margin-top: var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px dashed var(--color-gray-300);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3) var(--space-4);
  justify-content: center;
}
.volume-band .vb-legend-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  color: var(--color-gray-700);
}
.volume-band .vb-legend-chip {
  width: 14px;
  height: 8px;
  border-radius: 2px;
  display: inline-block;
}
.volume-band .vb-legend-chip.zone {
  background: rgba(207, 255, 0, 0.5);
  border: 1px dashed var(--color-ink);
}
.volume-band .vb-legend-chip.hps {
  width: 10px;
  height: 10px;
  border-radius: var(--radius-full);
  background: var(--color-primary);
  border: 2px solid var(--color-ink);
}

/* ---------- Section 7 · HPS Product ---------- */
.product h2 {
  margin-top: var(--space-3);
  font-size: 28px;
  font-weight: var(--fw-extra);
  line-height: 1.25;
  letter-spacing: var(--ls-tight);
  color: var(--color-ink);
  text-wrap: balance;
}

/* Block A — Sheet components */
.sheet-component {
  margin-top: var(--space-8);
  padding: var(--space-6);
  background: var(--color-paper);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
}
.sheet-component .sc-head {
  display: flex;
  align-items: baseline;
  gap: var(--space-3);
}
.sheet-component .sc-n {
  font-family: var(--font-en);
  font-variant-numeric: tabular-nums;
  font-size: 28px;
  font-weight: var(--fw-extra);
  color: var(--color-gray-200);
  letter-spacing: -0.02em;
  line-height: 1;
}
.sheet-component .sc-title {
  font-size: var(--fs-body);
  font-weight: var(--fw-bold);
  color: var(--color-ink);
  letter-spacing: var(--ls-tight);
}
.sheet-component .sc-body {
  margin-top: var(--space-3);
  font-size: var(--fs-caption);
  line-height: var(--lh-relaxed);
  color: var(--color-gray-700);
}
.sheet-component .sc-body strong {
  color: var(--color-ink);
  font-weight: var(--fw-bold);
}
.sheet-component .sc-ph {
  margin-top: var(--space-5);
  aspect-ratio: 16 / 10;
  border-radius: var(--radius-md);
  background: var(--color-gray-100);
  border: 1px dashed var(--border-strong);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: var(--color-gray-500);
  gap: var(--space-2);
  padding: var(--space-4);
  text-align: center;
}
/* When sc-ph contains an actual image, remove placeholder styling */
.sheet-component .sc-ph:has(.sc-img) {
  padding: 0;
  border: 1px solid var(--border-default);
  background: var(--color-paper);
  overflow: hidden;
}
.sheet-component .sc-ph.sc-ph-vertical {
  aspect-ratio: 3 / 4;
  max-width: 320px;
  margin-left: auto;
  margin-right: auto;
  margin-top: var(--space-5);
}
.sc-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.sheet-component .sc-list {
  margin-top: var(--space-4);
  padding: 0;
  list-style: none;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-2);
}
.sheet-component .sc-list li {
  padding: var(--space-3);
  background: var(--color-gray-50);
  border-radius: var(--radius-sm);
  font-size: 12px;
  font-weight: var(--fw-semibold);
  color: var(--color-gray-900);
  letter-spacing: var(--ls-tight);
  line-height: 1.3;
}
.sheet-component .sc-tail {
  margin-top: var(--space-4);
  font-size: var(--fs-caption);
  color: var(--color-gray-700);
}
.sheet-component .sc-tail strong {
  color: var(--color-ink);
  font-weight: var(--fw-bold);
}

/* Block A closer line */
.product .sheet-closer {
  margin-top: var(--space-8);
  padding: var(--space-5);
  background: var(--color-ink);
  color: var(--color-paper);
  border-radius: var(--radius-md);
  font-size: var(--fs-body);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-tight);
  line-height: var(--lh-snug);
}
.product .sheet-closer .hl {
  color: var(--color-primary);
  font-weight: var(--fw-bold);
}

/* Block B — packaged offering */
.offering {
  margin-top: var(--space-16);
  padding-top: var(--space-10);
  border-top: 1px solid var(--border-strong);
}
.offering .of-label {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-en);
  font-size: var(--fs-micro);
  font-weight: var(--fw-bold);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-gray-500);
}
.offering h3 {
  margin-top: var(--space-3);
  font-size: 22px;
  font-weight: var(--fw-bold);
  line-height: 1.3;
  letter-spacing: var(--ls-tight);
  color: var(--color-ink);
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
}
.offering h3 .tag {
  font-family: var(--font-en);
  font-size: 10px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.1em;
  padding: 4px 8px;
  border-radius: var(--radius-sm);
  background: var(--color-gray-100);
  color: var(--color-gray-700);
  text-transform: uppercase;
}
.offering h3 .tag.early {
  background: var(--color-primary);
  color: var(--color-ink);
}
.offering h3 .tag.ink {
  background: var(--color-ink);
  color: var(--color-primary);
}
.offering + .offering { margin-top: var(--space-12); padding-top: var(--space-8); border-top: 1px solid var(--border-default); }

.check-list {
  margin-top: var(--space-5);
  list-style: none;
  padding: 0;
}
.check-list li {
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--border-default);
  display: grid;
  grid-template-columns: 24px 1fr;
  gap: var(--space-3);
  align-items: start;
}
.check-list li:last-child { border-bottom: 0; }
.check-list li::before {
  content: "✓";
  width: 20px;
  height: 20px;
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: var(--color-ink);
  font-family: var(--font-en);
  font-size: 11px;
  font-weight: var(--fw-extra);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 2px;
}
.check-list li .li-title {
  font-size: var(--fs-body);
  font-weight: var(--fw-bold);
  color: var(--color-ink);
  letter-spacing: var(--ls-tight);
  line-height: 1.35;
}
.check-list li .li-body {
  margin-top: 2px;
  font-size: var(--fs-caption);
  line-height: var(--lh-snug);
  color: var(--color-gray-600);
}

/* Product lineup */
.lineup {
  margin-top: var(--space-5);
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-3);
}
.lineup .p-card {
  padding: var(--space-5);
  background: var(--color-paper);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: var(--space-4);
}
.lineup .p-card.full {
  background: var(--color-ink);
  color: var(--color-paper);
  border-color: var(--color-ink);
}
.lineup .p-card .p-name {
  font-size: var(--fs-body-lg);
  font-weight: var(--fw-bold);
  color: var(--color-ink);
  letter-spacing: var(--ls-tight);
  font-family: var(--font-en);
}
.lineup .p-card.full .p-name { color: var(--color-primary); }
.lineup .p-card .p-compose {
  margin-top: 2px;
  font-size: var(--fs-caption);
  color: var(--color-gray-700);
  font-weight: var(--fw-medium);
}
.lineup .p-card.full .p-compose { color: var(--color-gray-500); }
.lineup .p-card .p-target {
  margin-top: var(--space-2);
  font-size: var(--fs-micro);
  color: var(--color-gray-600);
  font-weight: var(--fw-medium);
}
.lineup .p-card.full .p-target { color: var(--color-gray-500); }
.lineup .p-card .p-badge {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: var(--radius-full);
  font-family: var(--font-en);
  font-size: 10px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  white-space: nowrap;
}
.lineup .p-card .p-badge.basic {
  background: var(--color-gray-100);
  color: var(--color-gray-700);
}
.lineup .p-card .p-badge.adv {
  background: var(--color-ink);
  color: var(--color-primary);
}
.lineup .p-card.full .p-badge {
  background: var(--color-primary);
  color: var(--color-ink);
}

/* Benefit items (구매자 전원 / 얼리버드) */
.benefit-row {
  margin-top: var(--space-5);
  padding: var(--space-5);
  background: var(--color-paper);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
}
.benefit-row.early {
  background: var(--color-primary-soft);
  border-color: var(--color-primary);
  border-left: 3px solid var(--color-primary);
}
.benefit-row .b-item {
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--border-default);
}
.benefit-row.early .b-item { border-bottom-color: rgba(10, 10, 10, 0.08); }
.benefit-row .b-item:last-child { border-bottom: 0; padding-bottom: 0; }
.benefit-row .b-item:first-child { padding-top: 0; }
.benefit-row .b-title {
  font-size: var(--fs-body);
  font-weight: var(--fw-bold);
  color: var(--color-ink);
  letter-spacing: var(--ls-tight);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.benefit-row .b-title .star {
  color: var(--color-ink);
  font-family: var(--font-en);
  font-size: 13px;
}
.benefit-row.early .b-title .star { color: var(--color-ink); }
.benefit-row .b-body {
  margin-top: var(--space-1);
  padding-left: 20px;
  font-size: var(--fs-caption);
  color: var(--color-gray-700);
  line-height: var(--lh-relaxed);
}
.benefit-row .b-deadline {
  margin-top: var(--space-4);
  padding-top: var(--space-3);
  border-top: 1px solid rgba(10, 10, 10, 0.08);
  font-size: var(--fs-micro);
  color: var(--color-gray-700);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-tight);
}

/* Block C — Transformations */
.transforms {
  margin-top: var(--space-16);
  padding-top: var(--space-10);
  border-top: 1px solid var(--border-strong);
}
.transforms h3 {
  margin-top: var(--space-3);
  font-size: 24px;
  font-weight: var(--fw-bold);
  line-height: 1.3;
  letter-spacing: var(--ls-tight);
  color: var(--color-ink);
}
.transform-list {
  margin-top: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.transform-card {
  display: grid;
  grid-template-columns: 48px 1fr;
  gap: var(--space-4);
  padding: var(--space-5);
  background: var(--color-paper);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
}
.transform-card .tr-n {
  font-family: var(--font-num);
  font-variant-numeric: tabular-nums;
  font-size: 32px;
  font-weight: var(--fw-extra);
  color: var(--color-primary);
  letter-spacing: -0.03em;
  line-height: 1;
}
.transform-card .tr-title {
  font-size: var(--fs-body-lg);
  font-weight: var(--fw-bold);
  color: var(--color-ink);
  letter-spacing: var(--ls-tight);
  line-height: 1.3;
}
.transform-card .tr-body {
  margin-top: var(--space-2);
  font-size: var(--fs-caption);
  color: var(--color-gray-700);
  line-height: var(--lh-relaxed);
}

/* 12주 뒤 — closing narrative */
.twelve-after {
  margin-top: var(--space-16);
  padding: var(--space-10) var(--space-6);
  background: var(--bg-band);
  border-radius: var(--radius-lg);
}
.twelve-after .ta-label {
  font-family: var(--font-en);
  font-size: 12px;
  font-weight: var(--fw-extra);
  letter-spacing: 0.14em;
  color: var(--color-ink);
  text-transform: uppercase;
}
.twelve-after .ta-big {
  margin-top: var(--space-2);
  font-size: 44px;
  font-weight: var(--fw-extra);
  color: var(--color-ink);
  letter-spacing: -0.03em;
  line-height: 1;
  font-family: var(--font-num);
  font-variant-numeric: tabular-nums;
}
.twelve-after .ta-big .suf {
  font-family: var(--font-ko);
  font-size: 20px;
  font-weight: var(--fw-bold);
  color: var(--color-gray-700);
  margin-left: 4px;
  letter-spacing: var(--ls-tight);
}
.twelve-after .ta-lead {
  margin-top: var(--space-5);
  font-size: var(--fs-body-lg);
  font-weight: var(--fw-semibold);
  color: var(--color-ink);
  line-height: 1.5;
  letter-spacing: var(--ls-tight);
}
.twelve-after p {
  margin-top: var(--space-4);
  font-size: var(--fs-body);
  color: var(--color-gray-700);
  line-height: var(--lh-relaxed);
}
.twelve-after .ta-dialog {
  margin-top: var(--space-5);
  padding: var(--space-4);
  background: var(--color-paper);
  border-radius: var(--radius-md);
  border-left: 3px solid var(--color-primary);
  font-size: var(--fs-body-lg);
  font-weight: var(--fw-bold);
  color: var(--color-ink);
  letter-spacing: var(--ls-tight);
}
.twelve-after .ta-final {
  margin-top: var(--space-4);
  font-size: var(--fs-body);
  font-weight: var(--fw-semibold);
  color: var(--color-ink);
}

@media (min-width: 480px) {
  .mech h2 { font-size: 30px; }
  .cause h2 { font-size: 30px; }
  .product h2 { font-size: 30px; }
  .part h3 { font-size: 24px; }
  .twelve-after .ta-big { font-size: 52px; }
}

/* =========================================================
   섹션 8~14
   ========================================================= */

/* Section eyebrow on dark surfaces */
.eyebrow.invert {
  color: var(--color-primary);
}
.eyebrow.invert::before {
  background: var(--color-primary);
}

/* ---------- Section 8 · Pricing ---------- */
.pricing h2 {
  margin-top: var(--space-3);
  font-size: 28px;
  font-weight: var(--fw-extra);
  line-height: 1.25;
  letter-spacing: var(--ls-tight);
  color: var(--color-ink);
}
.pg-block {
  margin-top: var(--space-8);
  padding: var(--space-6);
  background: var(--color-paper);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
}

/* ── Individual product card: black header band, white body ────────── */
.pg-block:not(.pg-full) > .pg-head {
  margin: calc(var(--space-6) * -1) calc(var(--space-6) * -1) 0;
  padding: var(--space-5) var(--space-6);
  background: var(--color-ink);
  border-bottom: 1px solid var(--color-ink);
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}
.pg-block:not(.pg-full) > .pg-head .pg-title { color: var(--color-paper); }
.pg-block:not(.pg-full) > .pg-head .pg-title .pg-sub {
  background: rgba(255,255,255,0.12);
  color: var(--color-paper);
}
.pg-block:not(.pg-full) > .pg-head .pg-prices { color: var(--color-paper); }
.pg-block:not(.pg-full) > .pg-head .pg-reg .lbl { color: var(--color-gray-400); }
.pg-block:not(.pg-full) > .pg-head .pg-reg .val { color: var(--color-gray-400); text-decoration: line-through; }
.pg-block:not(.pg-full) > .pg-head .pg-early .lbl { color: var(--color-primary); }
.pg-block:not(.pg-full) > .pg-head .pg-early .val { color: var(--color-paper); font-weight: var(--fw-extra); }
/* Push following content (the list) down a touch */
.pg-block:not(.pg-full) > .pg-head + * { margin-top: var(--space-5); }

.pg-head {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding-bottom: var(--space-4);
  border-bottom: 1px solid var(--border-default);
}
.pg-title {
  font-size: var(--fs-body-lg);
  font-weight: var(--fw-bold);
  color: var(--color-ink);
  letter-spacing: var(--ls-tight);
}
.pg-title .pg-sub {
  margin-left: var(--space-2);
  font-family: var(--font-en);
  font-size: 10px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 3px 8px;
  background: var(--color-gray-100);
  color: var(--color-gray-600);
  border-radius: var(--radius-sm);
  vertical-align: 2px;
}
.pg-title.invert { color: var(--color-primary); }
.pg-title.invert .pg-sub {
  background: var(--color-primary);
  color: var(--color-ink);
  font-weight: var(--fw-extra);
}
.pg-prices {
  display: flex;
  align-items: baseline;
  gap: var(--space-4);
  font-family: var(--font-num);
  font-variant-numeric: tabular-nums;
}
.pg-reg {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.pg-reg .lbl, .pg-early .lbl {
  font-size: 10px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.1em;
  color: var(--color-gray-500);
  text-transform: uppercase;
}
.pg-reg .val {
  font-size: 14px;
  color: var(--color-gray-500);
  text-decoration: line-through;
  font-weight: var(--fw-medium);
}
.pg-reg.invert .lbl { color: var(--color-gray-500); }
.pg-reg.invert .val { color: var(--color-gray-500); }
.pg-early {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.pg-early .val {
  font-size: 22px;
  font-weight: var(--fw-extra);
  color: var(--color-ink);
  letter-spacing: -0.02em;
}
.pg-list {
  margin-top: var(--space-4);
  list-style: none;
  padding: 0;
}
.pg-list li {
  display: grid;
  grid-template-columns: 32px 1fr auto;
  gap: var(--space-3);
  align-items: center;
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--border-default);
}
.pg-list li:last-child { border-bottom: 0; }
.pg-list .pg-n {
  font-family: var(--font-en);
  font-variant-numeric: tabular-nums;
  font-size: 11px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.06em;
  color: var(--color-gray-500);
}
.pg-list .pg-name {
  font-family: var(--font-en);
  font-size: var(--fs-body);
  font-weight: var(--fw-bold);
  color: var(--color-ink);
  letter-spacing: var(--ls-tight);
}
.pg-list .pg-meta {
  margin-top: 2px;
  font-size: var(--fs-micro);
  color: var(--color-gray-600);
  font-weight: var(--fw-medium);
}
.pg-list .pg-amount {
  font-family: var(--font-num);
  font-variant-numeric: tabular-nums;
  font-size: var(--fs-body);
  font-weight: var(--fw-extra);
  color: var(--color-ink);
  letter-spacing: -0.01em;
}
.pg-list .pg-amount small {
  font-size: 10px;
  font-weight: var(--fw-semibold);
  color: var(--color-gray-500);
  margin-left: 2px;
}

.pg-full {
  position: relative;
  background: var(--color-ink) !important;
  border-color: var(--color-ink) !important;
  color: var(--color-paper);
  overflow: hidden;
}
/* Reinforce: full pack header band must remain dark even though base
   .pg-block:not(.pg-full) selector wouldn't apply, this just protects
   against any future style cascading. */
.pg-full > .pg-head {
  background: transparent;
  border-bottom: 1px solid rgba(255,255,255,0.1);
  margin: 0;
  padding: 0 0 var(--space-4);
  border-radius: 0;
}
.pg-ribbon {
  position: absolute;
  top: 16px;
  right: -38px;
  padding: 4px 44px;
  background: var(--color-primary);
  color: var(--color-ink);
  font-family: var(--font-en);
  font-size: 10px;
  font-weight: var(--fw-extra);
  letter-spacing: 0.1em;
  transform: rotate(30deg);
}
.pg-full .pg-head { border-bottom-color: rgba(255,255,255,0.1); }
.pg-compose {
  margin-top: var(--space-2);
  font-size: var(--fs-caption);
  color: var(--color-gray-500);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-tight);
}
/* Override on dark fullpack card for readability */
.pg-full .pg-compose {
  color: var(--color-gray-200);
  font-weight: var(--fw-semibold);
}
.pg-full-prices {
  margin-top: var(--space-5);
  display: flex;
  align-items: flex-end;
  gap: var(--space-4);
  flex-wrap: wrap;
}
.pg-big {
  display: flex;
  align-items: baseline;
  gap: 2px;
  font-family: var(--font-num);
  font-variant-numeric: tabular-nums;
}
.pg-big-num {
  font-size: 44px;
  font-weight: var(--fw-extra);
  color: var(--color-primary);
  letter-spacing: -0.03em;
  line-height: 1;
}
.pg-big-unit {
  font-size: 18px;
  font-weight: var(--fw-bold);
  color: var(--color-paper);
}
.pg-full-note {
  font-size: var(--fs-micro);
  color: var(--color-gray-500);
  font-weight: var(--fw-semibold);
}
.pg-full-quote {
  margin-top: var(--space-5);
  padding-top: var(--space-5);
  border-top: 1px solid rgba(255,255,255,0.1);
  font-size: var(--fs-caption);
  color: var(--color-gray-500);
  line-height: var(--lh-relaxed);
}
.pg-full-quote strong {
  color: var(--color-primary);
  font-weight: var(--fw-bold);
}

.pg-included {
  margin-top: var(--space-10);
  padding: var(--space-5);
  border-top: 1px solid var(--border-strong);
  border-bottom: 1px solid var(--border-strong);
}
.pg-tagline {
  font-size: var(--fs-caption);
  font-weight: var(--fw-bold);
  color: var(--color-ink);
  letter-spacing: var(--ls-tight);
  margin-bottom: var(--space-3);
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
}
.pg-tagline .muted {
  color: var(--color-gray-500);
  font-weight: var(--fw-medium);
  font-size: var(--fs-micro);
}
.chip-early {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  background: var(--color-primary);
  color: var(--color-ink);
  font-family: var(--font-en);
  font-size: 10px;
  font-weight: var(--fw-extra);
  letter-spacing: 0.08em;
}
.pg-inc-row {
  padding: var(--space-2) 0;
  font-size: var(--fs-caption);
  color: var(--color-gray-900);
  font-weight: var(--fw-medium);
  line-height: var(--lh-relaxed);
  display: flex;
  align-items: baseline;
  gap: var(--space-2);
}
.pg-inc-row .check {
  color: var(--color-ink);
  font-weight: var(--fw-extra);
}
.pg-inc-row .muted {
  color: var(--color-gray-500);
  font-weight: var(--fw-regular);
}
.pg-footnote {
  margin-top: var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px dashed var(--border-default);
  font-size: var(--fs-micro);
  color: var(--color-gray-600);
  font-weight: var(--fw-medium);
}

/* ---------- Section 9 · Urgency ---------- */
.urgency {
  background: var(--color-ink);
  color: var(--color-paper);
}
.urgency h2 {
  margin-top: var(--space-3);
  font-size: 28px;
  font-weight: var(--fw-extra);
  line-height: 1.25;
  letter-spacing: var(--ls-tight);
  color: var(--color-paper);
}
.urgency h2 .date {
  color: var(--color-primary);
}
.ticker {
  margin-top: var(--space-10);
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--space-2);
  padding: var(--space-6) var(--space-4);
  background: rgba(207, 255, 0, 0.05);
  border-radius: var(--radius-lg);
  border: 1px solid rgba(207, 255, 0, 0.15);
}
.ticker-unit {
  flex: 1;
  text-align: center;
}
.ticker-unit .tu-v {
  font-family: var(--font-num);
  font-variant-numeric: tabular-nums;
  font-size: 40px;
  font-weight: var(--fw-extra);
  color: var(--color-primary);
  letter-spacing: -0.03em;
  line-height: 1;
}
.ticker-unit .tu-l {
  margin-top: 6px;
  font-family: var(--font-en);
  font-size: 10px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.14em;
  color: var(--color-gray-500);
}
.ticker-sep {
  font-family: var(--font-num);
  font-size: 28px;
  font-weight: var(--fw-extra);
  color: var(--color-gray-700);
  line-height: 1;
  padding-bottom: 16px;
}

.after-date {
  margin-top: var(--space-10);
  padding: var(--space-5);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: var(--radius-lg);
}
.ad-label {
  font-family: var(--font-en);
  font-size: 10px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.14em;
  color: var(--color-gray-500);
  text-transform: uppercase;
}
.ad-list {
  margin-top: var(--space-4);
  list-style: none;
  padding: 0;
}
.ad-list li {
  display: grid;
  grid-template-columns: 40px 1fr;
  gap: var(--space-3);
  padding: var(--space-3) 0;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  align-items: start;
}
.ad-list li:last-child { border-bottom: 0; }
.ad-list .ad-n {
  font-family: var(--font-num);
  font-variant-numeric: tabular-nums;
  font-size: 11px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.08em;
  color: var(--color-primary);
  padding-top: 2px;
}
.ad-list li strong {
  display: block;
  font-size: var(--fs-body);
  font-weight: var(--fw-bold);
  color: var(--color-paper);
  letter-spacing: var(--ls-tight);
}
.ad-list li span {
  display: block;
  margin-top: 2px;
  font-size: var(--fs-caption);
  color: var(--color-gray-500);
  line-height: var(--lh-relaxed);
}

.urgency-tail {
  margin-top: var(--space-10);
  font-size: var(--fs-body-lg);
  line-height: var(--lh-relaxed);
  color: var(--color-gray-500);
}
.urgency-tail strong {
  color: var(--color-paper);
  font-weight: var(--fw-bold);
}
.urgency-hl {
  margin-top: var(--space-4);
  font-size: 22px;
  font-weight: var(--fw-extra);
  color: var(--color-paper);
  line-height: 1.35;
  letter-spacing: var(--ls-tight);
}
.urgency-hl .hl {
  background: var(--color-primary);
  padding: 2px 8px;
  border-radius: 3px;
  color: var(--color-ink);
  font-weight: var(--fw-bold);
}

/* ---------- Section 10 · Summary Cards ---------- */
.summary h2 {
  margin-top: var(--space-3);
  font-size: 28px;
  font-weight: var(--fw-extra);
  line-height: 1.25;
  letter-spacing: var(--ls-tight);
  color: var(--color-ink);
}
.summary-grid {
  margin-top: var(--space-8);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.sum-card {
  position: relative;
  padding: var(--space-6);
  background: var(--color-paper);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
}
.sum-card.recommended {
  background: var(--color-ink);
  border-color: var(--color-ink);
  color: var(--color-paper);
}
.sum-ribbon {
  position: absolute;
  top: -10px;
  left: var(--space-6);
  padding: 4px 12px;
  background: var(--color-primary);
  color: var(--color-ink);
  font-family: var(--font-en);
  font-size: 10px;
  font-weight: var(--fw-extra);
  letter-spacing: 0.12em;
  border-radius: var(--radius-sm);
}
.sum-head { padding-bottom: var(--space-4); border-bottom: 1px solid var(--border-default); }
.sum-card.recommended .sum-head { border-bottom-color: rgba(255,255,255,0.1); }
.sum-name {
  font-size: var(--fs-body-lg);
  font-weight: var(--fw-bold);
  color: var(--color-ink);
  letter-spacing: var(--ls-tight);
}
.sum-name.invert { color: var(--color-primary); }
.sum-price-line {
  margin-top: var(--space-2);
  display: flex;
  align-items: baseline;
  gap: var(--space-2);
  font-family: var(--font-num);
  font-variant-numeric: tabular-nums;
}
.sum-was {
  font-size: 14px;
  color: var(--color-gray-500);
  text-decoration: line-through;
  font-weight: var(--fw-medium);
}
.sum-arrow { color: var(--color-gray-400); font-size: 12px; }
.sum-now {
  font-size: 28px;
  font-weight: var(--fw-extra);
  color: var(--color-ink);
  letter-spacing: -0.02em;
}
.sum-price-line.invert .sum-now { color: var(--color-paper); }
.sum-tag {
  margin-top: var(--space-2);
  font-size: var(--fs-micro);
  color: var(--color-gray-600);
  font-weight: var(--fw-semibold);
}
.sum-tag.invert { color: var(--color-primary); }
.sum-list {
  margin: var(--space-4) 0;
  padding: 0;
  list-style: none;
}
.sum-list li {
  position: relative;
  padding: var(--space-2) 0 var(--space-2) 24px;
  font-size: var(--fs-caption);
  color: var(--color-gray-900);
  line-height: var(--lh-relaxed);
}
.sum-list li::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: var(--space-2);
  width: 16px;
  height: 16px;
  background: var(--color-primary);
  color: var(--color-ink);
  border-radius: var(--radius-full);
  font-family: var(--font-en);
  font-size: 10px;
  font-weight: var(--fw-extra);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.sum-list.invert li { color: var(--color-paper); }
.sum-list li .muted {
  color: var(--color-gray-500);
  font-weight: var(--fw-medium);
  font-size: var(--fs-micro);
  margin-left: 4px;
}
.sum-list li.early::after {
  content: "EARLY";
  margin-left: 6px;
  padding: 1px 6px;
  background: var(--color-primary);
  color: var(--color-ink);
  font-family: var(--font-en);
  font-size: 9px;
  font-weight: var(--fw-extra);
  letter-spacing: 0.08em;
  border-radius: var(--radius-sm);
  vertical-align: 2px;
}
.btn-outline {
  background: var(--color-paper);
  color: var(--color-ink);
  border: 1px solid var(--color-ink);
}
.btn-outline:hover {
  background: var(--color-ink);
  color: var(--color-primary);
  transform: scale(1.01);
}

/* ---------- Section 10.5 · PT vs HPS (v3: comparison table + scenarios) ---------- */
.compare {
  background: var(--color-paper);
  padding: var(--space-12) var(--content-gutter);
}
.compare h2 {
  margin-top: var(--space-3);
  font-size: 28px;
  font-weight: var(--fw-extra);
  line-height: 1.25;
  letter-spacing: var(--ls-tight);
  color: var(--color-ink);
}
.compare .cmp-intro {
  margin-top: var(--space-4);
  font-size: var(--fs-caption);
  line-height: var(--lh-relaxed);
  color: var(--color-gray-700);
}

/* Comparison table - editorial style, not loud cards */
.cmp-table {
  margin-top: var(--space-8);
  border-top: 2px solid var(--color-ink);
  border-bottom: 2px solid var(--color-ink);
}
.cmp-row {
  display: grid;
  grid-template-columns: 88px 1fr 1fr;
  border-bottom: 1px solid var(--color-gray-200);
  align-items: stretch;
}
.cmp-row:last-child {
  border-bottom: 0;
}
.cmp-row.cmp-head {
  background: var(--color-ink);
  color: #fff;
  border-bottom: 0;
}
.cmp-row.cmp-head .cmp-cell {
  padding: var(--space-3) var(--space-3);
  font-family: var(--font-en);
  font-size: 11px;
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  text-transform: uppercase;
}
.cmp-row.cmp-head .cmp-cell.label {
  color: var(--color-gray-400);
}
.cmp-row.cmp-head .cmp-cell.pt-col {
  color: var(--color-gray-300);
  border-left: 1px solid rgba(255,255,255,0.12);
}
.cmp-row.cmp-head .cmp-cell.hps-col {
  color: var(--color-primary);
  border-left: 1px solid rgba(255,255,255,0.12);
}

.cmp-cell {
  padding: var(--space-4) var(--space-3);
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 2px;
}
.cmp-cell.label {
  font-size: 12px;
  font-weight: var(--fw-semibold);
  color: var(--color-gray-600);
  background: var(--color-gray-50);
  letter-spacing: var(--ls-tight);
}
.cmp-cell.pt-col {
  border-left: 1px solid var(--color-gray-200);
  color: var(--color-gray-600);
}
.cmp-cell.hps-col {
  border-left: 1px solid var(--color-gray-200);
  color: var(--color-ink);
}
.cmp-cell.hps-col.highlight {
  background: rgba(207, 255, 0, 0.12);
}
.cmp-cell .cmp-val {
  font-family: var(--font-en);
  font-size: 16px;
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-tight);
  line-height: 1.2;
  font-variant-numeric: tabular-nums;
}
.cmp-cell .cmp-val.big {
  font-size: 22px;
  font-weight: var(--fw-extra);
}
.cmp-cell.pt-col .cmp-val {
  color: var(--color-gray-700);
}
.cmp-cell.hps-col .cmp-val {
  color: var(--color-ink);
}
.cmp-cell.hps-col.highlight .cmp-val {
  color: var(--color-ink);
}
.cmp-cell .cmp-note {
  font-size: 11px;
  color: var(--color-gray-500);
  font-weight: var(--fw-regular);
  font-family: var(--font-ko);
}

/* Scenarios: 3 situational framings */
.cmp-scenarios {
  margin-top: var(--space-10);
}
.cmp-sc-title {
  font-family: var(--font-en);
  font-size: 11px;
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wide);
  color: var(--color-gray-600);
  margin-bottom: var(--space-4);
  text-transform: uppercase;
}
.cmp-sc {
  display: flex;
  gap: var(--space-3);
  padding: var(--space-4) 0;
  border-bottom: 1px dashed var(--color-gray-300);
}
.cmp-sc:last-child {
  border-bottom: 0;
}
.cmp-sc-icon {
  flex-shrink: 0;
  font-size: 22px;
  line-height: 1;
  margin-top: 2px;
}
.cmp-sc-body {
  flex: 1;
  min-width: 0;
}
.cmp-sc-q {
  font-size: var(--fs-body);
  font-weight: var(--fw-bold);
  color: var(--color-ink);
  letter-spacing: var(--ls-tight);
  line-height: var(--lh-snug);
}
.cmp-sc-a {
  margin-top: var(--space-2);
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.cmp-sc-a .row-pt,
.cmp-sc-a .row-hps {
  font-size: 12px;
  line-height: var(--lh-normal);
  padding: 2px 0 2px 14px;
  position: relative;
}
.cmp-sc-a .row-pt {
  color: var(--color-gray-500);
}
.cmp-sc-a .row-pt::before {
  content: "";
  position: absolute;
  left: 0;
  top: 8px;
  width: 8px;
  height: 1px;
  background: var(--color-gray-400);
}
.cmp-sc-a .row-hps {
  color: var(--color-ink);
  font-weight: var(--fw-semibold);
}
.cmp-sc-a .row-hps::before {
  content: "";
  position: absolute;
  left: 0;
  top: 6px;
  width: 8px;
  height: 5px;
  border-left: 2px solid var(--color-primary);
  border-bottom: 2px solid var(--color-primary);
  transform: rotate(-45deg);
}

/* Final recommendation */
.cmp-final {
  margin-top: var(--space-10);
  padding: var(--space-6);
  background: var(--color-ink);
  border-radius: var(--radius-lg);
  text-align: center;
}
.cmp-final-lead {
  font-size: var(--fs-body-lg);
  line-height: var(--lh-snug);
  color: var(--color-primary);
  font-weight: var(--fw-semibold);
  letter-spacing: var(--ls-tight);
}
.cmp-final-lead strong {
  color: var(--color-primary);
  font-weight: var(--fw-bold);
}
.cmp-final-body {
  margin-top: var(--space-3);
  font-size: var(--fs-caption);
  line-height: var(--lh-relaxed);
  color: var(--color-gray-300);
}
.cmp-final-body strong {
  color: #fff;
  font-weight: var(--fw-bold);
}

/* ---------- Section 11 · FAQ ---------- */
.faq h2 {
  margin-top: var(--space-3);
  font-size: 28px;
  font-weight: var(--fw-extra);
  line-height: 1.25;
  letter-spacing: var(--ls-tight);
  color: var(--color-ink);
}
.faq-list {
  margin-top: var(--space-8);
  border-top: 1px solid var(--border-strong);
}
.faq-item { border-bottom: 1px solid var(--border-default); }
.faq-q {
  width: 100%;
  display: grid;
  grid-template-columns: 44px 1fr 24px;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-5) 0;
  background: transparent;
  border: 0;
  text-align: left;
  cursor: pointer;
  font-family: inherit;
  color: var(--color-ink);
}
.faq-q .faq-n {
  font-family: var(--font-en);
  font-variant-numeric: tabular-nums;
  font-size: 11px;
  font-weight: var(--fw-extra);
  letter-spacing: 0.06em;
  color: var(--color-gray-500);
}
.faq-item.open .faq-q .faq-n { color: var(--color-ink); }
.faq-q .faq-qt {
  font-size: var(--fs-body);
  font-weight: var(--fw-semibold);
  color: var(--color-ink);
  letter-spacing: var(--ls-tight);
  line-height: 1.4;
}
.faq-q .faq-arr {
  font-family: var(--font-en);
  font-size: 22px;
  font-weight: var(--fw-medium);
  color: var(--color-gray-500);
  line-height: 1;
  text-align: center;
  transition: color var(--dur-base) var(--ease-out);
}
.faq-item.open .faq-q .faq-arr { color: var(--color-ink); }
.faq-a-wrap {
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transition: max-height 0.28s var(--ease-out), opacity 0.22s var(--ease-out);
}
.faq-item.open .faq-a-wrap {
  max-height: 480px;
  opacity: 1;
}
.faq-a {
  padding: 0 0 var(--space-5) 56px;
  font-size: var(--fs-caption);
  line-height: var(--lh-relaxed);
  color: var(--color-gray-700);
  text-wrap: pretty;
}

/* ---------- Section 12 · Final CTA ---------- */
.final-cta {
  background: var(--color-ink);
  color: var(--color-paper);
  text-align: center;
  padding-top: var(--space-24);
  padding-bottom: var(--space-24);
}
.final-cta .eyebrow {
  display: inline-flex;
  margin-bottom: var(--space-6);
}
.fc-lead {
  font-size: 32px;
  font-weight: var(--fw-extra);
  color: var(--color-paper);
  line-height: 1.25;
  letter-spacing: var(--ls-tight);
  text-wrap: balance;
}
.fc-lead .hl {
  background: var(--color-primary);
  padding: 2px 10px;
  border-radius: var(--radius-sm);
  color: var(--color-ink);
  display: inline-block;
  line-height: 1.1;
}
.fc-sub {
  margin-top: var(--space-4);
  font-size: var(--fs-body-lg);
  color: var(--color-gray-500);
  font-weight: var(--fw-medium);
  letter-spacing: var(--ls-tight);
}
.fc-btn {
  margin-top: var(--space-10);
  height: 64px;
  font-size: var(--fs-body-lg);
  box-shadow: var(--shadow-cta);
}
.fc-footnote {
  margin-top: var(--space-5);
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--fs-micro);
  color: var(--color-gray-500);
  font-weight: var(--fw-medium);
}
.fc-footnote .dot {
  width: 6px;
  height: 6px;
  border-radius: var(--radius-full);
  background: var(--color-primary);
  display: inline-block;
}

/* ---------- Section 13 · Refund ---------- */
.refund h2 {
  margin-top: var(--space-3);
  font-size: 26px;
  font-weight: var(--fw-extra);
  line-height: 1.3;
  letter-spacing: var(--ls-tight);
  color: var(--color-ink);
}
.rf-intro {
  margin-top: var(--space-5);
  font-size: var(--fs-body);
  line-height: var(--lh-relaxed);
  color: var(--color-gray-700);
}
.rf-cards {
  margin-top: var(--space-8);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.rf-card {
  padding: var(--space-5);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border-default);
}
.rf-card.yes {
  background: var(--color-paper);
  border-left: 3px solid var(--color-ink);
}
.rf-card.no {
  background: var(--color-gray-50);
  border: 1px dashed var(--border-strong);
}
.rf-flag {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-en);
  font-size: 10px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-gray-600);
}
.rf-tick {
  width: 16px;
  height: 16px;
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: var(--color-ink);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-en);
  font-size: 10px;
  font-weight: var(--fw-extra);
}
.rf-tick.ink {
  background: var(--color-gray-300);
  color: var(--color-gray-700);
}
.rf-headline {
  margin-top: var(--space-2);
  font-size: var(--fs-body-lg);
  font-weight: var(--fw-bold);
  color: var(--color-ink);
  letter-spacing: var(--ls-tight);
}
.rf-card.no .rf-headline { color: var(--color-gray-600); }
.rf-points {
  margin: var(--space-3) 0 0;
  padding: 0;
  list-style: none;
}
.rf-points li {
  position: relative;
  padding: 2px 0 2px 14px;
  font-size: var(--fs-caption);
  color: var(--color-gray-700);
  line-height: var(--lh-relaxed);
}
.rf-points li::before {
  content: "·";
  position: absolute;
  left: 2px;
  top: 2px;
  color: var(--color-gray-500);
  font-weight: var(--fw-bold);
}

.rf-steps {
  margin-top: var(--space-8);
  padding: var(--space-5);
  background: var(--color-gray-50);
  border-radius: var(--radius-md);
}
.rf-steps-title {
  font-size: var(--fs-caption);
  font-weight: var(--fw-bold);
  color: var(--color-ink);
  letter-spacing: var(--ls-tight);
}
.rf-ol {
  margin: var(--space-3) 0 0;
  padding: 0 0 0 20px;
  font-size: var(--fs-caption);
  color: var(--color-gray-700);
  line-height: var(--lh-relaxed);
}
.rf-ol li { padding: 2px 0; }

.rf-note {
  margin-top: var(--space-6);
  padding-top: var(--space-5);
  border-top: 1px solid var(--border-default);
}
.rf-note-label {
  font-family: var(--font-en);
  font-size: 10px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.12em;
  color: var(--color-gray-500);
  text-transform: uppercase;
}
.rf-note ul {
  margin: var(--space-3) 0 0;
  padding: 0;
  list-style: none;
}
.rf-note ul li {
  position: relative;
  padding: 4px 0 4px 14px;
  font-size: var(--fs-micro);
  color: var(--color-gray-600);
  line-height: var(--lh-relaxed);
}
.rf-note ul li::before {
  content: "※";
  position: absolute;
  left: 0;
  color: var(--color-gray-500);
}

/* ---------- Refund flow (download process) ---------- */
.rf-flow {
  margin-top: var(--space-8);
  padding: var(--space-5);
  background: var(--color-gray-50);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border-default);
}
.rf-flow-title {
  font-size: var(--fs-caption);
  font-weight: var(--fw-bold);
  color: var(--color-ink);
  letter-spacing: var(--ls-tight);
  margin-bottom: var(--space-4);
}
.rf-flow-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.rf-flow-list li {
  display: flex;
  gap: var(--space-3);
  align-items: flex-start;
  padding: var(--space-3) var(--space-4);
  background: #fff;
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-md);
}
.rf-flow-list li:last-child {
  border-color: var(--color-ink);
  background: var(--color-ink);
  color: var(--color-gray-200);
}
.rf-flow-n {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
  border-radius: var(--radius-full);
  background: var(--color-gray-200);
  color: var(--color-gray-700);
  display: grid;
  place-items: center;
  font-family: var(--font-en);
  font-size: 12px;
  font-weight: var(--fw-bold);
}
.rf-flow-list li:last-child .rf-flow-n {
  background: var(--color-primary);
  color: var(--color-ink);
}
.rf-flow-h {
  font-size: var(--fs-body);
  font-weight: var(--fw-semibold);
  color: var(--color-ink);
  line-height: var(--lh-snug);
  letter-spacing: var(--ls-tight);
}
.rf-flow-list li:last-child .rf-flow-h {
  color: var(--color-primary);
}
.rf-flow-b {
  font-size: var(--fs-caption);
  color: var(--color-gray-600);
  line-height: var(--lh-normal);
  margin-top: 2px;
}
.rf-flow-list li:last-child .rf-flow-b {
  color: var(--color-gray-400);
}
.rf-flow-note {
  margin-top: var(--space-4);
  padding: var(--space-3) var(--space-4);
  background: var(--color-primary);
  border-radius: var(--radius-md);
  font-size: var(--fs-caption);
  font-weight: var(--fw-semibold);
  color: var(--color-ink);
  text-align: center;
}

/* ---------- Section 14 · Footer ---------- */
.footer {
  padding: var(--space-16) var(--content-gutter) var(--space-12);
  background: var(--color-ink);
  color: var(--color-paper);
}
.footer .ft-mark {
  font-family: var(--font-ko);
  font-size: 22px;
  font-weight: var(--fw-bold);
  color: var(--color-paper);
  letter-spacing: var(--ls-tight);
}
.footer .ft-mark .ft-sub {
  font-family: var(--font-en);
  margin-left: 6px;
  color: var(--color-primary);
  font-weight: var(--fw-extra);
}
.footer .ft-tagline {
  margin-top: var(--space-2);
  font-size: var(--fs-caption);
  color: var(--color-gray-500);
  font-weight: var(--fw-medium);
}
.footer .ft-links {
  margin-top: var(--space-8);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--fs-caption);
}
.footer .ft-links a {
  color: var(--color-paper);
  font-weight: var(--fw-medium);
}
.footer .ft-links a:hover { color: var(--color-primary); }
.footer .ft-links .sep { color: var(--color-gray-700); }
.footer .ft-contact {
  margin-top: var(--space-6);
  padding-top: var(--space-6);
  border-top: 1px solid rgba(255,255,255,0.08);
}
.footer .ft-c-row {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  font-size: var(--fs-caption);
}
.footer .ft-c-row .k {
  font-family: var(--font-en);
  font-size: 10px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.12em;
  color: var(--color-gray-500);
  text-transform: uppercase;
  width: 50px;
}
.footer .ft-c-row .v { color: var(--color-paper); font-weight: var(--fw-medium); }
.footer .ft-legal {
  margin-top: var(--space-10);
  padding-top: var(--space-5);
  border-top: 1px solid rgba(255,255,255,0.08);
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-3);
  font-family: var(--font-en);
  font-size: var(--fs-micro);
  color: var(--color-gray-600);
  font-weight: var(--fw-medium);
  letter-spacing: 0.02em;
}

/* ---------- Sticky bottom CTA ---------- */
.sticky-cta {
  position: fixed;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%) translateY(100%);
  width: 100%;
  max-width: var(--content-max);
  z-index: 40;
  padding: var(--space-3) var(--content-gutter);
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: var(--space-3);
  background: rgba(255,255,255,0.95);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-top: 1px solid var(--border-default);
  box-shadow: var(--shadow-lg);
  transition: transform 0.35s var(--ease-out);
  pointer-events: none;
}
.sticky-cta.show {
  transform: translateX(-50%) translateY(0);
  pointer-events: auto;
}
.sticky-cta .sc-text { min-width: 0; }
.sticky-cta .sc-strong {
  font-size: var(--fs-body);
  font-weight: var(--fw-bold);
  color: var(--color-ink);
  letter-spacing: var(--ls-tight);
  font-family: var(--font-num);
  font-variant-numeric: tabular-nums;
}
.sticky-cta .sc-muted {
  font-size: 11px;
  color: var(--color-gray-600);
  font-weight: var(--fw-medium);
}
.sticky-cta .sc-btn {
  width: auto;
  height: 44px;
  padding: 0 var(--space-5);
  font-size: var(--fs-caption);
}

@media (min-width: 480px) {
  .pricing h2, .summary h2, .urgency h2, .faq h2 { font-size: 30px; }
  .refund h2 { font-size: 28px; }
  .fc-lead { font-size: 36px; }
  .pg-big-num { font-size: 52px; }
  .ticker-unit .tu-v { font-size: 48px; }
}
