/* ==========================================
   오늘의 운 - 메인 스타일시트 (리디자인판)
   타겟: 40~60대 / 라이트 모드 기본
   컨셉: 전통의 품격 + 현대적 따뜻함
   - 배경: 한지 느낌의 따뜻한 아이보리
   - 포인트: 단청 오렌지 + 깊은 감청색
   - 카드: 높은 명암 대비, 부드러운 쉐도우
   - 타이포: Noto Serif KR 제목 / Noto Sans KR 본문
   ========================================== */

/* ── CSS 커스텀 속성 (라이트 모드 기본) ── */
:root {
  /* 바탕 — 한지 아이보리 */
  --배경색: #f7f3ec;
  --배경보조: #efe9dd;
  --카드색: #ffffff;
  --카드그림자: 0 1px 3px rgba(50, 40, 30, 0.05), 0 6px 20px rgba(50, 40, 30, 0.06);
  --카드그림자강: 0 4px 12px rgba(50, 40, 30, 0.08), 0 12px 32px rgba(50, 40, 30, 0.08);

  /* 글자 */
  --글자색: #2b2017;
  --보조글자색: #6a5a4a;
  --연한글자색: #a69b8d;

  /* 강조 — 단청 오렌지 & 감청 */
  --강조색: #d4a037;        /* 전통 금빛 */
  --강조색진: #c86a1a;      /* 단청 주홍 */
  --강조색2: #8b3a1f;       /* 깊은 주홍 (호버 등) */
  --감청: #1f3b5e;          /* 감청/먹색 보조 */

  /* 주요 버튼 */
  --주요버튼색: #c86a1a;
  --주요버튼글자: #ffffff;

  /* 탭바 */
  --탭바배경: #ffffff;
  --탭바그림자: 0 -4px 20px rgba(50, 40, 30, 0.08);
  --탭비활성: #a69b8d;
  --탭활성: #c86a1a;

  /* 입력 */
  --입력배경: #faf6ef;
  --입력테두리: #e4dccb;
  --입력포커스: #d4a037;

  /* 구분선 */
  --구분선: #ece5d5;
  --구분선진: #d9cfbc;

  /* 유료 블러 */
  --블러배경: rgba(255, 255, 255, 0.78);

  /* 로또 공 (동행복권 공식 기준 — 변경 금지) */
  --공1to10: #fbc400;
  --공11to20: #69c8f2;
  --공21to30: #ff7272;
  --공31to40: #aaaaaa;
  --공41to45: #b0d840;

  /* 오행 (규칙 고정) */
  --오행목: #4CAF50;
  --오행화: #F44336;
  --오행토: #FF9800;
  --오행금: #9E9E9E;
  --오행수: #2196F3;

  --오행목배경: rgba(76, 175, 80, 0.12);
  --오행화배경: rgba(244, 67, 54, 0.10);
  --오행토배경: rgba(255, 152, 0, 0.12);
  --오행금배경: rgba(158, 158, 158, 0.10);
  --오행수배경: rgba(33, 150, 243, 0.10);

  /* 보조 표면색 */
  --보조카드색: #faf5ea;

  /* saju-web 호환 */
  --accent: var(--강조색진);
  --accent2: var(--강조색);
  --bg: var(--배경색);
  --text: var(--글자색);
  --text-dim: var(--보조글자색);
  --surface: var(--카드색);
  --surface2: var(--입력배경);
  --wood: var(--오행목);
  --fire: var(--오행화);
  --earth: var(--오행토);
  --metal: var(--오행금);
  --water: var(--오행수);
  --wood-bg: var(--오행목배경);
  --fire-bg: var(--오행화배경);
  --earth-bg: var(--오행토배경);
  --water-bg: var(--오행수배경);
  --metal-bg: var(--오행금배경);

  /* 폰트 */
  --본문폰트: 'Noto Sans KR', sans-serif;
  --제목폰트: 'Noto Serif KR', serif;

  /* 크기 */
  --최대너비: 600px;
  --탭바높이: 68px;
  --헤더높이: 60px;
  --라운드: 16px;
  --라운드소: 10px;
  --라운드대: 22px;
}

/* ── 다크 모드 — 먹색/감청 기반 ── */
body.dark {
  --배경색: #16171d;
  --배경보조: #1d1f28;
  --카드색: #22242e;
  --카드그림자: 0 2px 8px rgba(0, 0, 0, 0.35), 0 10px 28px rgba(0, 0, 0, 0.25);
  --카드그림자강: 0 4px 12px rgba(0, 0, 0, 0.4), 0 14px 34px rgba(0, 0, 0, 0.35);

  --글자색: #ece6dc;
  --보조글자색: #b4a999;
  --연한글자색: #7e7568;

  --강조색: #ffc857;
  --강조색진: #ff9c3e;
  --강조색2: #ffb24c;
  --감청: #88a7d9;

  --주요버튼색: #ff9c3e;

  --탭바배경: #22242e;
  --탭바그림자: 0 -4px 20px rgba(0, 0, 0, 0.4);
  --탭비활성: #7e7568;
  --탭활성: #ffc857;

  --입력배경: #1d1f28;
  --입력테두리: #383a46;
  --입력포커스: #ffc857;

  --구분선: #2d2f3a;
  --구분선진: #383a46;
  --블러배경: rgba(34, 36, 46, 0.78);

  --오행목배경: rgba(76, 175, 80, 0.18);
  --오행화배경: rgba(244, 67, 54, 0.15);
  --오행토배경: rgba(255, 152, 0, 0.16);
  --오행금배경: rgba(158, 158, 158, 0.14);
  --오행수배경: rgba(33, 150, 243, 0.15);

  --보조카드색: #282a35;
}

/* ── 리셋 ── */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 18px;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--본문폰트);
  background-color: var(--배경색);
  background-image:
    radial-gradient(circle at 0% 0%, rgba(212, 160, 55, 0.07), transparent 40%),
    radial-gradient(circle at 100% 100%, rgba(31, 59, 94, 0.05), transparent 40%);
  background-attachment: fixed;
  color: var(--글자색);
  line-height: 1.65;
  min-height: 100vh;
  padding-top: var(--헤더높이);
  padding-bottom: calc(var(--탭바높이) + 16px);
  transition: background-color 0.3s, color 0.3s;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

a {
  color: var(--강조색진);
  text-decoration: none;
}

button {
  font-family: var(--본문폰트);
}

/* ── 헤더 ── */
.앱헤더 {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  height: var(--헤더높이);
  background: var(--카드색);
  border-bottom: 1px solid var(--구분선);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 18px;
  max-width: 100%;
  transition: background-color 0.3s;
}

.서비스명 {
  font-family: var(--제목폰트);
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  background: linear-gradient(135deg, var(--강조색), var(--강조색진));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.서비스명::before {
  content: '';
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--강조색), var(--강조색진));
  margin-right: 8px;
  vertical-align: 3px;
  box-shadow: 0 0 10px rgba(200, 106, 26, 0.4);
}

.다크모드버튼 {
  display: flex;
  align-items: center;
  gap: 6px;
  background: var(--입력배경);
  border: 1px solid var(--입력테두리);
  border-radius: 24px;
  padding: 8px 14px;
  font-size: 0.82rem;
  color: var(--보조글자색);
  cursor: pointer;
  font-family: var(--본문폰트);
  transition: all 0.2s;
  min-height: 40px;
}

.다크모드버튼:hover {
  border-color: var(--강조색);
  color: var(--강조색진);
}

.다크모드버튼 .아이콘 {
  font-size: 1rem;
}

/* ── 메인 컨테이너 ── */
.메인컨테이너 {
  max-width: var(--최대너비);
  margin: 0 auto;
  padding: 20px 16px;
}

/* ── 탭 콘텐츠 전환 ── */
.탭콘텐츠 { display: none; }

.탭콘텐츠.활성 {
  display: block;
  animation: 페이드인 0.35s ease;
}

@keyframes 페이드인 {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ── 하단 탭바 ── */
.하단탭바 {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 100;
  height: var(--탭바높이);
  background: var(--탭바배경);
  border-top: 1px solid var(--구분선);
  box-shadow: var(--탭바그림자);
  display: flex;
  align-items: center;
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  padding-bottom: env(safe-area-inset-bottom, 0);
  transition: background-color 0.3s;
}

.하단탭바::-webkit-scrollbar { display: none; }

.하단탭바::before,
.하단탭바::after {
  position: fixed;
  bottom: 0;
  width: 32px;
  height: var(--탭바높이);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--강조색진);
  font-size: 1.4rem;
  font-weight: 700;
  pointer-events: none;
  z-index: 101;
  padding-bottom: env(safe-area-inset-bottom, 0);
  transition: opacity 0.3s;
}

.하단탭바::before {
  content: '‹';
  left: 0;
  background: linear-gradient(to left, transparent, var(--탭바배경) 55%);
  opacity: 0;
}

.하단탭바::after {
  content: '›';
  right: 0;
  background: linear-gradient(to right, transparent, var(--탭바배경) 55%);
}

.하단탭바.스크롤시작::before { opacity: 0; }
.하단탭바.스크롤중::before { opacity: 1; }
.하단탭바.스크롤끝::after { opacity: 0; }

.탭버튼 {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--탭비활성);
  font-family: var(--본문폰트);
  font-size: 0.75rem;
  padding: 8px 8px;
  min-width: 68px;
  min-height: 48px;
  flex-shrink: 0;
  transition: color 0.2s, transform 0.15s;
  -webkit-tap-highlight-color: transparent;
  position: relative;
}

.탭버튼:hover { color: var(--강조색); }

.탭버튼.활성 {
  color: var(--탭활성);
  font-weight: 700;
}

.탭버튼.활성::before {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 28px;
  height: 3px;
  border-radius: 0 0 4px 4px;
  background: linear-gradient(90deg, var(--강조색), var(--강조색진));
}

.탭아이콘 {
  font-size: 1.4rem;
  line-height: 1;
  transition: transform 0.2s;
}

.탭버튼.활성 .탭아이콘 {
  transform: scale(1.08);
}

.탭이름 { white-space: nowrap; }

/* ── 카드 ── */
.카드 {
  background: var(--카드색);
  border-radius: var(--라운드);
  box-shadow: var(--카드그림자);
  padding: 22px;
  margin-bottom: 16px;
  transition: background-color 0.3s, box-shadow 0.3s, transform 0.2s;
  border: 1px solid var(--구분선);
}

.카드제목 {
  font-family: var(--제목폰트);
  font-size: 1.3rem;
  font-weight: 700;
  margin-bottom: 14px;
  color: var(--글자색);
  letter-spacing: -0.01em;
  display: flex;
  align-items: center;
  gap: 10px;
}

.카드제목::before {
  content: '';
  display: inline-block;
  width: 4px;
  height: 20px;
  border-radius: 2px;
  background: linear-gradient(180deg, var(--강조색), var(--강조색진));
  flex-shrink: 0;
}

.소제목 {
  font-family: var(--제목폰트);
  font-size: 1.08rem;
  font-weight: 700;
  margin-bottom: 12px;
  color: var(--글자색);
}

.카드설명 {
  font-size: 0.95rem;
  color: var(--보조글자색);
  margin-bottom: 16px;
  line-height: 1.65;
}

/* ── 버튼 ── */
.주요버튼 {
  display: block;
  width: 100%;
  padding: 15px 24px;
  font-size: 1.08rem;
  font-weight: 700;
  font-family: var(--본문폰트);
  color: var(--주요버튼글자);
  background: linear-gradient(135deg, var(--강조색), var(--강조색진));
  border: none;
  border-radius: 14px;
  cursor: pointer;
  min-height: 54px;
  letter-spacing: 0.02em;
  box-shadow: 0 4px 14px rgba(200, 106, 26, 0.28);
  transition: transform 0.15s, box-shadow 0.2s, filter 0.2s;
  -webkit-tap-highlight-color: transparent;
  position: relative;
  overflow: hidden;
}

.주요버튼::after {
  content: '';
  position: absolute;
  top: 0; left: -100%;
  width: 100%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.25), transparent);
  transition: left 0.6s;
}

.주요버튼:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 22px rgba(200, 106, 26, 0.4);
  filter: brightness(1.05);
}

.주요버튼:hover::after { left: 100%; }

.주요버튼:active {
  transform: translateY(0);
  box-shadow: 0 2px 8px rgba(200, 106, 26, 0.3);
}

.보조버튼 {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 13px 22px;
  font-size: 0.98rem;
  font-weight: 600;
  font-family: var(--본문폰트);
  color: var(--강조색진);
  background: var(--카드색);
  border: 2px solid var(--강조색진);
  border-radius: 12px;
  cursor: pointer;
  min-height: 48px;
  transition: all 0.2s;
  -webkit-tap-highlight-color: transparent;
}

.보조버튼:hover {
  background: var(--강조색진);
  color: #fff;
  transform: translateY(-1px);
}

/* ── 입력 필드 ── */
.입력그룹 { margin-bottom: 16px; }

.입력그룹 label {
  display: block;
  font-size: 0.92rem;
  font-weight: 600;
  color: var(--글자색);
  margin-bottom: 8px;
}

.날짜입력줄 {
  display: flex;
  gap: 8px;
  margin-bottom: 8px;
}

.날짜입력 {
  flex: 1;
  padding: 13px;
  font-size: 1rem;
  font-family: var(--본문폰트);
  border: 1.5px solid var(--입력테두리);
  border-radius: var(--라운드소);
  background: var(--입력배경);
  color: var(--글자색);
  min-height: 50px;
  text-align: center;
  transition: all 0.2s;
  -webkit-appearance: none;
}

.날짜입력:focus {
  outline: none;
  border-color: var(--입력포커스);
  background: var(--카드색);
  box-shadow: 0 0 0 4px rgba(212, 160, 55, 0.15);
}

.날짜선택 {
  flex: 1;
  padding: 13px 10px;
  font-size: 1rem;
  font-family: var(--본문폰트);
  font-weight: 500;
  border: 1.5px solid var(--입력테두리);
  border-radius: var(--라운드소);
  background: var(--입력배경);
  color: var(--글자색);
  min-height: 50px;
  text-align: center;
  transition: all 0.2s;
  -webkit-appearance: none;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23c86a1a' fill='none' stroke-width='1.8' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: 28px;
  cursor: pointer;
}

.날짜선택:focus {
  outline: none;
  border-color: var(--입력포커스);
  background-color: var(--카드색);
  box-shadow: 0 0 0 4px rgba(212, 160, 55, 0.15);
}

/* 인라인 에러 */
.인라인에러 {
  color: #c62828;
  font-size: 0.88rem;
  font-weight: 500;
  padding: 10px 14px;
  margin: 10px 0;
  background: rgba(198, 40, 40, 0.08);
  border-left: 3px solid #c62828;
  border-radius: 8px;
}

body.dark .인라인에러 { color: #ef9a9a; background: rgba(239, 154, 154, 0.1); }

.시간선택 {
  width: 100%;
  padding: 13px;
  font-size: 1rem;
  font-family: var(--본문폰트);
  border: 1.5px solid var(--입력테두리);
  border-radius: var(--라운드소);
  background: var(--입력배경);
  color: var(--글자색);
  min-height: 50px;
  -webkit-appearance: none;
  appearance: none;
  cursor: pointer;
  transition: all 0.2s;
}

.시간선택:focus {
  outline: none;
  border-color: var(--입력포커스);
  box-shadow: 0 0 0 4px rgba(212, 160, 55, 0.15);
}

input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

input[type="number"] { -moz-appearance: textfield; }

input[type="checkbox"] {
  width: 20px;
  height: 20px;
  margin-right: 6px;
  accent-color: var(--강조색진);
  vertical-align: middle;
  cursor: pointer;
}

/* ── 로또 - 등급 선택 ── */
.등급선택영역 {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 18px;
}

.등급라벨 input[type="radio"] { display: none; }

.등급라벨 { display: flex; }

.등급버튼 {
  display: flex;
  flex-direction: row;
  align-items: center;
  padding: 14px 16px;
  font-size: 0.98rem;
  font-weight: 500;
  font-family: var(--본문폰트);
  border: 2px solid var(--입력테두리);
  border-radius: 12px;
  color: var(--글자색);
  background: var(--입력배경);
  transition: all 0.2s;
  min-height: 60px;
  gap: 10px;
  width: 100%;
  cursor: pointer;
}

.등급버튼 strong {
  font-size: 1rem;
  white-space: nowrap;
  font-family: var(--제목폰트);
}

.등급설명 {
  flex: 1;
  font-size: 0.78rem;
  font-weight: 400;
  color: var(--보조글자색);
  line-height: 1.4;
  text-align: left;
}

.등급태그 {
  display: inline-block;
  font-size: 0.68rem;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 10px;
  letter-spacing: 0.04em;
}

.무료태그 {
  background: rgba(76, 175, 80, 0.15);
  color: #388E3C;
}

body.dark .무료태그 { color: #81C784; }

.등급상세설명 {
  font-size: 0.88rem;
  color: var(--보조글자색);
  background: var(--보조카드색);
  border-left: 3px solid var(--강조색);
  border-radius: 8px;
  padding: 12px 16px;
  margin-bottom: 14px;
  line-height: 1.7;
  display: none;
}

.등급라벨 input[type="radio"]:checked + .등급버튼 {
  border-color: var(--강조색진);
  background: linear-gradient(135deg, rgba(212, 160, 55, 0.12), rgba(200, 106, 26, 0.08));
  color: var(--강조색2);
  box-shadow: 0 4px 14px rgba(200, 106, 26, 0.15);
}

.등급라벨 input[type="radio"]:checked + .등급버튼 .등급설명 {
  color: var(--강조색진);
  opacity: 0.9;
}

.등급라벨 input[type="radio"]:checked + .등급버튼 strong {
  color: var(--강조색진);
}

.성별선택영역 {
  display: flex;
  gap: 10px;
}

.성별라벨 {
  flex: 1;
  cursor: pointer;
}

.성별라벨 input[type="radio"] { display: none; }

.성별버튼 {
  display: block;
  text-align: center;
  padding: 13px 8px;
  font-size: 0.98rem;
  font-weight: 500;
  border-radius: 12px;
  border: 2px solid var(--입력테두리);
  background: var(--입력배경);
  transition: all 0.2s;
  min-height: 48px;
}

.성별라벨 input[type="radio"]:checked + .성별버튼 {
  border-color: var(--강조색진);
  background: linear-gradient(135deg, rgba(212, 160, 55, 0.12), rgba(200, 106, 26, 0.08));
  color: var(--강조색2);
  font-weight: 700;
}

.다이아잠금::after {
  content: ' (준비중)';
  font-size: 0.72rem;
  color: var(--연한글자색);
}

.맛보기태그 {
  display: inline-block;
  font-size: 0.68rem;
  font-weight: 700;
  color: var(--강조색진);
  background: rgba(200, 106, 26, 0.12);
  padding: 3px 8px;
  border-radius: 10px;
  margin-left: 4px;
  vertical-align: middle;
}

/* ── 로또 - 번호 입력 ── */
.회차입력줄 {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
}

.회차입력줄 label {
  font-size: 0.95rem;
  font-weight: 600;
  white-space: nowrap;
  color: var(--글자색);
}

.회차입력 {
  width: 110px;
  padding: 12px 14px;
  font-size: 1rem;
  font-family: var(--본문폰트);
  border: 1.5px solid var(--입력테두리);
  border-radius: var(--라운드소);
  background: var(--입력배경);
  color: var(--글자색);
  min-height: 48px;
  text-align: center;
  font-weight: 600;
}

.번호입력줄 {
  display: flex;
  gap: 6px;
  margin-bottom: 14px;
}

.번호입력칸 {
  flex: 1;
  padding: 12px 4px;
  font-size: 1.1rem;
  font-weight: 700;
  font-family: var(--본문폰트);
  border: 1.5px solid var(--입력테두리);
  border-radius: var(--라운드소);
  background: var(--입력배경);
  color: var(--글자색);
  min-height: 50px;
  text-align: center;
  min-width: 0;
  transition: all 0.2s;
}

.번호입력칸:focus {
  outline: none;
  border-color: var(--입력포커스);
  background: var(--카드색);
  box-shadow: 0 0 0 4px rgba(212, 160, 55, 0.15);
}

/* ── 로또 공 (공식 색상 유지) ── */
.로또공 {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 46px;
  height: 46px;
  flex-shrink: 0;
  border-radius: 50%;
  color: #fff;
  font-weight: 800;
  font-size: 1.02rem;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.25);
  margin: 3px;
  box-shadow:
    inset 0 -3px 6px rgba(0, 0, 0, 0.18),
    inset 0 2px 4px rgba(255, 255, 255, 0.35),
    0 2px 6px rgba(0, 0, 0, 0.15);
  transition: transform 0.2s;
  position: relative;
}

.로또공:hover { transform: scale(1.08); }

.로또공.공1to10 { background: var(--공1to10); color: #3e2f00; }
.로또공.공11to20 { background: var(--공11to20); }
.로또공.공21to30 { background: var(--공21to30); }
.로또공.공31to40 { background: var(--공31to40); }
.로또공.공41to45 { background: var(--공41to45); color: #2e3a00; }

.로또공.일치 {
  box-shadow:
    0 0 0 3px var(--강조색),
    0 0 18px rgba(212, 160, 55, 0.7),
    inset 0 -3px 6px rgba(0, 0, 0, 0.18),
    inset 0 2px 4px rgba(255, 255, 255, 0.35);
  animation: 공반짝 1.2s ease-in-out infinite;
}

@keyframes 공반짝 {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.05); }
}

.로또공.불일치 {
  opacity: 0.28;
  box-shadow: none;
}

.보너스구분 {
  display: inline-block;
  margin: 0 8px;
  font-size: 1.4rem;
  color: var(--연한글자색);
  vertical-align: middle;
  font-weight: 300;
}

/* 생성 결과 */
.생성결과 { margin-top: 18px; }

.번호세트 {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  padding: 14px 0;
  border-bottom: 1px dashed var(--구분선);
}

.번호세트:last-child { border-bottom: none; }

/* 당첨 결과 */
.당첨결과 { margin-top: 14px; }

.당첨확인영역 {
  padding: 18px 0;
  border-bottom: 1px dashed var(--구분선);
}

.당첨확인영역:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.QR리더 {
  margin-top: 14px;
  border-radius: var(--라운드);
  overflow: hidden;
  border: 2px solid var(--강조색);
}

/* ── 통계 차트 ── */
.통계탭영역 {
  display: flex;
  gap: 8px;
  margin-bottom: 18px;
  background: var(--입력배경);
  padding: 5px;
  border-radius: 12px;
}

.통계탭버튼 {
  flex: 1;
  padding: 10px;
  font-size: 0.9rem;
  font-family: var(--본문폰트);
  font-weight: 600;
  border: none;
  border-radius: 9px;
  background: transparent;
  color: var(--보조글자색);
  cursor: pointer;
  min-height: 44px;
  transition: all 0.2s;
}

.통계탭버튼.활성 {
  background: var(--카드색);
  color: var(--강조색진);
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.08);
  font-weight: 700;
}

.통계차트 { overflow-x: auto; }

.통계막대 {
  display: flex;
  align-items: flex-end;
  gap: 3px;
  min-height: 200px;
  padding: 8px 0;
}

.통계막대항목 {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: 12px;
}

.막대 {
  width: 100%;
  min-height: 4px;
  border-radius: 4px 4px 0 0;
  transition: height 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}

.막대번호 {
  font-size: 0.62rem;
  color: var(--보조글자색);
  margin-top: 4px;
  font-weight: 500;
}

/* ── 운세 결과 ── */
.종합점수 {
  text-align: center;
  padding: 24px 20px;
}

.점수숫자 {
  font-family: var(--제목폰트);
  font-size: 3.4rem;
  font-weight: 900;
  background: linear-gradient(135deg, var(--강조색), var(--강조색진));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  line-height: 1;
}

.점수라벨 {
  font-size: 0.95rem;
  color: var(--보조글자색);
  margin-top: 6px;
}

.운세영역목록 {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.운세영역항목 {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  background: var(--보조카드색);
  border-radius: 12px;
  min-height: 54px;
  border: 1px solid var(--구분선);
  transition: transform 0.15s, box-shadow 0.2s;
}

.운세영역항목:hover {
  transform: translateX(3px);
  box-shadow: 0 3px 10px rgba(0, 0, 0, 0.04);
}

.운세아이콘 {
  font-size: 1.5rem;
  flex-shrink: 0;
}

.운세이름 {
  font-weight: 600;
  flex: 1;
}

.운세점수 {
  font-weight: 700;
  color: var(--강조색진);
  font-size: 1.12rem;
}

.로또추천 {
  text-align: center;
  padding: 18px;
}

/* ── 궁합 ── */
.궁합입력그룹 {
  padding: 16px 0;
  border-bottom: 1px dashed var(--구분선);
}

.궁합입력그룹:last-of-type {
  border-bottom: none;
  margin-bottom: 16px;
}

/* ── 사주팔자 표 ── */
.사주표 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  text-align: center;
}

.사주칸 {
  padding: 14px 8px;
  border-radius: 12px;
  background: var(--보조카드색);
  border: 1px solid var(--구분선);
}

.사주칸제목 {
  font-size: 0.78rem;
  color: var(--보조글자색);
  margin-bottom: 6px;
  font-weight: 500;
}

.사주칸천간 {
  font-family: var(--제목폰트);
  font-size: 1.4rem;
  font-weight: 700;
}

.사주칸지지 {
  font-family: var(--제목폰트);
  font-size: 1.4rem;
  font-weight: 700;
  margin-top: 4px;
}

/* 오행 분석 */
.오행분석 {
  display: flex;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
}

.오행항목 {
  text-align: center;
  padding: 14px;
  border-radius: 12px;
  min-width: 60px;
  border: 1px solid var(--구분선);
}

.오행항목.목 { background: var(--오행목배경); color: var(--오행목); }
.오행항목.화 { background: var(--오행화배경); color: var(--오행화); }
.오행항목.토 { background: var(--오행토배경); color: var(--오행토); }
.오행항목.금 { background: var(--오행금배경); color: var(--오행금); }
.오행항목.수 { background: var(--오행수배경); color: var(--오행수); }

.오행이름 {
  font-family: var(--제목폰트);
  font-size: 1.15rem;
  font-weight: 700;
  display: block;
}

.오행값 {
  font-size: 0.82rem;
  display: block;
  margin-top: 4px;
}

/* ── 유료 영역 (블러) ── */
.유료영역 {
  position: relative;
  overflow: hidden;
}

.블러콘텐츠 {
  filter: blur(5px);
  user-select: none;
  pointer-events: none;
  padding: 16px;
  color: var(--보조글자색);
  font-size: 0.95rem;
  line-height: 1.65;
}

.구독안내 {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: var(--블러배경);
  backdrop-filter: blur(3px);
  border-radius: var(--라운드);
  gap: 14px;
}

.구독안내 p {
  font-size: 1rem;
  font-weight: 600;
  color: var(--글자색);
}

.구독버튼 {
  padding: 12px 28px;
  font-size: 0.98rem;
  font-weight: 700;
  font-family: var(--본문폰트);
  color: #fff;
  background: linear-gradient(135deg, var(--강조색), var(--강조색진));
  border: none;
  border-radius: 12px;
  cursor: pointer;
  min-height: 48px;
  box-shadow: 0 4px 14px rgba(200, 106, 26, 0.3);
  transition: transform 0.15s, box-shadow 0.2s;
}

.구독버튼:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(200, 106, 26, 0.4);
}

/* ── 미리보기 영역 ── */
.미리보기영역 { margin-bottom: 14px; }

.미리보기설명 {
  font-size: 0.92rem;
  color: var(--보조글자색);
  line-height: 1.6;
  margin-bottom: 12px;
}

.미리보기예시 {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.미리보기항목 {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 16px;
  background: var(--보조카드색);
  border-radius: var(--라운드소);
  border: 1px solid var(--구분선);
}

.미리보기라벨 {
  font-size: 0.9rem;
  color: var(--보조글자색);
  font-weight: 500;
}

.미리보기값 {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--글자색);
}

.준비중안내 {
  text-align: center;
  padding: 16px;
  margin-top: 12px;
  background: linear-gradient(135deg, rgba(212,160,55,0.1), rgba(200,106,26,0.08));
  border-radius: 12px;
  border: 1px dashed var(--강조색);
}

.준비중안내 p {
  font-size: 0.9rem;
  color: var(--강조색진);
  font-weight: 600;
}

/* 주간 운세 미리보기 */
.주간운세미리보기 {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding-bottom: 10px;
}

.주간운세일 {
  flex-shrink: 0;
  text-align: center;
  padding: 12px 10px;
  background: var(--보조카드색);
  border-radius: 12px;
  min-width: 68px;
  border: 1px solid var(--구분선);
}

.주간운세요일 {
  font-size: 0.72rem;
  color: var(--보조글자색);
  display: block;
  font-weight: 500;
}

.주간운세날짜 {
  font-size: 0.85rem;
  font-weight: 700;
  display: block;
  margin: 5px 0;
}

.주간운세점수 {
  font-size: 0.78rem;
  font-weight: 700;
  display: block;
}

.주간운세점수.높음 { color: var(--강조색진); }
.주간운세점수.보통 { color: var(--보조글자색); }
.주간운세점수.낮음 { color: #c62828; }

/* ── MBTI 퀴즈 ── */
.퀴즈진행바 { margin-bottom: 22px; }

.진행바배경 {
  width: 100%;
  height: 10px;
  background: var(--입력배경);
  border-radius: 5px;
  overflow: hidden;
  margin-bottom: 10px;
  border: 1px solid var(--구분선);
}

.진행바채움 {
  height: 100%;
  background: linear-gradient(90deg, var(--강조색), var(--강조색진));
  border-radius: 5px;
  transition: width 0.4s ease;
  width: 2%;
  box-shadow: 0 0 10px rgba(200, 106, 26, 0.4);
}

.진행텍스트 {
  font-size: 0.9rem;
  color: var(--보조글자색);
  font-weight: 600;
}

.퀴즈질문 {
  font-size: 1.15rem;
  font-weight: 600;
  margin-bottom: 18px;
  min-height: 60px;
  line-height: 1.6;
  color: var(--글자색);
}

.퀴즈선택 {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.퀴즈선택지, .퀴즈선택버튼 {
  display: block;
  width: 100%;
  padding: 15px 18px;
  font-size: 1rem;
  font-family: var(--본문폰트);
  text-align: left;
  border: 2px solid var(--입력테두리);
  border-radius: 12px;
  background: var(--입력배경);
  color: var(--글자색);
  cursor: pointer;
  min-height: 54px;
  transition: all 0.2s;
  line-height: 1.5;
}

.퀴즈선택지:hover, .퀴즈선택버튼:hover {
  border-color: var(--강조색);
  background: rgba(212, 160, 55, 0.06);
  transform: translateX(3px);
}

.퀴즈선택지.선택됨 {
  border-color: var(--강조색진);
  background: rgba(200, 106, 26, 0.08);
  font-weight: 700;
}

/* MBTI 결과 */
.MBTI결과 { text-align: center; }

.MBTI유형 {
  font-family: var(--제목폰트);
  font-size: 2.8rem;
  font-weight: 900;
  background: linear-gradient(135deg, var(--강조색), var(--강조색진));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  margin-bottom: 8px;
  letter-spacing: 0.08em;
}

.MBTI별명 {
  font-size: 1.12rem;
  color: var(--보조글자색);
  margin-bottom: 18px;
  font-weight: 500;
}

/* ── 등급 뱃지 ── */
.등급뱃지 {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 4px 12px;
  border-radius: 20px;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  margin-right: 6px;
}

.등급뱃지.SS, .뱃지-SS {
  background: linear-gradient(135deg, var(--강조색), var(--강조색진));
  color: #fff;
  box-shadow: 0 0 14px rgba(212, 160, 55, 0.5);
}

.등급뱃지.S, .뱃지-S {
  background: var(--강조색);
  color: #3e2f00;
}

.등급뱃지.A, .뱃지-A {
  background: #4a90d9;
  color: #fff;
}

.등급뱃지.B, .뱃지-B {
  background: #9a8a74;
  color: #fff;
}

.등급뱃지.C, .뱃지-C {
  background: #d9cfbc;
  color: #6a5a4a;
}

/* ── 메인 화면 ── */
.메인히어로 {
  text-align: center;
  padding: 28px 16px 24px;
  position: relative;
}

.메인인사 {
  font-family: var(--제목폰트);
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.4;
  margin-bottom: 12px;
  color: var(--글자색);
  letter-spacing: -0.01em;
}

.메인인사 br + * { color: var(--강조색진); }

.메인설명 {
  font-size: 0.98rem;
  color: var(--보조글자색);
  line-height: 1.7;
}

.빠른메뉴 {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 10px;
  margin-bottom: 22px;
}

.빠른메뉴항목 {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 18px 4px;
  background: var(--카드색);
  border: 1px solid var(--구분선);
  border-radius: 18px;
  box-shadow: var(--카드그림자);
  cursor: pointer;
  font-family: var(--본문폰트);
  transition: all 0.2s;
  -webkit-tap-highlight-color: transparent;
  min-height: 104px;
  position: relative;
  overflow: hidden;
}

.빠른메뉴항목::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(212,160,55,0.08), transparent 60%);
  opacity: 0;
  transition: opacity 0.2s;
}

.빠른메뉴항목:hover {
  transform: translateY(-3px);
  box-shadow: var(--카드그림자강);
  border-color: var(--강조색);
}

.빠른메뉴항목:hover::before { opacity: 1; }

.빠른메뉴항목:active { transform: translateY(-1px); }

.빠른메뉴아이콘 {
  font-size: 2.1rem;
  line-height: 1;
  position: relative;
}

.빠른메뉴이름 {
  font-size: 0.76rem;
  font-weight: 600;
  color: var(--글자색);
  text-align: center;
  line-height: 1.3;
  position: relative;
}

.오늘한마디텍스트 {
  font-family: var(--제목폰트);
  font-size: 1.15rem;
  color: var(--글자색);
  line-height: 1.8;
  text-align: center;
  padding: 12px 8px;
  font-weight: 500;
  position: relative;
}

.오늘한마디텍스트::before,
.오늘한마디텍스트::after {
  content: '"';
  color: var(--강조색);
  font-size: 2rem;
  font-family: var(--제목폰트);
  opacity: 0.4;
}

.오늘한마디텍스트::before { margin-right: 4px; }
.오늘한마디텍스트::after { margin-left: 4px; }

.메인로또정보 {
  text-align: center;
  font-size: 0.98rem;
  color: var(--보조글자색);
}

/* ── 카운트다운 ── */
.카운트다운카드 {
  background: linear-gradient(135deg, #c86a1a 0%, #8b3a1f 100%);
  color: #fff;
  border: none;
  position: relative;
  overflow: hidden;
}

.카운트다운카드::before {
  content: '';
  position: absolute;
  top: -50%; right: -30%;
  width: 240px; height: 240px;
  background: radial-gradient(circle, rgba(255, 215, 0, 0.25), transparent 65%);
  pointer-events: none;
}

.카운트다운카드 .카드제목 {
  color: #fff;
}

.카운트다운카드 .카드제목::before {
  background: linear-gradient(180deg, #ffd700, #fff);
}

.카운트다운헤더 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: relative;
}

.추첨회차 {
  font-size: 0.82rem;
  background: rgba(255,255,255,0.25);
  padding: 4px 12px;
  border-radius: 14px;
  font-weight: 600;
  backdrop-filter: blur(4px);
}

.카운트다운 {
  display: flex;
  justify-content: center;
  gap: 14px;
  margin-top: 16px;
  position: relative;
}

.카운트다운단위 {
  text-align: center;
  background: rgba(255, 255, 255, 0.14);
  padding: 10px 14px;
  border-radius: 12px;
  min-width: 68px;
  backdrop-filter: blur(6px);
  border: 1px solid rgba(255, 255, 255, 0.22);
}

.카운트다운숫자 {
  display: block;
  font-family: var(--제목폰트);
  font-size: 2.1rem;
  font-weight: 900;
  line-height: 1;
}

.카운트다운라벨 {
  font-size: 0.72rem;
  opacity: 0.9;
  margin-top: 5px;
  letter-spacing: 0.05em;
}

.카운트다운구분 {
  font-size: 1.6rem;
  font-weight: 700;
  align-self: center;
  opacity: 0.7;
}

.카운트다운카드 .주요버튼 {
  background: rgba(255,255,255,0.22);
  border: 1.5px solid rgba(255,255,255,0.55);
  backdrop-filter: blur(4px);
  color: #fff;
  box-shadow: none;
}

.카운트다운카드 .주요버튼:hover {
  background: rgba(255,255,255,0.38);
  box-shadow: 0 6px 18px rgba(0,0,0,0.15);
}

/* ── 꿈해몽 (야간 컨셉 유지, 세련되게) ── */
.꿈해몽카드 {
  background:
    radial-gradient(circle at 20% 20%, rgba(212, 160, 55, 0.12), transparent 50%),
    radial-gradient(circle at 80% 80%, rgba(136, 167, 217, 0.15), transparent 50%),
    linear-gradient(135deg, #1a1a3a, #2d2b55);
  color: #e8e8f0;
  border: 1px solid rgba(212, 160, 55, 0.25);
}

.꿈해몽카드 .카드제목 { color: #ffd700; }
.꿈해몽카드 .카드제목::before {
  background: linear-gradient(180deg, #ffd700, #ff8c00);
}
.꿈해몽카드 .카드설명 { color: #b6b6ce; }

.꿈입력필드 {
  width: 100%;
  padding: 15px;
  font-size: 1rem;
  font-family: var(--본문폰트);
  border: 1.5px solid rgba(255, 215, 0, 0.3);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.07);
  color: #e8e8f0;
  resize: none;
  margin-bottom: 14px;
  line-height: 1.6;
  min-height: 84px;
  transition: border-color 0.2s, box-shadow 0.2s;
}

.꿈입력필드::placeholder { color: rgba(255, 255, 255, 0.35); }

.꿈입력필드:focus {
  outline: none;
  border-color: #ffd700;
  box-shadow: 0 0 0 4px rgba(255, 215, 0, 0.15);
}

.꿈해몽카드 .주요버튼 {
  background: linear-gradient(135deg, #ffd700, #ff8c00);
  box-shadow: 0 4px 14px rgba(255, 140, 0, 0.4);
}

.꿈결과 {
  margin-top: 16px;
  padding: 18px;
  background: rgba(255, 255, 255, 0.06);
  border-radius: 12px;
  border: 1px solid rgba(255, 215, 0, 0.2);
}

.꿈해석제목 {
  font-size: 1.02rem;
  font-weight: 700;
  color: #ffd700;
  margin-bottom: 10px;
}

.꿈해석내용 {
  font-size: 0.98rem;
  line-height: 1.8;
  color: #d4d4ec;
  margin-bottom: 16px;
}

.꿈로또제목 {
  font-size: 0.92rem;
  font-weight: 700;
  color: #ffd700;
  margin-bottom: 10px;
}

.꿈로또번호줄 {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  flex-wrap: wrap;
}

.꿈로또설명 {
  font-size: 0.8rem;
  color: rgba(255, 255, 255, 0.42);
  text-align: center;
  margin-top: 12px;
}

.꿈로딩 {
  text-align: center;
  padding: 24px;
  color: #ffd700;
  font-size: 0.98rem;
}

/* ── 띠운세 미리보기 ── */
.띠운세미리보기 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
}

.띠운세항목 {
  text-align: center;
  padding: 12px 4px;
  background: var(--보조카드색);
  border: 1px solid var(--구분선);
  border-radius: 12px;
  transition: all 0.15s;
}

.띠운세항목:hover {
  transform: translateY(-3px);
  border-color: var(--강조색);
  box-shadow: 0 4px 12px rgba(200, 106, 26, 0.12);
}

.띠동물이모지 {
  font-size: 1.6rem;
  display: block;
}

.띠이름표시 {
  font-size: 0.72rem;
  color: var(--보조글자색);
  display: block;
  margin-top: 3px;
  font-weight: 500;
}

.띠운세한줄 {
  font-size: 0.68rem;
  color: var(--강조색진);
  font-weight: 700;
  display: block;
  margin-top: 4px;
}

/* ── 핫번호 ── */
.핫번호영역 {
  display: flex;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
}

.핫번호항목 {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
}

.핫번호횟수 {
  font-size: 0.72rem;
  color: var(--보조글자색);
  font-weight: 500;
}

/* ── 서비스 소개 ── */
.서비스소개카드 {
  background: linear-gradient(135deg, var(--카드색), var(--보조카드색));
}

.서비스소개목록 {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.서비스소개항목 {
  display: flex;
  align-items: flex-start;
  gap: 14px;
}

.서비스소개아이콘 {
  font-size: 1.7rem;
  flex-shrink: 0;
  width: 46px;
  height: 46px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, rgba(212,160,55,0.15), rgba(200,106,26,0.1));
  border-radius: 12px;
  border: 1px solid var(--구분선);
}

.서비스소개항목 strong {
  font-size: 1rem;
  font-family: var(--제목폰트);
  display: block;
  margin-bottom: 3px;
  color: var(--글자색);
}

.서비스소개항목 p {
  font-size: 0.85rem;
  color: var(--보조글자색);
  line-height: 1.5;
}

/* ── 로또 분석 요약 ── */
.분석요약카드 {
  background: linear-gradient(135deg, var(--카드색), var(--보조카드색));
}

.분석요약 {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.분석항목 {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  background: var(--카드색);
  border-radius: 12px;
  border: 1px solid var(--구분선);
}

.분석아이콘 {
  font-size: 1.4rem;
  flex-shrink: 0;
  width: 40px;
  text-align: center;
}

.분석내용 { flex: 1; }

.분석라벨 {
  font-size: 0.78rem;
  color: var(--보조글자색);
  display: block;
  font-weight: 500;
}

.분석값 {
  font-size: 0.95rem;
  font-weight: 700;
  display: block;
  margin-top: 3px;
  color: var(--글자색);
}

/* ── 로또공 클래스 (app.js에서 사용) ── */
.공색-노랑 { background: var(--공1to10); color: #3e2f00; }
.공색-파랑 { background: var(--공11to20); }
.공색-빨강 { background: var(--공21to30); }
.공색-회색 { background: var(--공31to40); }
.공색-초록 { background: var(--공41to45); color: #2e3a00; }

.생성결과줄 {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 4px;
  padding: 14px 0;
  border-bottom: 1px dashed var(--구분선);
}

.생성결과줄:last-child { border-bottom: none; }

.점수표시 {
  font-size: 0.82rem;
  color: var(--보조글자색);
  margin-left: 10px;
  font-weight: 500;
}

/* 오류 메시지 */
.오류메시지 {
  color: #c62828;
  font-size: 0.92rem;
  padding: 10px 0;
  font-weight: 500;
}

body.dark .오류메시지 { color: #ef9a9a; }

/* 당첨 결과 */
.당첨결과내용 { text-align: center; }

.회차정보 {
  font-weight: 600;
  color: var(--보조글자색);
  margin-bottom: 10px;
  font-size: 0.92rem;
}

.당첨번호줄 {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 14px;
}

.등수결과 {
  font-size: 1.4rem;
  font-weight: 800;
  color: var(--보조글자색);
  font-family: var(--제목폰트);
}

.등수결과.당첨 {
  background: linear-gradient(135deg, var(--강조색), var(--강조색진));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.일치정보 {
  font-size: 0.88rem;
  color: var(--보조글자색);
  margin-top: 6px;
}

/* 통계 빈도 차트 */
.빈도차트 {
  display: flex;
  align-items: flex-end;
  gap: 2px;
  height: 200px;
  padding: 8px 0 0;
}

.빈도막대 {
  flex: 1;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  min-width: 0;
}

.막대값 {
  font-size: 0.58rem;
  color: var(--보조글자색);
  margin-bottom: 2px;
  font-weight: 600;
}

.막대색-노랑 { background: var(--공1to10); }
.막대색-파랑 { background: var(--공11to20); }
.막대색-빨강 { background: var(--공21to30); }
.막대색-회색 { background: var(--공31to40); }
.막대색-초록 { background: var(--공41to45); }

/* 운세 점수바 */
.운세점수바 {
  flex: 1;
  height: 10px;
  background: var(--입력배경);
  border-radius: 5px;
  overflow: hidden;
  border: 1px solid var(--구분선);
}

.운세점수채움 {
  height: 100%;
  border-radius: 5px;
  transition: width 0.6s cubic-bezier(0.16, 1, 0.3, 1);
  background: linear-gradient(90deg, var(--강조색), var(--강조색진));
}

.운세점수값 {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--강조색진);
  margin-left: 10px;
  white-space: nowrap;
}

.운세점수 {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 1.5;
}

.점수원 { display: inline-block; }

.점수요약 {
  font-size: 1rem;
  color: var(--보조글자색);
  margin-top: 10px;
  text-align: center;
}

/* 로또 추천 */
.로또추천내용 { text-align: center; }

.추천점수 {
  font-size: 1.4rem;
  font-weight: 800;
  margin-bottom: 10px;
  font-family: var(--제목폰트);
}

.추천메시지 {
  font-size: 1rem;
  color: var(--보조글자색);
  line-height: 1.6;
}

/* 오행 막대 차트 */
.오행막대차트 {
  display: flex;
  flex-direction: column;
  gap: 11px;
}

.오행바 {
  flex: 1;
  height: 12px;
  background: var(--입력배경);
  border-radius: 6px;
  overflow: hidden;
  border: 1px solid var(--구분선);
}

.오행채움 {
  height: 100%;
  border-radius: 6px;
  transition: width 0.6s ease;
}

.궁합점수원 { margin: 0 auto; }

/* MBTI 카드 */
.MBTI유형카드 {
  text-align: center;
  padding: 18px 0;
}

.유형코드 {
  font-family: var(--제목폰트);
  font-size: 2.8rem;
  font-weight: 900;
  background: linear-gradient(135deg, var(--강조색), var(--강조색진));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  margin-bottom: 10px;
  letter-spacing: 0.08em;
}

.유형이름 {
  font-size: 1.15rem;
  font-weight: 700;
  margin-bottom: 14px;
  font-family: var(--제목폰트);
}

.유형설명 {
  font-size: 0.98rem;
  color: var(--보조글자색);
  line-height: 1.7;
  margin-bottom: 18px;
}

.유형특성 {
  text-align: left;
  padding: 14px 16px;
  background: var(--보조카드색);
  border-radius: 12px;
  margin-bottom: 10px;
  border: 1px solid var(--구분선);
}

.유형특성 h4 {
  font-size: 0.93rem;
  font-weight: 700;
  margin-bottom: 6px;
  color: var(--강조색진);
}

.유형특성 p {
  font-size: 0.93rem;
  color: var(--글자색);
  line-height: 1.6;
}

/* QR 결과 */
.QR결과목록 { text-align: center; }

.QR게임결과 {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 4px;
  padding: 10px 0;
  border-bottom: 1px dashed var(--구분선);
}

.QR게임결과:last-child { border-bottom: none; }

.게임번호 {
  font-weight: 700;
  color: var(--보조글자색);
  margin-right: 10px;
}

/* 유료 안내 카드 */
.유료안내카드 {
  text-align: center;
  padding: 22px;
  background: linear-gradient(135deg, rgba(212,160,55,0.08), rgba(200,106,26,0.05));
  border-radius: 14px;
  border: 1px dashed var(--강조색);
  color: var(--보조글자색);
  line-height: 1.65;
}

.유료안내카드 strong {
  color: var(--강조색진);
  font-family: var(--제목폰트);
}

/* ── 유틸리티 ── */
.숨김 { display: none !important; }
.텍스트중앙 { text-align: center; }
.마진상 { margin-top: 16px; }
.마진하 { margin-bottom: 16px; }

/* 스크롤바 커스텀 */
::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

::-webkit-scrollbar-track { background: transparent; }

::-webkit-scrollbar-thumb {
  background: var(--구분선진);
  border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover { background: var(--연한글자색); }

::selection {
  background: rgba(212, 160, 55, 0.3);
  color: var(--글자색);
}

/* ==========================================
   saju-web 풀이형 스타일
   ========================================== */

.section-title {
  font-family: var(--제목폰트);
  font-size: 1.5rem;
  color: var(--글자색);
  margin-bottom: 22px;
  display: flex;
  align-items: center;
  gap: 12px;
  font-weight: 700;
}

.section-title::before {
  content: '';
  display: inline-block;
  width: 5px;
  height: 26px;
  background: linear-gradient(180deg, var(--강조색), var(--강조색진));
  border-radius: 3px;
}

.info-birth {
  text-align: center;
  color: var(--보조글자색);
  font-size: 0.92rem;
  margin-bottom: 18px;
  padding: 8px;
  background: var(--보조카드색);
  border-radius: 10px;
  font-weight: 500;
}

/* 사주 팔자 테이블 */
.saju-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 8px;
  margin-bottom: 18px;
}

.saju-table th {
  font-size: 0.88rem;
  color: var(--보조글자색);
  font-weight: 500;
  padding: 8px;
  letter-spacing: 0.12em;
}

.saju-cell {
  text-align: center;
  padding: 18px 8px;
  border-radius: 14px;
  background: var(--보조카드색);
  border: 1px solid var(--구분선);
  transition: all 0.25s;
  box-shadow: inset 0 1px 2px rgba(0,0,0,0.03);
}

.saju-cell:hover {
  transform: translateY(-3px) scale(1.03);
  box-shadow: 0 8px 20px rgba(200, 106, 26, 0.12);
  border-color: var(--강조색);
}

.saju-hanja {
  font-family: var(--제목폰트);
  font-size: 2.3rem;
  font-weight: 900;
  line-height: 1.2;
}

.saju-hangul {
  font-size: 0.92rem;
  margin-top: 4px;
  color: var(--보조글자색);
}

.saju-element {
  font-size: 0.76rem;
  margin-top: 8px;
  padding: 3px 12px;
  border-radius: 20px;
  display: inline-block;
  font-weight: 600;
}

.saju-sipsung {
  font-size: 0.82rem;
  margin-top: 6px;
  color: var(--강조색진);
  font-weight: 600;
}

.color-wood  { color: var(--오행목); }
.color-fire  { color: var(--오행화); }
.color-earth { color: var(--오행토); }
.color-metal { color: var(--오행금); }
.color-water { color: var(--오행수); }

.el-wood  { color: var(--오행목); background: var(--오행목배경); }
.el-fire  { color: var(--오행화); background: var(--오행화배경); }
.el-earth { color: var(--오행토); background: var(--오행토배경); }
.el-metal { color: var(--오행금); background: var(--오행금배경); }
.el-water { color: var(--오행수); background: var(--오행수배경); }

/* 오행 막대 차트 */
.ohaeng-chart {
  display: flex;
  justify-content: center;
  gap: 14px;
  margin: 22px 0;
  flex-wrap: wrap;
}

.ohaeng-item {
  text-align: center;
  min-width: 80px;
}

.ohaeng-bar-wrap {
  height: 130px;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  margin-bottom: 10px;
}

@keyframes barGrow {
  from { height: 0 !important; opacity: 0; }
  to { opacity: 1; }
}

.ohaeng-bar {
  width: 42px;
  border-radius: 8px 8px 4px 4px;
  transition: height 0.8s ease;
  position: relative;
  animation: barGrow 0.8s cubic-bezier(0.16, 1, 0.3, 1) forwards;
  box-shadow: 0 2px 10px rgba(0,0,0,0.12);
}

.ohaeng-bar .count {
  position: absolute;
  top: -26px;
  left: 50%;
  transform: translateX(-50%);
  font-weight: 800;
  font-size: 1.05rem;
}

.ohaeng-label {
  font-size: 0.98rem;
  font-weight: 600;
}

.ohaeng-hanja {
  font-family: var(--제목폰트);
  font-size: 1.35rem;
}

.ohaeng-value {
  font-size: 0.85rem;
  color: var(--보조글자색);
  margin-top: 2px;
}

/* 해석 블록 */
.interp-block {
  background: var(--보조카드색);
  border-radius: 14px;
  padding: 24px 26px;
  margin-bottom: 16px;
  border-left: 4px solid var(--강조색진);
  position: relative;
  box-shadow: 0 1px 3px rgba(0,0,0,0.03);
  transition: all 0.25s;
}

.interp-block:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 22px rgba(0,0,0,0.06);
  border-left-color: var(--강조색2);
}

.interp-block h3 {
  font-family: var(--제목폰트);
  color: var(--강조색진);
  margin-bottom: 14px;
  font-size: 1.1rem;
  display: flex;
  align-items: center;
  gap: 10px;
}

.interp-block h3 .icon {
  font-size: 1.3rem;
  line-height: 1;
}

.interp-block p,
.interp-block ul {
  line-height: 2;
  color: var(--글자색);
  font-size: 0.96rem;
}

.interp-block ul { padding-left: 22px; }
.interp-block li { margin-bottom: 6px; }

.keyword {
  display: inline-block;
  background: rgba(200, 106, 26, 0.1);
  color: var(--강조색진);
  padding: 2px 10px;
  border-radius: 8px;
  font-weight: 600;
  font-size: 0.9rem;
}

/* 십성 그리드 */
.sipsung-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 12px;
  margin: 16px 0;
}

.sipsung-item {
  background: var(--카드색);
  border-radius: 12px;
  padding: 16px;
  text-align: center;
  transition: all 0.2s;
  box-shadow: 0 1px 3px rgba(0,0,0,0.04);
  border: 1px solid var(--구분선);
}

.sipsung-item:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 22px rgba(0,0,0,0.08);
  border-color: var(--강조색);
}

.sipsung-item .name {
  font-family: var(--제목폰트);
  font-size: 1.05rem;
  color: var(--강조색진);
  font-weight: 700;
}

.sipsung-item .count-val {
  font-size: 1.9rem;
  font-weight: 900;
  margin: 6px 0;
  font-family: var(--제목폰트);
}

.sipsung-item .desc {
  font-size: 0.78rem;
  color: var(--보조글자색);
}

/* 십이운성 */
.twelve-stage {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: center;
  margin: 16px 0;
}

.stage-item {
  background: var(--보조카드색);
  border-radius: 12px;
  padding: 12px 16px;
  text-align: center;
  min-width: 84px;
  transition: all 0.2s;
  border: 1px solid var(--구분선);
}

.stage-item:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 14px rgba(0,0,0,0.06);
}

.pillar-name {
  font-size: 0.72rem;
  color: var(--보조글자색);
  font-weight: 500;
}

.stage-name {
  font-family: var(--제목폰트);
  font-size: 1.12rem;
  color: var(--강조색진);
  font-weight: 700;
  margin-top: 4px;
}

.stage-desc {
  font-size: 0.76rem;
  color: var(--보조글자색);
  margin-top: 4px;
}

/* 성격 섹션 */
.personality-section { margin-bottom: 16px; }

.personality-header {
  text-align: center;
  padding: 20px 0;
  margin-bottom: 16px;
}

.personality-header .nature-badge {
  display: inline-block;
  padding: 7px 22px;
  border-radius: 22px;
  font-size: 0.88rem;
  font-weight: 600;
  margin-bottom: 14px;
}

.personality-header .desc {
  font-size: 1.1rem;
  line-height: 1.85;
  color: var(--글자색);
}

.trait-list {
  list-style: none;
  padding: 0;
}

.trait-list li {
  padding: 12px 18px;
  margin-bottom: 8px;
  background: var(--카드색);
  border-radius: 12px;
  border-left: 3px solid var(--강조색진);
  font-size: 0.95rem;
  line-height: 1.75;
  transition: all 0.15s;
  border-top: 1px solid var(--구분선);
  border-right: 1px solid var(--구분선);
  border-bottom: 1px solid var(--구분선);
}

.trait-list li:hover {
  transform: translateX(5px);
  border-left-width: 5px;
}

.strength-weakness {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin: 16px 0;
}

.sw-card {
  padding: 18px;
  border-radius: 14px;
  background: var(--보조카드색);
  border: 1px solid var(--구분선);
}

.sw-card h4 {
  font-size: 0.9rem;
  margin-bottom: 10px;
  font-weight: 700;
  font-family: var(--제목폰트);
}

.sw-card .tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.sw-card .tags span {
  display: inline-block;
  padding: 5px 13px;
  border-radius: 20px;
  font-size: 0.82rem;
  font-weight: 500;
}

/* 직업/건강 그리드 */
.career-grid,
.health-grid,
.health-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 12px;
  margin: 16px 0;
}

.career-item,
.health-item,
.health-card-item {
  background: var(--카드색);
  border-radius: 14px;
  padding: 18px;
  transition: all 0.2s;
  border: 1px solid var(--구분선);
  box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}

.career-item { text-align: center; }

.health-item,
.health-card-item {
  border-top: 3px solid var(--강조색);
}

.career-item:hover,
.health-item:hover,
.health-card-item:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 22px rgba(0,0,0,0.08);
  border-color: var(--강조색);
}

.health-item h4,
.health-card-item h4 {
  font-size: 0.95rem;
  margin-bottom: 10px;
  color: var(--강조색진);
  font-family: var(--제목폰트);
}

.health-item p,
.health-card-item p {
  font-size: 0.88rem;
  line-height: 1.75;
  color: var(--글자색);
}

/* 개운법 그리드 */
.advice-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 12px;
  margin: 16px 0;
}

.advice-item {
  background: var(--카드색);
  border-radius: 14px;
  padding: 18px;
  text-align: center;
  transition: all 0.2s;
  border: 1px solid var(--구분선);
  box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}

.advice-item:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 22px rgba(0,0,0,0.08);
  border-color: var(--강조색);
}

.advice-item .advice-icon {
  font-size: 1.7rem;
  margin-bottom: 8px;
}

.advice-item .advice-label {
  font-size: 0.8rem;
  color: var(--보조글자색);
  margin-bottom: 5px;
  font-weight: 500;
}

.advice-item .advice-value {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--글자색);
  line-height: 1.5;
}

.advice-quote {
  background: linear-gradient(135deg, rgba(200, 106, 26, 0.08), rgba(212, 160, 55, 0.08));
  border-radius: 16px;
  padding: 28px;
  margin: 18px 0;
  text-align: center;
  font-family: var(--제목폰트);
  font-size: 1.05rem;
  line-height: 2;
  color: var(--글자색);
  border: 1px solid rgba(200, 106, 26, 0.15);
  position: relative;
}

.advice-quote::before,
.advice-quote::after {
  content: '';
  position: absolute;
  font-size: 3rem;
  font-family: var(--제목폰트);
  color: var(--강조색);
  opacity: 0.3;
  line-height: 1;
}

.advice-quote::before { content: '"'; top: 14px; left: 16px; }
.advice-quote::after { content: '"'; bottom: 0; right: 16px; }

/* 대운 타임라인 */
.luck-timeline {
  display: flex;
  overflow-x: auto;
  gap: 0;
  padding: 12px 0;
  margin: 16px 0;
}

.luck-item {
  text-align: center;
  min-width: 76px;
  padding: 14px 8px;
  border-radius: 12px;
  transition: all 0.2s;
  flex-shrink: 0;
  border-right: 1px solid var(--구분선);
}

.luck-item:last-child { border-right: none; }
.luck-item:hover { background: var(--보조카드색); }

.luck-item.current {
  background: linear-gradient(135deg, rgba(212,160,55,0.12), rgba(200,106,26,0.08));
  border: 1px solid var(--강조색진);
  box-shadow: 0 0 24px rgba(200, 106, 26, 0.18);
}

.luck-age {
  font-size: 0.78rem;
  color: var(--보조글자색);
  font-weight: 500;
}

.luck-gan,
.luck-ji {
  font-family: var(--제목폰트);
  font-size: 1.55rem;
  font-weight: 800;
  margin: 4px 0;
}

.luck-hangul {
  font-size: 0.72rem;
  color: var(--보조글자색);
  margin-top: 4px;
}

.luck-table {
  width: 100%;
  border-collapse: collapse;
  margin: 16px 0;
}

.luck-table th,
.luck-table td {
  padding: 11px 8px;
  text-align: center;
  border-bottom: 1px solid var(--구분선);
  font-size: 0.92rem;
}

.luck-table th {
  color: var(--보조글자색);
  font-weight: 600;
  background: var(--보조카드색);
}

.yearly-card {
  background: var(--보조카드색);
  border-radius: 14px;
  padding: 22px;
  margin-bottom: 16px;
  text-align: center;
  border: 1px solid var(--구분선);
}

.yearly-hero {
  text-align: center;
  padding: 26px;
  margin-bottom: 20px;
  background: linear-gradient(135deg, var(--보조카드색), var(--카드색));
  border-radius: 16px;
  box-shadow: inset 0 1px 3px rgba(0,0,0,0.03);
  border: 1px solid var(--구분선);
}

/* 궁합 그리드 */
.compat-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin: 16px 0;
}

.compat-item {
  background: var(--카드색);
  border-radius: 14px;
  padding: 20px;
  border-top: 3px solid var(--강조색진);
  transition: all 0.2s;
  box-shadow: 0 1px 3px rgba(0,0,0,0.04);
  border-right: 1px solid var(--구분선);
  border-bottom: 1px solid var(--구분선);
  border-left: 1px solid var(--구분선);
}

.compat-item:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 22px rgba(0,0,0,0.08);
}

.compat-item h4 {
  color: var(--강조색진);
  font-size: 0.95rem;
  margin-bottom: 10px;
  font-family: var(--제목폰트);
}

.compat-item p {
  font-size: 0.9rem;
  line-height: 1.85;
  color: var(--글자색);
}

/* 궁합 점수 */
.compat-score {
  text-align: center;
  margin: 22px 0;
}

.compat-grade {
  font-family: var(--제목폰트);
  font-size: 2.2rem;
  font-weight: 900;
  background: linear-gradient(135deg, var(--강조색), var(--강조색진));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  margin-top: 10px;
}

.compat-vs {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 26px;
  margin: 22px 0;
  font-family: var(--제목폰트);
  font-size: 1.2rem;
}

.compat-detail { margin-top: 22px; }

.compat-section {
  background: var(--보조카드색);
  border-radius: 14px;
  padding: 22px;
  margin-bottom: 16px;
  border: 1px solid var(--구분선);
}

.compat-section h3 {
  font-family: var(--제목폰트);
  color: var(--강조색진);
  margin-bottom: 14px;
  font-size: 1.1rem;
}

.cheongan-hap {
  display: inline-block;
  padding: 5px 16px;
  border-radius: 22px;
  background: var(--오행화배경);
  color: var(--오행화);
  font-weight: 700;
  font-size: 0.88rem;
}

.compat-bar {
  height: 10px;
  background: var(--입력배경);
  border-radius: 5px;
  overflow: hidden;
  margin: 10px 0;
  border: 1px solid var(--구분선);
}

.compat-bar .fill {
  height: 100%;
  border-radius: 5px;
  transition: width 0.8s ease;
  background: linear-gradient(90deg, var(--강조색), var(--강조색진));
}

.tag {
  display: inline-block;
  padding: 5px 14px;
  border-radius: 22px;
  font-size: 0.82rem;
  margin: 4px 4px 4px 0;
  font-weight: 500;
  background: var(--입력배경);
  color: var(--보조글자색);
  border: 1px solid var(--구분선);
}

.divider {
  height: 1px;
  background: linear-gradient(to right, transparent, var(--구분선진), transparent);
  margin: 22px 0;
}

.section-cat {
  display: inline-block;
  width: 28px;
  height: 28px;
  vertical-align: middle;
  margin-right: 4px;
  opacity: 0.7;
  color: var(--강조색진);
}

.card-cat { display: none !important; }

/* ==========================================
   공유 버튼
   ========================================== */
.공유카드 {
  text-align: center;
  padding: 18px;
  background: linear-gradient(135deg, var(--카드색), var(--보조카드색));
}

.공유버튼 {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 13px 22px;
  font-size: 0.95rem;
  font-family: var(--본문폰트);
  font-weight: 700;
  border: none;
  border-radius: 12px;
  cursor: pointer;
  min-height: 48px;
  margin: 4px;
  transition: all 0.2s;
}

.공유버튼:hover { transform: translateY(-2px); }
.공유버튼:active { opacity: 0.85; }

.카카오공유 {
  background: #FEE500;
  color: #191919;
}

.일반공유 {
  background: var(--입력배경);
  color: var(--글자색);
  border: 1.5px solid var(--입력테두리);
}

/* ==========================================
   메인 운세 요약 카드
   ========================================== */
.운세유도카드,
.운세요약카드 {
  background: linear-gradient(135deg, var(--카드색), rgba(212, 160, 55, 0.06));
  border-left: 4px solid var(--강조색);
}

.운세요약점수 {
  text-align: center;
  margin: 14px 0;
}

.운세요약숫자 {
  font-size: 2.6rem;
  font-weight: 900;
  font-family: var(--제목폰트);
  background: linear-gradient(135deg, var(--강조색), var(--강조색진));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.운세요약등급 {
  font-size: 1.3rem;
  margin-left: 10px;
  color: var(--강조색진);
}

.운세요약한줄 {
  text-align: center;
  font-size: 0.98rem;
  color: var(--보조글자색);
  margin: 10px 0;
  line-height: 1.7;
}

.운세요약영역 {
  display: flex;
  justify-content: space-around;
  margin-top: 14px;
  gap: 4px;
}

.운세요약항목 {
  text-align: center;
  font-size: 0.82rem;
  color: var(--보조글자색);
}

.운세요약항목 .항목점수 {
  display: block;
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--강조색진);
  margin-top: 3px;
}

/* ══════════════════════════════════
   손금
   ══════════════════════════════════ */
.palm-loading {
  text-align: center;
  padding: 48px 20px;
}

.palm-loading-spinner {
  width: 52px;
  height: 52px;
  border: 4px solid var(--구분선);
  border-top-color: var(--강조색진);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
  margin: 0 auto 18px;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

.palm-loading-text {
  font-size: 1.15rem;
  font-weight: 700;
  margin-bottom: 5px;
  font-family: var(--제목폰트);
}

.palm-loading-sub {
  font-size: 0.88rem;
  color: var(--보조글자색);
}

.palm-photo-wrap {
  margin: 14px auto;
  width: 200px;
  height: 200px;
  border-radius: 18px;
  overflow: hidden;
  border: 3px solid var(--강조색);
  box-shadow: 0 4px 20px rgba(200, 106, 26, 0.18);
}

.palm-photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.palm-score-number {
  font-size: 3.2rem;
  font-weight: 900;
  background: linear-gradient(135deg, var(--강조색), var(--강조색진));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  margin: 10px 0 6px;
  font-family: var(--제목폰트);
}

.palm-score-unit {
  font-size: 1.3rem;
  font-weight: 400;
  color: var(--보조글자색);
  -webkit-text-fill-color: var(--보조글자색);
}

.palm-score-badge {
  display: inline-block;
  padding: 5px 18px;
  border-radius: 14px;
  font-size: 0.95rem;
  font-weight: 700;
  color: #fff;
}

.palm-badge-ss { background: linear-gradient(135deg, #ffd700, #ff8c00); }
.palm-badge-s { background: #ffd700; color: #333; }
.palm-badge-a { background: #4a90d9; }
.palm-badge-b { background: #9a8a74; }
.palm-badge-c { background: #757063; }

/* ══════════════════════════════════
   타로
   ══════════════════════════════════ */
#탭-타로 > .카드 {
  margin-bottom: 4px;
  padding: 12px 16px;
}

#탭-타로 > .카드 .카드제목 {
  margin-bottom: 4px;
}

#탭-타로 > .카드 .카드설명 {
  margin-bottom: 0;
  font-size: 0.92rem;
  line-height: 1.45;
}

.tarot-pick-guide {
  text-align: center;
  font-size: 1rem;
  font-weight: 700;
  color: var(--글자색);
  margin: 4px 0 4px;
  font-family: var(--제목폰트);
}

.tarot-cards-row {
  display: flex;
  justify-content: center;
  gap: 12px;
  margin: 2px 0 18px;
}

.tarot-card {
  width: 100px;
  height: 150px;
  perspective: 600px;
  cursor: pointer;
  transition: transform 0.2s;
}

.tarot-card:hover {
  transform: translateY(-6px);
}

.tarot-card-inner {
  position: relative;
  width: 100%;
  height: 100%;
  transition: transform 0.6s;
  transform-style: preserve-3d;
}

.tarot-card-inner.flipped {
  transform: rotateY(180deg);
}

.tarot-card-front,
.tarot-card-back-face {
  position: absolute;
  width: 100%;
  height: 100%;
  backface-visibility: hidden;
  border-radius: 14px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.tarot-card-back-face {
  background:
    radial-gradient(circle at 30% 30%, rgba(255, 215, 0, 0.2), transparent 50%),
    linear-gradient(135deg, #1a1a4e, #2d1b69);
  border: 2px solid #ffd700;
  color: #ffd700;
  font-size: 2rem;
  box-shadow: 0 4px 18px rgba(26, 26, 78, 0.4);
}

.tarot-back-pattern { font-size: 2.8rem; }

.tarot-card-front {
  background: var(--카드색);
  border: 2px solid var(--강조색);
  transform: rotateY(180deg);
  padding: 0;
  overflow: hidden;
}

.tarot-card-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 12px;
  display: block;
}

.tarot-reversed .tarot-card-img {
  transform: rotate(180deg);
}

.tarot-emoji {
  font-size: 2.1rem;
  margin-bottom: 5px;
}

.tarot-card-name {
  font-size: 0.72rem;
  font-weight: 700;
  text-align: center;
  line-height: 1.25;
}

.tarot-card.선택불가,
.tarot-not-selected {
  opacity: 0.3;
  pointer-events: none;
}

.tarot-card-revealed {
  width: 120px;
  height: 180px;
  cursor: default;
}

.tarot-card-revealed:hover { transform: none; }

.tarot-reversed .tarot-emoji {
  transform: rotate(180deg);
  display: inline-block;
}

.tarot-direction-badge {
  position: absolute;
  bottom: 6px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 0.68rem;
  padding: 3px 10px;
  border-radius: 10px;
  color: #fff;
  font-weight: 600;
  white-space: nowrap;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.3);
  z-index: 2;
}

.tarot-reversed .tarot-direction-badge {
  transform: translateX(-50%) rotate(180deg);
  bottom: auto;
  top: 6px;
}

.tarot-dir-upright { background: #4CAF50; }
.tarot-dir-reversed { background: #f44336; }

.tarot-done { margin-top: 18px; }

.tarot-result-card {
  background: var(--카드색);
  border-radius: 18px;
  padding: 28px 22px;
  margin: 18px 0;
  box-shadow: var(--카드그림자);
  border: 1px solid var(--구분선);
}

.tarot-result-header {
  text-align: center;
  margin-bottom: 22px;
}

.tarot-result-emoji {
  font-size: 3.8rem;
  margin-bottom: 10px;
}

.tarot-result-img {
  display: block;
  margin: 0 auto 14px;
  width: 180px;
  height: auto;
  border-radius: 12px;
  border: 3px solid var(--강조색);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.18);
}

.tarot-result-img-reversed {
  transform: rotate(180deg);
}

.tarot-result-title {
  font-size: 1.35rem;
  font-weight: 800;
  margin-bottom: 7px;
  font-family: var(--제목폰트);
}

.tarot-result-direction {
  display: inline-block;
  padding: 5px 16px;
  border-radius: 14px;
  font-size: 0.88rem;
  font-weight: 700;
  color: #fff;
  margin-bottom: 10px;
}

.tarot-result-keyword {
  color: var(--보조글자색);
  font-size: 0.98rem;
}

.tarot-result-section { margin-bottom: 18px; }

.tarot-result-section-title {
  font-size: 1.1rem;
  font-weight: 700;
  margin-bottom: 10px;
  font-family: var(--제목폰트);
}

.tarot-result-text {
  font-size: 1rem;
  line-height: 1.85;
  color: var(--글자색);
}

.tarot-result-details { margin: 18px 0; }

.tarot-detail-item {
  display: flex;
  align-items: baseline;
  gap: 10px;
  padding: 12px 0;
  border-bottom: 1px dashed var(--구분선);
  font-size: 0.97rem;
  line-height: 1.65;
}

.tarot-detail-item:last-child { border-bottom: none; }

.tarot-detail-icon { font-size: 1.15rem; flex-shrink: 0; }

.tarot-detail-label {
  font-weight: 700;
  color: var(--강조색진);
  min-width: 40px;
  flex-shrink: 0;
}

.tarot-detail-text { color: var(--글자색); }

.tarot-result-advice {
  background: linear-gradient(135deg, rgba(200,106,26,0.08), rgba(212,160,55,0.08));
  border-radius: 14px;
  padding: 18px;
  margin-top: 18px;
  border: 1px solid rgba(200, 106, 26, 0.15);
}

.tarot-advice-label {
  font-weight: 700;
  font-size: 1.02rem;
  margin-bottom: 7px;
  color: var(--강조색진);
  font-family: var(--제목폰트);
}

.tarot-advice-text {
  font-size: 1rem;
  line-height: 1.7;
}

.tarot-btn-disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.fade-in {
  animation: fadeIn 0.5s ease-in;
}

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ══════════════════════════════════
   별자리
   ══════════════════════════════════ */
.별자리그리드 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin: 18px 0;
}

.별자리항목 {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 14px 4px;
  border-radius: 14px;
  border: 2px solid var(--구분선);
  background: var(--카드색);
  cursor: pointer;
  transition: all 0.2s;
}

.별자리항목:hover,
.별자리항목:active {
  border-color: var(--강조색);
  transform: translateY(-2px);
  box-shadow: 0 4px 14px rgba(200, 106, 26, 0.15);
}

.별자리항목.내별자리 {
  border-color: var(--강조색);
  background: linear-gradient(135deg, rgba(212,160,55,0.1), rgba(200,106,26,0.06));
}

.별자리항목.선택됨,
.별자리항목.zodiac-active {
  border-color: var(--강조색진);
  box-shadow: 0 0 0 3px rgba(200, 106, 26, 0.25);
  background: linear-gradient(135deg, rgba(212,160,55,0.12), rgba(200,106,26,0.08));
}

.별자리이모지 {
  font-size: 1.65rem;
  margin-bottom: 5px;
}

.별자리이름텍스트 {
  font-size: 0.82rem;
  font-weight: 700;
  white-space: nowrap;
}

.별자리기간텍스트 {
  font-size: 0.66rem;
  color: var(--보조글자색);
}

.내별자리뱃지 {
  font-size: 0.62rem;
  background: linear-gradient(135deg, var(--강조색), var(--강조색진));
  color: #fff;
  padding: 2px 7px;
  border-radius: 10px;
  margin-top: 3px;
  font-weight: 600;
}

.별자리점수바배경 {
  width: 100%;
  height: 18px;
  background: var(--입력배경);
  border-radius: 9px;
  overflow: hidden;
  margin: 10px 0 18px;
  border: 1px solid var(--구분선);
}

.별자리점수바 {
  height: 100%;
  border-radius: 9px;
  background: linear-gradient(90deg, var(--강조색), var(--강조색진));
  transition: width 0.6s ease;
}

.별자리영역항목 {
  display: flex;
  gap: 10px;
  padding: 12px 0;
  border-bottom: 1px dashed var(--구분선);
  font-size: 0.97rem;
  line-height: 1.65;
}

.별자리영역항목:last-child { border-bottom: none; }

.별자리영역라벨 {
  font-weight: 700;
  color: var(--강조색진);
  min-width: 44px;
  flex-shrink: 0;
}

.별자리행운정보 {
  display: flex;
  gap: 16px;
  margin-top: 14px;
  padding: 14px;
  background: linear-gradient(135deg, rgba(200,106,26,0.08), rgba(212,160,55,0.06));
  border-radius: 12px;
  border: 1px solid rgba(200, 106, 26, 0.15);
}

.별자리행운항목 {
  flex: 1;
  text-align: center;
}

.별자리행운라벨 {
  font-size: 0.82rem;
  color: var(--보조글자색);
  margin-bottom: 5px;
  font-weight: 500;
}

.별자리행운값 {
  font-weight: 700;
  font-size: 0.97rem;
  color: var(--강조색진);
}

/* ══════════════════════════════════
   건강 체질
   ══════════════════════════════════ */
.체질질문텍스트 {
  font-size: 1.15rem;
  font-weight: 700;
  line-height: 1.6;
  margin-bottom: 18px;
  font-family: var(--제목폰트);
}

.체질선택버튼 {
  display: block;
  width: 100%;
  padding: 15px 18px;
  margin-bottom: 10px;
  background: var(--입력배경);
  border: 2px solid var(--입력테두리);
  border-radius: 12px;
  font-size: 1rem;
  font-family: var(--본문폰트);
  color: var(--글자색);
  text-align: left;
  cursor: pointer;
  transition: all 0.2s;
  line-height: 1.5;
  min-height: 54px;
}

.체질선택버튼:hover,
.체질선택버튼:active {
  border-color: var(--강조색);
  background: rgba(212, 160, 55, 0.06);
  transform: translateX(3px);
}

.체질결과카드 { text-align: center; }

.체질이모지 {
  font-size: 3.2rem;
  margin-bottom: 10px;
}

.체질이름 {
  font-size: 1.5rem;
  font-weight: 900;
  margin-bottom: 5px;
  font-family: var(--제목폰트);
  background: linear-gradient(135deg, var(--강조색), var(--강조색진));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.체질별명 {
  font-size: 1.02rem;
  color: var(--보조글자색);
  margin-bottom: 18px;
  font-weight: 500;
}

.체질비율영역 { margin-top: 18px; }

.체질비율항목 {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}

.체질비율이름 {
  min-width: 52px;
  font-size: 0.88rem;
  text-align: right;
  color: var(--보조글자색);
  font-weight: 500;
}

.체질활성 .체질비율이름 {
  color: var(--강조색진);
  font-weight: 700;
}

.체질비율바배경 {
  flex: 1;
  height: 14px;
  background: var(--입력배경);
  border-radius: 7px;
  overflow: hidden;
  border: 1px solid var(--구분선);
}

.체질비율바 {
  height: 100%;
  background: linear-gradient(90deg, var(--강조색), var(--강조색진));
  border-radius: 7px;
  transition: width 0.6s ease;
}

.체질비율숫자 {
  min-width: 40px;
  font-size: 0.88rem;
  font-weight: 700;
}

.체질장기줄 {
  display: flex;
  gap: 12px;
  margin-bottom: 16px;
}

.체질장기 {
  flex: 1;
  padding: 14px;
  border-radius: 12px;
  text-align: center;
  font-size: 1rem;
  line-height: 1.6;
  border: 1px solid;
}

.강한장기 {
  background: rgba(76, 175, 80, 0.1);
  color: #2E7D32;
  border-color: rgba(76, 175, 80, 0.3);
}

.약한장기 {
  background: rgba(244, 67, 54, 0.1);
  color: #C62828;
  border-color: rgba(244, 67, 54, 0.3);
}

body.dark .강한장기 { background: rgba(76, 175, 80, 0.18); color: #81C784; border-color: rgba(76,175,80,0.4); }
body.dark .약한장기 { background: rgba(244, 67, 54, 0.18); color: #EF9A9A; border-color: rgba(244,67,54,0.4); }

.건강라벨 {
  font-weight: 700;
  color: var(--강조색진);
  font-size: 0.97rem;
}

.건강본문 {
  font-size: 1.05rem;
  line-height: 1.85;
  margin-bottom: 14px;
}

.체질체형,
.체질성격,
.건강보강,
.건강주의점,
.건강운동 {
  margin-top: 12px;
  font-size: 0.97rem;
  line-height: 1.65;
}

.건강음식좋은,
.건강음식나쁜 { margin-bottom: 12px; }

.건강음식좋은 p,
.건강음식나쁜 p {
  margin-top: 5px;
  font-size: 0.97rem;
  line-height: 1.65;
}

.건강주의 ul {
  margin: 5px 0 0 22px;
  font-size: 0.97rem;
  line-height: 1.85;
}

.오행건강차트 { margin-top: 14px; }

.오행건강항목 {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}

.오행건강부호 {
  font-size: 1.35rem;
  min-width: 30px;
  text-align: center;
}

.오행건강이름 {
  min-width: 48px;
  font-size: 0.92rem;
  font-weight: 700;
}

.오행건강바배경 {
  flex: 1;
  height: 14px;
  background: var(--입력배경);
  border-radius: 7px;
  overflow: hidden;
  border: 1px solid var(--구분선);
}

.오행건강바 {
  height: 100%;
  border-radius: 7px;
  transition: width 0.6s ease;
}

.오행건강수치 {
  min-width: 54px;
  font-size: 0.88rem;
  text-align: right;
  font-weight: 500;
}

.오행강뱃지 {
  display: inline-block;
  background: #4CAF50;
  color: #fff;
  font-size: 0.72rem;
  padding: 2px 7px;
  border-radius: 6px;
  font-weight: 700;
}

.오행약뱃지 {
  display: inline-block;
  background: #f44336;
  color: #fff;
  font-size: 0.72rem;
  padding: 2px 7px;
  border-radius: 6px;
  font-weight: 700;
}

.오행약한카드 {
  border-left-width: 4px !important;
}

/* ══════════════════════════════════
   토정비결
   ══════════════════════════════════ */
.토정괘3열 {
  display: flex;
  justify-content: center;
  gap: 18px;
  margin: 18px 0;
}

.토정괘항목 {
  text-align: center;
  flex: 1;
  max-width: 120px;
  padding: 14px 8px;
  background: var(--보조카드색);
  border-radius: 12px;
  border: 1px solid var(--구분선);
}

.토정괘라벨 {
  font-size: 0.88rem;
  color: var(--보조글자색);
  margin-bottom: 6px;
  font-weight: 500;
}

.토정괘부호 {
  font-size: 2.6rem;
  line-height: 1.2;
  color: var(--글자색);
  font-family: var(--제목폰트);
}

.토정괘이름 {
  font-size: 1rem;
  font-weight: 700;
  margin-top: 6px;
  font-family: var(--제목폰트);
}

.토정괘설명 {
  font-size: 0.82rem;
  color: var(--보조글자색);
  margin-top: 3px;
}

.토정괘명 {
  text-align: center;
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--구분선);
}

.토정괘명텍스트 {
  font-family: var(--제목폰트);
  font-size: 1.3rem;
  font-weight: 800;
  color: var(--강조색진);
}

.토정길흉뱃지 {
  display: inline-block;
  color: #fff;
  font-weight: 800;
  font-size: 1.15rem;
  padding: 7px 24px;
  border-radius: 22px;
  margin-bottom: 14px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
}

.토정총운카드 { text-align: center; }

.토정총운내용 {
  text-align: left;
  font-size: 1.05rem;
  line-height: 1.85;
  color: var(--글자색);
  margin-top: 14px;
}

.토정월별항목 {
  display: flex;
  align-items: baseline;
  gap: 14px;
  padding: 12px 0;
  border-bottom: 1px dashed var(--구분선);
}

.토정월별항목:last-child { border-bottom: none; }

.토정월이름 {
  font-weight: 700;
  font-size: 0.97rem;
  min-width: 64px;
  color: var(--강조색진);
  flex-shrink: 0;
  font-family: var(--제목폰트);
}

.토정월내용 {
  font-size: 0.95rem;
  line-height: 1.65;
  color: var(--글자색);
}

.토정현재월 {
  background: linear-gradient(135deg, rgba(212,160,55,0.1), rgba(200,106,26,0.06));
  border-radius: 10px;
  padding: 12px 10px;
  margin: 0 -10px;
  border: 1px solid rgba(200, 106, 26, 0.2);
}

.토정현재월 .토정월이름 {
  color: var(--강조색);
}

.토정현재월 .토정월이름::after {
  content: ' ◀ 이번달';
  font-size: 0.7rem;
  color: var(--강조색진);
  font-family: var(--본문폰트);
}

.토정조언내용 {
  font-size: 1.05rem;
  line-height: 1.85;
  color: var(--글자색);
}

#토정-양력입력 {
  margin-right: 6px;
  transform: scale(1.2);
  vertical-align: middle;
}

.입력라벨 {
  font-size: 1rem;
  color: var(--글자색);
  cursor: pointer;
}

/* ==========================================
   푸터
   ========================================== */
.앱푸터 {
  max-width: 600px;
  margin: 0 auto;
  padding: 24px 16px 100px;
  text-align: center;
  font-size: 0.88rem;
  color: var(--보조글자색);
  line-height: 1.65;
}

.면책고지 {
  background: var(--카드색);
  border-radius: 14px;
  padding: 18px;
  margin-bottom: 14px;
  border: 1px solid var(--구분선);
}

.면책고지 p {
  margin: 5px 0;
  font-size: 0.82rem;
}

.푸터링크 { margin: 10px 0; }

.푸터링크 a {
  color: var(--강조색진);
  text-decoration: underline;
  font-size: 0.88rem;
  font-weight: 500;
}

.저작권 {
  margin-top: 10px;
  font-size: 0.78rem;
  color: var(--연한글자색);
}

/* ==========================================
   모달
   ========================================== */
.모달오버레이 {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(4px);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
}

.모달내용 {
  background: var(--카드색);
  border-radius: 18px;
  max-width: 560px;
  width: 100%;
  max-height: 80vh;
  overflow-y: auto;
  box-shadow: 0 12px 48px rgba(0,0,0,0.25);
  border: 1px solid var(--구분선);
}

.모달헤더 {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 22px 22px 14px;
  border-bottom: 1px solid var(--구분선);
  position: sticky;
  top: 0;
  background: var(--카드색);
  border-radius: 18px 18px 0 0;
}

.모달헤더 h2 {
  font-size: 1.25rem;
  margin: 0;
  font-family: var(--제목폰트);
}

.모달닫기 {
  background: none;
  border: none;
  font-size: 1.9rem;
  cursor: pointer;
  color: var(--보조글자색);
  padding: 0 4px;
  line-height: 1;
  transition: color 0.15s;
}

.모달닫기:hover { color: var(--강조색진); }

.모달본문 {
  padding: 22px;
  font-size: 0.93rem;
  line-height: 1.85;
  color: var(--글자색);
}

.모달본문 h3 {
  font-size: 1.02rem;
  margin: 22px 0 8px;
  color: var(--강조색진);
  font-family: var(--제목폰트);
}

.모달본문 h3:first-child { margin-top: 0; }
.모달본문 p { margin: 0 0 12px; }

.방침날짜 {
  margin-top: 26px;
  font-size: 0.82rem;
  color: var(--보조글자색);
  text-align: right;
}

/* ==========================================
   반응형: 401~500px (큰 모바일 — 아이폰 14, 갤럭시 등)
   ========================================== */
@media (min-width: 401px) and (max-width: 500px) {
  .로또공 { width: 42px; height: 42px; font-size: 0.96rem; margin: 2px; }
  .생성결과줄 { gap: 3px; }
}

/* ==========================================
   반응형: 400px 이하 모바일
   ========================================== */
@media (max-width: 400px) {
  html { font-size: 16px; }

  .앱헤더 { padding: 0 14px; }
  .서비스명 { font-size: 1.3rem; }

  .메인컨테이너 { padding: 14px 12px; }

  .카드 {
    padding: 18px;
    border-radius: 14px;
  }

  .카드제목 { font-size: 1.15rem; }

  .로또공 {
    width: 38px;
    height: 38px;
    font-size: 0.9rem;
    margin: 2px;
  }
  .생성결과줄 { gap: 2px; padding: 12px 0; }

  .등급선택영역 { gap: 8px; }
  .등급버튼 { font-size: 0.9rem; padding: 11px 12px; }
  .등급설명 { font-size: 0.72rem; }

  .번호입력칸 { padding: 9px 2px; font-size: 0.98rem; }
  .날짜입력 { padding: 11px 8px; font-size: 0.95rem; }

  .주요버튼 {
    padding: 13px 20px;
    font-size: 1rem;
    min-height: 50px;
  }

  .날짜선택 { padding: 11px 6px; font-size: 0.95rem; padding-right: 26px; }

  .사주표 { gap: 4px; }
  .사주칸천간, .사주칸지지 { font-size: 1.15rem; }

  .점수숫자 { font-size: 2.6rem; }

  .빠른메뉴 { grid-template-columns: repeat(3, 1fr); }
  .메인인사 { font-size: 1.7rem; }
  .빠른메뉴항목 {
    min-height: 92px;
    padding: 14px 4px;
  }
  .빠른메뉴아이콘 { font-size: 1.8rem; }

  .별자리그리드 { grid-template-columns: repeat(3, 1fr); }
  .tarot-card { width: 85px; height: 128px; }
}

/* saju-web 반응형 (600px 이하) */
@media (max-width: 600px) {
  .saju-hanja { font-size: 1.8rem; }
  .compat-grid { grid-template-columns: 1fr; }
  .strength-weakness { grid-template-columns: 1fr; }
  .advice-grid { grid-template-columns: 1fr 1fr; }
  .health-card-grid,
  .health-grid,
  .career-grid { grid-template-columns: 1fr; }
  .sipsung-grid { grid-template-columns: 1fr 1fr; }
  .section-title { font-size: 1.3rem; }
  .interp-block { padding: 20px 22px; }
}

/* saju-web 반응형 (400px 이하) */
@media (max-width: 400px) {
  .saju-hanja { font-size: 1.5rem; }
  .saju-cell { padding: 12px 6px; }
  .saju-table { border-spacing: 5px; }
  .advice-grid { grid-template-columns: 1fr; }
  .interp-block { padding: 18px; }
  .ohaeng-bar { width: 34px; }
  .ohaeng-bar-wrap { height: 96px; }
  .luck-item { min-width: 62px; padding: 10px 4px; }
  .luck-gan, .luck-ji { font-size: 1.25rem; }
  .section-title { font-size: 1.18rem; }
}

/* ── PC 대응 (768px 이상) ── */
@media (min-width: 768px) {
  #탭-메인 {
    max-width: 720px;
    margin: 0 auto;
  }

  .메인히어로 {
    padding: 52px 24px 34px;
  }

  .메인인사 { font-size: 2.4rem; }
  .메인설명 { font-size: 1.08rem; }

  .빠른메뉴 {
    grid-template-columns: repeat(5, 1fr);
    gap: 14px;
    margin-bottom: 26px;
  }

  .빠른메뉴항목 {
    padding: 22px 8px;
    min-height: 118px;
  }

  .빠른메뉴아이콘 { font-size: 2.5rem; }
  .빠른메뉴이름 { font-size: 0.88rem; }

  #탭-메인 .카드 {
    padding: 26px;
    margin-bottom: 20px;
  }

  .서비스소개목록 {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
  }

  .하단탭바 {
    justify-content: center;
  }

  .탭버튼 {
    min-width: 84px;
    font-size: 0.82rem;
    padding: 6px 12px;
  }
}

/* ============================================================
   미니게임 공통
   ============================================================ */
.게임안내카드 {
  text-align: center;
}

.게임서브탭바 {
  display: flex;
  gap: 6px;
  margin: 12px 0 14px;
  padding: 6px;
  background: var(--카드색);
  border-radius: 12px;
  box-shadow: var(--카드그림자);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.게임서브탭 {
  flex: 1 0 auto;
  min-width: 96px;
  padding: 10px 12px;
  border: none;
  border-radius: 8px;
  background: transparent;
  color: var(--보조글자색);
  font-size: 0.98rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.2s, color 0.2s, transform 0.1s;
  white-space: nowrap;
}

.게임서브탭:hover {
  color: var(--강조색진);
}

.게임서브탭.활성 {
  background: linear-gradient(135deg, var(--강조색) 0%, var(--강조색진) 100%);
  color: #fff;
  box-shadow: 0 2px 6px rgba(200, 106, 26, 0.3);
}

.게임패널 {
  display: none;
}

.게임패널.활성 {
  display: block;
  animation: 게임패널등장 0.3s ease-out;
}

@keyframes 게임패널등장 {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: translateY(0); }
}

.준비중카드 {
  text-align: center;
  padding: 40px 20px;
}

.준비중아이콘 {
  font-size: 3.4rem;
  margin-bottom: 14px;
  opacity: 0.75;
}

body.dark .게임서브탭바 {
  background: rgba(255, 255, 255, 0.04);
}

/* ============================================================
   오늘의 단어 (한글 자모 워들)
   ============================================================ */
.단어카드 {
  text-align: center;
  position: relative;
  overflow: hidden;
  /* 따뜻한 오로라 배경 (여러 겹 글로우 + 그라데이션) */
  background:
    radial-gradient(circle at 12% 12%, rgba(212, 160, 55, 0.20), transparent 42%),
    radial-gradient(circle at 88% 16%, rgba(200, 106, 26, 0.16), transparent 44%),
    radial-gradient(circle at 85% 92%, rgba(139, 58, 31, 0.12), transparent 46%),
    radial-gradient(circle at 8% 88%, rgba(212, 160, 55, 0.14), transparent 46%),
    linear-gradient(170deg, #fffdf9 0%, #fdf5e6 55%, #fbeed6 100%);
  box-shadow: var(--카드그림자강), 0 0 0 1px rgba(212, 160, 55, 0.25), 0 0 44px rgba(200, 106, 26, 0.10);
}

/* 상단 광채 (천천히 숨쉬기) */
.단어카드::before {
  content: "";
  position: absolute;
  top: -130px;
  left: 50%;
  width: 360px;
  height: 260px;
  transform: translateX(-50%);
  background: radial-gradient(ellipse at center, rgba(212, 160, 55, 0.28), transparent 70%);
  pointer-events: none;
  z-index: 0;
  animation: 단어광채 6s ease-in-out infinite;
}

@keyframes 단어광채 {
  0%, 100% { opacity: 0.65; transform: translateX(-50%) scale(1); }
  50% { opacity: 1; transform: translateX(-50%) scale(1.12); }
}

/* 하단 장식 글로우 */
.단어카드::after {
  content: "";
  position: absolute;
  bottom: -120px;
  right: -60px;
  width: 300px;
  height: 240px;
  background: radial-gradient(ellipse at center, rgba(200, 106, 26, 0.16), transparent 70%);
  pointer-events: none;
  z-index: 0;
}

.단어카드 > * { position: relative; z-index: 1; }

/* 다크모드 오로라 */
body.dark .단어카드 {
  background:
    radial-gradient(circle at 12% 12%, rgba(255, 200, 87, 0.16), transparent 42%),
    radial-gradient(circle at 88% 16%, rgba(255, 156, 62, 0.13), transparent 44%),
    radial-gradient(circle at 85% 92%, rgba(255, 156, 62, 0.10), transparent 46%),
    radial-gradient(circle at 8% 88%, rgba(255, 200, 87, 0.10), transparent 46%),
    linear-gradient(170deg, #24262f 0%, #1e2028 100%);
  box-shadow: var(--카드그림자강), 0 0 0 1px rgba(255, 200, 87, 0.18);
}

/* ── 화려한 헤더 ── */
.단어헤더 {
  margin-bottom: 14px;
}

.단어타이틀 {
  margin: 0 0 4px;
  font-size: 1.9rem;
  font-weight: 800;
  letter-spacing: -0.5px;
  background: linear-gradient(100deg, var(--강조색2) 0%, var(--강조색진) 35%, var(--강조색) 70%, var(--강조색진) 100%);
  background-size: 200% auto;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: 단어타이틀빛 4s linear infinite;
}

@keyframes 단어타이틀빛 {
  to { background-position: 200% center; }
}

.단어타이틀아이콘 {
  -webkit-text-fill-color: initial;
  display: inline-block;
  animation: 단어아이콘흔들 3s ease-in-out infinite;
}

@keyframes 단어아이콘흔들 {
  0%, 100% { transform: rotate(-6deg) scale(1); }
  50% { transform: rotate(6deg) scale(1.12); }
}

.단어부제 {
  margin: 0;
  font-size: 0.9rem;
  color: var(--보조글자색);
}

.단어안내 {
  margin-bottom: 16px;
}

.단어게임진행 {
  display: inline-block;
  margin: 0 auto 8px;
  padding: 5px 18px;
  background: linear-gradient(135deg, var(--강조색) 0%, var(--강조색진) 100%);
  border-radius: 999px;
  font-size: 0.92rem;
  font-weight: 700;
  color: #fff;
  box-shadow: 0 3px 10px rgba(200, 106, 26, 0.35);
}

.단어게임진행 strong { color: #fff; font-weight: 800; }

.단어다음문제버튼 {
  width: 100%;
  max-width: 380px;
  margin: 0 auto 12px;
  display: block;
}

.단어규칙 {
  font-size: 1.04rem;
  color: var(--글자색);
  margin: 0 0 8px;
}

.단어규칙 strong { color: var(--강조색진); }

.단어범례 {
  font-size: 0.86rem;
  color: var(--보조글자색);
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 4px 12px;
  justify-content: center;
  align-items: center;
}

.범례칩 {
  display: inline-block;
  width: 14px;
  height: 14px;
  border-radius: 3px;
  vertical-align: middle;
  margin-right: 3px;
}

.범례칩.초록 { background: #57a552; }
.범례칩.노랑 { background: #c9ac3f; }
.범례칩.회색 { background: #86888a; }

/* ── 정답 그리드 ── */
.단어그리드 {
  display: grid;
  gap: 7px;
  max-width: 380px;
  margin: 0 auto 18px;
  padding: 14px;
  background: rgba(255, 255, 255, 0.55);
  border-radius: 16px;
  box-shadow: inset 0 0 0 1px rgba(212, 160, 55, 0.18), 0 6px 20px rgba(120, 90, 40, 0.10);
  backdrop-filter: blur(3px);
  -webkit-backdrop-filter: blur(3px);
}

body.dark .단어그리드 {
  background: rgba(255, 255, 255, 0.06);
  box-shadow: inset 0 0 0 1px rgba(255, 200, 87, 0.15), 0 6px 20px rgba(0, 0, 0, 0.25);
}

.단어칸 {
  aspect-ratio: 1 / 1;
  min-width: 0;
  min-height: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  font-weight: 800;
  border-radius: 10px;
  color: #fff;
  user-select: none;
  transition: transform 0.15s, box-shadow 0.2s;
}

.단어칸.빈칸 {
  background: linear-gradient(180deg, rgba(255,255,255,0.5), rgba(120,110,95,0.05));
  border: 2px solid var(--테두리색, rgba(120, 110, 95, 0.25));
  color: var(--글자색);
}

.단어칸.입력됨 {
  background: linear-gradient(180deg, #fff, #fff5e6);
  border: 2px solid var(--강조색진);
  color: var(--글자색);
  box-shadow: 0 0 0 3px rgba(212, 160, 55, 0.18), 0 3px 8px rgba(200, 106, 26, 0.15);
}

/* 방금 입력한 칸 팝 */
.단어칸.pop { animation: 칸팝 0.18s ease; }
@keyframes 칸팝 {
  0% { transform: scale(0.8); }
  60% { transform: scale(1.12); }
  100% { transform: scale(1); }
}

/* 자리맞음 = 초록 (카톡 스타일) */
.단어칸.초록 {
  background: linear-gradient(160deg, #78c46e 0%, #57a552 100%);
  border: 2px solid #57a552;
  box-shadow: 0 4px 12px rgba(106, 170, 100, 0.5), inset 0 1px 2px rgba(255,255,255,0.35);
}
/* 있지만 자리틀림 = 노랑 */
.단어칸.노랑 {
  background: linear-gradient(160deg, #e0c85f 0%, #c9ac3f 100%);
  border: 2px solid #c9ac3f;
  box-shadow: 0 4px 12px rgba(201, 180, 88, 0.5), inset 0 1px 2px rgba(255,255,255,0.3);
}
/* 없음 = 회색 */
.단어칸.회색 {
  background: linear-gradient(160deg, #9a9c9e 0%, #7d7f81 100%);
  border: 2px solid #7d7f81;
  box-shadow: inset 0 1px 2px rgba(255,255,255,0.2);
}

/* 순차 공개 전 대기 상태 (글자만 보임) */
.단어칸.뒤집기대기 {
  background: transparent;
  border: 2px solid var(--강조색진);
  color: var(--글자색);
}

/* 왼쪽부터 한 칸씩 뒤집으며 색 공개 */
.단어칸.뒤집힘 {
  animation: 칸뒤집기 0.5s ease both;
}

@keyframes 칸뒤집기 {
  0%   { transform: rotateX(0deg); }
  45%  { transform: rotateX(90deg); }
  55%  { transform: rotateX(90deg); }
  100% { transform: rotateX(0deg); }
}

.단어그리드.흔들기 {
  animation: 단어흔들 0.4s;
}

@keyframes 단어흔들 {
  0%, 100% { transform: translateX(0); }
  20%, 60% { transform: translateX(-6px); }
  40%, 80% { transform: translateX(6px); }
}

/* ── 자모 키보드 ── */
.단어키보드 {
  margin: 0 auto 14px;
  max-width: 460px;
}

.단어키줄 {
  display: flex;
  gap: 4px;
  justify-content: center;
  margin-bottom: 5px;
}

.단어키 {
  flex: 1 1 0;
  min-width: 0;
  max-width: 42px;
  height: 50px;
  border: none;
  border-radius: 9px;
  background: linear-gradient(180deg, var(--단어키상, #ffffff), var(--단어키하, #ece3d2));
  color: var(--글자색);
  font-size: 1.14rem;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 2px 4px rgba(80, 60, 40, 0.12);
  transition: background 0.15s, transform 0.08s, box-shadow 0.12s;
}

/* 다크모드: 기본 키 배경을 어둡게 (밝은 글자가 보이도록) */
body.dark .단어키 {
  --단어키상: #3b3f4b;
  --단어키하: #2b2e38;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.35);
}

.단어키:hover {
  background: linear-gradient(180deg, var(--강조색), var(--강조색진));
  color: #fff;
}
.단어키:active { transform: translateY(1px) scale(0.94); box-shadow: 0 1px 2px rgba(80,60,40,0.15); }

.단어키.기능키 {
  flex: 1.4 1 0;
  max-width: 56px;
  font-size: 1.2rem;
}

.단어키.키초록 {
  background: linear-gradient(180deg, #78c46e, #57a552);
  color: #fff;
  box-shadow: 0 3px 8px rgba(106, 170, 100, 0.5);
}
.단어키.키노랑 {
  background: linear-gradient(180deg, #e0c85f, #c9ac3f);
  color: #fff;
  box-shadow: 0 3px 8px rgba(201, 180, 88, 0.4);
}
.단어키.키회색 {
  background: linear-gradient(180deg, #9a9c9e, #7d7f81);
  color: #fff;
  opacity: 0.85;
}

.단어제출버튼 {
  width: 100%;
  max-width: 380px;
  margin: 0 auto 12px;
  display: block;
}

.단어제출버튼:disabled {
  opacity: 0.5;
  cursor: default;
}

.단어상태 {
  font-size: 1rem;
  color: var(--보조글자색);
  margin-bottom: 8px;
}

.단어상태 strong { color: var(--강조색진); }

.단어정답공개 {
  font-size: 1.06rem;
  color: var(--글자색);
  margin: 8px 0 14px;
}

.단어정답공개 strong { color: var(--강조색진); font-size: 1.2rem; }

/* ── 결과 연출 (화려하게) ── */
#단어결과영역 {
  animation: 단어결과등장 0.5s cubic-bezier(0.2, 0.9, 0.3, 1.35) both;
}

@keyframes 단어결과등장 {
  0% { opacity: 0; transform: translateY(16px) scale(0.95); }
  100% { opacity: 1; transform: translateY(0) scale(1); }
}

#단어결과등급 {
  animation: 단어등급반짝 2s ease-in-out infinite;
}

@keyframes 단어등급반짝 {
  0%, 100% { filter: drop-shadow(0 0 0 rgba(212, 160, 55, 0)); transform: scale(1); }
  50% { filter: drop-shadow(0 0 12px rgba(212, 160, 55, 0.65)); transform: scale(1.05); }
}

/* 행운 번호 공 등장 */
#단어행운번호 .로또공 {
  animation: 단어공퐁 0.4s ease both;
}
@keyframes 단어공퐁 {
  0% { opacity: 0; transform: scale(0.3); }
  70% { transform: scale(1.15); }
  100% { opacity: 1; transform: scale(1); }
}

.단어통계 {
  max-width: 300px;
  margin: 4px auto 16px;
  padding: 12px 16px;
  background: var(--보조카드색);
  border-radius: 12px;
  text-align: left;
}

.통계행 {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  padding: 5px 0;
  font-size: 1rem;
}

.통계행 + .통계행 {
  border-top: 1px solid rgba(120, 110, 95, 0.14);
}

.통계라벨 { color: var(--보조글자색); min-width: 0; white-space: nowrap; flex-shrink: 0; }
.통계값 { color: var(--글자색); font-weight: 700; min-width: 0; text-align: right; overflow-wrap: anywhere; }
.통계값.레벨값 { color: var(--강조색진); }
.통계값.연패값 { color: #d9534f; }
.승값 { color: #2e7d32; }
.패값 { color: #d9534f; }
.연패강조 { color: #d9534f; font-weight: 700; }

@media (max-width: 400px) {
  .단어칸 { font-size: 1.24rem; }
  .단어키 { height: 44px; font-size: 1.04rem; }
}

/* ============================================================
   행운의 룰렛
   ============================================================ */

.룰렛카드 {
  padding: 24px 16px;
  text-align: center;
}

.룰렛컨테이너 {
  position: relative;
  width: 300px;
  height: 300px;
  margin: 10px auto 20px;
}

.룰렛판 {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  /* 섹터 0:대길(빨강) 1:길(주황) 2:평(청록) 3:길 4:평 5:길 6:평 7:흉(회색) */
  background:
    /* 좌상단 광택 (3D 입체감) */
    radial-gradient(circle at 32% 28%, rgba(255, 255, 255, 0.45), transparent 48%),
    /* 가장자리 음영 (둥근 돔 효과) */
    radial-gradient(circle at 50% 50%, transparent 58%, rgba(0, 0, 0, 0.18) 100%),
    /* 섹터 경계 흰색 라인 (별모양 분할) */
    repeating-conic-gradient(
      rgba(255, 255, 255, 0.92) 0deg 0.9deg,
      transparent 0.9deg 45deg
    ),
    /* 섹터 색상 */
    conic-gradient(
      #e63946 0deg 45deg,      /* 대길 — 선명한 빨강 */
      #f4a261 45deg 90deg,     /* 길  — 따뜻한 주황 */
      #4fb8b0 90deg 135deg,    /* 평  — 차분한 청록 */
      #f4a261 135deg 180deg,
      #4fb8b0 180deg 225deg,
      #f4a261 225deg 270deg,
      #4fb8b0 270deg 315deg,
      #90a4ae 315deg 360deg    /* 흉  — 블루그레이 */
    );
  box-shadow:
    0 0 0 5px #ffffff,
    0 0 0 9px var(--강조색),
    0 0 0 12px #ffffff,
    0 0 0 15px var(--강조색진),
    0 14px 38px rgba(200, 106, 26, 0.42);
  position: relative;
  transform: rotate(0deg);
  transition: transform 4.5s cubic-bezier(0.17, 0.67, 0.21, 1);
}

/* 안쪽 광택 링 (오버레이) */
.룰렛판::after {
  content: '';
  position: absolute;
  inset: 4%;
  border-radius: 50%;
  pointer-events: none;
  background:
    radial-gradient(circle at 30% 25%, rgba(255, 255, 255, 0.18), transparent 55%);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.35),
    inset 0 -8px 18px rgba(0, 0, 0, 0.08);
}

.룰렛라벨 {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.룰렛라벨span {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 92px;
  margin-left: -46px;
  margin-top: -78px;
  text-align: center;
  font-family: var(--제목폰트);
  font-weight: 900;
  font-size: 1.1rem;
  color: #ffffff;
  text-shadow:
    0 1px 2px rgba(0, 0, 0, 0.6),
    0 0 6px rgba(0, 0, 0, 0.45),
    0 2px 0 rgba(0, 0, 0, 0.25);
  letter-spacing: 0.04em;
  transform-origin: 50% 78px;
}

.룰렛포인터 {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 2.2rem;
  color: var(--강조색진);
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.25));
  z-index: 3;
}

.룰렛중앙버튼 {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 92px;
  height: 92px;
  border-radius: 50%;
  border: 4px solid #fff;
  background: linear-gradient(135deg, var(--강조색) 0%, var(--강조색진) 100%);
  color: #fff;
  font-weight: 800;
  font-size: 1.05rem;
  letter-spacing: 0.04em;
  cursor: pointer;
  box-shadow:
    0 4px 12px rgba(200, 106, 26, 0.45),
    inset 0 2px 6px rgba(255, 255, 255, 0.4);
  transition: transform 0.15s;
  z-index: 2;
}

.룰렛중앙버튼:hover:not(:disabled) {
  transform: translate(-50%, -50%) scale(1.05);
}

.룰렛중앙버튼:active:not(:disabled) {
  transform: translate(-50%, -50%) scale(0.96);
}

.룰렛중앙버튼:disabled {
  opacity: 0.55;
  cursor: not-allowed;
  filter: grayscale(0.3);
}

.룰렛상태 {
  font-size: 0.98rem;
  color: var(--보조글자색);
  margin-bottom: 10px;
}

.룰렛상태 strong {
  color: var(--강조색진);
  font-size: 1.1rem;
}

.룰렛결과영역 {
  margin-top: 18px;
  padding: 18px 14px;
  border-radius: 14px;
  background: var(--보조카드색);
  border: 2px solid var(--구분선진);
  animation: 룰렛결과나타남 0.5s ease-out;
}

@keyframes 룰렛결과나타남 {
  from { opacity: 0; transform: translateY(12px); }
  to { opacity: 1; transform: translateY(0); }
}

.룰렛결과등급 {
  font-family: var(--제목폰트);
  font-size: 1.8rem;
  font-weight: 800;
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
}

.룰렛결과등급.대길 { color: #d32f2f; }
.룰렛결과등급.길 { color: var(--강조색진); }
.룰렛결과등급.평 { color: var(--감청); }
.룰렛결과등급.흉 { color: #616161; }

.룰렛결과라벨 {
  font-size: 2rem;
  letter-spacing: 0.04em;
}

.룰렛결과등급태그 {
  font-size: 0.88rem;
  font-weight: 700;
  padding: 4px 12px;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.06);
  color: inherit;
  letter-spacing: 0.02em;
}

.룰렛결과메시지 {
  font-size: 1rem;
  color: var(--글자색);
  line-height: 1.55;
  margin-bottom: 14px;
}

.룰렛행운번호라벨 {
  font-size: 0.92rem;
  color: var(--보조글자색);
  margin-bottom: 8px;
}

.룰렛행운번호공들 {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: center;
}

/* 행운 5종 세트 */
.룰렛행운세트 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin: 14px 0 16px;
}

.행운항목 {
  background: var(--카드색);
  border: 1px solid var(--구분선);
  border-radius: 10px;
  padding: 10px 12px;
  text-align: left;
}

.행운한마디 {
  grid-column: 1 / -1;
  text-align: center;
  background: linear-gradient(135deg, rgba(212, 160, 55, 0.10) 0%, rgba(200, 106, 26, 0.10) 100%);
  border-color: var(--강조색);
}

.행운라벨 {
  font-size: 0.78rem;
  color: var(--보조글자색);
  margin-bottom: 4px;
  letter-spacing: 0.02em;
}

.행운값 {
  font-size: 1rem;
  color: var(--글자색);
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.행운값 strong {
  font-weight: 800;
  font-size: 1.08rem;
  color: var(--강조색진);
}

.행운값 .행운아이콘 {
  font-size: 1.2rem;
}

.행운값 .행운설명 {
  font-size: 0.82rem;
  color: var(--보조글자색);
  margin-left: 2px;
}

.행운한마디 .행운값 {
  justify-content: center;
  font-family: var(--제목폰트);
  font-size: 1.02rem;
  color: var(--글자색);
  font-style: italic;
  line-height: 1.5;
}

/* 결과 하단 액션 버튼 */
.룰렛결과액션 {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 14px;
}

.룰렛결과액션 .보조버튼 {
  width: 100%;
  justify-content: center;
}

.카톡공유버튼 {
  background: #fee500 !important;
  color: #3c1e1e !important;
  font-weight: 700;
  border: none !important;
}

.카톡공유버튼:hover {
  filter: brightness(0.95);
}

body.dark .행운항목 {
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(255, 255, 255, 0.08);
}

body.dark .룰렛결과영역 {
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(255, 255, 255, 0.12);
}

/* 반응형 */
@media (max-width: 400px) {
  .룰렛컨테이너 {
    width: 260px;
    height: 260px;
  }
  .룰렛중앙버튼 {
    width: 80px;
    height: 80px;
    font-size: 0.95rem;
  }
  .룰렛라벨span {
    font-size: 0.95rem;
    width: 80px;
    margin-left: -40px;
    margin-top: -68px;
    transform-origin: 50% 68px;
  }
}

/* ============================================================
   복권긁기 (스피또 스타일)
   ============================================================ */

.복권카드 {
  padding: 22px 16px 24px;
  text-align: center;
}

.복권안내 {
  margin-bottom: 18px;
}

.복권규칙 {
  font-size: 1rem;
  line-height: 1.55;
  color: var(--글자색);
  opacity: 0.85;
  margin: 0;
}

.복권규칙 strong {
  color: var(--강조색진);
}

/* 그리드 */
.복권그리드 {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 10px;
  width: 100%;
  max-width: 360px;
  margin: 0 auto 18px;
  padding: 12px;
  box-sizing: border-box;
  background: linear-gradient(135deg, #f5e7c8, #e9d6a8);
  border-radius: 14px;
  border: 2px dashed rgba(196, 138, 38, 0.45);
}

.복권그리드:empty {
  display: none !important;
}

/* 각 칸 */
.복권칸 {
  position: relative;
  width: 100%;
  min-width: 0;
  aspect-ratio: 5 / 4;
  background: #fff8e7;
  border-radius: 10px;
  overflow: hidden;
  box-shadow: inset 0 1px 2px rgba(0,0,0,0.06), 0 2px 4px rgba(50,40,30,0.06);
  user-select: none;
  -webkit-user-select: none;
  -webkit-tap-highlight-color: transparent;
}

.복권심볼 {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
}

.복권한자 {
  font-family: "Noto Serif KR", serif;
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1;
}

/* 심볼별 색상 (라이트 모드) */
.복권심볼-복 { color: #c0392b; }
.복권심볼-금 { color: #b8860b; }
.복권심볼-수 { color: #1f3b5e; }
.복권심볼-희 { color: #c86a1a; }
.복권심볼-재 { color: #7d6608; }
.복권심볼-길 { color: #1e6091; }
.복권심볼-안 { color: #2e7d32; }

/* 다크 모드: 어두운 배경에 잘 보이도록 채도/명도 ↑ */
body.dark .복권심볼-복 { color: #ff7a6a; }
body.dark .복권심볼-금 { color: #ffd166; }
body.dark .복권심볼-수 { color: #88a7d9; }
body.dark .복권심볼-희 { color: #ffb072; }
body.dark .복권심볼-재 { color: #e8c75a; }
body.dark .복권심볼-길 { color: #6cb6ff; }
body.dark .복권심볼-안 { color: #7dd87f; }

.복권의미 {
  font-size: 0.7rem;
  color: rgba(50, 40, 30, 0.55);
  letter-spacing: 0.05em;
}

.복권코팅 {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  cursor: grab;
  touch-action: none;
}

.복권칸.공개됨 .복권코팅 {
  display: none;
}

.복권칸.공개됨 {
  animation: 복권칸등장 0.4s ease-out;
}

@keyframes 복권칸등장 {
  0%   { transform: scale(0.92); }
  60%  { transform: scale(1.04); }
  100% { transform: scale(1); }
}

/* 매칭 강조 */
.복권칸.매칭 {
  background: linear-gradient(135deg, #fff4c4, #ffd97a);
  box-shadow:
    0 0 0 2px var(--강조색),
    0 0 16px rgba(212, 160, 55, 0.55),
    inset 0 1px 2px rgba(255,255,255,0.6);
  animation: 복권매칭빛남 1.5s ease-in-out infinite;
}

@keyframes 복권매칭빛남 {
  0%, 100% { box-shadow: 0 0 0 2px var(--강조색), 0 0 12px rgba(212, 160, 55, 0.45), inset 0 1px 2px rgba(255,255,255,0.6); }
  50%      { box-shadow: 0 0 0 2px var(--강조색), 0 0 22px rgba(212, 160, 55, 0.85), inset 0 1px 2px rgba(255,255,255,0.7); }
}

/* 액션 */
.복권액션 {
  display: flex;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
  margin: 8px 0 12px;
}

.복권시작버튼 {
  min-width: 160px;
  font-size: 1.05rem;
}

.복권모두긁기 {
  font-size: 0.95rem;
}

.복권상태 {
  font-size: 0.95rem;
  color: var(--글자색);
  opacity: 0.75;
  margin-bottom: 4px;
}

.복권상태 strong {
  color: var(--강조색진);
  font-size: 1.1rem;
}

/* 다크 모드 */
body.dark .복권그리드 {
  background: linear-gradient(135deg, #2c2a26, #3a3530);
  border-color: rgba(255, 200, 87, 0.35);
}

body.dark .복권칸 {
  background: #2a2820;
  box-shadow: inset 0 1px 2px rgba(0,0,0,0.4), 0 2px 4px rgba(0,0,0,0.3);
}

body.dark .복권의미 {
  color: rgba(236, 230, 220, 0.55);
}

body.dark .복권칸.매칭 {
  background: linear-gradient(135deg, #4a3d18, #6d5523);
  box-shadow:
    0 0 0 2px var(--강조색),
    0 0 18px rgba(255, 200, 87, 0.6),
    inset 0 1px 2px rgba(255, 220, 130, 0.25);
}

/* 반응형 */
@media (max-width: 400px) {
  .복권그리드 {
    max-width: 100%;
    gap: 8px;
    padding: 10px;
  }
  .복권한자 {
    font-size: 1.9rem;
  }
  .복권의미 {
    font-size: 0.65rem;
  }
  .복권시작버튼 {
    min-width: 140px;
    font-size: 1rem;
  }
}

@media (max-width: 360px) {
  .복권그리드 {
    gap: 6px;
    padding: 8px;
  }
  .복권한자 {
    font-size: 1.6rem;
  }
  .복권의미 {
    font-size: 0.6rem;
  }
}
