/* ============================================================
   HBT 187 Growup — Editorial Landing Page Styles
   Brand tokens: navy + pink + paper warm + gold accents
   Typography: Playfair Display (serif) + Pretendard (sans) + JetBrains Mono
   Mobile-first, single breakpoint at 720px
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Merriweather:ital,opsz,wght@0,18..144,300..900;1,18..144,300..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@200..700&display=swap');

:root {
  /* Typography — matches sister brand holisticbeautytour.com
     Poppins (sans) · Merriweather (serif accents) · Oswald (display)
     Noto Sans KR added as per-glyph fallback so Korean text doesn't render in Gulim. */
  --sans: 'Poppins', 'Noto Sans KR', -apple-system, 'Segoe UI', sans-serif;
  --serif: 'Merriweather', 'Noto Sans KR', 'Cormorant Garamond', Georgia, serif;
  --display: 'Oswald', 'Noto Sans KR', 'Poppins', sans-serif;
  --mono: 'JetBrains Mono', 'Noto Sans KR', ui-monospace, monospace;

  /* Ink scale */
  --ink: #0B0B0C;
  --ink80: #2B2B2E;
  --ink60: #6B6B72;
  --ink40: #9B9BA2;
  --ink20: #D6D6DB;
  --ink10: #ECECEF;
  --paper: #FFFFFF;
  --paperWarm: #F7F6F3;

  /* Navy */
  --navy: #1A2332;
  --navyDeep: #0F1620;

  /* Brand pink */
  --pink: #E91E63;
  --pinkHot: #F0256B;
  --pinkSoft: #FCE4EC;

  /* Gold (specialized) */
  --gold: #FFF3CD;
  --goldLight: #FFF8E1;
  --goldDark: #8a6500;
  --goldBorder: #F5D76E;

  /* Status */
  --warnAmber: #C8841A;
  --whatsapp: #25D366;
  --line: #06C755;

  /* Shadows */
  --shadow-sm: 0 2px 8px rgba(15,23,42,0.06);
  --shadow-md: 0 8px 24px rgba(15,23,42,0.10);
  --shadow-lg: 0 20px 48px rgba(15,23,42,0.14);

  /* Radius */
  --radius: 14px;
  --radius-lg: 22px;
  --radius-card: 18px;

  --tertiary: #8d9caf;
  --colour-lightblack: #0d0d0d;
  --primary:/*#028faa;*/ #e8006d;
}

/* ─── Reset ──────────────────────────────────────────────── */
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--sans);
  color: var(--ink);
  background: var(--paper);
  line-height: 1.55;
}
button { font-family: inherit; cursor: pointer; }
input, select { font-family: inherit; }
input::placeholder { color: var(--ink20); }
input[type=number] { -moz-appearance: textfield; }
input::-webkit-outer-spin-button, input::-webkit-inner-spin-button {
  -webkit-appearance: none; margin: 0;
}
.container { max-width: 720px; margin: 0 auto; }
.container-wide { max-width: 1080px; margin: 0 auto; }

.mono-label {
  font-family: var(--mono); font-size: 11px; letter-spacing: 2px;
  text-transform: uppercase; color: var(--ink60); font-weight: 500;
}

/* ─── Top Nav ────────────────────────────────────────────── */
.nav {
  position: sticky; top: 0; z-index: 30;
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 20px; height: 56px;
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(0,0,0,0.04);
  transition: box-shadow .2s ease;
}
.nav.scrolled { box-shadow: 0 4px 14px rgba(15,22,32,0.06); }
.nav-brand { display: flex; align-items: center; gap: 12px; }
.nav-mark svg { display: block; }
.nav-word { display: flex; align-items: baseline; gap: 6px; }
.nav-word .h { font-size: 13px; font-weight: 700; letter-spacing: 0.4px; color: var(--ink); }
.nav-word .num { font-family: var(--serif); font-style: italic; font-size: 17px; color: var(--pink); line-height: 1; transform: translateY(1px); }
.nav-word .g { font-size: 13px; font-weight: 500; letter-spacing: 0.4px; color: var(--ink80); }

.lang-switch { display: flex; align-items: center; gap: 4px; }
.lang-switch button {
  padding: 6px 12px; border: none; background: transparent;
  font-size: 11px; font-weight: 600; letter-spacing: 1px; color: var(--ink60);
  border-radius: 999px;
}
.lang-switch button.on { background: var(--ink); color: #fff; }

@media (min-width: 720px) {
  .nav { padding: 0 32px; height: 64px; }
}

/* ─── Hero ───────────────────────────────────────────────── */
.hero {
  position: relative; overflow: hidden;
  padding: 40px 24px 48px;
  background: linear-gradient(180deg, var(--paperWarm) 0%, var(--paper) 75%);
}
.hero-watermark {
  position: absolute; right: -40px; top: 70px;
  pointer-events: none; user-select: none;
  font-family: var(--display); font-weight: 700; font-style: normal;
  font-size: 260px; line-height: 0.85; letter-spacing: -4px;
  color: var(--pinkSoft); opacity: 0.85;
}
.hero-inner { position: relative; z-index: 2; max-width: 720px; }

.pink-pill {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 8px 16px; border-radius: 999px;
  background: var(--pinkSoft); color: var(--pink);
  font-size: 12px; font-weight: 600; letter-spacing: 0.2px;
}
.pulse-dot { position: relative; display: inline-block; width: 7px; height: 7px; }
.pulse-dot::before, .pulse-dot::after {
  content: ''; position: absolute; inset: 0; border-radius: 50%; background: var(--pink);
}
.pulse-dot::before { opacity: 0.35; animation: gupulse 1.8s linear infinite; }
@keyframes gupulse {
  0%   { transform: scale(1); opacity: 0.6; }
  70%  { transform: scale(2.4); opacity: 0; }
  100% { transform: scale(2.4); opacity: 0; }
}

.hero h1 {
  font-family: var(--sans); font-weight: 500;
  font-size: 38px; line-height: 1.1; letter-spacing: -0.5px;
  margin: 22px 0 18px; text-wrap: pretty;
}
.hero h1 .first { color: var(--pink); }
.hero-sub {
  font-size: 15px; line-height: 1.6; color: var(--ink60);
  margin: 0; max-width: 360px;
}
.hero-sub strong { color: var(--ink); font-weight: 600; }
.hero-sub em { font-family: var(--serif); color: var(--pink); font-style: italic; font-weight: 400; }

.trust-badges {
  display: flex; flex-direction: column; gap: 10px; align-items: stretch;
  margin-top: 24px; flex-wrap: wrap;
}
.trust-badge {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 10px 16px; border-radius: 999px;
  font-size: 12.5px; font-weight: 600; letter-spacing: 0.1px; line-height: 1.2;
}
.trust-badge .ic { font-size: 16px; line-height: 1; }
.trust-badge.gold {
  background: linear-gradient(135deg, var(--goldLight), var(--gold));
  color: var(--goldDark); border: 1px solid var(--goldBorder);
}
.trust-badge.navy {
  background: linear-gradient(135deg, var(--paperWarm), #ECE6DA);
  color: var(--navyDeep); border: 1px solid var(--ink20);
}

.trust-strip {
  display: flex; align-items: center; gap: 18px; flex-wrap: wrap; margin-top: 32px;
}
.trust-stat { display: flex; align-items: baseline; gap: 8px; }
.trust-stat .n {
  font-family: var(--display); font-size: 28px; color: var(--ink); font-weight: 600;
  letter-spacing: -0.5px;
}
.trust-stat .l {
  font-family: var(--mono); font-size: 10px; letter-spacing: 1.5px;
  color: var(--ink60); text-transform: uppercase;
}

@media (min-width: 720px) {
  .hero { padding: 72px 72px 96px; }
  .hero-watermark { right: -20px; top: 50px; font-size: 420px; }
  .hero h1 { font-size: 64px; margin: 32px 0 24px; }
  .hero-sub { font-size: 18px; max-width: 520px; }
  .trust-badges { flex-direction: row; align-items: center; margin-top: 32px; gap: 10px; }
  .trust-strip { gap: 28px; margin-top: 44px; }
  .trust-stat .n { font-size: 32px; }
}

/* ─── Calculator ─────────────────────────────────────────── */
.calc-section { padding: 40px 24px; background: var(--paper); }
.calc-title {
  font-family: var(--sans); font-weight: 500; font-size: 26px;
  color: var(--ink); margin: 12px 0 32px;
  letter-spacing: -0.5px; line-height: 1.25;
}
.calc-card {
  background: var(--paperWarm); padding: 24px; border-radius: 22px;
  display: flex; flex-direction: column; gap: 18px;
}
.field-label {
  font-size: 13px; font-weight: 500; color: var(--ink); margin-bottom: 8px;
  display: flex; align-items: baseline; justify-content: space-between;
}
.field-label .opt {
  font-family: var(--mono); font-size: 10px; color: var(--ink40);
  letter-spacing: 1px; text-transform: uppercase;
}

.segmented {
  display: grid; grid-template-columns: 1fr 1fr; gap: 4px; padding: 4px;
  background: var(--paperWarm); border-radius: 14px;
}
.calc-card .segmented { background: var(--paper); }
.segmented button {
  padding: 14px 12px; border: none; background: transparent;
  color: var(--ink60); border-radius: 10px;
  font-size: 14px; font-weight: 500;
  display: flex; align-items: center; justify-content: center; gap: 8px;
  transition: background .15s;
}
.segmented button .seg-ic { font-size: 16px; }
.segmented button.on {
  background: var(--ink); color: #fff; font-weight: 700;
  box-shadow: 0 4px 12px rgba(15,23,42,0.18);
  letter-spacing: 0.2px;
}
.segmented button.on .seg-ic { filter: grayscale(0) brightness(1.1); }

.field-wrap { display: block; }
.field {
  display: flex; align-items: center; gap: 8px;
  padding: 14px 16px; background: var(--paper);
  border: 1.5px solid var(--ink10); border-radius: 12px;
  transition: border-color .15s;
}
.field:focus-within { border-color: var(--pink); }
.field input {
  flex: 1; min-width: 0; border: none; outline: none; background: transparent;
  font-family: var(--display); font-size: 22px; color: var(--ink); font-weight: 500;
  letter-spacing: 0.3px;
}
.field .suffix {
  font-family: var(--sans); font-size: 12px; color: var(--ink60);
  letter-spacing: 0.2px; font-weight: 500;
}
.row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }

.btn-primary {
  width: 100%; padding: 18px 28px;
  background: var(--ink); color: #fff;
  border: none; border-radius: 999px;
  font-size: 15px; font-weight: 600; letter-spacing: 0.2px;
  display: flex; align-items: center; justify-content: center; gap: 12px;
  transition: transform .12s ease, background .15s ease;
}
.btn-primary:hover { background: var(--navyDeep); }
.btn-primary:active { transform: scale(0.98); }
.btn-primary.pink { background: var(--pink); }
.btn-primary.pink:hover { background: var(--pinkHot); }
.btn-primary::after { content: '→'; font-size: 16px; line-height: 1; }

.calc-foot {
  font-family: var(--mono); font-size: 10px; color: var(--ink40);
  letter-spacing: 1px; text-align: center; text-transform: uppercase;
}
.calc-error {
  background: var(--pinkSoft); color: var(--pinkHot);
  padding: 12px 14px; border-radius: 10px; font-size: 13px;
  display: none;
}
.calc-error.show { display: block; }

@media (min-width: 720px) {
  .calc-section { padding: 64px 72px; }
  .calc-card { padding: 36px; }
  .calc-title { font-size: 34px; }
}

/* ─── Result Card ────────────────────────────────────────── */
.result-section { padding: 24px 20px; background: var(--paperWarm); }
.result-card {
  position: relative; overflow: hidden;
  max-width: 720px; margin: 0 auto;
  background: var(--navyDeep); color: #fff;
  border-radius: 26px; padding: 28px;
  box-shadow: 0 20px 48px rgba(15,23,42,0.18);
  animation: guSlideUp .6s cubic-bezier(0.16,1,0.3,1) both;
  display: none;
}
.result-card.show { display: block; }
.result-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: var(--pink);
}
@keyframes guSlideUp {
  from { transform: translateY(24px); opacity: 0; }
  to   { transform: translateY(0); opacity: 1; }
}
.result-head { display: flex; align-items: baseline; justify-content: space-between; }
.result-head .label {
  font-family: var(--mono); font-size: 11px; letter-spacing: 2px;
  color: rgba(255,255,255,0.55); text-transform: uppercase; font-weight: 500;
}
.result-head .sig {
  font-family: var(--serif); font-style: italic; font-size: 18px; color: var(--pink); font-weight: 400;
}
.result-value { margin-top: 18px; display: flex; align-items: baseline; gap: 14px; flex-wrap: wrap; }
.result-value .v {
  font-family: var(--display); font-weight: 600; font-size: 72px;
  line-height: 0.95; letter-spacing: -2px;
}
.result-value .u {
  font-family: var(--mono); font-size: 14px; color: rgba(255,255,255,0.6); letter-spacing: 2px;
}
.result-range {
  margin-top: 16px; display: inline-flex; padding: 8px 18px;
  background: rgba(255,255,255,0.08); border-radius: 999px;
  font-size: 13px; color: rgba(255,255,255,0.85);
}
.result-note { margin-top: 24px; padding-top: 22px; border-top: 1px solid rgba(255,255,255,0.12); }
.result-branch { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }
.result-branch .b-dot { width: 8px; height: 8px; border-radius: 50%; }
.result-branch .b-dot.green { background: #7CE3B8; }
.result-branch .b-dot.amber { background: #FFC679; }
.result-branch .b-dot.red   { background: #FF8B8B; }
.result-branch .b-label {
  font-family: var(--mono); font-size: 11px; letter-spacing: 1.5px;
  text-transform: uppercase; color: rgba(255,255,255,0.7); font-weight: 500;
}
.result-quote {
  font-family: var(--serif); font-style: italic; font-size: 20px;
  line-height: 1.35; color: #fff;
}
.result-msg {
  font-size: 14px; color: rgba(255,255,255,0.6); margin-top: 12px; line-height: 1.6;
}
.result-msg .pink-em { color: var(--pink); font-weight: 600; }

@media (min-width: 720px) {
  .result-section { padding: 48px 72px; }
  .result-card { padding: 48px; }
  .result-value .v { font-size: 112px; }
  .result-quote { font-size: 24px; }
}

/* ─── Growth Potential Visualizer ────────────────────────── */
.viz-section {
  padding: 40px 20px;
  background: linear-gradient(180deg, var(--paperWarm) 0%, var(--paper) 100%);
  display: none;
}
.viz-section.show { display: block; }
.viz-head { display: flex; align-items: center; gap: 12px; margin-bottom: 18px; }
.viz-h2 {
  font-family: var(--sans); font-weight: 500; font-size: 28px;
  color: var(--ink); margin: 0 0 14px;
  letter-spacing: -0.5px; line-height: 1.2;
}
.viz-h2 .first { color: var(--pink); }
.viz-intro {
  font-size: 14px; color: var(--ink60); margin: 0 0 36px; line-height: 1.6; max-width: 520px;
}
.viz-intro strong { color: var(--ink); }
.viz-intro .pink-strong { color: var(--pink); font-weight: 600; }

.viz-body { display: grid; grid-template-columns: 1fr; gap: 28px; align-items: stretch; }

.ruler-card {
  background: var(--paper); border-radius: 22px; padding: 22px;
  border: 1px solid var(--ink10); position: relative;
  min-height: 360px; display: flex; flex-direction: column;
}
.ruler-track { position: relative; flex: 1; margin-top: 18px; min-height: 280px; }
.ruler-bar {
  position: absolute; left: 56px; top: 0; bottom: 0; width: 56px;
  background: var(--paperWarm); border-radius: 12px; overflow: hidden;
}
.ruler-fill {
  position: absolute; left: 0; right: 0; bottom: 0; height: 0;
  background: linear-gradient(180deg, var(--navy) 0%, var(--navyDeep) 100%);
  transition: height 1.2s cubic-bezier(0.4,0,0.2,1);
}
.ruler-fill-p {
  position: absolute; left: 0; right: 0; bottom: 0; height: 0;
  background: repeating-linear-gradient(135deg, var(--pink) 0 6px, var(--pinkHot) 6px 12px);
  opacity: 0.85;
  transition: height 1.2s cubic-bezier(0.4,0,0.2,1) 0.4s, bottom 1.2s cubic-bezier(0.4,0,0.2,1);
}
.ruler-tick {
  position: absolute; left: 0; right: 0; display: flex; align-items: center; gap: 8px;
  transform: translateY(50%);
}
.ruler-tick .t-label {
  font-family: var(--mono); font-size: 10px; color: var(--ink40);
  width: 38px; text-align: right;
}
.ruler-tick .t-line { width: 12px; height: 1px; background: var(--ink20); }

.ruler-marker {
  position: absolute; left: 120px; right: 4px; transform: translateY(50%);
  display: flex; align-items: center; gap: 8px;
  opacity: 0; transition: opacity .4s;
  z-index: 3;
  pointer-events: none;
}
.ruler-marker.show { opacity: 1; }
.ruler-marker .m-dash {
  width: 18px; height: 2px;
  flex-shrink: 0;
}
.ruler-marker > div {
  background: rgba(255,255,255,0.95);
  padding: 4px 10px; border-radius: 8px;
  box-shadow: 0 2px 8px rgba(15,23,42,0.10);
  min-width: 0;
  white-space: nowrap;
}
.ruler-marker .m-kind {
  font-family: var(--sans); font-size: 10px; font-weight: 600;
  letter-spacing: 0.5px;
}
.ruler-marker .m-v {
  font-family: var(--display); font-size: 22px; font-weight: 600; line-height: 1; letter-spacing: 0.2px;
}
.ruler-marker .m-v .m-u { font-family: var(--mono); font-size: 11px; }
.ruler-marker.current .m-dash { background: var(--navy); }
.ruler-marker.current .m-kind { color: var(--ink60); }
.ruler-marker.current .m-v { color: var(--ink); }
.ruler-marker.current .m-v .m-u { color: var(--ink60); }
.ruler-marker.potential .m-dash { background: var(--pink); }
.ruler-marker.potential .m-kind { color: var(--pink); }
.ruler-marker.potential .m-v { color: var(--pink); }

.viz-aside { display: flex; flex-direction: column; justify-content: space-between; gap: 24px; }
.gain-card {
  display: flex; align-items: baseline; gap: 14px;
  padding-bottom: 22px; border-bottom: 1px solid var(--ink10);
}
.gain-card .gain-n {
  font-family: var(--display); font-size: 56px; color: var(--pink);
  font-weight: 600; line-height: 0.9; letter-spacing: -1px;
}
.gain-card .gain-l {
  font-family: var(--mono); font-size: 10px; letter-spacing: 1.5px;
  color: var(--ink60); text-transform: uppercase;
}
.gain-card .gain-c {
  font-size: 14px; color: var(--ink); font-weight: 600;
}
.window-card { background: var(--paperWarm); border-radius: 14px; padding: 18px; }
.window-head { display: flex; align-items: center; gap: 8px; margin-bottom: 6px; }
.window-head .w-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--pink); }
.window-head.amber .w-dot { background: var(--warnAmber); }
.window-head .w-label {
  font-family: var(--mono); font-size: 11px; letter-spacing: 2px;
  color: var(--ink60); text-transform: uppercase; font-weight: 500;
}
.window-head.amber .w-label { color: var(--warnAmber); }
.window-body {
  font-family: var(--sans); font-size: 20px; color: var(--ink);
  font-weight: 500; line-height: 1.35; letter-spacing: -0.3px;
}
.window-body .pink-em { color: var(--pink); }

.viz-cta-stack { display: flex; flex-direction: column; gap: 10px; }
.viz-cta-foot {
  font-family: var(--mono); font-size: 10px; color: var(--ink40);
  letter-spacing: 1px; text-align: center; text-transform: uppercase;
}

@media (min-width: 720px) {
  .viz-section { padding: 80px 72px; }
  .viz-h2 { font-size: 40px; }
  .viz-intro { font-size: 16px; }
  .viz-body { grid-template-columns: 1fr 1fr; gap: 48px; }
  .ruler-card { padding: 32px; min-height: 440px; }
  .ruler-track { min-height: 360px; }
  .gain-card .gain-n { font-size: 64px; }
}

/* 16세+ branch */
.over-section { padding: 48px 20px; background: var(--paperWarm); display: none; }
.over-section.show { display: block; }
.over-card {
  max-width: 640px; margin: 0 auto; text-align: center;
  background: var(--paper); padding: 36px 24px; border-radius: 22px;
}
.over-card .pill {
  display: inline-flex; padding: 8px 18px; border-radius: 999px;
  background: rgba(200,132,26,0.1); color: var(--warnAmber);
  font-family: var(--mono); font-size: 11px; letter-spacing: 2px;
  text-transform: uppercase; font-weight: 600;
}
.over-card h3 {
  font-family: var(--sans); font-weight: 600; font-size: 26px;
  color: var(--ink); margin: 20px 0 12px; letter-spacing: -0.4px; line-height: 1.25;
}
.over-card p { font-size: 15px; color: var(--ink60); line-height: 1.65; }

/* ─── Who Needs Growth Care (Cases + Programs) ───────────── */
.cases-section { padding: 56px 20px; background: var(--paperWarm); }
.cases-head { max-width: 640px; }
.cases-head h2 {
  font-family: var(--sans); font-weight: 500; font-size: 28px;
  color: var(--ink); margin: 12px 0 14px; letter-spacing: -0.5px; line-height: 1.2;
}
.cases-head h2 .first { color: var(--pink); }
.cases-head p {
  font-size: 14px; color: var(--ink60); margin: 0; line-height: 1.65; max-width: 540px;
}
.cases-head p strong { color: var(--ink); }

.cases-grid {
  margin-top: 32px;
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px;
}
.case-card {
  position: relative; cursor: pointer; border: none; text-align: left;
  background: var(--paper); padding: 18px 16px; border-radius: 18px;
  display: flex; flex-direction: column; gap: 8px; min-height: 142px;
  box-shadow: inset 0 0 0 1.5px var(--ink10);
  transition: all .22s cubic-bezier(0.4,0,0.2,1);
  font-family: var(--sans);
}
.case-card .emoji { font-size: 26px; line-height: 1; }
.case-card .title { font-size: 14px; font-weight: 700; color: var(--ink); line-height: 1.3; }
.case-card .desc { font-size: 11.5px; line-height: 1.5; color: var(--ink60); }
.case-card .chips { margin-top: auto; display: flex; gap: 4px; flex-wrap: wrap; padding-top: 4px; }
.case-card .chip {
  font-family: var(--mono); font-size: 9px; letter-spacing: 0.5px;
  padding: 2px 6px; border-radius: 4px;
  background: var(--paperWarm); color: var(--ink60); font-weight: 600;
  transition: all .2s;
}
.case-card.featured {
  background: linear-gradient(135deg, var(--goldLight) 0%, var(--gold) 100%);
  box-shadow: 0 6px 18px rgba(240,198,68,0.18);
}
.case-card.featured .title { color: #5d4500; }
.case-card.featured .desc { color: var(--goldDark); }
.case-card.featured .chip { background: rgba(138,101,0,0.12); color: var(--goldDark); }
.case-card .spec-badge {
  position: absolute; top: 12px; right: 12px;
  padding: 3px 8px; border-radius: 999px;
  background: var(--goldDark); color: #fff;
  font-family: var(--mono); font-size: 8.5px; letter-spacing: 1.5px;
  text-transform: uppercase; font-weight: 700;
}
.cases-grid.has-active .case-card:not(.active) { opacity: 0.45; }
.case-card.active {
  transform: translateY(-2px);
  box-shadow: 0 0 0 2px var(--pink), 0 12px 28px var(--pinkSoft);
}
.case-card.active.featured {
  box-shadow: 0 0 0 2px var(--goldBorder), 0 12px 28px rgba(240,198,68,0.25);
}
.case-card.active .chip { background: var(--pink); color: #fff; }
.case-card.active.featured .chip { background: var(--goldDark); color: #fff; }

.cases-divider { margin: 40px 0 28px; display: flex; align-items: center; gap: 16px; }
.cases-divider .line { flex: 1; height: 1px; background: var(--ink20); }
.cases-divider .label-pill {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 18px; background: var(--paper);
  border: 1.5px solid var(--ink10); border-radius: 999px;
}
.cases-divider .label-pill .l {
  font-family: var(--mono); font-size: 10px; letter-spacing: 2px;
  color: var(--ink60); text-transform: uppercase; font-weight: 600;
}
.cases-divider .label-pill .arrow { color: var(--pink); font-family: var(--serif); font-style: italic; }

.programs-head { max-width: 640px; margin-bottom: 24px; }
.programs-head h3 {
  font-family: var(--sans); font-weight: 500; font-size: 24px;
  color: var(--ink); margin: 0 0 10px; letter-spacing: -0.4px; line-height: 1.25;
}
.programs-head h3 .first { color: var(--pink); }
.programs-head p { font-size: 13.5px; color: var(--ink60); margin: 0; line-height: 1.6; }
.programs-head .matched { color: var(--pink); font-weight: 600; }

.programs-grid { display: grid; grid-template-columns: 1fr; gap: 10px; }
.program-card {
  display: flex; gap: 16px; align-items: flex-start;
  padding: 20px 22px; border-radius: 16px;
  background: var(--paper); color: var(--ink);
  box-shadow: inset 0 0 0 1.5px var(--ink10);
  transition: all .25s cubic-bezier(0.4,0,0.2,1);
  position: relative;
}
.program-card .pg-num {
  width: 42px; height: 42px; flex-shrink: 0;
  background: var(--paperWarm); color: var(--ink60);
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--display); font-size: 18px; font-weight: 600;
}
.program-card .pg-body { flex: 1; min-width: 0; }
.program-card .pg-title {
  font-family: var(--sans); font-size: 17px; font-weight: 600;
  color: var(--ink); margin-bottom: 4px; letter-spacing: -0.2px;
}
.program-card .pg-desc { font-size: 12.5px; line-height: 1.5; color: var(--ink60); }
.program-card.match {
  background: var(--navyDeep); color: #fff;
  box-shadow: 0 16px 32px rgba(15,22,32,0.18); transform: translateY(-2px);
}
.program-card.match .pg-num { background: var(--pink); color: #fff; }
.program-card.match .pg-title { color: #fff; }
.program-card.match .pg-desc { color: rgba(255,255,255,0.7); }
.program-card.match::after {
  content: '↳ MATCH'; position: absolute; top: 18px; right: 18px;
  font-family: var(--mono); font-size: 9px; letter-spacing: 1.5px;
  color: var(--pink); text-transform: uppercase; font-weight: 600;
}
.programs-grid.has-active .program-card:not(.match) { opacity: 0.4; }

.cases-foot {
  margin-top: 32px; text-align: center;
  font-family: var(--mono); font-size: 10px; color: var(--ink40);
  letter-spacing: 1.5px; text-transform: uppercase;
}

@media (min-width: 720px) {
  .cases-section { padding: 96px 72px; }
  .cases-head h2 { font-size: 42px; }
  .cases-head p { font-size: 16px; }
  .cases-grid { grid-template-columns: repeat(3, 1fr); gap: 14px; }
  .cases-divider { margin: 64px 0 40px; }
  .programs-head h3 { font-size: 32px; }
  .programs-head p { font-size: 15px; }
  .programs-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
  .cases-foot { margin-top: 44px; }
}

/* ─── Method Comparison ──────────────────────────────────── */
.compare-section { padding: 40px 20px; background: var(--paper); }
.compare-h { max-width: 920px; margin: 0 auto; }
.compare-h h2 {
  font-family: var(--sans); font-weight: 500; font-size: 26px;
  color: var(--ink); margin: 12px 0 8px;
  letter-spacing: -0.4px; line-height: 1.25;
}
.compare-h h2 .first { color: var(--pink); }
.compare-h .sub { font-size: 15px; color: var(--ink60); margin: 0 0 36px; }
.compare-grid { display: flex; flex-direction: column; gap: 20px; max-width: 920px; margin: 0 auto; }
.method-card {
  background: var(--paper); border-radius: 22px; padding: 32px;
  box-shadow: inset 0 0 0 1px var(--ink10), 0 2px 8px rgba(15,23,42,0.04);
  position: relative;
}
.method-card.feat {
  box-shadow: inset 0 0 0 2px var(--pink), 0 20px 48px var(--pinkSoft);
}
.method-card .recommended {
  position: absolute; top: -12px; left: 28px;
  padding: 6px 14px; background: var(--pink); color: #fff;
  font-family: var(--mono); font-size: 10px; letter-spacing: 2px; font-weight: 600;
  text-transform: uppercase; border-radius: 999px;
}
.method-card .m-head { display: flex; align-items: center; gap: 12px; margin-bottom: 20px; }
.method-card .m-ic {
  width: 44px; height: 44px; border-radius: 12px;
  background: var(--paperWarm);
  display: flex; align-items: center; justify-content: center; font-size: 22px;
}
.method-card.feat .m-ic { background: var(--pinkSoft); }
.method-card .m-tag {
  font-family: var(--mono); font-size: 11px; letter-spacing: 2px;
  color: var(--ink60); text-transform: uppercase; font-weight: 500;
}
.method-card.feat .m-tag { color: var(--pink); }
.method-card .m-name {
  font-family: var(--sans); font-size: 22px; color: var(--ink);
  font-weight: 600; margin-top: 2px; letter-spacing: -0.3px;
}
.method-card .m-items { display: flex; flex-direction: column; gap: 12px; margin-bottom: 22px; }
.method-card .m-item { display: flex; gap: 12px; align-items: flex-start; }
.method-card .m-item .bullet {
  width: 18px; height: 18px; border-radius: 50%;
  background: var(--ink20); color: #fff; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 10px; font-weight: 700; margin-top: 2px;
}
.method-card.feat .m-item .bullet { background: var(--pink); }
.method-card .m-item .text { font-size: 14px; color: var(--ink80); line-height: 1.55; }
.method-card .m-quote {
  padding: 14px; border-radius: 12px; background: var(--paperWarm);
  font-family: var(--serif); font-style: italic; font-size: 14px;
  color: var(--ink60); line-height: 1.5;
}
.method-card.feat .m-quote { background: var(--pinkSoft); color: var(--pink); }

@media (min-width: 720px) {
  .compare-section { padding: 80px 72px; }
  .compare-h h2 { font-size: 36px; }
  .compare-grid { flex-direction: row; align-items: stretch; }
  .method-card { flex: 1; min-width: 0; }
}

/* ─── Lead Form (Dark) ───────────────────────────────────── */
.lead-section {
  padding: 48px 20px; background: var(--navyDeep); color: #fff;
  position: relative; overflow: hidden;
}
.lead-watermark {
  position: absolute; right: -40px; bottom: -120px;
  font-family: var(--display); font-weight: 700; font-style: normal;
  font-size: 320px; line-height: 0.85; letter-spacing: -6px;
  color: rgba(233,30,99,0.08); pointer-events: none; user-select: none;
}
.lead-inner { position: relative; z-index: 2; max-width: 560px; margin: 0 auto; }
.lead-section h2 {
  font-family: var(--sans); font-weight: 500; font-size: 30px;
  color: #fff; margin: 14px 0 14px;
  letter-spacing: -0.5px; line-height: 1.15;
}
.lead-section h2 .first { color: var(--pink); }
.lead-section .lead-sub {
  font-size: 15px; color: rgba(255,255,255,0.6);
  margin: 0 0 32px; line-height: 1.6;
}
.lead-fields { display: flex; flex-direction: column; gap: 14px; }
.lead-fields input::placeholder { color: var(--ink60); }
.lead-field-l {
  font-size: 12px; font-weight: 500; color: rgba(255,255,255,0.7);
  margin-bottom: 8px; display: block;
}
.lead-input, .lead-select {
  width: 100%; box-sizing: border-box;
  padding: 14px 16px; border-radius: 12px;
  background: rgba(255,255,255,0.06); color: #fff;
  border: 1px solid rgba(255,255,255,0.1); outline: none;
  font-size: 14px;
}
.lead-input::placeholder { color: rgba(255,255,255,0.4); }
.lead-select { appearance: none; -webkit-appearance: none; }
.lead-input:focus, .lead-select:focus { border-color: var(--pink); }

/* Lead form input fields on dark navy background (overrides) */
.lead-section .field-label {
  color: rgba(255,255,255,0.85);
}
.lead-section .field-label .opt {
  color: rgba(255,255,255,0.4);
}
.lead-section .segmented {
  background: rgba(255,255,255,0.06);
  padding: 4px;
}
.lead-section .segmented button {
  color: rgba(255,255,255,0.6);
}
.lead-section .segmented button.on {
  background: #fff; color: var(--ink);
  box-shadow: 0 4px 12px rgba(0,0,0,0.32);
}
.lead-section .field {
  background: rgba(255,255,255,0.06);
  border: 1.5px solid rgba(255,255,255,0.12);
}
.lead-section .field:focus-within { border-color: var(--pink); }
.lead-section .field input { color: #fff; }
.lead-section .field .suffix { color: rgba(255,255,255,0.6); }
.lead-section .prefill-hint {
  font-family: var(--mono); font-size: 10px; letter-spacing: 1.5px;
  color: rgba(255,255,255,0.4); text-transform: uppercase;
  text-align: center; margin-top: -6px;
}
.lead-section .prefill-hint.show { color: var(--pink); }

.lead-channels { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; }
.lead-channels button {
  padding: 14px 8px; border: none; border-radius: 12px;
  background: rgba(255,255,255,0.06); color: rgba(255,255,255,0.7);
  font-size: 13px; font-weight: 600;
}
.lead-channels button.on { color: #fff; }
.lead-channels button.on[data-c="whatsapp"] { background: var(--whatsapp); }
.lead-channels button.on[data-c="line"]     { background: var(--line); }
.lead-channels button.on[data-c="email"]    { background: var(--pink); }

.consent-row { display: flex; gap: 10px; align-items: flex-start; margin-top: 4px; }
.consent-row input { margin-top: 4px; accent-color: var(--pink); }
.consent-row span { font-size: 12px; color: rgba(255,255,255,0.6); line-height: 1.5; }

.lead-error {
  background: rgba(233,30,99,0.15); color: #ff8a9b;
  padding: 12px 14px; border-radius: 10px; font-size: 13px;
  display: none;
}
.lead-error.show { display: block; }

.lead-submit {
  margin-top: 10px; padding: 20px 24px;
  background: var(--pink); color: #fff;
  border: none; border-radius: 999px;
  font-size: 15px; font-weight: 600;
  display: flex; align-items: center; justify-content: center; gap: 10px;
  transition: background .15s;
}
.lead-submit:hover { background: var(--pinkHot); }
.lead-submit::after { content: '→'; }

.lead-or { display: flex; align-items: center; gap: 14px; margin: 8px 0; }
.lead-or .l { flex: 1; height: 1px; background: rgba(255,255,255,0.1); }
.lead-or .w {
  font-family: var(--mono); font-size: 10px; color: rgba(255,255,255,0.4); letter-spacing: 2px;
}

.chat-stack { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.chat-btn {
  padding: 14px 12px; background: transparent;
  border-radius: 999px; font-size: 13px; font-weight: 600;
  text-decoration: none; text-align: center;
}
.chat-btn.whatsapp { color: var(--whatsapp); border: 1.5px solid var(--whatsapp); }
.chat-btn.line     { color: var(--line);     border: 1.5px solid var(--line); }

/* Success state */
.lead-success { display: none; text-align: center; padding: 32px 20px; color: #fff; }
.lead-success.show { display: block; }
.lead-success .check {
  width: 56px; height: 56px; border-radius: 50%;
  background: var(--pink); color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 28px; margin-bottom: 14px;
}
.lead-success h3 {
  font-family: var(--sans); font-weight: 600; font-size: 22px;
  margin-bottom: 8px; letter-spacing: -0.3px;
}
.lead-success p { color: rgba(255,255,255,0.6); margin-bottom: 20px; }

@media (min-width: 720px) {
  .lead-section { padding: 96px 72px; }
  .lead-watermark { font-size: 520px; }
  .lead-section h2 { font-size: 44px; }
}

/* ─── Modal (Success Dialog) ─────────────────────────────── */
.modal-overlay {
  position: fixed; inset: 0; z-index: 100;
  background: rgba(11, 11, 12, 0.65);
  -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px);
  display: none;
  align-items: center; justify-content: center;
  padding: 20px;
  animation: guFade .25s ease both;
}
.modal-overlay.show { display: flex; }
@keyframes guFade { from { opacity: 0; } to { opacity: 1; } }

.modal-dialog {
  position: relative;
  background: var(--paper);
  border-radius: 24px;
  max-width: 440px; width: 100%;
  padding: 36px 28px 28px;
  text-align: center;
  box-shadow: 0 32px 64px rgba(0,0,0,0.32);
  animation: guPop .35s cubic-bezier(0.16,1,0.3,1) both;
  max-height: calc(100vh - 40px);
  overflow-y: auto;
}
@keyframes guPop {
  from { transform: scale(0.92) translateY(20px); opacity: 0; }
  to   { transform: scale(1) translateY(0); opacity: 1; }
}
.modal-close {
  position: absolute; top: 14px; right: 14px;
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--paperWarm); color: var(--ink60);
  border: none; cursor: pointer;
  font-size: 18px; line-height: 1; font-weight: 500;
  display: flex; align-items: center; justify-content: center;
  transition: all .15s ease;
}
.modal-close:hover { background: var(--ink10); color: var(--ink); }
.modal-check {
  width: 64px; height: 64px; border-radius: 50%;
  background: var(--pink); color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 32px; margin-bottom: 16px;
  box-shadow: 0 8px 20px rgba(233,30,99,0.32);
}
.modal-title {
  font-family: var(--sans); font-weight: 600; font-size: 22px;
  color: var(--ink); margin: 0 0 8px;
  letter-spacing: -0.3px;
}
.modal-body {
  font-size: 14px; color: var(--ink60); line-height: 1.6;
  margin: 0 0 24px;
}
.modal-cta {
  display: grid; grid-template-columns: 1fr 1fr; gap: 10px;
  margin-bottom: 16px;
}
.modal-cta .chat-btn {
  padding: 14px 12px; border-radius: 999px;
  font-size: 13px; font-weight: 600;
  text-decoration: none; text-align: center;
  background: transparent;
}
.modal-cta .chat-btn.whatsapp { color: var(--whatsapp); border: 1.5px solid var(--whatsapp); }
.modal-cta .chat-btn.line     { color: var(--line);     border: 1.5px solid var(--line); }
.modal-foot {
  font-family: var(--mono); font-size: 10px; color: var(--ink40);
  letter-spacing: 1.5px; text-transform: uppercase;
  padding-top: 14px; border-top: 1px solid var(--ink10);
}

@media (min-width: 720px) {
  .modal-dialog { padding: 44px 36px 32px; }
  .modal-title { font-size: 26px; }
}

/* Body scroll lock when modal open */
body.modal-open { overflow: hidden; }

footer {
  padding: 100px 0;
  background-color: #f2f2f2;
  line-height: normal;
  & div, dl, dt, dd, ul, ol, li, h1, h2, h3, p, img {
    margin: 0;
    padding: 0;
  }
  & a {
    text-decoration: none;
  }
  & ul, ol {
    list-style: none;
  }
  a, a:active, a:focus, a:visited {
    -webkit-tab-highlight-color: rgba(0, 0, 0, 0.1);
    color: var(--colour-lightblack);
  }
  & .row {
    max-width: 1280px;
    margin: 0 auto;
  }
  & .colwrap {
    display: flex;
    justify-content: space-between;
    & h1 {
      height: 40px;
      margin-bottom: 30px;
      opacity: 0.6;
      & img {
        width: 40px;
        height: auto;
        cursor: pointer;
      }
    }
    & p {
      font-size: clamp(11px, 1vw, 12px);
      color: var(--tertiary);
      margin-bottom: 10px;
      & a {
        color: var(--tertiary);
        &:hover {
          color: var(--primary);
        }
      }
    }
    & ul {
      & li {
        font-size: clamp(12px, 1vw, 12px);
        color: var(--tertiary);
        margin-bottom: 20px;
        cursor: pointer;
        &:hover {
          color: var(--primary);
        }
        &:first-child {
          font-weight: 500;
          font-size: clamp(14px, 1vw, 16px);
          color: #546b88;
        }
        & a {
          color: var(--tertiary);
          &:hover {
            color: var(--primary);
          }
        }
      }
    }
  }
}

@container body (max-width: 1279px) {
  .footer {
    padding: 0 30px;
  }
}

@container body (max-width: 855px) {
  footer {
    & .colwrap {
      display: block;
      & .col {
        margin-bottom: 70px;
        text-align: center;
        &:last-child {
          margin-bottom: 0;
        }
      }
    }
  }
}