/* ============================================================
   Withmarry Landing — style.css
   Dusty Rose — 로즈·모브 기반 톤(옐로우 베이지 지양). 디자인 토큰으로 전체 제어.
   섹션 순서: Reset → Token → Layout → Nav → Hero → How It Works
             → TTS Flow → 핵심 기능 → 세부 기능 → For Whom → Pricing → Closing → Footer
             → Reveal → Responsive
   ============================================================ */

/* ======================================================
   디자인 토큰
====================================================== */
:root {
  /* 색상 — Dusty Rose (파스텔 로즈, 표면·워시는 핑크 계열) */
  --color-bg:        #F3EBE8;
  --color-bg-alt:    #E9DDD9;
  --color-surface:   #FCF8F7;
  --color-wash:      #F1E4E1;
  --color-wash-deep: #E0CFCC;
  --color-ink:       #3A2F33;
  --color-ink-soft:  #8E7C78;
  --color-mute:      #AA9591;
  --color-line:      #DEC9C4;
  --color-gold:      #C9A39D;
  --color-gold-deep: #8F6E6A;
  --color-gold-soft: #EDDAD8;
  --color-kakao:     #FEE500;
  --color-kakao-ink: #181600;
  /* 가격 블록 — 랜딩 로즈 톤(머티리얼 레드 대신 더스트 로즈·딥 모브) */
  --color-pricing-red: #a64d58;
  --pricing-launch-cap-gradient: linear-gradient(90deg, #5a494f 0%, #3a2f33 100%);
  /* 특가 금액(14,900·9,900 등) — 진한 붉은·버건디 */
  --color-pricing-pink: #7a1f30;
  --color-pricing-pink-deep: #631a28;
  /* 할인 배지 — 로즈 골드 → 딥 버건디 로즈 */
  --color-pricing-badge-from: #d9aeb4;
  --color-pricing-badge-to:   #8a3d4a;
  --color-pricing-badge-border: rgba(106, 48, 58, 0.34);

  /* PART 1·2 — Warm Ivory Beige (핵심·세부 구성 블록) */
  --feat-warm-bg:      #F4EEEA;
  --feat-warm-ink:     #8B6F6A;
  --feat-warm-border:  #E7D9D2;
  --feat-warm-surface: #FFFCFA;
  /* PART 1·2 상단 알약 — Dusty Rose */
  --feat-pill-dusty-bg:     #EADDDD;
  --feat-pill-dusty-ink:    #7A5C5C;
  --feat-pill-dusty-border:   rgba(122, 92, 92, 0.46);

  /* 타이포: 본문·UI·카드 제목 = sans. 메인 헤드라인·큰 장식 숫자만 display 세리프 */
  --font-sans:    'Pretendard', -apple-system, BlinkMacSystemFont, 'Apple SD Gothic Neo', sans-serif;
  --font-display: 'Cormorant Garamond', 'Noto Serif KR', serif;

  /* 타입 스케일 — 모바일 기본 (--text-base는 ≥768px에서 16px로 상향) */
  --text-micro: 10px;
  --text-2xs:   11px;
  --text-xs:    12px;
  --text-sm:    13px;
  --text-md:    14px;
  --text-base:  15px;
  --text-lg:    16px;
  --text-xl:    18px;
  --leading-tight:   1.22;
  --leading-snug:    1.35;
  --leading-normal:  1.55;
  --leading-relaxed: 1.65;
  --leading-loose:   1.72;
  --leading-body:    1.63;
  /* UI 본문·라벨 */
  --tracking-tight:   -0.015em;
  /* 산세리프 카드·스텝 소제목 */
  --tracking-head:    -0.022em;
  /* Cormorant / Noto Serif KR 디스플레이 제목 */
  --tracking-display: -0.03em;
  /* 산세리프 굵기 스케일(랜딩 UI 통일) */
  --weight-sans-regular: 400;
  --weight-sans-medium: 500;
  --weight-sans-semibold: 600;
  --weight-sans-bold: 700;

  --space-section:        96px;
  --space-section-mobile: 52px;
  --container-max:        480px;

  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --dur:  0.6s;

  --shadow-soft: 0 10px 40px -10px rgba(56, 42, 46, 0.14);
  --shadow-gold: 0 8px 28px -8px rgba(194, 160, 155, 0.42);
}

/* ======================================================
   Reset
====================================================== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--font-sans);
  background: var(--color-bg);
  color: var(--color-ink);
  line-height: var(--leading-body);
  font-size: var(--text-base);
  letter-spacing: var(--tracking-tight);
  overflow-x: hidden;
  word-break: keep-all;
  overflow-wrap: break-word;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-optical-sizing: auto;
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }

/* ======================================================
   Layout
====================================================== */
.container {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 24px;
  width: 100%;
}
section {
  padding: var(--space-section-mobile) 0;
  position: relative;
}
@media (min-width: 768px) {
  section { padding: var(--space-section) 0; }
}

/* ======================================================
   공통 타이포
====================================================== */

/* 디스플레이·강조 타이틀 — 합자·커닝 */
.hero-title,
.how-title,
.feat-core-card-title,
.feat-det-name,
.pricing-tile-cap,
.closing-cta-title,
.whom-heading,
.whom-card-num {
  text-rendering: optimizeLegibility;
}

/* 시그니처 알약 — 랜딩 전역 통일 (세로 그라데이션·상단 하이라이트·안쪽 로즈 링·세리프) */
.wm-section-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin-bottom: 18px;
  padding: 12px 22px;
  border-radius: 999px;
  font-family: var(--font-sans);
  font-size: var(--text-md);
  font-weight: 600;
  letter-spacing: 0.02em;
  line-height: var(--leading-snug);
}
.wm-section-badge--signature {
  font-family: 'Noto Serif KR', 'Cormorant Garamond', Georgia, serif;
  font-weight: 600;
  font-style: normal;
  letter-spacing: 0.1em;
  color: #fef9f4;
  text-rendering: optimizeLegibility;
  font-size: clamp(13px, 2.85vw, 18px);
  padding: clamp(10px, 2.4vw, 14px) clamp(28px, 5vw, 44px);
  line-height: 1.2;
  background: linear-gradient(
    180deg,
    #6f5058 0%,
    #554040 36%,
    #3d2a30 68%,
    #2e2126 100%
  );
  border: 1px solid rgba(36, 24, 28, 0.55);
  box-shadow:
    inset 0 1px 0 rgba(255, 252, 250, 0.48),
    inset 0 -12px 24px -8px rgba(0, 0, 0, 0.2),
    inset 0 0 0 1px rgba(236, 212, 204, 0.42),
    0 14px 36px -16px rgba(38, 26, 30, 0.45),
    0 5px 14px -8px rgba(52, 34, 40, 0.28);
}
.wm-section-badge--signature .wm-section-badge__ic {
  filter: brightness(1.15);
}
.wm-section-badge__ic {
  font-size: var(--text-lg);
  line-height: 1;
  opacity: 0.92;
}

.flow-section-head {
  text-align: center;
}

/* ======================================================
   Nav
====================================================== */
.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  background: rgba(243, 235, 232, 0.9);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid transparent;
  transition: border-color 0.3s, background 0.3s;
}
.nav.scrolled { border-bottom-color: var(--color-line); }

.nav-inner {
  max-width: min(1200px, 100%);
  margin: 0 auto;
  min-height: 60px;
  padding: 10px 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
.nav-logo {
  display: flex;
  align-items: center;
  flex-shrink: 0;
}
.nav-logo-lockup {
  height: 42px;
  width: auto;
  max-width: min(42vw, 280px);
  display: block;
  object-fit: contain;
  object-position: left center;
}

.nav-quick {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 10px 22px;
  margin-left: auto;
  min-width: 0;
  flex: 1;
}
.nav-quick-link {
  font-size: var(--text-base);
  font-weight: 600;
  letter-spacing: var(--tracking-tight);
  color: var(--color-ink-soft);
  padding: 8px 6px;
  border-radius: 8px;
  white-space: nowrap;
  transition: color 0.2s ease, background 0.2s ease;
}
.nav-quick-link:hover {
  color: var(--color-gold-deep);
  background: rgba(194, 160, 155, 0.1);
}
.nav-quick-actions {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-left: 10px;
  padding-left: 18px;
  border-left: 1px solid rgba(194, 160, 155, 0.28);
}
.nav-quick-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 18px;
  font-size: var(--text-md);
  font-weight: 700;
  letter-spacing: var(--tracking-tight);
  border-radius: 999px;
  white-space: nowrap;
  transition: transform 0.2s var(--ease), box-shadow 0.2s ease, border-color 0.2s ease, background 0.2s ease;
}
.nav-quick-btn--ghost {
  border: 1px solid rgba(194, 160, 155, 0.42);
  background: rgba(252, 248, 247, 0.85);
  color: var(--color-ink);
}
.nav-quick-btn--ghost:hover {
  border-color: rgba(148, 112, 108, 0.55);
  background: #fff;
}
.nav-quick-btn--primary {
  color: #fffbfa;
  background: linear-gradient(145deg, #5a4148, #3a2c32);
  border: 1px solid rgba(56, 42, 46, 0.35);
  box-shadow: 0 4px 14px -8px rgba(56, 42, 46, 0.32);
}
.nav-quick-btn--primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 20px -10px rgba(56, 42, 46, 0.42);
}

@media (max-width: 900px) {
  .nav-quick {
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    -ms-overflow-style: none;
    padding-bottom: 2px;
    justify-content: flex-end;
    gap: 8px 16px;
  }
  .nav-quick::-webkit-scrollbar {
    display: none;
    width: 0;
    height: 0;
  }
  .nav-quick-link {
    font-size: var(--text-sm);
    padding: 7px 4px;
  }
  .nav-quick-btn {
    font-size: var(--text-sm);
    padding: 8px 14px;
  }
  .nav-quick-actions {
    margin-left: 6px;
    padding-left: 12px;
    gap: 10px;
    flex-shrink: 0;
  }
}
@media (max-width: 380px) {
  .nav-logo-lockup {
    max-width: min(56vw, 260px);
    height: 42px;
  }
}

/* 모바일 내비: 로고 · 문의하기 · 햄버거 + 드로어 */
.nav-mobile-bar {
  display: none;
}
.nav-menu-toggle {
  display: none;
}

@media (max-width: 767px) {
  .nav-inner {
    flex-wrap: wrap;
    align-items: center;
    row-gap: 0;
    column-gap: 12px;
    padding-top: 8px;
    padding-bottom: 8px;
  }
  .nav-logo-lockup {
    height: 46px;
    max-width: min(64vw, 300px);
  }
  .nav-mobile-bar {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-left: auto;
    flex-shrink: 0;
  }
  .nav-mobile-cta {
    padding: 8px 14px;
    font-size: var(--text-xs);
    font-weight: 700;
    min-height: 40px;
  }
  .nav-menu-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    padding: 0;
    border: 1px solid rgba(194, 160, 155, 0.45);
    border-radius: 12px;
    background: rgba(252, 248, 247, 0.95);
    color: var(--color-ink);
    cursor: pointer;
    transition: background 0.2s ease, border-color 0.2s ease;
  }
  .nav-menu-toggle:hover {
    background: #fff;
    border-color: rgba(148, 112, 108, 0.55);
  }
  .nav-menu-toggle:focus-visible {
    outline: 2px solid var(--color-gold-deep);
    outline-offset: 2px;
  }
  .nav-menu-toggle-bars {
    position: relative;
    width: 20px;
    height: 14px;
    flex-shrink: 0;
  }
  .nav-menu-bar {
    position: absolute;
    left: 0;
    right: 0;
    height: 2px;
    border-radius: 1px;
    background: var(--color-ink-soft);
    transition: transform 0.25s var(--ease), opacity 0.2s ease, top 0.25s var(--ease);
  }
  .nav-menu-bar:nth-child(1) {
    top: 0;
  }
  .nav-menu-bar:nth-child(2) {
    top: 6px;
  }
  .nav-menu-bar:nth-child(3) {
    top: 12px;
  }
  .nav.nav--menu-open .nav-menu-bar:nth-child(1) {
    top: 6px;
    transform: rotate(45deg);
  }
  .nav.nav--menu-open .nav-menu-bar:nth-child(2) {
    opacity: 0;
    transform: scaleX(0);
  }
  .nav.nav--menu-open .nav-menu-bar:nth-child(3) {
    top: 6px;
    transform: rotate(-45deg);
  }

  .nav-quick {
    order: 3;
    flex: 1 1 100%;
    width: 100%;
    max-width: 100%;
    margin: 0;
    margin-top: 8px;
    padding: 0 0 0;
    flex-direction: column;
    flex-wrap: nowrap;
    align-items: stretch;
    justify-content: flex-start;
    gap: 0;
    overflow: hidden;
    max-height: 0;
    border-top: 1px solid transparent;
    transition:
      max-height 0.38s var(--ease),
      padding 0.38s var(--ease),
      border-color 0.2s ease;
    -webkit-overflow-scrolling: touch;
  }
  .nav.nav--menu-open .nav-quick {
    max-height: min(380px, 72vh);
    padding: 10px 0 16px;
    overflow-y: auto;
    border-top-color: rgba(194, 160, 155, 0.22);
    gap: 2px;
    box-shadow: 0 14px 32px -18px rgba(56, 42, 46, 0.18);
  }
  .nav-quick-link {
    display: block;
    width: 100%;
    text-align: left;
    padding: 12px 12px;
    font-size: var(--text-md);
    border-radius: 10px;
    white-space: normal;
  }
  .nav-quick-actions {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
    margin: 10px 0 0;
    padding: 12px 0 0;
    border-left: none;
    border-top: 1px dashed rgba(194, 160, 155, 0.35);
  }
  .nav-quick-actions .nav-quick-btn {
    width: 100%;
    justify-content: center;
    padding: 12px 16px;
  }
  .nav-cta-inline {
    display: none;
  }
}

@media (max-width: 767px) and (prefers-reduced-motion: reduce) {
  .nav-quick {
    transition: none;
  }
  .nav-menu-bar {
    transition: none;
  }
}

body.nav-menu-open {
  overflow: hidden;
  touch-action: none;
}

@media (min-width: 768px) {
  body.nav-menu-open {
    overflow: auto;
    touch-action: auto;
  }
}

/* ======================================================
   Hero — 영상 풀스크린
====================================================== */
.hero {
  position: relative;
  min-height: 100vh;
  min-height: 100dvh;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 0;
  overflow: hidden;
  isolation: isolate;
  background: #000;
}

/* 배경 영상 */
.hero-video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
}

/* 어두운 그라디언트 오버레이 */
.hero-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.22) 0%,
    rgba(0, 0, 0, 0.38) 42%,
    rgba(0, 0, 0, 0.52) 72%,
    rgba(0, 0, 0, 0.62) 100%
  );
  pointer-events: none;
}
@media (max-width: 767px) {
  .hero-overlay {
    background: linear-gradient(
      180deg,
      rgba(0, 0, 0, 0.32) 0%,
      rgba(0, 0, 0, 0.48) 45%,
      rgba(0, 0, 0, 0.58) 78%,
      rgba(0, 0, 0, 0.68) 100%
    );
  }
}

/* 텍스트 콘텐츠 */
.hero-content {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0 24px;
  color: #fff;
}
.hero-mark {
  font-family: var(--font-sans);
  font-size: var(--text-2xs);
  letter-spacing: 0.42em;
  color: rgba(255,255,255,0.85);
  margin-bottom: 32px;
  text-transform: uppercase;
}
.hero-title {
  font-family: var(--font-display);
  font-size: clamp(44px, 10vw, 88px);
  line-height: var(--leading-tight);
  font-weight: 400;
  letter-spacing: var(--tracking-display);
  color: #fff;
  margin-bottom: 28px;
  text-shadow: 0 2px 30px rgba(0,0,0,0.3);
}
.hero-title .accent {
  font-style: italic;
  color: #d4567a;
}
.hero-sub {
  font-size: var(--text-md);
  line-height: var(--leading-loose);
  color: rgba(255,255,255,0.85);
  margin-bottom: 48px;
  text-shadow: 0 1px 20px rgba(0,0,0,0.3);
}
.hero-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 16px 32px;
  background: rgba(255,255,255,0.95);
  color: var(--color-ink);
  border-radius: 999px;
  font-size: var(--text-md);
  font-weight: 600;
  letter-spacing: 0.02em;
  transition: all 0.3s var(--ease);
  box-shadow: 0 8px 24px -8px rgba(0,0,0,0.25);
}
.hero-cta:hover {
  background: #fff;
  transform: translateY(-2px);
  box-shadow: 0 12px 30px -8px rgba(0,0,0,0.35);
}

@media (min-width: 1024px) {
  .hero-title { font-size: clamp(72px, 7.5vw, 112px); line-height: 1.02; }
  .hero-sub   { font-size: var(--text-lg); }
  .hero-cta   { padding: 20px 40px; font-size: var(--text-base); }
}

/* ======================================================
   How It Works — 폰 목업 + 샘플
====================================================== */
.howitworks {
  position: relative;
  z-index: 0;
  margin-top: 0;
  padding-top: var(--space-section-mobile);
  padding-bottom: var(--space-section-mobile);
  border-radius: 0;
  background: linear-gradient(180deg, var(--color-bg) 0%, var(--color-bg-alt) 100%);
  text-align: center;
  box-shadow: none;
}
.how-title {
  font-family: var(--font-display);
  font-size: clamp(24px, 5.5vw, 36px);
  font-weight: 500;
  letter-spacing: var(--tracking-display);
  color: var(--color-ink);
  margin-bottom: 18px;
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.5em 0.65em;
}
.how-title-wordmark {
  height: clamp(48px, 12vw, 80px);
  width: auto;
  max-width: 100%;
  display: block;
  object-fit: contain;
}
.how-title-suffix {
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  color: inherit;
}
.how-title-lockup {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  text-align: center;
  width: 100%;
  max-width: 22rem;
}
.how-title-tagline {
  display: block;
  font-family: var(--font-sans);
  font-size: clamp(14px, 3.6vw, 18px);
  font-weight: 500;
  line-height: var(--leading-snug);
  letter-spacing: var(--tracking-tight);
  color: var(--color-ink);
}

/* 스테이지: 폰 + 샘플 CTA */
.how-stage {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 22px;
}

/* 폰 그룹 — 세로 스택 */
.how-phones {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
}
.how-phones-row {
  display: flex;
  flex-wrap: nowrap;
  align-items: flex-end;
  justify-content: center;
  gap: 0;
  padding: 8px 0 4px;
  perspective: 900px;
}

/* 폰 목업 */
.how-phone {
  flex-shrink: 0;
  width: min(40vw, 168px);
  height: auto;
  aspect-ratio: 9 / 18;
  background: linear-gradient(135deg, var(--color-surface), var(--color-bg-alt));
  border-radius: 28px;
  border: 1px solid var(--color-line);
  box-shadow: var(--shadow-soft);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  transform-origin: 50% 92%;
  transition: transform 0.35s var(--ease);
}
.how-phones-row .how-phone:nth-child(1) {
  transform: rotate(-7deg) translate(4px, 8px);
  z-index: 2;
}
.how-phones-row .how-phone:nth-child(2) {
  transform: rotate(7deg) translate(-6px, 2px);
  z-index: 1;
  margin-left: min(-18px, -4vw);
}
@media (prefers-reduced-motion: reduce) {
  .how-phones-row .how-phone:nth-child(1),
  .how-phones-row .how-phone:nth-child(2) {
    transform: none;
  }
  .how-phones-row .how-phone:nth-child(2) {
    margin-left: 10px;
  }
}
.how-phone::before {
  content: '';
  position: absolute;
  top: 12px; left: 50%;
  transform: translateX(-50%);
  width: 60px; height: 5px;
  background: var(--color-line);
  border-radius: 3px;
  z-index: 1;
}
.how-phone-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* 샘플 버튼 */
.how-sample-cta { text-align: center; }
#how-samples {
  scroll-margin-top: 80px;
}
#tts-model,
#tts-sig-before,
#feat-flow,
#pricing,
#for-whom,
#cta {
  scroll-margin-top: 72px;
}
.how-sample-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 28px;
  border: 1.5px solid var(--color-gold);
  color: var(--color-gold-deep);
  border-radius: 999px;
  font-size: var(--text-md);
  font-weight: 600;
  letter-spacing: 0.02em;
  transition: all 0.3s var(--ease);
}
.how-sample-btn:hover {
  background: var(--color-gold);
  color: white;
  transform: translateY(-2px);
  box-shadow: var(--shadow-gold);
}

@media (min-width: 768px) {
  .howitworks {
    margin-top: 0;
    padding-top: var(--space-section);
    padding-bottom: var(--space-section);
  }
}

@media (min-width: 1024px) {
  .howitworks {
    margin-top: 0;
    padding: var(--space-section) 0;
  }
  .how-title { font-size: clamp(36px, 3.8vw, 44px); margin-bottom: 20px; }
  .how-title-wordmark { height: clamp(56px, 6vw, 88px); }
  .how-title-lockup { max-width: 28rem; gap: 12px; }
  .how-title-tagline { font-size: clamp(16px, 1.8vw, 19px); }
  .how-stage {
    flex-direction: row;
    justify-content: center;
    align-items: center;
    gap: 32px;
    text-align: center;
  }
  .how-phones { flex-shrink: 0; gap: 24px; }
  .how-phone {
    width: 220px;
    height: 440px;
    aspect-ratio: unset;
  }
  .how-phones-row .how-phone:nth-child(1) {
    transform: rotate(-6deg) translate(10px, 14px);
  }
  .how-phones-row .how-phone:nth-child(2) {
    transform: rotate(6deg) translate(-12px, 6px);
    margin-left: -28px;
  }
}

/* ======================================================
   TTS Flow — Upload / Synthesize / Deliver + 타입라이터
====================================================== */
.tts-model {
  --tts-board: #ebe3e0;
  --tts-card: var(--color-surface);
  --tts-conn-gold: var(--color-gold);
  background: linear-gradient(180deg, var(--tts-board) 0%, var(--color-bg) 72%);
  padding: var(--space-section-mobile) 0;
  overflow: hidden;
}
.tts-model-head {
  text-align: center;
  margin-bottom: clamp(18px, 4vw, 28px);
}
.tts-model-sub {
  margin: clamp(12px, 2.5vw, 18px) auto 0;
  max-width: 34em;
  font-family: var(--font-sans);
  font-size: clamp(var(--text-lg), 3.35vw, 20px);
  font-weight: 600;
  line-height: var(--leading-relaxed);
  letter-spacing: var(--tracking-tight);
  color: #2a2226;
}
.tts-model-note {
  display: inline-block;
  margin: clamp(10px, 2.2vw, 14px) auto 0;
  padding: 7px 16px;
  max-width: min(100%, 34em);
  box-sizing: border-box;
  font-family: var(--font-sans);
  font-size: clamp(var(--text-xs), 2.2vw, var(--text-md));
  font-weight: 600;
  letter-spacing: 0.03em;
  line-height: var(--leading-snug);
  color: var(--color-gold-deep);
  text-align: center;
  background: rgba(252, 248, 247, 0.85);
  border: 1px solid rgba(222, 201, 196, 0.55);
  border-radius: 999px;
}

.tts-pipeline-board {
  margin-top: 20px;
  padding: clamp(20px, 4vw, 36px) clamp(16px, 3vw, 28px);
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(252, 248, 247, 0.97) 0%, rgba(233, 218, 214, 0.92) 100%);
  border: 2px solid rgba(120, 88, 90, 0.38);
  box-shadow:
    0 0 0 1px rgba(194, 160, 155, 0.22),
    0 16px 48px -28px rgba(56, 42, 46, 0.14);
}

/* 시그니처 — BEFORE → AFTER 비교 (중간 단계 없음) */
.tts-sig-layout {
  display: grid;
  gap: clamp(12px, 2.5vw, 20px);
  grid-template-columns: 1fr;
  align-items: stretch;
  width: 100%;
}
.tts-sig-arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(194, 160, 155, 0.88);
  flex-shrink: 0;
  padding: 4px 0;
}
.tts-sig-arrow svg {
  display: block;
  filter: drop-shadow(0 2px 6px rgba(56, 42, 46, 0.08));
}
.tts-sig-card--before.tts-io-card {
  padding: 16px 14px 14px;
  box-shadow: 0 8px 28px -18px rgba(56, 42, 46, 0.1);
}
.tts-sig-card--before .tts-sig-title {
  font-size: var(--text-base);
  margin-bottom: 10px;
}
.tts-sig-card--before .tts-input1-panel {
  margin-top: 0;
  padding: 12px 12px 12px;
}
.tts-sig-card--before .tts-sig-listen-hint {
  text-align: center;
}
.tts-sig-card--before .tts-input1-transcript {
  order: -1;
  display: inline-flex;
  align-self: center;
  align-items: baseline;
  gap: 2px;
  max-width: 100%;
  margin: 0 auto 8px;
  padding: 0 2px 8px;
  border-top: none;
  border-bottom: 1px solid rgba(222, 201, 196, 0.45);
  box-sizing: border-box;
  font-size: clamp(14px, 3.6vw, 15px);
}
.tts-sig-card--before .tts-input1-transcript-text {
  flex: 0 1 auto;
  max-width: min(100%, 22rem);
  text-align: left;
}
.tts-sig-card--before .tts-input1-open-quote {
  margin-top: 0;
  line-height: 1.2;
}
.tts-sig-card--before .tts-sig-foot {
  margin-top: 10px;
  font-style: normal;
  font-size: var(--text-2xs);
  font-weight: 600;
  color: var(--color-mute);
}
.tts-sig-card--result .tts-sig-foot {
  margin-top: 12px;
  font-style: normal;
  font-size: var(--text-2xs);
  font-weight: 600;
  color: var(--color-mute);
  line-height: var(--leading-snug);
}
.tts-sig-main {
  min-width: 0;
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
.tts-sig-main .tts-sig-card--result {
  width: 100%;
  max-width: min(520px, 100%);
}
.tts-sig-card {
  border-radius: 18px;
  padding: 18px 16px 16px;
  text-align: left;
  min-width: 0;
  min-height: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.tts-sig-card.tts-io-card {
  padding: 18px 16px 14px;
}
.tts-sig-title {
  font-family: var(--font-sans);
  font-size: var(--text-lg);
  font-weight: 700;
  letter-spacing: var(--tracking-head);
  color: var(--color-ink);
  margin: 0 0 14px;
  line-height: var(--leading-snug);
}
.tts-sig-listen-hint {
  margin: 0 0 10px;
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--color-gold-deep);
  letter-spacing: var(--tracking-tight);
}
.tts-sig-listen-hint--panel {
  margin: 0 0 8px;
}
.tts-sig-listen-hint .tts-player-hint-idle[hidden],
.tts-sig-listen-hint .tts-player-hint-playing[hidden] {
  display: none !important;
}
.tts-sig-foot {
  margin: 12px 0 0;
  font-size: var(--text-xs);
  font-style: italic;
  color: var(--color-mute);
  line-height: var(--leading-snug);
}

/* 결과 카드 — RESULT 배지·테두리·그림자 강조 */
.tts-sig-result-badge {
  margin: 0 auto 10px;
  padding: 6px 18px;
  width: fit-content;
  font-family: var(--font-sans);
  font-size: var(--text-micro);
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(252, 248, 247, 0.98);
  background: linear-gradient(180deg, #5a4148 0%, #3a2c32 100%);
  border-radius: 999px;
  box-shadow: 0 4px 14px -6px rgba(56, 42, 46, 0.35);
}
.tts-sig-result-badge.tts-sig-result-badge--before {
  margin: 0 auto 10px;
  color: var(--feat-pill-dusty-ink);
  background: linear-gradient(180deg, var(--color-wash) 0%, var(--color-gold-soft) 100%);
  border: 1px solid var(--feat-pill-dusty-border);
  box-shadow: 0 2px 12px -6px rgba(56, 42, 46, 0.12);
}
.tts-sig-card--result {
  position: relative;
  z-index: 1;
}
.tts-sig-card--result .tts-sig-title {
  font-size: clamp(16px, 2.1vw, 18px);
}

@media (max-width: 899px) {
  .tts-sig-layout {
    gap: 10px;
  }
  /* 세로 스택: BEFORE → 아래 화살표 → AFTER */
  .tts-sig-arrow {
    display: flex;
    padding: 2px 0 4px;
  }
  .tts-sig-arrow svg {
    transform: rotate(90deg);
    width: 24px;
    height: 24px;
  }
  .tts-sig-card--before.tts-io-card {
    width: min(100%, 19.5rem);
    margin-left: auto;
    margin-right: auto;
    padding: 10px 9px 9px;
    border-radius: 14px;
    box-shadow: 0 6px 22px -16px rgba(56, 42, 46, 0.09);
  }
  .tts-sig-card--before .tts-sig-title {
    font-size: var(--text-sm);
    margin-bottom: 8px;
  }
  .tts-sig-card--before .tts-input1-transcript-text {
    max-width: 100%;
  }
  .tts-sig-card--before .tts-input1-panel {
    padding: 9px 10px 10px;
  }
  .tts-sig-card--before .tts-sig-listen-hint {
    margin-bottom: 7px;
    font-size: 11px;
  }
  .tts-sig-card--before .tts-sig-foot {
    margin-top: 8px;
    font-size: 10px;
  }
  .tts-sig-card--result .tts-sig-foot {
    margin-top: 10px;
    font-size: 10px;
  }
}

@media (min-width: 900px) {
  .tts-sig-layout {
    grid-template-columns: minmax(200px, 0.88fr) 52px minmax(0, 1.18fr);
    align-items: center;
    gap: clamp(8px, 1.5vw, 18px);
  }
}
.tts-sig-cta {
  margin-top: 22px;
  padding: 14px 18px;
  border-radius: 999px;
  background: linear-gradient(180deg, #5a4148 0%, #3a2c32 100%);
  color: rgba(252, 248, 247, 0.96);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
  text-align: left;
  box-shadow: 0 8px 28px -12px rgba(56, 42, 46, 0.32);
}
.tts-sig-cta-ic {
  flex-shrink: 0;
  display: flex;
  color: rgba(252, 248, 247, 0.95);
}
.tts-sig-cta-text {
  margin: 0;
  font-size: var(--text-sm);
  line-height: var(--leading-normal);
  font-weight: 500;
  letter-spacing: var(--tracking-tight);
  max-width: 36em;
}

@media (max-width: 899px) {
  .tts-sig-cta {
    margin-top: 18px;
    padding: 13px 16px;
    text-align: center;
    justify-content: center;
  }
  .tts-sig-cta-text {
    text-align: center;
    font-size: var(--text-xs);
  }
}

.tts-player-inner-row {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
}
.tts-player--out {
  flex-direction: column;
  align-items: stretch;
}
.tts-player--out .tts-player-inner-row {
  align-items: center;
}

.tts-visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* 스크롤 스태거 */
.tts-model .tts-del-0.reveal.in { transition-delay: 0s; }
.tts-model .tts-del-1.reveal.in { transition-delay: 0.12s; }
.tts-model .tts-del-3.reveal.in { transition-delay: 0.44s; }

.tts-io-card {
  background: var(--tts-card);
  border: 1px solid rgba(222, 201, 196, 0.65);
  border-radius: 18px;
  padding: 18px 18px 16px;
  text-align: left;
  box-shadow: 0 10px 32px -16px rgba(56, 42, 46, 0.1);
  transition: transform 0.35s var(--ease), box-shadow 0.35s var(--ease), border-color 0.3s var(--ease);
}
.tts-io-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 18px 44px -14px rgba(56, 42, 46, 0.12);
  border-color: rgba(194, 160, 155, 0.4);
}
.tts-io-card--out {
  flex: 1;
  display: flex;
  flex-direction: column;
}
.tts-io-card.tts-sig-card--result {
  border-width: 2px;
  border-color: rgba(78, 60, 58, 0.48);
  box-shadow:
    0 0 0 1px rgba(252, 246, 244, 0.7) inset,
    0 18px 48px -22px rgba(56, 42, 46, 0.22),
    0 28px 64px -28px rgba(78, 60, 58, 0.18);
}
.tts-io-card.tts-sig-card--result:hover {
  transform: translateY(-4px);
  border-color: rgba(78, 60, 58, 0.55);
  box-shadow:
    0 0 0 1px rgba(252, 246, 244, 0.7) inset,
    0 22px 56px -20px rgba(56, 42, 46, 0.26),
    0 32px 72px -26px rgba(78, 60, 58, 0.22);
}

/* INPUT 1 — 플레이어 + 파형 + 시간 + 대본 한 박스 */
.tts-input1-panel {
  display: flex;
  flex-direction: column;
  border-radius: 16px;
  padding: 16px 16px 14px;
  background: rgba(252, 248, 247, 0.95);
  border: 1px solid rgba(222, 201, 196, 0.55);
  box-shadow: 0 8px 28px -18px rgba(56, 42, 46, 0.08);
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
}
.tts-io-card.tts-audio-on .tts-input1-panel {
  border-color: rgba(194, 160, 155, 0.4);
  box-shadow: 0 10px 32px -14px rgba(194, 160, 155, 0.15);
}
.tts-sig-card--before.reveal.in .tts-input1-panel {
  animation: tts-input1-panel-in 0.72s var(--ease) 0.16s both;
}
@keyframes tts-input1-panel-in {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}
.tts-input1-inner-row {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  margin-bottom: 12px;
}
.tts-input1-body {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  align-items: stretch;
}
.tts-input1-play {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  box-shadow: 0 6px 16px -6px rgba(148, 112, 108, 0.45);
}
.tts-input1-body .tts-input1-wave {
  height: 28px;
  margin-bottom: 6px;
}
.tts-input1-wave {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 3px;
  padding: 0 2px;
}
.tts-input1-wave span {
  flex: 1;
  max-width: 5px;
  min-height: 22%;
  border-radius: 2px;
  background: rgba(194, 160, 155, 0.22);
  transform-origin: center bottom;
  transition: background 0.12s ease, transform 0.15s ease;
}
.tts-input1-wave span:nth-child(odd) { min-height: 38%; }
.tts-input1-wave span:nth-child(3n) { min-height: 55%; }
.tts-input1-wave span:nth-child(5n) { min-height: 72%; }
.tts-input1-wave span:nth-child(7n) { min-height: 48%; }
.tts-input1-wave span.tts-bar--past {
  background: linear-gradient(180deg, var(--color-gold), var(--color-gold-deep));
  box-shadow: 0 0 0 1px rgba(194, 160, 155, 0.15);
}
.tts-io-card.tts-audio-on .tts-input1-wave span {
  animation: tts-input1-bar-idle 1.1s ease-in-out infinite;
}
.tts-io-card.tts-audio-on .tts-input1-wave span.tts-bar--past {
  animation-duration: 0.75s;
}
@keyframes tts-input1-bar-idle {
  0%, 100% { transform: scaleY(0.92); }
  50% { transform: scaleY(1); }
}
.tts-input1-time {
  width: 100%;
  font-size: var(--text-2xs);
  font-variant-numeric: tabular-nums;
  font-weight: 500;
  color: var(--color-ink);
  letter-spacing: 0.02em;
  text-align: left;
  line-height: 1.35;
}
.tts-input1-vol {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.tts-input1-transcript {
  display: flex;
  align-items: flex-start;
  gap: 4px;
  padding-top: 2px;
  border-top: 1px solid rgba(222, 201, 196, 0.45);
}
.tts-input1-open-quote {
  flex-shrink: 0;
  font-family: var(--font-sans);
  font-size: 1.05em;
  font-weight: 500;
  font-style: italic;
  line-height: 1.15;
  color: var(--color-gold-deep);
  margin-top: 1px;
}
.tts-input1-transcript-text .tts-input1-close-quote {
  display: inline;
  font-family: var(--font-sans);
  font-size: 1.05em;
  font-weight: 500;
  font-style: italic;
  line-height: 1;
  color: var(--color-gold-deep);
  margin-left: 2px;
  vertical-align: -0.08em;
  white-space: nowrap;
}
.tts-input1-transcript-text {
  margin: 0;
  flex: 1;
  font-family: var(--font-sans);
  font-size: 1em;
  font-style: italic;
  line-height: var(--leading-loose);
  font-weight: 400;
  color: var(--color-ink);
  letter-spacing: var(--tracking-tight);
}

.tts-out-type-box {
  position: relative;
  margin: 0 0 14px;
  padding: 16px 16px 14px;
  border-radius: 14px;
  background: rgba(252, 248, 247, 0.92);
  border: 1px solid rgba(222, 201, 196, 0.55);
  display: flex;
  justify-content: center;
}
.tts-out-quote-static {
  display: inline-flex;
  align-items: flex-start;
  gap: 2px;
  max-width: 100%;
  font-size: clamp(14px, 3.6vw, 15px);
}
.tts-out-quote-static .tts-input1-open-quote {
  margin-top: 0;
  line-height: 1.2;
  flex-shrink: 0;
}
.tts-out-quote-static__body {
  flex: 0 1 auto;
  min-width: 0;
  max-width: min(100%, 26rem);
  text-align: left;
}
.tts-out-quote-static__body .tts-out-sample-line {
  margin: 0 0 8px;
}
.tts-out-quote-static__body .tts-out-sample-line:last-child {
  margin-bottom: 0;
}
.tts-out-quote-static__body .tts-input1-close-quote {
  display: inline;
  font-family: var(--font-sans);
  font-size: 1.05em;
  font-weight: 500;
  font-style: italic;
  line-height: 1;
  color: var(--color-gold-deep);
  margin-left: 2px;
  white-space: nowrap;
  vertical-align: -0.08em;
}
.tts-out-sample-line {
  margin: 0 0 10px;
  font-family: var(--font-sans);
  font-size: 1em;
  font-style: italic;
  line-height: var(--leading-loose);
  letter-spacing: var(--tracking-tight);
  color: var(--color-ink);
}
.tts-out-sample-line:last-child {
  margin-bottom: 0;
}

.tts-player {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px;
  border-radius: 14px;
  background: rgba(252, 248, 247, 0.92);
  border: 1px solid rgba(222, 201, 196, 0.65);
  margin-top: 4px;
}
.tts-player--out { margin-top: auto; }
.tts-sig-card--3 .tts-player--out {
  margin-top: 12px;
}
.tts-player-btn {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: none;
  display: grid;
  place-items: center;
  color: var(--color-surface);
  background: linear-gradient(145deg, var(--color-gold), var(--color-gold-deep));
  cursor: pointer;
  transition: opacity 0.25s var(--ease), transform 0.25s var(--ease);
}
.tts-player-btn--lg {
  width: 48px;
  height: 48px;
}
.tts-player-btn > svg { grid-area: 1 / 1; }
.tts-player-btn > svg[hidden] {
  display: none !important;
}
.tts-player-btn > svg:not([hidden]) {
  display: block;
}
.tts-player-btn:hover:not(:disabled) {
  transform: scale(1.04);
  opacity: 1;
}
.tts-player-btn:disabled {
  cursor: not-allowed;
  opacity: 0.42;
  transform: none;
}
.tts-player-body { flex: 1; min-width: 0; }
.tts-player .tts-input1-wave {
  height: 28px;
  margin-bottom: 6px;
}
.tts-player-bar {
  height: 3px;
  border-radius: 2px;
  background: rgba(56, 42, 46, 0.08);
  overflow: hidden;
  margin-bottom: 4px;
}
.tts-player-progress {
  display: block;
  width: 0%;
  height: 100%;
  min-width: 0;
  border-radius: 2px;
  background: linear-gradient(90deg, var(--color-gold), rgba(160, 128, 126, 0.85));
  transition: width 0.12s linear;
}
.tts-player-time {
  font-size: var(--text-2xs);
  font-variant-numeric: tabular-nums;
  color: var(--color-mute);
  letter-spacing: 0.02em;
}
.tts-player-vol { flex-shrink: 0; color: var(--color-mute); opacity: 0.75; }
.tts-player--error .tts-player-time {
  font-size: var(--text-micro);
  letter-spacing: var(--tracking-tight);
  color: var(--color-mute);
}

/* 결과 카드 전용 다크 플레이어 (.tts-player 기본 스타일 이후) */
.tts-player.tts-player--out.tts-player--out-hero {
  margin-top: 12px;
  padding: 14px 14px 12px;
  background: linear-gradient(180deg, #5a4148 0%, #3a2c32 100%);
  border: 1px solid rgba(56, 42, 46, 0.2);
  box-shadow: 0 10px 28px -14px rgba(56, 42, 46, 0.35);
}
.tts-player--out-hero .tts-sig-listen-hint--panel {
  color: rgba(252, 248, 247, 0.88);
}
.tts-player-hero-label {
  font-weight: 700;
  letter-spacing: -0.03em;
}
.tts-player--out-hero .tts-player-time {
  color: rgba(252, 248, 247, 0.72);
}
.tts-player--out-hero .tts-player-bar {
  background: rgba(252, 248, 247, 0.14);
}
.tts-player--out-hero .tts-player-progress {
  background: linear-gradient(90deg, var(--color-gold-soft), rgba(252, 246, 244, 0.95));
}
.tts-player--out-hero .tts-input1-wave span:not(.tts-bar--past) {
  background: linear-gradient(180deg, rgba(237, 218, 214, 0.95), rgba(194, 160, 155, 0.75));
}
.tts-player--out-hero .tts-player-vol {
  color: rgba(252, 248, 247, 0.55);
}
.tts-player--out-hero .tts-player-btn.tts-player-btn--lg {
  background: linear-gradient(145deg, var(--color-wash) 0%, var(--color-wash-deep) 100%);
  color: var(--color-ink);
  box-shadow: 0 6px 18px -8px rgba(56, 42, 46, 0.35);
}

@media (min-width: 1024px) {
  .tts-model { padding: var(--space-section) 0; }
}

@media (prefers-reduced-motion: reduce) {
  .tts-model .tts-del-0.reveal.in,
  .tts-model .tts-del-1.reveal.in,
  .tts-model .tts-del-3.reveal.in { transition-delay: 0s !important; }
  .tts-player-progress { transition: none !important; }
  .tts-sig-card--before.reveal.in .tts-input1-panel {
    animation: none !important;
    opacity: 1;
    transform: none;
  }
  .tts-io-card.tts-audio-on .tts-input1-wave span {
    animation: none !important;
  }
  .pricing-mock-caret {
    animation: none !important;
    opacity: 0 !important;
  }
}

/* ======================================================
   Closing — HOW IT WORKS + 하단 문의 카드
====================================================== */
.closing-flow {
  text-align: center;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(237, 218, 214, 0.55) 0%, transparent 55%),
    var(--color-bg);
  padding: clamp(56px, 10vw, 100px) 0 clamp(48px, 8vw, 72px);
}
.container--closing {
  max-width: min(920px, 100%);
}
.closing-head {
  margin-bottom: clamp(36px, 6vw, 56px);
}
.closing-badge.wm-section-badge {
  margin-top: 0;
  margin-bottom: clamp(16px, 3vw, 22px);
}
.closing-lead {
  margin: clamp(6px, 1.5vw, 12px) auto clamp(26px, 5vw, 40px);
  max-width: min(100%, 36em);
  padding: 0 clamp(12px, 3vw, 20px);
  box-sizing: border-box;
  text-align: center;
  font-family: var(--font-sans);
  font-size: clamp(var(--text-base), 2.5vw, var(--text-lg));
  font-weight: 500;
  line-height: var(--leading-relaxed);
  letter-spacing: var(--tracking-tight);
  color: var(--color-ink-soft);
}

/* 가로 5단계 + 중앙 연결선 */
.closing-steps-scroll {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin: 0 -24px;
  padding: 0 24px 8px;
  scroll-snap-type: x proximity;
  scrollbar-width: thin;
}
.closing-steps {
  list-style: none;
  margin: 0 auto;
  padding: 12px 0 28px;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 8px;
  position: relative;
  min-width: min(860px, 100%);
}
.closing-steps::before {
  content: '';
  position: absolute;
  left: 10%;
  right: 10%;
  top: 40px;
  height: 1px;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(194, 160, 155, 0.35) 8%,
    rgba(194, 160, 155, 0.35) 92%,
    transparent
  );
  z-index: 0;
  pointer-events: none;
}
.closing-step {
  position: relative;
  z-index: 1;
  flex: 1 1 0;
  min-width: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  scroll-snap-align: center;
  padding: 0 4px;
}
.closing-step-icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  margin-bottom: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-bg);
  border: 1.5px solid rgba(222, 201, 196, 0.95);
  color: var(--color-gold-deep);
  box-shadow: 0 0 0 4px var(--color-bg);
}
.closing-step-kicker {
  font-family: var(--font-sans);
  font-size: var(--text-micro);
  font-weight: 600;
  letter-spacing: 0.1em;
  color: var(--color-gold-deep);
  text-transform: uppercase;
  margin-bottom: 6px;
}
.closing-step-name {
  font-family: var(--font-display);
  font-size: clamp(14px, 2.2vw, 17px);
  font-weight: 600;
  color: var(--color-ink);
  line-height: 1.3;
  margin-bottom: 6px;
}
.closing-step-desc {
  font-family: var(--font-sans);
  font-size: var(--text-2xs);
  font-weight: var(--weight-sans-regular);
  letter-spacing: var(--tracking-tight);
  line-height: var(--leading-normal);
  color: var(--color-mute);
}
.closing-step-body {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
  min-width: 0;
}

.closing-cta-card {
  margin-top: clamp(28px, 5vw, 44px);
  background: #fff;
  border-radius: 20px;
  padding: clamp(28px, 5vw, 40px) clamp(22px, 4vw, 36px);
  box-shadow: 0 18px 48px -24px rgba(56, 42, 46, 0.18);
  border: 1px solid rgba(222, 201, 196, 0.35);
}
/* 클로징 CTA — 영문 브랜드는 네비·HOW·푸터와 동일 로고 PNG, 한글만 세리프 */
.closing-cta-title {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.38em 0.55em;
  font-size: clamp(24px, 4.8vw, 32px);
  color: var(--color-ink);
  margin-bottom: 10px;
  text-align: center;
}
.closing-cta-wordmark {
  height: clamp(30px, 5.2vw, 46px);
  width: auto;
  max-width: min(200px, 56vw);
  object-fit: contain;
  display: block;
  flex-shrink: 0;
}
.closing-cta-title-ko {
  font-family: 'Noto Serif KR', 'Cormorant Garamond', Georgia, serif;
  font-weight: 600;
  letter-spacing: -0.022em;
  line-height: var(--leading-tight);
  font-style: normal;
}
.closing-cta-lead {
  font-family: var(--font-sans);
  font-size: var(--text-md);
  font-weight: var(--weight-sans-regular);
  letter-spacing: var(--tracking-tight);
  color: var(--color-ink-soft);
  line-height: var(--leading-relaxed);
  margin-bottom: 24px;
}
.closing-cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: center;
  align-items: center;
}
.closing-cta-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 48px;
  padding: 0 22px;
  border-radius: 12px;
  font-family: var(--font-sans);
  font-size: var(--text-md);
  font-weight: 600;
  color: var(--color-ink);
  background: #fff;
  border: 1px solid rgba(56, 42, 46, 0.12);
  transition: border-color 0.2s var(--ease), transform 0.2s var(--ease), box-shadow 0.2s var(--ease);
}
.closing-cta-btn:hover {
  border-color: rgba(194, 160, 155, 0.55);
  box-shadow: 0 8px 24px -12px rgba(56, 42, 46, 0.12);
  transform: translateY(-1px);
}

/* 맨 아래 카카오 상담 — 시각적 강조 */
.closing-cta-btn--kakao {
  min-height: 54px;
  padding: 0 28px;
  font-size: var(--text-base);
  font-weight: 700;
  letter-spacing: var(--tracking-tight);
  border-width: 1px;
  border-color: rgba(194, 160, 155, 0.55);
  background: linear-gradient(180deg, #ffffff 0%, var(--color-surface) 52%, var(--color-wash) 100%);
  box-shadow:
    0 0 0 1px rgba(252, 248, 247, 0.95) inset,
    0 12px 36px -16px rgba(188, 110, 105, 0.38),
    0 6px 20px -12px rgba(56, 42, 46, 0.1),
    0 0 0 2px rgba(178, 72, 72, 0.34);
}
.closing-cta-btn--kakao:hover {
  border-color: rgba(148, 72, 72, 0.72);
  box-shadow:
    0 0 0 1px rgba(252, 248, 247, 0.98) inset,
    0 16px 44px -18px rgba(176, 92, 88, 0.48),
    0 10px 28px -14px rgba(56, 42, 46, 0.14),
    0 0 0 2px rgba(158, 52, 52, 0.42);
  transform: translateY(-2px);
}
.closing-cta-btn--kakao .closing-cta-btn-ic {
  width: 26px;
  height: 26px;
  border-radius: 8px;
  box-shadow: 0 2px 12px -2px rgba(148, 72, 72, 0.35);
}
.closing-cta-btn--kakao .closing-cta-btn-ic svg {
  width: 16px;
  height: 16px;
}

.closing-cta-btn-ic {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 6px;
  background: var(--color-kakao);
  color: var(--color-kakao-ink);
}
.closing-cta-btn-ic svg {
  width: 14px;
  height: 14px;
}
.closing-cta-meta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 20px;
  font-size: var(--text-xs);
  color: var(--color-mute);
  line-height: var(--leading-normal);
}
.closing-cta-meta-ic {
  display: flex;
  color: var(--color-mute);
  opacity: 0.85;
}

@media (max-width: 760px) {
  .closing-steps::before {
    display: none;
  }
  .closing-steps-scroll {
    overflow: visible;
    margin: 0;
    padding: 0;
    scroll-snap-type: none;
  }
  .closing-steps {
    flex-direction: column;
    align-items: stretch;
    min-width: 0;
    padding-left: 0;
    gap: 0;
  }
  .closing-step {
    flex-direction: row;
    align-items: flex-start;
    text-align: left;
    gap: 16px;
    padding: 16px 0;
    border-bottom: 1px solid rgba(222, 201, 196, 0.5);
  }
  .closing-step:last-child {
    border-bottom: none;
    padding-bottom: 0;
  }
  .closing-step-icon {
    margin-bottom: 0;
    flex-shrink: 0;
  }
  .closing-step-body {
    align-items: flex-start;
    text-align: left;
  }
  .closing-step-name {
    margin-bottom: 4px;
  }
}

/* ======================================================
   Pricing — 런칭 가격 · 리뷰 이벤트 (듀얼 카드)
====================================================== */
.container--pricing {
  max-width: min(1040px, 100%);
  display: flex;
  flex-direction: column;
  align-items: center;
}
.pricing {
  padding-top: clamp(40px, 6vw, 72px);
  padding-bottom: clamp(48px, 7vw, 88px);
  background: linear-gradient(180deg, var(--color-bg-alt) 0%, var(--color-bg) 42%, var(--color-wash) 100%);
}
.pricing-board {
  width: 100%;
  align-self: stretch;
  border-radius: 22px;
  border: 2px solid rgba(120, 88, 90, 0.32);
  background: linear-gradient(165deg, rgba(252, 248, 247, 0.98) 0%, var(--color-wash) 38%, rgba(233, 221, 217, 0.88) 100%);
  box-shadow:
    0 0 0 1px rgba(252, 246, 244, 0.8) inset,
    0 16px 48px -28px rgba(56, 42, 46, 0.11);
  overflow: hidden;
}
.pricing-launch-pill.wm-section-badge {
  margin-top: 0;
  margin-bottom: clamp(14px, 3vw, 22px);
}
.pricing-launch-pill.wm-section-badge--signature {
  max-width: min(100%, 40em);
  flex-wrap: wrap;
  row-gap: 6px;
  column-gap: 8px;
  justify-content: center;
}
.pricing-launch-pill .wm-section-badge__ic {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1em;
  line-height: 1;
}
.pricing-launch-pill .wm-section-badge__ic svg {
  width: 1.15em;
  height: 1.15em;
  display: block;
  flex-shrink: 0;
}
.pricing-launch-pill-lead {
  font-weight: 800;
  letter-spacing: 0.08em;
  color: inherit;
}
.pricing-launch-pill-dot {
  font-weight: 700;
  opacity: 0.9;
}
.pricing-launch-pill-dates {
  font-weight: 800;
  letter-spacing: 0.05em;
  color: #fff5ec;
  text-shadow:
    0 0 20px rgba(255, 214, 180, 0.42),
    0 1px 2px rgba(0, 0, 0, 0.22);
}

.pricing-hero {
  text-align: center;
  padding: clamp(20px, 3.5vw, 32px) clamp(18px, 4vw, 32px) clamp(18px, 3vw, 28px);
}
.pricing-hero-sub {
  margin: 0 auto;
  max-width: 32em;
  font-family: var(--font-sans);
  font-size: clamp(var(--text-md), 2.4vw, var(--text-lg));
  font-weight: 400;
  line-height: var(--leading-relaxed);
  letter-spacing: var(--tracking-tight);
  color: var(--color-ink-soft);
}
.pricing-dual {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 14px;
  padding: 0 clamp(14px, 3vw, 24px) clamp(20px, 3.5vw, 28px);
}
@media (min-width: 840px) {
  .pricing-dual {
    flex-direction: row;
    align-items: stretch;
    justify-content: center;
    gap: 10px;
    padding: 0 clamp(20px, 3vw, 32px) clamp(24px, 3.5vw, 32px);
  }
  .pricing-tile--launch {
    order: 1;
  }
  .pricing-dual-plus {
    order: 2;
  }
  .pricing-tile--event {
    order: 3;
  }
}
.pricing-dual-plus {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.pricing-dual-plus-inner {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-sans);
  font-size: clamp(var(--text-lg), 2.5vw, var(--text-xl));
  font-weight: 700;
  letter-spacing: var(--tracking-tight);
  color: rgba(255, 252, 252, 0.98);
  background: var(--pricing-launch-cap-gradient);
  box-shadow: 0 4px 16px -8px rgba(58, 47, 51, 0.28);
}
.pricing-tile {
  flex: 1 1 100%;
  min-width: 0;
  border-radius: 18px;
  background: var(--color-surface);
  box-shadow: 0 10px 32px -22px rgba(56, 42, 46, 0.14);
  border: 1px solid rgba(222, 201, 196, 0.65);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
@media (min-width: 840px) {
  .pricing-tile {
    flex: 1 1 0;
    max-width: min(420px, 50%);
  }
}
.pricing-tile-cap {
  font-family: var(--font-sans);
  font-size: clamp(var(--text-md), 2.8vw, var(--text-lg));
  font-weight: var(--weight-sans-bold);
  letter-spacing: var(--tracking-head);
  text-align: center;
  padding: 12px 16px;
  color: rgba(255, 252, 252, 0.98);
}
.pricing-tile-cap--deep {
  background: linear-gradient(145deg, #5c1a22 0%, #3f1218 42%, #2a0c10 100%);
  color: rgba(255, 251, 250, 0.97);
  border-bottom: 1px solid rgba(12, 4, 6, 0.35);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.1),
    0 1px 0 rgba(0, 0, 0, 0.12);
}
/* 리뷰 이벤트 캡 — 런칭(붉은 버건디)과 구분되는 플럼·모브 톤 */
.pricing-tile-cap--rose {
  background: linear-gradient(145deg, #524458 0%, #3d3248 42%, #2a2234 100%);
  color: rgba(255, 251, 252, 0.97);
  border-bottom: 1px solid rgba(14, 10, 20, 0.4);
  box-shadow:
    inset 0 1px 0 rgba(255, 248, 252, 0.12),
    0 1px 0 rgba(0, 0, 0, 0.14);
}
.pricing-tile-launch-name {
  color: #481219;
  font-weight: 800;
}
.pricing-tile-cap--event-row {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  /* 배지 폭만큼 좌우 여백 — 제목이 시각적 중앙에 오도록 */
  padding-left: clamp(16px, 16vw, 120px);
  padding-right: clamp(16px, 16vw, 120px);
}
.pricing-tile-cap-main {
  margin: 0;
  display: inline-block;
  font: inherit;
  font-weight: var(--weight-sans-bold);
  letter-spacing: inherit;
  line-height: 1.2;
  text-align: center;
}
.pricing-tile-limited.pricing-tile-limited--on-cap {
  position: absolute;
  right: clamp(10px, 3vw, 16px);
  top: 50%;
  transform: translateY(-50%);
  margin: 0;
  flex-shrink: 0;
  padding: 5px 11px;
  border-radius: 999px;
  font-family: var(--font-sans);
  font-size: var(--text-2xs);
  font-weight: var(--weight-sans-bold);
  letter-spacing: var(--tracking-tight);
  color: #9a1f32;
  background: rgba(255, 248, 247, 0.97);
  border: 1px solid rgba(200, 72, 88, 0.55);
  box-shadow: 0 1px 3px rgba(56, 42, 46, 0.08);
}
.pricing-tile-body {
  padding: clamp(18px, 2.8vw, 24px) clamp(16px, 2.8vw, 22px) clamp(20px, 3vw, 26px);
  display: flex;
  flex-direction: column;
  align-items: stretch;
  flex: 1 1 auto;
}
.pricing-tile-rate {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}
.pricing-tile-original {
  margin: 0;
  font-family: var(--font-sans);
  font-size: clamp(var(--text-md), 3vw, var(--text-lg));
  font-weight: 500;
  letter-spacing: var(--tracking-tight);
  color: var(--color-mute);
}
.pricing-tile-original-num {
  text-decoration: line-through;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}
.pricing-tile-discount-wrap {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 12px 18px;
  margin-top: 8px;
}
.pricing-tile-discount-ribbon {
  margin: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-width: 72px;
  min-height: 72px;
  padding: 6px;
  border-radius: 50%;
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: var(--weight-sans-bold);
  letter-spacing: var(--tracking-tight);
  line-height: var(--leading-tight);
  text-align: center;
  color: rgba(255, 252, 252, 0.98);
  background: linear-gradient(155deg, var(--color-pricing-badge-from) 0%, #b86a74 38%, var(--color-pricing-red) 58%, var(--color-pricing-badge-to) 100%);
  border: 1px solid var(--color-pricing-badge-border);
  box-shadow: 0 6px 18px -8px rgba(74, 38, 44, 0.28);
}
.pricing-tile-discount-pct {
  font-size: var(--text-sm);
}
.pricing-tile--launch .pricing-tile-price {
  color: var(--color-pricing-pink);
}
.pricing-tile-price {
  margin: 0;
  font-family: var(--font-sans);
  font-size: clamp(1.875rem, 8vw, 3rem);
  font-weight: var(--weight-sans-bold);
  letter-spacing: var(--tracking-head);
  line-height: var(--leading-tight);
  color: var(--color-gold-deep);
}
.pricing-tile-price-won {
  font-size: 0.5em;
  font-weight: 700;
}
.pricing-tile-rule {
  border: none;
  border-top: 1px dashed rgba(222, 201, 196, 0.85);
  margin: 16px 0 12px;
}
.pricing-tile-perks {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.pricing-tile-perks li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-family: var(--font-sans);
  font-size: clamp(var(--text-sm), 2.2vw, var(--text-md));
  font-weight: 600;
  letter-spacing: var(--tracking-tight);
  line-height: var(--leading-relaxed);
  color: var(--color-ink);
  text-align: left;
}
.pricing-tile-perk-ic {
  flex-shrink: 0;
  margin-top: 2px;
  color: var(--color-gold-deep);
}
/* 런칭 카드 — 혜택 리스트 줄간격으로 하단 빈 여백 완화 */
.pricing-tile--launch .pricing-tile-body {
  padding-top: clamp(16px, 2.5vw, 22px);
  padding-bottom: clamp(14px, 2vw, 18px);
}
.pricing-tile--launch .pricing-tile-rule {
  margin: 14px 0 14px;
}
.pricing-tile-limited {
  margin: 0 auto 10px;
  display: inline-flex;
  align-self: center;
  padding: 6px 14px;
  border-radius: 10px;
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--color-ink-soft);
  background: rgba(241, 228, 225, 0.85);
  border: 1px solid rgba(222, 201, 196, 0.55);
}
.pricing-tile-event-stack {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  margin-bottom: 2px;
}
.pricing-tile-event-top {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 8px 12px;
  width: 100%;
  padding-bottom: 8px;
}
.pricing-tile-from-line {
  margin: 0;
  display: inline-flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: center;
  gap: 6px 8px;
  max-width: 100%;
  text-align: center;
  font-family: var(--font-sans);
  font-size: clamp(var(--text-md), 2.8vw, var(--text-lg));
  font-weight: 600;
  letter-spacing: var(--tracking-tight);
  line-height: var(--leading-snug);
  color: var(--color-ink);
}
.pricing-tile-from-line del.pricing-tile-from-strike {
  margin: 0;
  padding: 0;
  border: none;
  background: none;
  font: inherit;
  text-decoration: line-through;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
  color: var(--color-mute);
  font-weight: 600;
  opacity: 1;
}
.pricing-tile-event-top .pricing-tile-extra-bubble {
  margin: 0;
  flex-shrink: 0;
}
.pricing-tile-extra-bubble {
  margin: 0;
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 7px 12px 9px;
  border-radius: 12px;
  font-family: var(--font-sans);
  font-size: clamp(var(--text-xs), 2.4vw, var(--text-sm));
  font-weight: var(--weight-sans-bold);
  letter-spacing: var(--tracking-tight);
  line-height: var(--leading-tight);
  white-space: nowrap;
  color: rgba(255, 252, 252, 0.98);
  background: linear-gradient(145deg, var(--color-pricing-badge-from) 0%, #b86a74 36%, var(--color-pricing-red) 55%, var(--color-pricing-badge-to) 100%);
  border: 1px solid var(--color-pricing-badge-border);
  box-shadow: 0 4px 14px -8px rgba(74, 38, 44, 0.26);
}
.pricing-tile-extra-bubble::after {
  content: '';
  position: absolute;
  bottom: -6px;
  left: 14px;
  right: auto;
  width: 0;
  height: 0;
  border-left: 7px solid transparent;
  border-right: 7px solid transparent;
  border-top: 7px solid var(--color-pricing-badge-to);
}
.pricing-tile-price--event {
  margin: 0;
  width: 100%;
  text-align: center;
  font-size: clamp(2rem, 9vw, 3.25rem);
  font-weight: var(--weight-sans-bold);
  letter-spacing: var(--tracking-head);
  line-height: var(--leading-tight);
  color: var(--color-pricing-pink);
}
.pricing-tile-condition {
  margin: 12px auto 14px;
  max-width: 28em;
  text-align: center;
  font-family: var(--font-sans);
  font-size: clamp(var(--text-sm), 2.2vw, var(--text-md));
  font-weight: var(--weight-sans-medium);
  letter-spacing: var(--tracking-tight);
  line-height: var(--leading-relaxed);
  color: var(--color-ink-soft);
}
.pricing-event-actions {
  margin-bottom: 0;
}
.pricing-event-brand {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px 12px;
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(252, 248, 247, 0.92);
  border: none;
}
.pricing-event-brand-txt {
  font-family: var(--font-sans);
  font-size: clamp(var(--text-xs), 2vw, var(--text-md));
  font-weight: 700;
  letter-spacing: var(--tracking-tight);
  color: var(--color-ink);
  line-height: var(--leading-snug);
}
.pricing-urgent {
  display: flex;
  align-items: center;
  gap: 10px 14px;
  padding: 16px clamp(16px, 3vw, 24px);
  background: linear-gradient(90deg, rgba(241, 228, 225, 0.55) 0%, rgba(252, 248, 247, 0.75) 40%, rgba(237, 218, 214, 0.35) 100%);
  border-top: 1px solid rgba(222, 201, 196, 0.55);
  box-shadow: 0 -1px 0 rgba(255, 255, 255, 0.5) inset;
}
.pricing-urgent-ic {
  flex-shrink: 0;
  margin-top: 0;
  color: var(--color-pricing-pink-deep);
}
.pricing-urgent-text {
  margin: 0;
  font-family: var(--font-sans);
  font-size: clamp(var(--text-sm), 2.4vw, var(--text-base));
  font-weight: 600;
  letter-spacing: var(--tracking-tight);
  line-height: var(--leading-relaxed);
  color: var(--color-ink-soft);
}

.pricing-step-ic {
  position: relative;
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-kakao);
  flex-shrink: 0;
  overflow: hidden;
}
/* Kakao 공유 버튼 PNG: Kakao Developers — https://developers.kakao.com/ */
.pricing-step-ic--kakao-dev {
  flex-shrink: 0;
  padding: 7px;
  border: 1px solid rgba(24, 22, 0, 0.1);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.35) inset;
}
.pricing-step-kakao-share-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  flex-shrink: 0;
}
.pricing-step-mock--review {
  margin-top: 6px;
  padding: 14px 14px 13px;
  border-radius: 14px;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  background: rgba(255, 255, 255, 0.78);
  border: 1px solid rgba(222, 201, 196, 0.65);
  box-shadow: 0 4px 22px -14px rgba(56, 42, 46, 0.12);
}
.pricing-review-chip {
  display: inline-flex;
  align-self: flex-start;
  align-items: center;
  margin: 0 0 10px;
  padding: 5px 11px;
  border-radius: 999px;
  font-family: var(--font-sans);
  font-size: var(--text-micro);
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--color-gold-deep);
  background: rgba(237, 218, 214, 0.45);
  border: 1px solid rgba(194, 160, 155, 0.35);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.75) inset;
}
.pricing-mock-quote {
  margin: 0 0 10px;
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: var(--tracking-tight);
  line-height: var(--leading-normal);
  color: var(--color-ink);
}
.pricing-review-sep {
  border: none;
  height: 0;
  margin: 6px 0;
  border-top: 1px dashed rgba(222, 201, 196, 0.65);
  opacity: 0.9;
}
.pricing-review-snippet--back:empty + .pricing-review-sep {
  display: none;
}
.pricing-mock-quote--cycle + .pricing-review-sep:has(+ .pricing-review-snippet--fore:empty) {
  display: none;
}
.pricing-step-mock--review.pricing-review--reduced .pricing-review-sep {
  display: none;
}
.pricing-review-snippet--back,
.pricing-review-snippet--fore {
  margin: 0;
  padding: 0 2px;
  font-family: var(--font-sans);
  font-size: var(--text-micro);
  line-height: 1.45;
  letter-spacing: var(--tracking-tight);
  font-style: italic;
  color: var(--color-mute);
  opacity: 0.68;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-clamp: 2;
}
.pricing-review-snippet--back:empty,
.pricing-review-snippet--fore:empty {
  display: none;
}
.pricing-review-snippet--back {
  margin-bottom: 0;
  text-align: left;
}
.pricing-review-snippet--fore {
  margin-top: 0;
  margin-bottom: 8px;
  text-align: left;
}
.pricing-mock-quote--cycle {
  margin: 0;
  padding: 12px 13px 13px;
  min-height: 4.35em;
  text-align: left;
  white-space: normal;
  border-radius: 11px;
  font-family: var(--font-sans);
  font-size: clamp(var(--text-xs), 1.5vw, var(--text-sm));
  font-weight: 500;
  letter-spacing: var(--tracking-tight);
  line-height: var(--leading-relaxed);
  color: var(--color-ink);
  background: rgba(252, 248, 247, 0.97);
  border: 1px solid rgba(237, 218, 214, 0.75);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.85) inset;
}
.pricing-mock-open,
.pricing-mock-close {
  color: var(--color-gold-deep);
  font-weight: 600;
  opacity: 0.42;
}
.pricing-mock-caret {
  display: inline-block;
  width: 2.5px;
  height: 1.05em;
  margin-left: 2px;
  vertical-align: -0.1em;
  background: linear-gradient(180deg, #c9a39d, #7a5552);
  border-radius: 1px;
  box-shadow: 0 0 0 1px rgba(252, 248, 247, 0.4);
  animation: pricing-review-caret 1.05s steps(2, end) infinite;
}
.pricing-step-mock--review:not(.pricing-review-is-typing) .pricing-mock-caret {
  opacity: 0 !important;
  animation: none;
}
@keyframes pricing-review-caret {
  0%, 45% { opacity: 1; }
  55%, 100% { opacity: 0; }
}
.pricing-step-link {
  margin-top: auto;
  padding-top: 8px;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: 700;
  letter-spacing: var(--tracking-tight);
  color: var(--color-gold-deep);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.pricing-event-brand .pricing-step-link--head {
  margin-top: 0;
  padding: 8px 14px;
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: var(--tracking-tight);
  color: var(--color-gold-deep);
  text-decoration: none;
  white-space: nowrap;
  border-radius: 999px;
  border: 1px solid rgba(194, 160, 155, 0.45);
  background: rgba(252, 248, 247, 0.95);
  box-shadow: 0 2px 8px -4px rgba(56, 42, 46, 0.12);
  flex-shrink: 0;
  align-self: center;
  text-align: center;
  transition: border-color 0.2s ease, background 0.2s ease, color 0.2s ease;
}
.pricing-event-brand .pricing-step-link--head:hover {
  color: var(--color-ink);
  border-color: rgba(148, 112, 108, 0.55);
  background: rgba(252, 248, 247, 1);
}
.pricing-step-link:hover {
  color: var(--color-ink);
}

/* ======================================================
   핵심·세부 기능 — 한 덩어리 흐름 (feat-flow)
====================================================== */
.feat-flow {
  --feat-flow-pad: clamp(16px, 4vw, 28px);
  --feat-flow-max: min(1080px, calc(100vw - clamp(20px, 4vw, 40px)));
  width: min(100%, var(--feat-flow-max));
  max-width: var(--feat-flow-max);
  margin-left: auto;
  margin-right: auto;
  margin-top: 0;
  margin-bottom: clamp(8px, 2vw, 16px);
  background: var(--feat-warm-bg);
  color: var(--feat-warm-ink);
  padding: clamp(28px, 5vw, 48px) var(--feat-flow-pad) 0;
  border-radius: 22px;
  border: 1px solid var(--feat-warm-border);
  box-shadow:
    0 0 0 1px rgba(255, 252, 250, 0.7) inset,
    0 12px 36px -22px rgba(139, 111, 106, 0.14);
  padding-bottom: clamp(20px, 4vw, 32px);
  transition: box-shadow 0.45s var(--ease), border-color 0.45s ease, padding-bottom 0.45s ease;
}
.feat-flow .feat-det {
  background: transparent;
}
@media (min-width: 768px) {
  .feat-flow {
    padding-top: clamp(40px, 5vw, 56px);
  }
}

/* ======================================================
   핵심 기능 — 2카드 + 폰 목업
====================================================== */
.feat-core {
  padding-top: 0;
  padding-bottom: clamp(12px, 3vw, 20px);
  overflow: visible;
  background: var(--feat-warm-bg);
}
@media (min-width: 768px) {
  .feat-core {
    padding-bottom: clamp(12px, 2.5vw, 20px);
  }
}

/* PART 1 ↔ PART 2 구분선 */
.feat-part-sep {
  display: block;
  height: 1px;
  margin: clamp(20px, 4vw, 36px) auto clamp(18px, 3.5vw, 30px);
  max-width: min(1080px, calc(100% - 40px));
  border: none;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(231, 217, 210, 0.35) 14%,
    rgba(231, 217, 210, 0.95) 50%,
    rgba(231, 217, 210, 0.35) 86%,
    transparent 100%
  );
  border-radius: 1px;
  box-shadow: 0 1px 0 rgba(255, 252, 250, 0.75);
}

.feat-core-head {
  margin-bottom: 28px;
}
@media (min-width: 768px) {
  .feat-core-head {
    margin-bottom: 36px;
  }
}
/* 박스(feat-flow) 안 상단: 알약 → 카드 그리드 */
.feat-flow > .container > .feat-core-head--in-flow {
  margin-top: 0;
}
.feat-flow > .container {
  max-width: 100%;
  width: 100%;
}
.feat-core-grid {
  display: grid;
  gap: 18px;
  grid-template-columns: 1fr;
  align-items: start;
  width: 100%;
}
.feat-core-sample-note {
  margin: 12px 0 0;
  text-align: center;
  font-size: var(--text-2xs);
  line-height: var(--leading-normal);
  color: var(--color-mute);
  letter-spacing: var(--tracking-tight);
}
.feat-core-sample-note--story {
  align-self: stretch;
  width: 100%;
  margin: 10px 0 0;
  padding: 0 2px 0;
  text-align: left;
}
@media (min-width: 768px) {
  .feat-core-card--story .feat-core-sample-note--story {
    margin-top: auto;
    padding-top: 12px;
  }
}
.feat-core-card {
  display: flex;
  flex-direction: column;
  width: 100%;
  min-height: 0;
  border-radius: 20px;
  overflow: hidden;
  border: 1px solid rgba(222, 201, 196, 0.55);
  background: var(--color-surface);
  box-shadow: 0 12px 40px -24px rgba(56, 42, 46, 0.12);
}
.feat-core-visual-details {
  flex-shrink: 0;
  margin: 0;
  border-top: 1px solid rgba(222, 201, 196, 0.65);
  background: var(--color-surface);
}
.feat-core-visual-summary {
  position: relative;
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 12px 40px 12px 16px;
  cursor: pointer;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: var(--tracking-tight);
  color: var(--color-gold-deep);
  transition: background 0.2s ease;
}
.feat-core-visual-summary::-webkit-details-marker {
  display: none;
}
.feat-core-visual-summary::marker {
  content: '';
}
.feat-core-visual-summary:hover {
  background: rgba(237, 218, 214, 0.35);
}
.feat-core-visual-summary-label {
  flex: 1;
  text-align: center;
}
.feat-core-visual-toggle--less {
  display: none;
}
.feat-core-visual-details[open] .feat-core-visual-toggle--more {
  display: none;
}
.feat-core-visual-details[open] .feat-core-visual-toggle--less {
  display: inline;
}
.feat-core-visual-chev {
  position: absolute;
  right: 14px;
  top: 50%;
  flex-shrink: 0;
  color: var(--color-ink-soft);
  transform: translateY(-50%);
  transition: transform 0.2s ease;
}
.feat-core-visual-details[open] .feat-core-visual-chev {
  transform: translateY(-50%) rotate(180deg);
}
.feat-core-visual-details[open] > .feat-core-visual-summary {
  border-bottom: 1px solid rgba(222, 201, 196, 0.45);
}
.feat-core-visual {
  flex: 0 0 auto;
  background: linear-gradient(180deg, #e4d8d5 0%, #cec2bf 100%);
  padding: 18px 16px 20px;
  display: flex;
  justify-content: center;
}
.feat-core-card--story .feat-core-visual {
  background: linear-gradient(180deg, #d5cac7 0%, #bfb4b1 100%);
}
.feat-core-phone {
  width: min(184px, 58vw);
  aspect-ratio: 9 / 18.5;
  border-radius: 22px;
  padding: 7px;
  background: #1a1a1a;
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.06) inset,
    0 16px 40px -18px rgba(0, 0, 0, 0.42);
}
.feat-core-phone-inner {
  width: 100%;
  height: 100%;
  border-radius: 16px;
  background: #b8aea8;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 12px;
  text-align: center;
}
.feat-core-phone-inner--video {
  position: relative;
  padding: 0;
  background: #1a1a1a;
  overflow: hidden;
}
.feat-core-phone-video {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: contain;
  object-position: center;
}
.feat-core-voice-chip {
  position: absolute;
  top: 7px;
  right: 6px;
  left: auto;
  transform: none;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 10px 5px 7px;
  border-radius: 999px;
  background: rgba(252, 248, 247, 0.98);
  border: 1px solid rgba(148, 112, 108, 0.42);
  box-shadow: 0 6px 20px -6px rgba(0, 0, 0, 0.28);
  pointer-events: none;
  font-family: var(--font-sans);
  font-size: var(--text-micro);
  font-weight: 600;
  letter-spacing: var(--tracking-tight);
  color: var(--color-ink);
  white-space: nowrap;
}
.feat-core-voice-dot {
  flex-shrink: 0;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: linear-gradient(145deg, var(--color-gold), var(--color-gold-deep));
  box-shadow: 0 0 0 1px rgba(112, 82, 84, 0.45);
}
.feat-core-story-kicker {
  margin: 0 0 10px;
  font-family: var(--font-sans);
  font-size: clamp(17px, 3.9vw, 21px);
  font-weight: 600;
  letter-spacing: 0.11em;
  text-transform: uppercase;
  color: var(--color-gold-deep);
}
.feat-core-card--story .feat-core-story-kicker {
  font-size: clamp(22px, 5.2vw, 30px);
  margin: 0 0 14px;
  letter-spacing: 0.11em;
}
.feat-core-card--story .feat-core-card-title {
  font-size: clamp(21px, 4vw, 24px);
  line-height: 1.32;
  color: var(--color-ink);
  margin-bottom: 12px;
}
.feat-core-card--story .feat-core-desc {
  margin-top: 6px;
  font-size: clamp(15px, 3vw, 17px);
  line-height: 1.72;
  color: var(--color-ink-soft);
}
.feat-core-card--story .feat-core-story-panel {
  margin-top: 12px;
}
.feat-core-card--story .feat-core-story-details-inner .feat-core-story-timeline {
  margin-top: 4px;
  margin-bottom: 10px;
}
.feat-core-card--story .feat-core-story-details-inner .feat-core-story-toolbar {
  margin-top: 16px;
  padding-top: 14px;
}
.feat-core-card--story .feat-core-story-details-inner .feat-core-story-note {
  margin-top: 14px;
  padding-top: 12px;
}
@media (max-width: 767px) {
  .feat-core-card--story .feat-core-visual-details {
    order: -1;
    border-top: none;
    border-bottom: 1px solid rgba(222, 201, 196, 0.65);
  }
}
@media (min-width: 768px) {
  .feat-core-card--story {
    flex-direction: row-reverse;
    align-items: stretch;
  }
  .feat-core-card--story .feat-core-visual-details {
    display: flex;
    flex-direction: column;
    flex: 1 1 36%;
    min-width: 0;
    align-self: stretch;
    border-top: none;
    border-right: 1px solid rgba(222, 201, 196, 0.65);
  }
  .feat-core-card--story .feat-core-visual {
    flex: 1 1 auto;
    align-items: center;
    justify-content: center;
    min-height: 0;
  }
  .feat-core-card--story .feat-core-body--story {
    flex: 1 1 64%;
    min-width: 0;
  }
  .feat-core-card--story .feat-core-phone {
    width: min(100%, clamp(168px, 18vw, 280px));
  }
}
.feat-core-story-panel {
  margin-top: 6px;
}
.feat-core-story-details-summary {
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 11px 12px;
  border-radius: 12px;
  border: 1px dashed rgba(194, 160, 155, 0.45);
  background: rgba(237, 218, 214, 0.4);
  cursor: pointer;
  font-family: var(--font-sans);
  color: var(--color-ink-soft);
  transition: background 0.2s ease, border-color 0.2s ease;
}
.feat-core-story-details-summary::-webkit-details-marker {
  display: none;
}
.feat-core-story-details-summary::marker {
  content: '';
}
.feat-core-story-details-summary:hover {
  background: rgba(237, 218, 214, 0.65);
  border-color: rgba(148, 112, 108, 0.55);
}
.feat-core-story-details-title {
  font-size: var(--text-md);
  font-weight: 600;
  letter-spacing: var(--tracking-tight);
}
.feat-core-story-details-meta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-gold-deep);
}
.feat-core-story-details-toggle--less {
  display: none;
}
.feat-core-story-details[open] .feat-core-story-details-toggle--more {
  display: none;
}
.feat-core-story-details[open] .feat-core-story-details-toggle--less {
  display: inline;
}
.feat-core-story-details-chev {
  flex-shrink: 0;
  color: var(--color-ink-soft);
  transition: transform 0.2s ease;
}
.feat-core-story-details[open] .feat-core-story-details-chev {
  transform: rotate(180deg);
}
.feat-core-story-details[open] > .feat-core-story-details-summary {
  margin-bottom: 2px;
  border-style: solid;
  border-color: rgba(148, 112, 108, 0.32);
}
.feat-core-story-details-inner {
  padding: 10px 0 2px;
}
.feat-core-story-details-inner .feat-core-story-timeline {
  margin-top: 0;
  margin-bottom: 6px;
}
.feat-core-story-details-inner .feat-core-story-toolbar {
  margin-top: 12px;
}
.feat-core-story-details-inner .feat-core-story-note {
  margin-top: 12px;
}
.feat-core-card--story .feat-core-story-details-inner {
  padding: 14px 0 2px;
}
.feat-core-story-timeline {
  position: relative;
  margin: 18px 0 6px;
  padding: 0 2px;
}
.feat-core-story-line {
  position: absolute;
  left: 8%;
  right: 8%;
  top: 17px;
  height: 2px;
  border-radius: 1px;
  background: linear-gradient(
    90deg,
    rgba(148, 112, 108, 0.38),
    rgba(56, 42, 46, 0.28),
    rgba(148, 112, 108, 0.38)
  );
  z-index: 0;
}
.feat-core-story-nodes {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 2px;
  position: relative;
  z-index: 1;
}
.feat-core-story-node {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 7px;
}
.feat-core-story-node-ring {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: var(--color-surface);
  border: 1px solid rgba(194, 160, 155, 0.45);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-ink-soft);
  flex-shrink: 0;
}
.feat-core-story-node--active .feat-core-story-node-ring {
  background: linear-gradient(145deg, #b8928c, #7a5552);
  border-color: rgba(64, 50, 50, 0.65);
  color: #fffbfa;
  box-shadow: 0 4px 14px -3px rgba(64, 50, 50, 0.4);
}
.feat-core-story-node-ring--dashed {
  border-style: dashed;
  border-color: rgba(194, 160, 155, 0.45);
  background: rgba(252, 248, 247, 0.95);
  color: var(--color-ink-soft);
}
.feat-core-story-svg {
  display: block;
}
.feat-core-story-node-label {
  font-size: 9px;
  font-weight: 500;
  line-height: 1.2;
  color: var(--color-ink-soft);
  text-align: center;
  max-width: 100%;
}
.feat-core-story-node--active .feat-core-story-node-label {
  color: var(--color-gold-deep);
  font-weight: 600;
}
.feat-core-story-toolbar {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 10px 6px;
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px dashed rgba(194, 160, 155, 0.45);
}
.feat-core-story-tool {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  font-size: 10px;
  font-weight: 500;
  letter-spacing: -0.02em;
  color: var(--color-ink-soft);
  text-align: center;
  line-height: 1.25;
}
.feat-core-story-tool svg {
  flex-shrink: 0;
  opacity: 1;
  color: var(--color-ink-soft);
}
.feat-core-story-note {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin: 16px 0 0;
  padding-top: 14px;
  border-top: 1px dashed rgba(194, 160, 155, 0.45);
  font-family: var(--font-sans);
  font-size: 12px;
  font-weight: 500;
  line-height: 1.55;
  letter-spacing: -0.02em;
  color: var(--color-ink-soft);
}
.feat-core-story-note-icon {
  flex-shrink: 0;
  margin-top: 1px;
  color: var(--color-gold-deep);
  opacity: 0.88;
}
.feat-core-story-note-icon svg {
  display: block;
}
.feat-core-story-note-copy {
  min-width: 0;
}
.feat-core-story-note-link {
  color: inherit;
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 2px;
  text-decoration-thickness: 1px;
}
.feat-core-story-note-link:hover {
  color: var(--color-gold-deep);
}
@media (min-width: 900px) {
  .feat-core-story-node-ring {
    width: 38px;
    height: 38px;
  }
  .feat-core-story-node-label {
    font-size: 10px;
  }
  .feat-core-story-tool {
    font-size: 11px;
  }
}
.feat-core-body.feat-core-body--story .feat-core-story-panel {
  align-self: stretch;
  width: 100%;
}
.feat-core-card--story .feat-core-story-toolbar {
  justify-content: center;
  gap: 14px 20px;
}
.feat-core-card--story .feat-core-story-tool {
  flex: 0 0 auto;
}
.feat-core-card--story .feat-core-story-note {
  justify-content: center;
  align-items: center;
  text-align: center;
  line-height: 1.65;
}
.feat-core-body {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  min-height: 0;
  padding: 20px 20px 22px;
  background: var(--color-surface);
}
.feat-core-body.feat-core-body--story {
  align-items: center;
  text-align: center;
  min-height: 0;
}
/* OUR STORY 글 칸: 클래스 규칙보다 ID로 패딩 고정(다른 .feat-core-body 규칙에 덮어쓰이지 않도록) */
#feat-story-body {
  padding: 28px 16px 12px;
}
@media (min-width: 900px) {
  #feat-story-body {
    padding: 34px 20px 14px;
  }
}
.feat-core-label {
  margin: 0 0 10px;
  font-family: var(--font-sans);
  font-size: clamp(17px, 3.9vw, 21px);
  font-weight: 600;
  letter-spacing: 0.11em;
  text-transform: uppercase;
  color: var(--color-gold-deep);
}
.feat-core-card-title {
  margin: 0 0 8px;
  font-family: var(--font-sans);
  font-size: clamp(19px, 4vw, 22px);
  font-weight: 700;
  letter-spacing: var(--tracking-head);
  color: var(--color-ink);
  line-height: var(--leading-tight);
}
.feat-core-desc {
  margin: 0;
  font-family: var(--font-sans);
  font-size: clamp(14px, 3vw, 16px);
  font-weight: var(--weight-sans-regular);
  letter-spacing: var(--tracking-tight);
  line-height: var(--leading-relaxed);
  color: var(--color-ink-soft);
}
/* ======================================================
   세부 기능 — 3×2 그리드 (항상 펼침 카드)
====================================================== */
.feat-det {
  overflow: hidden;
  padding-top: clamp(4px, 1vw, 10px);
  padding-bottom: clamp(20px, 4vw, 36px);
  background: linear-gradient(
    180deg,
    rgba(255, 253, 252, 0.65) 0%,
    rgba(252, 248, 247, 0.4) 48%,
    rgba(252, 248, 247, 0.15) 100%
  );
}
@media (min-width: 768px) {
  .feat-det {
    padding-top: clamp(6px, 1.2vw, 12px);
    padding-bottom: clamp(28px, 4vw, 44px);
  }
}
.feat-det-head {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
  margin-bottom: 24px;
  padding: 0;
  border: none;
  background: none;
  box-shadow: none;
}
@media (min-width: 768px) {
  .feat-det-head {
    max-width: 36rem;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 32px;
  }
}
.feat-det-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: 1fr;
  align-items: start;
}
@media (min-width: 640px) {
  .feat-det-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
}
@media (min-width: 1024px) {
  .feat-det-grid { grid-template-columns: repeat(3, 1fr); gap: 16px; }
}
.feat-det-card {
  border-radius: 14px;
  border: 1px solid rgba(230, 212, 206, 0.85);
  background: linear-gradient(180deg, #fffefd 0%, #fcf9f8 100%);
  overflow: hidden;
  transition: border-color 0.25s ease, box-shadow 0.25s ease;
}
.feat-det-card:hover {
  border-color: rgba(205, 178, 172, 0.65);
  box-shadow: 0 10px 28px -18px rgba(56, 42, 46, 0.06);
}
.feat-det-summary {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 18px 16px;
  -webkit-tap-highlight-color: transparent;
}
.feat-det-icon {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-gold-deep);
  background: rgba(245, 232, 228, 0.85);
  border: 1px solid rgba(218, 195, 190, 0.45);
}
.feat-det-titles {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
  text-align: left;
}
.feat-det-name {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  font-weight: 700;
  letter-spacing: var(--tracking-tight);
  color: var(--color-ink);
  line-height: var(--leading-snug);
}
.feat-det-sub {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: var(--weight-sans-medium);
  letter-spacing: var(--tracking-tight);
  color: var(--color-mute);
  line-height: var(--leading-snug);
}
/* ======================================================
   For Whom — 추천 대상 (카드 3열)
====================================================== */
.whom {
  background: linear-gradient(180deg, var(--color-bg) 0%, var(--color-bg-alt) 100%);
}
.container--whom {
  max-width: min(1080px, 100%);
}
.whom-head {
  text-align: center;
  margin: 0 auto;
}
/* FOR WHOM — 시그니처 알약은 전역 .wm-section-badge--signature, 여기서는 여밉·대문자만 */
.whom-head .whom-heading.wm-section-badge {
  margin-bottom: clamp(22px, 4vw, 40px);
}
.whom-head .whom-heading.wm-section-badge--signature,
.closing-badge.wm-section-badge--signature {
  text-transform: uppercase;
  letter-spacing: 0.14em;
}

.whom-grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
  align-items: stretch;
}

@media (min-width: 560px) and (max-width: 899px) {
  .whom-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .whom-card:nth-child(3) {
    grid-column: 1 / -1;
    max-width: 420px;
    justify-self: center;
    width: 100%;
  }
}

.whom-card {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 26px 22px 24px;
  background: #fff;
  border-radius: 20px;
  border: 1px solid rgba(222, 201, 196, 0.35);
  box-shadow: 0 14px 40px -18px rgba(56, 42, 46, 0.14);
}
.whom-card-num {
  align-self: flex-start;
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(32px, 5vw, 40px);
  font-weight: 500;
  color: #5a4148;
  line-height: 1;
  margin-bottom: 16px;
}
.whom-card-icon-wrap {
  width: 72px;
  height: 72px;
  margin: 0 auto 18px;
  border-radius: 50%;
  border: 1.5px solid rgba(194, 160, 155, 0.45);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #5a4148;
  flex-shrink: 0;
  background: rgba(255, 255, 255, 0.6);
}
.whom-card-icon {
  display: flex;
  align-items: center;
  justify-content: center;
}
.whom-card-icon--envelope {
  position: relative;
  width: 100%;
  height: 100%;
}
.whom-ic-heart {
  position: absolute;
  right: 10px;
  bottom: 12px;
  color: #5a4148;
  opacity: 0.95;
}
.whom-card-icon--process {
  position: relative;
  width: 100%;
  height: 100%;
}
.whom-spark {
  position: absolute;
  color: var(--color-gold);
  opacity: 0.9;
}
.whom-spark--tr {
  top: 6px;
  right: 6px;
}
.whom-spark--bl {
  bottom: 8px;
  left: 8px;
  opacity: 0.75;
}

.whom-card-lead {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  font-weight: 700;
  letter-spacing: var(--tracking-head);
  color: #5a4148;
  line-height: var(--leading-snug);
  margin-bottom: 0;
}
.whom-card-lead::after {
  content: '';
  display: block;
  width: min(44px, 32%);
  height: 0;
  margin: 10px auto 12px;
  border: 0;
  border-top: 1.5px solid rgba(194, 160, 155, 0.45);
}
.whom-card-desc {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
  letter-spacing: var(--tracking-tight);
  color: rgba(90, 65, 72, 0.82);
  margin-bottom: 20px;
  flex: 1 1 auto;
}
.whom-card-tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  max-width: 100%;
  box-sizing: border-box;
  margin-top: 0;
  margin-bottom: 12px;
  padding: 8px 14px;
  border-radius: 999px;
  border: 1.5px solid rgba(194, 160, 155, 0.45);
  font-family: var(--font-sans);
  font-size: var(--text-2xs);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-align: center;
  line-height: 1.25;
  color: #5a4148;
  white-space: normal;
  overflow-wrap: break-word;
}

.whom-foot {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 12px 20px;
  text-align: center;
}
/* 3열 카드 그리드 아래 마무리 카피 */
.whom-foot--lead {
  margin-top: clamp(32px, 5vw, 52px);
  margin-bottom: 0;
}
.whom-foot-dec {
  display: flex;
  color: var(--color-gold);
  opacity: 0.65;
  flex-shrink: 0;
}
.whom-foot-dec--flip {
  transform: scaleX(-1);
}
.whom-foot-text {
  font-family: var(--font-sans);
  font-size: clamp(var(--text-md), 2.6vw, var(--text-lg));
  line-height: var(--leading-relaxed);
  letter-spacing: var(--tracking-tight);
  color: rgba(58, 44, 50, 0.82);
  max-width: 28em;
}

@media (min-width: 900px) {
  .whom-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 22px;
  }
  .closing-lead {
    margin-bottom: clamp(40px, 5vw, 52px);
  }
}

@media (min-width: 1024px) {
  .whom-card {
    padding: 30px 26px 28px;
  }
}

/* ======================================================
   Footer
====================================================== */
.footer {
  padding: 40px 0 80px;
  border-top: 1px solid var(--color-line);
  background: var(--color-bg);
}
.footer-brand {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  gap: clamp(14px, 3vw, 28px);
  flex-wrap: nowrap;
}
.footer-logo {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0;
  margin-bottom: 0;
  flex-shrink: 0;
}
.footer-logo-lockup {
  height: 48px;
  width: auto;
  max-width: min(100%, 340px);
  display: block;
  object-fit: contain;
  object-position: left center;
}
.footer-info {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: var(--weight-sans-regular);
  letter-spacing: var(--tracking-tight);
  color: var(--color-mute);
  line-height: 1.45;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 4px;
  text-align: left;
  min-width: 0;
}
.footer-info p {
  margin: 0;
}
.footer-info__link {
  color: var(--color-gold-deep);
  text-decoration: underline;
  text-underline-offset: 3px;
  font-weight: var(--weight-sans-semibold);
}
.footer-info__link:hover {
  color: var(--color-ink);
}

@media (max-width: 767px) {
  .footer-brand {
    align-items: center;
    gap: clamp(12px, 3.2vw, 20px);
  }
  .footer-logo-lockup {
    height: 44px;
    max-width: min(42vw, 200px);
  }
  .footer-info {
    font-size: var(--text-2xs);
    gap: 3px;
  }
}

@media (min-width: 1024px) {
  .footer-logo-lockup {
    height: 56px;
    max-width: 380px;
  }
}

/* ======================================================
   Reveal 애니메이션 (IntersectionObserver 연동)
====================================================== */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.8s var(--ease), transform 0.8s var(--ease);
}
.reveal.in { opacity: 1; transform: none; }

/* ======================================================
   Responsive breakpoints
====================================================== */
@media (min-width: 768px) {
  :root {
    --container-max: 720px;
    --text-base: 16px;
    --text-md: 15px;
    --text-sm: 14px;
  }
}
@media (min-width: 1024px) {
  :root { --container-max: 1080px; --space-section: 140px; }
  .container    { padding: 0 40px; }
  .nav-inner    { height: 72px; }
  .nav-logo-lockup { height: 50px; max-width: 360px; }
}
@media (min-width: 1440px) {
  :root { --container-max: 1200px; }
}

/* ======================================================
   Mobile polish (≤639px) — 여백·내비·히어로·풀블리드 블록
====================================================== */
@media (max-width: 639px) {
  :root {
    --pad-page: 16px;
    --space-section-mobile: 46px;
  }

  body {
    -webkit-tap-highlight-color: rgba(194, 160, 155, 0.14);
  }

  .container {
    padding-left: var(--pad-page);
    padding-right: var(--pad-page);
  }

  /* 고정 내비: 가로 스크롤은 유지하되 스크롤바 숨김 */
  .nav-inner {
    padding: 8px var(--pad-page);
    min-height: 58px;
    gap: 10px;
  }
  .nav-quick {
    scrollbar-width: none;
    -ms-overflow-style: none;
    gap: 6px 12px;
  }
  .nav-quick::-webkit-scrollbar {
    display: none;
    width: 0;
    height: 0;
  }
  .nav-quick-link {
    font-size: var(--text-xs);
    font-weight: 600;
    padding: 10px 5px;
  }
  .nav-quick-btn {
    font-size: var(--text-xs);
    padding: 10px 14px;
    min-height: 40px;
  }
  /* 햄버거 드로어(≤767)와 충돌하지 않도록 좌측 보더·들여쓰기 제거 */
  .nav-quick-actions {
    margin-left: 0;
    padding-left: 0;
    gap: 8px;
  }

  /* 앵커 스크롤 시 고정 헤더에 가리지 않도록 */
  #how-samples {
    scroll-margin-top: 88px;
  }
  #tts-model,
  #tts-sig-before,
  #feat-flow,
  #pricing,
  #for-whom,
  #cta {
    scroll-margin-top: 84px;
  }

  /* 기능 플로우: 좌우 마진 제거로 모바일에서 단정한 전폭 블록 */
  .feat-flow {
    width: 100%;
    max-width: none;
    margin-left: 0;
    margin-right: 0;
    border-radius: 0;
    border-left: none;
    border-right: none;
    padding-left: var(--pad-page);
    padding-right: var(--pad-page);
    padding-top: 26px;
    padding-bottom: 22px;
    box-shadow: none;
  }

  .pricing {
    padding-top: clamp(32px, 8vw, 48px);
    padding-bottom: clamp(40px, 9vw, 64px);
  }
  .pricing-board {
    border-radius: 16px;
  }
  .pricing-dual {
    padding-left: 12px;
    padding-right: 12px;
  }

  .closing-lead {
    margin-top: 8px;
    margin-bottom: 20px;
    font-size: clamp(13px, 3.2vw, 15px);
  }
  /* FOR WHOM: 모바일에서 3카드 한눈에 (가로 3열·컴팩트) */
  .container--whom {
    padding-left: max(10px, calc(var(--pad-page) - 4px));
    padding-right: max(10px, calc(var(--pad-page) - 4px));
  }
  .whom-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    align-items: stretch;
  }
  .whom-card {
    padding: 12px 6px 14px;
    border-radius: 14px;
    min-width: 0;
  }
  .whom-card-num {
    font-size: clamp(18px, 5.2vw, 24px);
    margin-bottom: 6px;
    align-self: center;
  }
  .whom-card-icon-wrap {
    width: 44px;
    height: 44px;
    margin-bottom: 8px;
  }
  .whom-card-icon svg {
    width: 20px;
    height: 20px;
  }
  .whom-card-icon .whom-ic-envelope {
    width: 22px;
    height: 22px;
  }
  .whom-ic-heart {
    right: 5px;
    bottom: 8px;
    width: 9px;
    height: 9px;
  }
  .whom-spark--tr {
    top: 4px;
    right: 4px;
  }
  .whom-spark--bl {
    bottom: 4px;
    left: 4px;
  }
  .whom-card-lead::after {
    display: none;
  }
  .whom-card-lead {
    font-size: clamp(10px, 2.85vw, 12px);
    font-weight: 700;
    letter-spacing: var(--tracking-head);
    line-height: 1.28;
    margin-bottom: 0;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 4;
    line-clamp: 4;
    overflow: hidden;
    text-align: center;
    word-break: keep-all;
  }
  .whom-card-desc {
    display: none;
  }
  .whom-card-tag {
    display: inline-flex;
    margin-bottom: 6px;
    padding: 5px 7px;
    font-size: clamp(6.5px, 2.1vw, 9px);
    letter-spacing: 0.06em;
    line-height: 1.2;
  }

  .how-title {
    margin-bottom: 14px;
  }
  .how-title-lockup {
    max-width: 100%;
  }

  .closing-head {
    margin-bottom: clamp(28px, 8vw, 40px);
  }
  .closing-steps-scroll {
    margin: 0 calc(-1 * var(--pad-page));
    padding: 0 var(--pad-page) 8px;
  }
  .closing-cta-card {
    padding: clamp(22px, 5vw, 32px) clamp(18px, 4vw, 28px);
    border-radius: 18px;
  }

  .tts-model-head {
    margin-bottom: clamp(22px, 5vw, 32px);
  }
  .tts-pipeline-board {
    padding: clamp(16px, 4vw, 24px) clamp(14px, 3.5vw, 22px);
  }

  .footer {
    padding: 32px 0 max(40px, calc(env(safe-area-inset-bottom, 0px) + 28px));
  }

  .feat-det-summary {
    padding: 16px 14px;
    min-height: 48px;
    align-items: center;
  }
  .feat-det-card {
    border-radius: 12px;
  }
}

@media (max-width: 639px) and (min-width: 400px) {
  :root {
    --pad-page: 18px;
  }
}

@media (max-width: 767px) {
  .hero-content {
    padding-top: max(72px, calc(env(safe-area-inset-top, 0px) + 56px));
    padding-left: max(var(--pad-page, 16px), env(safe-area-inset-left, 0px));
    padding-right: max(var(--pad-page, 16px), env(safe-area-inset-right, 0px));
    padding-bottom: max(28px, env(safe-area-inset-bottom, 0px));
  }
  .hero-mark {
    margin-bottom: 22px;
    letter-spacing: 0.42em;
    font-size: 10px;
  }
  .hero-title {
    font-size: clamp(40px, 11.5vw, 72px);
    margin-bottom: 18px;
    line-height: 1.08;
  }
  .hero-sub {
    margin-bottom: 32px;
    font-size: 13px;
    line-height: var(--leading-loose);
    max-width: 22em;
  }
  .hero-cta {
    padding: 14px 26px;
    font-size: 13px;
    min-height: 46px;
  }
}

/* ======================================================
   OUR STORY — PC 등 넓은 뷰포트에서도 확실히 적용 (파일 말단)
====================================================== */
@media (min-width: 768px) {
  article.feat-core-card.feat-core-card--story {
    flex-direction: row-reverse;
    align-items: stretch;
  }
  article.feat-core-card.feat-core-card--story > .feat-core-visual-details {
    display: flex;
    flex-direction: column;
    flex: 1 1 36%;
    min-width: 0;
    align-self: stretch;
    border-top: none;
    border-right: 1px solid rgba(222, 201, 196, 0.65);
  }
  article.feat-core-card.feat-core-card--story > .feat-core-body.feat-core-body--story,
  article.feat-core-card.feat-core-card--story > #feat-story-body {
    flex: 1 1 64%;
    min-width: 0;
  }
  article.feat-core-card.feat-core-card--story .feat-core-visual {
    flex: 1 1 auto;
    align-items: center;
    justify-content: center;
    min-height: 0;
  }
}

@media (min-width: 1024px) {
  #feat-story-body {
    padding: clamp(36px, 3.4vw, 56px) clamp(22px, 2.2vw, 36px) clamp(16px, 1.8vw, 24px) !important;
  }
}
