/* ============================================================
   SajuDoctor — Design System v2 (모던 다크 SaaS 톤)
   레퍼런스: Linear / Vercel / Stripe / Apple Dark
   ============================================================ */

:root {
  /* 다크 사이트 컬러 */
  --bg-primary:    #08070B;
  --bg-secondary:  #111016;
  --bg-elevated:   #1A1822;
  --bg-card:       #0F0E13;

  --accent-gold:        #D4AF37;
  --accent-gold-soft:   #E8C547;
  --accent-gold-deep:   #8A7220;
  --accent-red:         #C73E3A;

  --text-primary:   #FFFFFF;
  --text-secondary: #9C98A6;
  --text-muted:     #5E5B68;
  --text-link:      #FFFFFF;

  --border-subtle:  #1E1C26;
  --border-strong:  #2A2734;

  /* 한지 톤 (결과 페이지/PDF) */
  --hanji-bg:           #FBF8F1;
  --hanji-bg-section:   #FFFEF7;
  --hanji-ink:          #1B1916;
  --hanji-gold:         #B8901E;
  --hanji-vermillion:   #A93226;
  --hanji-text:         #2C2A26;
  --hanji-text-soft:    #6B6862;
  --hanji-border:       #E5DFCD;

  /* 사주 오행 색 */
  --ohaeng-mok:  #2E8B57;
  --ohaeng-hwa:  #C73E3A;
  --ohaeng-to:   #C9A227;
  --ohaeng-geum: #C5C5C5;
  --ohaeng-su:   #1F3A6B;

  /* Typography — sans-first 모던 톤 */
  --font-sans:    'Pretendard Variable', 'Pretendard', -apple-system, BlinkMacSystemFont, 'Apple SD Gothic Neo', 'Inter', sans-serif;
  --font-serif:   'Noto Serif KR', serif;
  --font-display: 'Pretendard Variable', 'Pretendard', -apple-system, BlinkMacSystemFont, 'Inter', sans-serif;

  /* Layout */
  --max-width: 480px;
  --safe-padding: 20px;

  /* Radius — sharper */
  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 14px;
}

* {
  -webkit-tap-highlight-color: transparent;
  box-sizing: border-box;
}

html, body {
  margin: 0;
  padding: 0;
  background: var(--bg-primary);
  color: var(--text-primary);
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

body {
  min-height: 100vh;
  overflow-x: hidden;
  position: relative;
  background:
    radial-gradient(ellipse 800px 600px at 50% -10%, rgba(212, 175, 55, 0.08) 0%, transparent 55%),
    radial-gradient(ellipse 600px 800px at 100% 30%, rgba(212, 175, 55, 0.04) 0%, transparent 50%),
    radial-gradient(ellipse 600px 800px at 0% 60%, rgba(212, 175, 55, 0.03) 0%, transparent 50%),
    var(--bg-primary);
}

/* 골든 점 텍스처 (전체) */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image: radial-gradient(circle at 1px 1px, rgba(212, 175, 55, 0.06) 1px, transparent 0);
  background-size: 28px 28px;
  pointer-events: none;
  z-index: 0;
  opacity: 0.5;
}

/* SVG noise grain */
body::after {
  content: '';
  position: fixed;
  inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='300' height='300'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.83 0 0 0 0 0.69 0 0 0 0 0.22 0 0 0 0.5 0'/></filter><rect width='300' height='300' filter='url(%23n)'/></svg>");
  opacity: 0.04;
  pointer-events: none;
  z-index: 0;
  mix-blend-mode: overlay;
}

main, header, footer, .sticky-cta { position: relative; z-index: 1; }

.container {
  width: 100%;
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 var(--safe-padding);
}

@media (min-width: 768px) {
  body {
    background:
      radial-gradient(ellipse 1000px 800px at 50% 0%, rgba(212, 175, 55, 0.06) 0%, transparent 50%),
      #030206;
  }
  .container {
    background: linear-gradient(180deg, rgba(15, 14, 22, 0.85) 0%, rgba(8, 7, 11, 0.95) 100%);
    box-shadow:
      0 0 0 1px rgba(212, 175, 55, 0.06),
      0 40px 80px rgba(0, 0, 0, 0.5);
    backdrop-filter: blur(20px);
  }
}

/* Typography */
h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 700;
  line-height: 1.25;
  letter-spacing: -0.025em;
  color: var(--text-primary);
  margin: 0;
}

h1 { font-size: 32px; letter-spacing: -0.035em; }
h2 { font-size: 22px; letter-spacing: -0.025em; }
h3 { font-size: 17px; letter-spacing: -0.015em; }
h4 { font-size: 15px; }

p { margin: 0; }

.serif    { font-family: var(--font-serif); }
.sans     { font-family: var(--font-sans); }
.gold     { color: var(--accent-gold); }
.gold-soft{ color: var(--accent-gold-soft); }
.red      { color: var(--accent-red); }
.muted    { color: var(--text-muted); }
.secondary{ color: var(--text-secondary); }

.heading-gold {
  font-family: var(--font-display);
  color: var(--accent-gold);
  letter-spacing: -0.01em;
}

/* Header */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(8, 7, 11, 0.85);
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  border-bottom: 1px solid var(--border-subtle);
  padding: 14px 0;
}

.site-header .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: transparent;
  box-shadow: none;
}

.brand {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 600;
  color: var(--text-primary);
  text-decoration: none;
  letter-spacing: -0.03em;
}

.nav-menu-btn {
  background: none;
  border: none;
  color: var(--text-primary);
  font-size: 18px;
  cursor: pointer;
  padding: 4px 8px;
  letter-spacing: 0.05em;
}

/* Hero */
.hero {
  padding: 40px 0 36px;
  text-align: center;
  position: relative;
}

.hero::before {
  content: '';
  position: absolute;
  top: -40px;
  left: 50%;
  transform: translateX(-50%);
  width: 500px;
  height: 500px;
  max-width: 100%;
  background: radial-gradient(circle, rgba(212, 175, 55, 0.12) 0%, rgba(212, 175, 55, 0.04) 30%, transparent 65%);
  pointer-events: none;
  z-index: -1;
  filter: blur(20px);
}

.hero-tag {
  display: inline-block;
  font-size: 11px;
  letter-spacing: 0.22em;
  color: var(--text-muted);
  text-transform: uppercase;
  margin-bottom: 16px;
  font-family: var(--font-sans);
  font-weight: 500;
}

.hero h1 {
  font-size: 32px;
  line-height: 1.2;
  letter-spacing: -0.035em;
  margin-bottom: 16px;
  font-weight: 700;
}

.hero .subtitle {
  color: var(--text-secondary);
  font-size: 15px;
  margin-bottom: 32px;
  line-height: 1.65;
  letter-spacing: -0.005em;
}

.hero-img {
  width: 100%;
  max-width: 360px;
  margin: 0 auto 32px;
  display: block;
  border-radius: var(--radius-lg);
  box-shadow: 0 24px 60px rgba(0,0,0,0.5);
}

/* Buttons */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 15px 22px;
  font-family: var(--font-sans);
  font-size: 15px;
  font-weight: 600;
  border-radius: var(--radius-md);
  border: none;
  cursor: pointer;
  text-decoration: none;
  transition: transform 0.1s ease, background 0.15s ease, opacity 0.15s ease;
  letter-spacing: -0.01em;
}

.btn-primary {
  background: var(--text-primary);
  color: #08070B;
}

.btn-primary:hover { opacity: 0.92; }
.btn-primary:active { transform: translateY(1px); }

.btn-secondary {
  background: var(--bg-elevated);
  color: var(--text-primary);
  border: 1px solid var(--border-strong);
}

.btn-secondary:hover { background: #232030; }
.btn-secondary:active { transform: translateY(1px); }

.btn-ghost {
  background: transparent;
  color: var(--text-primary);
  border: 1px solid var(--border-strong);
}

.btn-ghost:hover { border-color: var(--text-secondary); }

.btn-gold {
  background: var(--accent-gold);
  color: #1A1416;
}
.btn-gold:hover { background: var(--accent-gold-soft); }

/* Product card */
.product-card {
  background: var(--bg-secondary);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin-bottom: 14px;
  transition: border-color 0.15s ease;
}

.product-card:hover {
  border-color: var(--border-strong);
}

.product-card-img {
  width: 100%;
  aspect-ratio: 16/9;
  background:
    radial-gradient(circle at 50% 60%, rgba(212,175,55,0.08) 0%, transparent 60%),
    linear-gradient(135deg, var(--bg-elevated) 0%, var(--bg-secondary) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
  font-size: 11px;
  letter-spacing: 0.22em;
  position: relative;
  border-bottom: 1px solid var(--border-subtle);
  text-transform: uppercase;
}

.product-card-mark {
  font-family: var(--font-serif);
  font-size: 24px;
  color: var(--accent-gold);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  border: 1px solid var(--accent-gold-deep);
  border-radius: 50%;
  margin-bottom: 12px;
  font-weight: 400;
}

.product-card-body {
  padding: 22px 20px;
}

.product-card-tag {
  display: inline-block;
  font-size: 11px;
  letter-spacing: 0.12em;
  color: var(--text-muted);
  text-transform: uppercase;
  margin-bottom: 10px;
  font-family: var(--font-sans);
  font-weight: 500;
}

.product-card h3 {
  font-size: 19px;
  margin-bottom: 10px;
  letter-spacing: -0.02em;
}

.product-card-desc {
  color: var(--text-secondary);
  font-size: 14px;
  margin-bottom: 18px;
  line-height: 1.65;
  letter-spacing: -0.005em;
}

.product-card-price {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 16px;
  padding: 12px 0;
  border-top: 1px solid var(--border-subtle);
  border-bottom: 1px solid var(--border-subtle);
}

.product-card-price .amount {
  font-family: var(--font-display);
  font-size: 22px;
  color: var(--text-primary);
  font-weight: 700;
  letter-spacing: -0.025em;
}

.product-card-price .label {
  font-size: 12px;
  color: var(--text-muted);
}

/* Section */
.section {
  padding: 44px 0;
  border-bottom: 1px solid var(--border-subtle);
}

.section:last-child { border-bottom: none; }

.section-title {
  font-family: var(--font-sans);
  font-size: 11px;
  letter-spacing: 0.3em;
  color: var(--text-muted);
  text-transform: uppercase;
  margin-bottom: 14px;
  text-align: center;
  font-weight: 500;
}

.section h2 {
  text-align: center;
  margin-bottom: 28px;
  font-size: 24px;
  letter-spacing: -0.025em;
}

/* Pain Point list */
.pain-list {
  list-style: none;
  padding: 0;
  margin: 0 0 24px;
}

.pain-list li {
  padding: 16px 18px;
  background: var(--bg-secondary);
  border-radius: var(--radius-md);
  margin-bottom: 8px;
  color: var(--text-secondary);
  font-size: 14.5px;
  border: 1px solid var(--border-subtle);
  line-height: 1.6;
  letter-spacing: -0.005em;
}

.pain-list li strong { color: var(--text-primary); font-weight: 600; }

/* About card */
.about-card {
  background: var(--bg-secondary);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  padding: 32px 24px;
  text-align: center;
  margin-bottom: 24px;
}

.about-card .doryeong-img {
  width: 120px;
  height: 120px;
  margin: 0 auto 20px;
  border-radius: 50%;
  object-fit: cover;
  border: 1px solid var(--border-strong);
}

.about-card .doryeong-name {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 4px;
  letter-spacing: -0.02em;
}

.about-card .doryeong-title {
  font-size: 12px;
  color: var(--text-muted);
  letter-spacing: 0.05em;
  margin-bottom: 18px;
}

.about-card .doryeong-bio {
  color: var(--text-secondary);
  font-size: 14px;
  line-height: 1.8;
  letter-spacing: -0.005em;
}

/* FAQ */
.faq-item {
  border-bottom: 1px solid var(--border-subtle);
  padding: 18px 0;
}

.faq-q {
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: 600;
  color: var(--text-primary);
  user-select: none;
  letter-spacing: -0.01em;
}

.faq-q .toggle {
  color: var(--text-muted);
  font-size: 16px;
  transition: transform 0.2s, color 0.15s;
}

.faq-item.open .faq-q .toggle {
  transform: rotate(45deg);
  color: var(--text-primary);
}

.faq-a {
  display: none;
  color: var(--text-secondary);
  font-size: 14px;
  padding-top: 12px;
  line-height: 1.75;
  letter-spacing: -0.005em;
}

.faq-item.open .faq-a { display: block; }

/* Forms */
.form-group { margin-bottom: 22px; }

.form-label {
  display: block;
  font-size: 13px;
  color: var(--text-secondary);
  margin-bottom: 8px;
  letter-spacing: -0.005em;
  font-weight: 500;
}

.form-label .required { color: var(--accent-red); }

.form-input,
.form-select,
.form-textarea {
  width: 100%;
  padding: 13px 14px;
  background: var(--bg-secondary);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-md);
  color: var(--text-primary);
  font-family: var(--font-sans);
  font-size: 16px;
  transition: border-color 0.15s, background 0.15s;
  -webkit-appearance: none;
  appearance: none;
}

.form-input:focus,
.form-select:focus,
.form-textarea:focus {
  outline: none;
  border-color: var(--text-secondary);
  background: var(--bg-elevated);
}

.form-input::placeholder { color: var(--text-muted); }

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.form-row-3 {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 8px;
}

.radio-group {
  display: flex;
  gap: 8px;
}

.radio-option { flex: 1; }
.radio-option input[type="radio"] { display: none; }

.radio-option label {
  display: block;
  padding: 12px 8px;
  background: var(--bg-secondary);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-md);
  text-align: center;
  color: var(--text-secondary);
  font-size: 14px;
  cursor: pointer;
  transition: all 0.15s;
}

.radio-option input[type="radio"]:checked + label {
  background: var(--bg-elevated);
  border-color: var(--text-primary);
  color: var(--text-primary);
}

.helper {
  font-size: 12px;
  color: var(--text-muted);
  margin-top: 6px;
  letter-spacing: -0.005em;
}

/* Steps */
.steps {
  display: flex;
  justify-content: center;
  gap: 6px;
  margin: 20px 0 28px;
}

.step-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--border-strong);
  transition: background 0.2s, width 0.2s;
}

.step-dot.active {
  background: var(--text-primary);
  width: 20px;
  border-radius: 3px;
}

/* Trust */
.trust-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin: 24px 0;
}

.trust-item {
  text-align: center;
  padding: 18px 8px;
  background: var(--bg-secondary);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
}

.trust-item .num {
  font-family: var(--font-display);
  font-size: 22px;
  color: var(--text-primary);
  display: block;
  margin-bottom: 4px;
  font-weight: 700;
  letter-spacing: -0.02em;
}

.trust-item .label {
  font-size: 11px;
  color: var(--text-muted);
  letter-spacing: 0.04em;
}

/* Disclaimer */
.disclaimer {
  background: var(--bg-secondary);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  padding: 14px 16px;
  margin: 24px 0;
  font-size: 12px;
  color: var(--text-muted);
  line-height: 1.7;
  letter-spacing: -0.005em;
}

/* Footer */
.site-footer {
  padding: 36px 0 100px;
  border-top: 1px solid var(--border-subtle);
  text-align: center;
}

.footer-links {
  display: flex;
  justify-content: center;
  gap: 18px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}

.footer-links a {
  color: var(--text-muted);
  font-size: 12px;
  text-decoration: none;
  letter-spacing: -0.005em;
}

.footer-links a:hover { color: var(--text-primary); }

.footer-copy {
  font-size: 11px;
  color: var(--text-muted);
  line-height: 1.7;
}

/* Sticky CTA */
.sticky-cta {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: linear-gradient(180deg, rgba(8,7,11,0) 0%, rgba(8,7,11,0.95) 35%);
  padding: 16px 20px 24px;
  z-index: 40;
}

.sticky-cta .container {
  max-width: var(--max-width);
  background: transparent;
  box-shadow: none;
}

/* Result page (한지) */
body.hanji {
  background: var(--hanji-bg);
  color: var(--hanji-text);
}

body.hanji .container {
  background: var(--hanji-bg);
  box-shadow: none;
}

body.hanji h1, body.hanji h2, body.hanji h3, body.hanji h4 {
  color: var(--hanji-ink);
  font-family: var(--font-serif);
}

body.hanji .site-header {
  background: rgba(251, 248, 241, 0.92);
  border-bottom: 1px solid var(--hanji-border);
}

body.hanji .brand { color: var(--hanji-ink); }
body.hanji .brand-mark { border-color: var(--hanji-ink); color: var(--hanji-ink); }

.hanji-card {
  background: var(--hanji-bg-section);
  border: 1px solid var(--hanji-border);
  border-radius: var(--radius-lg);
  padding: 24px 20px;
  margin-bottom: 16px;
}

.hanji-section-title {
  font-family: var(--font-serif);
  font-size: 11px;
  letter-spacing: 0.22em;
  color: var(--hanji-vermillion);
  text-transform: uppercase;
  margin-bottom: 8px;
  font-weight: 600;
}

.hanji-card h2 {
  color: var(--hanji-ink);
  font-size: 20px;
  margin-bottom: 14px;
  letter-spacing: -0.02em;
}

.hanji-card p {
  color: var(--hanji-text);
  font-size: 14.5px;
  line-height: 1.85;
  margin-bottom: 10px;
}

/* 사주 명식표 */
.saju-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
  margin: 18px 0;
  font-family: var(--font-serif);
}

.saju-cell {
  background: var(--hanji-bg);
  border: 1px solid var(--hanji-border);
  border-radius: var(--radius-sm);
  padding: 14px 6px;
  text-align: center;
}

.saju-cell .label {
  font-size: 10px;
  color: var(--hanji-text-soft);
  letter-spacing: 0.08em;
  display: block;
  margin-bottom: 6px;
}

.saju-cell .char {
  font-size: 26px;
  font-weight: 600;
  display: block;
  line-height: 1;
}

.saju-cell.mok  .char { color: var(--ohaeng-mok); }
.saju-cell.hwa  .char { color: var(--ohaeng-hwa); }
.saju-cell.to   .char { color: var(--ohaeng-to); }
.saju-cell.geum .char { color: var(--ohaeng-geum); }
.saju-cell.su   .char { color: var(--ohaeng-su); }

/* 풍부한 만세력 표 (정통 명리 양식) */
.manse-table {
  display: grid;
  grid-template-columns: 50px repeat(4, 1fr);
  gap: 2px;
  margin: 18px 0;
  font-family: var(--font-serif);
  background: var(--hanji-border);
  padding: 2px;
  border-radius: 8px;
  overflow: hidden;
}

.manse-row-label {
  background: var(--hanji-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  color: var(--hanji-text-soft);
  font-size: 10px;
  font-family: var(--font-serif);
  padding: 6px 2px;
  line-height: 1.3;
  text-align: center;
}
.manse-row-label .ko { font-size: 11px; color: var(--hanji-ink); font-weight: 600; }
.manse-row-label .ch { font-size: 9px; opacity: 0.7; }

.manse-cell-header {
  background: var(--hanji-bg);
  color: var(--hanji-text-soft);
  font-size: 10px;
  padding: 8px 2px;
  text-align: center;
  font-family: var(--font-serif);
  line-height: 1.3;
}
.manse-cell-header .ko { font-size: 12px; color: var(--hanji-ink); font-weight: 600; display: block; }
.manse-cell-header .ch { font-size: 9px; opacity: 0.7; }

.manse-cell {
  background: var(--hanji-bg-section);
  padding: 8px 4px;
  text-align: center;
  font-size: 11px;
  color: var(--hanji-text);
  line-height: 1.4;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 36px;
}
.manse-cell .ko { font-weight: 600; color: var(--hanji-ink); font-size: 12px; }
.manse-cell .ch { font-size: 9px; opacity: 0.7; }

/* 천간/지지 큰 셀 (오행 색상) */
.manse-cell-big {
  padding: 14px 4px;
  font-size: 28px;
  font-weight: 600;
  color: #fff;
  line-height: 1;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.manse-cell-big .sub {
  display: block;
  font-size: 10px;
  font-weight: 500;
  margin-top: 6px;
  letter-spacing: 0.02em;
  opacity: 0.95;
  color: #fff;
}

.manse-cell-big.mok  { background: linear-gradient(180deg, #2E8B57 0%, #1F6B40 100%); }
.manse-cell-big.hwa  { background: linear-gradient(180deg, #C73E3A 0%, #9A2D29 100%); }
.manse-cell-big.to   { background: linear-gradient(180deg, #D5A82E 0%, #9C7A1E 100%); color: #1B1916; }
.manse-cell-big.to .sub { color: #1B1916; }
.manse-cell-big.geum { background: linear-gradient(180deg, #4A4A4A 0%, #2A2A2A 100%); }
.manse-cell-big.su   { background: linear-gradient(180deg, #1F3A6B 0%, #122348 100%); }

/* 일간 강조 — 빨간 테두리 X, 일반 색 필드 + 살짝 글로우만 */
.manse-cell-big.day-stem,
.manse-cell-big.day-branch {
  outline: 1.5px solid rgba(255, 255, 255, 0.4);
  outline-offset: -3px;
}

/* 만세력 로딩 placeholder */
.manse-cell.placeholder { color: var(--hanji-text-soft); font-style: italic; opacity: 0.5; }

/* ============================================================
   오행 분포 (퍼센티지 + 오각형 레이더 차트)
   ============================================================ */
.ohaeng-block {
  background: var(--hanji-bg);
  border: 1px solid var(--hanji-border);
  border-radius: var(--radius-md);
  padding: 20px 18px;
  margin-top: 14px;
}

.ohaeng-title {
  font-family: var(--font-serif);
  font-size: 12px;
  letter-spacing: 0.2em;
  color: var(--hanji-vermillion);
  text-align: center;
  font-weight: 600;
  margin-bottom: 14px;
  text-transform: uppercase;
}

.ohaeng-radar-wrap {
  display: flex;
  justify-content: center;
  margin: 4px 0;
}

.ohaeng-radar {
  width: 240px;
  height: 240px;
}

.ohaeng-radar .grid {
  fill: none;
  stroke: var(--hanji-border);
  stroke-width: 1;
}

.ohaeng-radar .axis {
  stroke: var(--hanji-border);
  stroke-width: 0.5;
}

.ohaeng-radar .data-poly {
  fill: rgba(184, 144, 30, 0.25);
  stroke: var(--hanji-gold);
  stroke-width: 2;
  stroke-linejoin: round;
}

.ohaeng-radar .point {
  fill: var(--hanji-vermillion);
}

.ohaeng-radar .label {
  font-family: var(--font-serif);
  font-size: 14px;
  font-weight: 700;
  text-anchor: middle;
  dominant-baseline: middle;
}

.ohaeng-radar .label.mok  { fill: var(--ohaeng-mok); }
.ohaeng-radar .label.hwa  { fill: var(--ohaeng-hwa); }
.ohaeng-radar .label.to   { fill: var(--ohaeng-to); }
.ohaeng-radar .label.geum { fill: #5C5C5C; }
.ohaeng-radar .label.su   { fill: var(--ohaeng-su); }

.ohaeng-radar .pct {
  font-family: var(--font-sans);
  font-size: 10px;
  font-weight: 500;
  fill: var(--hanji-text-soft);
  text-anchor: middle;
}

/* 퍼센티지 막대 (radar 아래에 보조) */
.ohaeng-bars {
  display: grid;
  grid-template-columns: 1fr;
  gap: 6px;
  margin-top: 14px;
}

.ohaeng-bar {
  display: grid;
  grid-template-columns: 24px 1fr 42px;
  align-items: center;
  gap: 8px;
  font-family: var(--font-serif);
  font-size: 12px;
}

.ohaeng-bar .ch { font-weight: 600; font-size: 14px; }
.ohaeng-bar.mok .ch  { color: var(--ohaeng-mok); }
.ohaeng-bar.hwa .ch  { color: var(--ohaeng-hwa); }
.ohaeng-bar.to .ch   { color: var(--ohaeng-to); }
.ohaeng-bar.geum .ch { color: #5C5C5C; }
.ohaeng-bar.su .ch   { color: var(--ohaeng-su); }

.ohaeng-bar .track {
  background: var(--hanji-border);
  height: 8px;
  border-radius: 4px;
  overflow: hidden;
}

.ohaeng-bar .fill {
  height: 100%;
  border-radius: 4px;
  transition: width 0.6s ease;
}

.ohaeng-bar.mok  .fill { background: var(--ohaeng-mok); }
.ohaeng-bar.hwa  .fill { background: var(--ohaeng-hwa); }
.ohaeng-bar.to   .fill { background: var(--ohaeng-to); }
.ohaeng-bar.geum .fill { background: #888; }
.ohaeng-bar.su   .fill { background: var(--ohaeng-su); }

.ohaeng-bar .pct {
  font-family: var(--font-sans);
  font-size: 11px;
  font-weight: 600;
  color: var(--hanji-text);
  text-align: right;
}

/* ============================================================
   잠금 점수 카드 (preview 단계)
   ============================================================ */
.score-locked .score-num {
  filter: blur(8px);
  user-select: none;
  pointer-events: none;
}

.score-locked-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: linear-gradient(180deg, rgba(15, 14, 22, 0.2) 0%, rgba(15, 14, 22, 0.85) 100%);
  border-radius: var(--radius-lg);
  padding: 16px;
  text-align: center;
}

.score-locked-overlay .icon {
  font-size: 28px;
  margin-bottom: 6px;
}

.score-locked-overlay .text {
  font-family: var(--font-display);
  font-size: 14px;
  color: var(--text-primary);
  font-weight: 600;
  margin-bottom: 2px;
  letter-spacing: -0.015em;
}

.score-locked-overlay .sub {
  font-size: 11.5px;
  color: var(--accent-gold-soft);
  letter-spacing: -0.005em;
}

/* 전체 화면 로딩 (분석 시작 시 표시) */
.full-loader {
  position: fixed;
  inset: 0;
  z-index: 200;
  background: var(--bg-primary);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 20px;
  transition: opacity 0.5s ease;
}

.full-loader.hidden { opacity: 0; pointer-events: none; }

.full-loader .doryeong-circle {
  width: 96px;
  height: 96px;
  border-radius: 50%;
  background: linear-gradient(180deg, var(--bg-secondary), var(--bg-card));
  border: 2px solid rgba(212, 175, 55, 0.4);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-serif);
  color: var(--accent-gold-soft);
  font-size: 28px;
  margin-bottom: 24px;
  box-shadow: 0 0 60px rgba(212, 175, 55, 0.2);
  animation: pulse 2.4s ease-in-out infinite;
}

.full-loader .loader-title {
  font-family: var(--font-serif);
  font-size: 19px;
  color: var(--text-primary);
  margin-bottom: 8px;
  letter-spacing: -0.015em;
}

.full-loader .loader-status {
  font-size: 13px;
  color: var(--accent-gold-soft);
  letter-spacing: -0.005em;
  margin-bottom: 6px;
}

.full-loader .loader-sub {
  font-size: 11.5px;
  color: var(--text-muted);
  letter-spacing: -0.005em;
}

/* Expiry banner */
.expiry-banner {
  background: #FFF8E6;
  border: 1px solid #E5CC7A;
  border-radius: var(--radius-md);
  padding: 14px 16px;
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.expiry-text {
  font-size: 13px;
  color: var(--hanji-ink);
  line-height: 1.5;
}

.expiry-text strong { color: var(--hanji-vermillion); }

.expiry-btn {
  background: var(--hanji-ink);
  color: var(--hanji-bg);
  border: none;
  padding: 10px 14px;
  border-radius: var(--radius-sm);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
}

/* Doctor seal */
.seal {
  display: inline-flex;
  width: 56px;
  height: 56px;
  background: var(--hanji-vermillion);
  color: #FFF;
  border-radius: var(--radius-sm);
  font-family: var(--font-serif);
  font-size: 14px;
  align-items: center;
  justify-content: center;
  letter-spacing: 0.05em;
  transform: rotate(-3deg);
  font-weight: 600;
}

/* Utility */
.mt-1 { margin-top: 4px; }
.mt-2 { margin-top: 8px; }
.mt-3 { margin-top: 12px; }
.mt-4 { margin-top: 16px; }
.mt-6 { margin-top: 24px; }
.mt-8 { margin-top: 32px; }

.mb-1 { margin-bottom: 4px; }
.mb-2 { margin-bottom: 8px; }
.mb-3 { margin-bottom: 12px; }
.mb-4 { margin-bottom: 16px; }
.mb-6 { margin-bottom: 24px; }
.mb-8 { margin-bottom: 32px; }

.text-center { text-align: center; }
.text-left { text-align: left; }

.flex { display: flex; }
.flex-col { flex-direction: column; }
.gap-2 { gap: 8px; }
.gap-4 { gap: 16px; }
.items-center { align-items: center; }
.justify-between { justify-content: space-between; }

/* ============================================================
   COMMERCE LAYERS — urgency / price / social proof
   ============================================================ */

/* Urgency banner — 24h countdown (빨간 톤) */
.urgency-banner {
  background:
    linear-gradient(90deg, rgba(199, 62, 58, 0.08) 0%, rgba(199, 62, 58, 0.16) 50%, rgba(199, 62, 58, 0.08) 100%),
    var(--bg-secondary);
  border: 1px solid rgba(199, 62, 58, 0.32);
  border-radius: var(--radius-md);
  padding: 14px 16px;
  margin: 16px 0 20px;
  display: flex;
  align-items: center;
  gap: 12px;
}

.urgency-icon {
  font-size: 16px;
  flex-shrink: 0;
  opacity: 0.95;
}

.urgency-text {
  flex: 1;
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.5;
}

.urgency-text strong {
  color: #FF6B6B;
  font-weight: 700;
  letter-spacing: -0.005em;
}

.urgency-countdown {
  font-family: 'SF Mono', 'Monaco', monospace;
  font-size: 13px;
  font-weight: 700;
  color: #FF6B6B;
  white-space: nowrap;
  background: rgba(0, 0, 0, 0.45);
  border: 1px solid rgba(199, 62, 58, 0.35);
  padding: 6px 10px;
  border-radius: 6px;
  letter-spacing: 0.04em;
  font-variant-numeric: tabular-nums;
  min-width: 116px;
  display: inline-block;
  text-align: center;
  box-shadow: inset 0 0 8px rgba(199, 62, 58, 0.12);
}

/* Price anchor */
.price-anchor {
  display: flex;
  align-items: baseline;
  gap: 10px;
  flex-wrap: wrap;
}

.price-anchor .original {
  font-size: 14px;
  color: var(--text-muted);
  text-decoration: line-through;
  text-decoration-thickness: 1px;
}

.price-anchor .current {
  font-family: var(--font-display);
  font-size: 26px;
  font-weight: 700;
  color: var(--text-primary);
  letter-spacing: -0.025em;
}

.price-anchor .discount-pct {
  font-size: 12px;
  font-weight: 700;
  color: var(--accent-gold-soft);
  background: rgba(212, 175, 55, 0.1);
  border: 1px solid rgba(212, 175, 55, 0.3);
  padding: 3px 8px;
  border-radius: 5px;
  letter-spacing: 0.02em;
}

/* Rating */
.rating-row {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
  margin: 12px 0;
  font-size: 13px;
}

.rating-stars {
  color: var(--accent-gold-soft);
  font-size: 14px;
  letter-spacing: 0.05em;
}

.rating-score {
  font-weight: 600;
  color: var(--text-primary);
  margin-left: 4px;
}

.rating-count {
  color: var(--text-muted);
  font-size: 12px;
}

.rating-views {
  color: var(--text-muted);
  font-size: 12px;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

/* Detail page hero */
.detail-hero {
  padding: 24px 0 28px;
}

.detail-hero-img {
  width: 100%;
  aspect-ratio: 4/5;
  max-height: 440px;
  object-fit: cover;
  border-radius: var(--radius-lg);
  margin-bottom: 24px;
  background: linear-gradient(135deg, var(--bg-elevated), var(--bg-secondary));
}

.detail-category {
  display: inline-block;
  font-size: 11px;
  letter-spacing: 0.22em;
  color: var(--text-muted);
  text-transform: uppercase;
  margin-bottom: 12px;
  font-weight: 500;
}

.detail-title {
  font-size: 26px;
  line-height: 1.25;
  letter-spacing: -0.03em;
  margin-bottom: 14px;
  font-weight: 700;
}

.detail-tagline {
  font-size: 15px;
  color: var(--text-secondary);
  line-height: 1.6;
  margin-bottom: 18px;
  letter-spacing: -0.005em;
}

/* Review card */
.review-card {
  background: var(--bg-secondary);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  padding: 16px 18px;
  margin-bottom: 10px;
}

.review-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
}

.review-emoji {
  font-size: 20px;
}

.review-author {
  font-size: 13px;
  color: var(--text-primary);
  font-weight: 600;
}

.review-stars {
  color: var(--accent-gold-soft);
  font-size: 12px;
  margin-left: auto;
}

.review-body {
  font-size: 13.5px;
  color: var(--text-secondary);
  line-height: 1.65;
  letter-spacing: -0.005em;
}

.review-meta {
  font-size: 11px;
  color: var(--text-muted);
  margin-top: 8px;
}

/* Checklist (target audience) */
.check-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.check-list li {
  padding: 12px 14px 12px 38px;
  background: var(--bg-secondary);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  margin-bottom: 8px;
  color: var(--text-secondary);
  font-size: 14px;
  line-height: 1.55;
  position: relative;
  letter-spacing: -0.005em;
}

.check-list li::before {
  content: "✓";
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--accent-gold-soft);
  font-weight: 700;
  font-size: 14px;
}

.check-list li strong { color: var(--text-primary); font-weight: 600; }

/* Numbered step list */
.step-list {
  list-style: none;
  padding: 0;
  counter-reset: stepnum;
}

.step-list li {
  padding: 16px 16px 16px 50px;
  background: var(--bg-secondary);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  margin-bottom: 10px;
  position: relative;
  counter-increment: stepnum;
}

.step-list li::before {
  content: counter(stepnum);
  position: absolute;
  left: 14px;
  top: 18px;
  width: 24px;
  height: 24px;
  background: var(--text-primary);
  color: var(--bg-primary);
  border-radius: 50%;
  font-size: 12px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
}

.step-list .step-title {
  font-family: var(--font-display);
  font-size: 14.5px;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 4px;
  letter-spacing: -0.01em;
}

.step-list .step-desc {
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.65;
  letter-spacing: -0.005em;
}

/* Sample preview */
.sample-preview {
  background: var(--hanji-bg);
  border-radius: var(--radius-md);
  padding: 22px 18px;
  margin: 12px 0;
  position: relative;
  overflow: hidden;
}

.sample-preview::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 60px;
  background: linear-gradient(180deg, transparent 0%, var(--hanji-bg) 90%);
  pointer-events: none;
}

.sample-preview .sample-label {
  font-size: 11px;
  letter-spacing: 0.2em;
  color: var(--hanji-vermillion);
  font-weight: 600;
  margin-bottom: 8px;
  text-transform: uppercase;
}

.sample-preview h4 {
  color: var(--hanji-ink);
  font-size: 16px;
  margin-bottom: 10px;
  letter-spacing: -0.01em;
}

.sample-preview p {
  color: var(--hanji-text);
  font-size: 13.5px;
  line-height: 1.85;
  margin: 0;
}

.sample-preview p strong { color: var(--hanji-vermillion); }

/* CTA strip (sticky-ish at end of detail) */
.cta-strip {
  background: linear-gradient(180deg, var(--bg-secondary) 0%, var(--bg-elevated) 100%);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  padding: 24px 20px;
  margin: 20px 0;
  text-align: center;
}

.cta-strip-tag {
  font-size: 11px;
  letter-spacing: 0.22em;
  color: var(--accent-gold-soft);
  text-transform: uppercase;
  font-weight: 600;
  margin-bottom: 12px;
}

.cta-strip h3 {
  font-size: 19px;
  margin-bottom: 14px;
  letter-spacing: -0.02em;
}

/* Live activity ticker (골드 톤) */
.live-ticker {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: rgba(212, 175, 55, 0.06);
  border: 1px solid rgba(212, 175, 55, 0.2);
  color: var(--accent-gold-soft);
  font-size: 12px;
  font-weight: 500;
  padding: 6px 12px;
  border-radius: 999px;
  letter-spacing: -0.005em;
}

.live-ticker .dot {
  width: 6px;
  height: 6px;
  background: var(--accent-gold-soft);
  border-radius: 50%;
  box-shadow: 0 0 6px rgba(212, 175, 55, 0.5);
  animation: pulse 2.4s ease-in-out infinite;
}

@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.5; transform: scale(0.8); }
}

/* Back nav */
.back-nav {
  background: none;
  border: none;
  color: var(--text-secondary);
  font-size: 14px;
  cursor: pointer;
  padding: 0;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  text-decoration: none;
}

.back-nav:hover { color: var(--text-primary); }

/* Header (minimal) — 상세페이지: 로고만 중앙 */
.site-header.minimal .container {
  justify-content: center;
}

/* Detail hero image (상세 페이지 상단 큰 이미지) */
.detail-hero-img-wrap {
  width: calc(100% + 40px);
  margin: 0 -20px 28px;
  overflow: hidden;
  position: relative;
  background: var(--bg-secondary);
}

.detail-hero-img-wrap img {
  width: 100%;
  height: auto;
  display: block;
}

.detail-hero-img-wrap::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(180deg, transparent 60%, rgba(8,7,11,0.6) 100%);
}

/* Product card img with thumb image — 원본 비율 그대로 풀로 */
.product-card-img.with-image {
  aspect-ratio: unset;
  padding: 0;
  background: var(--bg-secondary);
  position: relative;
  overflow: hidden;
  display: block;
  height: auto;
}

.product-card-img.with-image img {
  position: static;
  width: 100%;
  height: auto;
  display: block;
}

.product-card-img.with-image .overlay {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(180deg, transparent 0%, rgba(8,7,11,0.88) 100%);
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: 24px 14px 16px;
  color: var(--text-primary);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 500;
}

/* 상세 페이지: sticky checkout 가림 방지용 하단 여백 */
body.has-sticky-checkout main {
  padding-bottom: 120px;
}

body.has-sticky-checkout .site-footer {
  padding-bottom: 120px;
}

/* Sticky checkout bar — 상세페이지 하단 결제 모달 */
.sticky-checkout {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 50;
  padding: 14px 16px 18px;
  background: linear-gradient(180deg, rgba(8,7,11,0) 0%, rgba(8,7,11,0.97) 30%);
}

.sticky-checkout-inner {
  max-width: var(--max-width);
  margin: 0 auto;
  background: linear-gradient(180deg, #14131C 0%, #0F0E16 100%);
  border: 1px solid rgba(212, 175, 55, 0.22);
  border-radius: var(--radius-md);
  padding: 12px 14px;
  box-shadow:
    0 -8px 24px rgba(0,0,0,0.5),
    0 0 0 1px rgba(212, 175, 55, 0.05) inset;
}

.sticky-checkout-row {
  display: flex;
  align-items: center;
  gap: 12px;
}

.sticky-checkout-price {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 2px;
  line-height: 1;
}

.sticky-checkout-price .label {
  font-size: 11px;
  color: #FF6B6B;
  letter-spacing: -0.005em;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 6px;
}

.sticky-checkout-price .label .urgency-countdown {
  font-family: 'SF Mono', 'Monaco', monospace;
  font-size: 10.5px;
  background: rgba(0, 0, 0, 0.5);
  border: 1px solid rgba(199, 62, 58, 0.35);
  color: #FF6B6B;
  padding: 2px 6px;
  border-radius: 4px;
  letter-spacing: 0.04em;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  min-width: 96px;
  display: inline-block;
  text-align: center;
}

.sticky-checkout-price .nums {
  display: flex;
  align-items: baseline;
  gap: 8px;
}

.sticky-checkout-price .nums .original {
  font-size: 12px;
  color: var(--text-muted);
  text-decoration: line-through;
}

.sticky-checkout-price .nums .current {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 700;
  color: var(--text-primary);
  letter-spacing: -0.025em;
}

.sticky-checkout-row .btn {
  width: auto;
  padding: 12px 18px;
  flex-shrink: 0;
  font-size: 14px;
  white-space: nowrap;
}

/* Simple urgency text (no countdown) */
.urgency-simple {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--accent-gold-soft);
  letter-spacing: -0.005em;
  font-weight: 500;
}

/* ============================================================
   MOBILE MENU (fullscreen overlay)
   ============================================================ */
.mobile-menu {
  position: fixed;
  inset: 0;
  z-index: 100;
  background: var(--bg-primary);
  transform: translateY(-100%);
  transition: transform 0.32s cubic-bezier(0.32, 0.72, 0, 1);
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  visibility: hidden;
}

.mobile-menu.open {
  transform: translateY(0);
  visibility: visible;
}

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

.mobile-menu-header {
  padding: 14px 20px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid var(--border-subtle);
  background: rgba(8, 7, 11, 0.92);
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  position: sticky;
  top: 0;
  z-index: 1;
}

.mobile-menu-close {
  background: none;
  border: none;
  color: var(--text-primary);
  font-size: 20px;
  cursor: pointer;
  padding: 6px 10px;
  letter-spacing: 0.05em;
  line-height: 1;
}

.mobile-menu .brand {
  font-size: 16px;
}

.mobile-menu-inner {
  flex: 1;
  max-width: var(--max-width);
  width: 100%;
  margin: 0 auto;
  padding: 28px 20px 40px;
  display: flex;
  flex-direction: column;
}

.menu-cta-block {
  background: linear-gradient(180deg, var(--bg-secondary) 0%, var(--bg-card) 100%);
  border: 1px solid rgba(212, 175, 55, 0.18);
  border-radius: var(--radius-lg);
  padding: 22px 20px;
  margin-bottom: 28px;
  text-align: center;
}

.menu-cta-block .title {
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 4px;
  letter-spacing: -0.015em;
}

.menu-cta-block .desc {
  font-size: 12.5px;
  color: var(--text-secondary);
  margin-bottom: 14px;
  line-height: 1.55;
}

.menu-cta-block .btn {
  margin-bottom: 8px;
}

.menu-cta-block .secondary-link {
  display: block;
  font-size: 13px;
  color: var(--text-secondary);
  text-decoration: none;
  margin-top: 6px;
}

.menu-cta-block .secondary-link:hover {
  color: var(--accent-gold-soft);
}

.menu-items {
  display: flex;
  flex-direction: column;
}

.menu-item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 18px 4px;
  border-bottom: 1px solid var(--border-subtle);
  color: var(--text-primary);
  text-decoration: none;
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 500;
  letter-spacing: -0.015em;
}

.menu-item:active { opacity: 0.6; }

.menu-item-icon {
  font-size: 18px;
  width: 24px;
  text-align: center;
  flex-shrink: 0;
}

.menu-item-text {
  flex: 1;
}

.menu-item-arrow {
  color: var(--text-muted);
  font-size: 16px;
  margin-left: auto;
}

.menu-item-badge {
  font-size: 10px;
  background: rgba(212, 175, 55, 0.12);
  color: var(--accent-gold-soft);
  border: 1px solid rgba(212, 175, 55, 0.25);
  padding: 2px 7px;
  border-radius: 999px;
  letter-spacing: 0.02em;
  font-weight: 500;
}

.menu-footer {
  margin-top: auto;
  padding-top: 32px;
  border-top: 1px solid var(--border-subtle);
}

.menu-footer-links {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}

.menu-footer-links a {
  color: var(--text-muted);
  font-size: 12px;
  text-decoration: none;
  letter-spacing: -0.005em;
}

.menu-footer-links a:hover { color: var(--text-link); }

.menu-footer .copy {
  font-size: 11px;
  color: var(--text-muted);
  line-height: 1.6;
}

/* ============================================================
   TABLE OF CONTENTS (목차) — 상세 페이지 + 결과 페이지
   ============================================================ */
.toc {
  background: var(--bg-card);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  padding: 22px 20px;
  margin: 12px 0;
}

.toc-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 18px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--border-subtle);
}

.toc-header .label {
  font-size: 11px;
  letter-spacing: 0.22em;
  color: var(--accent-gold-soft);
  text-transform: uppercase;
  font-weight: 500;
}

.toc-header .pages {
  font-size: 12px;
  color: var(--text-muted);
}

.toc-part {
  margin-bottom: 18px;
}

.toc-part:last-child { margin-bottom: 0; }

.toc-part-title {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 8px;
}

.toc-part-title .name {
  font-family: var(--font-display);
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
  letter-spacing: -0.015em;
}

.toc-part-title .pages {
  font-size: 11px;
  color: var(--text-muted);
  font-family: 'SF Mono', 'Monaco', monospace;
  letter-spacing: 0.05em;
  flex-shrink: 0;
}

.toc-sections {
  list-style: none;
  padding: 0;
  margin: 0;
}

.toc-sections li {
  font-size: 12.5px;
  color: var(--text-secondary);
  padding: 4px 0 4px 12px;
  border-left: 1px solid var(--border-subtle);
  margin-left: 2px;
  letter-spacing: -0.005em;
}

.toc-sections li::before {
  content: '·';
  margin-right: 6px;
  color: var(--text-muted);
}

/* ============================================================
   LOCKED CONTENT (결제 게이트 — 본판 미리보기)
   ============================================================ */
.locked-section {
  position: relative;
  margin: 16px 0;
  overflow: hidden;
}

.locked-content {
  filter: blur(6px);
  pointer-events: none;
  user-select: none;
  opacity: 0.85;
  max-height: 280px;
  overflow: hidden;
}

.locked-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg,
    rgba(8,7,11,0.2) 0%,
    rgba(8,7,11,0.7) 50%,
    rgba(8,7,11,0.98) 100%);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  padding: 0 20px 24px;
  text-align: center;
}

.locked-overlay .lock-icon {
  font-size: 28px;
  margin-bottom: 12px;
  opacity: 0.8;
}

.locked-overlay .lock-title {
  font-family: var(--font-display);
  font-size: 17px;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 6px;
  letter-spacing: -0.02em;
}

.locked-overlay .lock-desc {
  font-size: 13px;
  color: var(--text-secondary);
  margin-bottom: 18px;
  line-height: 1.55;
}

/* Result page — free vs locked */
.result-free-zone {
  position: relative;
}

.result-paywall {
  background: linear-gradient(180deg, var(--bg-secondary) 0%, var(--bg-card) 100%);
  border: 1px solid rgba(212, 175, 55, 0.25);
  border-radius: var(--radius-lg);
  padding: 28px 22px;
  margin: 28px 0;
  text-align: center;
}

.result-paywall .pw-tag {
  display: inline-block;
  font-size: 10px;
  letter-spacing: 0.22em;
  color: var(--accent-gold-soft);
  text-transform: uppercase;
  font-weight: 600;
  margin-bottom: 12px;
}

.result-paywall h2 {
  font-size: 22px;
  margin-bottom: 10px;
  letter-spacing: -0.025em;
}

.result-paywall .pw-desc {
  font-size: 13.5px;
  color: var(--text-secondary);
  line-height: 1.7;
  margin-bottom: 20px;
  letter-spacing: -0.005em;
}

.result-paywall .pw-features {
  text-align: left;
  background: var(--bg-primary);
  border-radius: var(--radius-md);
  padding: 16px 18px;
  margin-bottom: 22px;
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.85;
}

.result-paywall .pw-features li::before {
  content: '✓ ';
  color: var(--accent-gold-soft);
  font-weight: 600;
}

.result-paywall .pw-features ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

/* 사주 명식 카드 (결과 시작) */
.myeongsik-card {
  background: var(--hanji-bg);
  border-radius: var(--radius-lg);
  padding: 24px 20px;
  margin: 16px 0;
  position: relative;
}

.myeongsik-header {
  text-align: center;
  margin-bottom: 18px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--hanji-border);
}

.myeongsik-header .label {
  font-family: var(--font-serif);
  font-size: 11px;
  letter-spacing: 0.25em;
  color: var(--hanji-vermillion);
  font-weight: 600;
  margin-bottom: 6px;
  text-transform: uppercase;
}

.myeongsik-header h3 {
  color: var(--hanji-ink);
  font-size: 18px;
  font-family: var(--font-serif);
  letter-spacing: -0.01em;
  margin-bottom: 6px;
}

.myeongsik-header .meta {
  font-size: 12px;
  color: var(--hanji-text-soft);
}

/* ============================================================
   결과 페이지 — 분석 섹션 (AI 동적 채움)
   ============================================================ */
.analysis-section {
  background: var(--bg-card);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  padding: 22px 20px;
  margin-bottom: 14px;
  position: relative;
}

.analysis-section-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--border-subtle);
}

.analysis-section-header .part {
  font-size: 11px;
  letter-spacing: 0.2em;
  color: var(--accent-gold-soft);
  text-transform: uppercase;
  font-weight: 600;
}

.analysis-section-header .pages {
  font-size: 11px;
  color: var(--text-muted);
  font-family: 'SF Mono', 'Monaco', monospace;
}

.analysis-section h3.part-title {
  font-size: 19px;
  letter-spacing: -0.02em;
  margin-bottom: 4px;
}

.analysis-section-body {
  font-size: 14px;
  line-height: 1.85;
  color: var(--text-secondary);
  letter-spacing: -0.005em;
}

.analysis-section-body h3 {
  font-family: var(--font-display);
  font-size: 15.5px;
  font-weight: 600;
  color: var(--text-primary);
  letter-spacing: -0.015em;
  margin: 18px 0 8px;
}

.analysis-section-body h3:first-child { margin-top: 0; }

.analysis-section-body p {
  margin: 0 0 12px;
}

.analysis-section-body strong {
  color: var(--text-primary);
}

/* 로딩 상태 */
.analysis-loading {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 0;
  color: var(--text-muted);
  font-size: 13.5px;
  letter-spacing: -0.005em;
}

.analysis-loading .spinner {
  width: 16px;
  height: 16px;
  border: 1.5px solid var(--border-strong);
  border-top-color: var(--accent-gold-soft);
  border-radius: 50%;
  animation: spin 0.7s linear infinite;
  flex-shrink: 0;
}

/* 에러 상태 */
.analysis-error {
  background: rgba(199, 62, 58, 0.06);
  border: 1px solid rgba(199, 62, 58, 0.2);
  border-radius: var(--radius-md);
  padding: 14px 16px;
  font-size: 13px;
  color: #E97470;
  line-height: 1.6;
}

/* 글로벌 로딩 (페이지 진입 시) */
.global-analysis-status {
  position: sticky;
  top: 60px;
  z-index: 30;
  background: rgba(8, 7, 11, 0.85);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(212, 175, 55, 0.2);
  border-radius: 999px;
  padding: 10px 16px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 12.5px;
  color: var(--accent-gold-soft);
  letter-spacing: -0.005em;
  margin: 12px 0;
}

.global-analysis-status .spinner {
  width: 14px;
  height: 14px;
  border: 1.5px solid rgba(212, 175, 55, 0.25);
  border-top-color: var(--accent-gold-soft);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}

.global-analysis-status.done {
  background: rgba(74, 222, 128, 0.08);
  border-color: rgba(74, 222, 128, 0.25);
  color: #4ADE80;
}

/* ============================================================
   이연 도령 환영 카드 (사주 보고 첫 한 마디)
   ============================================================ */
.doryeong-card {
  background:
    radial-gradient(ellipse at top right, rgba(212, 175, 55, 0.08) 0%, transparent 60%),
    linear-gradient(180deg, var(--bg-secondary) 0%, var(--bg-card) 100%);
  border: 1px solid rgba(212, 175, 55, 0.22);
  border-radius: var(--radius-lg);
  padding: 22px 20px;
  display: flex;
  gap: 16px;
  align-items: flex-start;
  position: relative;
  overflow: hidden;
}
.doryeong-card::before {
  content: '';
  position: absolute;
  top: -20px; right: -20px;
  width: 120px; height: 120px;
  background: radial-gradient(circle, rgba(212, 175, 55, 0.12) 0%, transparent 60%);
  pointer-events: none;
  filter: blur(8px);
}
.doryeong-portrait {
  flex-shrink: 0;
  position: relative;
  width: 64px;
  height: 64px;
}
.doryeong-portrait-inner {
  width: 64px; height: 64px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 35% 30%, rgba(232, 197, 71, 0.35), transparent 55%),
    linear-gradient(150deg, #1F1B1A 0%, #2A2522 60%, #1A1714 100%);
  border: 1.5px solid rgba(212, 175, 55, 0.35);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-serif);
  font-size: 28px;
  color: var(--accent-gold-soft);
  letter-spacing: 0;
  box-shadow:
    inset 0 1px 0 rgba(232, 197, 71, 0.2),
    0 4px 12px rgba(0, 0, 0, 0.35);
}
.doryeong-stamp {
  position: absolute;
  bottom: -4px; right: -6px;
  background: var(--accent-red, #B23A3A);
  color: #FFF;
  font-family: var(--font-serif);
  font-size: 9px;
  letter-spacing: 0.05em;
  padding: 3px 5px;
  border-radius: 3px;
  transform: rotate(-6deg);
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.3);
}
.doryeong-body {
  flex: 1;
  min-width: 0;
  position: relative;
}
.doryeong-tag {
  font-family: var(--font-serif);
  font-size: 11px;
  color: var(--accent-gold-soft);
  letter-spacing: 0.18em;
  margin-bottom: 6px;
  font-weight: 500;
}
.doryeong-greeting {
  font-family: var(--font-display);
  font-size: 17px;
  line-height: 1.45;
  letter-spacing: -0.02em;
  color: var(--text-primary);
  font-weight: 600;
  margin: 0 0 10px;
}
.doryeong-firstline {
  font-size: 14px;
  line-height: 1.85;
  letter-spacing: -0.005em;
  color: var(--text-secondary);
  margin: 0;
}
.doryeong-firstline strong {
  color: var(--accent-gold-soft);
  font-weight: 600;
}

/* ============================================================
   도령의 묻는 듯한 멘트 (프리뷰 hook · paywall 직전)
   ============================================================ */
.doryeong-questions {
  background: linear-gradient(180deg, var(--bg-card) 0%, var(--bg-secondary) 100%);
  border: 1px solid rgba(212, 175, 55, 0.20);
  border-radius: var(--radius-lg);
  padding: 24px 22px 22px;
  position: relative;
  overflow: hidden;
}
.doryeong-questions::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent 0%, var(--accent-gold-soft) 50%, transparent 100%);
  opacity: 0.6;
}
.dq-header {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  margin-bottom: 18px;
}
.dq-mark {
  flex-shrink: 0;
  width: 40px; height: 40px;
  border: 1.5px solid var(--accent-gold-soft);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-serif);
  font-size: 20px;
  color: var(--accent-gold-soft);
  background: rgba(212, 175, 55, 0.05);
}
.dq-tag {
  font-family: var(--font-serif);
  font-size: 10px;
  color: var(--accent-gold-soft);
  letter-spacing: 0.2em;
  margin-bottom: 4px;
  font-weight: 500;
}
.dq-title {
  font-family: var(--font-display);
  font-size: 18px;
  line-height: 1.4;
  letter-spacing: -0.025em;
  color: var(--text-primary);
  font-weight: 600;
  margin: 0;
}
.dq-list {
  list-style: none;
  padding: 0;
  margin: 0 0 18px;
  border-top: 1px solid rgba(212, 175, 55, 0.15);
}
.dq-list li {
  padding: 14px 4px 14px 22px;
  border-bottom: 1px dashed rgba(212, 175, 55, 0.12);
  font-size: 14px;
  line-height: 1.7;
  color: var(--text-secondary);
  letter-spacing: -0.005em;
  position: relative;
}
.dq-list li::before {
  content: '問';
  position: absolute;
  left: 0;
  top: 13px;
  font-family: var(--font-serif);
  font-size: 13px;
  color: var(--accent-gold-soft);
  opacity: 0.7;
}
.dq-list li:last-child {
  border-bottom: none;
}
.dq-teaser {
  position: relative;
  background:
    repeating-linear-gradient(180deg, rgba(212, 175, 55, 0.025) 0px, rgba(212, 175, 55, 0.025) 1px, transparent 1px, transparent 6px),
    var(--bg-elevated);
  border: 1px solid rgba(212, 175, 55, 0.18);
  border-radius: var(--radius-md);
  padding: 16px 16px 26px;
  margin-bottom: 14px;
  overflow: hidden;
}
.dq-teaser-label {
  font-family: var(--font-serif);
  font-size: 10px;
  letter-spacing: 0.2em;
  color: var(--accent-gold-soft);
  margin-bottom: 8px;
  font-weight: 500;
}
.dq-teaser-body {
  font-family: var(--font-serif);
  font-size: 13.5px;
  line-height: 1.85;
  color: var(--text-secondary);
  letter-spacing: -0.005em;
  margin: 0;
  font-style: italic;
}
.dq-blur {
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 38px;
  background: linear-gradient(180deg, transparent 0%, var(--bg-elevated) 80%);
  pointer-events: none;
}
.dq-sign {
  font-family: var(--font-serif);
  font-size: 12px;
  color: var(--text-muted);
  text-align: right;
  margin: 0;
  letter-spacing: 0.03em;
}

@media (max-width: 480px) {
  .doryeong-card { padding: 18px 16px; gap: 14px; }
  .doryeong-portrait, .doryeong-portrait-inner { width: 56px; height: 56px; }
  .doryeong-portrait-inner { font-size: 24px; }
  .doryeong-greeting { font-size: 16px; }
  .doryeong-firstline { font-size: 13.5px; }
  .doryeong-questions { padding: 20px 18px 18px; }
  .dq-title { font-size: 16px; }
  .dq-list li { font-size: 13.5px; padding-left: 20px; }
  .dq-teaser-body { font-size: 13px; }
}

.global-analysis-status.done .spinner { display: none; }

/* ============================================================
   ☞ THEME: Anthropic-style Paper (베이지 한지 톤)
   ============================================================
   적용: <body class="theme-paper"> 만 — 결과 페이지 전용.
   메인/상세/로그인 페이지는 기존 다크 테마 그대로.
   ============================================================ */
body.theme-paper {
  /* 종이 톤 (베이지 카드 안쪽용) */
  --paper-base:    #F5F0E5;
  --paper-soft:    #FAF7F0;
  --paper-card:    #FBF8F2;
  --paper-warm:    #ECE4D2;
  --paper-edge:    #DDD2B9;
  /* 잉크 톤 */
  --ink-primary:   #2A2620;
  --ink-secondary: #5C5448;
  --ink-muted:     #8B8273;
  --ink-line:      #D4CBB8;
  /* 강조 */
  --accent-vermillion: #C44536;
  --accent-vermillion-soft: #D96A5E;
  --accent-seal-gold:  #A07C2F;
  --accent-celadon:    #6B8A7A;
  --accent-celadon-soft: #8FA89A;
  --accent-indigo:     #3D5A6C;
  --accent-clay:       #B8806B;

  /* 다크 프레임 (메인 사이트와 통일) */
  background: #08070B;
  color: var(--text-primary, #F5F2EC);
  font-family: var(--font-display);  /* Pretendard 고딕 통일 */
  position: relative;
}

/* 베이지 카드 안에서만 종이결 효과 */
body.theme-paper main,
body.theme-paper .container { position: relative; z-index: 1; }

/* 헤더는 다크 (사이트 통일) */
body.theme-paper .site-header.minimal {
  background: rgba(8, 7, 11, 0.92);
  border-bottom: 1px solid rgba(212, 175, 55, 0.18);
  backdrop-filter: blur(8px);
}
body.theme-paper .site-header .brand {
  color: var(--text-primary, #F5F2EC);
  font-family: var(--font-display);
}

/* 본문 h/p 기본 — 다크 프레임 (헤더 영역) */
body.theme-paper h1, body.theme-paper h2, body.theme-paper h3, body.theme-paper h4 {
  font-family: var(--font-display);  /* 고딕 통일 */
}
body.theme-paper > main h1,
body.theme-paper > main > section:first-of-type h1 {
  color: var(--text-primary, #F5F2EC);
}
/* section h2 — 다크 프레임에 떠있음, 밝은 톤으로 잘 보이게 */
body.theme-paper .section > h2 {
  color: var(--text-primary, #F5F2EC);
  font-weight: 700;
  letter-spacing: -0.02em;
}
body.theme-paper p {
  font-family: var(--font-display);
  line-height: 1.95;
  letter-spacing: -0.005em;
  font-size: 15px;  /* 본문 base 키움 (13.5 → 15) */
  margin-bottom: 14px;  /* p 사이 여백 — 문단 가독성 ↑ */
}
body.theme-paper p:last-child { margin-bottom: 0; }

/* 베이지 카드 안에서는 잉크 톤 + 다시 베이지 결 */
body.theme-paper .myeongsik-card,
body.theme-paper .gapja-card,
body.theme-paper .doryeong-card,
body.theme-paper .doryeong-questions,
body.theme-paper .pattern-card,
body.theme-paper .comparison-bars,
body.theme-paper .medical-compare,
body.theme-paper .daeun-timeline,
body.theme-paper .jingnyowa-card,
body.theme-paper .golden-clock,
body.theme-paper .gaeun-card,
body.theme-paper #scoreCard,
body.theme-paper .result-paywall,
body.theme-paper .paywall-doryeong-final,
body.theme-paper .preview-locked-wrap,
body.theme-paper .about-doryeong {
  color: var(--ink-primary);
}
body.theme-paper .myeongsik-card *,
body.theme-paper .gapja-card *,
body.theme-paper .doryeong-card *,
body.theme-paper .doryeong-questions *,
body.theme-paper .pattern-card *,
body.theme-paper .medical-compare *,
body.theme-paper .daeun-timeline *,
body.theme-paper .jingnyowa-card *,
body.theme-paper .gaeun-card *,
body.theme-paper #scoreCard *,
body.theme-paper .paywall-doryeong-final * {
  font-family: var(--font-display) !important;  /* 강제 고딕 */
}
/* ============================================================
   ☞ 다크 배경 + 베이지 inner 카드 — 결과 페이지 컨텐츠
   ============================================================
   배경: 다크 페이지 그대로 (#08070B)
   각 Part body 들은 베이지 카드로 wrap 되어 가독성 확보
   ============================================================ */
body.theme-paper #ilganLong,
body.theme-paper #part2Body,
body.theme-paper #part3Body,
body.theme-paper #daeunWrap,
body.theme-paper #kyukgukBody,
body.theme-paper #shinsalBody,
body.theme-paper #part5Body,
body.theme-paper #mbtiBody,
body.theme-paper #healthBody,
body.theme-paper #part6Body,
body.theme-paper #gaeunDeck,
body.theme-paper #comparisonBars,
body.theme-paper #goldenClockWrap,
body.theme-paper #gaeunIntro,
body.theme-paper .shipsin-donut-wrap {
  background: var(--paper-card, #FBF8F2);
  border: 1px solid var(--ink-line, #D4CBB8);
  border-radius: 14px;
  padding: 20px 18px;
  color: var(--ink-primary);
  margin-top: 10px;
  margin-bottom: 4px;
}
/* 도넛 중앙 텍스트 (식/印/官 등) 가독성 ↑ */
body.theme-paper .shipsin-donut .center-text {
  fill: var(--ink-primary, #2A2620);
  font-weight: 800;
}
body.theme-paper .shipsin-donut .center-sub {
  fill: var(--ink-secondary, #5C5448);
  font-weight: 600;
}
/* 도넛 중앙 원 배경 — 베이지 카드 위에서 잘 보이도록 */
body.theme-paper .shipsin-donut .center-bg {
  fill: var(--paper-warm, #ECE4D2);
}
/* 도넛 범례 라벨 가독성 (베이지 위) */
body.theme-paper .shipsin-legend-item {
  color: var(--ink-primary, #2A2620);
}
body.theme-paper .shipsin-legend-item .val {
  color: var(--ink-primary, #2A2620);
  font-weight: 700;
}
/* 대운 wrap 안 timeline과 notes는 배경 X */
body.theme-paper #daeunTimeline,
body.theme-paper #daeunNotes {
  background: transparent;
  border: none;
  padding: 0;
  margin: 0;
}
body.theme-paper #daeunNotes { margin-top: 16px; }
/* 십신 도넛 영역 베이지 카드 + 색감 조정 */
body.theme-paper .shipsin-donut .ring-bg {
  stroke: var(--paper-warm, #ECE4D2);
}
body.theme-paper .shipsin-donut .center-text {
  fill: var(--ink-primary, #2A2620);
}
body.theme-paper .shipsin-donut .center-sub {
  fill: var(--ink-muted, #8B8273);
}
body.theme-paper .shipsin-legend-item {
  color: var(--ink-secondary, #5C5448);
  font-size: 14px;
}
body.theme-paper .shipsin-legend-item .val {
  color: var(--ink-primary, #2A2620);
}
/* gaeunIntro는 위 일반 p 스타일 + 베이지 카드라 padding 조정 */
body.theme-paper #gaeunIntro {
  padding: 16px 18px;
  font-family: var(--font-display);
  font-size: 13.5px;
  line-height: 1.85;
  color: var(--ink-secondary);
  font-style: italic;
  letter-spacing: -0.005em;
  margin-bottom: 12px;
}
/* 베이지 wrap 안에 있는 모든 텍스트는 잉크 톤 */
body.theme-paper #ilganLong,
body.theme-paper #ilganLong p,
body.theme-paper #part2Body p,
body.theme-paper #part3Body p,
body.theme-paper #daeunNotes p,
body.theme-paper #kyukgukBody p,
body.theme-paper #shinsalBody p,
body.theme-paper #part5Body p,
body.theme-paper #mbtiBody p,
body.theme-paper #healthBody p,
body.theme-paper #part6Body p {
  color: var(--ink-secondary);
}
/* 헤더 (section-title, h2) — 위계 유지 위해 다크 프레임에 노출, 골드 톤 */
body.theme-paper .section > .section-title,
body.theme-paper .section > h2 {
  margin-left: 4px;
}

/* inner 카드들은 paper-soft로 위계 차별화 */
body.theme-paper #part2Body .pattern-card,
body.theme-paper #daeunNotes > div,
body.theme-paper #kyukgukBody > div,
body.theme-paper #shinsalBody > div,
body.theme-paper #mbtiBody > div,
body.theme-paper #healthBody > div,
body.theme-paper #part6Body > div,
body.theme-paper #gaeunDeck > .gaeun-card {
  background: var(--paper-soft, #FAF7F0);
  border-color: var(--paper-edge, #DDD2B9);
}

/* preview-locked-wrap 안에 있는 body는 wrap이 베이지 처리하니 내부 body는 배경 제거 */
body.theme-paper .preview-locked-wrap #part2Body,
body.theme-paper .preview-locked-wrap #part3Body,
body.theme-paper .preview-locked-wrap #daeunNotes,
body.theme-paper .preview-locked-wrap #kyukgukBody,
body.theme-paper .preview-locked-wrap #shinsalBody,
body.theme-paper .preview-locked-wrap #part5Body,
body.theme-paper .preview-locked-wrap #mbtiBody,
body.theme-paper .preview-locked-wrap #healthBody,
body.theme-paper .preview-locked-wrap #part6Body,
body.theme-paper .preview-locked-wrap #gaeunDeck {
  background: transparent;
  border: none;
  padding: 0;
  margin: 0;
}

/* preview-locked-wrap 자체에 베이지 톤 */
body.theme-paper .preview-locked-wrap {
  background: var(--paper-card, #FBF8F2);
  border: 1px solid var(--ink-line, #D4CBB8);
  padding: 20px 18px;
  margin-top: 10px;
}

/* 카드 안 텍스트 색 */
body.theme-paper .myeongsik-card p,
body.theme-paper .gapja-card p,
body.theme-paper .doryeong-card p,
body.theme-paper .pattern-card p,
body.theme-paper .gaeun-card p,
body.theme-paper .paywall-doryeong-final p,
body.theme-paper .about-doryeong p,
body.theme-paper .jingnyowa-desc {
  color: var(--ink-secondary);
}

body.theme-paper strong { color: var(--accent-vermillion); font-weight: 700; }
body.theme-paper em { color: var(--accent-seal-gold); font-style: normal; font-weight: 600; }

/* 다크 프레임 영역의 muted/secondary는 밝은 톤 */
body.theme-paper .muted,
body.theme-paper .secondary {
  color: var(--text-muted, #8E8898);
}
body.theme-paper .myeongsik-card .muted,
body.theme-paper .gapja-card .muted,
body.theme-paper .doryeong-card .muted,
body.theme-paper .pattern-card .muted,
body.theme-paper .paywall-doryeong-final .muted,
body.theme-paper .about-doryeong .muted {
  color: var(--ink-muted);
}

/* hero-tag (다크 프레임에 있음 — 골드 톤) */
body.theme-paper .hero-tag {
  background: transparent;
  color: var(--accent-gold-soft, #E8C547);
  border-bottom: 1px solid rgba(212, 175, 55, 0.22);
  font-family: var(--font-display);
  letter-spacing: 0.22em;
  font-weight: 500;
  padding-bottom: 6px;
  margin-bottom: 14px;
}

body.theme-paper .section { padding: 26px 0 8px; }

/* 다크 프레임 위에 떠있는 컴포넌트 — 살짝 그림자로 깊이감 */
body.theme-paper .myeongsik-card,
body.theme-paper .doryeong-card,
body.theme-paper .gapja-card,
body.theme-paper .doryeong-questions,
body.theme-paper .preview-locked-wrap,
body.theme-paper #ilganLong,
body.theme-paper #part2Body,
body.theme-paper #part3Body,
body.theme-paper #daeunNotes,
body.theme-paper #kyukgukBody,
body.theme-paper #shinsalBody,
body.theme-paper #part5Body,
body.theme-paper #mbtiBody,
body.theme-paper #healthBody,
body.theme-paper #part6Body,
body.theme-paper #gaeunDeck,
body.theme-paper #comparisonBars,
body.theme-paper #goldenClockWrap,
body.theme-paper #daeunTimeline,
body.theme-paper #scoreCard,
body.theme-paper #hiddenSummaryCard > div {
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.25);
}

/* section-title — 다크 프레임이 보이는 영역에 있는 경우 골드 톤 */
body.theme-paper .section-title {
  color: var(--accent-gold-soft, #E8C547);
  font-family: var(--font-display);
  letter-spacing: 0.22em;
  font-weight: 500;
  font-size: 11px;
  margin-bottom: 8px;
  text-transform: uppercase;
}

/* footer — 다크 통일 */
body.theme-paper .site-footer {
  background: #08070B;
  color: var(--text-secondary, #B8B0C2);
  border-top: 1px solid rgba(212, 175, 55, 0.12);
}
body.theme-paper .site-footer a { color: var(--text-secondary, #B8B0C2); }
body.theme-paper .footer-copy { color: var(--text-muted, #8E8898); }

/* disclaimer — 다크 프레임 */
body.theme-paper .disclaimer {
  background: rgba(212, 175, 55, 0.04);
  border: 1px dashed rgba(212, 175, 55, 0.22);
  color: var(--text-muted, #8E8898);
}

body.theme-paper .btn-primary {
  background: var(--accent-vermillion);
  color: #FFF8EE;
  border: 1px solid var(--accent-vermillion);
}
body.theme-paper .btn-primary:hover { background: var(--accent-vermillion-soft); }
body.theme-paper .btn-secondary {
  background: transparent;
  color: var(--ink-primary);
  border: 1px solid var(--ink-line);
}

/* ============================================================
   ☞ 도령 환영 카드 (베이지 테마 오버라이드)
   ============================================================ */
body.theme-paper .doryeong-card {
  background:
    radial-gradient(ellipse at top right, rgba(160, 124, 47, 0.08) 0%, transparent 60%),
    linear-gradient(180deg, var(--paper-card) 0%, var(--paper-soft) 100%);
  border: 1px solid var(--ink-line);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.4),
    0 1px 0 rgba(180, 150, 100, 0.15);
}
body.theme-paper .doryeong-card::before {
  background: radial-gradient(circle, rgba(196, 69, 54, 0.10) 0%, transparent 60%);
}
body.theme-paper .doryeong-portrait-inner {
  background:
    radial-gradient(circle at 35% 30%, rgba(196, 69, 54, 0.18), transparent 55%),
    linear-gradient(150deg, var(--paper-warm) 0%, var(--paper-edge) 60%, #D5C4A8 100%);
  border: 1.5px solid var(--accent-seal-gold);
  color: var(--accent-vermillion);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.5),
    0 2px 6px rgba(140, 100, 50, 0.15);
}
body.theme-paper .doryeong-stamp {
  background: var(--accent-vermillion);
  color: #FFF8EE;
}
body.theme-paper .doryeong-tag {
  color: var(--accent-seal-gold);
}
body.theme-paper .doryeong-greeting {
  color: var(--ink-primary);
}
body.theme-paper .doryeong-firstline {
  color: var(--ink-secondary);
}
body.theme-paper .doryeong-firstline strong {
  color: var(--accent-vermillion);
}

/* ============================================================
   ☞ 60갑자 일주 카드 (메인 비주얼 컴포넌트)
   ============================================================ */
.gapja-card {
  background: var(--paper-card, #FBF8F2);
  border: 1px solid var(--ink-line, #D4CBB8);
  border-radius: 16px;
  padding: 28px 22px 26px;
  text-align: center;
  position: relative;
  overflow: hidden;
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.5),
    0 2px 10px rgba(140, 100, 50, 0.08);
}
.gapja-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 80% 40% at 50% 0%, var(--gapja-tint, rgba(196, 69, 54, 0.06)) 0%, transparent 70%);
  pointer-events: none;
}
.gapja-card-tag {
  font-family: var(--font-serif);
  font-size: 10.5px;
  color: var(--accent-seal-gold, #A07C2F);
  letter-spacing: 0.24em;
  font-weight: 500;
  margin-bottom: 12px;
  position: relative;
  z-index: 1;
}
.gapja-card-emoji {
  font-size: 80px;
  line-height: 1;
  margin-bottom: 12px;
  filter: drop-shadow(0 4px 12px rgba(140, 100, 50, 0.18));
  position: relative;
  z-index: 1;
}
.gapja-card-name {
  font-family: var(--font-serif);
  font-size: 24px;
  font-weight: 700;
  color: var(--ink-primary, #2A2620);
  letter-spacing: -0.02em;
  margin-bottom: 4px;
  position: relative;
  z-index: 1;
}
.gapja-card-name .chars {
  font-size: 17px;
  font-weight: 500;
  color: var(--ink-muted, #8B8273);
  margin-left: 8px;
  letter-spacing: 0.05em;
}
.gapja-card-keyword {
  font-family: var(--font-serif);
  font-size: 14px;
  color: var(--accent-vermillion, #C44536);
  font-style: italic;
  margin-bottom: 18px;
  position: relative;
  z-index: 1;
  letter-spacing: -0.005em;
}
.gapja-card-keyword::before, .gapja-card-keyword::after {
  content: '·';
  margin: 0 8px;
  color: var(--accent-seal-gold, #A07C2F);
  opacity: 0.6;
}
.gapja-card-chips {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 6px;
  margin-bottom: 16px;
  position: relative;
  z-index: 1;
}
.gapja-chip {
  background: var(--paper-warm, #ECE4D2);
  color: var(--ink-primary, #2A2620);
  border: 1px solid var(--ink-line, #D4CBB8);
  font-size: 12px;
  padding: 5px 12px;
  border-radius: 100px;
  font-weight: 500;
  letter-spacing: -0.005em;
}
.gapja-chip.weakness {
  background: transparent;
  color: var(--ink-muted, #8B8273);
  border-color: var(--ink-line, #D4CBB8);
}
.gapja-card-body {
  font-family: var(--font-serif);
  font-size: 13px;
  color: var(--ink-secondary, #5C5448);
  font-style: italic;
  line-height: 1.7;
  padding-top: 14px;
  border-top: 1px solid var(--ink-line, #D4CBB8);
  position: relative;
  z-index: 1;
}
.gapja-card-body .label {
  display: block;
  font-style: normal;
  font-family: var(--font-serif);
  font-size: 10px;
  letter-spacing: 0.2em;
  color: var(--accent-seal-gold, #A07C2F);
  margin-bottom: 4px;
}

/* ============================================================
   ☞ 십신 도넛 차트 (SVG-based)
   ============================================================ */
.shipsin-donut-wrap {
  display: flex;
  align-items: center;
  gap: 24px;
  flex-wrap: wrap;
  justify-content: center;
}
.shipsin-donut {
  width: 200px;
  height: 200px;
  flex-shrink: 0;
}
.shipsin-donut .ring-bg { fill: none; stroke: var(--paper-warm, #ECE4D2); stroke-width: 32; }
.shipsin-donut .center-text {
  font-family: var(--font-serif);
  font-size: 14px;
  fill: var(--ink-primary, #2A2620);
  text-anchor: middle;
  font-weight: 600;
}
.shipsin-donut .center-sub {
  font-size: 10px;
  fill: var(--ink-muted, #8B8273);
  text-anchor: middle;
  letter-spacing: 0.18em;
}
.shipsin-legend {
  display: grid;
  grid-template-columns: auto auto;
  gap: 8px 18px;
  font-size: 13px;
}
.shipsin-legend-item {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--ink-secondary, #5C5448);
}
.shipsin-legend-item .dot {
  width: 12px; height: 12px; border-radius: 3px; flex-shrink: 0;
}
.shipsin-legend-item .val {
  font-weight: 700; color: var(--ink-primary, #2A2620);
  font-variant-numeric: tabular-nums;
  margin-left: 4px;
}

/* ============================================================
   ☞ 패턴 카드 (Part 2)
   ============================================================ */
.pattern-card {
  background: var(--paper-card, #FBF8F2);
  border: 1px solid var(--ink-line, #D4CBB8);
  border-left: 4px solid var(--accent-vermillion, #C44536);
  border-radius: 12px;
  padding: 18px 18px 16px;
  position: relative;
}
.pattern-card-head {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
  flex-wrap: wrap;
}
.pattern-rank {
  background: var(--accent-vermillion, #C44536);
  color: #FFF8EE;
  font-family: var(--font-serif);
  font-size: 10px;
  letter-spacing: 0.12em;
  padding: 3px 8px;
  border-radius: 4px;
  font-weight: 600;
}
.pattern-tags {
  font-size: 11px;
  color: var(--ink-muted, #8B8273);
  letter-spacing: -0.005em;
}
.pattern-label {
  font-family: var(--font-serif);
  font-size: 17px;
  color: var(--ink-primary, #2A2620);
  margin: 0 0 10px;
  font-weight: 700;
  letter-spacing: -0.015em;
}
.pattern-desc {
  font-family: var(--font-serif);
  font-size: 13.5px;
  color: var(--ink-secondary, #5C5448);
  line-height: 1.85;
  font-style: italic;
  margin: 0 0 14px;
  letter-spacing: -0.005em;
}
.pattern-stats {
  display: flex;
  gap: 18px;
  padding: 10px 0;
  border-top: 1px dashed var(--ink-line, #D4CBB8);
  border-bottom: 1px dashed var(--ink-line, #D4CBB8);
  margin-bottom: 12px;
}
.pattern-stats > div {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.pattern-stats .stat-label {
  font-size: 10px;
  letter-spacing: 0.18em;
  color: var(--ink-muted, #8B8273);
  text-transform: uppercase;
}
.pattern-stats .stat-val {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 700;
  color: var(--ink-primary, #2A2620);
  letter-spacing: -0.02em;
}
.pattern-detail {
  font-size: 12.5px;
  color: var(--ink-secondary, #5C5448);
  line-height: 1.75;
}
.pattern-detail strong {
  color: var(--accent-seal-gold, #A07C2F);
  font-weight: 600;
  margin-right: 4px;
}

/* ============================================================
   ☞ 합격 패턴 비교 막대 (내 vs 합격 평균)
   ============================================================ */
.comparison-bars {
  background: var(--paper-warm, #ECE4D2);
  border-radius: 12px;
  padding: 18px;
  margin: 16px 0 0;
}
.comparison-bar-row {
  display: grid;
  grid-template-columns: 70px 1fr 50px;
  gap: 10px;
  align-items: center;
  margin-bottom: 10px;
}
.comparison-bar-row:last-child { margin-bottom: 0; }
.comparison-bar-label {
  font-family: var(--font-serif);
  font-size: 12px;
  color: var(--ink-primary, #2A2620);
  font-weight: 600;
}
.comparison-bar-track {
  background: var(--paper-soft, #FAF7F0);
  border: 1px solid var(--ink-line, #D4CBB8);
  border-radius: 6px;
  height: 22px;
  position: relative;
  overflow: hidden;
}
.comparison-bar-fill {
  position: absolute;
  top: 0; left: 0; bottom: 0;
  background: linear-gradient(90deg, var(--accent-celadon, #6B8A7A) 0%, var(--accent-celadon-soft, #8FA89A) 100%);
  transition: width 0.6s ease;
}
.comparison-bar-fill.me {
  background: linear-gradient(90deg, var(--accent-vermillion, #C44536) 0%, var(--accent-vermillion-soft, #D96A5E) 100%);
}
.comparison-bar-fill .avg-marker {
  position: absolute;
  right: -1px; top: -2px; bottom: -2px;
  width: 2px;
  background: var(--ink-primary, #2A2620);
}
.comparison-bar-val {
  font-family: var(--font-display);
  font-variant-numeric: tabular-nums;
  font-size: 13px;
  font-weight: 700;
  color: var(--ink-primary, #2A2620);
  text-align: right;
}

/* ============================================================
   ☞ 대운 차트 (전통 만세력 8칸 — 천간/지지 + 십신 + 오행 색상)
   ============================================================ */
.daeun-timeline {
  background: var(--paper-card, #FBF8F2);
  border: 1px solid var(--ink-line, #D4CBB8);
  border-radius: 12px;
  padding: 18px 14px;
  overflow-x: auto;
}
.daeun-chart {
  min-width: 100%;
}
.daeun-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 4px 2px;
  table-layout: fixed;
}
.daeun-table th,
.daeun-table td {
  text-align: center;
  padding: 6px 2px;
  font-family: var(--font-serif);
  line-height: 1.2;
  letter-spacing: -0.005em;
}
.daeun-table .age-row th {
  font-family: var(--font-display);
  font-size: 14px;
  font-weight: 700;
  color: var(--ink-primary, #2A2620);
  padding-bottom: 6px;
  border-bottom: 1px solid var(--ink-line, #D4CBB8);
}
.daeun-table .shipsin-top td,
.daeun-table .shipsin-bottom td {
  font-size: 11.5px;
  color: var(--ink-muted, #8B8273);
  font-weight: 500;
  padding: 4px 2px;
}
.daeun-table .stem-row td,
.daeun-table .branch-row td {
  font-size: 22px;
  font-weight: 800;
  padding: 12px 4px;
  border-radius: 6px;
  border: 1.5px solid var(--ink-line, #D4CBB8);
  font-family: var(--font-serif);
}
.daeun-table .flow-row td {
  font-size: 16px;
  padding: 6px 2px;
}
/* 오행 색상 — 만세력 컨벤션 */
.daeun-table td.oh-mok   { background: #C9E6CF; color: #1B3D24; border-color: #5BA070; }  /* 木 — 녹색 */
.daeun-table td.oh-hwa   { background: #F4B6A8; color: #5C1810; border-color: #C44536; }  /* 火 — 적색 */
.daeun-table td.oh-to    { background: #F2D785; color: #4A3308; border-color: #A07C2F; }  /* 土 — 황색 */
.daeun-table td.oh-geum  { background: #FBFAF6; color: #2A2620; border-color: #B3A88E; }  /* 金 — 백색 */
.daeun-table td.oh-su    { background: #2A2620; color: #FBFAF6; border-color: #0F0E0C; }  /* 水 — 흑색 */
.daeun-chart-legend {
  margin-top: 12px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  color: var(--ink-muted, #8B8273);
}
.daeun-chart-legend .lg {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 4px;
  font-family: var(--font-serif);
  font-weight: 700;
  font-size: 13px;
  border: 1px solid var(--ink-line, #D4CBB8);
}
.daeun-chart-legend .lg-mok  { background: #C9E6CF; color: #1B3D24; }
.daeun-chart-legend .lg-hwa  { background: #F4B6A8; color: #5C1810; }
.daeun-chart-legend .lg-to   { background: #F2D785; color: #4A3308; }
.daeun-chart-legend .lg-geum { background: #FBFAF6; color: #2A2620; }
.daeun-chart-legend .lg-su   { background: #2A2620; color: #FBFAF6; }
.daeun-chart-legend .lg-note { margin-left: 4px; font-style: italic; }

@media (max-width: 520px) {
  .daeun-table .stem-row td,
  .daeun-table .branch-row td { font-size: 18px; padding: 10px 2px; }
  .daeun-table .age-row th { font-size: 12px; }
  .daeun-table .shipsin-top td,
  .daeun-table .shipsin-bottom td { font-size: 10px; }
  .daeun-table .flow-row td { font-size: 14px; }
}

/* ============================================================
   ☞ 학습 골든타임 시계 (24h dial)
   ============================================================ */
.golden-clock {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding: 18px;
  background: var(--paper-card, #FBF8F2);
  border: 1px solid var(--ink-line, #D4CBB8);
  border-radius: 12px;
}
.golden-clock svg {
  width: 200px;
  height: 200px;
}
.golden-clock-info {
  text-align: center;
}
.golden-clock-info .time {
  font-family: var(--font-serif);
  font-size: 18px;
  font-weight: 700;
  color: var(--accent-vermillion, #C44536);
  margin-bottom: 4px;
}
.golden-clock-info .why {
  font-size: 12.5px;
  color: var(--ink-secondary, #5C5448);
  line-height: 1.65;
  letter-spacing: -0.005em;
}

/* ============================================================
   ☞ 진료과 핏 카드 (의사 결혼 한정)
   ============================================================ */
.jingnyowa-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
.jingnyowa-card {
  background: var(--paper-card, #FBF8F2);
  border: 1px solid var(--ink-line, #D4CBB8);
  border-left: 4px solid var(--accent-celadon, #6B8A7A);
  border-radius: 12px;
  padding: 16px 16px 14px;
}
.jingnyowa-card-head {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 8px;
}
.jingnyowa-emoji { font-size: 28px; }
.jingnyowa-name {
  font-family: var(--font-serif);
  font-size: 16px;
  font-weight: 700;
  color: var(--ink-primary, #2A2620);
  flex: 1;
  letter-spacing: -0.01em;
}
.jingnyowa-rank {
  background: var(--accent-celadon, #6B8A7A);
  color: #FBF8F2;
  font-family: var(--font-serif);
  font-size: 10px;
  padding: 3px 8px;
  border-radius: 4px;
  letter-spacing: 0.1em;
}
.jingnyowa-score {
  display: flex;
  align-items: baseline;
  gap: 6px;
  margin-bottom: 10px;
}
.jingnyowa-score .num {
  font-family: var(--font-display);
  font-size: 28px;
  font-weight: 700;
  color: var(--accent-vermillion, #C44536);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.025em;
}
.jingnyowa-score .label {
  font-size: 11px;
  color: var(--ink-muted, #8B8273);
  letter-spacing: 0.12em;
}
.jingnyowa-desc {
  font-family: var(--font-serif);
  font-size: 13px;
  color: var(--ink-secondary, #5C5448);
  font-style: italic;
  line-height: 1.75;
  margin: 0 0 10px;
}
.jingnyowa-spot {
  font-size: 11.5px;
  color: var(--ink-muted, #8B8273);
  padding-top: 8px;
  border-top: 1px dashed var(--ink-line, #D4CBB8);
}
.jingnyowa-spot::before {
  content: '📍 ';
  font-size: 11px;
}

/* ============================================================
   ☞ 의대 vs 의료계열 비교
   ============================================================ */
.medical-compare {
  background: var(--paper-card, #FBF8F2);
  border: 1px solid var(--ink-line, #D4CBB8);
  border-radius: 12px;
  padding: 16px;
}
.medical-compare-row {
  display: grid;
  grid-template-columns: 60px 1fr 48px;
  gap: 10px;
  align-items: center;
  padding: 10px 0;
  border-bottom: 1px dashed var(--ink-line, #D4CBB8);
}
.medical-compare-row:last-child { border-bottom: none; }
.medical-compare-row .label-cell {
  font-family: var(--font-serif);
  font-weight: 700;
  color: var(--ink-primary, #2A2620);
  font-size: 14px;
}
.medical-compare-row .bar-cell {
  position: relative;
  height: 16px;
  background: var(--paper-warm, #ECE4D2);
  border-radius: 4px;
  overflow: hidden;
}
.medical-compare-row .bar-fill {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, var(--accent-seal-gold, #A07C2F) 0%, var(--accent-vermillion, #C44536) 100%);
  transform-origin: left;
}
.medical-compare-row .bar-cell .note {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  padding-left: 8px;
  font-size: 10px;
  color: var(--paper-soft);
  font-weight: 600;
}
.medical-compare-row .score-cell {
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 700;
  color: var(--ink-primary, #2A2620);
  text-align: right;
  font-variant-numeric: tabular-nums;
}

/* ============================================================
   ☞ 개운법 5장 — 세로 스택 (캐러셀 X)
   ============================================================ */
.gaeun-deck {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 0;
  margin: 0;
  overflow: visible;
}
.gaeun-card {
  flex: 0 0 auto;
  width: 100%;
  background: var(--paper-card, #FBF8F2);
  border: 1px solid var(--ink-line, #D4CBB8);
  border-radius: 12px;
  padding: 16px 16px 18px;
  position: relative;
}
.gaeun-card-icon {
  font-size: 30px;
  margin-bottom: 8px;
}
.gaeun-card-cat {
  font-family: var(--font-display);
  font-size: 11.5px;
  letter-spacing: 0.22em;
  color: var(--accent-seal-gold, #A07C2F);
  margin-bottom: 6px;
  font-weight: 600;
}
.gaeun-card-title {
  font-family: var(--font-display);
  font-size: 17px;
  font-weight: 700;
  color: var(--ink-primary, #2A2620);
  margin-bottom: 10px;
  letter-spacing: -0.015em;
}
.gaeun-card-detail {
  font-size: 14.5px;
  color: var(--ink-secondary, #5C5448);
  line-height: 1.85;
  letter-spacing: -0.005em;
}

/* ============================================================
   ☞ 명식 표 베이지 변형 (theme-paper에서 자동)
   ============================================================ */
body.theme-paper .myeongsik-card {
  background: var(--paper-card, #FBF8F2);
  border: 1px solid var(--ink-line, #D4CBB8);
  color: var(--ink-primary);
}
body.theme-paper .myeongsik-card .label,
body.theme-paper .myeongsik-card .meta {
  color: var(--accent-seal-gold, #A07C2F);
}
body.theme-paper .manse-row-label,
body.theme-paper .manse-cell-header {
  color: var(--ink-secondary, #5C5448);
  border-color: var(--ink-line, #D4CBB8);
}
body.theme-paper .manse-cell {
  color: var(--ink-primary, #2A2620);
  border-color: var(--ink-line, #D4CBB8);
}
body.theme-paper .manse-cell-big {
  border-color: var(--ink-line, #D4CBB8);
  /* 오행 색깔(mok/hwa/to/geum/su)은 base CSS의 그라데이션 색 그대로 유지 */
}
body.theme-paper .manse-cell.placeholder,
body.theme-paper .manse-cell-big.placeholder {
  color: var(--ink-muted, #8B8273);
}
/* 일간 셀 — 다른 천간과 동일한 오행 색을 그대로 유지, 강조는 outline만 */
body.theme-paper .manse-cell-big.day-stem,
body.theme-paper .manse-cell-big.day-branch {
  /* background X — base 오행 그라데이션 유지 */
  border-color: var(--ink-line, #D4CBB8);
}
body.theme-paper .ohaeng-title {
  color: var(--accent-seal-gold, #A07C2F);
}
body.theme-paper .ohaeng-radar .grid { stroke: var(--ink-line, #D4CBB8); }
body.theme-paper .ohaeng-radar .axis { stroke: var(--ink-line, #D4CBB8); }
body.theme-paper .ohaeng-radar .data-poly {
  fill: rgba(196, 69, 54, 0.18);
  stroke: var(--accent-vermillion, #C44536);
}
body.theme-paper .ohaeng-radar .point { fill: var(--accent-vermillion, #C44536); }
body.theme-paper .ohaeng-radar .label {
  fill: var(--ink-primary, #2A2620);
  font-weight: 700;
}
body.theme-paper .ohaeng-radar .pct { fill: var(--ink-secondary, #5C5448); }
body.theme-paper .ohaeng-bar .ch { color: var(--ink-primary, #2A2620); }
body.theme-paper .ohaeng-bar .track { background: var(--paper-warm, #ECE4D2); }
body.theme-paper .ohaeng-bar .pct { color: var(--ink-secondary, #5C5448); }

/* ============================================================
   ☞ 점수 카드 (베이지 변형)
   ============================================================ */
body.theme-paper #scoreCard {
  background: linear-gradient(180deg, var(--paper-card) 0%, var(--paper-soft) 100%) !important;
  border-color: var(--accent-vermillion-soft, #D96A5E) !important;
}
body.theme-paper #scoreCard .score-num,
body.theme-paper #scoreValue {
  color: var(--accent-vermillion, #C44536);
}
body.theme-paper #scoreLabel {
  color: var(--accent-seal-gold, #A07C2F);
}
body.theme-paper #scoreDesc {
  color: var(--ink-secondary, #5C5448);
}
body.theme-paper .score-locked-overlay {
  background: rgba(245, 240, 229, 0.92);
  color: var(--ink-primary, #2A2620);
}
body.theme-paper .score-locked-overlay .icon { color: var(--accent-vermillion, #C44536); }
body.theme-paper .score-locked-overlay .sub { color: var(--ink-muted, #8B8273); }

/* ============================================================
   ☞ Paywall 베이지
   ============================================================ */
body.theme-paper .result-paywall {
  background: var(--paper-card, #FBF8F2);
  border: 1px solid var(--ink-line, #D4CBB8);
  color: var(--ink-primary);
}
body.theme-paper .result-paywall h2 { color: var(--ink-primary); }
body.theme-paper .result-paywall .pw-desc { color: var(--ink-secondary); }
body.theme-paper .pw-tag {
  background: var(--accent-vermillion, #C44536);
  color: #FFF8EE;
}
body.theme-paper .pw-features {
  background: var(--paper-warm, #ECE4D2);
  border-color: var(--ink-line, #D4CBB8);
}
body.theme-paper .pw-features ul li { color: var(--ink-secondary); }
body.theme-paper .pw-features ul li::before { color: var(--accent-vermillion); }

body.theme-paper .doryeong-questions {
  background: var(--paper-card, #FBF8F2);
  border: 1px solid var(--ink-line, #D4CBB8);
}
body.theme-paper .doryeong-questions::before {
  background: linear-gradient(90deg, transparent 0%, var(--accent-vermillion, #C44536) 50%, transparent 100%);
}
body.theme-paper .dq-mark {
  border-color: var(--accent-vermillion, #C44536);
  color: var(--accent-vermillion);
  background: rgba(196, 69, 54, 0.05);
}
body.theme-paper .dq-tag { color: var(--accent-seal-gold, #A07C2F); }
body.theme-paper .dq-title { color: var(--ink-primary, #2A2620); }
body.theme-paper .dq-list { border-top-color: var(--ink-line, #D4CBB8); }
body.theme-paper .dq-list li {
  border-bottom-color: var(--ink-line, #D4CBB8);
  color: var(--ink-secondary, #5C5448);
}
body.theme-paper .dq-list li::before { color: var(--accent-vermillion, #C44536); }
body.theme-paper .dq-teaser {
  background:
    repeating-linear-gradient(180deg, rgba(160, 124, 47, 0.025) 0px, rgba(160, 124, 47, 0.025) 1px, transparent 1px, transparent 6px),
    var(--paper-warm, #ECE4D2);
  border-color: var(--ink-line, #D4CBB8);
}
body.theme-paper .dq-teaser-label { color: var(--accent-seal-gold); }
body.theme-paper .dq-teaser-body { color: var(--ink-secondary); }
body.theme-paper .dq-blur {
  background: linear-gradient(180deg, transparent 0%, var(--paper-warm) 80%);
}
body.theme-paper .dq-sign { color: var(--ink-muted); }

/* ============================================================
   ☞ Section 일반 텍스트 + advice list (베이지)
   ============================================================ */
body.theme-paper .advice-list {
  list-style: none;
  padding: 0;
  margin: 16px 0 0;
}
body.theme-paper .advice-list li {
  padding: 10px 0 10px 26px;
  border-bottom: 1px dashed var(--ink-line, #D4CBB8);
  font-size: 13.5px;
  line-height: 1.85;
  color: var(--ink-secondary, #5C5448);
  position: relative;
  letter-spacing: -0.005em;
}
body.theme-paper .advice-list li::before {
  content: '✦';
  position: absolute;
  left: 4px;
  top: 11px;
  color: var(--accent-vermillion, #C44536);
}
body.theme-paper .advice-list li:last-child { border-bottom: none; }

/* ============================================================
   ☞ 블러 프리뷰 — 비로그인/미결제 시 Parts 2~7 잠금 노출
   ============================================================
   "있는데 가려진" 느낌으로 결제 호기심 hook 강화
   ============================================================ */
body.theme-paper .preview-locked-wrap {
  position: relative;
  max-height: 420px;
  overflow: hidden;
  border-radius: 14px;
}
body.theme-paper .preview-locked-wrap > * {
  filter: blur(4.5px);
  user-select: none;
  pointer-events: none;
  opacity: 0.95;
}
body.theme-paper .preview-locked-wrap::before {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 60%;
  background: linear-gradient(180deg,
    rgba(251, 248, 242, 0) 0%,
    rgba(251, 248, 242, 0.55) 45%,
    rgba(251, 248, 242, 0.95) 85%,
    var(--paper-card, #FBF8F2) 100%);
  z-index: 2;
  pointer-events: none;
}
body.theme-paper .preview-locked-badge {
  position: absolute;
  bottom: 18px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--accent-vermillion, #C44536);
  color: #FFF8EE;
  font-family: var(--font-display);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  padding: 8px 18px;
  border-radius: 100px;
  z-index: 3;
  white-space: nowrap;
  box-shadow: 0 4px 14px rgba(196, 69, 54, 0.3);
  pointer-events: auto;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 6px;
}
body.theme-paper .preview-locked-badge:hover {
  background: var(--accent-vermillion-soft, #D96A5E);
  transform: translateX(-50%) translateY(-1px);
  box-shadow: 0 6px 18px rgba(196, 69, 54, 0.4);
}

/* Part 1 일간 분석 — 마지막 단락 페이드 */
body.theme-paper .part1-fade {
  position: relative;
  max-height: 600px;
  overflow: hidden;
}
body.theme-paper .part1-fade::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 200px;
  background: linear-gradient(180deg,
    rgba(245, 240, 229, 0) 0%,
    rgba(245, 240, 229, 0.85) 70%,
    var(--paper-base, #F5F0E5) 100%);
  pointer-events: none;
}

/* 마지막 도령 멘트 + 결제 CTA */
body.theme-paper .paywall-doryeong-final {
  background:
    radial-gradient(ellipse at top, rgba(196, 69, 54, 0.10) 0%, transparent 60%),
    radial-gradient(ellipse at bottom, rgba(160, 124, 47, 0.06) 0%, transparent 60%),
    var(--paper-card, #FBF8F2);
  border: 1.5px solid var(--accent-vermillion-soft, #D96A5E);
  border-radius: 16px;
  padding: 36px 24px 28px;
  text-align: center;
  position: relative;
  overflow: hidden;
  margin-top: 8px;
  box-shadow: 0 10px 30px rgba(196, 69, 54, 0.15);
}
/* 도령 인장 (李緣) — 카드 우상단 */
body.theme-paper .paywall-doryeong-final::before {
  content: '李緣';
  position: absolute;
  top: 14px;
  right: 16px;
  background: var(--accent-vermillion);
  color: #FFF8EE;
  font-family: var(--font-display);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  padding: 5px 9px;
  border-radius: 5px;
  transform: rotate(-4deg);
  box-shadow: 0 3px 8px rgba(196, 69, 54, 0.35);
}
/* 도령 ✦ 마크 — 카드 상단 가운데 */
body.theme-paper .paywall-doryeong-final::after {
  content: '✦';
  position: absolute;
  top: 14px;
  left: 50%;
  transform: translateX(-50%);
  color: var(--accent-vermillion);
  font-size: 16px;
  opacity: 0.65;
}
body.theme-paper .paywall-doryeong-final .seal {
  font-family: var(--font-display);
  font-size: 11px;
  letter-spacing: 0.22em;
  color: var(--accent-vermillion);
  margin-top: 10px;
  margin-bottom: 14px;
  font-weight: 700;
}
body.theme-paper .paywall-doryeong-final h3 {
  font-family: var(--font-display);
  font-size: 22px;
  letter-spacing: -0.025em;
  color: var(--ink-primary);
  margin-bottom: 14px;
  font-weight: 700;
}
body.theme-paper .paywall-doryeong-final p {
  font-family: var(--font-display);
  font-size: 14px;
  line-height: 1.85;
  color: var(--ink-secondary);
  margin-bottom: 22px;
  font-style: italic;
  letter-spacing: -0.005em;
}
body.theme-paper .paywall-doryeong-final .price-row {
  background: var(--paper-warm, #ECE4D2);
  border-radius: 12px;
  padding: 14px 16px;
  margin-bottom: 22px;
}
body.theme-paper .paywall-doryeong-final .price-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin-bottom: 18px;
}
body.theme-paper .paywall-doryeong-final .price-row .orig {
  font-size: 14px;
  color: var(--ink-muted);
  text-decoration: line-through;
}
body.theme-paper .paywall-doryeong-final .price-row .now {
  font-family: var(--font-display);
  font-size: 26px;
  font-weight: 700;
  color: var(--accent-vermillion);
  letter-spacing: -0.025em;
}
body.theme-paper .paywall-doryeong-final .price-row .pct {
  background: var(--accent-vermillion);
  color: #FFF8EE;
  font-size: 11px;
  padding: 3px 7px;
  border-radius: 4px;
  font-weight: 700;
}
body.theme-paper .paywall-doryeong-final .unlock-btn {
  background: linear-gradient(180deg, var(--accent-vermillion) 0%, #B23A2E 100%);
  color: #FFF8EE;
  border: none;
  padding: 16px 32px;
  border-radius: 12px;
  font-size: 16px;
  font-weight: 700;
  font-family: var(--font-display);
  cursor: pointer;
  letter-spacing: -0.01em;
  transition: all 0.18s ease;
  box-shadow: 0 6px 18px rgba(196, 69, 54, 0.35);
  width: 100%;
  max-width: 320px;
}
body.theme-paper .paywall-doryeong-final .unlock-btn:hover {
  background: linear-gradient(180deg, var(--accent-vermillion-soft) 0%, var(--accent-vermillion) 100%);
  transform: translateY(-1px);
  box-shadow: 0 8px 22px rgba(196, 69, 54, 0.45);
}
body.theme-paper .paywall-doryeong-final .unlock-btn:active {
  transform: translateY(0);
}
body.theme-paper .paywall-doryeong-final .fineprint {
  margin-top: 14px;
  font-size: 11px;
  color: var(--ink-muted);
  letter-spacing: -0.005em;
}

@media (max-width: 480px) {
  .gapja-card-emoji { font-size: 64px; }
  .gapja-card-name { font-size: 20px; }
  .gapja-card-name .chars { font-size: 14px; }
  .shipsin-donut { width: 170px; height: 170px; }
  .pattern-label { font-size: 15px; }
  .pattern-desc { font-size: 13px; }
  .daeun-timeline-track { grid-auto-columns: 88px; }
  .gaeun-card { flex: 0 0 230px; }
}

/* ============================================================
   ☞ 모바일 칼럼 강제 (데스크탑에서도 좁은 폭 + 양옆 다크 wood)
   ============================================================
   결과 페이지(.theme-paper)만 적용. 메인/상세는 기존 그대로.
   ============================================================ */
@media (min-width: 768px) {
  body.theme-paper {
    background:
      radial-gradient(ellipse 60% 40% at 50% 0%, rgba(196, 69, 54, 0.04) 0%, transparent 60%),
      /* 양옆 다크 wood 톤 */
      linear-gradient(90deg,
        #1A1612 0%,
        #1A1612 calc(50% - 240px),
        #F5F0E5 calc(50% - 240px),
        #F5F0E5 calc(50% + 240px),
        #1A1612 calc(50% + 240px),
        #1A1612 100%);
  }

  body.theme-paper::before {
    /* 한지 noise를 가운데 칼럼에만 적용 */
    left: calc(50% - 240px);
    right: calc(50% - 240px);
    inset: 0 auto;
    width: 480px;
    margin: 0 auto;
  }

  body.theme-paper .container,
  body.theme-paper main.container {
    max-width: 460px;
    margin: 0 auto;
    padding-left: 20px;
    padding-right: 20px;
  }

  body.theme-paper .site-header.minimal,
  body.theme-paper .site-footer {
    background: transparent;
    border-color: transparent;
  }
  body.theme-paper .site-header.minimal .container,
  body.theme-paper .site-footer .container {
    background: rgba(245, 240, 229, 0.92);
    border-radius: 0;
    padding-left: 20px;
    padding-right: 20px;
  }

  /* 양옆 떨어지는 꽃잎 영역 (decorative only) */
  body.theme-paper .side-decor {
    position: fixed;
    top: 0;
    bottom: 0;
    width: calc((100vw - 480px) / 2);
    pointer-events: none;
    overflow: hidden;
    z-index: 0;
  }
  body.theme-paper .side-decor.left { left: 0; }
  body.theme-paper .side-decor.right { right: 0; }
}
@media (max-width: 767px) {
  body.theme-paper .side-decor { display: none; }
}

/* ============================================================
   ☞ 떨어지는 한지/단풍 조각 애니메이션 (연화문 꽃잎 모티브 차용)
   ============================================================ */
.hanji-piece {
  position: absolute;
  width: 14px;
  height: 18px;
  border-radius: 60% 40% 50% 50% / 50% 60% 40% 50%;
  opacity: 0;
  animation: hanjiFall 14s linear infinite;
  filter: drop-shadow(0 1px 2px rgba(140, 100, 50, 0.25));
}
.hanji-piece:nth-child(1)  { left:  4%; top: -10%; background:#E8C290; transform: rotate(12deg); animation-delay: -2s;  animation-duration: 15s; }
.hanji-piece:nth-child(2)  { left: 12%; top: -10%; background:#C99B6E; transform: rotate(-30deg); animation-delay: -6s; animation-duration: 12s; }
.hanji-piece:nth-child(3)  { left: 22%; top: -10%; background:#D4A574; transform: rotate(45deg); animation-delay: -9s; animation-duration: 18s; }
.hanji-piece:nth-child(4)  { left: 32%; top: -10%; background:#B8806B; transform: rotate(80deg); animation-delay: -1s; animation-duration: 16s; }
.hanji-piece:nth-child(5)  { left: 44%; top: -10%; background:#E8D2A0; transform: rotate(-15deg); animation-delay: -5s; animation-duration: 13s; }
.hanji-piece:nth-child(6)  { left: 56%; top: -10%; background:#D9B47C; transform: rotate(35deg); animation-delay: -8s; animation-duration: 17s; }
.hanji-piece:nth-child(7)  { left: 66%; top: -10%; background:#C28F60; transform: rotate(-50deg); animation-delay: -3s; animation-duration: 14s; }
.hanji-piece:nth-child(8)  { left: 76%; top: -10%; background:#E8C290; transform: rotate(60deg); animation-delay: -11s; animation-duration: 15s; }
.hanji-piece:nth-child(9)  { left: 86%; top: -10%; background:#A07C2F; transform: rotate(-20deg); animation-delay: -7s; animation-duration: 19s; }
.hanji-piece:nth-child(10) { left: 92%; top: -10%; background:#D4A574; transform: rotate(25deg); animation-delay: -4s; animation-duration: 16s; }
.hanji-piece:nth-child(11) { left: 18%; top: -10%; background:#C44536; opacity:0; animation-delay: -10s; animation-duration: 20s; width:10px;height:13px; }
.hanji-piece:nth-child(12) { left: 72%; top: -10%; background:#C44536; opacity:0; animation-delay: -13s; animation-duration: 21s; width:10px;height:13px; }

@keyframes hanjiFall {
  0%   { transform: translateY(-10vh) translateX(0) rotate(0deg); opacity: 0; }
  10%  { opacity: 0.55; }
  50%  { transform: translateY(50vh) translateX(20px) rotate(180deg); opacity: 0.6; }
  90%  { opacity: 0.45; }
  100% { transform: translateY(120vh) translateX(-20px) rotate(360deg); opacity: 0; }
}

/* ============================================================
   ☞ FORTUNE 4카드 (연화문 모티브 — 호기심 hook)
   ============================================================ */
.fortune-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  margin-top: 12px;
}
.fortune-card {
  background: var(--bg-secondary);
  border: 1px solid rgba(212, 175, 55, 0.15);
  border-radius: 12px;
  padding: 16px 16px 14px;
  display: flex;
  align-items: flex-start;
  gap: 16px;
  position: relative;
  transition: border-color 0.2s;
}
.fortune-card:hover {
  border-color: rgba(212, 175, 55, 0.35);
}
.fortune-card .num {
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: rgba(212, 175, 55, 0.06);
  border: 1px solid rgba(212, 175, 55, 0.18);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 700;
  color: var(--accent-gold-soft);
  letter-spacing: -0.01em;
}
.fortune-card .body {
  flex: 1;
  min-width: 0;
}
.fortune-card .title {
  font-family: var(--font-serif);
  font-size: 16px;
  font-weight: 700;
  color: var(--text-primary);
  letter-spacing: -0.015em;
  margin-bottom: 4px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.fortune-card .title .emoji { font-size: 16px; }
.fortune-card .desc {
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.65;
  letter-spacing: -0.005em;
}

/* ============================================================
   ☞ ABOUT 이연 도령 정통성 섹션
   ============================================================ */
.about-doryeong {
  background:
    radial-gradient(ellipse 80% 60% at 50% 0%, rgba(212, 175, 55, 0.05) 0%, transparent 70%),
    linear-gradient(180deg, var(--bg-secondary) 0%, var(--bg-card) 100%);
  border: 1px solid rgba(212, 175, 55, 0.18);
  border-radius: 14px;
  padding: 28px 22px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.about-doryeong::before {
  content: '✦';
  position: absolute;
  top: 14px; left: 50%;
  transform: translateX(-50%);
  color: var(--accent-gold-soft);
  font-size: 14px;
  opacity: 0.7;
}
.about-doryeong .tag {
  font-family: var(--font-serif);
  font-size: 11px;
  color: var(--accent-gold-soft);
  letter-spacing: 0.22em;
  margin-bottom: 16px;
  margin-top: 14px;
  font-weight: 500;
}
.about-doryeong h2 {
  font-size: 22px;
  letter-spacing: -0.02em;
  margin-bottom: 14px;
  font-weight: 700;
}
.about-doryeong h2 .gold {
  color: var(--accent-gold-soft);
  font-style: italic;
}
.about-doryeong p {
  font-size: 14px;
  color: var(--text-secondary);
  line-height: 1.85;
  letter-spacing: -0.005em;
  margin: 0;
  font-family: var(--font-serif);
}
.about-doryeong .doryeong-bar {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 12px;
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px dashed rgba(212, 175, 55, 0.15);
  font-size: 11.5px;
  color: var(--text-muted);
  letter-spacing: -0.005em;
  flex-wrap: wrap;
}
.about-doryeong .doryeong-bar .item {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.about-doryeong .doryeong-bar .num {
  color: var(--accent-gold-soft);
  font-weight: 700;
  font-family: var(--font-display);
}

/* ============================================================
   ☞ 방법론 배지 (별점 대체) — 상세페이지 · 4줄 single column
   ============================================================ */
.method-badges {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin: 20px 0 22px;
}
.method-badges .mb-item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(201, 162, 39, 0.25);
  border-radius: 10px;
  font-size: 14px;
  font-weight: 500;
  color: var(--text-primary, #FFFFFF);
  letter-spacing: -0.005em;
  line-height: 1.45;
}
.method-badges .mb-icon {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
  color: var(--accent-gold-soft, #C9A227);
  opacity: 0.95;
}

/* ============================================================
   ☞ 가격 비교 박스 — 가치 정당화
   ============================================================ */
.price-compare {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.10);
  border-radius: 10px;
  padding: 16px 16px 14px;
  margin: 14px 0 16px;
}
.price-compare .pc-title {
  font-family: var(--font-display);
  font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--accent-gold-soft, #C9A227);
  text-transform: uppercase;
  font-weight: 700;
  margin-bottom: 10px;
}
.price-compare .pc-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 7px 0;
  border-bottom: 1px dashed rgba(255, 255, 255, 0.08);
  font-size: 13px;
}
.price-compare .pc-row:last-of-type {
  border-bottom: none;
}
.price-compare .pc-label {
  color: var(--text-secondary, #B8B5AC);
  letter-spacing: -0.005em;
}
.price-compare .pc-amount {
  color: var(--text-muted, #8B8273);
  font-variant-numeric: tabular-nums;
  font-weight: 500;
}
.price-compare .pc-highlight {
  margin-top: 4px;
  padding: 12px 12px;
  background: rgba(196, 69, 54, 0.12);
  border: 1px solid rgba(196, 69, 54, 0.30);
  border-radius: 6px;
}
.price-compare .pc-highlight .pc-label,
.price-compare .pc-highlight .pc-amount {
  color: var(--text-primary, #FFFFFF);
}
.price-compare .pc-highlight .pc-amount strong {
  color: #FF8870;
  font-size: 15px;
  font-weight: 800;
}
.price-compare .pc-note {
  margin-top: 12px;
  font-size: 11.5px;
  color: var(--text-muted, #8B8273);
  font-style: italic;
  letter-spacing: -0.005em;
  text-align: center;
  line-height: 1.5;
}

/* ============================================================
   ☞ 적합도 체크리스트 (Part 2 — 사례 공통 5요소 진단)
   ============================================================ */
.adapt-checklist {
  background: var(--paper-card, #FBF8F2);
  border: 1px solid var(--ink-line, #D4CBB8);
  border-radius: 12px;
  padding: 18px 16px 16px;
}
.adapt-list {
  list-style: none;
  padding: 0;
  margin: 0 0 18px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.adapt-item {
  display: flex;
  gap: 14px;
  padding: 14px 14px;
  background: var(--paper-soft, #FAF7F0);
  border: 1px solid var(--ink-line, #D4CBB8);
  border-radius: 10px;
  border-left: 4px solid var(--ink-line, #D4CBB8);
}
.adapt-item.ok {
  border-left-color: var(--accent-celadon, #6B8A7A);
  background: rgba(107, 138, 122, 0.06);
}
.adapt-item.no {
  border-left-color: var(--accent-vermillion-soft, #D96A5E);
  background: rgba(196, 69, 54, 0.05);
}
.adapt-icon {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: 800;
  margin-top: 1px;
}
.adapt-item.ok .adapt-icon {
  background: var(--accent-celadon, #6B8A7A);
  color: #FFF8EE;
}
.adapt-item.no .adapt-icon {
  background: var(--paper-warm, #ECE4D2);
  color: var(--ink-muted, #8B8273);
}
.adapt-body { flex: 1; min-width: 0; }
.adapt-label {
  font-family: var(--font-display);
  font-size: 14.5px;
  font-weight: 700;
  color: var(--ink-primary, #2A2620);
  letter-spacing: -0.01em;
  margin-bottom: 3px;
}
.adapt-sub {
  font-size: 12px;
  color: var(--ink-muted, #8B8273);
  letter-spacing: -0.005em;
  margin-bottom: 8px;
}
.adapt-note {
  font-size: 13px;
  color: var(--ink-secondary, #5C5448);
  line-height: 1.6;
  letter-spacing: -0.005em;
  padding: 8px 10px;
  background: var(--paper-card, #FBF8F2);
  border-radius: 6px;
}
.adapt-item.ok .adapt-note { color: var(--ink-secondary, #5C5448); }
.adapt-item.no .adapt-note { color: var(--ink-secondary, #5C5448); }

.adapt-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px;
  background: var(--paper-warm, #ECE4D2);
  border-radius: 10px;
  gap: 12px;
}
.adapt-big {
  font-family: var(--font-display);
  font-size: 32px;
  font-weight: 800;
  color: var(--accent-vermillion, #C44536);
  letter-spacing: -0.03em;
  line-height: 1;
}
.adapt-big .adapt-of {
  font-size: 18px;
  color: var(--ink-muted, #8B8273);
  font-weight: 600;
  margin-left: 2px;
}
.adapt-pct {
  font-size: 13.5px;
  color: var(--ink-secondary, #5C5448);
  letter-spacing: -0.005em;
  text-align: right;
  line-height: 1.55;
}
.adapt-pct strong {
  display: block;
  font-size: 18px;
  font-weight: 800;
  color: var(--accent-vermillion, #C44536);
  letter-spacing: -0.02em;
  margin-top: 2px;
}

@media (max-width: 380px) {
  .adapt-summary { flex-direction: column; align-items: center; text-align: center; }
  .adapt-pct { text-align: center; }
}

/* ============================================================
   ☞ 통합 미리보기 + 결제 카드 (블러 대체)
   ============================================================ */
.paywall-card {
  background: linear-gradient(180deg, var(--paper-warm, #ECE4D2) 0%, #E0D5B8 100%);
  border: 2px solid var(--accent-vermillion-soft, #D96A5E);
  border-radius: 16px;
  padding: 28px 22px 24px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 24px rgba(196, 69, 54, 0.18), 0 0 0 1px rgba(196, 69, 54, 0.08);
}
.paywall-card .pwc-part {
  background: var(--paper-soft, #FAF7F0);
}
.paywall-card .pwc-part-teaser {
  background: rgba(43, 38, 32, 0.05);
}
.paywall-card .pwc-score {
  background: #FFFEF8;
  border: 1.5px solid var(--accent-vermillion-soft, #D96A5E);
}
.paywall-card * { font-family: var(--font-display) !important; }

/* Header */
.paywall-card .pwc-header {
  text-align: center;
  padding-bottom: 18px;
  border-bottom: 1px dashed var(--ink-line, #D4CBB8);
  margin-bottom: 18px;
}
.paywall-card .pwc-seal {
  display: inline-block;
  background: var(--accent-vermillion, #C44536);
  color: #FFF8EE;
  font-size: 13px;
  letter-spacing: 0.08em;
  padding: 6px 12px;
  border-radius: 4px;
  transform: rotate(-3deg);
  box-shadow: 0 2px 6px rgba(196,69,54,0.25);
  margin-bottom: 12px;
  font-weight: 700;
}
.paywall-card .pwc-tag {
  font-size: 11px;
  letter-spacing: 0.22em;
  color: var(--accent-vermillion, #C44536);
  text-transform: uppercase;
  font-weight: 700;
  margin-bottom: 8px;
}
.paywall-card .pwc-title {
  font-size: 22px;
  font-weight: 800;
  color: var(--ink-primary, #2A2620);
  letter-spacing: -0.02em;
  margin-bottom: 10px;
}
.paywall-card .pwc-lead {
  font-size: 13.5px;
  color: var(--ink-secondary, #5C5448);
  line-height: 1.8;
  letter-spacing: -0.005em;
  margin: 0;
}
.paywall-card .pwc-lead strong {
  color: var(--accent-vermillion, #C44536);
  font-weight: 800;
}

/* Score preview */
.paywall-card .pwc-score {
  background: var(--paper-soft, #FAF7F0);
  border: 1px solid var(--accent-vermillion-soft, #D96A5E);
  border-radius: 12px;
  padding: 18px 16px;
  text-align: center;
  margin-bottom: 22px;
}
.paywall-card .pwc-score-label {
  font-size: 11px;
  letter-spacing: 0.22em;
  color: var(--accent-seal-gold, #A07C2F);
  text-transform: uppercase;
  font-weight: 700;
  margin-bottom: 6px;
}
.paywall-card .pwc-score-value {
  font-size: 56px;
  font-weight: 800;
  color: var(--accent-vermillion, #C44536);
  letter-spacing: -0.04em;
  line-height: 1;
  margin-bottom: 6px;
}
.paywall-card .pwc-score-value .of {
  font-size: 18px;
  color: var(--ink-muted, #8B8273);
  font-weight: 400;
  margin-left: 2px;
}
.paywall-card .pwc-score-note {
  font-size: 12px;
  color: var(--ink-muted, #8B8273);
}

/* 6 Parts list */
.paywall-card .pwc-parts {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 22px;
}
.paywall-card .pwc-part {
  background: var(--paper-card, #FBF8F2);
  border: 1px solid var(--ink-line, #D4CBB8);
  border-left: 4px solid var(--accent-vermillion, #C44536);
  border-radius: 10px;
  padding: 14px 16px 12px;
}
.paywall-card .pwc-part-head {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}
.paywall-card .pwc-part-icon {
  font-size: 22px;
  line-height: 1;
}
.paywall-card .pwc-part-titles {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1;
}
.paywall-card .pwc-part-num {
  font-size: 10.5px;
  letter-spacing: 0.18em;
  color: var(--accent-vermillion, #C44536);
  text-transform: uppercase;
  font-weight: 700;
}
.paywall-card .pwc-part-title {
  font-size: 15.5px;
  font-weight: 800;
  color: var(--ink-primary, #2A2620);
  letter-spacing: -0.015em;
}
.paywall-card .pwc-part-items {
  list-style: none;
  padding: 0;
  margin: 0 0 10px;
}
.paywall-card .pwc-part-items li {
  position: relative;
  padding: 5px 0 5px 16px;
  font-size: 13px;
  line-height: 1.7;
  color: var(--ink-secondary, #5C5448);
  letter-spacing: -0.005em;
}
.paywall-card .pwc-part-items li::before {
  content: '✓';
  position: absolute;
  left: 0;
  top: 5px;
  color: var(--accent-celadon, #6B8A7A);
  font-weight: 700;
  font-size: 12px;
}
.paywall-card .pwc-part-teaser {
  padding: 10px 12px;
  background: var(--paper-warm, #ECE4D2);
  border-radius: 6px;
  font-size: 12.5px;
  color: var(--ink-secondary, #5C5448);
  line-height: 1.65;
  font-style: italic;
  letter-spacing: -0.005em;
}

/* Footer / CTA */
.paywall-card .pwc-footer {
  text-align: center;
  padding-top: 6px;
}
.paywall-card .pwc-stats {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  font-size: 12.5px;
  color: var(--ink-secondary, #5C5448);
  margin-bottom: 14px;
  flex-wrap: wrap;
}
.paywall-card .pwc-stats strong {
  color: var(--accent-vermillion, #C44536);
  font-weight: 800;
}
.paywall-card .pwc-stats .dot {
  color: var(--ink-line, #D4CBB8);
}
.paywall-card .pwc-price-row {
  display: flex;
  justify-content: center;
  align-items: baseline;
  gap: 10px;
  margin-bottom: 14px;
}
.paywall-card .pwc-orig {
  font-size: 14px;
  color: var(--ink-muted, #8B8273);
  text-decoration: line-through;
}
.paywall-card .pwc-now {
  font-size: 28px;
  color: var(--accent-vermillion, #C44536);
  font-weight: 800;
  letter-spacing: -0.02em;
}
.paywall-card .pwc-pct {
  font-size: 12px;
  font-weight: 700;
  background: var(--accent-vermillion, #C44536);
  color: #FFF8EE;
  padding: 3px 6px;
  border-radius: 4px;
}
.paywall-card .pwc-unlock-btn {
  background: linear-gradient(180deg, var(--accent-vermillion, #C44536) 0%, #9D3528 100%);
  color: #FFF8EE;
  border: none;
  padding: 16px 28px;
  border-radius: 10px;
  font-size: 16px;
  font-weight: 800;
  cursor: pointer;
  width: 100%;
  max-width: 340px;
  letter-spacing: -0.005em;
  box-shadow: 0 6px 18px rgba(196,69,54,0.35);
  margin-bottom: 10px;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.paywall-card .pwc-unlock-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 22px rgba(196,69,54,0.45);
}
.paywall-card .pwc-unlock-btn:active { transform: translateY(0); }
.paywall-card .pwc-fineprint {
  font-size: 11px;
  color: var(--ink-muted, #8B8273);
  line-height: 1.55;
}

@media (max-width: 480px) {
  .paywall-card { padding: 22px 16px 20px; }
  .paywall-card .pwc-title { font-size: 19px; }
  .paywall-card .pwc-score-value { font-size: 48px; }
  .paywall-card .pwc-now { font-size: 24px; }
}
