/* Reset + Base */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--font-sans);
  /* Purple Haze radial — 전체 페이지에 보라 글로우 배경 */
  background: var(--page-bg-radial);
  background-attachment: fixed;
  color: var(--text-primary);
  line-height: 1.6;
  font-size: var(--text-base);
  -webkit-font-smoothing: antialiased;
  /* Sticky footer — main 이 남은 공간을 채워 footer 가 항상 바닥에 */
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}
main { flex: 1 0 auto; }
.site-footer { flex-shrink: 0; }
a { color: var(--color-accent-soft); text-decoration: none; transition: color var(--duration-fast); }
a:hover { color: var(--accent-hover); }

.container {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--space-6);
}

/* Header — Liquid Glass */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: var(--glass-bg);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border-bottom: 1px solid var(--glass-border);
}
.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4) var(--space-6);
  min-height: 64px;
}
.brand { display: flex; align-items: center; gap: var(--space-2); color: var(--text-primary); font-weight: 700; }
.brand-mark { color: var(--accent-hover); font-size: var(--text-md); }
.brand-name { font-size: var(--text-md); }
.nav-main { display: flex; align-items: center; gap: var(--space-6); }
.nav-main a { color: var(--text-secondary); font-size: var(--text-sm); }
.nav-main a:hover { color: var(--text-primary); }
.nav-main .cta-link {
  background: var(--color-accent);
  color: white;
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-full);
  font-weight: 600;
}
.nav-main .cta-link:hover { background: var(--accent-hover); color: white; }

/* Hero — Vercel 풍 멀티 라디얼 광원 + 여유로운 여백 */
.hero {
  padding: clamp(120px, 14vw, 180px) 0 clamp(96px, 12vw, 140px);
  position: relative;
  text-align: center;
  overflow: hidden;
  isolation: isolate;
}
/* 메인 보라 광원 — hero 중앙 위에서 강하게 */
.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 1200px 800px at 50% 25%,
      rgba(156, 38, 24, 0.40) 0%,
      rgba(156, 38, 24, 0.20) 30%,
      rgba(156, 38, 24, 0.08) 55%,
      transparent 75%),
    radial-gradient(circle 600px at 50% 50%,
      rgba(214, 186, 180, 0.18) 0%,
      transparent 70%);
  pointer-events: none;
  z-index: -2;
}
/* 보조 오렌지 광원 (CLAUDE 쪽) — 따뜻한 액센트 */
.hero::after {
  content: "";
  position: absolute;
  top: 10%;
  left: -10%;
  width: 60%;
  height: 50%;
  background: radial-gradient(ellipse at 30% 40%,
    rgba(217, 119, 87, 0.22) 0%,
    rgba(217, 119, 87, 0.08) 35%,
    transparent 65%);
  pointer-events: none;
  z-index: -2;
  filter: blur(20px);
}
.hero-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(var(--space-5), 2.5vw, var(--space-8));
  position: relative;
  z-index: 1;
}
.badge-scarcity {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  background: var(--bg-elevated);
  border: 1px solid var(--border-subtle);
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-full);
  font-size: var(--text-sm);
  color: var(--text-secondary);
}
.badge-scarcity .dot {
  width: 8px;
  height: 8px;
  background: var(--color-success);
  border-radius: 50%;
  animation: pulse 1.8s infinite;
}
@keyframes pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.4; }
}
.hero-title {
  font-size: clamp(var(--text-display-sm), 6vw, var(--text-display-lg));
  line-height: 1.15;
  font-weight: 800;
  margin: 0;
  background: linear-gradient(135deg, var(--text-primary) 0%, var(--color-accent-soft) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Equation hero — Claude icon × Mac icon = SUPERPOWER (한 줄 임팩트) */
.hero-title.hero-equation {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(0.5rem, 2vw, 1.4rem);
  flex-wrap: wrap;
  /* equation 변형은 단어별 색을 별도 지정하므로 gradient text-clip 해제 */
  background: none;
  -webkit-background-clip: initial;
  background-clip: initial;
  -webkit-text-fill-color: initial;
  color: var(--text-primary);
  font-size: clamp(3rem, 9vw, 6rem);
  font-weight: 900;
  line-height: 1;
  letter-spacing: -0.02em;
}
.hero-icon {
  width: clamp(56px, 10vw, 104px);
  height: clamp(56px, 10vw, 104px);
  flex-shrink: 0;
  filter: drop-shadow(0 0 24px var(--accent-glow));
}
.hero-icon-claude { color: #D97757; }  /* Anthropic 시그니처 orange */
.hero-icon-mac { color: var(--text-primary); }
.hero-op {
  font-family: var(--font-mono);
  font-weight: 500;
  font-size: 0.5em;
  color: var(--text-tertiary);
  flex-shrink: 0;
  align-self: center;
}
/* 마지막 등호는 다음 줄로 — 결과 라벨이 새 줄에 강조 표시되게 */
.hero-op--break {
  flex: 0 0 100%;
  text-align: center;
  margin: var(--space-1) 0;
}
.hero-label {
  flex: 0 0 100%;
  text-align: center;
  background: linear-gradient(135deg, var(--text-primary) 0%, var(--color-accent-soft) 55%, var(--color-accent) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  letter-spacing: 0;
}

/* hero-equation v2 — Claude + Mac = 크리에이터를 위한 두번째 뇌 (한국어 라벨, 14자) */
.hero-equation--v2 .hero-label {
  font-size: clamp(2.2rem, 6.5vw, 4.2rem);
  line-height: 1.15;
  letter-spacing: -0.015em;
  word-break: keep-all;
  padding: 0 var(--space-2);
}

/* ─────────────────────────────────────────────────────────────
   hero-equation v3 — CLAUDE × MAC = SECOND BRAIN
   메가 디스플레이 타이포 (Descript / Beehiiv 패턴)
   ───────────────────────────────────────────────────────────── */
.hero-title.hero-equation--v3 {
  display: flex;
  align-items: baseline;
  justify-content: center;
  flex-wrap: wrap;
  gap: clamp(0.6rem, 2vw, 1.2rem);
  font-weight: 900;
  line-height: 0.92;
  letter-spacing: -0.045em;
  text-transform: uppercase;
  margin: 0;
  position: relative;
  background: none;
  -webkit-background-clip: initial;
  background-clip: initial;
  -webkit-text-fill-color: initial;
  color: var(--text-primary);
}

.hero-equation--v3 .hero-eq-term {
  display: inline-block;
  font-weight: 900;
  line-height: 0.95;
}

/* CLAUDE × MAC — eyebrow 톤, 차분히 (정점은 BRAIN) */
.hero-equation--v3 .hero-eq-term--claude,
.hero-equation--v3 .hero-eq-term--mac {
  font-size: clamp(2.4rem, 6.5vw, 4.6rem);
  color: rgba(255, 255, 255, 0.92);
  filter: drop-shadow(0 0 28px rgba(255, 255, 255, 0.18));
}
.hero-equation--v3 .hero-eq-term--claude {
  /* CLAUDE에만 Anthropic 시그니처 오렌지 — 살짝 강조 */
  color: transparent;
  background: linear-gradient(135deg, #FFB088 0%, #E89067 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  filter: drop-shadow(0 0 32px rgba(217, 119, 87, 0.35));
}

/* SECOND BRAIN — 메가 사이즈 시선 정점 */
.hero-equation--v3 .hero-eq-term--brain {
  flex: 0 0 100%;
  text-align: center;
  font-size: clamp(3.6rem, 12vw, 8.5rem);
  letter-spacing: -0.055em;
  line-height: 0.9;
  background: linear-gradient(180deg,
    #ffffff 0%,
    #ffffff 30%,
    #d4c5ff 60%,
    var(--color-accent-soft) 85%,
    var(--color-accent) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  filter: drop-shadow(0 0 48px rgba(156, 38, 24, 0.6))
          drop-shadow(0 0 120px rgba(156, 38, 24, 0.35))
          drop-shadow(0 0 200px rgba(156, 38, 24, 0.18));
  margin-top: clamp(0.2rem, 0.8vw, 0.7rem);
}

/* 연산자 × = — 차분한 mono */
.hero-equation--v3 .hero-op {
  font-family: var(--font-mono);
  font-weight: 300;
  color: rgba(255, 255, 255, 0.32);
  letter-spacing: 0.08em;
  align-self: center;
  line-height: 1;
}
.hero-equation--v3 .hero-op--mul {
  font-size: clamp(1.4rem, 3.5vw, 2.4rem);
  align-self: center;
  transform: translateY(-0.02em);
}
.hero-equation--v3 .hero-op--eq {
  flex: 0 0 100%;
  text-align: center;
  font-size: clamp(1.2rem, 2.6vw, 1.8rem);
  color: rgba(156, 38, 24, 0.5);
  margin: clamp(0.1rem, 0.6vw, 0.4rem) 0;
  font-weight: 400;
}

/* hero-equation v3 — 상하 위계 꺽쇠 (Down chevron) */
.hero-equation--v3 .hero-chevron-wrap {
  flex: 0 0 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: clamp(0.8rem, 2vw, 1.4rem) 0 clamp(0.4rem, 1vw, 0.7rem);
}
.hero-equation--v3 .hero-chevron {
  display: block;
  width: clamp(44px, 5vw, 64px);
  height: auto;
  filter: drop-shadow(0 0 12px rgba(156, 38, 24, 0.55))
          drop-shadow(0 0 28px rgba(156, 38, 24, 0.28));
  animation: heroChevronPulse 2.6s cubic-bezier(0.4, 0, 0.2, 1) infinite;
}
@keyframes heroChevronPulse {
  0%, 100% { transform: translateY(0); opacity: 0.92; }
  50%      { transform: translateY(5px); opacity: 1; }
}
@media (prefers-reduced-motion: reduce) {
  .hero-equation--v3 .hero-chevron { animation: none; }
}

/* 보조 한국어 카피 */
.hero-equation-sub {
  margin: var(--space-5) 0 var(--space-2);
  font-size: clamp(1rem, 1.4vw, 1.2rem);
  color: var(--text-secondary);
  text-align: center;
  letter-spacing: 0.02em;
  font-weight: 500;
  text-transform: none;
}

/* 통합 이미지 슬롯 — 라이언이 등식 이미지 만들어 박을 때 사용 */
.hero-equation-img {
  display: block;
  max-width: min(720px, 90vw);
  width: 100%;
  height: auto;
  margin: 0 auto;
  filter: drop-shadow(0 0 24px var(--accent-glow));
}

/* Hero — Discord mockup (등식 직하 product feel) */
.hero-mockup {
  width: 100%;
  max-width: 520px;
  margin: var(--space-6) auto var(--space-3);
}
/* Hero mockup — 테두리 부드럽게, 배경에 스미는 글래스 톤 */
.hero-mockup .mock-ui--discord {
  border: 1px solid rgba(156, 38, 24, 0.14);
  background: rgba(49, 51, 56, 0.55);
  backdrop-filter: blur(24px) saturate(140%);
  -webkit-backdrop-filter: blur(24px) saturate(140%);
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.32),
              0 0 120px rgba(156, 38, 24, 0.08);
}
.hero-mockup .mock-discord-channel {
  background: rgba(43, 45, 49, 0.5);
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}
.hero-mockup-caption {
  margin: var(--space-3) 0 0;
  font-size: var(--text-sm);
  color: var(--text-secondary);
  text-align: center;
  letter-spacing: 0.01em;
  line-height: 1.55;
}
.hero-mockup-caption-sub {
  display: inline-block;
  margin-top: 2px;
  font-size: var(--text-xs);
  color: var(--text-tertiary);
}

/* Hero — 사용처 chip grid + 아코디언 (Riverside 패턴) */
.hero-chips-block {
  margin: var(--space-6) auto var(--space-2);
  max-width: 760px;
  width: 100%;
}
.hero-chips-label {
  margin: 0 0 var(--space-3);
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  text-align: center;
  font-family: var(--font-mono);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.hero-chips {
  display: flex;
  flex-direction: column;
  gap: 6px;
  align-items: center;
}
.hero-chips-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: center;
}
.hero-chip {
  appearance: none;
  display: inline-block;
  padding: 7px 16px;
  font-size: var(--text-sm);
  font-weight: 600;
  font-family: inherit;
  background: rgba(156, 38, 24, 0.08);
  border: 1px solid rgba(156, 38, 24, 0.28);
  border-radius: var(--radius-full);
  color: var(--text-primary);
  letter-spacing: 0.005em;
  cursor: pointer;
  transition: background var(--duration-fast),
              border-color var(--duration-fast),
              transform var(--duration-fast),
              color var(--duration-fast);
}
.hero-chip:hover {
  background: rgba(156, 38, 24, 0.18);
  border-color: var(--color-accent);
  transform: translateY(-1px);
}
.hero-chip.active {
  background: var(--gradient-accent);
  color: var(--on-accent);
  border-color: transparent;
  font-weight: 700;
  box-shadow: 0 4px 16px rgba(156, 38, 24, 0.35);
}

/* 아코디언 패널 — chip 아래 펼쳐짐 */
.hero-chip-panels {
  margin-top: var(--space-5);
  min-height: 0;
}
.hero-chips-block .hero-chip-panel {
  display: none !important;
}
.hero-chips-block .hero-chip-panel.open {
  display: block !important;
  animation: chipPanelIn 0.28s cubic-bezier(0.2, 0.8, 0.2, 1);
}
@keyframes chipPanelIn {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}
.hero-chip-panel-inner {
  max-width: 720px;
  margin: 0 auto;
  padding: var(--space-5);
  background: var(--glass-bg);
  border: 1px solid rgba(156, 38, 24, 0.3);
  border-radius: var(--radius-xl);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.2);
}

.chip-mockup-row {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: var(--space-3);
  align-items: stretch;
}
.chip-mockup-row .mock-ui--discord {
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.3);
}
.chip-arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: clamp(1.4rem, 2.4vw, 2rem);
  font-weight: 800;
  background: var(--gradient-accent);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  line-height: 1;
  padding: 0 var(--space-2);
}

/* 에이전트 답장 mock — 채널 헤더 생략, 메시지만 표시 */
.mock-discord-user--agent {
  background: var(--gradient-accent);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.mock-discord-avatar--designer {
  background: linear-gradient(135deg, #ec4899 0%, #f59e0b 100%);
}
.mock-discord-avatar--writer {
  background: linear-gradient(135deg, #9c2618 0%, #3b82f6 100%);
}
.mock-discord-avatar--developer {
  background: linear-gradient(135deg, #10b981 0%, #06b6d4 100%);
}
.mock-discord-avatar--brain {
  background: linear-gradient(135deg, #f59e0b 0%, #eab308 100%);
}
.mock-discord-avatar--assistant {
  background: linear-gradient(135deg, #9c2618 0%, #b8442e 100%);
}

@media (max-width: 768px) {
  .chip-mockup-row { grid-template-columns: 1fr; }
  .chip-arrow { transform: rotate(90deg); padding: var(--space-1) 0; }
  .hero-chip-panel-inner { padding: var(--space-4) var(--space-3); }
}

/* chip panel 안의 Discord mock — 폰트 한 단계 작게 (chip 폭 좁음) */
.hero-chip-panel-inner .mock-discord-channel {
  padding: 7px 11px;
}
.hero-chip-panel-inner .mock-discord-icon { font-size: 14px; }
.hero-chip-panel-inner .mock-discord-channelname { font-size: 12px; }
.hero-chip-panel-inner .mock-discord-message {
  padding: 11px 12px;
  gap: 9px;
}
.hero-chip-panel-inner .mock-discord-avatar {
  width: 30px;
  height: 30px;
  font-size: 12px;
}
.hero-chip-panel-inner .mock-discord-user { font-size: 12px; }
.hero-chip-panel-inner .mock-discord-time { font-size: 10px; }
.hero-chip-panel-inner .mock-discord-text {
  font-size: var(--text-sm);
  font-weight: 500;
  line-height: 1.55;
  text-align: left;
  padding: 0;
  text-indent: 0;
}
.hero-chip-panel-inner .mock-discord-content {
  display: flex;
  flex-direction: column;
  gap: 4px;
  align-items: flex-start;
}
.hero-sub {
  font-size: var(--text-md);
  color: var(--text-secondary);
  max-width: 640px;
  margin: 0;
}
.hero-cta {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
  justify-content: center;
  margin-top: var(--space-4);
}
.hero-note {
  font-size: var(--text-sm);
  color: var(--text-tertiary);
  margin-top: var(--space-2);
}

/* Buttons */
.btn-primary, .btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-3) var(--space-8);
  border-radius: var(--radius-full);
  font-weight: 700;
  font-size: var(--text-base);
  border: 1px solid transparent;
  cursor: pointer;
  transition: all var(--duration-normal);
  text-decoration: none;
}
.btn-primary {
  background: var(--gradient-accent);
  color: var(--on-accent);
  box-shadow: var(--shadow-md), var(--shadow-glow);
}
.btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg), var(--accent-glow);
  color: var(--on-accent);
}
.btn-secondary {
  background: var(--bg-elevated);
  color: var(--text-primary);
  border-color: var(--border-subtle);
}
.btn-secondary:hover {
  background: var(--bg-elevated-2);
  color: var(--text-primary);
}
.btn-primary.block, .btn-secondary.block {
  width: 100%;
  margin-top: var(--space-6);
}

/* Depth Tiers — 3단계 사용자 깊이 (가벼운 → 모바일 → 프로 도구) */
.depth-tiers { padding: var(--space-16) 0 var(--space-12); }
.section-sub {
  text-align: center;
  color: var(--text-secondary);
  font-size: var(--text-md);
  margin: calc(var(--space-12) * -1 + var(--space-2)) 0 var(--space-12);
  max-width: 640px;
  margin-left: auto;
  margin-right: auto;
}
.tier-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
}
.tier-card {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-2xl);
  padding: var(--space-8) var(--space-6);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  transition: border-color var(--duration-normal),
              background var(--duration-normal),
              box-shadow var(--duration-normal),
              transform var(--duration-normal) var(--ease-spring);
}
.tier-card:hover {
  transform: translateY(var(--hover-lift));
  background: var(--glass-bg-hi);
  border-color: var(--glass-border-hi);
  box-shadow: var(--glass-shadow), var(--glass-glow);
}
.tier-num {
  font-family: var(--font-mono);
  font-size: var(--text-display-sm);
  font-weight: 800;
  background: var(--gradient-accent);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  letter-spacing: -0.02em;
  line-height: 1;
}
.tier-title {
  margin: 0;
  font-size: var(--text-md);
  font-weight: 700;
  color: var(--text-primary);
}
.tier-text {
  margin: 0;
  font-size: var(--text-sm);
  line-height: 1.6;
  color: var(--text-secondary);
}
.tier-note {
  display: inline-block;
  margin-top: var(--space-3);
  padding: 2px var(--space-2);
  font-size: var(--text-xs);
  font-family: var(--font-mono);
  letter-spacing: 0.04em;
  border-radius: var(--radius-sm);
  background: var(--accent-bg);
  color: var(--color-accent-soft);
}

@media (max-width: 1024px) {
  .tier-list { grid-template-columns: 1fr 1fr; }
  .tier-card:nth-child(3) { grid-column: 1 / -1; max-width: 480px; margin: 0 auto; width: 100%; }
}
@media (max-width: 640px) {
  .tier-list { grid-template-columns: 1fr; }
  .tier-card:nth-child(3) { grid-column: auto; max-width: none; }
}

/* Day Flow — hero 직후 시나리오 timeline (라이언 voice: 추상 베네핏 → 구체 하루) */
.day-flow { padding: var(--space-12) 0 var(--space-16); }
.day-list {
  list-style: none;
  counter-reset: day-step;
  padding: 0;
  margin: 0 auto;
  max-width: 720px;
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.day-list::before {
  /* 좌측 세로 연결선 */
  content: "";
  position: absolute;
  left: 28px;
  top: 28px;
  bottom: 28px;
  width: 2px;
  background: linear-gradient(180deg, var(--glass-border-hi), var(--glass-border) 40%, transparent);
  pointer-events: none;
}
.day-step {
  counter-increment: day-step;
  position: relative;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  padding: var(--space-4) var(--space-6) var(--space-4) 72px;
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  transition: border-color var(--duration-normal),
              background var(--duration-normal),
              box-shadow var(--duration-normal);
}
.day-step::before {
  /* 좌측 dot — 단계 번호 */
  content: counter(day-step);
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--gradient-accent);
  color: var(--on-accent);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: var(--text-sm);
  font-family: var(--font-mono);
  box-shadow: var(--accent-glow);
}
.day-step:hover {
  background: var(--glass-bg-hi);
  border-color: var(--glass-border-hi);
  box-shadow: var(--glass-shadow);
}
.day-step-label {
  display: inline-block;
  font-size: var(--text-xs);
  font-family: var(--font-mono);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--color-accent-soft);
  margin-bottom: var(--space-2);
}
.day-step-text {
  margin: 0;
  font-size: var(--text-base);
  line-height: 1.6;
  color: var(--text-primary);
}
.day-step-text strong {
  color: var(--color-accent-soft);
  font-weight: 700;
}

@media (max-width: 640px) {
  .day-list::before { left: 20px; }
  .day-step { padding-left: 56px; }
  .day-step::before { left: 4px; width: 28px; height: 28px; font-size: var(--text-xs); }
}

/* Section Common */
.section-title {
  font-size: var(--text-display-sm);
  text-align: center;
  margin: 0 0 var(--space-12);
  font-weight: 700;
}
section { padding: var(--space-16) 0; }

/* Agents — 5명 카드 (라이언 2026-05-19):
   데스크탑은 5열 한 줄, 태블릿은 3+2 두 줄, 모바일은 1열. */
.agents { padding: var(--space-16) 0; }
.agent-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--space-4);
}
.agent-card {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  text-align: center;
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  transition: transform var(--duration-normal) var(--ease-spring),
              border-color var(--duration-normal),
              background var(--duration-normal),
              box-shadow var(--duration-normal);
}
.agent-card:hover {
  transform: translateY(var(--hover-lift));
  background: var(--glass-bg-hi);
  border-color: var(--glass-border-hi);
  box-shadow: var(--glass-shadow), var(--glass-glow);
}
.agent-icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--color-accent) 0%, var(--color-accent-soft) 100%);
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--text-lg);
  font-weight: 800;
  margin: 0 auto var(--space-4);
}
.agent-card h3 { margin: 0 0 var(--space-2); font-size: var(--text-md); }
.agent-card p { color: var(--text-secondary); font-size: var(--text-sm); margin: 0; }

/* Pricing — 3 공개 plan 카드 (Lite / Pro / Creator, 2026-05-21 최종) + Creator Club 비공개 */
.pricing { padding: var(--space-16) 0 var(--space-12); }

/* 공통 features (모든 plan 동일) */
.features-common {
  max-width: 720px;
  margin: 0 auto var(--space-12);
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
}
.features-common-label {
  margin: 0 0 var(--space-4);
  font-size: var(--text-sm);
  font-family: var(--font-mono);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--color-accent-soft);
  text-align: center;
}
.features-common-list {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-4);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--space-3);
}
.features-common-list li {
  color: var(--text-secondary);
  font-size: var(--text-sm);
  padding-left: var(--space-4);
  position: relative;
}
.features-common-list li::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--color-success);
  font-weight: 700;
}
.features-common-list strong {
  color: var(--text-primary);
  margin-right: var(--space-1);
}
.features-common-foot {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--text-tertiary);
  text-align: center;
  padding-top: var(--space-3);
  border-top: 1px solid var(--glass-border);
}

/* Cost Structure — 포함/별도 2 블록 (가격 카드 위 강조) */
.cost-structure {
  max-width: 880px;
  margin: 0 auto var(--space-12);
}
.cost-structure-title {
  margin: 0 0 var(--space-4);
  font-size: var(--text-sm);
  font-family: var(--font-mono);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--color-accent-soft);
  text-align: center;
}
.cost-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
}
@media (max-width: 768px) {
  .cost-grid { grid-template-columns: 1fr; }
}

.cost-block {
  padding: var(--space-6);
  border-radius: var(--radius-xl);
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.cost-block--included {
  background: linear-gradient(180deg,
    rgba(156, 38, 24, 0.12) 0%,
    rgba(156, 38, 24, 0.04) 100%);
  border-color: var(--color-accent);
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.2), 0 0 32px rgba(156, 38, 24, 0.16);
}

.cost-block-stage {
  display: inline-block;
  align-self: flex-start;
  padding: 4px 10px;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  border-radius: var(--radius-sm);
}
.cost-block--included .cost-block-stage {
  background: var(--gradient-accent);
  color: var(--on-accent);
}
.cost-block--external .cost-block-stage {
  background: rgba(255, 255, 255, 0.08);
  color: var(--text-tertiary);
}

.cost-block-title {
  margin: 0;
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--text-primary);
  line-height: 1.3;
}

.cost-block-price {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--text-secondary);
}
.cost-block-price strong {
  color: var(--text-primary);
  font-size: var(--text-md);
  font-weight: 800;
}
.cost-block--included .cost-block-price strong {
  background: var(--gradient-accent);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.cost-block-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.cost-block-list li {
  font-size: var(--text-sm);
  line-height: 1.55;
  color: var(--text-secondary);
  padding-left: 14px;
  position: relative;
}
.cost-block-list li::before {
  content: "·";
  position: absolute;
  left: 4px;
  color: var(--color-accent-soft);
  font-weight: 700;
}
.cost-block-list li strong {
  color: var(--text-primary);
  font-weight: 700;
}

.cost-structure-foot {
  margin: var(--space-5) auto 0;
  max-width: 720px;
  padding: var(--space-3) var(--space-5);
  background: rgba(156, 38, 24, 0.06);
  border-left: 2px solid var(--color-accent);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  font-size: var(--text-sm);
  line-height: 1.6;
  color: var(--text-secondary);
  text-align: left;
}
.cost-structure-foot strong { color: var(--color-accent-soft); }

/* Cost Summary — 가벼운 2줄 인라인 비교 (모바일 헤비 해소) */
.cost-summary {
  max-width: 640px;
  margin: 0 auto var(--space-8);
  padding: var(--space-4) var(--space-5);
  background: rgba(156, 38, 24, 0.05);
  border: 1px solid rgba(156, 38, 24, 0.18);
  border-radius: var(--radius-lg);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.cost-summary-line {
  margin: 0;
  font-size: var(--text-sm);
  line-height: 1.55;
  color: var(--text-secondary);
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
}
.cost-summary-text {
  flex: 1;
  word-break: keep-all;
}
.cost-summary-text strong {
  color: var(--text-primary);
  font-weight: 700;
}
.cost-summary-tag {
  flex-shrink: 0;
  padding: 3px 9px;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  border-radius: var(--radius-sm);
  line-height: 1.3;
}
.cost-summary-tag--in {
  background: var(--gradient-accent);
  color: var(--on-accent);
}
.cost-summary-tag--out {
  background: rgba(255, 255, 255, 0.08);
  color: var(--text-tertiary);
}

/* ─────────────────────────────────────────────────────────────
   한국어 자연 개행 — 단어 단위 break (모바일 어색 개행 방지, 2026-06-08)
   영문 code/prompt 블록은 예외 처리.
   ───────────────────────────────────────────────────────────── */
h1, h2, h3, h4, h5, h6,
p, li, dt, dd, blockquote,
.section-title, .section-sub {
  word-break: keep-all;
  overflow-wrap: break-word;
}

code,
pre,
pre code,
.compare-prompt code,
.mock-web-body pre code {
  word-break: normal;
  overflow-wrap: anywhere;
}

/* ─────────────────────────────────────────────────────────────
   Floating CTA — 우측 하단 고정, 디자인 토큰 정합 + 글래스+글로우
   ───────────────────────────────────────────────────────────── */
.floating-cta {
  position: fixed;
  bottom: clamp(16px, 2.4vw, 28px);
  right: clamp(16px, 2.4vw, 28px);
  z-index: 100;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: clamp(12px, 1.4vw, 16px) clamp(20px, 2vw, 26px);
  background: var(--gradient-accent);
  color: var(--on-accent);
  font-weight: 700;
  font-size: var(--text-base);
  letter-spacing: 0.005em;
  border-radius: var(--radius-full);
  text-decoration: none;
  border: 1px solid rgba(255, 255, 255, 0.12);
  box-shadow:
    0 12px 32px rgba(0, 0, 0, 0.35),
    0 0 32px rgba(156, 38, 24, 0.45),
    0 0 72px rgba(156, 38, 24, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.15);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  opacity: 0;
  transform: translateY(24px) scale(0.96);
  pointer-events: none;
  transition: opacity 0.4s var(--ease-spring),
              transform 0.4s var(--ease-spring),
              box-shadow var(--duration-fast);
}
.floating-cta.visible {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}
.floating-cta:hover {
  color: var(--on-accent);
  transform: translateY(-3px) scale(1.03);
  box-shadow:
    0 16px 40px rgba(0, 0, 0, 0.4),
    0 0 48px rgba(156, 38, 24, 0.6),
    0 0 96px rgba(156, 38, 24, 0.32),
    inset 0 1px 0 rgba(255, 255, 255, 0.2);
}
.floating-cta-arrow {
  display: inline-block;
  font-weight: 800;
  transition: transform var(--duration-fast);
}
.floating-cta:hover .floating-cta-arrow {
  transform: translateX(3px);
}

@media (max-width: 480px) {
  .floating-cta {
    padding: 11px 18px;
    font-size: var(--text-sm);
    gap: 8px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .floating-cta { transition: opacity 0.2s linear; transform: none; }
  .floating-cta.visible { transform: none; }
  .floating-cta:hover { transform: none; }
}

/* 사용 조건 박스 (Mac + Claude 구독 강조) */
.pricing-prereq {
  max-width: 720px;
  margin: 0 auto var(--space-6);
  background: rgba(156, 38, 24, 0.08);
  border: 1px solid rgba(156, 38, 24, 0.25);
  border-left: 3px solid var(--color-accent);
  border-radius: var(--radius-lg);
  padding: var(--space-5) var(--space-6);
}
.pricing-prereq-label {
  margin: 0 0 var(--space-3);
  font-size: var(--text-sm);
  font-weight: 700;
  color: var(--color-accent-soft);
}
.pricing-prereq-list {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-3);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.pricing-prereq-list li {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  padding-left: var(--space-4);
  position: relative;
  line-height: 1.6;
}
.pricing-prereq-list li::before {
  content: "·";
  position: absolute;
  left: var(--space-2);
  color: var(--color-accent-soft);
  font-weight: 700;
}
.pricing-prereq-list strong { color: var(--text-primary); }
.pricing-prereq-foot {
  margin: 0;
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  line-height: 1.6;
  padding-top: var(--space-3);
  border-top: 1px solid rgba(156, 38, 24, 0.15);
}

/* plan 카드 그리드 (3 또는 4 카드) */
.plan-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
  align-items: stretch;
}
.plan-grid--4 { grid-template-columns: repeat(4, 1fr); }
.plan-grid--single {
  display: block;
  max-width: 640px;
}
.plan-grid--single .plan-card { width: 100%; }
.plan-card--lite { opacity: 0.92; }
.plan-card--lite:hover { opacity: 1; }
.plan-card {
  position: relative;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-2xl);
  padding: var(--space-8) var(--space-6);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  transition: border-color var(--duration-normal),
              background var(--duration-normal),
              box-shadow var(--duration-normal),
              transform var(--duration-normal) var(--ease-spring);
}
.plan-card:hover {
  transform: translateY(var(--hover-lift));
  background: var(--glass-bg-hi);
  border-color: var(--glass-border-hi);
  box-shadow: var(--glass-shadow), var(--glass-glow);
}
.plan-card--featured {
  background: var(--glass-bg-hi);
  border-color: var(--accent-glow);
  box-shadow: var(--glass-shadow), var(--accent-glow);
}
.plan-card--featured::before {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: var(--radius-2xl);
  padding: 1px;
  background: var(--gradient-accent);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  opacity: 0.5;
}
.plan-card--subdued { opacity: 0.85; }
.plan-card--subdued:hover { opacity: 1; }

.plan-badge {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--gradient-accent);
  color: var(--on-accent);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.05em;
  box-shadow: var(--accent-glow);
}

.plan-head { display: flex; flex-direction: column; gap: var(--space-2); }
.plan-name {
  margin: 0;
  font-size: var(--text-md);
  font-weight: 700;
  color: var(--text-primary);
}
.plan-price {
  margin: 0;
  font-size: var(--text-display-sm);
  font-weight: 800;
  color: var(--text-primary);
  line-height: 1;
  letter-spacing: -0.02em;
  font-family: var(--font-mono);
}
.plan-price-unit {
  display: inline-block;
  margin-left: var(--space-2);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--text-tertiary);
  font-family: var(--font-sans);
  letter-spacing: 0;
}
.plan-tagline {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--text-primary);
  font-weight: 600;
  line-height: 1.4;
}
.plan-period {
  margin: 0;
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  font-family: var(--font-mono);
  letter-spacing: 0.04em;
}
.pricing-footnote {
  text-align: center;
  margin: var(--space-8) auto 0;
  max-width: 600px;
  font-size: var(--text-sm);
  color: var(--text-tertiary);
  padding: var(--space-3) var(--space-4);
  border-top: 1px solid var(--glass-border);
  padding-top: var(--space-6);
}
.plan-features {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  flex-grow: 1;
}
.plan-features li {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  line-height: 1.5;
  padding-left: var(--space-4);
  position: relative;
}
.plan-features li::before {
  content: "→";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--color-accent-soft);
  font-weight: 700;
}
.plan-features li strong {
  color: var(--text-primary);
}
.plan-cta { margin-top: auto; }
.plan-cta-note {
  margin: var(--space-2) 0 0;
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  text-align: center;
}
.plan-fineprint {
  margin: 0;
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  line-height: 1.5;
  padding-top: var(--space-3);
  border-top: 1px solid var(--glass-border);
}

@media (max-width: 1200px) {
  .plan-grid, .plan-grid--4 { grid-template-columns: 1fr 1fr; }
  .plan-card--subdued { grid-column: 1 / -1; max-width: 480px; margin: 0 auto; width: 100%; }
}
@media (max-width: 640px) {
  .plan-grid, .plan-grid--4 { grid-template-columns: 1fr; }
  .plan-card--subdued { grid-column: auto; max-width: none; }
}
.price-features { list-style: none; padding: 0; margin: 0 0 var(--space-6); }
.price-features li {
  padding: var(--space-3) 0 var(--space-3) var(--space-6);
  border-bottom: 1px solid var(--border-subtle);
  position: relative;
}
.price-features li::before {
  content: "✓";
  color: var(--color-success);
  position: absolute;
  left: 0;
  top: var(--space-3);
  font-weight: 700;
}
.price-features li strong {
  display: block;
  color: var(--text-primary);
  font-size: var(--text-base);
  font-weight: 600;
  margin-bottom: 2px;
}
.price-features li span {
  display: block;
  color: var(--text-secondary);
  font-size: var(--text-sm);
}
.price-features li:last-child { border-bottom: none; }

/* Claude 도리토스 박스 — '단점을 강점으로' (라이언 결정 2026-05-19) */
.claude-note {
  background: var(--accent-bg);
  border: 1px solid var(--accent-glow);
  border-radius: var(--radius-lg);
  padding: var(--space-4) var(--space-6);
  margin: 0 0 var(--space-6);
}
.claude-note strong {
  display: block;
  color: var(--text-primary);
  font-size: var(--text-base);
  font-weight: 600;
  margin-bottom: var(--space-2);
}
.claude-note p {
  margin: 0;
  color: var(--text-secondary);
  font-size: var(--text-sm);
  line-height: 1.5;
}

/* Page Hero */
.page-hero { padding: var(--space-16) 0 var(--space-8); text-align: center; }
.page-hero h1 { font-size: var(--text-display-md); margin: 0 0 var(--space-3); }
.page-hero p { color: var(--text-secondary); font-size: var(--text-md); margin: 0; }

/* Install Steps — glass */
.step-list { list-style: none; counter-reset: step; padding: 0; max-width: 720px; margin: 0 auto; }
.step-list li {
  counter-increment: step;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  margin-bottom: var(--space-3);
  position: relative;
  padding-left: 96px;
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
}
.step-list li::before {
  content: counter(step);
  position: absolute;
  left: var(--space-4);
  top: var(--space-6);
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--color-accent);
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
}
.video-placeholder {
  margin-top: var(--space-12);
  aspect-ratio: 16/9;
  background: var(--bg-elevated);
  border: 2px dashed var(--border-subtle);
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Counter Live — glass with glow */
.counter-live { text-align: center; padding: var(--space-12) 0; }
.counter-big {
  display: inline-flex;
  align-items: baseline;
  gap: var(--space-3);
  background: var(--glass-bg-hi);
  padding: var(--space-12) var(--space-16);
  border-radius: var(--radius-2xl);
  border: 1px solid var(--glass-border);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  box-shadow: var(--glass-shadow), var(--glass-glow);
}
.counter-num { font-size: var(--text-display-lg); font-weight: 800; color: var(--accent-hover); }
.counter-label { font-size: var(--text-lg); color: var(--text-secondary); }
.counter-status { margin-top: var(--space-6); color: var(--text-secondary); font-size: var(--text-base); }
.counter-cta { margin-top: var(--space-8); }

/* Misc */
.muted { color: var(--text-tertiary); }
.faq-stub, .legal-stub { padding: var(--space-12) 0; text-align: center; }

/* FAQ — markdown rendered content */
.faq-content { padding-top: var(--space-8); padding-bottom: var(--space-16); max-width: 820px; }
.faq-divider { border: 0; border-top: 1px solid var(--border-subtle); margin: var(--space-12) 0 var(--space-6); }

.markdown-body { font-size: var(--text-base); line-height: 1.75; color: var(--text-primary); }
.markdown-body h1 { font-size: var(--text-lg); margin: var(--space-12) 0 var(--space-4); color: var(--text-primary); }
.markdown-body h2 {
  font-size: var(--text-md);
  margin: var(--space-12) 0 var(--space-4);
  padding-bottom: var(--space-2);
  border-bottom: 1px solid var(--border-subtle);
  color: var(--accent-hover);
}
.markdown-body h3 { font-size: var(--text-md); margin: var(--space-6) 0 var(--space-2); color: var(--text-primary); }
.markdown-body h4 { font-size: var(--text-base); margin: var(--space-4) 0 var(--space-2); color: var(--text-secondary); }
.markdown-body p { margin: 0 0 var(--space-4); color: var(--text-secondary); }
.markdown-body ul, .markdown-body ol { margin: 0 0 var(--space-4); padding-left: var(--space-6); color: var(--text-secondary); }
.markdown-body li { margin-bottom: var(--space-2); }
.markdown-body li > p { margin: 0 0 var(--space-2); }
.markdown-body strong { color: var(--text-primary); font-weight: 700; }
.markdown-body code {
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  padding: 0.1em 0.4em;
  border-radius: 4px;
  font-size: 0.9em;
  font-family: ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace;
}
.markdown-body pre { background: var(--bg-surface); border: 1px solid var(--border-subtle); border-radius: 8px; padding: var(--space-4); overflow-x: auto; }
.markdown-body pre code { background: none; border: 0; padding: 0; }
.markdown-body blockquote {
  border-left: 3px solid var(--color-accent);
  padding: var(--space-2) var(--space-4);
  margin: 0 0 var(--space-4);
  color: var(--text-tertiary);
  background: var(--bg-surface);
  border-radius: 0 6px 6px 0;
}
.markdown-body hr { border: 0; border-top: 1px solid var(--border-subtle); margin: var(--space-8) 0; }
.markdown-body a { color: var(--accent-hover); text-decoration: underline; }
.markdown-body a:hover { color: var(--color-accent-soft); }
/* toc.anchorlink=True 가 헤딩 텍스트를 <a class="toclink"> 로 감싸므로
   헤딩 안 link 는 underline·색상 inherit (라이언 2026-05-19) */
.markdown-body h1 .toclink,
.markdown-body h2 .toclink,
.markdown-body h3 .toclink,
.markdown-body h4 .toclink {
  color: inherit;
  text-decoration: none;
}
.markdown-body h1 .toclink:hover,
.markdown-body h2 .toclink:hover,
.markdown-body h3 .toclink:hover,
.markdown-body h4 .toclink:hover { color: var(--accent-hover); }
.markdown-body table { width: 100%; border-collapse: collapse; margin: 0 0 var(--space-4); }
.markdown-body th, .markdown-body td { padding: var(--space-2) var(--space-3); border: 1px solid var(--border-subtle); text-align: left; }
.markdown-body th { background: var(--bg-surface); color: var(--text-primary); font-weight: 600; }
.markdown-body .headerlink { color: var(--text-tertiary); margin-left: var(--space-2); opacity: 0; transition: opacity var(--duration-fast); }
.markdown-body h2:hover .headerlink,
.markdown-body h3:hover .headerlink { opacity: 1; }

/* FAQ — collapsible Q&A (details/summary) */
.markdown-body details {
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: 10px;
  margin: 0 0 var(--space-3);
  transition: border-color var(--duration-fast), background var(--duration-fast);
}
.markdown-body details:hover { border-color: var(--color-accent); }
.markdown-body details[open] {
  border-color: var(--color-accent);
  background: var(--bg-base);
}
.markdown-body summary {
  cursor: pointer;
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-base);
  color: var(--text-primary);
  list-style: none;
  position: relative;
  padding-right: calc(var(--space-4) + 20px);
  user-select: none;
  line-height: 1.5;
}
.markdown-body summary::-webkit-details-marker { display: none; }
.markdown-body summary::after {
  content: "+";
  position: absolute;
  right: var(--space-4);
  top: 50%;
  transform: translateY(-50%);
  font-size: var(--text-md);
  color: var(--accent-hover);
  font-weight: 400;
  transition: transform var(--duration-fast);
  line-height: 1;
}
.markdown-body details[open] > summary::after {
  content: "−";
}
.markdown-body summary:hover { color: var(--accent-hover); }
.markdown-body summary strong {
  color: var(--accent-hover);
  font-weight: 600;
  margin-right: var(--space-2);
}
/* details[open] 본문 — 모든 자식에 일관 padding. separator 제거 (라이언 2026-05-19).
   summary 와 본문 사이 시각 분리는 details[open] 의 padding-top + 색 변화로 충분. */
.markdown-body details[open] > *:not(summary) {
  padding-left: var(--space-4);
  padding-right: var(--space-4);
}
.markdown-body details[open] > *:not(summary):first-of-type {
  padding-top: var(--space-3);
  margin-top: 0;
}
.markdown-body details[open] > *:last-child {
  padding-bottom: var(--space-3);
  margin-bottom: 0;
}
/* ul/ol bullet 이 박스 안에 정확히 들어가도록 — 박스 padding + list bullet space */
.markdown-body details[open] > ul,
.markdown-body details[open] > ol {
  padding-left: calc(var(--space-4) + var(--space-6));
}

/* Footer — glass top stripe */
.site-footer {
  background: var(--glass-bg);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  border-top: 1px solid var(--glass-border);
  padding: var(--space-12) 0 var(--space-6);
  margin-top: var(--space-16);
}
.footer-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-4);
}
.footer-tag { color: var(--text-tertiary); font-size: var(--text-sm); margin: 0; }
.footer-nav { display: flex; gap: var(--space-6); flex-wrap: wrap; }
.footer-nav a { color: var(--text-secondary); font-size: var(--text-sm); }

/* Responsive */
/* 태블릿 — agent-grid 5 → 3+2 (2026-05-19) */
@media (max-width: 1024px) {
  .agent-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 768px) {
  .nav-main { gap: var(--space-3); }
  .nav-main a:not(.cta-link) { display: none; }
  .hero { padding: var(--space-12) 0 var(--space-8); }
  .hero-cta { flex-direction: column; width: 100%; }
  .hero-cta .btn-primary, .hero-cta .btn-secondary { width: 100%; }
  .footer-inner { flex-direction: column; text-align: center; }
  /* agent-grid 모바일 — 1열 */
  .agent-grid { grid-template-columns: 1fr; }
}

/* ─────────────────────────────────────────────────────────
   Welcome — 초대 링크 재발송 페이지 (/welcome)
   ───────────────────────────────────────────────────────── */

/* Accordion — JS .open 토글 전용 (인라인으로 처리 불가) */
.welcome-accordion { overflow: hidden; max-height: 0; opacity: 0; transition: max-height 0.35s ease, opacity 0.25s ease; }
.welcome-accordion.open { max-height: 560px; opacity: 1; }

/* 구매 내역 dl 테이블 레이아웃 */
.welcome-result-row { display: flex; justify-content: space-between; align-items: baseline; gap: var(--space-4); padding: var(--space-2) 0; border-bottom: 1px solid var(--glass-border); }
.welcome-result-row:last-child { border-bottom: none; }
.welcome-result-row dt { font-size: var(--text-sm); color: var(--text-tertiary); flex-shrink: 0; }
.welcome-result-row dd { margin: 0; font-size: var(--text-sm); color: var(--text-primary); font-weight: 500; text-align: right; word-break: break-all; }

/* ─────────────────────────────────────────────────────────
   Guide Image — welcome/install 페이지 가이드 이미지 + Lightbox
   ───────────────────────────────────────────────────────── */

.guide-img-wrap {
  position: relative;
  margin-top: var(--space-6);
  border-radius: var(--radius-lg);
  overflow: hidden;
  cursor: zoom-in;
  border: 1px solid var(--glass-border);
  transition: border-color var(--duration-normal),
              box-shadow var(--duration-normal),
              transform var(--duration-normal) var(--ease-spring);
}
.guide-img-wrap:hover {
  border-color: var(--glass-border-hi);
  box-shadow: var(--glass-shadow);
  transform: translateY(var(--hover-lift));
}
.guide-img-wrap img {
  display: block;
  width: 100%;
  border-radius: calc(var(--radius-lg) - 1px);
}
.guide-img-overlay {
  display: none;
}
.guide-img-zoom-btn {
  display: none;
}

/* Lightbox */
.lightbox {
  position: fixed; inset: 0; z-index: 1000;
  display: none;
  align-items: center; justify-content: center;
  padding: var(--space-8);
  background: rgba(0,0,0,0.82);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  cursor: zoom-out;
  animation: lb-in 0.18s var(--ease-spring);
}
.lightbox.open { display: flex; }
@keyframes lb-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}
.lightbox-img {
  max-width: min(88vw, 860px);
  max-height: 84vh;
  width: auto; height: auto;
  border-radius: var(--radius-xl);
  box-shadow: 0 32px 96px rgba(0,0,0,0.55);
  cursor: default;
  animation: lb-scale-in 0.2s var(--ease-spring);
}
@keyframes lb-scale-in {
  from { transform: scale(0.94); }
  to   { transform: scale(1); }
}
.lightbox-close {
  position: absolute;
  top: var(--space-5); right: var(--space-5);
  width: 40px; height: 40px;
  border: 1px solid rgba(255,255,255,0.18);
  background: rgba(255,255,255,0.1);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  color: #fff;
  font-size: 20px;
  border-radius: 50%;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background var(--duration-fast);
  line-height: 1;
}
.lightbox-close:hover { background: rgba(255,255,255,0.22); }


/* ════════════════════════════════════════════════════════════════
   메인페이지 11섹션 재구성 (2026-05-24) — 신규 섹션 스타일
   기존 .hero / .depth-tiers / .agents / .day-flow / .pricing 재활용 +
   .shift-section / .tools-section / .workflow-section / .vs-section /
   .claude-section / .trust-section / .final-cta-section 신규 추가
   ════════════════════════════════════════════════════════════════ */

/* ════════════════════════════════════════════════════════════════
   가로 스크롤 방지 + 메인 섹션 안전 가운데 정렬
   ════════════════════════════════════════════════════════════════ */
html, body { overflow-x: hidden; max-width: 100vw; }
.usp-section, .voice-section, .meta-section, .privacy-section, .claude-section,
.trust-section, .shift-section, .tools-section, .workflow-section,
.vs-section, .final-cta-section, .agents, .day-flow, .pricing,
.depth-tiers, .hero {
  width: 100%;
}
.meta-tools, .meta-quote, .meta-tools-pairs, .meta-update,
.usp-pitch, .usp-cases, .usp-foot,
.claude-compare, .claude-pitch,
.trust-grid, .privacy-pillars, .privacy-backup,
.shift-grid, .tools-grid, .workflow-grid, .vs-grid,
.tier-list, .plan-grid, .features-common, .agent-grid, .day-list,
.meta-foot, .final-cta-inner {
  margin-left: auto !important;
  margin-right: auto !important;
}

/* ════════════════════════════════════════════════════════════════
   메타 도구 — 월 라벨 (NEW)
   ════════════════════════════════════════════════════════════════ */
.meta-tool {
  position: relative;
  padding: var(--space-10) var(--space-6) var(--space-6) !important;
  gap: var(--space-2) !important;
  min-height: 180px;
}
.meta-tool-icon {
  margin-bottom: var(--space-2) !important;
}
.meta-tool-month {
  position: absolute;
  top: var(--space-4);
  right: var(--space-4);
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.04em;
  padding: 4px 10px;
  background: rgba(234, 179, 8, 0.14);
  color: #fbbf24;
  border: 1px solid rgba(234, 179, 8, 0.35);
  border-radius: var(--radius-full);
  white-space: nowrap;
}
.meta-tools-pair .meta-tool {
  padding: var(--space-10) var(--space-6) var(--space-6) !important;
}
.meta-tool-desc strong {
  color: var(--color-accent-soft);
}

/* ════════════════════════════════════════════════════════════════
   모바일 pretty 개행 — 전역 적용 (한국어 어절 단위 + 라인 균형)
   ════════════════════════════════════════════════════════════════ */
.hero-sub,
.section-sub,
.tier-text,
.agent-example,
.usp-pitch-line,
.usp-output,
.usp-foot-line,
.usp-foot-close,
.meta-quote-text,
.meta-tools-sub,
.meta-tools-foot,
.meta-foot-line,
.meta-foot-close,
.meta-update-desc,
.meta-update-sub,
.privacy-pillar-desc,
.privacy-backup-result,
.trust-desc,
.final-cta-note,
.shift-message,
.workflow-foot,
.workflow-list li,
.wf-h2-sub,
.wf-mode-desc,
.wf-agent-ex,
.wf-tier-intro,
.wf-tier-foot,
.wf-coming-intro,
.wf-coming-foot,
.wf-matrix-foot,
.wf-status-sub {
  word-break: keep-all;
  text-wrap: balance;
  overflow-wrap: anywhere;
}

/* ════════════════════════════════════════════════════════════════
   메타 도구 그리드 — 2-col 페어 (모바일 가독성)
   ════════════════════════════════════════════════════════════════ */
.meta-tools-pairs {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  max-width: 920px;
  margin: 0 auto;
}
.meta-tools-pair {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-3);
}
.meta-tools-pair .meta-tool {
  align-items: flex-start;
  padding: var(--space-5) var(--space-5);
}
.meta-tools-pair .meta-tool-desc {
  white-space: normal;
  line-height: 1.5;
  font-size: var(--text-sm);
  margin-top: var(--space-1);
}
@media (max-width: 640px) {
  .meta-tools-pair { grid-template-columns: 1fr; }
}

/* 메타 quote 인스타 핸들 */
.meta-quote-handle {
  display: inline-block;
  margin-left: var(--space-2);
  padding: 2px var(--space-2);
  background: rgba(156, 38, 24, 0.14);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-full);
  color: var(--color-accent-soft);
  text-decoration: none;
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 600;
}
.meta-quote-handle:hover { background: rgba(156, 38, 24, 0.22); }

/* meta-foot 가운데 정렬 강제 */
.meta-foot { text-align: center !important; }
.meta-foot-line { text-align: center; }
.meta-foot-close { text-align: center; }

/* 메인 섹션 padding 통일 — 더 여유롭게 (96px) */
.usp-section,
.voice-section,
.privacy-section,
.meta-section,
.claude-section,
.trust-section,
.shift-section,
.tools-section,
.workflow-section,
.vs-section,
.final-cta-section {
  padding-top: var(--space-24, 96px) !important;
  padding-bottom: var(--space-24, 96px) !important;
}

/* meta update 섹션 위 간격 */
.meta-update { margin-top: var(--space-16); }

/* Workflow 페이지 wf-cmd-list — 슬래시 + 설명 가로 정렬 */
.wf-cmd-list { display: flex; flex-direction: column; gap: var(--space-2); }
.wf-cmd-list li {
  display: flex;
  align-items: baseline;
  gap: var(--space-3);
  padding: var(--space-2) 0;
  border-bottom: 1px dashed rgba(156, 38, 24, 0.15);
}
.wf-cmd-list li:last-child { border-bottom: 0; }
.wf-cmd {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--color-accent-soft);
  background: rgba(156, 38, 24, 0.12);
  padding: 3px 10px;
  border-radius: var(--radius-md);
  white-space: nowrap;
  flex-shrink: 0;
  font-weight: 600;
}
.wf-cmd-desc {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  line-height: 1.5;
}

/* ════════════════════════════════════════════════════════════════
   Workflow 페이지 — 출시 완료 vs 업데이트 예정 시각 구별
   ════════════════════════════════════════════════════════════════ */

/* Workflow 페이지 컨테이너·간격 */
.wf-container { padding: 0 var(--space-4) var(--space-20); }
.wf-wrap {
  max-width: 1040px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: var(--space-16);
}
.wf-block { padding: 0; }
.wf-h2 {
  margin: 0 0 var(--space-3);
  font-size: var(--text-2xl);
  text-align: center;
  letter-spacing: -0.02em;
  color: var(--text-primary);
}
.wf-h2-sub {
  margin: 0 auto var(--space-8);
  max-width: 720px;
  text-align: center;
  color: var(--text-secondary);
  font-size: var(--text-md);
  line-height: 1.7;
}

.wf-two-modes {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4);
}
.wf-mode-card { padding: var(--space-8) !important; text-align: left; }
.wf-mode-label { margin: 0 0 var(--space-3) !important; color: var(--color-accent-soft) !important; }
.wf-mode-title { margin: 0 0 var(--space-3); font-size: var(--text-lg); color: var(--text-primary); }
.wf-mode-desc {
  margin: 0;
  color: var(--text-secondary);
  font-size: var(--text-sm);
  line-height: 1.7;
}
.wf-mode-desc strong { color: var(--text-primary); }
@media (max-width: 768px) { .wf-two-modes { grid-template-columns: 1fr; } }

.wf-agents-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--space-3);
}
.wf-agent { padding: var(--space-5) !important; }
.wf-agent .mono-label { margin: 0 0 var(--space-2); color: var(--color-accent-soft); }
.wf-agent-role { margin: 0 0 var(--space-2); font-size: var(--text-sm); color: var(--text-primary); font-weight: 600; }
.wf-agent-ex {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--text-tertiary);
  font-style: italic;
  line-height: 1.55;
}

.wf-tier-intro {
  margin: 0 0 var(--space-6);
  text-align: center;
  font-size: var(--text-sm);
  color: var(--text-secondary);
  line-height: 1.7;
}

.wf-cat-tier-pill {
  display: inline-block;
  margin-right: var(--space-2);
  padding: 2px 8px;
  border-radius: var(--radius-full);
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.05em;
  vertical-align: middle;
}
.wf-cat-tier-pill--all {
  background: rgba(74, 222, 128, 0.15);
  color: #4ade80;
  border: 1px solid rgba(74, 222, 128, 0.3);
}
.wf-cat-tier-pill--pro {
  background: rgba(167, 139, 250, 0.18);
  color: #e6cabf;
  border: 1px solid rgba(167, 139, 250, 0.35);
}
.wf-cat-tier-pill--creator {
  background: rgba(156, 38, 24, 0.18);
  color: var(--color-accent-soft);
  border: 1px solid rgba(156, 38, 24, 0.4);
}

.wf-system-card {
  padding: var(--space-6) !important;
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  line-height: 2;
  color: var(--text-secondary);
  word-break: keep-all;
  text-wrap: balance;
}

.wf-matrix-wrap { padding: 0 !important; overflow: hidden; }
.wf-matrix-foot {
  margin: var(--space-6) auto 0;
  max-width: 720px;
  text-align: center;
  color: var(--text-tertiary);
  font-size: var(--text-sm);
  line-height: 1.7;
}
.wf-cta-wrap {
  text-align: center;
  margin-top: var(--space-8);
}
@media (max-width: 640px) {
  .wf-matrix { font-size: var(--text-xs); }
  .wf-matrix th, .wf-matrix td { padding: var(--space-2) var(--space-2); }
}


/* ════════════════════════════════════════════════════════════════
   Workflow 페이지 — 출시 완료 vs 업데이트 예정 시각 구별 (legacy)
   ════════════════════════════════════════════════════════════════ */
.wf-section {
  padding: var(--space-10) 0;
}
.wf-section--live {
  background: linear-gradient(180deg, rgba(34, 197, 94, 0.04) 0%, transparent 100%);
  border-radius: var(--radius-2xl);
  padding: var(--space-10) var(--space-6);
  border: 1px solid rgba(34, 197, 94, 0.15);
}
.wf-section--coming {
  background: linear-gradient(180deg, rgba(234, 179, 8, 0.06) 0%, transparent 100%);
  border-radius: var(--radius-2xl);
  padding: var(--space-10) var(--space-6);
  border: 1px solid rgba(234, 179, 8, 0.18);
}

.wf-status-header { text-align: center; margin-bottom: var(--space-10); }
.wf-status-badge {
  display: inline-block;
  padding: var(--space-2) var(--space-5);
  border-radius: var(--radius-full);
  font-size: var(--text-md);
  font-weight: 700;
  letter-spacing: -0.01em;
}
.wf-status-badge--live {
  background: rgba(34, 197, 94, 0.12);
  color: #4ade80;
  border: 1px solid rgba(34, 197, 94, 0.4);
}
.wf-status-badge--coming {
  background: rgba(234, 179, 8, 0.14);
  color: #fbbf24;
  border: 1px solid rgba(234, 179, 8, 0.4);
}
.wf-status-sub {
  margin: var(--space-3) 0 0;
  font-size: var(--text-sm);
  color: var(--text-tertiary);
}

/* 티어 블록 (출시 완료 영역 안) */
.wf-tier-block {
  margin-top: var(--space-8);
  padding-top: var(--space-8);
  border-top: 1px dashed var(--glass-border);
}
.wf-tier-block:first-of-type { border-top: 0; padding-top: 0; margin-top: 0; }
.wf-tier-label {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-6);
  padding: var(--space-3) var(--space-5);
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-full);
}
.wf-tier-dot {
  width: 12px; height: 12px;
  border-radius: 50%;
  flex-shrink: 0;
}
.wf-tier-dot--all { background: #4ade80; box-shadow: 0 0 8px rgba(74, 222, 128, 0.5); }
.wf-tier-dot--pro { background: #c87a5a; box-shadow: 0 0 8px rgba(167, 139, 250, 0.5); }
.wf-tier-dot--creator { background: var(--color-accent); box-shadow: 0 0 12px rgba(156, 38, 24, 0.6); }
.wf-tier-name {
  flex: 1;
  font-size: var(--text-md);
  font-weight: 600;
  color: var(--text-primary);
}
.wf-tier-count {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--color-accent-soft);
  font-weight: 700;
}
.wf-tier-foot {
  margin: var(--space-6) 0 0;
  padding: var(--space-4);
  background: rgba(156, 38, 24, 0.08);
  border: 1px solid rgba(156, 38, 24, 0.2);
  border-radius: var(--radius-lg);
  font-size: var(--text-sm);
  color: var(--text-secondary);
  line-height: 1.65;
  text-align: center;
}

.wf-cat-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4);
}
.wf-cat-grid--single { grid-template-columns: 1fr; max-width: 720px; margin: 0 auto; }
.wf-cat {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-xl);
  padding: var(--space-5) var(--space-6);
}
.wf-cat-title {
  margin: 0 0 var(--space-3);
  font-size: var(--text-md);
  font-weight: 700;
  color: var(--text-primary);
}
.wf-cat-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.wf-cat-list li {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  line-height: 1.6;
  padding-left: var(--space-3);
  position: relative;
}
.wf-cat-list li::before {
  content: "·";
  position: absolute;
  left: 0;
  color: var(--text-tertiary);
}
.wf-cat-list code {
  background: rgba(156, 38, 24, 0.10);
  color: var(--color-accent-soft);
  padding: 1px 6px;
  border-radius: 4px;
  font-size: 12px;
}
.wf-cat-mock {
  margin-top: var(--space-4);
  padding-top: var(--space-3);
  border-top: 1px dashed var(--glass-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.wf-cat-mock img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 10px;
  border: 1px solid var(--glass-border);
}

.wf-credit-pill {
  display: inline-block;
  margin-left: 6px;
  padding: 2px 9px;
  font-size: 11px;
  font-family: var(--font-mono);
  font-weight: 600;
  letter-spacing: 0.02em;
  background: rgba(156, 38, 24, 0.16);
  color: var(--color-accent-soft);
  border: 1px solid rgba(156, 38, 24, 0.35);
  border-radius: 999px;
  white-space: nowrap;
  vertical-align: middle;
}
.wf-credit-pill--free {
  background: rgba(34, 197, 94, 0.14);
  color: #4ade80;
  border-color: rgba(34, 197, 94, 0.35);
}

.wf-cat-example {
  margin-top: var(--space-4);
  padding-top: var(--space-3);
  border-top: 1px dashed var(--glass-border);
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}
.wf-ex-user {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--text-secondary);
  line-height: 1.5;
  font-style: italic;
}
.wf-ex-user::before {
  content: "💬 ";
  font-style: normal;
}
.wf-ex-bot {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--color-accent-soft);
  line-height: 1.5;
  font-weight: 500;
}
.wf-ex-bot::before {
  content: "↳ ";
  color: var(--text-tertiary);
}

.wf-cat-foot {
  margin: var(--space-4) 0 0;
  padding-top: var(--space-3);
  border-top: 1px solid var(--glass-border);
  font-size: var(--text-sm);
  color: var(--text-tertiary);
  line-height: 1.6;
  font-style: italic;
}
@media (max-width: 768px) {
  .wf-cat-grid { grid-template-columns: 1fr; }
}

/* Coming Soon 영역 */
.wf-coming-intro {
  max-width: 760px;
  margin: 0 auto var(--space-10);
  text-align: center;
  font-size: var(--text-md);
  color: var(--text-secondary);
  line-height: 1.65;
}
.wf-coming-intro strong { color: var(--color-accent-soft); }

.wf-coming-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4);
}
.wf-coming-card {
  background: var(--glass-bg);
  border: 1px solid rgba(234, 179, 8, 0.25);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  position: relative;
}
.wf-coming-cat {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 1px dashed var(--glass-border);
  flex-wrap: wrap;
}
.wf-coming-icon { font-size: 24px; }
.wf-coming-name {
  flex: 1;
  font-size: var(--text-md);
  font-weight: 700;
  color: var(--text-primary);
}
.wf-coming-tier {
  font-family: var(--font-mono);
  font-size: 11px;
  padding: 2px var(--space-2);
  border-radius: var(--radius-full);
  font-weight: 600;
  letter-spacing: 0.02em;
}
.wf-coming-tier--all {
  background: rgba(74, 222, 128, 0.15);
  color: #4ade80;
  border: 1px solid rgba(74, 222, 128, 0.3);
}
.wf-coming-tier--pro {
  background: rgba(167, 139, 250, 0.18);
  color: #e6cabf;
  border: 1px solid rgba(167, 139, 250, 0.35);
}
.wf-coming-tier--creator {
  background: rgba(156, 38, 24, 0.18);
  color: var(--color-accent-soft);
  border: 1px solid rgba(156, 38, 24, 0.4);
}
.wf-coming-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.wf-coming-list li {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  line-height: 1.65;
  padding-left: var(--space-3);
  position: relative;
}
.wf-coming-list li::before {
  content: "·";
  position: absolute;
  left: 0;
  color: var(--text-tertiary);
}
.wf-coming-list li strong { color: var(--text-primary); }
.wf-coming-foot {
  max-width: 720px;
  margin: var(--space-10) auto 0;
  text-align: center;
  padding: var(--space-5);
  background: rgba(234, 179, 8, 0.08);
  border: 1px solid rgba(234, 179, 8, 0.25);
  border-radius: var(--radius-lg);
  font-size: var(--text-sm);
  color: var(--text-primary);
  line-height: 1.65;
}
@media (max-width: 768px) {
  .wf-coming-grid { grid-template-columns: 1fr; }
}

/* 매트릭스 표 */
.wf-matrix {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
}
.wf-matrix thead tr { border-bottom: 1px solid var(--glass-border); }
.wf-matrix th {
  padding: var(--space-4) var(--space-5);
  text-align: center;
  color: var(--text-tertiary);
  font-weight: 500;
}
.wf-matrix th:first-child { text-align: left; width: 45%; }
.wf-matrix th.wf-matrix-creator { color: var(--color-accent-soft); font-weight: 700; }
.wf-matrix tbody tr { border-bottom: 1px solid var(--glass-border); }
.wf-matrix tbody tr:last-child { border-bottom: 0; }
.wf-matrix td {
  padding: var(--space-4) var(--space-5);
  text-align: center;
  color: var(--text-secondary);
}
.wf-matrix td:first-child { text-align: left; }
.wf-matrix td strong { color: var(--text-primary); }

@media (max-width: 768px) {
  .wf-matrix { font-size: var(--text-xs); }
  .wf-matrix th,
  .wf-matrix td { padding: var(--space-3) var(--space-2); }
  .wf-matrix th:first-child,
  .wf-matrix td:first-child {
    width: auto;
    word-break: keep-all;
    overflow-wrap: anywhere;
  }
  .wf-matrix .wf-credit-pill { white-space: nowrap; }
}


/* ── 6.5 META — Creator OS는 Creator OS로 만들어졌어요 ⭐ ── */
.meta-section {
  padding: var(--space-20) 0;
  background:
    radial-gradient(ellipse at center top, rgba(156, 38, 24, 0.10) 0%, transparent 70%),
    linear-gradient(180deg, transparent 0%, rgba(156, 38, 24, 0.04) 100%);
}
.meta-quote {
  max-width: 720px;
  margin: var(--space-10) auto var(--space-14);
  text-align: center;
  padding: var(--space-10) var(--space-8);
  background: var(--glass-bg);
  border: 1px solid rgba(156, 38, 24, 0.3);
  border-radius: var(--radius-2xl);
  box-shadow: 0 0 32px rgba(156, 38, 24, 0.18);
  backdrop-filter: var(--glass-blur);
  position: relative;
}
.meta-quote::before {
  content: """;
  position: absolute;
  top: -16px;
  left: 24px;
  font-size: 72px;
  color: rgba(156, 38, 24, 0.4);
  font-family: serif;
  line-height: 1;
}
.meta-quote-text {
  margin: 0;
  font-size: var(--text-lg);
  line-height: 1.6;
  color: var(--text-secondary);
}
.meta-quote-text strong { color: var(--text-primary); }
.meta-quote-text--emph {
  margin-top: var(--space-2);
  font-size: var(--text-xl);
  color: var(--text-primary);
}
.meta-quote-text--emph strong {
  background: var(--gradient-accent);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.meta-quote-sig {
  margin: var(--space-5) 0 0;
  font-size: var(--text-sm);
  color: var(--text-tertiary);
  font-family: var(--font-mono);
  letter-spacing: 0.05em;
}

.meta-tools { max-width: 1080px; margin: 0 auto; padding: var(--space-6) 0; }
.meta-tools-title {
  margin: 0 0 var(--space-2);
  font-size: var(--text-lg);
  text-align: center;
  color: var(--text-primary);
  font-weight: 700;
}
.meta-tools-sub {
  margin: 0 0 var(--space-8);
  text-align: center;
  font-size: var(--text-sm);
  color: var(--text-tertiary);
}
.meta-tools-illustration {
  max-width: 1200px;
  margin: 0 auto;
  border-radius: var(--radius-2xl);
  overflow: hidden;
  border: 1px solid var(--glass-border);
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.5), 0 0 32px rgba(156, 38, 24, 0.18);
}
.meta-tools-illustration img {
  width: 100%;
  height: auto;
  display: block;
}
.meta-tools-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-3);
}
.meta-tool {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  align-items: flex-start;
  transition: border-color var(--duration-fast), transform var(--duration-fast);
}
.meta-tool:hover {
  border-color: rgba(156, 38, 24, 0.4);
  transform: translateY(-2px);
}
.meta-tool-icon { font-size: 24px; line-height: 1; }
.meta-tool-name {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--color-accent-soft);
  font-weight: 600;
  letter-spacing: -0.01em;
}
.meta-tool-desc {
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  line-height: 1.45;
}
.meta-tools-foot {
  margin: var(--space-6) 0 0;
  text-align: center;
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  font-style: italic;
}
@media (max-width: 768px) {
  .meta-tools-grid { grid-template-columns: repeat(2, 1fr); }
}

.meta-update {
  margin: var(--space-14) auto 0;
  max-width: 1000px;
}
.meta-update-title {
  margin: 0 0 var(--space-2);
  font-size: var(--text-xl);
  text-align: center;
  color: var(--text-primary);
  font-weight: 700;
}
.meta-update-sub {
  margin: 0 auto var(--space-8);
  max-width: 720px;
  text-align: center;
  font-size: var(--text-sm);
  color: var(--text-secondary);
  line-height: 1.6;
}
.meta-update-sub strong { color: var(--color-accent-soft); }
.meta-update-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
}
.meta-update-grid--single {
  display: block;
  max-width: 640px;
  margin-left: auto;
  margin-right: auto;
}
.meta-update-tier {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
}
.meta-update-tier--mid { border-color: rgba(156, 38, 24, 0.25); }
.meta-update-tier--top {
  border-color: rgba(156, 38, 24, 0.5);
  background: rgba(156, 38, 24, 0.08);
  box-shadow: 0 0 24px rgba(156, 38, 24, 0.18);
}
.meta-update-name {
  margin: 0 0 var(--space-3);
  font-size: var(--text-md);
  color: var(--text-primary);
  font-weight: 700;
}
.meta-update-desc {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--text-secondary);
  line-height: 1.65;
}
.meta-update-desc strong { color: var(--color-accent-soft); }
@media (max-width: 768px) {
  .meta-update-grid { grid-template-columns: 1fr; }
}

.meta-foot {
  margin: var(--space-14) auto 0;
  max-width: 640px;
  text-align: center;
}
.meta-foot-line {
  margin: 0;
  font-size: var(--text-md);
  color: var(--text-tertiary);
  line-height: 1.8;
  font-weight: 500;
}
.meta-foot-close {
  margin: var(--space-3) 0 0;
  font-size: var(--text-md);
  color: var(--text-primary);
  line-height: 1.7;
}
.meta-foot-close strong { color: var(--color-accent-soft); }


/* ── 10b-priv. 데이터 프라이버시 ⭐ ── */
.privacy-section {
  padding: var(--space-20) 0;
  background: linear-gradient(180deg, transparent 0%, rgba(156, 38, 24, 0.04) 100%);
}
.privacy-pillars {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
  max-width: 960px;
  margin: 0 auto var(--space-12);
}
.privacy-pillar {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.privacy-pillar-icon { margin: 0; font-size: 32px; }
.privacy-pillar-title { margin: 0; font-size: var(--text-md); font-weight: 700; color: var(--text-primary); }
.privacy-pillar-desc { margin: 0; font-size: var(--text-sm); color: var(--text-secondary); line-height: 1.55; }
@media (max-width: 768px) {
  .privacy-pillars { grid-template-columns: 1fr; }
}

.privacy-backup {
  max-width: 800px;
  margin: 0 auto;
  padding: var(--space-8);
  background: rgba(156, 38, 24, 0.08);
  border: 1px solid rgba(156, 38, 24, 0.3);
  border-radius: var(--radius-2xl);
}
.privacy-backup-title {
  margin: 0 0 var(--space-2);
  font-size: var(--text-md);
  color: var(--text-primary);
  font-weight: 700;
  text-align: center;
}
.privacy-backup-sub {
  margin: 0 0 var(--space-5);
  text-align: center;
  font-size: var(--text-sm);
  color: var(--text-secondary);
}
.privacy-backup-cmd {
  background: rgba(20, 14, 36, 0.6);
  border: 1px solid rgba(156, 38, 24, 0.4);
  border-radius: var(--radius-lg);
  padding: var(--space-4) var(--space-5);
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  line-height: 1.7;
  margin-bottom: var(--space-4);
}
.privacy-backup-mention {
  color: var(--color-accent-soft);
  font-weight: 700;
  margin-right: var(--space-2);
}
.privacy-backup-text { color: var(--text-secondary); }
.privacy-backup-result {
  margin: 0;
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  line-height: 1.65;
}


/* 5 에이전트 프로필 아바타 — Team 섹션 */
.agent-avatar {
  width: 96px;
  height: 96px;
  margin: 0 auto var(--space-4);
  border-radius: 50%;
  overflow: hidden;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3), 0 0 0 1px rgba(124, 58, 237, 0.18);
  transition: transform var(--duration-normal) var(--ease-spring), box-shadow var(--duration-normal);
}
.agent-avatar img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}
.agent-card:hover .agent-avatar {
  transform: translateY(-2px) scale(1.05);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.4), 0 0 0 2px var(--color-accent-soft);
}

/* Voice 3단계 Discord mock */
.voice-how-mock {
  margin-top: var(--space-4);
  padding-top: var(--space-3);
  border-top: 1px dashed var(--glass-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.voice-how-mock img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 10px;
  border: 1px solid var(--glass-border);
}


/* ── 3.6 Voice — 이 맥락 그대로, 내 목소리로 ⭐ ── */
.voice-section {
  background:
    radial-gradient(ellipse at bottom, rgba(156, 38, 24, 0.10) 0%, transparent 60%),
    linear-gradient(180deg, rgba(156, 38, 24, 0.06) 0%, rgba(156, 38, 24, 0.02) 100%);
}
.voice-pitch {
  max-width: 720px;
  margin: var(--space-10) auto var(--space-12);
  text-align: center;
  padding: var(--space-10) var(--space-6);
  background: rgba(156, 38, 24, 0.10);
  border: 1px solid rgba(156, 38, 24, 0.35);
  border-radius: var(--radius-2xl);
  box-shadow: 0 0 40px rgba(156, 38, 24, 0.18);
}
.voice-pitch-line {
  margin: 0;
  font-size: var(--text-lg);
  line-height: 1.55;
  color: var(--text-secondary);
  word-break: keep-all;
  text-wrap: balance;
}
.voice-pitch-line strong { color: var(--text-primary); }
.voice-pitch-line code {
  background: rgba(156, 38, 24, 0.18);
  color: var(--color-accent-soft);
  padding: 2px 10px;
  border-radius: var(--radius-full);
  font-family: var(--font-mono);
  font-size: var(--text-md);
  font-weight: 600;
}
.voice-pitch-line--emph {
  margin-top: var(--space-3);
  font-size: var(--text-xl);
  color: var(--text-primary);
}
.voice-pitch-line--emph strong {
  background: var(--gradient-accent);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-weight: 800;
}
.voice-pitch-divider {
  margin: var(--space-3) 0;
  text-align: center;
  color: var(--color-accent-soft);
  font-size: 22px;
  letter-spacing: 0.5em;
  line-height: 1;
  opacity: 0.5;
}

/* Voice — 3단계 방법 */
.voice-how {
  display: grid;
  grid-template-columns: 1fr auto 1fr auto 1fr;
  gap: var(--space-4);
  align-items: stretch;
  max-width: 1040px;
  margin: 0 auto var(--space-12);
}
.voice-how-step {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-2xl);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  text-align: center;
  transition: border-color var(--duration-normal), box-shadow var(--duration-normal);
}
.voice-how-step:hover {
  border-color: rgba(156, 38, 24, 0.4);
  box-shadow: 0 0 24px rgba(156, 38, 24, 0.18);
}
.voice-how-num {
  margin: 0;
  font-family: var(--font-mono);
  font-size: var(--text-display-sm);
  background: var(--gradient-accent);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-weight: 800;
  line-height: 1;
  letter-spacing: -0.02em;
}
.voice-how-title {
  margin: var(--space-2) 0 0;
  font-size: var(--text-md);
  color: var(--text-primary);
  font-weight: 700;
  letter-spacing: -0.01em;
}
.voice-how-title code {
  background: rgba(156, 38, 24, 0.14);
  color: var(--color-accent-soft);
  padding: 1px 8px;
  border-radius: var(--radius-md);
  font-family: var(--font-mono);
  font-size: 14px;
}
.voice-how-desc {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--text-secondary);
  line-height: 1.6;
  word-break: keep-all;
  text-wrap: balance;
}
.voice-how-arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  color: var(--color-accent-soft);
  font-weight: 300;
  opacity: 0.6;
}
@media (max-width: 768px) {
  .voice-how {
    grid-template-columns: 1fr;
  }
  .voice-how-arrow { transform: rotate(90deg); padding: var(--space-2) 0; }
}

/* Voice — 적용 콘텐츠 그리드 */
.voice-applies {
  max-width: 960px;
  margin: 0 auto var(--space-12);
  text-align: center;
}
.voice-applies-label {
  margin: 0 0 var(--space-5);
  font-size: var(--text-sm);
  color: var(--text-tertiary);
  font-family: var(--font-mono);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.voice-applies-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: var(--space-3);
}
.voice-apply {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-xl);
  padding: var(--space-4) var(--space-3);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  transition: border-color var(--duration-fast);
}
.voice-apply:hover { border-color: rgba(156, 38, 24, 0.4); }
.voice-apply-icon { font-size: 24px; }
.voice-apply span:last-child {
  font-size: var(--text-xs);
  color: var(--text-secondary);
  text-align: center;
  line-height: 1.4;
  font-weight: 500;
}
@media (max-width: 960px) {
  .voice-applies-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 480px) {
  .voice-applies-grid { grid-template-columns: repeat(2, 1fr); }
}

/* Voice — 푸터 */
.voice-foot {
  text-align: center;
  max-width: 640px;
  margin: 0 auto;
}
.voice-foot p {
  margin: 0;
  font-size: var(--text-md);
  color: var(--text-primary);
  line-height: 1.7;
}
.voice-foot p strong {
  color: var(--color-accent-soft);
}
.voice-foot-sub {
  margin-top: var(--space-3) !important;
  font-size: var(--text-sm) !important;
  color: var(--text-tertiary) !important;
}
.voice-foot-sub code {
  background: rgba(156, 38, 24, 0.10);
  color: var(--color-accent-soft);
  padding: 1px 6px;
  border-radius: 4px;
  font-family: var(--font-mono);
  font-size: 12px;
}


/* ── 3.5 USP — 맥락이 살아있는 협업 (Claude × DB) ⭐ ── */
.usp-section {
  padding: var(--space-24, 96px) 0;
  background:
    radial-gradient(ellipse at top, rgba(156, 38, 24, 0.12) 0%, transparent 60%),
    linear-gradient(180deg, rgba(156, 38, 24, 0.04) 0%, rgba(156, 38, 24, 0.08) 100%);
}
.usp-pitch {
  max-width: 720px;
  margin: var(--space-10) auto var(--space-12);
  text-align: center;
  padding: var(--space-10) var(--space-6);
  background: rgba(156, 38, 24, 0.10);
  border: 1px solid rgba(156, 38, 24, 0.35);
  border-radius: var(--radius-2xl);
  box-shadow: 0 0 48px rgba(156, 38, 24, 0.22);
}
.usp-pitch-line {
  margin: 0;
  font-size: var(--text-lg);
  line-height: 1.55;
  color: var(--text-secondary);
}
.usp-pitch-line strong { color: var(--text-primary); }
.usp-pitch-line--emph {
  margin-top: var(--space-3);
  font-size: var(--text-xl);
  color: var(--text-primary);
}
.usp-pitch-line--emph strong {
  background: var(--gradient-accent);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-weight: 800;
}
.usp-pitch-divider {
  margin: var(--space-3) 0;
  text-align: center;
  color: var(--color-accent-soft);
  font-size: 24px;
  letter-spacing: 0.5em;
  line-height: 1;
  opacity: 0.5;
}

.usp-cases {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4);
  max-width: 960px;
  margin: 0 auto var(--space-10);
}
.usp-case {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-2xl);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  align-items: center;
  text-align: center;
  transition: border-color var(--duration-normal), box-shadow var(--duration-normal);
}
.usp-case:hover {
  border-color: rgba(156, 38, 24, 0.4);
  box-shadow: 0 0 24px rgba(156, 38, 24, 0.18);
}
.usp-input {
  margin: 0;
  font-size: var(--text-md);
  color: var(--text-primary);
  line-height: 1.55;
  padding: var(--space-4) var(--space-5);
  background: rgba(156, 38, 24, 0.10);
  border: 1px solid rgba(156, 38, 24, 0.25);
  border-radius: var(--radius-lg);
  font-weight: 500;
  font-style: italic;
}
.usp-arrow {
  font-size: 24px;
  color: var(--color-accent-soft);
  font-weight: 300;
  line-height: 1;
}
.usp-output {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--text-secondary);
  line-height: 1.65;
}
.usp-output strong { color: var(--text-primary); }

.usp-foot {
  max-width: 720px;
  margin: 0 auto;
  text-align: center;
  padding: var(--space-6) 0;
}
.usp-foot-list {
  margin: 0;
  font-size: var(--text-md);
  color: var(--text-tertiary);
  line-height: 1.8;
  font-weight: 500;
}
.usp-foot-close {
  margin: var(--space-3) 0 0;
  font-size: var(--text-md);
  color: var(--text-primary);
  line-height: 1.7;
}
.usp-foot-close strong { color: var(--color-accent-soft); }
@media (max-width: 768px) {
  .usp-cases { grid-template-columns: 1fr; }
}


/* Hero — Pain → Resolve 시각 구별 */
.hero-sub-block {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  margin: var(--space-6) auto var(--space-4);
  max-width: 720px;
}
.hero-pain {
  margin: 0;
  font-size: var(--text-md);
  color: var(--text-tertiary);
  opacity: 0.85;
  text-align: center;
  letter-spacing: -0.01em;
  line-height: 1.6;
  word-break: keep-all;
  text-wrap: balance;
}
.hero-divider {
  font-size: 26px;
  color: var(--color-accent-soft);
  font-weight: 300;
  line-height: 1;
  opacity: 0.55;
  margin: var(--space-1) 0;
}
.hero-resolve {
  margin: 0;
  font-size: var(--text-lg);
  color: var(--text-primary);
  text-align: center;
  line-height: 1.65;
  letter-spacing: -0.01em;
  word-break: keep-all;
  text-wrap: balance;
}
.hero-resolve strong {
  color: var(--color-accent-soft);
  background: linear-gradient(180deg, transparent 60%, rgba(156, 38, 24, 0.18) 60%);
  padding: 0 4px;
}

/* Hero — 평생 사용 강조 라인 (legacy, hero-quote 로 교체됨) */
.hero-lifetime {
  margin: var(--space-4) 0 var(--space-6);
  font-size: var(--text-md);
  color: var(--text-primary);
  background: rgba(156, 38, 24, 0.12);
  border: 1px solid rgba(156, 38, 24, 0.35);
  padding: var(--space-3) var(--space-5);
  border-radius: var(--radius-full);
  display: inline-block;
}
.hero-lifetime strong { color: var(--color-accent-soft); }

/* Hero — 라이언 인용 */
.hero-quote {
  margin: var(--space-6) 0;
  padding: var(--space-5) var(--space-6);
  background: rgba(156, 38, 24, 0.06);
  border-left: 3px solid var(--color-accent);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  max-width: 560px;
  width: 100%;
  text-align: left;
}
.hero-quote-text {
  margin: 0;
  font-size: var(--text-md);
  line-height: 1.55;
  color: var(--text-primary);
  font-style: italic;
}
.hero-quote-text strong {
  font-style: normal;
  background: var(--gradient-accent);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-weight: 700;
}
.hero-quote-sig {
  margin: var(--space-2) 0 0;
  font-size: var(--text-sm);
  color: var(--text-tertiary);
  text-align: right;
  font-family: var(--font-mono);
  letter-spacing: 0.03em;
}
.hero-quote-sig a {
  color: var(--color-accent-soft);
  text-decoration: none;
  transition: color var(--duration-fast);
}
.hero-quote-sig a:hover {
  color: var(--color-accent);
  text-decoration: underline;
}
.hero-quote-sig-meta {
  margin-left: 6px;
  color: var(--text-tertiary);
  font-family: var(--font-mono);
  letter-spacing: 0.02em;
}
.hero-quote-sig-meta strong {
  color: var(--text-primary);
  font-weight: 700;
}

/* Hero — social proof line (본인 사용 메타) */
.hero-proof {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin: var(--space-5) auto var(--space-2);
  padding: var(--space-3) var(--space-5);
  max-width: 560px;
  width: 100%;
  background: rgba(156, 38, 24, 0.06);
  border: 1px solid rgba(156, 38, 24, 0.22);
  border-radius: var(--radius-lg);
}
.hero-proof-icon {
  font-size: 22px;
  line-height: 1;
  flex-shrink: 0;
}
.hero-proof-text {
  font-size: var(--text-sm);
  line-height: 1.6;
  color: var(--text-secondary);
  text-align: left;
}
.hero-proof-text strong {
  color: var(--text-primary);
  font-weight: 700;
}

/* ── 3. Shift Before/After ── */
.shift-section {
  padding: var(--space-20) 0;
  background: linear-gradient(180deg, transparent 0%, rgba(156, 38, 24, 0.04) 100%);
}
.shift-grid {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: var(--space-6);
  align-items: stretch;
  max-width: 960px;
  margin: 0 auto;
}
.shift-card {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-2xl);
  padding: var(--space-8);
  backdrop-filter: var(--glass-blur);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.shift-before {
  opacity: 0.85;
}
.shift-after {
  border-color: rgba(156, 38, 24, 0.4);
  background: rgba(156, 38, 24, 0.08);
  box-shadow: 0 0 32px rgba(156, 38, 24, 0.18);
}
.shift-label {
  margin: 0;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-tertiary);
}
.shift-after .shift-label { color: var(--color-accent-soft); }
.shift-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.shift-list li {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  line-height: 1.6;
  padding-left: var(--space-4);
  position: relative;
}
.shift-list li::before {
  content: "·";
  position: absolute;
  left: 0;
  color: var(--text-tertiary);
}
.shift-foot {
  margin: 0;
  padding-top: var(--space-3);
  border-top: 1px solid var(--glass-border);
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  font-family: var(--font-mono);
}
.shift-message {
  margin: 0;
  font-size: var(--text-lg);
  line-height: 1.5;
  color: var(--text-primary);
}
.shift-message strong { color: var(--color-accent-soft); }
.shift-arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 36px;
  color: var(--color-accent-soft);
  font-weight: 300;
}
@media (max-width: 768px) {
  .shift-grid { grid-template-columns: 1fr; }
  .shift-arrow { transform: rotate(90deg); padding: var(--space-2) 0; }
}

/* ── 4. Team detail — agent-grid-detail ── */
.agent-grid-detail .agent-card { padding: var(--space-6); }
.agent-role {
  margin: var(--space-1) 0 var(--space-3);
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  font-family: var(--font-mono);
  letter-spacing: 0.02em;
}
.agent-example {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--text-secondary);
  line-height: 1.55;
  padding: var(--space-3);
  background: rgba(124, 58, 237, 0.08);
  border-left: 2px solid var(--color-accent-soft);
  border-radius: var(--radius-md);
  font-style: italic;
}
.agents-foot {
  margin: var(--space-8) auto 0;
  max-width: 640px;
  text-align: center;
  font-size: var(--text-sm);
  color: var(--text-tertiary);
  line-height: 1.6;
}
.agents-foot a { color: var(--color-accent-soft); }

/* ── 5. Tools — /create * ── */
.tools-section { padding: var(--space-20) 0; }
.tools-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--space-4);
  max-width: 960px;
  margin: 0 auto;
}
.tool-card {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-xl);
  padding: var(--space-5) var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.tool-cat { margin: 0; font-size: var(--text-sm); color: var(--text-primary); font-weight: 600; }
.tool-cmd { margin: 0; font-size: var(--text-xs); color: var(--color-accent-soft); font-family: var(--font-mono); }
.tool-cmd code { background: none; padding: 0; color: var(--color-accent-soft); }
.tool-desc { margin: 0; font-size: var(--text-xs); color: var(--text-tertiary); line-height: 1.55; }

/* ── 6. Workflow — Live + Coming Soon ── */
.workflow-section {
  padding: var(--space-20) 0;
  background: linear-gradient(180deg, rgba(156, 38, 24, 0.04) 0%, transparent 100%);
}
.workflow-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-6);
  max-width: 1000px;
  margin: 0 auto;
}
.workflow-col {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-2xl);
  padding: var(--space-8);
  min-width: 0;
  max-width: 100%;
}
.workflow-live { border-color: rgba(34, 197, 94, 0.3); }
.workflow-coming { border-color: rgba(234, 179, 8, 0.3); }
.workflow-status {
  margin: 0 0 var(--space-5);
  font-size: var(--text-sm);
  font-weight: 700;
  color: var(--text-primary);
}
.workflow-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.workflow-list li {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  line-height: 1.65;
  padding-left: var(--space-4);
  position: relative;
}
.workflow-list li::before {
  content: "·";
  position: absolute;
  left: 0;
  color: var(--text-tertiary);
}
.workflow-foot {
  margin: var(--space-8) auto 0;
  max-width: 720px;
  text-align: center;
  font-size: var(--text-sm);
  color: var(--text-tertiary);
  line-height: 1.65;
}
@media (max-width: 768px) {
  .workflow-grid { grid-template-columns: 1fr; }
}

/* ── 8. Vs — 2-column 위 + Creator OS 풀폭 하단 ── */
.vs-section { padding: var(--space-20) 0; }
.vs-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4);
  max-width: 1000px;
  margin: 0 auto;
}
.vs-card {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  text-align: center;
  opacity: 0.85;
}
.vs-card--featured {
  grid-column: 1 / -1;
  border: 3px solid var(--color-accent);
  background:
    radial-gradient(ellipse at center, rgba(156, 38, 24, 0.18) 0%, rgba(156, 38, 24, 0.06) 70%);
  box-shadow:
    0 0 40px rgba(156, 38, 24, 0.30),
    0 0 0 1px rgba(156, 38, 24, 0.4) inset;
  padding: var(--space-10) var(--space-8);
  opacity: 1;
  position: relative;
  margin-top: var(--space-2);
}
.vs-card--featured::before {
  content: "✨";
  position: absolute;
  top: -16px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--color-accent);
  color: #fff;
  font-size: 16px;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 16px rgba(156, 38, 24, 0.5);
}
.vs-name {
  margin: 0 0 var(--space-3);
  font-size: var(--text-md);
  font-weight: 700;
  color: var(--text-primary);
  line-height: 1.4;
}
.vs-name-sub {
  display: inline-block;
  margin-top: 4px;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: 500;
  color: var(--text-tertiary);
  letter-spacing: 0.02em;
}
.vs-card--featured .vs-name-sub {
  color: var(--color-accent-soft);
  font-weight: 700;
  -webkit-text-fill-color: var(--color-accent-soft);
  background: none;
}
.vs-card--featured .vs-name {
  font-size: var(--text-xl);
  background: var(--gradient-accent);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-weight: 800;
  letter-spacing: -0.02em;
}
.vs-desc {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--text-secondary);
  line-height: 1.6;
}
.vs-card--featured .vs-desc {
  font-size: var(--text-md);
  color: var(--text-primary);
  max-width: 720px;
  margin: 0 auto;
  line-height: 1.7;
}
.vs-card--featured .vs-desc strong { color: var(--color-accent-soft); }
@media (max-width: 768px) {
  .vs-grid { grid-template-columns: 1fr; }
  .vs-card--featured { grid-column: 1 / -1; padding: var(--space-8) var(--space-5); }
}

/* ── Pricing — 평생 사용 + 크레딧 매트릭스 ── */
.plan-lifetime {
  display: inline-block;
  margin: var(--space-2) 0;
  padding: 4px var(--space-3);
  font-size: var(--text-xs);
  color: var(--color-accent-soft);
  background: rgba(156, 38, 24, 0.12);
  border: 1px solid rgba(156, 38, 24, 0.3);
  border-radius: var(--radius-full);
  font-weight: 600;
}
.plan-credit-matrix {
  margin-top: var(--space-4);
  padding: var(--space-4);
  background: rgba(156, 38, 24, 0.08);
  border: 1px solid rgba(156, 38, 24, 0.25);
  border-radius: var(--radius-lg);
}
.plan-credit-label {
  margin: 0 0 var(--space-2);
  font-size: var(--text-xs);
  color: var(--color-accent-soft);
  font-weight: 700;
  letter-spacing: 0.03em;
}
.plan-credit-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}
.plan-credit-list li {
  font-size: var(--text-xs);
  color: var(--text-secondary);
  line-height: 1.6;
}

/* ── 10a. Claude 구독 비교 ── */
.claude-section {
  padding: var(--space-20) 0;
  background: linear-gradient(180deg, transparent 0%, rgba(156, 38, 24, 0.04) 50%, transparent 100%);
}
.claude-compare {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: var(--space-6);
  align-items: stretch;
  max-width: 960px;
  margin: 0 auto var(--space-8);
}
.claude-col {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-2xl);
  padding: var(--space-8);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.claude-col-api { opacity: 0.85; }
.claude-col-sub {
  border-color: rgba(156, 38, 24, 0.4);
  background: rgba(156, 38, 24, 0.08);
  box-shadow: 0 0 32px rgba(156, 38, 24, 0.18);
}
.claude-col-label {
  margin: 0;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-tertiary);
}
.claude-col-sub .claude-col-label { color: var(--color-accent-soft); }
.claude-col-price {
  margin: 0;
  font-size: var(--text-xl);
  color: var(--text-primary);
}
.claude-col-price-note {
  margin: 2px 0 0;
  font-size: var(--text-sm);
  color: var(--text-tertiary);
  font-weight: 500;
}
.claude-plan-cards {
  list-style: none;
  margin: var(--space-4) 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
}
.claude-plan-card {
  padding: var(--space-3) var(--space-4);
  border: 1px solid var(--glass-border);
  background: rgba(255, 255, 255, 0.03);
}
.claude-plan-card:first-child { border-radius: 12px 12px 0 0; }
.claude-plan-card:last-child { border-radius: 0 0 12px 12px; }
.claude-plan-card + .claude-plan-card { border-top: none; }
.claude-plan-name {
  margin: 0;
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--text-primary);
}
.claude-plan-price {
  margin: 2px 0 0;
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-size: var(--text-sm);
  color: var(--text-secondary);
}
.claude-plan-krw {
  font-size: var(--text-xs);
  color: var(--text-tertiary);
}
.claude-col-detail {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--text-secondary);
  line-height: 1.6;
}
.claude-col-note {
  margin: 0;
  padding-top: var(--space-3);
  border-top: 1px solid var(--glass-border);
  font-size: var(--text-xs);
  color: var(--text-tertiary);
}
.claude-col-note-label {
  margin: 0 0 6px;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-accent-soft);
}
.claude-col-note-list {
  margin: 0;
  padding-left: 32px;
  list-style: disc;
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  line-height: 1.6;
}
.claude-col-note-list li { margin-bottom: 2px; }
.claude-vs {
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: var(--text-md);
  color: var(--text-tertiary);
  font-weight: 700;
  letter-spacing: 0.05em;
}
.claude-pitch {
  max-width: 720px;
  margin: 0 auto;
  text-align: center;
  padding: var(--space-6);
  background: rgba(156, 38, 24, 0.12);
  border: 1px solid rgba(156, 38, 24, 0.35);
  border-radius: var(--radius-2xl);
}
.claude-pitch p {
  margin: 0;
  font-size: var(--text-md);
  color: var(--text-primary);
  line-height: 1.6;
}
.claude-pitch strong { color: var(--color-accent-soft); }
.claude-pitch-sub {
  margin-top: var(--space-2) !important;
  font-size: var(--text-sm) !important;
  color: var(--text-secondary) !important;
}
@media (max-width: 768px) {
  .claude-compare { grid-template-columns: 1fr; }
  .claude-vs { transform: rotate(90deg); padding: var(--space-2) 0; }
}

/* ── 10b. Trust ── */
.trust-section { padding: var(--space-20) 0; }
.trust-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--space-4);
  max-width: 1000px;
  margin: 0 auto;
}
.trust-card {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.trust-icon { margin: 0; font-size: 32px; }
.trust-title { margin: 0; font-size: var(--text-md); font-weight: 700; color: var(--text-primary); }
.trust-desc { margin: 0; font-size: var(--text-sm); color: var(--text-secondary); line-height: 1.55; }

/* ── 11. Final CTA ── */
.final-cta-section {
  padding: var(--space-20) 0;
  background: linear-gradient(180deg, transparent 0%, rgba(156, 38, 24, 0.06) 100%);
}
.final-cta-inner { max-width: 720px; margin: 0 auto; text-align: center; }
.final-cta-buttons {
  display: flex;
  justify-content: center;
  gap: var(--space-3);
  margin: var(--space-8) 0 var(--space-6);
  flex-wrap: wrap;
}
.final-cta-note {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--text-tertiary);
  line-height: 1.7;
}
.final-cta-note a { color: var(--color-accent-soft); }

/* ─────────────────────────────────────────────────────────────
   v2 — 크리에이터를 위한 AI 포지셔닝 (2026-06-08)
   ───────────────────────────────────────────────────────────── */

/* Hero v2 — headline + 자연어 프롬프트 데모 */
.hero-title.hero-headline-v2 {
  font-size: clamp(2.4rem, 6.5vw, 4.6rem);
  line-height: 1.15;
  font-weight: 800;
  letter-spacing: -0.02em;
  background: linear-gradient(135deg, var(--text-primary) 0%, var(--color-accent-soft) 70%, var(--color-accent) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-align: center;
  margin: 0;
}
.hero-title.hero-headline-v2 strong {
  background: var(--gradient-accent);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-weight: 900;
}

.hero-prompt-demo {
  margin-top: var(--space-4);
  padding: var(--space-6) var(--space-8);
  background: var(--bg-elevated);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-2xl);
  max-width: 640px;
  text-align: center;
  position: relative;
  box-shadow: var(--shadow-md);
}
.hero-prompt-demo::before {
  content: "💬";
  position: absolute;
  top: -14px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--color-accent);
  color: var(--on-accent);
  padding: 2px 10px;
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
}
.hero-prompt-line {
  font-family: var(--font-mono);
  font-size: var(--text-md);
  line-height: 1.6;
  color: var(--text-primary);
  margin: 0;
}
.hero-prompt-line strong { color: var(--color-accent-soft); }
.hero-prompt-meta {
  margin: var(--space-3) 0 0;
  font-size: var(--text-sm);
  color: var(--text-tertiary);
}

/* ── Prompt Compare — 같은 한 줄, 다른 결과 ── */
.prompt-compare {
  padding: var(--space-20) 0;
  background: linear-gradient(180deg,
    transparent 0%,
    rgba(156, 38, 24, 0.04) 50%,
    transparent 100%);
}

.compare-case {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-2xl);
  padding: var(--space-8);
  margin-bottom: var(--space-8);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
}
.compare-case:last-of-type { margin-bottom: var(--space-12); }

.compare-case-head {
  text-align: center;
  margin-bottom: var(--space-6);
  padding-bottom: var(--space-5);
  border-bottom: 1px dashed var(--border-subtle);
}
.compare-case-tag {
  display: inline-block;
  padding: 4px 12px;
  background: var(--gradient-accent);
  color: var(--on-accent);
  font-size: var(--text-xs);
  font-weight: 700;
  border-radius: var(--radius-full);
  letter-spacing: 0.04em;
  margin-bottom: var(--space-3);
}
.compare-intent {
  margin: 0;
  font-size: var(--text-md);
  color: var(--text-primary);
  font-weight: 600;
}

.compare-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  gap: var(--space-3);
  align-items: stretch;
}

/* BEFORE → AFTER 화살표 */
.compare-arrow {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 0 var(--space-2);
  min-width: 48px;
}
.compare-arrow-icon {
  font-size: clamp(1.5rem, 2.6vw, 2.25rem);
  font-weight: 800;
  background: var(--gradient-accent);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  line-height: 1;
}

/* BEFORE / AFTER stage 배지 */
.compare-stage {
  display: inline-block;
  margin-right: var(--space-2);
  padding: 2px 8px;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  border-radius: var(--radius-sm);
  vertical-align: 1px;
}
.compare-col--general .compare-stage {
  background: rgba(255, 255, 255, 0.07);
  color: var(--text-tertiary);
}
.compare-col--coscale .compare-stage {
  background: var(--gradient-accent);
  color: var(--on-accent);
}

/* 결과 메트릭 — 작업시간 / 반복 / 실패 (양쪽 동일 row 구조) */
.compare-result-stats {
  list-style: none;
  margin: var(--space-2) 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.compare-result-stats li {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-xs);
  line-height: 1.5;
}
.compare-result-stats li > span {
  color: var(--text-tertiary);
  flex-shrink: 0;
}
.compare-result-stats li > strong {
  color: var(--text-primary);
  font-weight: 700;
  text-align: right;
  word-break: keep-all;
}
.compare-result--coscale .compare-result-stats li > strong {
  color: #ffffff;
  background: none;
  -webkit-text-fill-color: #ffffff;
  font-weight: 800;
}
.compare-result--coscale .compare-result-stats li > span {
  color: rgba(255, 255, 255, 0.65);
}

/* Discord 답장(reply) 표시 */
.mock-discord-reply {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 6px;
  padding-left: 22px;
  position: relative;
  font-size: 12px;
  line-height: 1.4;
  color: #b0b3b8;
}
.mock-discord-reply::before {
  content: "";
  position: absolute;
  left: 4px;
  top: 8px;
  width: 12px;
  height: 8px;
  border-top: 2px solid #4e505b;
  border-left: 2px solid #4e505b;
  border-top-left-radius: 6px;
}
.mock-discord-reply-user {
  color: #c87a5a;
  font-weight: 600;
  flex-shrink: 0;
}
.mock-discord-reply-text {
  color: #80848e;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
}

.compare-col {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-6);
  border-radius: var(--radius-xl);
  background: var(--bg-elevated);
  border: 1px solid var(--border-subtle);
  min-width: 0;
  max-width: 100%;
}
.compare-col > * { min-width: 0; max-width: 100%; }
.compare-col .mock-ui { min-width: 0; max-width: 100%; box-sizing: border-box; }
.compare-col pre { max-width: 100%; min-width: 0; overflow-x: auto; }
.compare-col--coscale {
  background: linear-gradient(180deg,
    rgba(156, 38, 24, 0.10) 0%,
    rgba(156, 38, 24, 0.04) 100%);
  border-color: var(--color-accent);
  box-shadow: var(--shadow-md), 0 0 32px rgba(156, 38, 24, 0.15);
}

.compare-col-label {
  margin: 0;
  font-size: var(--text-sm);
  font-weight: 700;
  color: var(--text-tertiary);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.compare-col--coscale .compare-col-label {
  background: var(--gradient-accent);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.compare-col-sub {
  margin: 0 0 var(--space-2);
  font-size: var(--text-sm);
  color: var(--text-secondary);
}

.compare-prompt {
  margin: 0;
  padding: var(--space-4);
  background: rgba(0, 0, 0, 0.35);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  overflow-x: auto;
}
.compare-prompt code {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  line-height: 1.6;
  color: var(--text-secondary);
  white-space: pre-wrap;
  word-break: keep-all;
}
.compare-prompt--natural {
  background: rgba(156, 38, 24, 0.10);
  border-color: var(--color-accent);
}
.compare-prompt--natural code {
  color: var(--text-primary);
  font-weight: 600;
  font-size: var(--text-base);
}

/* Mock UI — 웹 인터페이스 + Discord 메시지 (위계 핵심) */
.mock-ui {
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid rgba(0, 0, 0, 0.4);
  margin: 0;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3);
}

/* 일반 AI = 웹 사이트 모의 */
.mock-ui--web {
  background: #1e1f22;
}
.mock-browser-bar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 8px 12px;
  background: #2a2a2e;
  border-bottom: 1px solid #16171a;
}
.mock-browser-dots {
  display: inline-flex;
  gap: 6px;
  flex-shrink: 0;
}
.mock-browser-dots i {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  display: block;
}
.mock-browser-dots i:nth-child(1) { background: #ff5f57; }
.mock-browser-dots i:nth-child(2) { background: #febc2e; }
.mock-browser-dots i:nth-child(3) { background: #28c840; }
.mock-browser-url {
  flex: 1;
  font-family: var(--font-mono);
  font-size: 11px;
  color: #8a8d93;
  padding: 4px 10px;
  background: #16171a;
  border-radius: 4px;
  text-align: center;
}
.mock-web-body {
  padding: var(--space-3);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.mock-web-body pre {
  margin: 0;
  padding: var(--space-3);
  background: #0f1012;
  border: 1px solid #2a2b30;
  border-radius: var(--radius-sm);
  overflow-x: auto;
}
.mock-web-body pre code {
  font-family: var(--font-mono);
  font-size: 12px;
  line-height: 1.55;
  color: #8a8d93;
  white-space: pre-wrap;
  word-break: keep-all;
}
.mock-web-submit {
  align-self: flex-end;
  padding: 6px 16px;
  background: #3b3d44;
  color: #b0b3b8;
  border: none;
  border-radius: var(--radius-sm);
  font-size: 11px;
  font-weight: 600;
  cursor: default;
  pointer-events: none;
}

/* Creator-OS = Discord 메시지 모의 — 보라 테두리는 희미하게 빛나는 글로우로 */
.mock-ui--discord {
  background: #313338;
  border: 1px solid rgba(156, 38, 24, 0.18);
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.35),
              0 0 24px rgba(156, 38, 24, 0.12),
              0 0 64px rgba(156, 38, 24, 0.10),
              0 0 120px rgba(156, 38, 24, 0.06);
  text-align: left;
}
.mock-discord-channel {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  background: #2b2d31;
  border-bottom: 1px solid #1f2123;
  font-size: 13px;
}
.mock-discord-icon {
  color: #80848e;
  font-weight: 600;
  font-size: 18px;
  line-height: 1;
}
.mock-discord-channelname {
  color: #f2f3f5;
  font-weight: 600;
}
.mock-discord-message {
  display: flex;
  gap: 14px;
  padding: 16px 14px;
}
.mock-discord-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--color-accent) 0%, #ec4899 100%);
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 16px;
  flex-shrink: 0;
  overflow: hidden;
  background-size: cover;
  background-position: center;
}
.mock-discord-avatar--ryan {
  background: url("/static/img/hero/ryan_profile.jpg") center/cover no-repeat,
              linear-gradient(135deg, var(--color-accent) 0%, #ec4899 100%);
  color: transparent;
}
.mock-discord-content { flex: 1; min-width: 0; }
.mock-discord-meta {
  display: flex;
  align-items: baseline;
  gap: 8px;
  margin-bottom: 4px;
}
.mock-discord-user { color: #f2f3f5; font-weight: 600; font-size: 14px; }
.mock-discord-time { color: #80848e; font-size: 11px; }
/* 강조 — 짧은 한 줄 메시지 (위계 최상위) */
.mock-discord-text {
  margin: 0;
  color: #ffffff;
  font-size: clamp(1.05rem, 1.7vw, 1.25rem);
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: -0.005em;
}

/* 위계 보정 — 컨텍스트 리스트와 결과 설명은 보조 정보로 한 단계 낮춤 */
.compare-col .compare-context {
  margin-top: var(--space-3);
  padding: var(--space-3) var(--space-4);
}
.compare-col .compare-context-label {
  font-size: 10px;
}
.compare-col .compare-context-list li {
  font-size: var(--text-xs);
  line-height: 1.55;
  color: var(--text-tertiary);
}
.compare-col .compare-result {
  padding: var(--space-3) var(--space-4);
}
.compare-col .compare-result-label {
  font-size: 10px;
}
.compare-col .compare-result-desc {
  font-size: var(--text-xs);
  line-height: 1.55;
}

.compare-context {
  margin-top: var(--space-3);
  padding: var(--space-4);
  background: rgba(156, 38, 24, 0.06);
  border-left: 3px solid var(--color-accent);
  border-radius: var(--radius-md);
}
.compare-context-label {
  margin: 0 0 var(--space-2);
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--color-accent-soft);
  letter-spacing: 0.04em;
}
.compare-context-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}
.compare-context-list li {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  line-height: 1.6;
}

/* 한 줄 disclaimer — "이게 되는 이유" 보조 설명 */
.compare-disclaimer {
  margin: var(--space-3) 0 0;
  padding: var(--space-2) 0 var(--space-2) var(--space-3);
  border-left: 2px solid rgba(156, 38, 24, 0.45);
  font-size: var(--text-xs);
  line-height: 1.55;
  color: var(--text-tertiary);
}
.compare-disclaimer-label {
  display: inline-block;
  margin-right: var(--space-2);
  padding: 1px 6px;
  background: rgba(156, 38, 24, 0.14);
  color: var(--color-accent-soft);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.04em;
  border-radius: var(--radius-sm);
  vertical-align: 1px;
}

.compare-result {
  margin-top: auto;
  padding: var(--space-4);
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--border-subtle);
}
.compare-result--coscale {
  background: rgba(156, 38, 24, 0.12);
  border-color: var(--color-accent-soft);
}
.compare-result-label {
  margin: 0 0 var(--space-1);
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--text-tertiary);
  letter-spacing: 0.04em;
}
.compare-result--coscale .compare-result-label { color: var(--color-accent-soft); }
.compare-result-desc {
  margin: 0;
  font-size: var(--text-sm);
  line-height: 1.6;
  color: var(--text-secondary);
}
.compare-result--coscale .compare-result-desc { color: var(--text-primary); }
.compare-result-desc strong { color: var(--text-primary); }

@media (max-width: 768px) {
  .compare-grid { grid-template-columns: 1fr; }
  .compare-case { padding: var(--space-6) var(--space-4); }
  .compare-col { padding: var(--space-5) var(--space-4); }
  .compare-arrow { padding: var(--space-2) 0; min-width: 0; }
  .compare-arrow-icon { transform: rotate(90deg); }
}

.compare-foot {
  text-align: center;
  max-width: 640px;
  margin: 0 auto;
  padding-top: var(--space-6);
}
.compare-foot-lead {
  font-size: var(--text-lg);
  color: var(--text-primary);
  line-height: 1.6;
  margin: 0 0 var(--space-2);
}
.compare-foot-lead strong {
  background: var(--gradient-accent);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.compare-foot-sub {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--text-tertiary);
}

/* ── Why Works — 비교가 가능한 이유 ── */
.why-works {
  padding: var(--space-16) 0 var(--space-20);
}
.why-works .section-sub code {
  font-family: var(--font-mono);
  font-size: 0.95em;
  padding: 1px 6px;
  background: rgba(156, 38, 24, 0.12);
  border-radius: var(--radius-sm);
  color: var(--color-accent-soft);
}

.why-pillars {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-4);
}
@media (max-width: 980px) {
  .why-pillars { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .why-pillars { grid-template-columns: 1fr; }
}

.why-pillar {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-xl);
  padding: var(--space-6) var(--space-5);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  transition: border-color var(--duration-normal),
              transform var(--duration-normal) var(--ease-spring);
}
.why-pillar:hover {
  transform: translateY(var(--hover-lift));
  border-color: var(--color-accent);
}
.why-pillar-icon {
  margin: 0;
  font-size: 28px;
  line-height: 1;
}
.why-pillar-title {
  margin: 0;
  font-size: var(--text-md);
  font-weight: 700;
  color: var(--text-primary);
}
.why-pillar-title code {
  font-family: var(--font-mono);
  font-size: 0.9em;
  color: var(--color-accent-soft);
}
.why-pillar-desc {
  margin: 0;
  font-size: var(--text-sm);
  line-height: 1.6;
  color: var(--text-secondary);
}
.why-pillar-desc code {
  font-family: var(--font-mono);
  padding: 1px 5px;
  background: rgba(156, 38, 24, 0.12);
  border-radius: var(--radius-sm);
  color: var(--color-accent-soft);
}

.why-foot {
  text-align: center;
  margin-top: var(--space-10);
  padding-top: var(--space-6);
  border-top: 1px dashed var(--border-subtle);
}
.why-foot-line {
  margin: 0;
  font-size: var(--text-md);
  color: var(--text-secondary);
}
.why-foot-close {
  margin: var(--space-3) 0 0;
  font-size: var(--text-lg);
  color: var(--text-primary);
}
.why-foot-close strong {
  background: var(--gradient-accent);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ── Evolve — 쓸수록 더 정교 ── */
.evolve-section {
  padding: var(--space-16) 0 var(--space-20);
  background: linear-gradient(180deg,
    transparent 0%,
    rgba(156, 38, 24, 0.06) 50%,
    transparent 100%);
}

.evolve-timeline {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
  position: relative;
}
@media (max-width: 880px) {
  .evolve-timeline { grid-template-columns: 1fr; }
}

.evolve-step {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-2xl);
  padding: var(--space-6) var(--space-5);
  backdrop-filter: var(--glass-blur);
  -webkit-backdrop-filter: var(--glass-blur);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  position: relative;
  transition: transform var(--duration-normal) var(--ease-spring),
              border-color var(--duration-normal),
              box-shadow var(--duration-normal);
}
.evolve-step:hover {
  transform: translateY(var(--hover-lift));
  border-color: var(--color-accent);
}

.evolve-step--peak {
  background: linear-gradient(180deg,
    rgba(156, 38, 24, 0.14) 0%,
    rgba(156, 38, 24, 0.04) 100%);
  border-color: var(--color-accent);
  box-shadow: var(--shadow-md), 0 0 40px rgba(156, 38, 24, 0.18);
}

.evolve-week {
  display: inline-block;
  align-self: flex-start;
  padding: 4px 12px;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.06em;
  background: var(--bg-elevated);
  color: var(--text-secondary);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-full);
}
.evolve-step--peak .evolve-week {
  background: var(--gradient-accent);
  color: var(--on-accent);
  border-color: transparent;
}

.evolve-title {
  margin: 0;
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--text-primary);
  line-height: 1.35;
}
.evolve-title code {
  font-family: var(--font-mono);
  font-size: 0.92em;
  padding: 1px 6px;
  background: rgba(156, 38, 24, 0.12);
  border-radius: var(--radius-sm);
  color: var(--color-accent-soft);
}
.evolve-desc {
  margin: 0;
  font-size: var(--text-sm);
  line-height: 1.65;
  color: var(--text-secondary);
}
.evolve-desc strong { color: var(--text-primary); }

.evolve-foot {
  margin-top: var(--space-10);
  padding-top: var(--space-6);
  border-top: 1px dashed var(--border-subtle);
  text-align: center;
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
}
.evolve-foot-line {
  margin: 0;
  font-size: var(--text-md);
  color: var(--text-tertiary);
}
.evolve-foot-close {
  margin: var(--space-3) 0 0;
  font-size: var(--text-xl);
  line-height: 1.5;
  color: var(--text-primary);
}
.evolve-foot-close strong {
  background: var(--gradient-accent);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* CTA 플랫폼 게이트 — Windows / 확정 Intel Mac 에서 구매 버튼 대체 문구 (cta_gate.js) */
.cta-gate-note {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-3) var(--space-8);
  border-radius: var(--radius-full);
  font-weight: 600;
  font-size: var(--text-sm);
  color: var(--text-tertiary);
  background: var(--bg-elevated);
  border: 1px solid var(--border-subtle);
  margin: 0;
}
