/* ==========================================================
   사주 × MBTI — DinoLab Pixel Aesthetic
   ========================================================== */

@import url('https://fonts.googleapis.com/css2?family=Press+Start+2P&family=Noto+Serif+KR:wght@300;400;500;600;700&family=Noto+Sans+KR:wght@300;400;500;700&family=Gowun+Batang:wght@400;700&family=Gaegu:wght@400;700&family=Nanum+Pen+Script&display=swap');

/* 메인 히어로 타이틀 한정 한글 픽셀 폰트 (Galmuri14, OFL) */
@font-face {
  font-family: 'Galmuri14';
  src: url('https://cdn.jsdelivr.net/gh/quiple/galmuri@latest/dist/Galmuri14.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

:root {
  --bg: #f4f3ef;
  --surface: #ffffff;
  --surface2: #f9f9f6;
  --pink: #ff2d78;
  --pink-bg: #ff2d78;
  --black: #111111;
  --text: #111111;
  --subtext: #666666;
  --border: #111111;
  --gold: #f0c040;
  --purple: #9b8ff0;
  --green: #22c564;
  --pixel: 'Press Start 2P', monospace;
  --serif: 'Noto Serif KR', serif;
  --sans: 'Noto Sans KR', sans-serif;
  --shadow: 4px 4px 0 #111111;
  --shadow-sm: 2px 2px 0 #111111;
  --shadow-pink: 4px 4px 0 #ff2d78;
  --shadow-gold: 4px 4px 0 #f0c040;

  /* Compatibility aliases for legacy inline styles in app.js */
  --gold-light: #f0c040;
  --border-soft: rgba(17,17,17,0.12);
  --radius: 0px;
  --radius-sm: 0px;
  --radius-lg: 0px;

  /* ============ 모바일 우선 반응형 토큰 ============ */
  /* container padding (좌우 안전 마진) */
  --space-page: clamp(12px, 4vw, 20px);
  /* 챕터 카드 padding (모바일에서 좁게, 데스크톱에서 넓게) */
  --card-padding-y: clamp(20px, 5vw, 32px);
  --card-padding-x: clamp(16px, 4.5vw, 28px);
  /* 본문 글자 크기 (모바일 14, 데스크톱 15.5) */
  --text-body: clamp(14px, 3.8vw, 15.5px);
  --text-title: clamp(13px, 3.5vw, 15px);
  --text-small: clamp(11px, 3vw, 12.5px);
  --text-pixel-md: clamp(10px, 2.6vw, 12px);
  --text-pixel-sm: clamp(8px, 2.2vw, 10px);
  /* 본문 줄간격 (모바일에서 살짝 좁게) */
  --line-body: 1.85;
  /* bottom-nav 높이 + safe-area */
  --bnav-h: 84px;
  --bnav-pad: calc(var(--bnav-h) + env(safe-area-inset-bottom, 0px));
}

/* ============ Reset & Base ============ */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html, body {
  min-height: 100vh;
  background: var(--bg);
  color: var(--text);
  font-family: var(--sans);
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  line-height: 1.6;
  overflow-x: hidden;
}

body {
  background-color: var(--bg);
  background-image: radial-gradient(circle, rgba(17,17,17,0.07) 1px, transparent 1px);
  background-size: 24px 24px;
}

button {
  font-family: inherit;
  cursor: pointer;
  border: none;
  background: none;
  color: inherit;
}

input, select {
  font-family: inherit;
  color: inherit;
}

a {
  color: var(--pink);
  text-decoration: none;
}
a:hover { text-decoration: underline; }

.hidden { display: none !important; }
.pixel-font { font-family: var(--pixel) !important; }

/* ============ Page Load Screen ============ */
#page-loader {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: var(--bg);
  background-image: radial-gradient(circle, rgba(17,17,17,0.07) 1px, transparent 1px);
  background-size: 24px 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}

.pl-card {
  width: min(520px, 92vw);
  padding: 48px 40px;
  background: var(--surface);
  border: 3px solid var(--black);
  box-shadow: 8px 8px 0 var(--black);
  text-align: center;
  position: relative;
}

/* Corner pixel accents on loader card */
.pl-card::before {
  content: '';
  position: absolute;
  top: -6px;
  left: -6px;
  width: 16px;
  height: 16px;
  background: var(--pink);
  border: 2px solid var(--black);
}
.pl-card::after {
  content: '';
  position: absolute;
  bottom: -6px;
  right: -6px;
  width: 16px;
  height: 16px;
  background: var(--pink);
  border: 2px solid var(--black);
}

.pl-logo {
  font-size: clamp(16px, 4vw, 22px);
  color: var(--black);
  margin-bottom: 6px;
  letter-spacing: 0.05em;
}

.pl-tagline {
  font-size: 8px;
  color: var(--pink);
  letter-spacing: 0.2em;
  margin-bottom: 28px;
}

.pl-pct {
  font-size: clamp(36px, 8vw, 52px);
  color: var(--pink);
  line-height: 1;
  margin-bottom: 16px;
  letter-spacing: 0.02em;
}

.pl-bar-track {
  width: 100%;
  height: 28px;
  background: var(--surface2);
  border: 2px solid var(--black);
  box-shadow: var(--shadow-sm);
  position: relative;
  overflow: hidden;
  margin-bottom: 16px;
}

.pl-bar-fill {
  height: 100%;
  background: var(--pink);
  transition: width 0.12s linear;
  position: relative;
}

/* Pixel segment marks on progress bar */
.pl-bar-fill::after {
  content: '';
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    90deg,
    transparent 0px,
    transparent 20px,
    rgba(255,255,255,0.25) 20px,
    rgba(255,255,255,0.25) 22px
  );
}

.pl-msg {
  font-size: 11px;
  color: var(--subtext);
  letter-spacing: 0.05em;
  min-height: 18px;
  font-family: var(--sans);
}

/* ============ Site Wrap ============ */
#site-wrap {
  opacity: 0;
  visibility: hidden;
}

/* ============ Container ============ */
.container {
  max-width: 760px;
  margin: 0 auto;
  padding: 0 var(--space-page);
  position: relative;
  z-index: 1;
}

/* ============ Header ============ */
.game-header {
  background: var(--surface);
  border-bottom: 3px solid var(--black);
  padding: 0 5%;
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: sticky;
  top: 0;
  z-index: 100;
  box-shadow: 0 3px 0 var(--black);
}

.logo {
  font-size: 11px;
  color: var(--black);
  letter-spacing: 0.03em;
  line-height: 1;
  padding: 12px 4px; /* WCAG 2.2 — 44px 터치 타겟 (글자 작음 → 패딩 큼) */
  display: inline-flex;
  align-items: center;
  min-height: 44px;
}

/* 페이지 하단 footer 링크 (개인정보/이용약관) — 9 페이지 inline style 글로벌 보강 */
footer a {
  display: inline-block;
  padding: 8px 6px; /* 17px → ~33px 높이로 (footer 위치라 44px까지는 안 가도 됨) */
  min-height: 33px;
  line-height: 1.4;
}
.logo-x {
  color: var(--pink);
  margin: 0 3px;
}

/* 처음으로 돌아가기 버튼 (좌상단) */
.header-reset {
  font-size: 9px;
  color: var(--black);
  letter-spacing: 0.05em;
  padding: 10px 12px; /* WCAG 2.2 — 44px 터치 타겟 */
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  border: 2px solid var(--black);
  box-shadow: 2px 2px 0 var(--black);
  background: var(--surface);
  text-decoration: none;
  cursor: pointer;
  transition: transform 0.06s ease, box-shadow 0.06s ease;
  white-space: nowrap;
}
.header-reset:hover {
  transform: translate(1px, 1px);
  box-shadow: 1px 1px 0 var(--black);
}
.header-reset:active {
  transform: translate(2px, 2px);
  box-shadow: 0 0 0 var(--black);
}
@media (max-width: 480px) {
  .header-reset { font-size: 8px; padding: 10px 10px; }
}

/* Phase C — 잠긴 챕터 (12 챕터 중 8 유료) */
.chapter-card.chapter-locked {
  background: linear-gradient(135deg, #fafafa 0%, #f0eee8 100%);
  border-style: dashed;
}
.chapter-lock-box {
  text-align: center;
  padding: 32px 16px;
}
.chapter-lock-icon {
  font-size: 42px;
  margin-bottom: 12px;
  opacity: 0.7;
}
.chapter-lock-msg {
  font-size: 12px;
  color: var(--subtext);
  letter-spacing: 0.04em;
  margin-bottom: 18px;
  font-family: var(--sans);
}
.chapter-lock-cta {
  display: inline-block;
  font-size: 11px;
  padding: 12px 22px;
  text-decoration: none;
}

/* 픽셀 테마 커스텀 드롭다운 (yearly + this-month 등) */
.picker-row {
  margin-bottom: 16px;
}
.picker-label {
  font-size: 10px;
  color: var(--gold);
  letter-spacing: 0.05em;
  margin-bottom: 6px;
  display: block;
}
.px-dropdown {
  position: relative;
  display: inline-block;
  width: 100%;
  max-width: 320px;
}
.px-dropdown-button {
  width: 100%;
  background: var(--surface);
  border: 2px solid var(--black);
  box-shadow: 3px 3px 0 var(--black);
  padding: 10px 14px;
  font-size: 11px;
  color: var(--black);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  text-align: left;
  transition: transform 0.06s ease, box-shadow 0.06s ease;
}
.px-dropdown-button:hover {
  transform: translate(1px, 1px);
  box-shadow: 2px 2px 0 var(--black);
}
.px-dropdown.open .px-dropdown-button {
  background: var(--bg);
}
.px-dropdown-caret {
  font-size: 9px;
  color: var(--pink);
  transition: transform 0.15s ease;
}
.px-dropdown.open .px-dropdown-caret {
  transform: rotate(180deg);
}
.px-dropdown-menu {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  background: var(--surface);
  border: 2px solid var(--black);
  box-shadow: 4px 4px 0 var(--black);
  list-style: none;
  margin: 0;
  padding: 4px;
  max-height: 280px;
  overflow-y: auto;
  z-index: 50;
  display: none;
}
.px-dropdown.open .px-dropdown-menu {
  display: block;
}
.px-dropdown-menu li {
  padding: 10px 12px;
  font-size: 11px;
  cursor: pointer;
  border: 2px solid transparent;
  transition: background 0.06s ease, border-color 0.06s ease;
}
.px-dropdown-menu li:hover {
  background: var(--bg);
  border-color: var(--black);
}
.px-dropdown-menu li.selected {
  background: var(--gold-light, #fff3c4);
  border-color: var(--black);
  font-weight: 700;
}
.px-dropdown-menu li.muted {
  color: var(--subtext);
  font-size: 9px;
  pointer-events: none;
  padding: 6px 12px 4px;
}

/* 카탈로그 모달 (홈 버튼 클릭 시) */
.home-catalog-modal {
  position: fixed;
  inset: 0;
  z-index: 200;
  background: rgba(17, 17, 17, 0.7);
  display: none;
  align-items: flex-start;
  justify-content: center;
  padding: 60px 16px 100px;
  overflow-y: auto;
}
.home-catalog-modal.open {
  display: flex;
}
.home-catalog-modal-card {
  background: var(--surface);
  border: 3px solid var(--black);
  box-shadow: 6px 6px 0 var(--black);
  max-width: 720px;
  width: 100%;
  padding: 28px 24px 32px;
  position: relative;
}
.home-catalog-modal-close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 36px;
  height: 36px;
  background: var(--surface);
  border: 2px solid var(--black);
  box-shadow: 2px 2px 0 var(--black);
  font-size: 18px;
  cursor: pointer;
  line-height: 1;
}
.home-catalog-modal-close:hover {
  transform: translate(1px, 1px);
  box-shadow: 1px 1px 0 var(--black);
}
.home-catalog-modal-eyebrow {
  font-size: 10px;
  color: var(--gold);
  letter-spacing: 0.1em;
  margin-bottom: 8px;
}
.home-catalog-modal-title {
  font-size: 18px;
  margin-bottom: 20px;
  line-height: 1.4;
}
.home-catalog-modal-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}
@media (max-width: 480px) {
  /* 모바일에서도 2열 유지 (사용자 요청 #1) — 카드 컴팩트화 */
  .home-catalog-modal-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
  }
}
.home-catalog-modal-card-item {
  background: var(--bg);
  border: 2px solid var(--black);
  box-shadow: 3px 3px 0 var(--black);
  padding: 14px 12px;
  text-decoration: none;
  color: var(--black);
  display: flex;
  flex-direction: column;
  gap: 4px;
  transition: transform 0.06s ease, box-shadow 0.06s ease;
}
.home-catalog-modal-card-item:hover {
  transform: translate(1px, 1px);
  box-shadow: 2px 2px 0 var(--black);
}
.home-catalog-modal-card-icon { font-size: 20px; }
.home-catalog-modal-card-title { font-size: 11px; font-weight: 700; }
.home-catalog-modal-card-desc { font-size: 11px; color: var(--subtext); line-height: 1.4; }

.header-link {
  font-size: 8px;
  color: var(--black);
  letter-spacing: 0.08em;
  padding: 8px 12px;
  border: 2px solid var(--black);
  box-shadow: var(--shadow-sm);
  background: var(--surface);
  transition: transform 0.08s, box-shadow 0.08s, background 0.08s;
  text-decoration: none;
}
.header-link:hover {
  background: var(--pink);
  color: #fff;
  transform: translate(-2px, -2px);
  box-shadow: 4px 4px 0 var(--black);
  text-decoration: none;
}

/* ============ Hero Section ============ */
#hero-section {
  background: var(--surface);
  position: relative;
  overflow: hidden;
  padding: 0 0 0;
  background-image: radial-gradient(circle, rgba(17,17,17,0.06) 1px, transparent 1px);
  background-size: 24px 24px;
  background-color: var(--surface);
}

.hero-content {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  align-items: center;
  padding-top: 60px;
  padding-bottom: 60px;
}

.hero-left {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0;
}

.hero-eyebrow {
  font-size: 7px;
  color: var(--pink);
  letter-spacing: 0.15em;
  border: 2px solid var(--pink);
  padding: 6px 12px;
  box-shadow: 3px 3px 0 var(--pink);
  margin-bottom: 24px;
  display: inline-block;
  background: #fff;
  animation: eyebrow-pulse 2.5s steps(1) infinite;
}

@keyframes eyebrow-pulse {
  0%, 49% { opacity: 1; }
  50%, 100% { opacity: 0.7; }
}

.hero-title {
  /* 메인 타이틀 — 사용자 제공 이미지 (img/hero-title.png) */
  margin: 0 0 20px 0;
  padding: 0;
  line-height: 0;
}
.hero-title.hero-title-img img {
  display: block;
  width: 100%;
  max-width: 480px;
  height: auto;
}
@media (min-width: 1024px) {
  .hero-title.hero-title-img img { max-width: 560px; }
}
@media (max-width: 480px) {
  .hero-title.hero-title-img img { max-width: 320px; }
}

.hero-sub {
  font-size: 14px;
  color: var(--subtext);
  line-height: 1.8;
  margin-bottom: 32px;
  font-family: var(--sans);
}
.hero-sub.hero-sub-img {
  margin: 0 0 28px 0;
  padding: 0;
  line-height: 0;
}
.hero-sub.hero-sub-img img {
  display: block;
  width: 100%;
  max-width: 320px;
  height: auto;
  image-rendering: pixelated;
  image-rendering: crisp-edges;
}
@media (min-width: 1024px) {
  .hero-sub.hero-sub-img img { max-width: 380px; }
}
@media (max-width: 480px) {
  .hero-sub.hero-sub-img img { max-width: 240px; }
}

.hero-right {
  display: flex !important;
  align-items: center;
  justify-content: center;
  position: relative;
  padding: 20px;
  min-height: 200px;
}

.pixel-char {
  display: block !important;
  width: min(240px, 90%);
  height: auto;
  min-width: 120px;
  image-rendering: pixelated;
  image-rendering: crisp-edges;
  filter: drop-shadow(6px 6px 0 rgba(17,17,17,0.15));
}

.char-sparkle {
  position: absolute;
  font-size: 14px;
  color: var(--pink);
  animation: float-px 3s ease-in-out infinite;
}
.char-sparkle-1 { top: 10%; left: 5%; animation-delay: 0s; }
.char-sparkle-2 { top: 15%; right: 8%; font-size: 18px; color: var(--gold); animation-delay: 1.2s; }
.char-sparkle-3 { bottom: 18%; right: 12%; animation-delay: 0.6s; }

@keyframes float-px {
  0%, 100% { transform: translateY(0); opacity: 0.8; }
  50% { transform: translateY(-10px); opacity: 1; }
}

/* Floating sparkle decorations */
.pixel-float {
  position: absolute;
  font-family: var(--pixel);
  font-size: 10px;
  color: var(--pink);
  opacity: 0.25;
  pointer-events: none;
  user-select: none;
  animation: float-px 4s ease-in-out infinite;
  z-index: 0;
}
.pixel-float:nth-child(2) { animation-delay: 0.8s; }
.pixel-float:nth-child(3) { animation-delay: 2s; }
.pixel-float:nth-child(4) { animation-delay: 1.4s; }

/* Hero bottom strip */
.hero-strip {
  background: var(--black);
  color: #fff;
  font-size: 7px;
  letter-spacing: 0.15em;
  padding: 12px 20px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ============ Jagged Dividers ============ */
.jagged-to-pink {
  line-height: 0;
  background: var(--surface);
  display: block;
}
.jagged-to-pink svg {
  display: block;
  width: 100%;
  height: 48px;
}

.jagged-from-pink {
  line-height: 0;
  background: var(--pink);
  display: block;
}
.jagged-from-pink svg {
  display: block;
  width: 100%;
  height: 48px;
}

/* ============ Stats Section ============ */
.stats-section {
  background: var(--pink);
  padding: 48px 0;
}

.stats-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  text-align: center;
}

.stat-item {
  padding: 16px;
}

.stat-num {
  font-size: clamp(20px, 4vw, 32px);
  color: #fff;
  line-height: 1.2;
  margin-bottom: 8px;
  letter-spacing: 0.04em;
  text-shadow: 3px 3px 0 rgba(0,0,0,0.25);
}

.stat-label {
  font-size: 13px;
  color: rgba(255,255,255,0.8);
  font-family: var(--sans);
}

/* ============ Features Section ============ */
.features-section {
  background: var(--bg);
  padding: 72px 0 80px;
  background-image: radial-gradient(circle, rgba(17,17,17,0.07) 1px, transparent 1px);
  background-size: 24px 24px;
}

.section-title-big {
  font-size: clamp(18px, 3.5vw, 28px);
  color: var(--black);
  margin-bottom: 40px;
  line-height: 1.6;
  letter-spacing: 0.02em;
}

.features-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  margin-bottom: 48px;
}

.feature-card {
  background: var(--surface);
  border: 2px solid var(--black);
  box-shadow: var(--shadow);
  padding: 28px 24px;
  transition: transform 0.08s, box-shadow 0.08s;
}

.feature-card:hover {
  transform: translate(-2px, -2px);
  box-shadow: 6px 6px 0 var(--black);
}

.feature-icon {
  font-family: var(--serif);
  font-size: 36px;
  font-weight: 700;
  line-height: 1;
  margin-bottom: 12px;
}

.feature-card h3 {
  font-size: 9px;
  color: var(--black);
  letter-spacing: 0.1em;
  margin-bottom: 10px;
}

.feature-card p {
  font-size: 13px;
  color: var(--subtext);
  line-height: 1.7;
  font-family: var(--sans);
}

.features-cta {
  text-align: center;
  margin-top: 16px;
}

/* ============ Catalog Section (사주아이 미러링) ============ */
.catalog-section {
  background: #fff8ec;
  padding: 56px 0 64px;
  border-top: 4px solid var(--black);
  border-bottom: 4px solid var(--black);
  background-image:
    radial-gradient(circle, rgba(255,45,120,0.08) 1px, transparent 1px),
    radial-gradient(circle, rgba(240,192,64,0.08) 1px, transparent 1px);
  background-size: 24px 24px, 24px 24px;
  background-position: 0 0, 12px 12px;
}

.catalog-eyebrow {
  display: inline-block;
  font-size: 7px;
  letter-spacing: 0.2em;
  color: var(--pink);
  border: 2px solid var(--pink);
  padding: 6px 12px;
  background: #fff;
  box-shadow: 3px 3px 0 var(--pink);
  margin-bottom: 20px;
}

.catalog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 8px;
}

.catalog-card {
  display: flex;
  flex-direction: column;
  background: var(--surface);
  border: 2px solid var(--black);
  box-shadow: var(--shadow);
  padding: 22px 20px 20px;
  text-decoration: none;
  color: var(--text);
  transition: transform 0.08s, box-shadow 0.08s;
  min-height: 220px;
}
.catalog-card:hover {
  transform: translate(-2px, -2px);
  box-shadow: 6px 6px 0 var(--black);
  text-decoration: none;
}

.catalog-thumb {
  width: 56px;
  height: 56px;
  border: 2px solid var(--black);
  background: #fff8ec;
  display: grid;
  place-items: center;
  margin-bottom: 14px;
  box-shadow: 3px 3px 0 var(--gold);
}
.catalog-thumb-icon {
  font-size: 28px;
  line-height: 1;
}

.catalog-card-title {
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--black);
  margin-bottom: 10px;
  line-height: 1.4;
}

.catalog-card-desc {
  font-size: 13px;
  color: var(--subtext);
  line-height: 1.55;
  margin-bottom: 14px;
  flex: 1;
}

.catalog-card-price {
  font-size: 11px;
  color: var(--black);
  background: #fff8ec;
  border: 2px solid var(--black);
  padding: 6px 8px;
  margin-bottom: 10px;
  letter-spacing: 0.04em;
  line-height: 1.4;
}
.catalog-card-price .cc-star { color: var(--pink); margin-right: 4px; }
.catalog-card-price .cc-won {
  color: var(--subtext);
  font-size: 9px;
  margin-left: 4px;
}
.catalog-card-price.catalog-free {
  background: var(--green);
  color: #fff;
  border-color: var(--black);
}

.catalog-card-cta {
  font-size: 9px;
  color: var(--pink);
  letter-spacing: 0.1em;
  align-self: flex-start;
  border-bottom: 2px solid var(--pink);
  padding: 4px 0 2px;
}

/* ============ SEO / Trust Box ============ */
.seo-box {
  background: var(--bg);
  padding: 64px 0 72px;
}

.seo-eyebrow {
  display: inline-block;
  font-size: 7px;
  letter-spacing: 0.2em;
  color: var(--gold);
  border: 2px solid var(--gold);
  padding: 6px 12px;
  background: #fff;
  margin-bottom: 18px;
}

.seo-title {
  font-size: 22px;
  line-height: 32px;
  color: var(--black);
  margin-bottom: 24px;
  letter-spacing: 0.02em;
}

.seo-lead {
  font-size: 14px;
  line-height: 22px;
  color: var(--text);
  margin-bottom: 8px;
}

.seo-list {
  list-style: none;
  margin: 24px 0 16px;
  padding: 16px;
  background: var(--surface);
  border: 2px solid var(--black);
  box-shadow: var(--shadow-pink);
}
.seo-list li {
  font-size: 13px;
  line-height: 22px;
  color: var(--text);
  padding: 4px 0 4px 12px;
  position: relative;
}
.seo-list li::before {
  content: '✦';
  position: absolute;
  left: -2px;
  color: var(--pink);
  font-size: 11px;
}
.seo-list strong {
  color: var(--black);
  font-weight: 700;
}

.seo-tags {
  margin-top: 20px;
  font-size: 9px;
  color: var(--subtext);
  letter-spacing: 0.05em;
  line-height: 1.8;
}

/* Mobile catalog/SEO */
@media (max-width: 768px) {
  .catalog-grid { grid-template-columns: 1fr; gap: 12px; }
  .catalog-card { min-height: 0; padding: 18px 16px; }
  .catalog-thumb { width: 48px; height: 48px; }
  .catalog-thumb-icon { font-size: 24px; }
  .seo-title { font-size: 18px; line-height: 28px; }
  .seo-list li { font-size: 12px; line-height: 20px; }
}

/* ============ Result Page (13챕터 페이게이트) ============ */
.result-header-section {
  background: linear-gradient(180deg, #fff8ec 0%, var(--bg) 100%);
  padding: 32px 0 24px;
  border-bottom: 4px solid var(--black);
}
.result-eyebrow {
  display: inline-block;
  font-size: 7px;
  letter-spacing: 0.2em;
  color: var(--pink);
  border: 2px solid var(--pink);
  padding: 6px 12px;
  background: #fff;
  box-shadow: 3px 3px 0 var(--pink);
  margin-bottom: 16px;
}
.result-title {
  font-size: 24px;
  line-height: 32px;
  color: var(--black);
  letter-spacing: 0.04em;
  margin-bottom: 16px;
}
.result-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 16px;
}
.result-meta-item {
  font-size: 12px;
  background: #fff;
  border: 2px solid var(--black);
  padding: 4px 10px;
  font-family: var(--sans);
  color: var(--text);
  box-shadow: 2px 2px 0 var(--black);
}
.result-progress {
  margin-top: 12px;
  font-size: 9px;
  color: var(--subtext);
  letter-spacing: 0.1em;
}
.progress-bar {
  margin-top: 8px;
  height: 14px;
  background: #fff;
  border: 2px solid var(--black);
  box-shadow: 2px 2px 0 var(--black);
  overflow: hidden;
  position: relative;
}
.progress-bar-fill {
  height: 100%;
  background: repeating-linear-gradient(90deg, var(--pink) 0 8px, #ff6ba0 8px 16px);
  transition: width 0.3s;
}

.chapters-section {
  background: var(--bg);
  padding: 32px 0 48px;
  background-image: radial-gradient(circle, rgba(17,17,17,0.07) 1px, transparent 1px);
  background-size: 24px 24px;
}
.chapters-list {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-bottom: 32px;
}

/* 챕터 카드 기본 (4643 라인 업그레이드 룰이 최종 적용) */
.chapter-card {
  background: var(--surface);
  border: 2px solid var(--black);
  box-shadow: var(--shadow);
  padding: var(--card-padding-y) var(--card-padding-x);
  position: relative;
}
.chapter-num {
  font-size: 9px;
  color: var(--pink);
  letter-spacing: 0.15em;
  margin-bottom: 8px;
}
.chapter-title {
  font-size: 14px;
  color: var(--black);
  margin-bottom: 14px;
  letter-spacing: 0.04em;
}
.chapter-body {
  font-size: var(--text-body);
  line-height: var(--line-body);
  color: var(--text);
  font-family: var(--sans);
  margin-bottom: 12px;
  letter-spacing: 0; /* 한글에 letter-spacing 제거 — 모바일 줄당 글자수 ↑ */
  word-break: keep-all;
  overflow-wrap: anywhere;
}
.chapter-body p {
  margin: 0 0 14px;
}
.chapter-body p:last-child {
  margin-bottom: 0;
}
.chapter-tag {
  display: inline-block;
  font-size: 9px;
  letter-spacing: 0.1em;
  padding: 4px 8px;
  border: 2px solid var(--black);
}
.chapter-tag-free {
  background: var(--green);
  color: #fff;
}
.chapter-tag-locked {
  background: var(--surface2);
  color: var(--subtext);
  font-size: 10px;
  display: block;
  text-align: center;
  padding: 10px 12px;
  letter-spacing: 0.06em;
}

/* 풀이 받는 중 — 로딩 애니메이션 */
.chapter-pending {
  background: linear-gradient(180deg, #fff 0%, #faf8f0 100%);
}
.chapter-body-loading {
  color: var(--subtext);
  font-style: italic;
  animation: chapter-pulse 1.5s ease-in-out infinite;
}
@keyframes chapter-pulse {
  0%, 100% { opacity: 0.55; }
  50% { opacity: 1; }
}

/* 잠긴 챕터 */
.chapter-locked {
  background: linear-gradient(180deg, #fff 0%, #fff8ec 100%);
  border-color: var(--black);
}
.chapter-body-blur {
  filter: blur(4px);
  user-select: none;
  pointer-events: none;
  color: var(--subtext);
  margin-bottom: 16px;
}
.chapter-lock-btn {
  display: block;
  width: 100%;
  background: var(--pink);
  color: #fff;
  font-family: var(--pixel);
  font-size: 11px;
  letter-spacing: 0.06em;
  padding: 14px 20px;
  border: 2px solid var(--black);
  box-shadow: 4px 4px 0 var(--black);
  cursor: pointer;
  text-align: center;
  transition: transform 0.08s, box-shadow 0.08s;
}
.chapter-lock-btn:hover {
  transform: translate(-2px, -2px);
  box-shadow: 6px 6px 0 var(--black);
}
.chapter-lock-btn small {
  font-size: 9px;
  opacity: 0.85;
  margin-left: 4px;
}

/* 모두 열기 배너 */
.unlock-all-banner {
  background: var(--surface);
  border: 3px solid var(--black);
  box-shadow: 6px 6px 0 var(--gold);
  padding: 28px 24px;
  text-align: center;
  margin-top: 8px;
}
.unlock-all-eyebrow {
  display: inline-block;
  font-size: 7px;
  letter-spacing: 0.2em;
  color: var(--gold);
  border: 2px solid var(--gold);
  padding: 6px 12px;
  background: #fff;
  margin-bottom: 14px;
}
.unlock-all-banner h3 {
  font-size: 18px;
  line-height: 26px;
  color: var(--black);
  letter-spacing: 0.04em;
  margin-bottom: 12px;
}
.unlock-all-banner p {
  font-size: 13px;
  color: var(--subtext);
  margin-bottom: 18px;
  font-family: var(--sans);
  line-height: 1.7;
}
.unlock-all-btn {
  font-size: 12px;
  letter-spacing: 0.06em;
  padding: 16px 22px;
}
.unlock-all-btn small {
  font-size: 10px;
  margin-left: 4px;
  opacity: 0.85;
}
.unlock-all-note {
  margin-top: 14px !important;
  font-size: 11px !important;
  color: var(--text) !important;
}

/* ============ Post-Result CTA (다른 풀이 둘러보기) ============ */
.post-result-cta {
  background: #fff8ec;
  border-top: 4px solid var(--black);
  border-bottom: 4px solid var(--black);
  padding: 40px 0 44px;
  text-align: center;
}
.post-cta-eyebrow {
  display: inline-block;
  font-size: 7px;
  letter-spacing: 0.2em;
  color: var(--gold);
  border: 2px solid var(--gold);
  padding: 6px 12px;
  background: #fff;
  margin-bottom: 18px;
}
.post-result-cta h3 {
  font-size: 18px;
  line-height: 28px;
  color: var(--black);
  letter-spacing: 0.04em;
  margin-bottom: 22px;
}
.post-cta-buttons {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 18px;
}
.post-cta-btn {
  font-size: 11px !important;
  padding: 14px 22px !important;
}
.post-cta-saved {
  font-size: 12px;
  color: var(--subtext);
  font-family: var(--sans);
}
.post-cta-saved a {
  color: var(--pink);
  text-decoration: underline;
}

/* ============ Library Page (보관함) ============ */
.library-section {
  padding: 32px 0 48px;
  background: var(--bg);
  background-image: radial-gradient(circle, rgba(17,17,17,0.07) 1px, transparent 1px);
  background-size: 24px 24px;
  min-height: 60vh;
}
.library-list {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-top: 20px;
}
.library-card {
  display: flex;
  align-items: stretch;
  background: var(--surface);
  border: 2px solid var(--black);
  box-shadow: var(--shadow);
  text-decoration: none;
  color: var(--text);
  transition: transform 0.08s, box-shadow 0.08s;
}
.library-card:hover {
  transform: translate(-2px, -2px);
  box-shadow: 6px 6px 0 var(--black);
  text-decoration: none;
}
.library-card-icon {
  width: 64px;
  background: #fff8ec;
  border-right: 2px solid var(--black);
  display: grid;
  place-items: center;
  font-size: 26px;
}
.library-card-body {
  flex: 1;
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.library-card-title {
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--black);
}
.library-card-meta {
  font-size: 12px;
  color: var(--subtext);
  font-family: var(--sans);
  line-height: 1.5;
}
.library-card-tag {
  font-size: 9px;
  color: var(--pink);
  letter-spacing: 0.1em;
  margin-top: 4px;
}
.library-empty {
  text-align: center;
  padding: 48px 24px;
  color: var(--subtext);
  font-family: var(--sans);
}
.library-empty-icon {
  font-size: 48px;
  margin-bottom: 16px;
}

/* ============ Chat Page (상담소) ============ */
.chat-page {
  background: var(--bg);
  min-height: 100vh;
  padding-bottom: 100px;
}
.chat-balance-bar {
  background: #fff8ec;
  border-bottom: 4px solid var(--black);
  padding: 12px 20px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--sans);
  font-size: 13px;
}
.chat-balance-bar strong { color: var(--pink); }
.chat-history {
  padding: 24px 20px 20px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.msg {
  max-width: 80%;
  padding: 12px 14px;
  border: 2px solid var(--black);
  font-family: var(--sans);
  font-size: 14px;
  line-height: 1.55;
}
.msg-user {
  align-self: flex-end;
  background: var(--pink);
  color: #fff;
  box-shadow: var(--shadow-sm);
}
.msg-bot {
  align-self: flex-start;
  background: #f3edff; /* 옅은 라벤더 — 헤더와 명확히 구분 (2026-05-20) */
  color: var(--text);
  box-shadow: var(--shadow-sm);
  border-color: var(--purple, #7a4ec8);
}
.msg-bot-name {
  font-family: var(--pixel);
  font-size: 9px;
  color: var(--purple, #7a4ec8);
  letter-spacing: 0.1em;
  margin-bottom: 6px;
}

/* 대답 중 — typing indicator (2026-05-20) */
.msg-bot-typing {
  opacity: 0.95;
}
.typing-dots {
  display: inline-flex;
  gap: 4px;
  margin-left: 6px;
  vertical-align: middle;
}
.typing-dots span {
  width: 6px;
  height: 6px;
  background: var(--purple, #7a4ec8);
  border-radius: 50%;
  animation: typing-bounce 1.2s infinite ease-in-out;
}
.typing-dots span:nth-child(2) { animation-delay: 0.18s; }
.typing-dots span:nth-child(3) { animation-delay: 0.36s; }
@keyframes typing-bounce {
  0%, 60%, 100% { transform: translateY(0); opacity: 0.4; }
  30%           { transform: translateY(-5px); opacity: 1; }
}

.chat-suggest-box {
  background: var(--surface);
  border: 2px solid var(--black);
  box-shadow: var(--shadow);
  padding: 14px 16px;
  margin: 8px 20px 20px;
}
.chat-suggest-eyebrow {
  font-family: var(--pixel);
  font-size: 8px;
  color: var(--pink);
  letter-spacing: 0.1em;
  margin-bottom: 10px;
}
.chat-suggest-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.chat-suggest-btn {
  background: #fff8ec;
  border: 2px solid var(--black);
  padding: 10px 12px;
  font-family: var(--sans);
  font-size: 13px;
  text-align: left;
  cursor: pointer;
  color: var(--text);
  transition: transform 0.08s;
}
.chat-suggest-btn:hover {
  transform: translate(-1px, -1px);
  box-shadow: 3px 3px 0 var(--black);
}

.chat-input-bar {
  position: fixed;
  bottom: var(--bnav-pad); /* bottom-nav 높이 + safe-area 위 */
  left: 0; right: 0;
  background: var(--surface);
  border-top: 4px solid var(--black);
  padding: 12px var(--space-page);
  display: flex;
  gap: 8px;
  z-index: 70;
}
.chat-input {
  flex: 1;
  border: 2px solid var(--black);
  padding: 10px 12px;
  font-family: var(--sans);
  font-size: 14px;
  background: #fff;
}
.chat-input:focus {
  outline: none;
  box-shadow: 3px 3px 0 var(--pink);
}
.chat-send-btn {
  background: var(--pink);
  color: #fff;
  border: 2px solid var(--black);
  padding: 0 16px;
  font-family: var(--pixel);
  font-size: 10px;
  letter-spacing: 0.06em;
  cursor: pointer;
  box-shadow: 2px 2px 0 var(--black);
}
.chat-send-btn:disabled {
  background: #c5c0b5;
  color: #6f6a5e;
  cursor: not-allowed;
  box-shadow: 1px 1px 0 var(--black);
  transform: translate(1px, 1px);
}
.chat-input-bar { flex-wrap: wrap; }
.chat-input-counter {
  width: 100%;
  text-align: right;
  font-family: var(--sans);
  font-size: 11px;
  color: var(--subtext);
  margin-top: 4px;
  letter-spacing: 0.02em;
}
.chat-input-counter.over {
  color: var(--pink);
  font-weight: 700;
}

/* ============ Lock Modal ============ */
.lock-modal {
  position: fixed;
  inset: 0;
  z-index: 100;
  background: rgba(17,17,17,0.55);
  display: grid;
  place-items: center;
  padding: 16px;
}
.lock-modal.hidden { display: none; }
.lock-modal-card {
  background: var(--surface);
  border: 3px solid var(--black);
  box-shadow: 8px 8px 0 var(--pink);
  padding: 28px 24px 24px;
  max-width: 380px;
  width: 100%;
  position: relative;
  text-align: center;
}
.lock-modal-close {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 32px;
  height: 32px;
  font-size: 22px;
  font-weight: 700;
  background: #fff;
  border: 2px solid var(--black);
  cursor: pointer;
  line-height: 1;
}
.lock-modal-icon {
  font-size: 40px;
  line-height: 1;
  margin-bottom: 12px;
}
.lock-modal-card h3 {
  font-size: 13px;
  letter-spacing: 0.06em;
  color: var(--black);
  margin-bottom: 16px;
}
.lock-modal-card p {
  font-size: 14px;
  color: var(--text);
  font-family: var(--sans);
  line-height: 1.6;
  margin-bottom: 8px;
}
.lock-modal-card .muted { color: var(--subtext); font-size: 13px; }
.lock-modal-coming {
  margin-top: 12px !important;
  padding: 10px;
  background: #fff8ec;
  border: 2px dashed var(--gold);
  font-size: 12px !important;
  color: var(--text) !important;
}
.lock-modal-actions {
  display: flex;
  gap: 10px;
  margin-top: 18px;
  justify-content: center;
}
.lock-modal-actions .btn-game { flex: 1; }
.btn-ghost {
  background: #fff;
  color: var(--black);
}

/* ============ Onboarding / Add Form ============ */
.onboarding-section { padding: 24px 0 56px; background: var(--bg); }
.onboarding-form { display: flex; flex-direction: column; gap: 22px; max-width: 500px; margin: 0 auto; }

.ob-field { display: flex; flex-direction: column; gap: 8px; }
.ob-label { font-size: 9px; color: var(--black); letter-spacing: 0.1em; }
.ob-input, .ob-select {
  font-family: var(--sans);
  font-size: 15px;
  padding: 12px 14px;
  border: 2px solid var(--black);
  background: var(--surface);
  color: var(--text);
  width: 100%;
  box-shadow: 3px 3px 0 var(--black);
}
.ob-input:focus, .ob-select:focus { outline: none; box-shadow: 4px 4px 0 var(--pink); }
.ob-select-full { width: 100%; }
.ob-date-row { display: grid; grid-template-columns: 1.2fr 1fr 1fr; gap: 8px; }

.ob-radio-group, .ob-relation-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.ob-relation-grid { grid-template-columns: 1fr 1fr 1fr; }
.ob-radio, .ob-relation-btn {
  display: flex; align-items: center; justify-content: center;
  gap: 6px; padding: 12px 8px;
  border: 2px solid var(--black);
  background: var(--surface);
  cursor: pointer;
  font-family: var(--sans);
  font-size: 14px;
  box-shadow: 2px 2px 0 var(--black);
  transition: transform 0.08s, background 0.08s;
}
.ob-radio input, .ob-relation-btn input {
  position: absolute; opacity: 0; pointer-events: none;
}
.ob-radio:has(input:checked), .ob-relation-btn:has(input:checked) {
  background: var(--pink); color: #fff; transform: translate(-1px, -1px);
  box-shadow: 3px 3px 0 var(--black);
}

.ob-mbti-grid {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.ob-mbti-axis-row {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.ob-mbti-axis-label {
  font-family: var(--sans);
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--subtext);
  padding-left: 2px;
}
.ob-mbti-axis {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.ob-mbti-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 12px 8px;
  min-height: 64px; /* 모바일 큰 탭 영역 */
  border: 2px solid var(--border-soft);
  background: var(--surface2);
  font-family: var(--pixel);
  font-size: 14px;
  cursor: pointer;
  letter-spacing: 0.04em;
  transition: all 0.15s;
}
.ob-mbti-letter {
  font-family: var(--pixel);
  font-size: 18px;
  line-height: 1;
  color: var(--black);
}
.ob-mbti-hint {
  font-family: var(--sans);
  font-size: 10px;
  line-height: 1.3;
  color: var(--subtext);
  letter-spacing: 0;
  text-align: center;
}
.ob-mbti-btn:hover {
  border-color: var(--black);
}
.ob-mbti-btn.active {
  background: var(--pink);
  color: #fff;
  border-color: var(--black);
  box-shadow: 3px 3px 0 var(--black);
}
.ob-mbti-btn.active .ob-mbti-letter { color: #fff; }
.ob-mbti-btn.active .ob-mbti-hint { color: rgba(255,255,255,0.92); }

/* 모바일 ≤480 — hint 짧게 보이게 */
@media (max-width: 480px) {
  .ob-mbti-btn {
    min-height: 58px;
    padding: 10px 6px;
  }
  .ob-mbti-letter { font-size: 16px; }
  .ob-mbti-hint { font-size: 9.5px; line-height: 1.25; }
  .ob-mbti-axis-label { font-size: 10.5px; }
}
.ob-mbti-display { font-size: 11px; text-align: center; padding: 8px; background: #fff8ec; border: 2px dashed var(--gold); margin-top: 4px; }
.ob-mbti-help { font-size: 12px; color: var(--subtext); font-family: var(--sans); text-align: center; }
.ob-mbti-help a { color: var(--pink); text-decoration: underline; }

.ob-submit-btn {
  width: 100%; padding: 18px 20px !important;
  font-size: 12px !important; letter-spacing: 0.06em;
  margin-top: 8px;
}
.ob-submit-btn:disabled { opacity: 0.4; cursor: not-allowed; }
.ob-disclaimer {
  font-size: 12px; color: var(--subtext); font-family: var(--sans);
  text-align: center; padding: 12px;
  background: #fff8ec; border: 2px dashed var(--border);
}

/* ============ Today (오늘의 한 줄) ============ */
.today-section { padding: 32px 0 48px; background: var(--bg); }
.today-empty { text-align: center; padding: 32px 24px; background: var(--surface); border: 2px solid var(--black); box-shadow: var(--shadow); }
.today-empty-icon { font-size: 48px; margin-bottom: 16px; }
.today-empty p { font-family: var(--sans); font-size: 13px; line-height: 1.7; color: var(--subtext); margin-bottom: 20px; }
.today-empty h3 { font-size: 14px; color: var(--text); margin-bottom: 12px; letter-spacing: 0.04em; }

.today-card {
  background: var(--surface);
  border: 3px solid var(--black);
  box-shadow: 6px 6px 0 var(--gold);
  padding: 32px 24px;
  text-align: center;
  margin-bottom: 24px;
}
.today-card-eyebrow {
  display: inline-block; font-size: 8px; letter-spacing: 0.2em;
  color: var(--gold); border: 2px solid var(--gold);
  padding: 6px 12px; background: #fff; margin-bottom: 18px;
}
.today-card-quote {
  font-family: var(--sans); font-size: 17px; line-height: 1.8;
  color: var(--text); margin-bottom: 24px; font-weight: 500;
}
.today-card-tags {
  display: flex; flex-wrap: wrap; justify-content: center; gap: 8px;
  font-size: 10px; letter-spacing: 0.06em;
}
.today-card-tags span {
  padding: 6px 10px; background: #fff8ec;
  border: 2px solid var(--black); box-shadow: 2px 2px 0 var(--black);
}

.today-streak {
  text-align: center; padding: 20px; margin-bottom: 32px;
}
.today-streak-num { font-size: 42px; color: var(--pink); }
.today-streak-label { font-family: var(--sans); font-size: 13px; color: var(--subtext); }

.today-recommend h3 { font-size: 14px; text-align: center; margin-bottom: 16px; letter-spacing: 0.04em; }
.today-recommend-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.today-recommend-card {
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  padding: 16px 10px; background: var(--surface);
  border: 2px solid var(--black); box-shadow: var(--shadow);
  text-decoration: none; color: var(--text);
  transition: transform 0.08s, box-shadow 0.08s;
}
.today-recommend-card:hover {
  transform: translate(-2px, -2px); box-shadow: 6px 6px 0 var(--black);
  text-decoration: none;
}
.today-recommend-card strong { font-size: 12px; font-family: var(--sans); }
.today-recommend-card .today-recommend-icon { font-size: 24px; }
.today-recommend-cta { font-size: 8px; color: var(--pink); letter-spacing: 0.1em; }

@media (max-width: 480px) {
  .today-recommend-grid { grid-template-columns: 1fr; }
  .today-card-quote { font-size: 15px; }
}

/* ============ Recharge (별조각 충전) ============ */
.recharge-section { padding: 24px 0 56px; background: var(--bg); }

.recharge-balance {
  text-align: center; padding: 24px;
  background: linear-gradient(180deg, #fff 0%, #fff8ec 100%);
  border: 3px solid var(--black); box-shadow: 6px 6px 0 var(--gold);
  margin-bottom: 32px;
}
.recharge-balance-eyebrow { font-size: 8px; color: var(--subtext); letter-spacing: 0.2em; margin-bottom: 8px; }
.recharge-balance-num { font-size: 42px; color: var(--pink); margin-bottom: 6px; }
.recharge-balance-help { font-size: 12px; color: var(--subtext); font-family: var(--sans); }

.recharge-section-title { font-size: 14px; text-align: center; margin-bottom: 20px; letter-spacing: 0.04em; color: var(--text); }
.recharge-packages { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 32px; }

.recharge-pack {
  position: relative;
  background: var(--surface);
  border: 2px solid var(--black);
  box-shadow: var(--shadow);
  padding: 20px 16px; text-align: center;
}
.recharge-pack-best { box-shadow: 4px 4px 0 var(--pink); }
.recharge-pack-vip { box-shadow: 4px 4px 0 var(--gold); }
.recharge-pack-badge {
  position: absolute; top: -10px; left: 50%; transform: translateX(-50%);
  font-size: 8px; padding: 4px 8px;
  background: var(--pink); color: #fff;
  border: 2px solid var(--black); letter-spacing: 0.1em;
}
.recharge-pack-badge-gold { background: var(--gold); color: var(--black); }
.recharge-pack-icon { font-size: 24px; margin-bottom: 8px; }
.recharge-pack-name { font-size: 12px; margin-bottom: 6px; letter-spacing: 0.04em; }
.recharge-pack-desc { font-size: 11px; color: var(--subtext); font-family: var(--sans); margin-bottom: 12px; line-height: 1.5; min-height: 32px; }
.recharge-pack-price { font-size: 16px; color: var(--pink); margin-bottom: 12px; }
.recharge-btn { width: 100%; font-size: 10px !important; padding: 10px 12px !important; }
.recharge-btn:disabled { opacity: 0.4; cursor: not-allowed; }

.recharge-payment-info {
  background: #fff8ec; border: 2px dashed var(--gold);
  padding: 20px; margin-bottom: 24px; text-align: center;
}
.recharge-payment-info h3 { font-size: 12px; margin-bottom: 14px; letter-spacing: 0.06em; }
.recharge-payment-methods { display: flex; justify-content: center; gap: 12px; flex-wrap: wrap; margin-bottom: 14px; }
.recharge-payment-method {
  display: flex; align-items: center; gap: 6px;
  padding: 8px 12px; background: #fff; border: 2px solid var(--black);
  font-size: 12px; font-family: var(--sans); box-shadow: 2px 2px 0 var(--black);
}
.recharge-payment-icon { font-size: 18px; }
.recharge-payment-help { font-size: 12px; color: var(--subtext); font-family: var(--sans); line-height: 1.6; }

.recharge-faq h3 { font-size: 12px; margin-bottom: 12px; letter-spacing: 0.06em; }
.recharge-faq-item {
  background: var(--surface); border: 2px solid var(--black);
  margin-bottom: 8px; box-shadow: 3px 3px 0 var(--black);
}
.recharge-faq-item summary {
  padding: 14px 16px; cursor: pointer;
  font-family: var(--sans); font-size: 14px; font-weight: 500;
  list-style: none;
}
.recharge-faq-item summary::-webkit-details-marker { display: none; }
.recharge-faq-item[open] summary { border-bottom: 2px dashed var(--border); }
.recharge-faq-item p { padding: 12px 16px; font-family: var(--sans); font-size: 13px; line-height: 1.6; color: var(--subtext); }

@media (max-width: 480px) {
  .recharge-packages { grid-template-columns: 1fr; }
}

/* ============ Compatibility (궁합) ============ */
.compat-pair {
  display: grid; grid-template-columns: 1fr auto 1fr; gap: 12px;
  align-items: center; margin-bottom: 24px; margin-top: 16px;
}
.compat-person {
  background: var(--surface); border: 2px solid var(--black);
  box-shadow: var(--shadow); padding: 14px 12px;
  text-align: center;
}
.compat-person-eyebrow { font-size: 7px; color: var(--pink); letter-spacing: 0.2em; margin-bottom: 6px; }
.compat-person-name { font-family: var(--sans); font-size: 16px; font-weight: 700; margin-bottom: 6px; }
.compat-person-meta { display: flex; flex-direction: column; gap: 2px; font-size: 11px; color: var(--subtext); font-family: var(--sans); }
.compat-vs { font-size: 32px; color: var(--pink); }

.compat-score {
  background: var(--surface); border: 3px solid var(--black);
  box-shadow: 6px 6px 0 var(--pink); padding: 20px; text-align: center;
}
.compat-score-label { font-size: 8px; color: var(--subtext); letter-spacing: 0.2em; margin-bottom: 8px; }
.compat-score-num { font-size: 38px; color: var(--pink); margin-bottom: 12px; }
.compat-score-bar {
  height: 14px; background: #fff; border: 2px solid var(--black);
  box-shadow: 2px 2px 0 var(--black); overflow: hidden; margin-bottom: 12px;
}
.compat-score-fill { height: 100%; background: repeating-linear-gradient(90deg, var(--pink) 0 8px, #ff6ba0 8px 16px); transition: width 0.6s, background 0.3s; }
.compat-score-fill[data-band="high"] { background: repeating-linear-gradient(90deg, var(--green) 0 8px, #4dd982 8px 16px); }
.compat-score-fill[data-band="mid"] { background: repeating-linear-gradient(90deg, var(--gold) 0 8px, #f5d169 8px 16px); }
.compat-score-fill[data-band="low"] { background: repeating-linear-gradient(90deg, var(--pink) 0 8px, #ff6ba0 8px 16px); }
.compat-score[data-band="high"] { box-shadow: 6px 6px 0 var(--green); }
.compat-score[data-band="high"] .compat-score-num { color: var(--green); }
.compat-score[data-band="mid"] { box-shadow: 6px 6px 0 var(--gold); }
.compat-score[data-band="mid"] .compat-score-num { color: var(--gold); }
.compat-score[data-band="low"] { box-shadow: 6px 6px 0 var(--pink); }
.compat-score[data-band="low"] .compat-score-num { color: var(--pink); }
.compat-score-comment { font-family: var(--sans); font-size: 13px; color: var(--text); }

/* ============ Yearly (연도별) ============ */
.yearly-section { padding: 24px 0 48px; background: var(--bg); }
.yearly-tabs {
  display: flex; gap: 0; margin-bottom: 20px;
  border: 2px solid var(--black); box-shadow: var(--shadow);
}
.yearly-tab {
  flex: 1; padding: 14px 8px;
  background: var(--surface); border: 0; cursor: pointer;
  font-size: 11px; letter-spacing: 0.06em;
}
.yearly-tab + .yearly-tab { border-left: 2px solid var(--black); }
.yearly-tab-active { background: var(--pink); color: #fff; }

.yearly-timeline { display: flex; flex-direction: column; gap: 10px; }
/* yearly-card: chapter-card 단일 컬럼 사용 (2026-05-10: grid 제거 — chapter-body 컬럼 squish 버그) */
.yearly-card {
  /* layout은 chapter-card 사용. yearly만의 색깔/액센트만 여기에 */
}
.yearly-card-current {
  background: linear-gradient(90deg, #fff 0%, #fff8ec 100%);
  box-shadow: 4px 4px 0 var(--pink);
}
.yearly-card-year { font-size: 18px; color: var(--pink); }
.yearly-card-age { font-size: 11px; color: var(--subtext); font-family: var(--sans); margin-top: 2px; }
.yearly-card-quote { font-family: var(--sans); font-size: 14px; line-height: 1.6; grid-column: 1 / -1; margin-top: 8px; }
.yearly-card-tip {
  font-size: 9px; color: var(--gold); letter-spacing: 0.1em;
  grid-column: 1 / -1; padding: 4px 8px; background: #fff8ec; border: 2px solid var(--gold);
  width: fit-content;
}

/* ============ Big Fortune (대운) ============ */
.big-fortune-section { padding: 24px 0 48px; background: var(--bg); }
.big-fortune-timeline { display: flex; flex-direction: column; gap: 14px; margin-bottom: 32px; }

/* 인생 굴곡 그래프 (2026-05-20) */
.life-graph {
  background: var(--surface);
  border: 2px solid var(--black);
  box-shadow: 4px 4px 0 var(--purple, #7a4ec8);
  padding: 16px 14px 12px;
  margin-bottom: 28px;
}
.life-graph-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 6px;
}
.life-graph-eyebrow {
  font-size: 10px;
  letter-spacing: 0.1em;
  color: var(--purple, #7a4ec8);
}
.life-graph-hint {
  font-size: 11px;
  color: var(--subtext);
  font-family: var(--sans);
}
.life-graph svg {
  width: 100%;
  height: auto;
  display: block;
}
.life-graph .lg-point:hover circle:nth-of-type(2) {
  transform-origin: center;
  filter: drop-shadow(0 0 6px rgba(255,61,127,0.5));
}
.big-fortune-card {
  background: var(--surface); border: 2px solid var(--black);
  box-shadow: var(--shadow); padding: 18px 20px;
}
.big-fortune-card-current { background: linear-gradient(90deg, #fff 0%, #fff8ec 100%); box-shadow: 6px 6px 0 var(--pink); }
.big-fortune-card-locked { background: linear-gradient(180deg, #fff 0%, #f4f3ef 100%); }
.big-fortune-card-age { font-size: 10px; color: var(--pink); letter-spacing: 0.1em; margin-bottom: 8px; display: flex; align-items: center; gap: 8px; }
.bf-now-badge {
  font-size: 8px; padding: 2px 6px; background: var(--pink); color: #fff;
  border: 2px solid var(--black); letter-spacing: 0.1em;
}
.big-fortune-card-title { font-size: 14px; margin-bottom: 12px; letter-spacing: 0.04em; }
.big-fortune-card-body { font-family: var(--sans); font-size: 14px; line-height: 1.75; color: var(--text); margin-bottom: 12px; }
.big-fortune-card-body p { margin: 0 0 16px; }
.big-fortune-card-body p:last-child { margin-bottom: 0; }

/* 본문 안 섹션 구분선 (🌊 인생 흐름 / 💼 일·직업) */
.bf-section-divider {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 4px 0 14px;
  padding: 8px 12px;
  background: linear-gradient(90deg, #fff4d6 0%, #fff8ec 100%);
  border-left: 4px solid var(--pink);
  border-radius: 2px;
}
.bf-section-divider:not(:first-child) { margin-top: 22px; }
.bf-section-icon { font-size: 16px; line-height: 1; }
.bf-section-label {
  font-size: 9px;
  letter-spacing: 0.16em;
  color: var(--black);
  font-weight: 700;
}

/* 대운 카드 — 아코디언(시기별 탭 접기/펴기) */
.big-fortune-card { cursor: pointer; position: relative; padding-right: 44px; }
.big-fortune-card-locked { cursor: default; }
.big-fortune-card-header { display: block; }
.bf-toggle-icon {
  position: absolute;
  right: 16px;
  top: 16px;
  width: 20px;
  height: 20px;
  display: grid;
  place-items: center;
  font-family: var(--pixel);
  font-size: 12px;
  color: var(--subtext);
  transition: transform 0.18s ease;
  pointer-events: none;
}
.big-fortune-card-locked .bf-toggle-icon { display: none; }
.big-fortune-card-collapsed .big-fortune-card-body { display: none; }
.big-fortune-card-collapsed .big-fortune-card-title { margin-bottom: 0; }
.big-fortune-card-open .bf-toggle-icon { transform: rotate(180deg); color: var(--pink); }
.big-fortune-card:not(.big-fortune-card-locked):hover { transform: translate(-1px, -1px); box-shadow: 7px 7px 0 var(--pink); transition: transform .1s, box-shadow .1s; }

/* ============================================================
   📂 입력된 사주 정보 — 모든 결과 페이지 통합 UI
   ============================================================ */
.saju-input-card {
  display: block;
  background: #fff;
  border: 2.5px solid var(--black);
  box-shadow: 3px 3px 0 var(--black);
  padding: 10px 14px 12px;
  margin-bottom: 16px;
  font-family: var(--sans);
}
.saju-input-card-label {
  display: inline-block;
  font-family: var(--pixel);
  font-size: 8px;
  letter-spacing: 0.18em;
  color: var(--pink);
  background: #fff;
  border: 2px solid var(--pink);
  padding: 3px 7px;
  margin-bottom: 8px;
}
.saju-input-card-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 12px;
  align-items: center;
}
.saju-input-chip {
  font-size: 12px;
  color: var(--text);
  font-weight: 500;
  white-space: nowrap;
}
.saju-input-chip strong {
  color: var(--black);
  font-weight: 700;
}
.saju-input-divider { color: var(--subtext); opacity: 0.5; }
@media (max-width: 400px) {
  .saju-input-card { padding: 9px 12px 11px; }
  .saju-input-chip { font-size: 11px; }
  .saju-input-card-label { font-size: 7px; }
}

/* ============ Bottom Nav (사주아이 미러링) ============ */
body { padding-bottom: var(--bnav-pad); } /* nav 영역만큼 콘텐츠에 여유 + iOS safe-area */

.bottom-nav {
  position: fixed;
  left: 0; right: 0; bottom: 0;
  z-index: 80;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  align-items: end;
  background: var(--surface);
  border-top: 4px solid var(--black);
  box-shadow: 0 -4px 0 rgba(17,17,17,0.08);
  padding: 10px 0 calc(10px + env(safe-area-inset-bottom, 0px));
  font-family: var(--sans);
}

.bnav-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 4px 6px;
  color: var(--subtext);
  text-decoration: none;
  transition: transform 0.08s, color 0.08s;
}
.bnav-item:hover { text-decoration: none; transform: translateY(-1px); }
.bnav-item.bnav-active { color: var(--pink); }
.bnav-item.bnav-active .bnav-icon svg { stroke: var(--pink); }

.bnav-icon {
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
}
.bnav-icon svg {
  width: 26px;
  height: 26px;
  stroke: currentColor;
}

.bnav-label {
  font-size: 11px;
  letter-spacing: 0.04em;
  line-height: 1;
  font-weight: 500;
}

/* 가운데 홈 — 평면 핑크 원형 (이전 디자인 유지) */
.bnav-center {
  position: relative;
  margin-top: -28px; /* 위로 솟음 */
}
.bnav-icon-circle {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  border: 3px solid var(--black);
  background: linear-gradient(135deg, #c4a8ff 0%, #ff2d78 100%);
  display: grid;
  place-items: center;
  box-shadow: 0 4px 0 rgba(17,17,17,0.18), inset 0 -3px 0 rgba(17,17,17,0.12);
  margin-bottom: 4px;
}
.bnav-icon-circle svg {
  width: 36px;
  height: 36px;
  image-rendering: pixelated;
}
.bnav-center .bnav-label { color: var(--text); font-weight: 700; }

@media (max-width: 380px) {
  .bnav-label { font-size: 10px; }
  .bnav-icon-circle { width: 48px; height: 48px; }
  .bnav-icon-circle svg { width: 32px; height: 32px; }
  .bnav-center { margin-top: -22px; }
}

/* ============ Buttons ============ */
.btn-game {
  font-family: var(--pixel);
  font-size: 10px;
  border: 2px solid var(--black);
  padding: 14px 24px;
  cursor: pointer;
  letter-spacing: 0.1em;
  transition: transform 0.08s, box-shadow 0.08s;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border-radius: 0;
  line-height: 1;
  text-decoration: none;
}
.btn-game:hover {
  transform: translate(-2px, -2px);
}
.btn-game:active {
  transform: translate(2px, 2px);
}

.btn-pink {
  background: var(--pink);
  color: #fff;
  box-shadow: 4px 4px 0 var(--black);
}
.btn-pink:hover { box-shadow: 6px 6px 0 var(--black); }
.btn-pink:active { box-shadow: 2px 2px 0 var(--black); }

.btn-black {
  background: var(--black);
  color: #fff;
  box-shadow: 4px 4px 0 var(--pink);
}
.btn-black:hover { box-shadow: 6px 6px 0 var(--pink); }
.btn-black:active { box-shadow: 2px 2px 0 var(--pink); }

.btn-ghost {
  background: var(--surface);
  color: var(--black);
  box-shadow: var(--shadow);
}
.btn-ghost:hover { box-shadow: 6px 6px 0 var(--black); }
.btn-ghost:active { box-shadow: var(--shadow-sm); }

.btn-gold {
  background: var(--gold);
  color: var(--black);
  box-shadow: var(--shadow);
}
.btn-gold:hover { box-shadow: 6px 6px 0 var(--black); }
.btn-gold:active { box-shadow: var(--shadow-sm); }

/* Legacy .btn aliases — keep JS-generated buttons working */
.btn {
  font-family: var(--pixel);
  font-size: 10px;
  border: 2px solid var(--black);
  padding: 14px 24px;
  cursor: pointer;
  letter-spacing: 0.1em;
  transition: transform 0.08s, box-shadow 0.08s;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border-radius: 0;
  line-height: 1;
}
.btn:hover { transform: translate(-2px,-2px); }
.btn:active { transform: translate(2px,2px); }

.btn-primary {
  background: var(--pink);
  color: #fff;
  box-shadow: 4px 4px 0 var(--black);
}
.btn-primary:hover { box-shadow: 6px 6px 0 var(--black); }
.btn-primary:active { box-shadow: 2px 2px 0 var(--black); }

/* ============ Wizard / Input Section ============ */
#input-section {
  background: var(--bg);
  background-image: radial-gradient(circle, rgba(17,17,17,0.07) 1px, transparent 1px);
  background-size: 24px 24px;
  padding: 40px 0 80px;
}

.wizard {
  background: var(--surface);
  border: 2px solid var(--black);
  box-shadow: var(--shadow);
  padding: 32px 26px 28px;
  margin-top: 0;
  position: relative;
}

.steps {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 30px;
  position: relative;
}

.step {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  flex: 1;
  position: relative;
}

.step-circle {
  width: 34px;
  height: 34px;
  background: var(--surface2);
  border: 2px solid var(--black);
  box-shadow: var(--shadow-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  color: var(--subtext);
  font-family: var(--pixel);
  transition: background 0.15s, color 0.15s;
}

.step.active .step-circle {
  background: var(--pink);
  color: #fff;
  border-color: var(--black);
  box-shadow: var(--shadow-sm);
}

.step.done .step-circle {
  background: var(--black);
  color: #fff;
}

.step-label {
  font-size: 9px;
  color: var(--subtext);
  letter-spacing: 0.05em;
  font-family: var(--sans);
  text-align: center;
  white-space: nowrap;
}
.step.active .step-label { color: var(--black); }

.step:not(:last-child)::after {
  content: '';
  position: absolute;
  top: 17px;
  left: calc(50% + 20px);
  right: calc(-50% + 20px);
  height: 2px;
  background: repeating-linear-gradient(
    90deg,
    var(--black) 0px, var(--black) 6px,
    transparent 6px, transparent 12px
  );
}
.step.done:not(:last-child)::after {
  background: var(--black);
}

.step-content { position: relative; }

.step-title {
  font-family: var(--pixel);
  font-size: 12px;
  margin-bottom: 6px;
  letter-spacing: 0.05em;
  color: var(--black);
}
.step-subtitle {
  color: var(--subtext);
  font-size: 12px;
  margin-bottom: 22px;
  font-family: var(--sans);
}

/* Year stepper */
.year-stepper {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  margin-bottom: 24px;
  padding: 20px;
  background: var(--surface2);
  border: 2px solid var(--black);
  box-shadow: var(--shadow-sm);
}

.year-btn {
  width: 40px;
  height: 40px;
  background: var(--black);
  color: #fff;
  font-size: 18px;
  font-weight: 700;
  border: 2px solid var(--black);
  box-shadow: var(--shadow-sm);
  transition: transform 0.08s, box-shadow 0.08s;
  display: flex;
  align-items: center;
  justify-content: center;
}
.year-btn:hover {
  background: var(--pink);
  transform: translate(-1px, -1px);
  box-shadow: 3px 3px 0 var(--black);
}
.year-btn:active {
  transform: translate(1px, 1px);
  box-shadow: 1px 1px 0 var(--black);
}

.year-display {
  font-family: var(--pixel);
  font-size: 24px;
  color: var(--black);
  letter-spacing: 0.04em;
  min-width: 110px;
  text-align: center;
}
.year-display .suffix {
  font-size: 11px;
  color: var(--subtext);
  margin-left: 4px;
}

/* Section labels */
.field-label {
  font-size: 9px;
  color: var(--black);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin: 18px 0 10px;
  font-family: var(--pixel);
}

/* Tab grid (months, days, hours) */
.tab-grid { display: grid; gap: 6px; }
.tab-grid.cols-4 { grid-template-columns: repeat(4, 1fr); }
.tab-grid.cols-6 { grid-template-columns: repeat(6, 1fr); }
.tab-grid.cols-7 { grid-template-columns: repeat(7, 1fr); }
.tab-grid.cols-3 { grid-template-columns: repeat(3, 1fr); }
.tab-grid.cols-2 { grid-template-columns: repeat(2, 1fr); }

/* 6-col unknown pill spans full width */
.tab-grid.cols-6 .pill.unknown { grid-column: span 6; }


/* Pill buttons */
.pill {
  background: var(--surface);
  border: 2px solid var(--black);
  color: var(--text);
  padding: 10px 6px;
  font-size: 12px;
  text-align: center;
  transition: transform 0.08s, box-shadow 0.08s, background 0.08s;
  font-family: var(--sans);
  cursor: pointer;
  box-shadow: var(--shadow-sm);
  line-height: 1.2;
}
.pill:hover:not(:disabled) {
  background: var(--surface2);
  transform: translate(-1px, -1px);
  box-shadow: 3px 3px 0 var(--black);
}
.pill.active {
  background: var(--pink);
  color: #fff;
  border-color: var(--black);
  font-weight: 600;
  box-shadow: inset 1px 1px 0 rgba(255,255,255,0.2);
  transform: translate(1px, 1px);
}
.pill:disabled {
  opacity: 0.25;
  cursor: not-allowed;
  box-shadow: none;
}

.pill.hour {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 10px 4px;
  gap: 3px;
  font-family: var(--serif);
}
.pill.hour .name { font-size: 13px; font-weight: 500; }
.pill.hour .range { font-size: 9px; color: var(--subtext); font-family: var(--sans); }
.pill.hour.active .range { color: rgba(255,255,255,0.75); }

.pill.unknown {
  grid-column: span 4;
  margin-top: 6px;
  padding: 12px;
  background: var(--surface2);
  border: 2px dashed var(--black);
  font-family: var(--sans);
  font-size: 13px;
  color: var(--subtext);
}
/* 모름 버튼 — 진짜 체크박스 (□ → ☑) */
.pill.unknown {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}
.pill.unknown.active {
  background: var(--purple);
  border-style: solid;
  color: #fff;
  border-color: var(--black);
  font-weight: 600;
}
.unknown-checkbox {
  display: inline-block;
  width: 18px;
  height: 18px;
  border: 2px solid var(--black);
  background: #fff;
  vertical-align: middle;
  position: relative;
  flex-shrink: 0;
}
.unknown-checkbox.checked::after {
  content: '✓';
  position: absolute;
  top: -3px;
  left: 1px;
  font-size: 16px;
  font-weight: 700;
  color: var(--black);
  line-height: 16px;
}
.pill.unknown.active .unknown-checkbox {
  background: #fff;
}
.unknown-label {
  display: inline-block;
}

/* 이번 달 운명 — 12개월 탭 (사용자 요청 #5) */
.month-tabs {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 4px;
  margin-bottom: 4px;
}
.month-tab {
  padding: 10px 4px;
  min-height: 44px; /* WCAG 2.2 AA 터치 타겟 */
  border: 2px solid var(--border-soft);
  background: var(--surface);
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.15s;
}
.month-tab:hover { border-color: var(--black); }
.month-tab.month-tab-current {
  border-color: var(--gold);
  background: #fff8ec;
}
.month-tab.month-tab-active {
  background: var(--pink);
  color: #fff;
  border-color: var(--black);
}
@media (max-width: 480px) {
  .month-tabs { grid-template-columns: repeat(4, 1fr); }
  .month-tab { font-size: 11px; padding: 8px 2px; }
}

/* 연/월 슬라이더 (이번 달 운명) */
.ym-picker {
  background: var(--surface);
  border: 2.5px solid var(--black);
  box-shadow: 3px 3px 0 var(--black);
  padding: 14px 14px 12px;
  margin-bottom: 14px;
}
.ym-year-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 18px;
  margin-bottom: 12px;
}
.ym-year {
  font-size: 16px;
  letter-spacing: 0.06em;
  color: var(--black);
  min-width: 70px;
  text-align: center;
}
.ym-year-btn {
  width: 36px;
  height: 36px;
  border: 2px solid var(--black);
  background: var(--surface);
  color: var(--black);
  font-size: 14px;
  cursor: pointer;
  box-shadow: 2px 2px 0 var(--black);
  transition: transform .1s, box-shadow .1s, opacity .15s;
}
.ym-year-btn:hover { transform: translate(-1px, -1px); box-shadow: 3px 3px 0 var(--black); }
.ym-year-btn:disabled { opacity: 0.35; cursor: not-allowed; box-shadow: 1px 1px 0 var(--black); transform: none; }

/* 연도별 운세 picker (사용자 요청 #4 — 드롭다운 + 한 연도씩) */
.yearly-picker {
  background: var(--surface);
  border: 2px solid var(--black);
  box-shadow: var(--shadow);
  padding: 16px 18px;
  margin-bottom: 20px;
}
.yearly-picker-label {
  display: block;
  font-size: 11px;
  letter-spacing: 0.08em;
  margin-bottom: 8px;
  color: var(--text);
}
.yearly-select {
  width: 100%;
  padding: 12px 10px;
  border: 2px solid var(--black);
  background: var(--surface2);
  font-family: var(--sans);
  font-size: 14px;
  cursor: pointer;
}
.yearly-select:focus {
  outline: none;
  background: #fff;
  box-shadow: 3px 3px 0 var(--black);
}

/* 궁합 책장 picker — 두 사주 자유 선택 (사용자 요청 #7) */
.compat-picker {
  background: var(--surface);
  border: 2px solid var(--black);
  box-shadow: var(--shadow);
  padding: 22px 18px;
  margin: 16px 0 32px;
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
}
.picker-eyebrow {
  font-size: 12px;
  text-align: center;
  letter-spacing: 0.06em;
  margin-bottom: 16px;
  color: var(--text);
}
.picker-slots {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 12px;
  align-items: center;
  margin-bottom: 14px;
}
.picker-slot {
  background: var(--surface2);
  border: 2px dashed var(--border-soft);
  padding: 14px 12px;
  text-align: center;
  min-height: 70px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.picker-slot.filled {
  border-style: solid;
  border-color: var(--pink);
  background: #fff;
  box-shadow: 3px 3px 0 var(--pink);
}
.picker-slot-label {
  font-size: 9px;
  letter-spacing: 0.1em;
  color: var(--subtext);
  margin-bottom: 6px;
}
.picker-slot.filled .picker-slot-label { color: var(--pink); }
.picker-slot-name {
  font-size: 13px;
  color: var(--text);
  word-break: keep-all;
}
.picker-vs {
  font-size: 24px;
  color: var(--pink);
  font-weight: 700;
}
.picker-go-btn {
  display: block;
  width: 100%;
  margin-bottom: 18px;
}
.picker-go-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.picker-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 10px;
  margin-bottom: 16px;
}
.picker-card {
  background: var(--surface);
  border: 2px solid var(--border-soft);
  padding: 14px 10px;
  cursor: pointer;
  text-align: center;
  font-family: var(--sans);
  transition: all 0.15s;
  position: relative;
}
.picker-card:hover { border-color: var(--black); }
.picker-card.selected {
  border-color: var(--pink);
  background: #fff5f9;
  box-shadow: 3px 3px 0 var(--pink);
}
.picker-card.selected::after {
  content: attr(data-order);
  position: absolute;
  top: -6px;
  right: -6px;
  width: 22px;
  height: 22px;
  line-height: 18px;
  text-align: center;
  background: var(--pink);
  color: #fff;
  border: 2px solid var(--black);
  font-family: var(--pixel);
  font-size: 11px;
}
.picker-card.selected-1::after { content: '1'; }
.picker-card.selected-2::after { content: '2'; }
.picker-card-icon { font-size: 24px; margin-bottom: 6px; }
.picker-card-name {
  font-size: 12px;
  letter-spacing: 0.04em;
  margin-bottom: 4px;
  color: var(--text);
}
.picker-card-meta {
  font-size: 10px;
  color: var(--subtext);
  line-height: 1.5;
  word-break: keep-all;
  margin-bottom: 6px;
}
.picker-card-tag {
  font-size: 8px;
  background: var(--surface2);
  padding: 2px 6px;
  display: inline-block;
  letter-spacing: 0.08em;
  color: var(--subtext);
}
.picker-empty {
  grid-column: 1 / -1;
  text-align: center;
  padding: 28px 16px;
  color: var(--subtext);
  font-size: 13px;
  line-height: 1.7;
}
.picker-add-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.picker-add-btn {
  font-size: 11px !important;
  padding: 10px 8px !important;
}
.picker-relation-row {
  margin-bottom: 14px;
  background: var(--surface2);
  padding: 12px 14px;
  border: 2px solid var(--border-soft);
}
.picker-relation-label {
  font-size: 10px;
  letter-spacing: 0.1em;
  color: var(--subtext);
  margin-bottom: 8px;
}
.picker-relation-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(85px, 1fr));
  gap: 6px;
}
.picker-rel-btn {
  padding: 10px 6px;
  border: 2px solid var(--border-soft);
  background: var(--surface);
  font-family: var(--sans);
  font-size: 12px;
  cursor: pointer;
  transition: all 0.15s;
}
.picker-rel-btn:hover { border-color: var(--black); }
.picker-rel-btn.active {
  background: var(--pink);
  color: #fff;
  border-color: var(--black);
  box-shadow: 2px 2px 0 var(--black);
}

/* MBTI 4축 토글 (메인 위저드 — 사용자 요청 #4) */
.mbti-axis-wrap {
  display: flex;
  flex-direction: column;
  gap: 18px;
  margin: 20px 0;
}
.mbti-axis-row {
  background: var(--surface);
  border: 2px solid var(--black);
  box-shadow: var(--shadow);
  padding: 14px 16px;
}
.mbti-axis-hint {
  font-size: 12px;
  color: var(--subtext);
  margin-bottom: 10px;
  line-height: 1.6;
}
.mbti-axis-toggle {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.mbti-axis-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 14px 10px;
  background: var(--surface2);
  border: 2px solid var(--border-soft);
  font-family: var(--sans);
  cursor: pointer;
  transition: all 0.15s;
  min-height: 64px;
}
.mbti-axis-btn:hover {
  border-color: var(--black);
}
.mbti-axis-btn.active {
  background: var(--pink);
  border-color: var(--black);
  box-shadow: 3px 3px 0 var(--black);
  color: #fff;
}
.mbti-axis-letter {
  font-family: var(--pixel);
  font-size: 22px;
  letter-spacing: 0.04em;
  margin-bottom: 4px;
}
.mbti-axis-btn.active .mbti-axis-letter { color: #fff; }
.mbti-axis-desc {
  font-size: 12px;
  color: var(--subtext);
}
.mbti-axis-btn.active .mbti-axis-desc { color: rgba(255,255,255,0.85); }

/* 직업 카드 — 라디오 동그라미 (선택 시 채워짐) */
.job-card {
  position: relative;
}
.job-card::before {
  content: '';
  position: absolute;
  top: 10px;
  right: 10px;
  width: 18px;
  height: 18px;
  border: 2px solid var(--border-soft);
  background: var(--surface);
  border-radius: 50%;
  transition: all 0.15s ease;
}
.job-card.active::before {
  background: var(--gold);
  border-color: var(--black);
  content: '✓';
  color: var(--black);
  font-size: 12px;
  font-weight: 700;
  line-height: 14px;
  text-align: center;
  font-family: var(--sans);
}

/* MBTI mini toggle (used in compat) */
.mbti-grid { display: grid; gap: 10px; margin-bottom: 20px; }
.mbti-row {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 10px;
  align-items: stretch;
}
.mbti-side {
  background: var(--surface2);
  border: 2px solid var(--black);
  padding: 12px 10px;
  text-align: center;
  transition: background 0.12s;
  cursor: pointer;
  box-shadow: var(--shadow-sm);
}
.mbti-side .letter {
  font-family: var(--pixel);
  font-size: 20px;
  color: var(--subtext);
  line-height: 1;
}
.mbti-side .label { font-size: 11px; color: var(--subtext); margin-top: 4px; }
.mbti-side .desc { font-size: 9px; color: var(--subtext); margin-top: 2px; }
.mbti-side.active {
  background: var(--gold);
  border-color: var(--black);
  box-shadow: var(--shadow-sm);
}
.mbti-side.active .letter { color: var(--black); }
.mbti-side.active .label { color: var(--black); }

.mbti-vs {
  display: flex;
  align-items: center;
  color: var(--subtext);
  font-family: var(--serif);
  font-size: 13px;
}

/* "모르겠어요" 옵션 — MBTI 없이 사주만 풀이 */
.mbti-unknown-btn {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  margin: 18px 0 0;
  padding: 14px 18px;
  background: var(--surface);
  border: 2px dashed var(--subtext);
  cursor: pointer;
  font-family: var(--sans);
  font-size: 14px;
  color: var(--text);
  transition: all 0.15s;
  text-align: left;
}
.mbti-unknown-btn:hover {
  border-color: var(--gold);
  background: var(--surface2);
}
.mbti-unknown-btn.active {
  border: 2px solid var(--gold);
  background: var(--surface2);
  box-shadow: 3px 3px 0 var(--gold);
}
.mbti-unknown-check {
  width: 18px;
  height: 18px;
  border: 2px solid var(--subtext);
  flex-shrink: 0;
  position: relative;
}
.mbti-unknown-btn.active .mbti-unknown-check {
  border-color: var(--gold);
}
.mbti-unknown-check.checked::after {
  content: '✓';
  position: absolute;
  inset: -4px 0 0 1px;
  color: var(--gold);
  font-weight: 700;
  font-size: 16px;
}
.mbti-unknown-text {
  font-weight: 500;
  line-height: 1.4;
}

.mbti-result {
  text-align: center;
  margin: 20px 0 8px;
  padding: 20px;
  background: var(--surface2);
  border: 2px solid var(--black);
  box-shadow: var(--shadow);
}
.mbti-result-type {
  font-family: var(--pixel);
  font-size: 28px;
  color: var(--purple);
  letter-spacing: 0.1em;
}
.mbti-result-name {
  font-size: 13px;
  color: var(--subtext);
  margin-top: 4px;
}

/* Gender */
.gender-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 20px;
}
.gender-card {
  padding: 22px;
  background: var(--surface2);
  border: 2px solid var(--black);
  text-align: center;
  transition: transform 0.08s, box-shadow 0.08s, background 0.08s;
  cursor: pointer;
  box-shadow: var(--shadow);
}
.gender-card:hover {
  transform: translate(-2px, -2px);
  box-shadow: 6px 6px 0 var(--black);
}
.gender-card .icon {
  font-family: var(--serif);
  font-size: 30px;
  color: var(--subtext);
}
.gender-card .label {
  margin-top: 6px;
  font-size: 13px;
  color: var(--subtext);
  font-family: var(--sans);
}
.gender-card.active {
  background: var(--gold);
  border-color: var(--black);
  box-shadow: var(--shadow-sm);
  transform: translate(1px, 1px);
}
.gender-card.active .icon { color: var(--black); }
.gender-card.active .label { color: var(--black); }

/* Wizard nav */
.wizard-nav {
  display: flex;
  gap: 10px;
  margin-top: 28px;
}
.wizard-nav button { flex: 1; }
.wizard-nav .back {
  background: var(--surface2);
  border: 2px solid var(--black);
  color: var(--subtext);
  padding: 14px;
  font-size: 11px;
  flex: 0.4;
  font-family: var(--pixel);
  box-shadow: var(--shadow-sm);
  transition: transform 0.08s, box-shadow 0.08s;
  cursor: pointer;
}
.wizard-nav .back:hover {
  color: var(--text);
  transform: translate(-1px, -1px);
  box-shadow: 3px 3px 0 var(--black);
}

/* ============ Results Section ============ */
#results-section {
  background: var(--bg);
  background-image: radial-gradient(circle, rgba(17,17,17,0.07) 1px, transparent 1px);
  background-size: 24px 24px;
  padding: 40px 0 80px;
}

.results-header {
  text-align: center;
  margin-bottom: 28px;
  padding-top: 12px;
}

.results-eyebrow {
  font-family: var(--pixel);
  font-size: 8px;
  color: var(--pink);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  margin-bottom: 10px;
}

.results-title {
  font-family: var(--serif);
  font-size: 24px;
  font-weight: 500;
  color: var(--black);
  letter-spacing: -0.01em;
}

/* Pillars */
/* /result/profile/ 사주 시각화 카드 (홈페이지의 .pillars/.ohaeng 재사용) */
.saju-chart-section {
  padding: 8px 0 28px;
}
.saju-chart-card {
  background: var(--surface);
  border: 2px solid var(--black);
  box-shadow: var(--shadow);
  padding: 22px 18px 18px;
}
.saju-chart-eyebrow {
  font-size: 9px;
  letter-spacing: 0.2em;
  color: var(--pink);
  margin-bottom: 14px;
}
.saju-chart-meta {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 8px;
}
.saju-strength {
  font-family: var(--sans);
  font-size: 13px;
  color: var(--subtext);
  text-align: center;
  padding: 8px 0 4px;
  letter-spacing: 0.04em;
}

.pillars {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  margin-bottom: 24px;
}
@media (max-width: 520px) {
  .pillars { grid-template-columns: repeat(2, 1fr); }
}

.pillar {
  background: var(--surface);
  border: 2px solid var(--black);
  box-shadow: var(--shadow);
  padding: 14px 8px 12px;
  text-align: center;
  position: relative;
  transition: transform 0.08s, box-shadow 0.08s;
}
.pillar:hover {
  transform: translate(-2px, -2px);
  box-shadow: 6px 6px 0 var(--black);
}

.pillar-label {
  font-family: var(--pixel);
  font-size: 7px;
  letter-spacing: 0.2em;
  color: var(--pink);
  text-transform: uppercase;
  margin-bottom: 10px;
}

.pillar-stem,
.pillar-branch {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 4px 0;
}

.pillar-hanja {
  font-family: var(--serif);
  font-size: 32px;
  font-weight: 600;
  line-height: 1;
  color: var(--black);
}

.pillar-kr {
  font-size: 10px;
  color: var(--subtext);
  margin-top: 3px;
  font-family: var(--sans);
}

.pillar-divider {
  height: 2px;
  background: var(--black);
  margin: 5px 4px;
}

.pillar-element {
  display: inline-block;
  margin-top: 8px;
  padding: 3px 8px;
  font-size: 10px;
  font-family: var(--pixel);
  border: 2px solid var(--black);
  box-shadow: 1px 1px 0 var(--black);
  background: var(--surface);
}

.elem-木 { color: #22a86a; background: #e0f7ed; }
.elem-火 { color: #c43a1a; background: #fce8e2; }
.elem-土 { color: #9a6a10; background: #fef5e0; }
.elem-金 { color: #5a6070; background: #e8eaf0; }
.elem-水 { color: #1a60b0; background: #e0eeff; }

.pillar.unknown {
  border-style: dashed;
  opacity: 0.5;
}

/* MBTI badge */
.mbti-badge {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin: 0 auto 24px;
  padding: 14px 20px;
  width: fit-content;
  background: var(--surface);
  border: 2px solid var(--black);
  box-shadow: var(--shadow);
}
.mbti-badge .type {
  font-family: var(--pixel);
  font-size: 16px;
  color: var(--purple);
  letter-spacing: 0.1em;
}
.mbti-badge .sep { color: var(--subtext); }
.mbti-badge .name { font-size: 13px; color: var(--text); font-family: var(--sans); }

/* Ohaeng */
.ohaeng {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 6px;
  margin-bottom: 24px;
}
.ohaeng-item {
  background: var(--surface);
  border: 2px solid var(--black);
  box-shadow: var(--shadow-sm);
  padding: 10px 6px;
  text-align: center;
}
.ohaeng-item .el {
  font-family: var(--pixel);
  font-size: 14px;
  font-weight: 600;
}
.ohaeng-item .ct {
  font-size: 11px;
  color: var(--subtext);
  margin-top: 4px;
  font-family: var(--sans);
}

/* Tabs */
.tabs {
  display: flex;
  gap: 0;
  background: var(--surface);
  border: 2px solid var(--black);
  box-shadow: var(--shadow);
  margin-bottom: 20px;
  position: sticky;
  top: 66px;
  z-index: 5;
}

.tab-btn {
  flex: 1;
  padding: 13px 10px;
  font-size: 11px;
  color: var(--subtext);
  transition: background 0.1s, color 0.1s;
  font-family: var(--sans);
  font-weight: 500;
  border-right: 2px solid var(--black);
  text-align: center;
}
.tab-btn:last-child { border-right: none; }
.tab-btn:hover { color: var(--text); background: var(--surface2); }
.tab-btn.active {
  background: var(--black);
  color: #fff;
  font-weight: 600;
  border-bottom: 3px solid var(--pink);
}

.tab-content { animation: fadeIn 0.25s ease; }
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Reading card */
.reading-card {
  background: var(--surface);
  border: 2px solid var(--black);
  box-shadow: var(--shadow);
  padding: 22px 20px;
  margin-bottom: 12px;
}

.reading-text {
  font-family: var(--serif);
  font-size: 15px;
  line-height: 1.95;
  color: var(--text);
  white-space: pre-wrap;
  word-break: keep-all;
}
.reading-text strong,
.reading-text b {
  color: var(--pink);
  font-weight: 700;
  display: block;
  margin-top: 16px;
  margin-bottom: 4px;
  font-size: 13px;
  letter-spacing: 0.04em;
  font-family: var(--pixel);
}
.reading-text strong:first-child,
.reading-text b:first-child { margin-top: 0; }

/* Skeleton */
.skeleton { display: flex; flex-direction: column; gap: 10px; padding: 4px 0; }
.skeleton-line {
  height: 12px;
  background: linear-gradient(90deg, var(--surface2) 0%, #e8e7e3 50%, var(--surface2) 100%);
  background-size: 200% 100%;
  animation: shimmer 1.4s linear infinite;
  border: 1px solid rgba(17,17,17,0.08);
}
.skeleton-line.short { width: 55%; }
.skeleton-line.medium { width: 78%; }
@keyframes shimmer {
  from { background-position: 200% 0; }
  to { background-position: -200% 0; }
}

/* Year timeline */
.yearly-list {
  display: flex;
  flex-direction: column;
  gap: 4px;
  position: relative;
}
.yearly-list::before {
  content: '';
  position: absolute;
  left: 60px;
  top: 16px;
  bottom: 16px;
  width: 2px;
  background: repeating-linear-gradient(
    180deg,
    var(--black) 0px, var(--black) 6px,
    transparent 6px, transparent 12px
  );
}

.year-row {
  display: grid;
  grid-template-columns: 52px 20px 1fr;
  gap: 12px;
  align-items: flex-start;
  padding: 12px 14px 12px 0;
  background: var(--surface);
  border: 2px solid var(--black);
  box-shadow: var(--shadow-sm);
  cursor: pointer;
  transition: transform 0.08s, box-shadow 0.08s;
  position: relative;
}
.year-row:hover {
  transform: translate(-2px, -2px);
  box-shadow: 4px 4px 0 var(--black);
}
.year-row.past { opacity: 0.65; }
.year-row.current {
  border-color: var(--pink);
  box-shadow: 4px 4px 0 var(--pink);
  border-left: 4px solid var(--pink);
}

.year-row .yr-label {
  font-family: var(--pixel);
  font-size: 8px;
  color: var(--text);
  text-align: right;
  padding-top: 3px;
  padding-left: 10px;
  line-height: 1.6;
}
.year-row.past .yr-label { color: var(--subtext); }
.year-row.current .yr-label { color: var(--pink); }

.year-row .yr-dot {
  width: 12px;
  height: 12px;
  background: var(--surface2);
  border: 2px solid var(--black);
  margin: 5px auto 0;
  position: relative;
  z-index: 1;
}
.year-row.current .yr-dot {
  background: var(--pink);
  border-color: var(--black);
}
.year-row.future .yr-dot { border-color: var(--purple); }

.yr-body { padding-top: 2px; }
.yr-ganzhi {
  font-family: var(--serif);
  font-size: 13px;
  color: var(--gold);
  margin-bottom: 3px;
  font-weight: 600;
}
.yr-hint { font-size: 11px; color: var(--subtext); font-family: var(--sans); }
.yr-text {
  font-family: var(--serif);
  font-size: 13px;
  line-height: 1.9;
  color: var(--text);
  margin-top: 10px;
  white-space: pre-wrap;
  word-break: keep-all;
  border-top: 1px solid rgba(17,17,17,0.1);
  padding-top: 10px;
}

/* Section cards (profile accordion) */
.section-card {
  border: 2px solid var(--black);
  overflow: hidden;
  margin-bottom: 8px;
  background: var(--surface);
  transition: box-shadow 0.08s, transform 0.08s;
  box-shadow: var(--shadow-sm);
  border-left: 4px solid rgba(17,17,17,0.2);
}
.section-card:hover {
  transform: translate(-1px, -1px);
  box-shadow: 3px 3px 0 var(--black);
}
.section-card.open {
  border-left-color: var(--pink);
  box-shadow: var(--shadow);
}
.section-card:first-of-type {
  border-left-color: var(--purple);
}
.section-card:first-of-type .section-tag {
  color: var(--purple);
  border-color: var(--purple);
}

.section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 13px 16px;
  cursor: pointer;
  user-select: none;
  gap: 10px;
}

.section-header-left {
  display: flex;
  align-items: baseline;
  gap: 10px;
  flex: 1;
  min-width: 0;
}

.section-tag {
  flex-shrink: 0;
  font-family: var(--pixel);
  font-size: 7px;
  letter-spacing: 0.12em;
  color: var(--pink);
  border: 2px solid var(--pink);
  padding: 3px 7px;
  background: var(--surface);
}

.section-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  font-family: var(--serif);
  line-height: 1.4;
  white-space: normal;
  word-break: keep-all;
}

.section-chevron {
  font-size: 14px;
  color: var(--subtext);
  transition: transform 0.2s;
  flex-shrink: 0;
}
.section-card.open .section-chevron {
  transform: rotate(180deg);
  color: var(--pink);
}

.section-body {
  display: none;
  padding: 0 16px 16px;
  font-size: 13px;
  line-height: 2;
  color: var(--text);
  border-top: 2px solid var(--black);
  padding-top: 14px;
  animation: fadeIn 0.2s ease;
  font-family: var(--serif);
}
.section-card.open .section-body { display: block; }

/* API 로딩 */
.api-loading {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding: 32px 16px;
}
.api-loading-msg {
  font-size: 13px;
  color: var(--subtext);
  font-family: var(--sans);
  text-align: center;
  animation: fade-cycle 7s steps(1) infinite;
}
.api-loading-timer {
  font-family: var(--pixel);
  font-size: 11px;
  color: var(--pink);
  letter-spacing: 0.1em;
}
@keyframes fade-cycle {
  0%, 49% { opacity: 1; }
  50%, 100% { opacity: 0.6; }
}

/* Streaming caret */
.streaming::after {
  content: '▍';
  color: var(--pink);
  margin-left: 2px;
  animation: blink 0.8s infinite;
}
@keyframes blink {
  0%, 49% { opacity: 1; }
  50%, 100% { opacity: 0; }
}

/* ============ PROFILE LOADING SCREEN ============ */
.profile-loading-wrap {
  padding: 48px 24px 56px;
  display: flex;
  justify-content: center;
}
.profile-loading-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
  width: 100%;
  max-width: 320px;
}
.pl-orbs {
  position: relative;
  width: 88px;
  height: 88px;
}
.pl-orb {
  position: absolute;
  font-family: var(--pixel);
  color: var(--pink);
  animation: orbit-spin 3s linear infinite;
  transform-origin: 44px 44px;
}
.pl-orb1 { font-size: 10px; top: 0;   left: 38px; animation-delay: 0s;    }
.pl-orb2 { font-size: 9px;  top: 38px; right: 0;   animation-delay: -0.75s; color: var(--gold); }
.pl-orb3 { font-size: 10px; bottom: 0; left: 38px; animation-delay: -1.5s;  }
.pl-orb4 { font-size: 9px;  top: 38px; left: 0;    animation-delay: -2.25s; color: var(--purple); }
@keyframes orbit-spin {
  0%   { transform: rotate(0deg)   translateY(-32px) rotate(0deg); }
  100% { transform: rotate(360deg) translateY(-32px) rotate(-360deg); }
}
.pl-symbol {
  font-size: 9px;
  color: var(--pink);
  letter-spacing: 0.15em;
  text-shadow: 2px 2px 0 rgba(255,45,120,0.25);
}
.pl-bar-wrap {
  width: 100%;
  height: 6px;
  background: var(--surface2);
  border: 2px solid var(--black);
  overflow: hidden;
}
.pl-bar-inner {
  height: 100%;
  width: 0%;
  background: var(--pink);
  transition: width 0.8s ease;
  box-shadow: 0 0 8px rgba(255,45,120,0.5);
}
.pl-label {
  font-size: 8px;
  color: var(--subtext);
  letter-spacing: 0.1em;
  text-align: center;
  min-height: 20px;
}
.pl-timer {
  font-size: 10px;
  color: rgba(255,45,120,0.5);
  letter-spacing: 0.12em;
}

/* ============ SECTION REVEAL ANIMATION ============ */
@keyframes section-enter {
  from {
    opacity: 0;
    transform: translateY(14px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.section-reveal {
  animation: section-enter 0.38s cubic-bezier(0.22, 1, 0.36, 1) both;
}

/* ============ SECTION TYPOGRAPHY IMPROVEMENTS ============ */
.section-body {
  font-size: 14px;
  line-height: 2.1;
  letter-spacing: -0.01em;
  word-break: keep-all;
}
.section-body p {
  margin: 0 0 12px;
}
.section-body p:last-child {
  margin-bottom: 0;
}

/* ============ MBTI Type Grid ============ */
.mbti-type-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
  margin-bottom: 18px;
}
.mbti-type-grid.compact { gap: 4px; }

.mbti-type-card {
  background: var(--surface2);
  border: 2px solid var(--black);
  box-shadow: var(--shadow-sm);
  padding: 9px 5px;
  text-align: center;
  cursor: pointer;
  transition: transform 0.08s, box-shadow 0.08s, background 0.08s;
}
.mbti-type-card:hover {
  background: var(--surface);
  transform: translate(-1px, -1px);
  box-shadow: 3px 3px 0 var(--black);
}
.mbti-type-card.active {
  background: var(--pink);
  border-color: var(--black);
  box-shadow: var(--shadow-sm);
  transform: translate(1px, 1px);
}

.mbti-type-card .mtc-type {
  font-family: var(--pixel);
  font-size: 9px;
  color: var(--black);
  letter-spacing: 0.05em;
  line-height: 1.3;
}
.mbti-type-card.active .mtc-type { color: #fff; }

.mbti-type-card .mtc-name {
  font-size: 9px;
  color: var(--subtext);
  margin-top: 3px;
  line-height: 1.3;
  font-family: var(--sans);
}
.mbti-type-card.active .mtc-name { color: rgba(255,255,255,0.75); }

@media (max-width: 480px) {
  .mbti-type-grid { gap: 4px; }
  .mbti-type-card { padding: 7px 3px; }
  .mbti-type-card .mtc-type { font-size: 8px; }
  .mbti-type-card .mtc-name { font-size: 8px; }
}

/* ============ Compatibility ============ */
.compat-form {
  background: var(--surface);
  border: 2px solid var(--black);
  box-shadow: var(--shadow);
  padding: 22px 20px;
  margin-bottom: 16px;
}
.compat-form h3 {
  font-family: var(--pixel);
  font-size: 10px;
  margin-bottom: 6px;
  letter-spacing: 0.06em;
  color: var(--black);
}
.compat-form .sub {
  font-size: 12px;
  color: var(--subtext);
  margin-bottom: 18px;
  font-family: var(--sans);
}

.compat-row {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 8px;
  margin-bottom: 10px;
}
.compat-row input,
.compat-row select {
  background: var(--surface2);
  border: 2px solid var(--black);
  color: var(--text);
  padding: 10px 10px;
  font-size: 13px;
  outline: none;
  transition: border-color 0.1s;
  width: 100%;
}
.compat-row input:focus,
.compat-row select:focus { border-color: var(--pink); }
.compat-row label {
  display: flex;
  flex-direction: column;
  gap: 5px;
  font-size: 10px;
  color: var(--subtext);
  letter-spacing: 0.06em;
  font-family: var(--pixel);
}

.compat-mbti-mini {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 5px;
  margin-bottom: 12px;
}
.compat-mbti-mini .mini-toggle {
  display: flex;
  background: var(--surface2);
  border: 2px solid var(--black);
  overflow: hidden;
}
.compat-mbti-mini .mini-toggle button {
  flex: 1;
  padding: 8px 0;
  font-family: var(--serif);
  font-size: 13px;
  color: var(--subtext);
  transition: background 0.1s, color 0.1s;
  cursor: pointer;
  border: none;
  background: none;
}
.compat-mbti-mini .mini-toggle button.active {
  background: var(--gold);
  color: var(--black);
  font-weight: 700;
}

.compat-result {
  background: var(--surface);
  border: 2px solid var(--black);
  box-shadow: var(--shadow);
  padding: 24px 20px;
}

.compat-score {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 20px;
  padding-bottom: 20px;
  border-bottom: 2px solid var(--black);
}
.compat-score-num {
  font-family: var(--pixel);
  font-size: clamp(40px, 10vw, 64px);
  color: var(--pink);
  letter-spacing: -0.02em;
  line-height: 1;
  text-shadow: 4px 4px 0 var(--black);
}
.compat-score-label {
  margin-top: 8px;
  font-size: 10px;
  color: var(--subtext);
  letter-spacing: 0.15em;
  font-family: var(--pixel);
}

/* ============ Modal ============ */
.modal {
  position: fixed;
  inset: 0;
  background: rgba(17, 17, 17, 0.7);
  z-index: 200;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  animation: fadeIn 0.2s ease;
}

.modal-card {
  background: var(--surface);
  border: 3px solid var(--black);
  box-shadow: 8px 8px 0 var(--black);
  padding: 32px 26px;
  max-width: 460px;
  width: 100%;
  position: relative;
}
.modal-card h3 {
  font-size: 12px;
  margin-bottom: 12px;
  color: var(--black);
  letter-spacing: 0.08em;
}
.modal-card p {
  color: var(--subtext);
  font-size: 13px;
  line-height: 1.7;
  margin-bottom: 18px;
  font-family: var(--sans);
}
.modal-card a { color: var(--pink); }
.modal-card input {
  width: 100%;
  background: var(--surface2);
  border: 2px solid var(--black);
  color: var(--text);
  padding: 12px 12px;
  font-size: 13px;
  outline: none;
  margin-bottom: 12px;
  font-family: monospace;
  box-shadow: var(--shadow-sm);
}
.modal-card input:focus { border-color: var(--pink); }

.modal-actions {
  display: flex;
  gap: 10px;
  margin-top: 4px;
}
.modal-actions button { flex: 1; justify-content: center; }

.modal-error {
  color: #c43a1a;
  font-size: 11px;
  margin-bottom: 10px;
  min-height: 16px;
  font-family: var(--sans);
}

.modal-close {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 32px;
  height: 32px;
  background: var(--surface2);
  border: 2px solid var(--black);
  color: var(--subtext);
  font-size: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: var(--shadow-sm);
  transition: transform 0.08s, background 0.08s;
}
.modal-close:hover {
  background: var(--pink);
  color: #fff;
  transform: translate(-1px, -1px);
}

/* ============ Game Loading Screen (transition overlay) ============ */
#game-loading {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: var(--bg);
  background-image: radial-gradient(circle, rgba(17,17,17,0.07) 1px, transparent 1px);
  background-size: 24px 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}

.gl-inner {
  text-align: center;
  width: min(520px, 92vw);
  padding: 40px 36px;
  background: var(--surface);
  border: 3px solid var(--black);
  box-shadow: 8px 8px 0 var(--black);
  position: relative;
}

.gl-inner::before {
  content: '';
  position: absolute;
  top: -6px;
  left: -6px;
  width: 16px;
  height: 16px;
  background: var(--pink);
  border: 2px solid var(--black);
}
.gl-inner::after {
  content: '';
  position: absolute;
  bottom: -6px;
  right: -6px;
  width: 16px;
  height: 16px;
  background: var(--pink);
  border: 2px solid var(--black);
}

.gl-blink {
  font-family: var(--pixel);
  font-size: 8px;
  color: var(--subtext);
  letter-spacing: 0.2em;
  margin-bottom: 24px;
  animation: gl-blink 1.1s steps(1) infinite;
}
@keyframes gl-blink {
  0%, 49% { opacity: 1; }
  50%, 100% { opacity: 0; }
}

.gl-title {
  font-family: var(--pixel);
  font-size: clamp(16px, 4vw, 24px);
  color: var(--black);
  margin-bottom: 6px;
  line-height: 1.7;
  letter-spacing: 0.05em;
}

.gl-sub {
  font-family: var(--pixel);
  font-size: 8px;
  color: var(--pink);
  letter-spacing: 0.1em;
  margin-bottom: 32px;
}

.gl-msg {
  font-size: 12px;
  color: var(--subtext);
  letter-spacing: 0.06em;
  margin-bottom: 16px;
  min-height: 18px;
  font-family: var(--sans);
}

.gl-bar-track {
  width: 100%;
  height: 28px;
  background: var(--surface2);
  border: 2px solid var(--black);
  box-shadow: var(--shadow-sm);
  position: relative;
  overflow: hidden;
  margin-bottom: 16px;
}

.gl-bar-fill {
  height: 100%;
  background: var(--pink);
  transition: width 0.12s linear;
  position: relative;
}
.gl-bar-fill::after {
  content: '';
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    90deg,
    transparent 0px, transparent 20px,
    rgba(255,255,255,0.25) 20px, rgba(255,255,255,0.25) 22px
  );
}

.gl-pct {
  font-family: var(--pixel);
  font-size: clamp(28px, 6vw, 40px);
  color: var(--pink);
  line-height: 1;
  text-shadow: 3px 3px 0 rgba(255,45,120,0.2);
}

/* ============ Error Banner ============ */
.error-banner {
  background: #fce8e2;
  border: 2px solid #c43a1a;
  box-shadow: var(--shadow-sm);
  color: #c43a1a;
  padding: 12px 14px;
  font-size: 13px;
  margin-bottom: 12px;
  font-family: var(--sans);
}

/* ============ Footer ============ */
.game-footer {
  background: var(--black);
  color: rgba(255,255,255,0.6);
  text-align: center;
  padding: 36px 20px 28px;
  font-size: 11px;
  letter-spacing: 0.06em;
  font-family: var(--sans);
}
.game-footer .ornament {
  font-family: var(--pixel);
  font-size: 9px;
  color: var(--gold);
  letter-spacing: 0.35em;
  margin-bottom: 10px;
}
/* ornament blink */
.game-footer .ornament {
  animation: gl-blink 3s steps(1) infinite;
}

/* Hero mark (used in JS-generated markup) */
.hero-mark {
  font-family: var(--pixel);
  font-size: clamp(32px, 10vw, 64px);
  color: var(--pink);
  display: inline-block;
  margin-bottom: 16px;
  text-shadow: 4px 4px 0 rgba(255,45,120,0.2);
}

/* Hero pixel bar (used in JS-generated markup) */
.hero-pixel-bar {
  width: 48px;
  height: 4px;
  background: var(--pink);
  margin: 0 0 20px;
  box-shadow: 2px 2px 0 var(--black);
}

/* Hero pixel tag */
.hero-pixel-tag {
  display: inline-block;
  font-family: var(--pixel);
  font-size: 7px;
  color: var(--pink);
  border: 2px solid var(--pink);
  padding: 6px 12px;
  letter-spacing: 0.12em;
  margin-bottom: 18px;
  background: #fff;
  box-shadow: 3px 3px 0 var(--pink);
}

/* ============ Summary block in wizard step 4 ============ */
#input-section .container > div > div[style] {
  border: 2px solid var(--black) !important;
  box-shadow: var(--shadow-sm) !important;
  border-radius: 0 !important;
}

/* ============ Hero stat grid (legacy) ============ */
.hero-stat-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-top: 36px;
}
.hero-stat-card {
  text-align: center;
  padding: 16px 10px;
  background: var(--surface2);
  border: 2px solid var(--black);
  box-shadow: var(--shadow-sm);
  transition: transform 0.08s, box-shadow 0.08s;
}
.hero-stat-card:hover {
  transform: translate(-2px, -2px);
  box-shadow: 4px 4px 0 var(--black);
}
.hero-stat-icon {
  font-family: var(--serif);
  font-size: 22px;
  font-weight: 700;
}
.hero-stat-label {
  font-size: 10px;
  color: var(--subtext);
  margin-top: 6px;
  line-height: 1.6;
  font-family: var(--sans);
}

/* Hero divider (used in JS hero) */
.hero-divider {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin: 36px auto 0;
  color: var(--subtext);
  font-size: 11px;
  letter-spacing: 0.25em;
  font-family: var(--pixel);
}
.hero-divider::before,
.hero-divider::after {
  content: '';
  flex: 1;
  height: 2px;
  background: repeating-linear-gradient(
    90deg,
    var(--black) 0px, var(--black) 6px,
    transparent 6px, transparent 12px
  );
}

/* =====================================================
   RESPONSIVE
   ===================================================== */

/* ── 768px: 히어로 · 통계 · 결과 레이아웃 ─────────── */
@media (max-width: 768px) {
  body { overflow-x: hidden; }

  /* Header */
  .game-header { padding: 0 16px; }
  .logo { font-size: 10px; }

  /* Hero: 세로 스택 */
  .hero-content {
    grid-template-columns: 1fr;
    text-align: center;
    gap: 16px;
    padding-top: 28px;
    padding-bottom: 28px;
  }
  .hero-left { align-items: center; }
  .hero-right { order: -1; padding: 4px; }
  .pixel-char { width: min(130px, 38vw); }
  .hero-eyebrow { font-size: 6px; }
  .hero-title.hero-title-img img { max-width: 320px; }
  .hero-sub { font-size: 13px; }
  .hero-strip { font-size: 5px; overflow: hidden; }

  /* Stats */
  .stats-section { padding: 32px 0; }
  .stats-grid { grid-template-columns: repeat(3, 1fr); gap: 6px; }
  .stat-num { font-size: 16px; }
  .stat-label { font-size: 11px; }

  /* Features */
  .features-section { padding: 40px 0 48px; }
  .features-grid { grid-template-columns: 1fr; gap: 10px; }
  .section-title-big { font-size: 14px; }
  .feature-card { padding: 20px 16px; }

  /* Results tabs */
  .tabs { top: 63px; overflow-x: auto; white-space: nowrap; }
  .tab-btn { font-size: 10px; padding: 12px 10px; min-height: 44px; white-space: nowrap; flex-shrink: 0; }

  /* Compat */
  .compat-row { grid-template-columns: 1fr 1fr; }

  /* Pillars */
  .pillars { grid-template-columns: repeat(2, 1fr); }
  .pillar-hanja { font-size: 28px; }

  /* Loaders */
  .pl-card { padding: 32px 20px; }
  .pl-pct { font-size: 36px; }
  .gl-title { font-size: 14px; }
  .gl-pct { font-size: 28px; }
}

/* ── 600px: 모바일 위저드 전체화면 ─────────────────── */
@media (max-width: 600px) {

  /* 히어로 — 자연 높이 (이전: 100svh 강제로 인한 상단 거대 빈공간 제거) */
  #hero-section {
    min-height: auto;
    display: block;
  }
  .hero-content {
    padding-top: 24px;
    padding-bottom: 32px;
    gap: 16px;
  }
  .hero-title.hero-title-img img { max-width: 280px; }
  .hero-sub {
    font-size: 14px;
    margin-bottom: 24px;
  }
  /* START 버튼 모바일 — 전체 너비, 크게 */
  .hero-left .btn-game {
    width: 100%;
    padding: 18px 0;
    font-size: 12px;
    text-align: center;
    min-height: 56px;
  }

  /* 피처 카드 섹션 모바일 compact */
  .features-section {
    padding: 28px 0 32px;
  }
  .features-cta { display: none; }

  /* 날짜 선택 드롭다운 */
  .select-row {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 8px;
    margin-bottom: 12px;
  }
  .saju-select {
    width: 100%;
    padding: 16px 4px;
    font-size: 16px; /* 16px 이상 → iOS zoom 방지 */
    font-family: var(--sans);
    font-weight: 500;
    text-align: center;
    border: 2px solid var(--black);
    box-shadow: 3px 3px 0 var(--black);
    background: var(--surface);
    color: var(--black);
    border-radius: 0;
    -webkit-appearance: none;
    appearance: none;
    cursor: pointer;
  }
  .saju-select:focus {
    outline: none;
    border-color: var(--pink);
    box-shadow: 3px 3px 0 var(--pink);
  }
  .date-preview {
    text-align: center;
    padding: 14px;
    font-family: var(--pixel);
    font-size: 9px;
    color: var(--pink);
    letter-spacing: 0.1em;
    border: 2px solid var(--pink);
    box-shadow: 3px 3px 0 var(--pink);
    background: var(--surface);
  }

  /* 위저드 모바일 레이아웃 — 콘텐츠 길면 스크롤 허용 (이전: overflow hidden으로 잘림 버그) */
  #input-section {
    padding: 0;
    min-height: calc(100svh - 63px); /* 최소 한 화면, 콘텐츠 길면 늘어남 */
    scroll-margin-top: 63px;
  }

  #input-section > .container {
    padding: 0;
    max-width: 100%;
    display: flex;
    flex-direction: column;
  }
  .wizard {
    display: flex;
    flex-direction: column;
    border: none;
    border-top: 3px solid var(--black);
    box-shadow: none;
    padding: 22px 20px 18px;
  }

  /* 스텝 인디케이터 */
  .steps { margin-bottom: 18px; }
  .step-circle { width: 28px; height: 28px; font-size: 9px; }
  .step-label { font-size: 7px; white-space: normal; line-height: 1.3; text-align: center; }
  .step:not(:last-child)::after { top: 14px; }

  /* 스텝 콘텐츠 — 콘텐츠 자연 흐름 (이전 overflow:hidden + justify-content:center로 위/아래 잘림) */
  .step-content {
    display: flex;
    flex-direction: column;
    /* overflow + justify-content:center 제거 — 콘텐츠 다 보이게 */
  }
  .step-title { font-size: 12px; margin-bottom: 4px; }
  .step-subtitle { font-size: 12px; color: var(--subtext); margin-bottom: 18px; }
  .field-label { font-size: 8px; margin: 10px 0 7px; }

  /* 다음 버튼 — 콘텐츠 바로 아래 (이전: margin-top:auto + overflow chain으로 안 보였음) */
  .wizard-nav {
    margin-top: 24px;
    padding-top: 12px;
  }
  .wizard-nav button { min-height: 48px; font-size: 10px; }
  .wizard-nav .back { min-height: 48px; font-size: 10px; }

  /* 시간 6열 그리드 */
  .tab-grid.cols-6 { gap: 5px; }
  .tab-grid.cols-6 .pill {
    min-height: 48px; padding: 5px 2px;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
  }
  .tab-grid.cols-6 .pill.hour .name { font-size: 11px; font-weight: 600; }
  .tab-grid.cols-6 .pill.hour .range { font-size: 7px; color: var(--subtext); }
  .tab-grid.cols-6 .pill.hour.active .range { color: rgba(255,255,255,0.7); }
  .tab-grid.cols-6 .pill.unknown {
    grid-column: span 6;
    min-height: 44px;
    font-size: 12px;
    flex-direction: row;
    margin-top: 4px;
  }

  /* MBTI 4×4 — 균일한 크기 */
  .mbti-type-grid {
    grid-template-columns: repeat(4, 1fr);
    gap: 5px;
    margin-bottom: 10px;
  }
  .mbti-type-card {
    min-height: 50px;
    padding: 6px 3px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
  }
  .mbti-type-card .mtc-type { font-size: 9px; }
  .mbti-type-card .mtc-name { font-size: 7px; margin-top: 2px; }
  .mbti-result { padding: 12px; margin: 10px 0 0; }
  .mbti-result-type { font-size: 22px; }
  .mbti-result-name { font-size: 12px; }

  /* 모바일 MBTI 4축 토글 — 컴팩트 (4축 모두 + 버튼이 화면에 들어오게) */
  .mbti-axis-wrap { gap: 10px; margin: 12px 0; }
  .mbti-axis-row { padding: 10px 12px; }
  .mbti-axis-hint { font-size: 11px; margin-bottom: 7px; line-height: 1.45; }
  .mbti-axis-toggle { gap: 8px; }
  .mbti-axis-btn { padding: 9px 6px; min-height: 52px; }
  .mbti-axis-letter { font-size: 18px; margin-bottom: 2px; }
  .mbti-axis-desc { font-size: 11px; }
  /* wizard 본문 끝에 bnav 가려짐 방지 — 추가 여유 */
  #input-section { padding-bottom: calc(80px + var(--bnav-pad, 0px)); }

  /* 성별 카드 */
  .gender-row { gap: 12px; }
  .gender-card { padding: 28px 16px; }
  .gender-card .icon { font-size: 36px; }
  .gender-card .label { font-size: 14px; }

  /* 결과 */
  .results-title { font-size: 18px; }
  .reading-text { font-size: 13px; line-height: 1.85; }
  .section-header { padding: 12px; min-height: 50px; }
  .section-title { font-size: 12px; }
  .section-tag { font-size: 6px; padding: 3px 5px; }
  .year-row { gap: 8px; padding: 10px 10px 10px 0; }
  .yr-ganzhi { font-size: 12px; }
  .yr-text { font-size: 12px; line-height: 1.75; }
  .yr-hint { font-size: 10px; }
  .yearly-list::before { left: 52px; }
  .compat-row { grid-template-columns: 1fr; }
  .compat-form { padding: 16px 14px; }
  .ohaeng { grid-template-columns: repeat(5, 1fr); }

  /* 모달 */
  .modal-card { padding: 22px 16px; }
  #api-key-input { font-size: 16px; }
}

/* ============ 이름 입력 ============ */
.name-field-wrap {
  margin-bottom: 24px;
}
.name-input {
  width: 100%;
  background: var(--surface2);
  border: 2px solid var(--black);
  color: var(--text);
  padding: 12px 14px;
  font-size: 15px;
  font-family: var(--sans);
  outline: none;
  box-shadow: var(--shadow-sm);
  margin-top: 8px;
  display: block;
}
.name-input:focus {
  border-color: var(--pink);
  box-shadow: 3px 3px 0 var(--pink);
}
.name-input-hint {
  font-size: 11px;
  color: var(--subtext);
  margin-top: 4px;
  font-family: var(--sans);
}

/* (구) 옛 today-card 스타일 제거 — 충돌 원인. 1554의 새 정의 사용 */

/* ============ 대운 타임라인 ============ */
.daewun-list {
  display: flex;
  flex-direction: column;
  gap: 4px;
  position: relative;
}
.daewun-list::before {
  content: '';
  position: absolute;
  left: 44px;
  top: 16px;
  bottom: 16px;
  width: 2px;
  background: repeating-linear-gradient(
    180deg,
    var(--black) 0px, var(--black) 6px,
    transparent 6px, transparent 12px
  );
}

.daewun-row {
  display: grid;
  grid-template-columns: 40px 20px 1fr;
  gap: 10px;
  align-items: flex-start;
  padding: 12px 14px 12px 0;
  background: var(--surface);
  border: 2px solid var(--black);
  box-shadow: var(--shadow-sm);
  cursor: pointer;
  transition: transform 0.08s, box-shadow 0.08s;
  position: relative;
}
.daewun-row:hover {
  transform: translate(-2px, -2px);
  box-shadow: 4px 4px 0 var(--black);
}
.daewun-row.past { opacity: 0.6; }
.daewun-row.current {
  border-color: var(--gold);
  box-shadow: 4px 4px 0 var(--gold);
  border-left: 4px solid var(--gold);
}

.dw-num {
  font-family: var(--pixel);
  font-size: 7px;
  color: var(--subtext);
  text-align: right;
  padding-top: 3px;
  padding-left: 10px;
  line-height: 1.6;
}
.daewun-row.current .dw-num { color: var(--gold); }

.dw-dot {
  width: 12px;
  height: 12px;
  background: var(--surface2);
  border: 2px solid var(--black);
  margin: 4px auto 0;
  position: relative;
  z-index: 1;
}
.daewun-row.current .dw-dot {
  background: var(--gold);
}

.dw-body { padding-top: 0; }

.dw-age {
  font-family: var(--pixel);
  font-size: 8px;
  color: var(--pink);
  margin-bottom: 3px;
  letter-spacing: 0.05em;
}

.dw-ganzhi {
  font-family: var(--serif);
  font-size: 14px;
  color: var(--text);
  font-weight: 600;
  margin-bottom: 2px;
}

.dw-elem {
  font-size: 11px;
  color: var(--subtext);
  font-family: var(--sans);
}

.dw-text {
  font-family: var(--serif);
  font-size: 13px;
  line-height: 1.9;
  color: var(--text);
  margin-top: 10px;
  white-space: pre-wrap;
  word-break: keep-all;
  border-top: 1px solid rgba(17,17,17,0.1);
  padding-top: 10px;
}

/* ============================================================
   v2 — UI 통일 (2026-05-09)
   빈 상태 / 로딩 / 에러 / 모바일 반응형 + 미세 polishing
   ============================================================ */

/* ---------- 공통 빈 상태 박스 (library-empty / today-empty / compat-empty 통합) ---------- */
.empty-state,
.library-empty,
.today-empty {
  background: var(--surface);
  border: 2px solid var(--black);
  box-shadow: var(--shadow);
  padding: 36px 24px;
  text-align: center;
  margin: 24px auto;
  max-width: 520px;
}
.empty-state-icon,
.library-empty-icon,
.today-empty-icon {
  font-size: 44px;
  margin-bottom: 16px;
  display: block;
  line-height: 1;
}
.empty-state-title {
  font-family: var(--pixel);
  font-size: 14px;
  letter-spacing: 0.04em;
  margin-bottom: 12px;
  color: var(--black);
}
.empty-state-text {
  font-size: 13px;
  line-height: 1.7;
  color: var(--subtext);
  margin-bottom: 20px;
  word-break: keep-all;
}

/* ---------- 통일 로딩 (도트 펄스) ---------- */
.loading-dots {
  display: inline-flex;
  gap: 4px;
  vertical-align: middle;
}
.loading-dots span {
  width: 6px;
  height: 6px;
  background: var(--pink);
  display: inline-block;
  animation: loading-pulse 1.2s ease-in-out infinite;
}
.loading-dots span:nth-child(2) { animation-delay: 0.2s; }
.loading-dots span:nth-child(3) { animation-delay: 0.4s; }
@keyframes loading-pulse {
  0%, 100% { opacity: 0.3; transform: translateY(0); }
  50% { opacity: 1; transform: translateY(-3px); }
}

/* ---------- 통일 에러 박스 ---------- */
.error-state {
  background: var(--surface);
  border: 2px solid var(--pink);
  box-shadow: var(--shadow-pink);
  padding: 20px 22px;
  margin: 16px 0;
  text-align: center;
}
.error-state-title {
  font-family: var(--pixel);
  font-size: 11px;
  color: var(--pink);
  letter-spacing: 0.08em;
  margin-bottom: 8px;
}
.error-state-text {
  font-size: 13px;
  line-height: 1.6;
  color: var(--text);
}

/* ---------- 모바일 반응형 (320~400px 작은 화면에서 자주 깨지는 곳) ---------- */
@media (max-width: 400px) {
  /* 챕터 카드 padding 조금 줄임 */
  .chapter-card {
    padding: 18px 16px;
  }
  .chapter-title {
    font-size: 13px;
    letter-spacing: 0.02em;
  }
  .chapter-body {
    font-size: 13px;
    line-height: 1.8;
  }
  .chapter-body p {
    margin: 0 0 12px;
  }
  /* 챕터 본문 단락 사이 visual gap */
  .chapter-num {
    font-size: 8px;
  }

  /* 빈 상태 padding 줄임 */
  .empty-state,
  .library-empty,
  .today-empty {
    padding: 28px 18px;
  }
  .empty-state-icon,
  .library-empty-icon,
  .today-empty-icon {
    font-size: 36px;
  }

  /* result 헤더 메타 줄바꿈 */
  .result-meta {
    flex-wrap: wrap;
    gap: 6px 12px;
  }
  .result-meta-item {
    font-size: 11px;
  }

  /* compat 점수 박스 패딩 */
  .compat-score {
    padding: 18px 16px;
  }
  .compat-score-num {
    font-size: 28px;
  }

  /* 카탈로그 카드 — 모바일 1열 + padding 정리 */
  .catalog-grid {
    grid-template-columns: 1fr !important;
    gap: 16px;
  }
  .catalog-card {
    padding: 18px 18px;
  }
  .catalog-card-title {
    font-size: 13px;
  }

  /* hero 타이틀 클램핑 */
  .hero-title {
    font-size: clamp(24px, 8vw, 36px);
    line-height: 1.25;
  }
  .hero-sub {
    font-size: 13px;
  }

  /* bottom nav 라벨 폰트 */
  .bnav-label {
    font-size: 9px;
  }
}

/* ---------- 터치 타겟 최소 44px (WCAG 2.2 AA) ---------- */
@media (pointer: coarse) {
  .btn-game,
  .bnav-item,
  .chapter-lock-btn,
  .chat-send-btn {
    min-height: 44px;
  }
}

/* ---------- 큰 화면 (1024+) 챕터 카드 패딩 살짝 ↑ ---------- */
@media (min-width: 1024px) {
  .chapter-card {
    padding: 24px 28px;
  }
  .chapter-body {
    font-size: 15px;
  }
}

/* ---------- placeholder loading 텍스트 (compat 챕터 fetch 전) ---------- */
.chapter-body.chapter-body-loading {
  color: var(--subtext);
  font-style: italic;
  animation: chapter-pulse 1.5s ease-in-out infinite;
}

/* ============================================================
   💬 챗 핸드오프 — 미끼 질문 카드 + 컨텍스트 배너
   ============================================================ */

/* 결과 페이지 하단의 "챗 미끼 질문 섹션" */
.chat-bait-section {
  margin: 36px 0 24px;
  padding: 22px 18px 20px;
  background: linear-gradient(135deg, rgba(108, 92, 231, 0.06) 0%, rgba(214, 51, 132, 0.06) 100%);
  border: 1.5px solid rgba(108, 92, 231, 0.18);
  border-radius: 14px;
  position: relative;
}
.chat-bait-eyebrow {
  font-family: var(--pixel, 'Press Start 2P', monospace);
  font-size: 10px;
  letter-spacing: 0.5px;
  color: #6c5ce7;
  margin-bottom: 6px;
}
.chat-bait-title {
  font-family: var(--sans);
  font-size: 17px;
  font-weight: 700;
  color: var(--text);
  margin: 0 0 4px;
  line-height: 1.35;
}
.chat-bait-sub {
  font-family: var(--sans);
  font-size: 13px;
  color: var(--subtext);
  margin: 0 0 16px;
  line-height: 1.55;
}
.chat-bait-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
}
@media (max-width: 480px) {
  .chat-bait-grid { grid-template-columns: 1fr; }
}
.chat-bait-card {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 13px 14px;
  background: #fff;
  border: 1.5px solid var(--border-soft, #e5e7eb);
  border-radius: 10px;
  cursor: pointer;
  text-align: left;
  font-family: var(--sans);
  font-size: 13.5px;
  font-weight: 500;
  color: var(--text);
  line-height: 1.45;
  transition: all 0.18s ease;
  min-height: 56px;
}
.chat-bait-card:hover,
.chat-bait-card:focus-visible {
  border-color: #6c5ce7;
  box-shadow: 0 4px 12px rgba(108, 92, 231, 0.18);
  transform: translateY(-1px);
  outline: none;
}
.chat-bait-card:active {
  transform: translateY(0);
  box-shadow: 0 1px 3px rgba(108, 92, 231, 0.12);
}
.chat-bait-card-icon {
  font-size: 22px;
  flex-shrink: 0;
  width: 30px;
  text-align: center;
}
.chat-bait-card-text {
  flex: 1;
  min-width: 0;
}

/* 자유 입력 버튼 (미끼 카드 아래) */
.chat-bait-free {
  margin-top: 14px;
  display: flex;
  justify-content: center;
}
.chat-bait-free-btn {
  font-family: var(--sans);
  font-size: 13px;
  color: #6c5ce7;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 8px 12px;
  text-decoration: underline;
}
.chat-bait-free-btn:hover { color: #4834c0; }

/* 챗 페이지의 컨텍스트 배너 */
.chat-context-banner {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 14px;
  padding: 10px 12px 10px 14px;
  background: linear-gradient(135deg, rgba(108, 92, 231, 0.10) 0%, rgba(214, 51, 132, 0.10) 100%);
  border: 1.5px solid rgba(108, 92, 231, 0.25);
  border-radius: 999px;
  font-family: var(--sans);
  font-size: 13px;
  color: #4834c0;
  font-weight: 600;
}
.chat-context-banner-icon {
  font-size: 15px;
}
.chat-context-clear {
  margin-left: auto;
  background: transparent;
  border: none;
  color: #4834c0;
  cursor: pointer;
  font-size: 18px;
  line-height: 1;
  padding: 10px 12px; /* WCAG 2.2 — 44px 터치 타겟 */
  min-width: 44px;
  min-height: 44px;
  border-radius: 50%;
}
.chat-context-clear:hover { background: rgba(108, 92, 231, 0.15); }

/* ============================================================
   🚀 베타 모드 배너
   ============================================================ */
.beta-banner {
  position: sticky;
  top: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 8px 14px;
  background: linear-gradient(90deg, #6c5ce7 0%, #d63384 100%);
  color: #fff;
  font-family: var(--sans);
  font-size: 12.5px;
  font-weight: 700;
  letter-spacing: 0.3px;
  box-shadow: 0 2px 8px rgba(108, 92, 231, 0.25);
  text-align: center;
}
.beta-banner-text {
  flex: 1;
  text-align: center;
}
.beta-banner-close {
  background: rgba(255, 255, 255, 0.18);
  border: none;
  color: #fff;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  cursor: pointer;
  font-size: 16px;
  line-height: 1;
  flex-shrink: 0;
  transition: background 0.15s;
}
.beta-banner-close:hover {
  background: rgba(255, 255, 255, 0.32);
}

/* 베타 코드 입력 박스 (recharge 페이지) */
.beta-redeem-box {
  margin: 24px 0;
  padding: 22px 18px;
  background: linear-gradient(135deg, rgba(108, 92, 231, 0.06) 0%, rgba(214, 51, 132, 0.06) 100%);
  border: 1.5px dashed rgba(108, 92, 231, 0.35);
  border-radius: 14px;
}
.beta-redeem-eyebrow {
  font-family: var(--pixel, 'Press Start 2P', monospace);
  font-size: 10px;
  color: #6c5ce7;
  letter-spacing: 0.5px;
  margin-bottom: 6px;
}
.beta-redeem-title {
  font-family: var(--sans);
  font-size: 16px;
  font-weight: 700;
  color: var(--text);
  margin: 0 0 4px;
}
.beta-redeem-sub {
  font-family: var(--sans);
  font-size: 13px;
  color: var(--subtext);
  margin: 0 0 14px;
  line-height: 1.55;
}
.beta-redeem-row {
  display: flex;
  gap: 8px;
}
.beta-redeem-input {
  flex: 1;
  padding: 12px 14px;
  border: 1.5px solid var(--border-soft, #e5e7eb);
  border-radius: 10px;
  font-family: var(--sans);
  font-size: 14px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  background: #fff;
  color: var(--text);
  min-height: 44px;
}
.beta-redeem-input:focus {
  outline: none;
  border-color: #6c5ce7;
  box-shadow: 0 0 0 3px rgba(108, 92, 231, 0.15);
}
.beta-redeem-btn {
  padding: 0 18px;
  border-radius: 10px;
  background: #6c5ce7;
  color: #fff;
  border: none;
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  min-height: 44px;
  transition: background 0.15s;
}
.beta-redeem-btn:hover { background: #4834c0; }
.beta-redeem-btn:disabled { opacity: 0.5; cursor: not-allowed; }
.beta-redeem-feedback {
  margin-top: 10px;
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 600;
}
.beta-redeem-feedback.success { color: #1f8a4c; }
.beta-redeem-feedback.error { color: #d63384; }

/* 활성 베타 표시 (recharge 박스 내부) */
.beta-active-card {
  margin-top: 14px;
  padding: 14px;
  background: rgba(108, 92, 231, 0.10);
  border-radius: 10px;
  font-family: var(--sans);
  font-size: 13px;
  color: #4834c0;
  line-height: 1.5;
}

/* ============================================================
   ▣▣▣ QUALITY UPGRADE PASS — Refined Pixel Game UI
   2026-05-10 — sweep result/home/recharge/today
   ============================================================ */

/* Black Han Sans 추가 (이미 일부 페이지에서 import) */
@import url('https://fonts.googleapis.com/css2?family=Black+Han+Sans&display=swap');

/* ===== 결과 페이지 — 챕터 카드 풍성하게 ===== */

.chapter-card {
  background: var(--surface);
  border: 3px solid var(--black);
  box-shadow: 5px 5px 0 var(--gold), 9px 9px 0 var(--black);
  padding: var(--card-padding-y) var(--card-padding-x);
  border-radius: 6px;
  margin-top: 18px;
  transition: transform .2s cubic-bezier(.16,1,.3,1), box-shadow .2s;
  position: relative;
}
.chapter-card::before {
  content: '';
  position: absolute;
  top: -8px; left: -8px;
  width: 14px; height: 14px;
  background: var(--pink);
  border: 2.5px solid var(--black);
  z-index: 2;
}
.chapter-card::after {
  content: '';
  position: absolute;
  bottom: -8px; right: -8px;
  width: 14px; height: 14px;
  background: var(--gold);
  border: 2.5px solid var(--black);
  z-index: 2;
}
.chapter-card:hover {
  transform: translate(-2px, -2px);
  box-shadow: 7px 7px 0 var(--gold), 11px 11px 0 var(--black) !important;
}

/* 챕터별 컬러 로테이션 (6색) — shadow 색만 바꿈 */
.chapter-card:nth-of-type(6n+1) { box-shadow: 5px 5px 0 var(--pink), 9px 9px 0 var(--black) !important; }
.chapter-card:nth-of-type(6n+1)::before { background: var(--gold); }
.chapter-card:nth-of-type(6n+2) { box-shadow: 5px 5px 0 var(--gold), 9px 9px 0 var(--black) !important; }
.chapter-card:nth-of-type(6n+3) { box-shadow: 5px 5px 0 #8ddec5, 9px 9px 0 var(--black) !important; }
.chapter-card:nth-of-type(6n+3)::before { background: #8ddec5; }
.chapter-card:nth-of-type(6n+4) { box-shadow: 5px 5px 0 #c4a8e8, 9px 9px 0 var(--black) !important; }
.chapter-card:nth-of-type(6n+4)::before { background: #c4a8e8; }
.chapter-card:nth-of-type(6n+5) { box-shadow: 5px 5px 0 #ff8b6b, 9px 9px 0 var(--black) !important; }
.chapter-card:nth-of-type(6n+5)::before { background: #ff8b6b; }
.chapter-card:nth-of-type(6n+0) { box-shadow: 5px 5px 0 var(--pink), 9px 9px 0 var(--black) !important; }

/* 챕터 번호 — 큰 픽셀 칩 */
.chapter-num {
  display: inline-block;
  font-family: var(--pixel) !important;
  font-size: 14px !important;
  color: var(--black) !important;
  background: var(--gold);
  border: 2.5px solid var(--black);
  padding: 8px 14px !important;
  margin-bottom: 18px !important;
  letter-spacing: 0.12em !important;
  box-shadow: 3px 3px 0 var(--black);
  line-height: 1;
  position: relative;
  z-index: 1;
}

/* 챕터 타이틀 — Black Han Sans 굵직 */
.chapter-title {
  font-family: 'Black Han Sans', var(--sans) !important;
  font-size: 26px !important;
  color: var(--black) !important;
  line-height: 1.3 !important;
  letter-spacing: -0.01em !important;
  margin-bottom: 20px !important;
  font-weight: 400;
}
@media (max-width: 600px) {
  .chapter-title { font-size: 20px !important; }
  /* padding 은 토큰(var(--card-padding-*))이 처리 — 모바일에서 자동 축소 */
}

/* 챕터 본문 — 더 넓은 행간 (모바일 친화 clamp) */
.chapter-body {
  font-size: var(--text-body) !important;
  line-height: var(--line-body) !important;
  color: #2a221a !important;
  font-family: var(--sans) !important;
  letter-spacing: 0 !important; /* 한글에 letter-spacing 제거 — 모바일 줄당 글자수 ↑ */
  word-break: keep-all; /* 한국어 단어 단위 줄바꿈 */
  overflow-wrap: anywhere;
}
.chapter-body p { margin-bottom: 16px !important; }
.chapter-body p:first-of-type { position: relative; }

/* 챕터 카드 사이 ◆ 디바이더 */
.chapter-card + .chapter-card {
  margin-top: 36px;
}
.chapter-card + .chapter-card::after {
  /* keep gold corner */
}
.chapters-list {
  position: relative;
}
.chapters-list .chapter-card:not(:first-child)::before {
  /* override would lose corner pixel; instead add a separate pseudo via wrapper not possible. Use background ornament. */
}

/* ===== 사주 차트 카드 강화 ===== */
.saju-chart-card {
  border: 3px solid var(--black) !important;
  box-shadow: 6px 6px 0 var(--gold), 10px 10px 0 var(--black) !important;
  position: relative;
  border-radius: 8px;
}
.saju-chart-card::before {
  content: '';
  position: absolute; top: -8px; left: -8px;
  width: 14px; height: 14px;
  background: var(--pink);
  border: 2.5px solid var(--black);
}
.saju-chart-card::after {
  content: '';
  position: absolute; bottom: -8px; right: -8px;
  width: 14px; height: 14px;
  background: var(--gold);
  border: 2.5px solid var(--black);
}

/* ===== 결과 페이지 진행 바 — 더 두껍고 픽셀하게 ===== */
.result-progress {
  margin-top: 14px;
}
.progress-bar {
  height: 18px !important;
  border: 2.5px solid var(--black) !important;
  background: #fff !important;
  box-shadow: 3px 3px 0 var(--black) !important;
  position: relative;
  overflow: hidden;
}
.progress-bar-fill {
  background: linear-gradient(90deg, var(--pink) 0%, var(--gold) 100%) !important;
  position: relative;
}
.progress-bar-fill::after {
  content: '';
  position: absolute; inset: 0;
  background-image: repeating-linear-gradient(45deg, rgba(255,255,255,0.3) 0 6px, transparent 6px 12px);
}

/* ===== 챕터 12 마지막 — 특별 처리 (마무리) ===== */
.chapter-card:nth-last-of-type(1) {
  background: linear-gradient(180deg, #fff 0%, #fff7e8 100%) !important;
  border-width: 3.5px !important;
}

/* ===== 잠긴 챕터 시각 강화 ===== */
.chapter-card.chapter-locked {
  background: linear-gradient(180deg, #fff 0%, #fff8ec 100%) !important;
  position: relative;
}
.chapter-card.chapter-locked .chapter-body {
  filter: blur(0);
}

/* ===== 떠다니는 챕터 네비 (오른쪽) ===== */
.chapter-mini-nav {
  position: fixed;
  right: 18px;
  top: 50%;
  transform: translateY(-50%);
  display: none;
  flex-direction: column;
  gap: 6px;
  z-index: 50;
  background: rgba(255,255,255,0.95);
  border: 2.5px solid var(--black);
  box-shadow: 4px 4px 0 var(--gold), 7px 7px 0 var(--black);
  padding: 10px 8px;
  border-radius: 6px;
}
@media (min-width: 1080px) {
  .chapter-mini-nav { display: flex; }
}
.chapter-mini-nav-dot {
  width: 22px; height: 22px;
  display: grid; place-items: center;
  border: 2px solid var(--black);
  background: #fff;
  font-family: var(--pixel);
  font-size: 8px;
  color: var(--black);
  cursor: pointer;
  transition: transform .12s, background .12s;
  text-decoration: none;
  line-height: 1;
}
.chapter-mini-nav-dot:hover {
  transform: translate(-1px, -1px);
  background: var(--gold);
  text-decoration: none;
}
.chapter-mini-nav-dot.is-current {
  background: var(--pink);
  color: #fff;
  box-shadow: 2px 2px 0 var(--black);
}
.chapter-mini-nav-dot.is-locked { opacity: 0.5; }

/* ===== 읽기 진행률 — 화면 상단 ===== */
.reading-progress-bar {
  position: fixed;
  top: 0; left: 0;
  height: 4px;
  width: 0%;
  background: linear-gradient(90deg, var(--pink) 0%, var(--gold) 100%);
  z-index: 9999;
  transition: width .12s linear;
  box-shadow: 0 1px 0 rgba(0,0,0,0.3);
}

/* ===== 공유 카드 (결과 페이지 끝) ===== */
.result-share-card {
  margin: 36px auto 0;
  max-width: 720px;
  background: linear-gradient(135deg, var(--surface) 0%, #fff8ec 100%);
  border: 3px solid var(--black);
  box-shadow: 5px 5px 0 var(--pink), 9px 9px 0 var(--black);
  padding: 28px 24px;
  position: relative;
  border-radius: 8px;
}
.result-share-card::before, .result-share-card::after {
  content: '';
  position: absolute;
  width: 14px; height: 14px;
  border: 2.5px solid var(--black);
}
.result-share-card::before { top: -8px; left: -8px; background: var(--gold); }
.result-share-card::after { bottom: -8px; right: -8px; background: var(--pink); }

.result-share-eyebrow {
  display: inline-block;
  font-family: var(--pixel);
  font-size: 9px;
  letter-spacing: 0.15em;
  color: #fff;
  background: var(--pink);
  border: 2px solid var(--black);
  padding: 4px 8px;
  margin-bottom: 12px;
}
.result-share-title {
  font-family: 'Black Han Sans', var(--sans);
  font-size: 24px;
  margin-bottom: 8px;
  color: var(--black);
}
.result-share-sub {
  font-size: 14px;
  color: var(--subtext);
  margin-bottom: 18px;
}
.result-share-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.share-btn {
  flex: 1 1 auto;
  min-width: 110px;
  padding: 12px 14px;
  border: 2.5px solid var(--black);
  background: #fff;
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 3px 3px 0 var(--black);
  transition: transform .12s, box-shadow .12s;
  text-align: center;
  color: var(--black);
}
.share-btn:hover {
  transform: translate(-1px, -1px);
  box-shadow: 4px 4px 0 var(--black);
}
.share-btn:active {
  transform: translate(2px, 2px);
  box-shadow: 1px 1px 0 var(--black);
}
.share-btn.share-kakao { background: #fee500; }
.share-btn.share-insta { background: linear-gradient(135deg, #ff8b6b 0%, var(--pink) 100%); color: #fff; }
.share-btn.share-link { background: var(--gold); }

/* ===== 베타 박스 — 픽셀 톤으로 통째 재디자인 (보라 그라디언트 폐기) ===== */
.beta-redeem-box {
  margin: 24px 0 !important;
  padding: 26px 22px !important;
  background: var(--surface) !important;
  border: 3px solid var(--black) !important;
  box-shadow: 5px 5px 0 var(--pink), 9px 9px 0 var(--black) !important;
  border-radius: 6px !important;
  position: relative;
}
.beta-redeem-box::before, .beta-redeem-box::after {
  content: '';
  position: absolute;
  width: 14px; height: 14px;
  border: 2.5px solid var(--black);
}
.beta-redeem-box::before { top: -8px; left: -8px; background: var(--gold); }
.beta-redeem-box::after { bottom: -8px; right: -8px; background: var(--pink); }

.beta-redeem-eyebrow {
  display: inline-block !important;
  font-family: var(--pixel) !important;
  font-size: 10px !important;
  color: #fff !important;
  background: var(--pink) !important;
  border: 2px solid var(--black);
  padding: 4px 10px !important;
  letter-spacing: 0.15em !important;
  margin-bottom: 12px !important;
  box-shadow: 2px 2px 0 var(--black);
}
.beta-redeem-title {
  font-family: 'Black Han Sans', var(--sans) !important;
  font-size: 22px !important;
  color: var(--black) !important;
  margin: 0 0 6px !important;
  font-weight: 400 !important;
  line-height: 1.25 !important;
}
.beta-redeem-sub {
  font-size: 13.5px !important;
  color: var(--subtext) !important;
  margin: 0 0 16px !important;
  line-height: 1.6 !important;
}

.beta-redeem-input {
  flex: 1;
  padding: 12px 14px !important;
  border: 2.5px solid var(--black) !important;
  border-radius: 0 !important;
  font-family: var(--pixel) !important;
  font-size: 11px !important;
  background: var(--surface2) !important;
  color: var(--black) !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  min-height: 46px !important;
}
.beta-redeem-input:focus {
  outline: none !important;
  background: #fff7d6 !important;
  box-shadow: 3px 3px 0 var(--gold) !important;
  border-color: var(--black) !important;
}

.beta-redeem-btn {
  padding: 0 20px !important;
  border-radius: 0 !important;
  background: var(--pink) !important;
  color: #fff !important;
  border: 2.5px solid var(--black) !important;
  font-family: var(--pixel) !important;
  font-size: 10px !important;
  font-weight: 400 !important;
  letter-spacing: 0.08em !important;
  min-height: 46px !important;
  box-shadow: 3px 3px 0 var(--black);
  transition: transform .1s, box-shadow .1s, background .15s !important;
}
.beta-redeem-btn:hover {
  background: var(--pink-bg) !important;
  transform: translate(-1px, -1px);
  box-shadow: 4px 4px 0 var(--black);
}
.beta-redeem-btn:active {
  transform: translate(2px, 2px);
  box-shadow: 1px 1px 0 var(--black);
}

.beta-active-card {
  background: linear-gradient(135deg, #fff7e8 0%, #ffeec8 100%) !important;
  border: 2.5px solid var(--black) !important;
  border-radius: 0 !important;
  color: var(--black) !important;
  box-shadow: 3px 3px 0 var(--gold);
  font-weight: 700 !important;
}

/* ===== 베타 배너 — 픽셀 톤으로 변경 ===== */
.beta-banner {
  background: var(--gold) !important;
  background-image: repeating-linear-gradient(90deg, transparent 0 18px, rgba(0,0,0,0.06) 18px 20px) !important;
  color: var(--black) !important;
  border-bottom: 3px solid var(--black) !important;
  font-family: var(--pixel) !important;
  font-size: 10px !important;
  font-weight: 400 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase;
  box-shadow: none !important;
  padding: 10px 14px !important;
  position: relative;
}
.beta-banner::before, .beta-banner::after {
  content: '★';
  color: var(--pink);
  font-size: 14px;
  animation: betaStarBlink 1.4s steps(2) infinite;
}
.beta-banner::after { animation-delay: 0.7s; }
@keyframes betaStarBlink {
  0%, 50% { opacity: 1; }
  50.01%, 100% { opacity: 0.25; }
}
.beta-banner-close {
  background: #fff !important;
  border: 2px solid var(--black) !important;
  border-radius: 0 !important;
  color: var(--black) !important;
  width: 24px !important;
  height: 24px !important;
  box-shadow: 2px 2px 0 var(--black);
  transition: transform .1s !important;
}
.beta-banner-close:hover {
  background: var(--pink) !important;
  color: #fff !important;
  transform: translate(-1px, -1px);
}

/* ===== 홈 카탈로그 카드 — 게임 콜렉션 카드 톤 ===== */
.catalog-card {
  border: 3px solid var(--black) !important;
  box-shadow: 5px 5px 0 var(--gold), 8px 8px 0 var(--black) !important;
  border-radius: 6px;
  padding: 26px 22px 22px !important;
  position: relative;
  transition: transform .2s cubic-bezier(.16,1,.3,1), box-shadow .2s !important;
}
.catalog-card::before, .catalog-card::after {
  content: '';
  position: absolute;
  width: 12px; height: 12px;
  border: 2px solid var(--black);
  z-index: 2;
}
.catalog-card::before { top: -7px; left: -7px; background: var(--pink); }
.catalog-card::after { bottom: -7px; right: -7px; background: var(--gold); }
.catalog-card:hover {
  transform: translate(-3px, -3px) !important;
  box-shadow: 7px 7px 0 var(--gold), 11px 11px 0 var(--black) !important;
}
.catalog-card:nth-child(2n) { box-shadow: 5px 5px 0 var(--pink), 8px 8px 0 var(--black) !important; }
.catalog-card:nth-child(3n) { box-shadow: 5px 5px 0 #8ddec5, 8px 8px 0 var(--black) !important; }
.catalog-card:nth-child(2n)::before { background: var(--gold); }
.catalog-card:nth-child(3n)::before { background: #c4a8e8; }

.catalog-thumb {
  border: 2.5px solid var(--black) !important;
  box-shadow: 3px 3px 0 var(--pink) !important;
  border-radius: 4px;
  width: 64px !important;
  height: 64px !important;
  background: linear-gradient(135deg, #fff8ec 0%, #fff0d8 100%) !important;
}
.catalog-card:hover .catalog-thumb {
  animation: catalogThumbBob 1.2s ease-in-out infinite;
}
@keyframes catalogThumbBob {
  0%, 100% { transform: translateY(0) rotate(-2deg); }
  50% { transform: translateY(-3px) rotate(2deg); }
}

.catalog-card-title {
  font-family: 'Black Han Sans', var(--sans) !important;
  font-size: 18px !important;
  letter-spacing: 0 !important;
  font-weight: 400 !important;
  margin-bottom: 8px !important;
  line-height: 1.2 !important;
}
.catalog-card-desc {
  font-size: 13px !important;
  line-height: 1.6 !important;
  color: #4a3f35 !important;
}
.catalog-card-cta {
  font-family: var(--pixel) !important;
  font-size: 9px !important;
  background: var(--gold);
  color: var(--black) !important;
  border: 2px solid var(--black);
  padding: 6px 10px;
  border-bottom-width: 2px !important;
  box-shadow: 2px 2px 0 var(--black);
  display: inline-block;
  letter-spacing: 0.1em !important;
  align-self: flex-start;
  transition: transform .1s, box-shadow .1s, background .12s;
}
.catalog-card:hover .catalog-card-cta {
  background: var(--pink);
  color: #fff !important;
  transform: translate(-1px, -1px);
  box-shadow: 3px 3px 0 var(--black);
}

/* ===== Today 페이지 — 보라 카드 톤 통일 ===== */
[class*="chat-context"], .chat-context-clear {
  background: var(--surface) !important;
  border: 2.5px solid var(--black) !important;
  border-radius: 0 !important;
  color: var(--black) !important;
  box-shadow: 3px 3px 0 var(--gold);
}

/* ===== 떠다니는 픽셀 별 (장식 — body 전역) ===== */
.pixel-sparkle {
  position: absolute;
  width: 8px; height: 8px;
  background: var(--gold);
  pointer-events: none;
  z-index: 0;
  animation: sparkleFloat 4s ease-in-out infinite;
  opacity: 0.5;
}
.pixel-sparkle.s-pink { background: var(--pink); }
@keyframes sparkleFloat {
  0%, 100% { transform: translate(0,0) rotate(45deg); opacity: 0.4; }
  50% { transform: translate(4px,-6px) rotate(135deg); opacity: 0.9; }
}

/* ===== 마스코트 픽셀 캐릭터 — 일정 호흡 애니 ===== */
.character-pixel, .pixel-character {
  animation: characterBob 2.4s ease-in-out infinite !important;
}
@keyframes characterBob {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-4px); }
}

/* ===== reduced motion — 모든 wiggle 끔 ===== */
@media (prefers-reduced-motion: reduce) {
  .chapter-card, .catalog-card, .character-pixel, .pixel-character,
  .beta-banner::before, .beta-banner::after, .pixel-sparkle, .catalog-thumb {
    animation: none !important;
    transition: none !important;
  }
}

/* ============================================================
   ▣▣▣ SPROUT PIXEL ASSET INTEGRATION
   2026-05-11 — Sprout Lands UI Pack Premium 통합
   ============================================================ */

/* Sprout 픽셀 폰트 (보조) */
@font-face {
  font-family: 'SproutPixel';
  src: url('/img/sprout/fonts/sprout.ttf') format('truetype');
  font-display: swap;
}

/* 모든 sprout 스프라이트 픽셀 렌더링 */
img.sprout, .sprout-sprite {
  image-rendering: pixelated;
  image-rendering: crisp-edges;
}

/* ===== Sprout 다이얼로그 박스 — border-image 9-slice ===== */
.sprout-dialog {
  border-style: solid !important;
  border-color: transparent !important;
  border-width: 18px 20px 22px 20px !important;
  border-image-source: url('/img/sprout/ui/dialog-medium.png') !important;
  border-image-slice: 12 14 16 14 fill !important;
  border-image-width: 18px 20px 22px 20px !important;
  border-image-repeat: stretch !important;
  background: transparent !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  image-rendering: pixelated;
  padding: 8px 14px !important;
}

/* ===== 상담소 말풍선 — Sprout speech bubble PNG 사용 ===== */
.chat-msg-bot, .chat-message.bot, .chat-bot-bubble {
  /* speech_bubble_yellow.png (medium variant, ~y=64 area) */
  background: url('/img/sprout/emojis/speech_bubble_yellow.png') !important;
  background-size: 800% auto !important;
  background-position: -50% -25% !important;
  background-repeat: no-repeat !important;
  image-rendering: pixelated;
  border: none !important;
  box-shadow: none !important;
}

/* ===== 별조각 카운터 — heart inventory bar 활용 ===== */
.sprout-heart-bar {
  display: inline-block;
  width: 96px;
  height: 16px;
  background: url('/img/sprout/emojis/inventory-hearts.png') no-repeat 0 -118px;
  background-size: 96px auto;
  image-rendering: pixelated;
  vertical-align: middle;
}
.sprout-coin-icon {
  display: inline-block;
  width: 16px; height: 16px;
  background: url('/img/sprout/ui/all-icons.png') no-repeat;
  background-size: 256px 320px;
  /* Coin icon position (대략 위치 — 결과 보고 미세 조정) */
  background-position: -176px -96px;
  image-rendering: pixelated;
  vertical-align: middle;
}
.sprout-star-icon {
  display: inline-block;
  width: 16px; height: 16px;
  background: url('/img/sprout/ui/all-icons.png') no-repeat;
  background-size: 256px 320px;
  /* Star icon position */
  background-position: -64px 0;
  image-rendering: pixelated;
  vertical-align: middle;
}
.sprout-gift-icon {
  display: inline-block;
  width: 16px; height: 16px;
  background: url('/img/sprout/ui/all-icons.png') no-repeat;
  background-size: 256px 320px;
  background-position: -176px -64px;
  image-rendering: pixelated;
  vertical-align: middle;
}
.sprout-heart-icon {
  display: inline-block;
  width: 16px; height: 16px;
  background: url('/img/sprout/ui/all-icons.png') no-repeat;
  background-size: 256px 320px;
  background-position: -160px -64px;
  image-rendering: pixelated;
  vertical-align: middle;
}

/* ===== 베타 박스에 Sprout 다이얼로그 프레임 입히기 ===== */
.beta-redeem-box.sprout-skin {
  border-image-source: url('/img/sprout/ui/premade-medium.png') !important;
  border-image-slice: 18 18 22 56 fill !important;
  border-style: solid !important;
  border-color: transparent !important;
  border-width: 22px 22px 26px 60px !important;
  border-image-width: 22px 22px 26px 60px !important;
  border-image-repeat: stretch !important;
  background: transparent !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  image-rendering: pixelated;
  padding: 4px 12px !important;
  min-height: 100px;
}

/* ===== 결과 페이지 챕터 카드에 Sprout 다이얼로그 프레임 ===== */
/* (옵션: .sprout-chapter 클래스 붙이면 적용) */
.chapter-card.sprout-frame {
  border-style: solid !important;
  border-color: transparent !important;
  border-width: 20px 22px 24px 22px !important;
  border-image-source: url('/img/sprout/ui/dialog-big.png') !important;
  border-image-slice: 14 16 18 16 fill !important;
  border-image-width: 20px 22px 24px 22px !important;
  border-image-repeat: stretch !important;
  background: transparent !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  image-rendering: pixelated;
  padding: 10px 16px !important;
}
.chapter-card.sprout-frame::before, .chapter-card.sprout-frame::after {
  display: none !important;
}

/* ===== 상담소 메시지 — Sprout 다이얼로그 프레임 적용 ===== */
.msg-bot {
  border-style: solid !important;
  border-color: transparent !important;
  border-width: 16px 18px 20px 18px !important;
  border-image-source: url('/img/sprout/ui/dialog-medium.png') !important;
  border-image-slice: 10 12 14 12 fill !important;
  border-image-width: 16px 18px 20px 18px !important;
  border-image-repeat: stretch !important;
  background: transparent !important;
  box-shadow: none !important;
  padding: 4px 10px !important;
  image-rendering: pixelated;
  min-height: 60px;
}
.msg-user {
  border-style: solid !important;
  border-color: transparent !important;
  border-width: 14px 16px 18px 16px !important;
  border-image-source: url('/img/sprout/emojis/speech_bubble_pink.png') !important;
  border-image-slice: 16 16 32 16 fill !important;
  border-image-width: 14px 16px 18px 16px !important;
  border-image-repeat: stretch !important;
  background: transparent !important;
  color: var(--text) !important;
  box-shadow: none !important;
  padding: 6px 10px !important;
  image-rendering: pixelated;
}

/* (결과 페이지 챕터 카드는 흰 배경 + multi-color shadow 유지 — Sprout 프레임 안 씀) */

/* ===== 충전 페이지 베타 박스 — Sprout 프레임 ===== */
.beta-redeem-box {
  border-style: solid !important;
  border-color: transparent !important;
  border-width: 22px 24px 26px 24px !important;
  border-image-source: url('/img/sprout/ui/dialog-big.png') !important;
  border-image-slice: 12 14 16 14 fill !important;
  border-image-width: 22px 24px 26px 24px !important;
  border-image-repeat: stretch !important;
  background: transparent !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  image-rendering: pixelated;
  padding: 8px 14px !important;
  margin: 32px 0 !important;
}
.beta-redeem-box::before, .beta-redeem-box::after {
  display: none !important;
}

/* ============================================================
   ▣▣▣ SPROUT 2차 통합 (사용자 결정 후)
   ============================================================ */

/* 결과 페이지 챕터 카드 — 흰 배경 + multi-color shadow 명시 (Sprout 프레임 무효화) */
.chapter-card {
  border-style: solid !important;
  border-image: none !important;
  border-width: 3px !important;
  border-color: var(--black) !important;
  background: var(--surface) !important;
  border-radius: 6px !important;
  padding: var(--card-padding-y) var(--card-padding-x) !important;
  margin-top: 18px !important;
  box-shadow: 5px 5px 0 var(--pink), 9px 9px 0 var(--black) !important;
  position: relative;
  image-rendering: auto;
}
.chapter-card::before {
  content: '' !important;
  display: block !important;
  position: absolute;
  top: -8px; left: -8px;
  width: 14px; height: 14px;
  background: var(--gold);
  border: 2.5px solid var(--black);
}
.chapter-card::after {
  content: '' !important;
  display: block !important;
  position: absolute;
  bottom: -8px; right: -8px;
  width: 14px; height: 14px;
  background: var(--pink);
  border: 2.5px solid var(--black);
}
.chapter-card:nth-of-type(6n+1) { box-shadow: 5px 5px 0 var(--pink), 9px 9px 0 var(--black) !important; }
.chapter-card:nth-of-type(6n+2) { box-shadow: 5px 5px 0 var(--gold), 9px 9px 0 var(--black) !important; }
.chapter-card:nth-of-type(6n+3) { box-shadow: 5px 5px 0 #8ddec5, 9px 9px 0 var(--black) !important; }
.chapter-card:nth-of-type(6n+4) { box-shadow: 5px 5px 0 #c4a8e8, 9px 9px 0 var(--black) !important; }
.chapter-card:nth-of-type(6n+5) { box-shadow: 5px 5px 0 #ff8b6b, 9px 9px 0 var(--black) !important; }
.chapter-card:nth-of-type(6n+0) { box-shadow: 5px 5px 0 var(--pink), 9px 9px 0 var(--black) !important; }

/* ===== 사용자 채팅 메시지 — Sprout 분홍 말풍선 ===== */
.msg-user {
  border-style: solid !important;
  border-color: transparent !important;
  border-width: 16px 18px 28px 18px !important;
  border-image-source: url('/img/sprout/emojis/speech_bubble_pink.png') !important;
  border-image-slice: 18 18 38 18 fill !important;
  border-image-width: 16px 18px 28px 18px !important;
  border-image-repeat: stretch !important;
  background: transparent !important;
  color: var(--text) !important;
  font-weight: 600;
  box-shadow: none !important;
  padding: 4px 10px 14px !important;
  image-rendering: pixelated;
  margin-bottom: 8px;
}

/* ===== 별조각 카운터 — 픽셀 동전/하트 시각화 ===== */
.recharge-balance {
  position: relative;
  text-align: center;
}
.recharge-balance-num {
  position: relative;
  display: inline-block;
}
/* 결제 데모 모달 */
.pay-demo-modal {
  position: fixed;
  inset: 0;
  background: rgba(17,17,17,0.55);
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
}
.pay-demo-modal[hidden] { display: none; }
.pay-demo-card {
  background: var(--surface, #fff);
  border: 3px solid var(--black);
  box-shadow: 6px 6px 0 var(--black);
  border-radius: 8px;
  padding: 26px 22px 20px;
  max-width: 360px;
  width: 100%;
  position: relative;
  text-align: center;
  font-family: var(--sans);
}
.pay-demo-close {
  position: absolute;
  top: 8px;
  right: 10px;
  background: none;
  border: none;
  font-size: 24px;
  color: var(--subtext);
  cursor: pointer;
  line-height: 1;
  padding: 4px 8px;
}
.pay-demo-badge {
  display: inline-block;
  font-size: 8px;
  letter-spacing: 0.2em;
  color: var(--gold);
  background: var(--black);
  padding: 4px 10px;
  border-radius: 2px;
  margin-bottom: 12px;
}
.pay-demo-title {
  font-size: 18px;
  letter-spacing: 0.04em;
  margin-bottom: 12px;
  color: var(--black);
}
.pay-demo-pack {
  font-family: var(--pixel);
  font-size: 12px;
  background: var(--surface2, #fdf9f0);
  border: 2px solid var(--black);
  padding: 10px 14px;
  margin-bottom: 14px;
  border-radius: 4px;
  letter-spacing: 0.04em;
}
.pay-demo-sub {
  font-size: 13px;
  line-height: 1.6;
  color: var(--text);
  margin-bottom: 18px;
}
.pay-demo-divider {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 14px 0 10px;
  color: var(--subtext);
  font-size: 11px;
}
.pay-demo-divider::before,
.pay-demo-divider::after {
  content: '';
  flex: 1;
  border-top: 1.5px dashed var(--border-soft, #d8d2c5);
}
.pay-demo-cta {
  display: block;
  width: 100%;
  background: var(--pink);
  color: #fff;
  border: 2.5px solid var(--black);
  box-shadow: 3px 3px 0 var(--black);
  font-family: var(--pixel);
  font-size: 11px;
  letter-spacing: 0.05em;
  padding: 14px 12px;
  cursor: pointer;
  border-radius: 4px;
  margin-bottom: 8px;
  transition: transform .12s, box-shadow .12s;
}
.pay-demo-cta:hover {
  transform: translate(-1px, -1px);
  box-shadow: 4px 4px 0 var(--black);
}
.pay-demo-hint {
  font-size: 11px;
  color: var(--subtext);
  line-height: 1.5;
}

.recharge-balance-num::before {
  content: '★';
  display: inline-block;
  font-family: 'Press Start 2P', var(--pixel), monospace;
  font-size: 36px;
  color: var(--gold);
  text-shadow: 2px 2px 0 var(--black);
  vertical-align: -4px;
  margin-right: 12px;
  line-height: 1;
}

/* 패키지 카드 안의 별 아이콘 (Sprout 스타일 hint) */
.recharge-pack-icon {
  filter: drop-shadow(2px 2px 0 rgba(17,17,17,0.2));
  image-rendering: pixelated;
}

/* ===== 홈 카탈로그 카드 — Sprout 프레임 (선택적 .sprout-cat 클래스로 적용) ===== */
.catalog-card.sprout-cat,
.home-catalog-modal-card-item.sprout-cat {
  border-style: solid !important;
  border-color: transparent !important;
  border-width: 18px 20px 22px 20px !important;
  border-image-source: url('/img/sprout/ui/dialog-medium.png') !important;
  border-image-slice: 12 14 16 14 fill !important;
  border-image-width: 18px 20px 22px 20px !important;
  border-image-repeat: stretch !important;
  background: transparent !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  image-rendering: pixelated;
}

/* ===== 사주 추가 폼 박스 (옵션 .sprout-form-frame) ===== */
.sprout-form-frame {
  border-style: solid !important;
  border-color: transparent !important;
  border-width: 22px 24px 26px 24px !important;
  border-image-source: url('/img/sprout/ui/dialog-big.png') !important;
  border-image-slice: 14 16 18 16 fill !important;
  border-image-width: 22px 24px 26px 24px !important;
  border-image-repeat: stretch !important;
  background: transparent !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  image-rendering: pixelated;
  padding: 12px 18px !important;
  margin-bottom: 32px;
}

/* ===== Sprout 폰트 — 픽셀 폰트 클래스에 한국 텍스트도 대응 ===== */
.pixel-font.use-sprout, .sprout-pixel {
  font-family: 'SproutPixel', 'Press Start 2P', monospace !important;
  letter-spacing: 0 !important;
}

/* ===== 카탈로그 카드 안 하트/별 픽셀 액센트 — 호버 시 등장 ===== */
.catalog-card { position: relative; }
.catalog-card:hover .catalog-thumb-icon {
  animation: catalogIconBob 0.8s ease-in-out infinite;
}
@keyframes catalogIconBob {
  0%,100% { transform: rotate(-4deg) translateY(0); }
  50% { transform: rotate(4deg) translateY(-3px); }
}

/* ===== 사용자 메시지 — 분홍 단색 (border-image multi-bubble 버그 fix) ===== */
.msg-user {
  border-style: solid !important;
  border-image: none !important;
  border-image-source: none !important;
  border-width: 2.5px !important;
  border-color: var(--black) !important;
  background: var(--pink) !important;
  color: #fff !important;
  box-shadow: 4px 4px 0 var(--black) !important;
  padding: 12px 16px !important;
  border-radius: 6px !important;
  image-rendering: auto;
  align-self: flex-end !important;
  font-weight: 600;
}

/* ============================================================
   ▣▣▣ CATALOG V2 — 사용자 디자인 6 카드 통합 (2026-05-11)
   각 카드별 다른 색 타이틀 + 이미지 상단 + 텍스트 하단
   ============================================================ */

.catalog-grid.catalog-grid-v2 {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 18px !important;
}
@media (max-width: 920px) {
  .catalog-grid.catalog-grid-v2 { grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 520px) {
  /* 모바일: 2열 컴팩트 그리드 — 홈 모달 스타일에 가깝게 */
  .catalog-grid.catalog-grid-v2 { grid-template-columns: repeat(2, 1fr) !important; gap: 12px !important; }
  .catalog-grid-v2 .catalog-card { min-height: 0 !important; box-shadow: 3px 3px 0 var(--gold), 5px 5px 0 var(--black) !important; }
  .catalog-grid-v2 .catalog-card::before,
  .catalog-grid-v2 .catalog-card::after { width: 10px; height: 10px; }
  .catalog-grid-v2 .cat-img { aspect-ratio: 1 / 1; }
  .catalog-grid-v2 .cat-title { font-size: 16px !important; margin: 9px 10px 4px !important; }
  .catalog-grid-v2 .cat-desc { font-size: 11px !important; line-height: 1.45 !important; margin: 0 10px 10px !important; }
}
@media (max-width: 380px) {
  .catalog-grid.catalog-grid-v2 { gap: 10px !important; }
  .catalog-grid-v2 .cat-title { font-size: 14px !important; }
  .catalog-grid-v2 .cat-desc { font-size: 10px !important; }
}

.catalog-grid-v2 .catalog-card {
  display: flex !important;
  flex-direction: column !important;
  background: var(--surface) !important;
  border: 3px solid var(--black) !important;
  border-radius: 8px !important;
  padding: 0 !important;
  text-decoration: none !important;
  color: var(--text) !important;
  overflow: hidden;
  position: relative;
  transition: transform .2s cubic-bezier(.16,1,.3,1), box-shadow .2s !important;
  min-height: 320px;
  box-shadow: 5px 5px 0 var(--gold), 9px 9px 0 var(--black) !important;
}
.catalog-grid-v2 .catalog-card::before,
.catalog-grid-v2 .catalog-card::after {
  content: '';
  position: absolute;
  width: 14px; height: 14px;
  border: 2.5px solid var(--black);
  z-index: 3;
}
.catalog-grid-v2 .catalog-card::before { top: -8px; left: -8px; background: var(--pink); }
.catalog-grid-v2 .catalog-card::after { bottom: -8px; right: -8px; background: var(--gold); }
.catalog-grid-v2 .catalog-card:hover {
  transform: translate(-3px, -3px) !important;
  box-shadow: 7px 7px 0 var(--gold), 11px 11px 0 var(--black) !important;
  text-decoration: none !important;
}

/* 카드별 코너 픽셀 + shadow 색깔 회전 */
.cat-profile {       box-shadow: 5px 5px 0 #ff3d7f, 9px 9px 0 var(--black) !important; }
.cat-profile::before { background: #ff3d7f !important; }
.cat-compatibility { box-shadow: 5px 5px 0 #ffc83d, 9px 9px 0 var(--black) !important; }
.cat-compatibility::before { background: #ffc83d !important; }
.cat-big-fortune {   box-shadow: 5px 5px 0 #8ddec5, 9px 9px 0 var(--black) !important; }
.cat-big-fortune::before { background: #8ddec5 !important; }
.cat-yearly {        box-shadow: 5px 5px 0 #ff8b6b, 9px 9px 0 var(--black) !important; }
.cat-yearly::before { background: #ff8b6b !important; }
.cat-this-month {    box-shadow: 5px 5px 0 #ff3d7f, 9px 9px 0 var(--black) !important; }
.cat-this-month::before { background: #ff3d7f !important; }
.cat-chat {          box-shadow: 5px 5px 0 #c4a8e8, 9px 9px 0 var(--black) !important; }
.cat-chat::before { background: #c4a8e8 !important; }

/* 이미지 영역 — 카드 상단 60% (정사각형 가깝게) */
.cat-img {
  width: 100%;
  aspect-ratio: 1 / 1;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  border-bottom: 3px solid var(--black);
  background-color: #fff8ec;
  image-rendering: pixelated;
  image-rendering: crisp-edges;
  transition: transform .25s;
}
.catalog-grid-v2 .catalog-card:hover .cat-img {
  transform: scale(1.04);
}

/* 타이틀 — 카드별 다른 색 */
.cat-title {
  font-family: 'Black Han Sans', var(--sans) !important;
  font-size: 24px !important;
  letter-spacing: -0.01em !important;
  font-weight: 400 !important;
  margin: 14px 16px 8px !important;
  line-height: 1.2 !important;
}
.cat-profile       .cat-title { color: #ff3d7f !important; }
.cat-compatibility .cat-title { color: #d99a1a !important; }
.cat-big-fortune   .cat-title { color: #1aaa50 !important; }
.cat-yearly        .cat-title { color: #ff5544 !important; }
.cat-this-month    .cat-title { color: #ff3d7f !important; }
.cat-chat          .cat-title { color: #9b5fd6 !important; }

/* 설명 텍스트 */
.cat-desc {
  font-family: var(--sans) !important;
  font-size: 14px !important;
  line-height: 1.55 !important;
  color: #2a221a !important;
  margin: 0 16px 18px !important;
  word-break: keep-all;
  flex: 1;
}

/* 기존 v1 카드 스타일 무효화 (이미지 카드만 보이도록) */
.catalog-grid-v2 .catalog-thumb,
.catalog-grid-v2 .catalog-card-title,
.catalog-grid-v2 .catalog-card-desc,
.catalog-grid-v2 .catalog-card-price,
.catalog-grid-v2 .catalog-card-cta {
  display: none !important;
}

@media (max-width: 520px) {
  .cat-title { font-size: 22px !important; }
  .cat-desc { font-size: 13px !important; }
  .catalog-grid-v2 .catalog-card { min-height: 280px; }
}

/* ===== 직업 폼 "선택 안 함" — 카드 그대로, 글씨만 카드 정중앙 (2026-05-11) ===== */
.job-grid .job-card-skip {
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;  /* 세로 중앙 */
  align-items: center !important;       /* 가로 중앙 */
  text-align: center !important;
}
/* 빈 아이콘 div는 자리 차지 X */
.job-grid .job-card-skip > div:first-child {
  display: none !important;
}

/* ============================================================
   ▣▣▣ 보관함 사주 PICKER 모달 (2026-05-11)
   ============================================================ */
.saju-picker {
  position: fixed;
  inset: 0;
  z-index: 9000;
  background: rgba(17,17,17,0.55);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  animation: spkFadeIn 0.18s ease-out;
}
@keyframes spkFadeIn { from { opacity: 0; } to { opacity: 1; } }
.saju-picker[hidden] { display: none !important; }
.saju-picker-card {
  background: var(--surface);
  border: 3px solid var(--black);
  border-radius: 8px;
  box-shadow: 6px 6px 0 var(--gold), 10px 10px 0 var(--black);
  max-width: 480px;
  width: 100%;
  max-height: 80vh;
  overflow-y: auto;
  padding: 28px 24px 22px;
  position: relative;
}
.saju-picker-card::before, .saju-picker-card::after {
  content: '';
  position: absolute;
  width: 14px; height: 14px;
  border: 2.5px solid var(--black);
}
.saju-picker-card::before { top: -8px; left: -8px; background: var(--pink); }
.saju-picker-card::after { bottom: -8px; right: -8px; background: var(--gold); }
.saju-picker-close {
  position: absolute;
  top: 12px; right: 12px;
  width: 32px; height: 32px;
  border: 2.5px solid var(--black);
  background: #fff;
  border-radius: 0;
  font-size: 18px;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 2px 2px 0 var(--black);
}
.saju-picker-close:hover { background: var(--pink); color: #fff; }
.saju-picker-eyebrow {
  display: inline-block;
  font-family: var(--pixel);
  font-size: 10px;
  color: #fff;
  background: var(--pink);
  border: 2px solid var(--black);
  padding: 4px 8px;
  letter-spacing: 0.15em;
  margin-bottom: 12px;
  box-shadow: 2px 2px 0 var(--black);
}
.saju-picker-title {
  font-family: 'Black Han Sans', var(--sans);
  font-size: 22px;
  font-weight: 400;
  line-height: 1.3;
  margin-bottom: 6px;
  color: var(--black);
}
.saju-picker-sub {
  font-size: 13px;
  color: var(--subtext);
  margin-bottom: 18px;
  line-height: 1.6;
}
.saju-picker-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 18px;
}
.saju-picker-empty {
  text-align: center;
  padding: 28px 16px 22px;
  background: var(--surface2, #fdf9f0);
  border: 2.5px dashed var(--black);
  border-radius: 6px;
}
.spk-empty-icon { font-size: 36px; line-height: 1; margin-bottom: 10px; }
.spk-empty-title { font-family: var(--pixel); font-size: 12px; letter-spacing: 0.04em; margin-bottom: 8px; color: var(--black); }
.spk-empty-sub { font-size: 12px; color: var(--subtext); line-height: 1.5; }
.saju-pick-card {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 14px;
  background: var(--surface2);
  border: 2.5px solid var(--black);
  border-radius: 6px;
  cursor: pointer;
  box-shadow: 3px 3px 0 var(--black);
  text-align: left;
  font-family: var(--sans);
  width: 100%;
  transition: transform .12s, box-shadow .12s, background .15s;
}
.saju-pick-card:hover {
  transform: translate(-2px, -2px);
  box-shadow: 5px 5px 0 var(--black);
  background: #fff;
}
.saju-pick-card.is-selected {
  background: linear-gradient(135deg, #fff7e8 0%, #ffeec8 100%);
  box-shadow: 4px 4px 0 var(--gold);
}
.spc-avatar {
  flex-shrink: 0;
  width: 44px; height: 44px;
  background: var(--pink);
  border: 2.5px solid var(--black);
  border-radius: 6px;
  box-shadow: 2px 2px 0 var(--black);
}
.spc-info { flex: 1; min-width: 0; }
.spc-name {
  font-family: 'Black Han Sans', var(--sans);
  font-size: 17px;
  color: var(--black);
  line-height: 1.2;
  margin-bottom: 4px;
}
.spc-meta {
  font-size: 12px;
  color: var(--subtext);
  line-height: 1.4;
}
.spc-arrow {
  font-family: var(--pixel);
  color: var(--pink);
  font-size: 11px;
}
.saju-picker-add {
  display: block;
  text-align: center;
  padding: 12px 14px;
  background: var(--gold);
  color: var(--black);
  border: 2.5px solid var(--black);
  border-radius: 6px;
  text-decoration: none;
  font-family: var(--sans);
  font-size: 14px;
  font-weight: 700;
  box-shadow: 3px 3px 0 var(--black);
  transition: transform .12s, box-shadow .12s;
}
.saju-picker-add:hover {
  transform: translate(-1px, -1px);
  box-shadow: 4px 4px 0 var(--black);
  text-decoration: none;
}

/* ============================================================
   ▣▣▣ 대운 시기 잠금 UI (2026-05-11 — d옵션: 베타 자동 해제)
   ============================================================ */
.big-fortune-card.big-fortune-card-locked {
  background: linear-gradient(180deg, #fff 0%, #fff8ec 60%, #f5e6b2 100%);
  opacity: 0.92;
  position: relative;
}
.big-fortune-card-locked::before {
  background: #8a7d6f !important;
}
.bf-lock-badge {
  display: inline-block;
  font-family: var(--pixel);
  font-size: 8px;
  background: var(--black);
  color: var(--gold);
  border: 2px solid var(--black);
  padding: 3px 7px;
  margin-left: 6px;
  letter-spacing: 0.1em;
  box-shadow: 2px 2px 0 var(--gold);
  vertical-align: middle;
}
.bf-lock-box {
  text-align: center;
  padding: 24px 16px 16px;
  background: linear-gradient(180deg, rgba(255,200,61,0.08) 0%, rgba(255,61,127,0.05) 100%);
  border: 2.5px dashed var(--black);
  border-radius: 6px;
  margin-top: 12px;
}
.bf-lock-icon {
  font-size: 36px;
  margin-bottom: 8px;
  filter: drop-shadow(2px 2px 0 rgba(17,17,17,0.2));
}
.bf-lock-msg {
  font-family: var(--sans);
  font-size: 14px;
  font-weight: 700;
  color: var(--black);
  margin-bottom: 14px;
}
.bf-lock-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--pink);
  color: #fff !important;
  border: 2.5px solid var(--black);
  border-radius: 6px;
  padding: 12px 18px; /* WCAG 2.2 — 44px 터치 타겟 */
  min-height: 44px;
  font-family: var(--pixel);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-decoration: none !important;
  box-shadow: 3px 3px 0 var(--black);
  transition: transform .12s, box-shadow .12s;
}
.bf-lock-cta:hover {
  transform: translate(-1px, -1px);
  box-shadow: 4px 4px 0 var(--black);
  text-decoration: none !important;
}
.bf-lock-cta:active {
  transform: translate(2px, 2px);
  box-shadow: 1px 1px 0 var(--black);
}
.bf-lock-hint {
  margin-top: 10px;
  font-size: 11px;
  color: var(--subtext);
  font-style: italic;
}

/* ============================================================
   ▣▣▣ home-catalog-modal — 사용자 캐릭터 이미지 통일 (2026-05-11)
   모달 안 카드 6장에 새 이미지 + 카드별 색 타이틀
   ============================================================ */
.home-catalog-modal-grid {
  gap: 12px !important;
}
.home-catalog-modal-card-item {
  padding: 12px 10px 14px !important;
  text-align: center;
  border: 2.5px solid var(--black) !important;
  border-radius: 6px !important;
  box-shadow: 3px 3px 0 var(--gold), 5px 5px 0 var(--black) !important;
  overflow: hidden;
  background: var(--surface) !important;
  position: relative;
  transition: transform .15s, box-shadow .15s !important;
}
.home-catalog-modal-card-item:hover {
  transform: translate(-2px, -2px);
  box-shadow: 5px 5px 0 var(--gold), 7px 7px 0 var(--black) !important;
}
.home-catalog-modal-card-icon {
  width: 72px !important;
  height: 72px !important;
  background-size: cover !important;
  background-position: center !important;
  background-repeat: no-repeat;
  font-size: 0 !important;        /* 이모지 텍스트 숨김 */
  image-rendering: pixelated;
  border: 2px solid var(--black);
  border-radius: 4px;
  margin: 0 auto 6px !important;
  background-color: #fff8ec;
}
/* cat별 이미지 매핑 (HTML attribute selector) */
.home-catalog-modal-card-item[href*="cat=profile"] .home-catalog-modal-card-icon {
  background-image: url('/img/cards/profile.png');
}
.home-catalog-modal-card-item[href*="cat=compatibility"] .home-catalog-modal-card-icon {
  background-image: url('/img/cards/compatibility.png');
}
.home-catalog-modal-card-item[href*="cat=big-fortune"] .home-catalog-modal-card-icon {
  background-image: url('/img/cards/big-fortune.png');
}
.home-catalog-modal-card-item[href*="cat=yearly"] .home-catalog-modal-card-icon {
  background-image: url('/img/cards/yearly.png');
}
.home-catalog-modal-card-item[href*="cat=this-month"] .home-catalog-modal-card-icon,
.home-catalog-modal-card-item[href="/today/"] .home-catalog-modal-card-icon {
  background-image: url('/img/cards/this-month.png');
}
.home-catalog-modal-card-item[href="/chat/"] .home-catalog-modal-card-icon {
  background-image: url('/img/cards/chat.png');
}
/* 타이틀 카드별 색 (모달 버전) */
.home-catalog-modal-card-title {
  font-family: 'Black Han Sans', var(--sans) !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  letter-spacing: 0 !important;
  line-height: 1.2 !important;
  margin-bottom: 4px !important;
}
.home-catalog-modal-card-item[href*="cat=profile"] .home-catalog-modal-card-title { color: #ff3d7f !important; }
.home-catalog-modal-card-item[href*="cat=compatibility"] .home-catalog-modal-card-title { color: #d99a1a !important; }
.home-catalog-modal-card-item[href*="cat=big-fortune"] .home-catalog-modal-card-title { color: #1aaa50 !important; }
.home-catalog-modal-card-item[href*="cat=yearly"] .home-catalog-modal-card-title { color: #ff5544 !important; }
.home-catalog-modal-card-item[href*="cat=this-month"] .home-catalog-modal-card-title,
.home-catalog-modal-card-item[href="/today/"] .home-catalog-modal-card-title { color: #ff3d7f !important; }
.home-catalog-modal-card-item[href="/chat/"] .home-catalog-modal-card-title { color: #9b5fd6 !important; }
.home-catalog-modal-card-desc {
  font-size: 11px !important;
  line-height: 1.4 !important;
  color: var(--subtext) !important;
}

/* 모바일 ≤480px — 2열 유지를 위해 카드 컴팩트화 (사용자 요청 #1) */
@media (max-width: 480px) {
  /* 모달 컨테이너 자체도 컴팩트 — 홈 카탈로그 그리드 사이즈 맞춤 */
  .home-catalog-modal-card {
    padding: 18px 14px 18px !important;
  }
  .home-catalog-modal-eyebrow {
    font-size: 8px !important;
    margin-bottom: 4px !important;
  }
  .home-catalog-modal-title {
    font-size: 15px !important;
    margin-bottom: 14px !important;
  }
  .home-catalog-modal-card-item {
    padding: 10px 8px 12px !important;
    box-shadow: 2px 2px 0 var(--gold), 4px 4px 0 var(--black) !important;
  }
  .home-catalog-modal-card-icon {
    width: 56px !important;
    height: 56px !important;
    margin: 0 auto 4px !important;
  }
  .home-catalog-modal-card-title {
    font-size: 12px !important;
    margin-bottom: 2px !important;
  }
  .home-catalog-modal-card-desc {
    font-size: 9.5px !important;
    line-height: 1.35 !important;
  }
}

/* ============================================================
   ⭐ 카탈로그 카드 제목 두껍게 (사용자 요청)
   12챕터/궁합/대운/연도별/이번달/상담소 — 6 카드 모두
   ============================================================ */
.home-catalog-modal-card-title,
.catalog-card-title {
  font-weight: 900 !important;
  /* text-stroke로 더 두꺼운 효과 — 픽셀 폰트 미지원이라도 일반 폰트에서 효과 */
  -webkit-text-stroke: 0.6px currentColor;
  text-stroke: 0.6px currentColor;
  /* paint-order로 stroke 안쪽으로만 (글자가 굵어 보이게) */
  paint-order: stroke fill;
}
@media (max-width: 480px) {
  .home-catalog-modal-card-title,
  .catalog-card-title {
    -webkit-text-stroke: 0.5px currentColor;
    text-stroke: 0.5px currentColor;
  }
}

/* ============================================================
   ▣▣▣ Picker 추가 폼 CSS (saju-picker.js의 .spk-* 클래스)
   ============================================================ */
.spk-form {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-top: 10px;
}
.spk-field { display: flex; flex-direction: column; gap: 6px; }
.spk-label {
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 700;
  color: var(--black);
  letter-spacing: 0.02em;
}
.spk-opt {
  font-weight: 400;
  color: var(--subtext);
  font-size: 11px;
}
.spk-input {
  width: 100%;
  padding: 10px 12px;
  border: 2.5px solid var(--black);
  background: #fff;
  font-family: var(--sans);
  font-size: 14px;
  color: var(--black);
  border-radius: 6px;
  box-shadow: 2px 2px 0 var(--black);
}
.spk-input:focus {
  outline: none;
  box-shadow: 3px 3px 0 var(--gold);
}
.spk-row {
  display: flex;
  gap: 8px;
  align-items: center;
}
.spk-row-3 .spk-input { flex: 1; min-width: 0; }
.spk-radio {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 12px;
  border: 2.5px solid var(--black);
  border-radius: 6px;
  background: var(--surface);
  cursor: pointer;
  font-size: 13px;
  font-weight: 600;
  flex: 1;
  text-align: center;
  justify-content: center;
  box-shadow: 2px 2px 0 var(--black);
}
.spk-radio input { accent-color: var(--pink); }
.spk-radio:has(input:checked) {
  background: var(--gold);
}
/* 4축 페어 정렬 (위저드와 동일 톤) */
.spk-mbti-axes {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.spk-mbti-axis-row {
  background: var(--surface2, #fdf9f0);
  border: 2px solid var(--black);
  padding: 9px 11px;
  border-radius: 4px;
}
.spk-mbti-axis-hint {
  font-size: 11px;
  color: var(--subtext);
  margin-bottom: 7px;
  line-height: 1.4;
}
.spk-mbti-pair {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.spk-mbti-btn {
  padding: 10px 0;
  border: 2.5px solid var(--black);
  background: var(--surface);
  font-family: var(--pixel);
  font-size: 11px;
  cursor: pointer;
  border-radius: 4px;
  box-shadow: 2px 2px 0 var(--black);
  transition: all .12s;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  min-height: 50px;
}
.spk-mbti-letter { font-family: var(--pixel); font-size: 16px; letter-spacing: 0.05em; }
.spk-mbti-desc { font-family: var(--sans); font-size: 10px; color: var(--subtext); font-weight: 500; }
.spk-mbti-btn:hover {
  background: #fff8ec;
}
.spk-mbti-btn.is-active {
  background: var(--pink);
  color: #fff;
  box-shadow: 1px 1px 0 var(--black);
  transform: translate(1px, 1px);
}
.spk-mbti-btn.is-active .spk-mbti-desc { color: rgba(255,255,255,0.85); }
.spk-mbti-preview {
  margin-top: 8px;
  font-family: var(--pixel);
  font-size: 12px;
  color: var(--gold);
  text-align: center;
  letter-spacing: 0.2em;
}
.spk-actions {
  display: flex;
  gap: 10px;
  margin-top: 6px;
  flex-wrap: wrap;
}
.spk-back-btn {
  flex: 1;
  padding: 12px;
  background: var(--surface2);
  border: 2.5px solid var(--black);
  border-radius: 6px;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 2px 2px 0 var(--black);
  color: var(--black);
}
.spk-submit-btn {
  flex: 2;
  padding: 12px;
  background: var(--pink);
  color: #fff;
  border: 2.5px solid var(--black);
  border-radius: 6px;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 3px 3px 0 var(--black);
}
.spk-submit-btn:hover {
  transform: translate(-1px, -1px);
  box-shadow: 4px 4px 0 var(--black);
}

/* Picker 모달 add 버튼을 button으로 변경 (기존 a 스타일은 이미 있음) */
button.saju-picker-add {
  display: block;
  width: 100%;
  text-align: center;
  padding: 12px 14px;
  background: var(--gold);
  color: var(--black);
  border: 2.5px solid var(--black);
  border-radius: 6px;
  font-family: var(--sans);
  font-size: 14px;
  font-weight: 700;
  box-shadow: 3px 3px 0 var(--black);
  cursor: pointer;
}
button.saju-picker-add:hover {
  transform: translate(-1px, -1px);
  box-shadow: 4px 4px 0 var(--black);
}
