/* ════════════════════════════════════════════════════════════
   결 · Kyeol — 한지·박물관 톤 통합 테마 (paper-theme)
   적용 원칙: kyeol-master-tone.html 톤 코드 1:1 정렬
   - 베이지 한지 베이스, 검은 먹, 빨간 낙관, 명조 메인, 정관
   - 광고형 다크 → 박물관형 라이트로 전 섹션 전환
   ════════════════════════════════════════════════════════════ */

:root {
  /* === 액센트 (낙관 빨강) === */
  --terra:    #B8332B;
  --terra-dk: #8E2820;
  --terra-lt: rgba(184,51,43,0.08);
  --seal:     #B8332B;

  /* === 잉크 (검은 먹) === */
  --ink:   #0a0a0a;
  --body:  #2a2a2a;
  --mute:  #6b6b70;
  --light: rgba(10,10,10,0.18);

  /* === 한지 (종이) === */
  --bg:    #FAF6EC;
  --paper: #F4ECD8;
  --paper-dk: #EDE2C8;
  --card:  #FFFFFF;
  --cream: #F4ECD8;
  --dark:  #1a1a1a;
  --gold:  #B8893A;
  --silver: #6b6b70;

  --shadow:    0 1px 3px rgba(0,0,0,0.06), 0 6px 20px rgba(0,0,0,0.08);
  --shadow-lg: 0 2px 8px rgba(0,0,0,0.10), 0 16px 48px rgba(0,0,0,0.14);
  --glass-border: 1px solid rgba(10,10,10,0.08);
}

/* === 페이지 베이스 === */
body {
  background: var(--bg) !important;
  color: var(--body) !important;
  /* 한글 어절 단위 줄바꿈 — 음절 끊김 금지 (디자인 룰) */
  word-break: keep-all !important;
  overflow-wrap: break-word !important;
  line-break: strict;
}
/* 모든 텍스트 컨테이너 강제 적용 */
h1, h2, h3, h4, h5, h6,
p, li, span, a, button, label, em, strong, small,
.hero-headline, .hero-subhead, .sec-title, .sec-body,
.how-step-title, .how-step-desc, .how-step-note,
.bs-title, .bs-body,
.review-card, .review-text,
.bujok-rx-text, .bujok-summary, .bujok-closing-verse,
.relation-callout, .relation-callout-lead,
.footer-tagline-ko, .footer-by, .biz-list, .biz-list li {
  word-break: keep-all !important;
  overflow-wrap: break-word !important;
}

/* 노이즈 그레인은 라이트에서 너무 진하면 가독성 해침 → 약하게 */
body::after {
  opacity: 0.03 !important;
  mix-blend-mode: multiply;
}

h1, h2, h3, .hero-headline, .sec-title, .bs-title { color: var(--ink); }

/* === HEADER === */
.site-header {
  background: rgba(250, 246, 236, 0.92) !important;
  border-bottom: 1px solid rgba(10,10,10,0.08) !important;
}
.header-logo { color: var(--ink) !important; }
.header-sub  { color: var(--mute) !important; border-left-color: rgba(10,10,10,0.10) !important; }
.beta-header-badge { color: var(--seal) !important; border-color: var(--seal) !important; }
.beta-uses-badge {
  color: #8E5A14 !important;
  background: rgba(184,137,58,0.10) !important;
  border-color: rgba(184,137,58,0.25) !important;
}
.b2b-header-btn { color: #8E5A14 !important; border-color: var(--gold) !important; }
.b2b-header-btn:hover { background: var(--gold) !important; color: #fff !important; }
.invite-header-btn { background: linear-gradient(135deg, var(--seal), var(--gold)) !important; color: #fff !important; }

/* === 베타 모달 === */
.beta-overlay { background: rgba(10,10,10,0.55) !important; }
.beta-modal {
  background: #FFFFFF !important;
  border: 1px solid rgba(10,10,10,0.10) !important;
  box-shadow: 0 0 80px rgba(184,51,43,0.10), 0 24px 64px rgba(0,0,0,0.20) !important;
}
.beta-modal-title { color: var(--ink) !important; }
.beta-modal-desc  { color: var(--body) !important; }
.beta-modal-desc strong { color: var(--seal) !important; }
.beta-input {
  background: #FCFAF2 !important;
  border: 1px solid rgba(10,10,10,0.14) !important;
  color: var(--ink) !important;
}
.beta-input:focus { border-color: var(--seal) !important; }
.beta-input::placeholder { color: var(--mute) !important; }
.beta-submit-btn { background: var(--seal) !important; color: #fff !important; }
.beta-submit-btn:hover { background: var(--terra-dk) !important; }
.beta-privacy { color: var(--mute) !important; }
.invite-link-box {
  background: #FCFAF2 !important;
  border-color: rgba(10,10,10,0.10) !important;
}
.invite-link-text { color: var(--seal) !important; }
.invite-copy-btn { background: var(--seal) !important; color: #fff !important; }
.invite-share-copy {
  background: rgba(10,10,10,0.06) !important;
  border-color: rgba(10,10,10,0.10) !important;
  color: var(--ink) !important;
}
.invite-share-copy:hover { background: rgba(10,10,10,0.10) !important; }
.reward-item {
  background: #FCFAF2 !important;
  border-color: rgba(10,10,10,0.08) !important;
}
.reward-title { color: var(--ink) !important; }
.reward-desc  { color: var(--mute) !important; }
.reward-badge { background: var(--seal) !important; color: #fff !important; }
.invite-close { color: var(--mute) !important; }
.invite-stats { color: var(--mute) !important; }
.invite-stats strong { color: var(--seal) !important; }

/* === HERO (이미 fullbleed beige — 미세조정만) === */
.hero-section.hero-fullbleed {
  background: var(--paper) !important;
  /* 결 글자가 잘리지 않도록 충분한 높이 확보 */
  min-height: 720px !important;
  height: 100vh !important;
}
/* 영상은 contain — 결 글자 마지막 획까지 보이게 */
.hero-section.hero-fullbleed .hero-bg-video {
  object-fit: contain !important;
  object-position: center 60% !important;
}
.hero-section::before { display: none !important; }  /* 다크 라디얼 그라데이션 제거 */
.hero-bg-video { background: var(--paper) !important; }

/* CTA 바 — 한지 톤에 더 자연스럽게 */
.hero-cta-bar {
  background: rgba(250, 246, 236, 0.85) !important;
  border: 1px solid rgba(10,10,10,0.08) !important;
}
.hero-cta-bar .btn-start { background: var(--seal) !important; color: #fff !important; }
.hero-cta-bar .btn-start:hover { background: var(--terra-dk) !important; }
.btn-ghost-paper {
  background: rgba(10,10,10,0.04) !important;
  color: var(--ink) !important;
  border-color: rgba(10,10,10,0.10) !important;
}
.hero-scroll-hint .line, .hero-scroll-hint .arrow { background: var(--ink); color: var(--ink); }

/* 마퀴 톤 다운 */
.hero-marquee {
  border-top: 1px solid rgba(10,10,10,0.06) !important;
  border-bottom: 1px solid rgba(10,10,10,0.06) !important;
}

/* === ABOUT-SECTION (Why I built / How to use) === */
.about-section { background: var(--bg) !important; }
.sec-overline { color: var(--mute) !important; }
.sec-overline::before { background: var(--seal) !important; }
.sec-title em { color: var(--seal) !important; }
.sec-body, .sec-body p { color: var(--body) !important; }
.sec-body strong { color: var(--ink) !important; }
.relation-callout {
  background: var(--paper) !important;
  border: 1px solid rgba(10,10,10,0.08) !important;
  border-left: 4px solid var(--seal) !important;
  color: var(--body) !important;
}
.relation-callout-lead { color: var(--ink) !important; }
.relation-callout strong { color: var(--seal) !important; }
.about-divider { background: rgba(10,10,10,0.10) !important; }

/* How steps */
.how-step-item {
  background: #FFFFFF !important;
  border: 1px solid rgba(10,10,10,0.08) !important;
}
.how-step-num { color: var(--seal) !important; }
.how-step-title { color: var(--ink) !important; }
.how-step-desc { color: var(--body) !important; }
.how-step-note { color: var(--mute) !important; }
.how-step-arrow { color: var(--seal) !important; }

/* === REVIEWS LANDING === */
.reviews-landing-section { background: var(--paper) !important; }
.review-landing-card {
  background: #FFFFFF !important;
  border: 1px solid rgba(10,10,10,0.08) !important;
  box-shadow: var(--shadow);
}
.review-landing-card .review-text { color: var(--body) !important; }
.review-landing-card .review-meta { color: var(--mute) !important; }
.review-stars { color: var(--seal) !important; }
.review-type-badge { color: #fff !important; }
.review-type-badge.rl-romantic { background: #B8332B !important; }
.review-type-badge.rl-family   { background: #8E5A14 !important; }
.review-type-badge.rl-work     { background: #2a4d3a !important; }
.review-type-badge.rl-friend   { background: #4a3a6e !important; }

/* === BRAND STORY === */
.brand-story-section { background: var(--bg) !important; }
.bs-kicker { color: var(--mute) !important; }
.bs-title em { color: var(--seal) !important; }
.bs-chapter { border-bottom: 1px solid rgba(10,10,10,0.08) !important; }
.bs-ch-num { color: var(--seal) !important; }
.bs-ch-content h3 { color: var(--ink) !important; }
.bs-ch-content p  { color: var(--body) !important; }
.bs-ch-content strong { color: var(--seal) !important; }
.bs-quote {
  background: var(--paper) !important;
  border-left: 4px solid var(--seal) !important;
  color: var(--body) !important;
  font-family: 'Gowun Batang', serif;
}

/* === APP DIVIDER === */
.app-divider {
  border-color: rgba(10,10,10,0.10) !important;
  background: rgba(10,10,10,0.10) !important;
}

/* === APP SECTION (사주 등록·관계 카드 등) === */
.app-section { background: var(--bg) !important; }
.my-profile-card {
  background: #FFFFFF !important;
  border: 1px solid rgba(10,10,10,0.08) !important;
  color: var(--ink) !important;
}
.my-profile-name { color: var(--ink) !important; }
.my-profile-detail { color: var(--mute) !important; }
.no-profile-banner {
  background: var(--paper) !important;
  border: 1px solid rgba(10,10,10,0.10) !important;
  color: var(--body) !important;
}
.couple-list .couple-card,
.couple-card {
  background: #FFFFFF !important;
  border: 1px solid rgba(10,10,10,0.08) !important;
  color: var(--ink) !important;
  box-shadow: var(--shadow);
}
.couple-card .meta, .couple-card .desc { color: var(--mute) !important; }
.couple-card:hover { border-color: var(--seal) !important; }

/* === 등록·세팅 뷰 === */
#view-register, #view-my-setup, #view-dashboard {
  background: var(--bg) !important;
  color: var(--ink) !important;
}
input[type="text"], input[type="date"], input[type="number"], input[type="email"],
select, textarea {
  background: #FFFFFF !important;
  border: 1px solid rgba(10,10,10,0.14) !important;
  color: var(--ink) !important;
}
input:focus, select:focus, textarea:focus { border-color: var(--seal) !important; }
input::placeholder, textarea::placeholder { color: var(--mute) !important; }
label { color: var(--body) !important; }

/* 단계 / 역할 버튼 */
.stage-buttons button, .role-buttons button,
.btn-stage, .btn-role {
  background: #FFFFFF !important;
  border: 1px solid rgba(10,10,10,0.10) !important;
  color: var(--ink) !important;
}
.stage-buttons button.selected, .role-buttons button.selected,
.btn-stage.selected, .btn-role.selected {
  background: var(--seal) !important;
  color: #fff !important;
  border-color: var(--seal) !important;
}

/* 주요 버튼 */
.btn-primary {
  background: var(--seal) !important;
  color: #fff !important;
  border: none !important;
}
.btn-primary:hover { background: var(--terra-dk) !important; }
.btn-back, .btn-secondary {
  background: rgba(10,10,10,0.05) !important;
  color: var(--ink) !important;
  border: 1px solid rgba(10,10,10,0.10) !important;
}
.btn-back:hover, .btn-secondary:hover { background: rgba(10,10,10,0.08) !important; }

/* === 대운 / 삶 흐름 (lifecycle) === */
.lifecycle-section { background: var(--bg) !important; }
.lifecycle-section .section-title { color: var(--ink) !important; }
.lc-card, .lifecycle-card {
  background: #FFFFFF !important;
  border: 1px solid rgba(10,10,10,0.08) !important;
}
.lc-period, .daewoon-cell {
  background: #FCFAF2 !important;
  border: 1px solid rgba(10,10,10,0.10) !important;
  color: var(--body) !important;
}
.lc-period.current, .daewoon-cell.current {
  background: rgba(184,51,43,0.08) !important;
  border-color: var(--seal) !important;
  color: var(--ink) !important;
}
.lc-summary, [id^="lc-summary"] {
  background: var(--paper) !important;
  color: var(--body) !important;
  border: 1px solid rgba(10,10,10,0.08) !important;
}
[id^="lc-btn"] {
  background: rgba(10,10,10,0.05) !important;
  color: var(--ink) !important;
  border: 1px solid rgba(10,10,10,0.12) !important;
}
[id^="lc-btn"]:hover { background: rgba(184,51,43,0.10) !important; border-color: var(--seal) !important; color: var(--seal) !important; }

/* === 분석 결과·도사 === */
.dosha-wrap { background: transparent !important; }
.dosha-bubble {
  background: #FFFFFF !important;
  border: 1px solid rgba(10,10,10,0.10) !important;
  color: var(--body) !important;
}
.compat-result, .compat-section {
  background: #FFFFFF !important;
  border: 1px solid rgba(10,10,10,0.08) !important;
  color: var(--body) !important;
}
.compat-result h2, .compat-result h3 { color: var(--ink) !important; }
.compat-result .score-num { color: var(--seal) !important; }

/* 부적 CTA */
.bujok-cta-section {
  background: var(--paper) !important;
  border: 1px solid rgba(10,10,10,0.10) !important;
}
.bujok-cta-title { color: var(--ink) !important; }
.bujok-cta-desc  { color: var(--body) !important; }
.bujok-cta-badge { color: var(--seal) !important; }
.bujok-cta-btn { background: var(--seal) !important; color: #fff !important; }
.bujok-cta-btn:hover { background: var(--terra-dk) !important; }
.bujok-cta-stamp { color: var(--seal) !important; }

/* === 푸터 === */
.site-footer, footer {
  background: var(--paper) !important;
  border-top: 1px solid rgba(10,10,10,0.10) !important;
  color: var(--body) !important;
}
.site-footer a { color: var(--seal) !important; }

/* === 일반 .glass·rgba 흰색 흔적 정리 === */
.glass {
  background: #FFFFFF !important;
  border: 1px solid rgba(10,10,10,0.08) !important;
  box-shadow: var(--shadow) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

/* 다른 곳에 남은 dark 패턴 일괄 잡기 — 안전한 범위에서만 */
[style*="background: rgba(255,255,255"],
[style*="background:#0c0a18"],
[style*="background: #0c0a18"],
[style*="background:#0b0b0d"],
[style*="background: #0b0b0d"] {
  background: var(--paper) !important;
}

/* 부적 모달 등 일부 오버레이 */
.bujok-gun-modal, .bujok-final-modal, .gun-options button, .gun-option {
  background: #FFFFFF !important;
  border: 1px solid rgba(10,10,10,0.10) !important;
  color: var(--ink) !important;
}
.gun-option .gun-name { color: var(--ink) !important; }
.gun-option .gun-desc { color: var(--mute) !important; }
.gun-option:hover { border-color: var(--seal) !important; background: rgba(184,51,43,0.04) !important; }
.gun-option.selected { background: rgba(184,51,43,0.08) !important; border-color: var(--seal) !important; }

/* 카테고리·태그 잔존 (혹시 남아있다면) */
.cat-btn {
  background: rgba(10,10,10,0.05) !important;
  border: 1px solid rgba(10,10,10,0.10) !important;
  color: var(--ink) !important;
}
.cat-btn.selected { background: var(--seal) !important; color: #fff !important; }

/* === 모바일 보조 카피·로딩 === */
.hero-mobile-copy {
  background: rgba(244,236,216,0.8) !important;
  color: var(--ink) !important;
}
.loading-spinner-overlay, .saju-loading {
  background: rgba(250,246,236,0.95) !important;
  color: var(--ink) !important;
}

/* ════════════════════════════════════════════════════════════
   디자인팀 검수 1차 (박지현 팀장) 누수 보강 — 2026-04-26
   ════════════════════════════════════════════════════════════ */

/* brand-story: 명조 통일 + H3 색·크기 보강 (P10 60대 가독성) */
.bs-title, .bs-quote, .bs-ch-content h3 {
  font-family: 'Gowun Batang', 'Noto Serif KR', serif !important;
  color: var(--ink) !important;
}
.bs-ch-content p {
  font-size: 1rem !important;
  line-height: 1.85 !important;
  color: var(--body) !important;
}
.bs-quote {
  color: var(--body) !important;
  border-left-color: var(--seal) !important;
}

/* app-divider 다크 그라데이션 잔존 → 단색 */
.app-divider, hr.app-divider {
  background-image: none !important;
  background: rgba(10,10,10,0.10) !important;
  border: none !important;
  height: 1px;
}

/* invite·beta 잔존 다크 누수 */
.invite-header-btn { background: var(--seal) !important; }
.beta-modal-badge { background: var(--seal) !important; color: #fff !important; border: none !important; }
.invite-share-copy { color: var(--ink) !important; }

/* 헤더 산세리프(Bricolage) → 명조 유지하되 logo만 산세리프 (마스터 톤) */
.beta-modal-title { font-family: 'Gowun Batang', 'Noto Serif KR', serif !important; }
.sec-title { font-family: 'Gowun Batang', 'Noto Serif KR', serif !important; }

/* P10 가독성 — 작은 글씨 페르소나별 보강 */
.hero-sub, .review-text, .how-step-desc {
  font-size: 0.95rem !important;
}

/* 히어로 서브라벨 (실용형 페르소나 컨텍스트 보강) */
.hero-sublabel {
  position: absolute;
  left: 50%; bottom: 142px;
  transform: translateX(-50%) translateY(8px);
  display: flex; align-items: center; gap: 12px;
  z-index: 4;
  opacity: 0;
  transition: opacity 0.8s ease, transform 0.8s ease;
  white-space: nowrap;
}
.hero-sublabel.is-visible {
  opacity: 0.78;
  transform: translateX(-50%) translateY(0);
}
.hero-sublabel-text {
  font-family: 'Gowun Batang', 'Noto Serif KR', serif;
  font-size: 13px;
  letter-spacing: 4px;
  color: #1a1a1a;
}
.hero-sublabel-line {
  width: 28px; height: 1px;
  background: #1a1a1a;
  opacity: 0.5;
}
@media (max-width: 700px) {
  .hero-sublabel { bottom: 156px; }
  .hero-sublabel-text { font-size: 11px; letter-spacing: 2px; }
  .hero-sublabel-line { width: 16px; }
}
@media (max-width: 480px) {
  .hero-sublabel-text { font-size: 10px; }
}

/* iOS Safari — bottom safe-area + 동적 viewport 보정 */
@supports (padding: env(safe-area-inset-bottom)) {
  @media (max-width: 600px) {
    .hero-cta-bar {
      padding-bottom: calc(8px + env(safe-area-inset-bottom)) !important;
      bottom: calc(12px + env(safe-area-inset-bottom)) !important;
    }
  }
}
@supports (height: 100dvh) {
  .hero-section.hero-fullbleed { height: 100dvh; }
}

/* ════════════════════════════════════════════════════════════
   디자인팀 검수 2차 — 사주 비교카드 & 푸터 가독성 (2026-04-26)
   문제: 다크브라운 카드 + 검정 텍스트(paper-theme --ink) → 라벨 invisible
        푸터 opacity .25~.30 → 텍스트 사라짐
   ════════════════════════════════════════════════════════════ */

/* === 사주 비교 카드 — 한지 화이트로 통일 === */
.saju-card {
  background: #FFFFFF !important;
  border: 1px solid rgba(10,10,10,0.10) !important;
  box-shadow: var(--shadow) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}
.saju-card .person-name { color: var(--ink) !important; }
.saju-card .person-name small { color: var(--mute) !important; }
.saju-card .birth-info {
  color: var(--mute) !important;
  font-size: 0.88rem !important;
}
.saju-card .lunar-info { color: var(--seal) !important; opacity: 1 !important; }
.saju-card .pillar { color: var(--mute) !important; }
.saju-card .pillar b { color: var(--ink) !important; }
.saju-card .pillar b[style*="color:#ccc"] { color: var(--mute) !important; }

/* 카드 편집 버튼 — 라이트 톤으로 */
.card-edit-btn {
  background: rgba(10,10,10,0.04) !important;
  border: 1px solid rgba(10,10,10,0.12) !important;
  color: var(--mute) !important;
}
.card-edit-btn:hover {
  background: rgba(184,51,43,0.06) !important;
  border-color: var(--seal) !important;
  color: var(--seal) !important;
}

/* 두 카드 사이 vs 디바이더 — 라이트 배경에서 보이게 */
.vs-divider { color: var(--mute) !important; opacity: 0.6; }

/* 오행 칩 — 라이트 배경에서 콘트라스트 보강 */
.ohaeng-금 { background: rgba(107,107,112,0.12) !important; color: #5a5a60 !important; }

/* 본인 프로필 카드(상단) — 한지 톤 통일 */
.my-profile-card {
  background: #FFFFFF !important;
  border: 1px solid rgba(10,10,10,0.10) !important;
}
.my-profile-name { color: var(--ink) !important; }
.my-profile-detail { color: var(--mute) !important; }
.my-profile-label { color: var(--seal) !important; opacity: 1 !important; }
.my-profile-card .btn-back { color: var(--mute) !important; }

/* === 푸터 — 한지 톤 + 가독성 복원 === */
.site-footer {
  background: var(--paper) !important;
  color: var(--body) !important;
  border-top: 1px solid rgba(10,10,10,0.10) !important;
}
.footer-logo {
  color: var(--ink) !important;
  font-family: 'Gowun Batang', 'Noto Serif KR', serif !important;
}
.footer-tagline {
  color: var(--ink) !important;
  opacity: 1 !important;
  font-family: 'Gowun Batang', 'Noto Serif KR', serif !important;
}
.footer-tagline-ko {
  color: var(--body) !important;
  opacity: 1 !important;
  font-family: 'Gowun Batang', 'Noto Serif KR', serif !important;
}
.footer-by { color: var(--mute) !important; opacity: 1 !important; }
.footer-email a { color: var(--seal) !important; font-weight: 600 !important; }
.footer-privacy h4 { color: var(--mute) !important; opacity: 1 !important; }
.footer-privacy li { color: var(--body) !important; opacity: 1 !important; }
.footer-privacy li::before { color: var(--seal) !important; }
.footer-bottom {
  color: var(--mute) !important;
  border-top-color: rgba(10,10,10,0.10) !important;
}

/* ════════════════════════════════════════════════════════════
   디자인팀 검수 3차 — 폼 카드 가독성 + 선택 버튼 강조 (2026-04-26)
   ════════════════════════════════════════════════════════════ */

/* === 새 관계 추가 폼 카드 — 한지 화이트 === */
.form-card {
  background: #FFFFFF !important;
  border: 1px solid rgba(10,10,10,0.10) !important;
  box-shadow: var(--shadow) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}
.person-form h3 {
  color: var(--ink) !important;
  font-size: 0.92rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.5px !important;
  text-transform: none !important;
  font-family: 'Gowun Batang', 'Noto Serif KR', serif !important;
}
.person-form label,
.stage-select > label {
  color: var(--body) !important;
  font-size: 0.82rem !important;
  font-weight: 600 !important;
}
.person-form input,
.person-form select {
  background: #FCFAF2 !important;
  border: 1px solid rgba(10,10,10,0.14) !important;
  color: var(--ink) !important;
}
.person-form input:focus,
.person-form select:focus {
  border-color: var(--seal) !important;
  box-shadow: 0 0 0 3px rgba(184,51,43,0.10) !important;
  background: #FFFFFF !important;
}

/* 페이지 헤더 (← 뒤로 / 새 관계 추가) */
.page-header h2 { color: var(--ink) !important; }
.btn-edit-couple {
  background: rgba(10,10,10,0.04) !important;
  border: 1px solid rgba(10,10,10,0.12) !important;
  color: var(--mute) !important;
}
.btn-edit-couple:hover {
  background: rgba(184,51,43,0.06) !important;
  border-color: var(--seal) !important;
  color: var(--seal) !important;
}

/* === 관계 유형/단계 버튼 — 선택 시 확실히 강조 (모바일 가독성) === */
.rel-type-btn {
  background: #FFFFFF !important;
  border: 1.5px solid rgba(10,10,10,0.15) !important;
  color: var(--body) !important;
  font-weight: 600 !important;
}
.rel-type-btn:hover:not(.active) {
  background: rgba(184,51,43,0.06) !important;
  border-color: var(--seal) !important;
  color: var(--seal) !important;
}
.rel-type-btn.active {
  background: var(--seal) !important;
  color: #FFFFFF !important;
  border-color: var(--seal) !important;
  font-weight: 700 !important;
  box-shadow: 0 4px 12px rgba(184,51,43,0.30) !important;
  transform: scale(1.03);
}

.stage-btn {
  background: #FFFFFF !important;
  border: 1.5px solid rgba(10,10,10,0.15) !important;
  color: var(--body) !important;
  font-weight: 600 !important;
}
.stage-btn:hover:not(.active) {
  background: rgba(184,51,43,0.06) !important;
  border-color: var(--seal) !important;
  color: var(--seal) !important;
}
.stage-btn.active {
  background: var(--seal) !important;
  color: #FFFFFF !important;
  border-color: var(--seal) !important;
  font-weight: 700 !important;
  box-shadow: 0 4px 12px rgba(184,51,43,0.30) !important;
  transform: scale(1.03);
}

/* 모바일 — 선택 시 더 큰 강조 (44px 터치 + 또렷한 배경) */
@media (max-width: 700px) {
  .rel-type-btn,
  .stage-btn {
    min-height: 44px !important;
    font-size: 0.92rem !important;
  }
  .rel-type-btn.active,
  .stage-btn.active {
    transform: scale(1.05);
    box-shadow: 0 6px 16px rgba(184,51,43,0.40) !important;
  }
}

/* ════════════════════════════════════════════════════════════
   디자인팀 검수 4차 — 검증해 통합 패치 (2026-04-26)
   히어로 헤드라인 노출 / 궁합 결과 가독성 / 오행 칩 라이트 / 풋터 운영정보
   ════════════════════════════════════════════════════════════ */

/* === 히어로 헤드라인 — 붓글씨 영상 영역 위쪽으로 완전 분리 === */
.hero-headline-overlay {
  position: absolute;
  left: 50%;
  top: 7%;
  transform: translate(-50%, 0);
  z-index: 5;
  text-align: center;
  width: 88%;
  max-width: 760px;
  pointer-events: none;
  text-shadow: 0 2px 24px rgba(244,236,216,0.95), 0 1px 2px rgba(244,236,216,0.95);
}
.hero-headline {
  font-family: 'Gowun Batang', 'Noto Serif KR', serif !important;
  font-size: clamp(1.6rem, 4vw, 2.6rem) !important;
  font-weight: 700 !important;
  color: #0a0a0a !important;
  line-height: 1.3 !important;
  letter-spacing: -0.5px !important;
  margin: 0 0 12px !important;
  word-break: keep-all !important;
}
.hero-subhead {
  font-family: 'Gowun Batang', 'Noto Serif KR', serif !important;
  font-size: clamp(0.95rem, 2.2vw, 1.15rem) !important;
  color: #2a2a2a !important;
  margin: 0 !important;
  font-weight: 500;
}
@media (max-width: 700px) {
  .hero-headline-overlay {
    top: 12%;
    width: 92%;
  }
  .hero-headline { font-size: 1.75rem !important; }
  .hero-subhead { font-size: 0.9rem !important; }
}

/* === 헤더 로고 영문(kyeol) — 풋터 Bricolage 톤과 동일 === */
.header-logo .logo-en {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--mute);
  letter-spacing: 0.5px;
  margin-left: 8px;
  padding-left: 8px;
  border-left: 1px solid rgba(10,10,10,0.12);
  text-transform: lowercase;
  position: relative;
  top: -1px;
}
@media (max-width: 700px) {
  .header-logo .logo-en {
    font-size: 0.72rem;
    margin-left: 6px;
    padding-left: 6px;
  }
}

/* === 궁합 결과 텍스트 가독성 (라이트 배경에 라이트 텍스트 잔존 fix) === */
.score-display {
  border-bottom-color: rgba(10,10,10,0.10) !important;
}
.score-number {
  color: var(--seal) !important;
  font-family: 'Gowun Batang', 'Noto Serif KR', serif !important;
}
.score-label {
  color: var(--mute) !important;
}
.compat-text {
  color: var(--body) !important;
}
.compat-text h1, .compat-text h2, .compat-text h3 {
  color: var(--ink) !important;
}
.compat-text h2 {
  border-bottom-color: rgba(10,10,10,0.12) !important;
}
.compat-text strong, .h-answer strong, .answer-box strong {
  color: var(--ink) !important;
}
.compat-text em {
  color: var(--mute) !important;
}
.compat-text hr, .answer-box hr {
  border-top-color: rgba(10,10,10,0.12) !important;
}
.h-answer {
  border-color: rgba(10,10,10,0.10) !important;
  background: #FFFFFF !important;
}
.answer-box {
  background: #FFFFFF !important;
  border: 1px solid rgba(10,10,10,0.10) !important;
}

/* === 오행 칩 — 라이트 배경 콘트라스트 보강 === */
.ohaeng-목 {
  background: rgba(46,125,50,0.12) !important;
  color: #1f6b3f !important;
}
.ohaeng-화 {
  background: rgba(184,51,43,0.10) !important;
  color: #8E2820 !important;
}
.ohaeng-토 {
  background: rgba(193,124,55,0.14) !important;
  color: #8a541b !important;
}
.ohaeng-수 {
  background: rgba(21,101,192,0.12) !important;
  color: #1452a0 !important;
}

/* === 풋터 운영정보 블록 (검증해 P0 — 법정 정보) === */
.footer-business h4 {
  font-size: 0.72rem !important;
  font-weight: 700 !important;
  letter-spacing: 1.5px !important;
  text-transform: uppercase !important;
  color: var(--mute) !important;
  margin-bottom: 12px !important;
}
.footer-business ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.footer-business li {
  font-size: 0.78rem !important;
  color: var(--body) !important;
  line-height: 1.6;
}
.footer-business .biz-label {
  display: inline-block;
  min-width: 64px;
  color: var(--mute);
  font-weight: 600;
  margin-right: 8px;
}
.footer-business a {
  color: var(--seal) !important;
  text-decoration: none;
  font-weight: 500;
}
.footer-business a:hover { text-decoration: underline; }

.footer-legal-links {
  margin-top: 14px;
  font-size: 0.82rem;
  display: flex;
  align-items: center;
  gap: 8px;
}
.footer-legal-links a {
  color: var(--seal) !important;
  text-decoration: none;
  font-weight: 500;
}
.footer-legal-links a:hover { text-decoration: underline; }
.footer-legal-links span { color: var(--mute); }

/* ════════════════════════════════════════════════════════════
   부적 카드 — 한지·붉은 낙관 강화 (2026-04-26 부적스러움 보강)
   ════════════════════════════════════════════════════════════ */

/* 부적 모달 배경 — 어두운 한지 무드 */
#bujok-overlay {
  background: radial-gradient(ellipse at center, rgba(40,20,10,0.85), rgba(10,5,2,0.95)) !important;
}

/* 부적 카드 — 한지 결 텍스처 강화 */
.bujok-card {
  background:
    radial-gradient(ellipse at 30% 20%, rgba(255,240,210,0.6), transparent 60%),
    radial-gradient(ellipse at 70% 80%, rgba(220,180,120,0.4), transparent 55%),
    linear-gradient(180deg, #f3e4c0 0%, #ead2a4 100%) !important;
  border-radius: 4px !important;
  box-shadow:
    0 0 0 1px rgba(120,60,20,0.5),
    inset 0 0 60px rgba(180,120,40,0.18),
    0 0 80px rgba(196,154,42,0.4),
    0 24px 80px rgba(0,0,0,0.85) !important;
}

/* 한지 섬유 결 */
.bujok-card::before {
  background:
    repeating-linear-gradient(0deg, transparent 0, transparent 1px,
      rgba(140,80,20,0.06) 1px, rgba(140,80,20,0.06) 2px),
    repeating-linear-gradient(90deg, transparent 0, transparent 3px,
      rgba(160,100,20,0.04) 3px, rgba(160,100,20,0.04) 4px) !important;
}

/* 외곽 이중 테두리 강화 */
.bujok-border {
  inset: 10px !important;
  border: 2px double rgba(139,26,26,0.55) !important;
  border-radius: 2px !important;
}
.bujok-border::before {
  inset: 6px !important;
  border: 1px solid rgba(139,26,26,0.25) !important;
}

/* 메인 한자 — 더 굵게, 먹 느낌 */
.bujok-main-char {
  font-family: 'Gowun Batang', 'Noto Serif KR', serif !important;
  font-size: 76px !important;
  font-weight: 900 !important;
  color: #1a0a05 !important;
  text-shadow:
    0 1px 0 rgba(255,255,255,0.3),
    0 2px 8px rgba(139,26,26,0.25),
    0 0 30px rgba(139,26,26,0.15) !important;
  letter-spacing: 0;
  line-height: 1 !important;
  margin: 4px 0 8px;
}

/* 오행 4글자 — 격조 강화 */
.bujok-ohaeng-row {
  font-family: 'Gowun Batang', 'Noto Serif KR', serif !important;
  font-size: 22px !important;
  color: #5a1a10 !important;
  letter-spacing: 12px !important;
  font-weight: 600 !important;
  opacity: 1 !important;
}

/* 도장 원형 — 더 진한 인주 */
.bujok-stamp-circle {
  border: 2.5px solid #6b1414 !important;
  background: rgba(139,26,26,0.05);
  color: #6b1414 !important;
  font-family: 'Gowun Batang', serif !important;
  box-shadow:
    inset 0 0 0 1px rgba(139,26,26,0.2),
    0 1px 3px rgba(139,26,26,0.3);
}

/* 三 줄 요약 박스 */
.bujok-summary {
  position: relative;
  z-index: 3;
  padding: 14px 28px 8px;
  text-align: center;
}
.bujok-summary-line {
  font-family: 'Gowun Batang', 'Noto Serif KR', serif;
  font-size: 13.5px;
  color: #3a1a08;
  line-height: 1.7;
  letter-spacing: 0.3px;
  font-weight: 500;
  word-break: keep-all;
  overflow-wrap: break-word;
}
.bujok-summary-line + .bujok-summary-line {
  margin-top: 2px;
}
.bujok-summary-mark {
  color: #8b1a1a;
  margin-right: 8px;
  font-weight: 900;
}

/* 처방 — 한 문장 짧게 */
.bujok-rx-text {
  font-family: 'Gowun Batang', 'Noto Serif KR', serif !important;
  font-size: 12.5px !important;
  color: #3a1a08 !important;
  line-height: 1.65 !important;
  word-break: keep-all !important;
  overflow-wrap: break-word !important;
}
.bujok-rx-text strong {
  color: #6b1414 !important;
  letter-spacing: 0.5px;
}
.bujok-rx-num {
  border: 1.5px solid rgba(107,20,20,0.6) !important;
  color: #6b1414 !important;
  font-family: 'Gowun Batang', serif !important;
  font-weight: 700 !important;
}

/* 마무리 시구 — 가독성 */
.bujok-closing-verse {
  font-family: 'Gowun Batang', 'Noto Serif KR', serif !important;
  font-size: 12px !important;
  color: rgba(58,26,8,0.85) !important;
  word-break: keep-all !important;
}

/* 인장 — 더 진하게 */
.bujok-sign-seal {
  border: 2.5px solid #6b1414 !important;
  color: #6b1414 !important;
  background: rgba(139,26,26,0.06);
  font-family: 'Gowun Batang', serif !important;
  box-shadow: 0 1px 4px rgba(139,26,26,0.25);
}

/* 구분선 텍스트 한자 강조 */
.bujok-divider-line span {
  font-family: 'Gowun Batang', serif !important;
  background: linear-gradient(180deg, #f3e4c0, #ead2a4) !important;
  color: rgba(107,20,20,0.7) !important;
  font-weight: 600;
}
