/* ======================================================
   AI Wellness — Light Bright UI
   ====================================================== */

/* ── Variables ── */
:root {
  --bg:        #f0f4ff;
  --bg-card:   #ffffff;
  --bg-card2:  #eef1ff;
  --bg-hover:  #e3e8ff;
  --border:    rgba(20,0,100,0.09);
  --border-hi: rgba(20,0,100,0.18);
  --txt:       #0f172a;
  --txt-muted: #4b5675;
  --txt-dim:   #94a3b8;
  --accent:    #4f46e5;
  --accent-dim:rgba(79,70,229,0.12);
  /* five element colors */
  --wood:  #16a34a;
  --fire:  #dc2626;
  --earth: #b45309;
  --metal: #475569;
  --water: #1d4ed8;
  /* pillar top colors */
  --wood-glow:  rgba(22,163,74,0.15);
  --fire-glow:  rgba(220,38,38,0.15);
  --earth-glow: rgba(180,83,9,0.15);
  --metal-glow: rgba(71,85,105,0.15);
  --water-glow: rgba(29,78,216,0.15);

  --r-sm:  8px;
  --r-md:  14px;
  --r-lg:  20px;
  --r-xl:  28px;
  --hdr:   56px;
  --font:  'Noto Sans KR', -apple-system, 'Helvetica Neue', sans-serif;
  --serif: 'Noto Serif KR', 'Batang', 'UnBatang', serif;
  --ease:  cubic-bezier(0.4,0,0.2,1);
  --t:     0.22s;
}

/* ── Reset ── */
*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body {
  font-family: var(--font);
  background: var(--bg);
  color: var(--txt);
  min-height: 100vh;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
a { color:inherit; text-decoration:none; }
button { cursor:pointer; font-family:var(--font); border:none; background:none; }
select { font-family:var(--font); }
ul { list-style:none; }

/* ── Stars Canvas ── */
#starsBg {
  display: none; /* hidden on light theme */
}

/* ── Header ── */
.site-header {
  position: fixed;
  top:0; left:0; right:0;
  z-index: 100;
  height: var(--hdr);
  background: rgba(240,244,255,0.92);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--border);
  box-shadow: 0 1px 20px rgba(0,0,60,0.06);
}
.header-inner {
  max-width: 680px;
  margin: 0 auto;
  padding: 0 20px;
  height: 100%;
  display: flex;
  align-items: center;
}
.logo {
  display: flex;
  align-items: center;
  gap: 9px;
}
.logo-sym {
  font-size: 22px;
  background: linear-gradient(135deg, var(--earth), var(--accent));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.logo-text {
  font-family: var(--serif);
  font-size: 17px;
  font-weight: 700;
  letter-spacing: 0.02em;
  background: linear-gradient(135deg, #fff 40%, var(--accent) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ── Container ── */
.cw {
  max-width: 680px;
  margin: 0 auto;
  padding: 0 20px 60px;
}

/* ════════════════════════════
   FORM SECTION
════════════════════════════ */
#formSection {
  position: relative;
  z-index: 1;
  min-height: 100vh;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: calc(var(--hdr) + 48px) 20px 60px;
}
.form-wrap {
  width: 100%;
  max-width: 480px;
}
.form-eyebrow {
  font-size: 12px;
  font-weight: 600;
  color: var(--accent);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 12px;
  text-align: center;
}
.form-title {
  font-size: clamp(20px, 5vw, 26px);
  font-weight: 700;
  text-align: center;
  margin-bottom: 28px;
  letter-spacing: -0.01em;
  color: var(--txt);
}
.form-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

/* Field */
.field-group {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.field-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 14px;
  align-items: start;
}
.fg-gender { min-width: 130px; }
.field-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--txt-muted);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 5px;
}

/* Text Input */
.text-inp {
  width: 100%;
  background: var(--bg-card2);
  border: 1px solid var(--border-hi);
  border-radius: var(--r-md);
  padding: 12px 14px;
  color: var(--txt);
  font-size: 15px;
  font-family: var(--font);
  outline: none;
  transition: border-color var(--t) var(--ease), box-shadow var(--t) var(--ease);
}
.text-inp::placeholder { color: var(--txt-dim); }
.text-inp:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(61,220,132,0.12);
}

/* Toggle Buttons */
.toggle-wrap {
  display: flex;
  background: var(--bg-card2);
  border-radius: var(--r-md);
  padding: 3px;
  gap: 2px;
  border: 1px solid var(--border);
}
.tog-btn {
  flex: 1;
  padding: 9px 14px;
  border-radius: calc(var(--r-md) - 3px);
  font-size: 13px;
  font-weight: 500;
  color: var(--txt-muted);
  transition: all var(--t) var(--ease);
}
.tog-btn.active {
  background: var(--accent);
  color: #ffffff;
  font-weight: 700;
}

/* Custom Select */
.sel-row { display: grid; gap: 10px; }
.sel-row.three-col { grid-template-columns: 1fr 1fr 1fr; }
.sel-row.two-col   { grid-template-columns: 1fr 1fr; }
.sel-box { position: relative; }
.sel-box::after {
  content: '▾';
  position: absolute;
  right: 12px; top: 50%;
  transform: translateY(-50%);
  font-size: 11px;
  color: var(--txt-muted);
  pointer-events: none;
}
.sel-full { width: 100%; }
.csel {
  width: 100%;
  background: var(--bg-card2);
  border: 1px solid var(--border-hi);
  border-radius: var(--r-md);
  padding: 12px 32px 12px 14px;
  color: var(--txt);
  font-size: 14px;
  appearance: none;
  -webkit-appearance: none;
  cursor: pointer;
  outline: none;
  transition: border-color var(--t) var(--ease);
}
.csel:focus { border-color: var(--accent); }
.csel option { background: #fff; color: #0f172a; }

/* Sub Notes */
.sub-note {
  font-size: 12px;
  color: var(--txt-muted);
  line-height: 1.6;
  margin-top: 4px;
}
.sub-note strong { color: var(--accent); }

/* Tip Badge */
.tip-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 16px; height: 16px;
  border-radius: 50%;
  background: var(--bg-hover);
  border: 1px solid var(--border-hi);
  font-size: 10px;
  color: var(--txt-muted);
  cursor: pointer;
  font-weight: 700;
  transition: background var(--t);
  flex-shrink: 0;
}
.tip-badge:hover { background: var(--bg-card2); }

/* Analyze Button */
.analyze-btn {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 16px;
  border-radius: var(--r-lg);
  background: var(--accent);
  color: #ffffff;
  font-size: 15px;
  font-weight: 700;
  font-family: var(--font);
  transition: transform var(--t) var(--ease), box-shadow var(--t) var(--ease), opacity var(--t);
  box-shadow: 0 4px 24px rgba(61,220,132,0.3);
  margin-top: 4px;
}
.analyze-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 32px rgba(61,220,132,0.4);
}
.analyze-btn:active { transform: translateY(0); }
.analyze-btn:disabled { opacity: 0.55; cursor: not-allowed; transform: none; }

/* Tooltip */
.tooltip {
  position: fixed;
  z-index: 999;
  background: #1e293b;
  color: #f8fafc;
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: var(--r-sm);
  padding: 8px 12px;
  font-size: 12px;
  line-height: 1.6;
  max-width: 220px;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.15s;
}
.tooltip.show { opacity: 1; }

/* ════════════════════════════
   RESULT SECTION
════════════════════════════ */
#resultSection {
  position: relative;
  z-index: 1;
  padding-top: var(--hdr);
  animation: fadeUp 0.45s var(--ease) both;
}
@keyframes fadeUp {
  from { opacity:0; transform:translateY(20px); }
  to   { opacity:1; transform:translateY(0); }
}

/* Result Header */
.res-header {
  position: sticky;
  top: var(--hdr);
  z-index: 90;
  background: rgba(240,244,255,0.95);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 20px;
}
.back-btn {
  width: 40px; height: 40px;
  display: flex; align-items:center; justify-content:center;
  border-radius: 50%;
  background: var(--bg-card2);
  border: 1px solid var(--border-hi);
  color: var(--txt);
  transition: background var(--t);
}
.back-btn:hover { background: var(--bg-hover); }
.res-user {
  font-size: 14px;
  font-weight: 500;
  color: var(--txt-muted);
  text-align: center;
}
.res-user strong { color: var(--txt); }

/* Saju ToC */
.saju-toc {
  position: sticky;
  top: var(--hdr);
  z-index: 85;
  background: rgba(240,244,255,0.97);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 0 16px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  min-height: 44px;
}
.saju-toc::-webkit-scrollbar { display: none; }
.saju-toc-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.1em;
  color: var(--txt-dim);
  text-transform: uppercase;
  white-space: nowrap;
}
.saju-toc-links {
  display: flex;
  gap: 4px;
  align-items: center;
}
.saju-toc-item {
  padding: 6px 12px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 500;
  color: var(--txt-muted);
  white-space: nowrap;
  transition: all var(--t);
  text-decoration: none;
  border: 1px solid transparent;
}
.saju-toc-item:hover {
  color: var(--accent);
  background: var(--accent-dim);
}
.saju-toc-item.active {
  color: var(--accent);
  background: var(--accent-dim);
  border-color: rgba(79,70,229,0.2);
  font-weight: 600;
}

/* Tab Bar */
.tab-bar-wrap {
  position: sticky;
  top: calc(var(--hdr) + 44px);
  z-index: 80;
  background: rgba(240,244,255,0.95);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border);
  padding: 0 20px;
}
.tab-bar {
  max-width: 680px;
  margin: 0 auto;
  display: flex;
  gap: 0;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.tab-bar::-webkit-scrollbar { display:none; }
.tb {
  padding: 14px 16px;
  font-size: 13px;
  font-weight: 500;
  color: var(--txt-muted);
  white-space: nowrap;
  border-bottom: 2px solid transparent;
  transition: all var(--t) var(--ease);
}
.tb.active {
  color: var(--accent);
  border-bottom-color: var(--accent);
}

/* Tab Panes */
.tab-pane {
  display: none;
  animation: fadeUp 0.3s var(--ease) both;
}
.tab-pane.active { display: block; }

/* Section Head */
.sec-head {
  padding: 32px 0 20px;
}
.sec-title {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 6px;
  color: var(--txt);
}
.sec-desc {
  font-size: 13px;
  color: var(--txt-muted);
  line-height: 1.7;
}
.sub-section-title {
  font-size: 15px;
  font-weight: 700;
  margin-bottom: 14px;
  color: var(--txt);
}

/* ──────────────────────────
   PILLAR CARDS
────────────────────────── */
.pillars-scroller {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  margin: 0 -20px;
  padding: 0 20px;
}
.pillars-scroller::-webkit-scrollbar { display:none; }
.pillars-track {
  display: flex;
  gap: 12px;
  padding-bottom: 4px;
}

.pillar-card {
  flex: 0 0 calc(25% - 9px);
  min-width: 100px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  position: relative;
  transition: transform var(--t) var(--ease), box-shadow var(--t);
}
.pillar-card:hover {
  transform: translateY(-3px);
}
.pillar-label {
  width: 100%;
  padding: 8px 6px;
  font-size: 11px;
  font-weight: 600;
  color: var(--txt-muted);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  border-bottom: 1px solid var(--border);
  background: rgba(255,255,255,0.02);
}
.pillar-chars {
  padding: 16px 8px 12px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  flex: 1;
}
.pillar-stem {
  font-family: var(--serif);
  font-size: clamp(36px, 8vw, 52px);
  font-weight: 900;
  line-height: 1;
}
.pillar-branch {
  font-family: var(--serif);
  font-size: clamp(28px, 6vw, 40px);
  font-weight: 700;
  line-height: 1;
}
.pillar-kor {
  width: 100%;
  padding: 8px 6px;
  border-top: 1px solid var(--border);
  background: rgba(255,255,255,0.02);
  font-size: 12px;
  font-weight: 600;
  color: var(--txt-muted);
  letter-spacing: 0.08em;
}
/* glow top stripe per element */
.pillar-card[data-elem="0"] { box-shadow: 0 0 0 1px rgba(74,222,128,0.18), 0 -2px 0 0 var(--wood) inset; }
.pillar-card[data-elem="1"] { box-shadow: 0 0 0 1px rgba(239,68,68,0.18),  0 -2px 0 0 var(--fire) inset; }
.pillar-card[data-elem="2"] { box-shadow: 0 0 0 1px rgba(234,179,8,0.18),  0 -2px 0 0 var(--earth) inset; }
.pillar-card[data-elem="3"] { box-shadow: 0 0 0 1px rgba(156,163,175,0.18),0 -2px 0 0 var(--metal) inset; }
.pillar-card[data-elem="4"] { box-shadow: 0 0 0 1px rgba(107,114,128,0.18),0 -2px 0 0 var(--water) inset; }

/* Strength Row */
.strength-row {
  display: flex;
  gap: 10px;
  margin: 16px 0;
  flex-wrap: wrap;
}
.strength-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 14px;
  border-radius: 999px;
  border: 1px solid;
  font-size: 13px;
  font-weight: 600;
}

/* Overview Card */
.ov-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 22px 20px;
  margin-bottom: 16px;
}
.ov-headline {
  font-size: 16px;
  font-weight: 700;
  margin-bottom: 14px;
  color: var(--txt);
  line-height: 1.5;
}
.ov-bullets {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.ov-bullets li {
  font-size: 14px;
  color: var(--txt-muted);
  line-height: 1.7;
  padding-left: 16px;
  position: relative;
}
.ov-bullets li::before {
  content: '•';
  position: absolute;
  left: 0;
  color: var(--accent);
  font-weight: 700;
}

/* Yongsin/Gishin Row */
.yong-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 24px;
}
.yong-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 18px 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.yong-label {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--txt-muted);
}
.yong-elem {
  font-family: var(--serif);
  font-size: 32px;
  font-weight: 900;
  line-height: 1;
}
.yong-name {
  font-size: 13px;
  font-weight: 600;
}
.yong-desc {
  font-size: 12px;
  color: var(--txt-muted);
  line-height: 1.6;
}

/* Sipsung Grid */
.sipsung-wrap {
  margin-top: 8px;
}
.sipsung-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 10px;
}
.sipsung-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 14px 12px;
  text-align: center;
}
.ss-name {
  font-size: 12px;
  color: var(--txt-muted);
  margin-bottom: 6px;
  font-weight: 500;
}
.ss-char {
  font-family: var(--serif);
  font-size: 24px;
  font-weight: 700;
  margin-bottom: 4px;
}
.ss-meaning {
  font-size: 11px;
  color: var(--txt-muted);
}

/* ──────────────────────────
   OHAENG (오행 분포)
────────────────────────── */
.ohaeng-viz-row {
  display: flex;
  gap: 24px;
  align-items: center;
  margin-bottom: 24px;
  flex-wrap: wrap;
}
.radar-container {
  flex: 0 0 260px;
  max-width: 100%;
}
#radarSvg {
  width: 100%;
  height: auto;
}
.ohaeng-bar-col {
  flex: 1;
  min-width: 160px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.oh-bar-row {
  display: flex;
  align-items: center;
  gap: 10px;
}
.oh-bar-label {
  font-family: var(--serif);
  font-size: 18px;
  font-weight: 700;
  width: 24px;
  text-align: center;
  flex-shrink: 0;
}
.oh-bar-track {
  flex: 1;
  height: 8px;
  background: var(--bg-card2);
  border-radius: 4px;
  overflow: hidden;
}
.oh-bar-fill {
  height: 100%;
  border-radius: 4px;
  transition: width 1s var(--ease);
}
.oh-bar-count {
  font-size: 13px;
  font-weight: 700;
  width: 20px;
  text-align: right;
}

.ohaeng-desc-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 10px;
}
.oh-desc-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 14px 12px;
  text-align: center;
}
.oh-desc-sym {
  font-family: var(--serif);
  font-size: 26px;
  font-weight: 900;
  margin-bottom: 6px;
}
.oh-desc-cnt {
  font-size: 22px;
  font-weight: 800;
  line-height: 1;
  margin-bottom: 4px;
}
.oh-desc-name {
  font-size: 11px;
  color: var(--txt-muted);
}

/* ──────────────────────────
   FLOW CHART
────────────────────────── */
.flow-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  margin-bottom: 20px;
}
.flow-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px 12px;
  border-bottom: 1px solid var(--border);
}
.flow-card-label {
  font-size: 14px;
  font-weight: 700;
  color: var(--txt);
}
.flow-tabs {
  display: flex;
  gap: 2px;
  background: var(--bg-card2);
  border-radius: var(--r-sm);
  padding: 3px;
}
.ft {
  padding: 6px 12px;
  border-radius: calc(var(--r-sm) - 2px);
  font-size: 12px;
  font-weight: 500;
  color: var(--txt-muted);
  transition: all var(--t) var(--ease);
}
.ft.active {
  background: var(--accent);
  color: #0a0a0a;
  font-weight: 700;
}
.flow-chart-box {
  padding: 16px 16px 8px;
  overflow: hidden;
}
#flowSvg { width: 100%; height: auto; }
.flow-legend {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  padding: 10px 20px 16px;
  border-top: 1px solid var(--border);
}
.leg-item {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  color: var(--txt-muted);
}
.leg-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
}
.leg-star {
  color: var(--earth);
  font-size: 12px;
}
.leg-warn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 14px; height: 14px;
  border-radius: 50%;
  background: rgba(239,68,68,0.2);
  color: var(--fire);
  font-size: 10px;
  font-weight: 700;
}

/* Deep Tab Bar */
.deep-tab-bar {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}
.dtb {
  padding: 8px 16px;
  border-radius: var(--r-md);
  background: var(--bg-card);
  border: 1px solid var(--border);
  font-size: 12px;
  font-weight: 600;
  color: var(--txt-muted);
  transition: all var(--t) var(--ease);
}
.dtb.active {
  background: var(--accent-dim);
  border-color: var(--accent);
  color: var(--accent);
}

/* Deep Card */
.deep-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 22px 20px;
  margin-bottom: 24px;
}
.deep-card h4 {
  font-size: 15px;
  font-weight: 700;
  margin-bottom: 12px;
}
.deep-card p {
  font-size: 14px;
  color: var(--txt-muted);
  line-height: 1.8;
}
.deep-pillar-row {
  display: flex;
  gap: 8px;
  margin: 14px 0;
  flex-wrap: wrap;
}
.dp-pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid var(--border);
  font-size: 13px;
  font-weight: 600;
}
.dp-pill .dp-char {
  font-family: var(--serif);
  font-size: 16px;
}

/* Lucky Section */
.lucky-section { margin-top: 8px; }
.lucky-title {
  font-size: 15px;
  font-weight: 700;
  margin-bottom: 14px;
}
.lucky-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
  gap: 10px;
}
.lucky-item {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 16px 12px;
  text-align: center;
  transition: transform var(--t);
}
.lucky-item:hover { transform: translateY(-2px); }
.lucky-icon { font-size: 26px; margin-bottom: 8px; }
.lucky-label { font-size: 11px; color: var(--txt-muted); margin-bottom: 4px; }
.lucky-val {
  font-size: 15px;
  font-weight: 700;
  color: var(--earth);
}

/* ──────────────────────────
   PERSONALITY TAB
────────────────────────── */
.pers-hero {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: 28px 24px;
  display: flex;
  align-items: center;
  gap: 20px;
  margin-bottom: 16px;
}
.pers-char-big {
  font-family: var(--serif);
  font-size: 64px;
  font-weight: 900;
  line-height: 1;
  flex-shrink: 0;
}
.pers-info { flex: 1; }
.pers-title {
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 6px;
}
.pers-sub {
  font-size: 13px;
  color: var(--txt-muted);
  line-height: 1.7;
}
.pers-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 16px;
}
.pers-block {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 18px 16px;
}
.pers-block-title {
  font-size: 12px;
  font-weight: 600;
  color: var(--txt-muted);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: 10px;
}
.pers-block ul {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.pers-block li {
  font-size: 13px;
  color: var(--txt-muted);
  line-height: 1.5;
  padding-left: 14px;
  position: relative;
}
.pers-block li::before {
  content: '◆';
  position: absolute; left: 0;
  font-size: 8px;
  color: var(--accent);
  top: 4px;
}
.pers-career {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 18px 16px;
  margin-bottom: 12px;
}
.pers-career-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}
.career-tag {
  padding: 6px 12px;
  border-radius: 999px;
  background: var(--bg-card2);
  border: 1px solid var(--border-hi);
  font-size: 12px;
  font-weight: 500;
  color: var(--txt-muted);
}
.pers-compat {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 18px 16px;
}
.compat-chars {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 10px;
}
.compat-pill {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 7px 14px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--bg-card2);
}
.compat-ch {
  font-family: var(--serif);
  font-size: 16px;
  font-weight: 700;
}
.compat-nm {
  font-size: 11px;
  color: var(--txt-muted);
}

/* ── Detail Sections ── */
.detail-jump-nav {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 24px;
  padding: 16px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
}
.detail-jump-item {
  padding: 8px 16px;
  border-radius: 999px;
  background: var(--bg-card2);
  border: 1px solid var(--border);
  color: var(--txt-muted);
  font-size: 13px;
  font-weight: 500;
  text-decoration: none;
  transition: all var(--t);
}
.detail-jump-item:hover {
  color: var(--accent);
  border-color: var(--accent);
  background: var(--accent-dim);
}
.detail-section {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  margin-bottom: 16px;
  animation: fadeUp 0.4s var(--ease) both;
}
.detail-sec-head {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 20px;
  background: linear-gradient(135deg, var(--bg-card2) 0%, var(--bg-card) 100%);
  border-bottom: 1px solid var(--border);
}
.detail-sec-icon { font-size: 22px; }
.detail-sec-title {
  font-family: var(--serif);
  font-size: 17px;
  font-weight: 700;
  color: var(--txt);
}
.detail-sec-body {
  padding: 20px;
}
.detail-sec-body p {
  font-size: 14px;
  line-height: 1.9;
  color: var(--txt-muted);
  margin-bottom: 14px;
}
.detail-sec-body p:last-child { margin-bottom: 0; }
.detail-ilgan-badge {
  display: inline-flex;
  align-items: center;
  padding: 4px 12px;
  border-radius: 999px;
  border: 1px solid;
  font-size: 12px;
  font-weight: 700;
  margin-bottom: 14px;
}
.detail-sub-head {
  font-weight: 700;
  color: var(--txt) !important;
  margin-top: 16px !important;
  font-size: 13px !important;
}

/* ── Toast ── */
.toast {
  position: fixed;
  bottom: 28px;
  left: 50%;
  transform: translateX(-50%) translateY(60px);
  background: #1e293b;
  border: 1px solid rgba(255,255,255,0.1);
  color: #f8fafc;
  padding: 12px 22px;
  border-radius: 999px;
  font-size: 14px;
  font-weight: 500;
  z-index: 999;
  opacity: 0;
  transition: transform 0.35s var(--ease), opacity 0.35s;
  white-space: nowrap;
  pointer-events: none;
  backdrop-filter: blur(12px);
}
.toast.show {
  transform: translateX(-50%) translateY(0);
  opacity: 1;
}

/* ════════════════════════════
   AMBIENT ORBS
════════════════════════════ */
.orb {
  position: fixed;
  border-radius: 50%;
  filter: blur(80px);
  pointer-events: none;
  z-index: 0;
  animation: orbFloat 12s ease-in-out infinite;
}
.orb-1 {
  width: 600px; height: 600px;
  background: radial-gradient(circle, rgba(79,70,229,0.08) 0%, transparent 70%);
  top: -200px; left: -150px;
  animation-delay: 0s;
}
.orb-2 {
  width: 500px; height: 500px;
  background: radial-gradient(circle, rgba(124,58,237,0.06) 0%, transparent 70%);
  top: 20%; right: -120px;
  animation-delay: -4s;
}
.orb-3 {
  width: 450px; height: 450px;
  background: radial-gradient(circle, rgba(14,165,233,0.06) 0%, transparent 70%);
  bottom: 0; left: 25%;
  animation-delay: -8s;
}
@keyframes orbFloat {
  0%, 100% { transform: translateY(0) scale(1); }
  50%       { transform: translateY(-30px) scale(1.06); }
}

/* ════════════════════════════
   HUB PAGE
════════════════════════════ */
.hub-header-inner {
  max-width: 1000px;
  justify-content: space-between;
}
.hub-nav {
  display: flex;
  gap: 2px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.hub-nav::-webkit-scrollbar { display: none; }
.hn-link {
  padding: 7px 14px;
  font-size: 13px;
  font-weight: 500;
  color: var(--txt-muted);
  border-radius: var(--r-sm);
  white-space: nowrap;
  transition: background var(--t), color var(--t);
}
.hn-link:hover { background: var(--bg-card2); color: var(--txt); }
.hn-link.active { background: var(--accent-dim); color: var(--accent); }

.hub-main {
  position: relative;
  z-index: 1;
  max-width: 1000px;
  margin: 0 auto;
  padding: calc(var(--hdr) + 72px) 24px 100px;
}

/* Hero */
.hub-hero {
  text-align: center;
  margin-bottom: 72px;
}
.hub-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 16px;
  border-radius: 999px;
  background: rgba(61,220,132,0.08);
  border: 1px solid rgba(61,220,132,0.25);
  font-size: 11px;
  font-weight: 700;
  color: var(--accent);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: 28px;
}
.hub-title {
  font-family: var(--serif);
  font-size: clamp(38px, 9vw, 64px);
  font-weight: 900;
  line-height: 1.15;
  margin-bottom: 22px;
  background: linear-gradient(135deg, #ffffff 0%, #e2e8f0 30%, var(--accent) 60%, #a855f7 100%);
  background-size: 300% 300%;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: titleGradient 8s ease infinite;
}
@keyframes titleGradient {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}
.hub-sub {
  font-size: 16px;
  color: var(--txt-muted);
  line-height: 1.9;
  margin-bottom: 36px;
}
.hub-scroll-hint {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--txt-dim);
  letter-spacing: 0.04em;
  animation: scrollBounce 2.4s ease-in-out infinite;
}
@keyframes scrollBounce {
  0%, 100% { transform: translateY(0); opacity: 0.6; }
  50%       { transform: translateY(5px); opacity: 1; }
}

/* Services Grid */
.services-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 16px;
}
.svc-card {
  display: flex;
  align-items: flex-start;
  gap: 20px;
  background: rgba(20, 20, 22, 0.8);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: 26px 22px;
  text-decoration: none;
  color: var(--txt);
  transition: border-color 0.3s, transform 0.3s var(--ease), box-shadow 0.3s;
  position: relative;
  overflow: hidden;
  backdrop-filter: blur(12px);
}
/* Colored top stripe */
.svc-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--svc-c, #3ddc84), transparent);
  opacity: 0;
  transition: opacity 0.3s;
}
/* Shimmer overlay */
.svc-shimmer {
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(ellipse at 50% 0%, var(--svc-glow, rgba(61,220,132,0.12)) 0%, transparent 60%);
  opacity: 0;
  transition: opacity 0.4s;
  pointer-events: none;
}
a.svc-card:hover {
  border-color: var(--svc-c, var(--border-hi));
  transform: translateY(-5px);
  box-shadow: 0 20px 60px rgba(0,0,0,0.4), 0 0 0 1px var(--svc-c, transparent);
}
a.svc-card:hover::before { opacity: 1; }
a.svc-card:hover .svc-shimmer { opacity: 1; }
a.svc-card:hover .svc-arrow { transform: translateX(4px); }

.svc-card.svc-soon { cursor: default; opacity: 0.45; }
.svc-soon-badge {
  position: absolute;
  top: 16px;
  right: 16px;
  font-size: 10px;
  font-weight: 700;
  padding: 3px 9px;
  border-radius: 999px;
  background: var(--bg-card2);
  border: 1px solid var(--border-hi);
  color: var(--txt-muted);
  letter-spacing: 0.05em;
}
.svc-icon-wrap {
  width: 56px;
  height: 56px;
  flex-shrink: 0;
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  transition: transform 0.3s var(--ease);
}
a.svc-card:hover .svc-icon-wrap { transform: scale(1.1) rotate(-3deg); }
.svc-body { flex: 1; min-width: 0; }
.svc-name {
  font-size: 17px;
  font-weight: 700;
  margin-bottom: 7px;
  letter-spacing: -0.01em;
}
.svc-desc {
  font-size: 13px;
  color: var(--txt-muted);
  line-height: 1.7;
  margin-bottom: 14px;
}
.svc-cta-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.svc-cta {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.02em;
}
.svc-arrow {
  font-size: 16px;
  font-weight: 700;
  transition: transform 0.25s var(--ease);
}

/* Inner page back nav */
.page-back-nav {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 600;
  color: var(--txt-muted);
  text-decoration: none;
  padding: 6px 12px;
  border-radius: var(--r-md);
  border: 1px solid var(--border);
  background: var(--bg-card);
  transition: background var(--t), color var(--t), border-color var(--t);
}
.page-back-nav:hover { background: var(--bg-card2); color: var(--txt); border-color: var(--border-hi); }
.page-back-nav svg { flex-shrink: 0; }
.page-title-badge {
  font-size: 14px;
  font-weight: 700;
  color: var(--txt);
  padding: 6px 14px;
  border-radius: var(--r-md);
  background: var(--bg-card2);
  border: 1px solid var(--border-hi);
  letter-spacing: 0.01em;
}

/* ════════════════════════════
   TAROT PAGE
════════════════════════════ */
.tarot-page { --tarot-accent: #a855f7; }
.tarot-page body { background: var(--bg); }

.tarot-intro {
  text-align: center;
  padding: calc(var(--hdr) + 48px) 20px 0;
}
.tarot-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 5px 16px;
  border-radius: 999px;
  background: rgba(168,85,247,0.1);
  border: 1px solid rgba(168,85,247,0.25);
  font-size: 11px;
  font-weight: 700;
  color: #c084fc;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 20px;
}
.tarot-title {
  font-family: var(--serif);
  font-size: clamp(26px, 6vw, 36px);
  font-weight: 900;
  margin-bottom: 8px;
  background: linear-gradient(135deg, #7c3aed 20%, #c084fc 80%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Spread selector */
.spread-selector {
  display: flex;
  gap: 8px;
  justify-content: center;
  flex-wrap: wrap;
  margin: 24px 0;
}
.spread-btn {
  padding: 10px 18px;
  border-radius: var(--r-md);
  background: var(--bg-card);
  border: 1px solid var(--border);
  font-size: 13px;
  font-weight: 600;
  color: var(--txt-muted);
  transition: all var(--t);
}
.spread-btn.active {
  background: rgba(168,85,247,0.15);
  border-color: #a855f7;
  color: #c084fc;
}

/* Question area */
.tarot-question-wrap {
  max-width: 480px;
  margin: 0 auto 28px;
  padding: 0 20px;
}
.tarot-question-input {
  width: 100%;
  background: var(--bg-card);
  border: 1px solid var(--border-hi);
  border-radius: var(--r-md);
  padding: 13px 16px;
  color: var(--txt);
  font-size: 14px;
  font-family: var(--font);
  outline: none;
  text-align: center;
  transition: border-color var(--t), box-shadow var(--t);
}
.tarot-question-input::placeholder { color: var(--txt-dim); }
.tarot-question-input:focus {
  border-color: #a855f7;
  box-shadow: 0 0 0 3px rgba(168,85,247,0.12);
}
.tarot-draw-btn {
  width: 100%;
  padding: 15px;
  border-radius: var(--r-lg);
  background: #a855f7;
  color: #fff;
  font-size: 15px;
  font-weight: 700;
  font-family: var(--font);
  margin-top: 12px;
  transition: transform var(--t), box-shadow var(--t), opacity var(--t);
  box-shadow: 0 4px 24px rgba(168,85,247,0.3);
}
.tarot-draw-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 32px rgba(168,85,247,0.4);
}
.tarot-draw-btn:disabled { opacity: 0.5; cursor: not-allowed; transform: none; }

/* Deck shuffle area */
.deck-area {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 200px;
  padding: 20px;
}
.deck-stack {
  position: relative;
  width: 120px;
  height: 200px;
  cursor: pointer;
  transition: transform var(--t);
}
.deck-stack:hover { transform: scale(1.04); }
.deck-card-layer {
  position: absolute;
  width: 120px;
  height: 200px;
  border-radius: 12px;
  background: linear-gradient(135deg, #1a0533 0%, #2d1066 50%, #1a0533 100%);
  border: 1px solid rgba(168,85,247,0.3);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 32px;
}
.deck-card-layer:nth-child(1) { transform: rotate(-4deg); top: -4px; left: -4px; }
.deck-card-layer:nth-child(2) { transform: rotate(-2deg); top: -2px; left: -2px; }
.deck-card-layer:nth-child(3) { transform: rotate(0deg); }

/* Card spread */
.card-spread {
  display: flex;
  gap: 16px;
  justify-content: center;
  align-items: flex-start;
  flex-wrap: wrap;
  padding: 20px 20px 32px;
}
.tarot-slot {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}
.tarot-slot-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--txt-muted);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

/* Card flip */
.tarot-card-wrap {
  perspective: 1000px;
  width: 130px;
  height: 220px;
  cursor: pointer;
}
.tarot-card-inner {
  position: relative;
  width: 100%;
  height: 100%;
  transform-style: preserve-3d;
  transition: transform 0.75s cubic-bezier(0.4, 0, 0.2, 1);
}
.tarot-card-wrap.revealed .tarot-card-inner {
  transform: rotateY(180deg);
}
.tarot-card-face {
  position: absolute;
  inset: 0;
  border-radius: 12px;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.tarot-card-back-face {
  background: linear-gradient(135deg, #1a0533 0%, #2d1066 50%, #1a0533 100%);
  border: 1px solid rgba(168,85,247,0.3);
  font-size: 40px;
}
.tarot-back-pattern {
  position: absolute;
  inset: 6px;
  border: 1px solid rgba(168,85,247,0.2);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 44px;
  opacity: 0.7;
}
.tarot-card-front-face {
  transform: rotateY(180deg);
  flex-direction: column;
  padding: 10px;
  gap: 6px;
}
.tarot-card-num {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  opacity: 0.7;
  align-self: flex-start;
}
.tarot-card-sym {
  font-size: 42px;
  line-height: 1;
  flex: 1;
  display: flex;
  align-items: center;
}
.tarot-card-name-kr {
  font-family: var(--serif);
  font-size: 14px;
  font-weight: 700;
}
.tarot-card-name-en {
  font-size: 9px;
  opacity: 0.6;
  letter-spacing: 0.03em;
}
.tarot-reversed-label {
  font-size: 9px;
  color: #ef4444;
  font-weight: 700;
  letter-spacing: 0.04em;
}

/* Card meaning panel */
.card-meaning-panel {
  max-width: 560px;
  margin: 0 auto;
  padding: 0 20px 60px;
}
.card-meaning-item {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 20px;
  margin-bottom: 12px;
  animation: fadeUp 0.4s var(--ease) both;
}
.cmi-header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
}
.cmi-sym { font-size: 32px; line-height: 1; }
.cmi-names { flex: 1; }
.cmi-name-kr { font-family: var(--serif); font-size: 16px; font-weight: 700; }
.cmi-name-en { font-size: 11px; color: var(--txt-muted); margin-top: 2px; }
.cmi-position {
  font-size: 11px;
  font-weight: 600;
  color: var(--txt-muted);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 999px;
  background: var(--bg-card2);
  border: 1px solid var(--border);
}
.cmi-keyword-row {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: 10px;
}
.cmi-keyword {
  font-size: 11px;
  font-weight: 500;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(168,85,247,0.12);
  border: 1px solid rgba(168,85,247,0.3);
  color: #c084fc;
}
.cmi-keyword.reversed-kw {
  background: rgba(239,68,68,0.1);
  border-color: rgba(239,68,68,0.3);
  color: #f87171;
}
.cmi-detail { font-size: 13px; color: var(--txt-muted); line-height: 1.8; }
.cmi-context {
  font-size: 12px;
  color: var(--txt-dim);
  font-style: italic;
  margin: -4px 0 10px;
  padding: 6px 10px;
  border-left: 2px solid rgba(168,85,247,0.35);
  background: rgba(168,85,247,0.05);
  border-radius: 0 4px 4px 0;
}

/* Card spread grids */
.card-spread-grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 16px;
  padding: 20px 16px 32px;
}
.spread-7 .tarot-card-wrap,
.spread-10 .tarot-card-wrap { width: 88px; height: 148px; }
.spread-7 .tarot-card-sym,
.spread-10 .tarot-card-sym { font-size: 28px; }
.spread-7 .tarot-card-name-kr,
.spread-10 .tarot-card-name-kr { font-size: 11px; }

/* Overall reading synthesis */
.overall-reading {
  max-width: 560px;
  margin: 0 auto 16px;
  padding: 24px 20px;
  background: linear-gradient(135deg, rgba(168,85,247,0.07) 0%, rgba(99,102,241,0.07) 100%);
  border: 1px solid rgba(168,85,247,0.25);
  border-radius: var(--r-lg);
}
.overall-title {
  font-family: var(--serif);
  font-size: 16px;
  font-weight: 700;
  color: #a855f7;
  margin-bottom: 14px;
}
.overall-text {
  font-size: 14px;
  line-height: 1.9;
  color: var(--txt-muted);
}
.overall-text strong { color: var(--txt); }

.tarot-again-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: calc(100% - 40px);
  margin: 0 20px 60px;
  padding: 14px;
  border-radius: var(--r-lg);
  background: var(--bg-card);
  border: 1px solid rgba(168,85,247,0.3);
  color: #c084fc;
  font-size: 14px;
  font-weight: 600;
  font-family: var(--font);
  transition: background var(--t), border-color var(--t);
}
.tarot-again-btn:hover { background: rgba(168,85,247,0.1); border-color: #a855f7; }

/* ════════════════════════════
   MEDITATION PAGE
════════════════════════════ */
.med-page { --med-accent: #60a5fa; }

.med-wrap {
  max-width: 540px;
  margin: 0 auto;
  padding: calc(var(--hdr) + 48px) 20px 80px;
  position: relative;
  z-index: 1;
}
.med-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 5px 16px;
  border-radius: 999px;
  background: rgba(96,165,250,0.1);
  border: 1px solid rgba(96,165,250,0.25);
  font-size: 11px;
  font-weight: 700;
  color: #93c5fd;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 16px;
  display: block;
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
}
.med-title {
  font-family: var(--serif);
  font-size: clamp(24px, 5vw, 32px);
  font-weight: 900;
  text-align: center;
  margin-bottom: 32px;
  background: linear-gradient(135deg, #1e40af 20%, #60a5fa 80%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Session type selector */
.med-type-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 20px;
}
.med-type-btn {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 14px 12px;
  text-align: center;
  transition: all var(--t);
  cursor: pointer;
}
.med-type-btn.active {
  border-color: var(--med-accent);
  background: rgba(96,165,250,0.1);
}
.med-type-icon { font-size: 24px; margin-bottom: 6px; }
.med-type-name { font-size: 13px; font-weight: 600; color: var(--txt); margin-bottom: 2px; }
.med-type-sub { font-size: 11px; color: var(--txt-muted); }

/* Duration selector */
.med-duration-row {
  display: flex;
  gap: 8px;
  margin-bottom: 24px;
  flex-wrap: wrap;
}
.med-dur-btn {
  flex: 1;
  min-width: 60px;
  padding: 9px 8px;
  border-radius: var(--r-md);
  background: var(--bg-card);
  border: 1px solid var(--border);
  font-size: 13px;
  font-weight: 600;
  color: var(--txt-muted);
  text-align: center;
  transition: all var(--t);
}
.med-dur-btn.active {
  border-color: var(--med-accent);
  color: var(--med-accent);
  background: rgba(96,165,250,0.1);
}

/* Sound theme selector */
.med-sound-section {
  margin-bottom: 24px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 16px;
}
.med-sound-label {
  font-size: 12px;
  font-weight: 700;
  color: var(--txt-muted);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 12px;
}
.med-sound-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 8px;
  margin-bottom: 14px;
}
@media (max-width: 400px) {
  .med-sound-grid { grid-template-columns: repeat(4, 1fr); }
}
.med-sound-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 10px 4px;
  border-radius: var(--r-md);
  border: 1px solid var(--border);
  background: var(--bg-card2);
  cursor: pointer;
  transition: all var(--t);
}
.med-sound-btn:hover {
  border-color: var(--med-accent);
  background: rgba(96,165,250,0.08);
}
.med-sound-btn.active {
  border-color: var(--med-accent);
  background: rgba(96,165,250,0.15);
  box-shadow: 0 0 12px rgba(96,165,250,0.25);
}
.med-sound-icon { font-size: 20px; line-height: 1; }
.med-sound-name { font-size: 10px; font-weight: 600; color: var(--txt-muted); text-align: center; }
.med-sound-btn.active .med-sound-name { color: var(--med-accent); }

.med-volume-row {
  display: flex;
  align-items: center;
  gap: 10px;
}
.med-vol-icon { font-size: 16px; }
.med-volume-slider {
  flex: 1;
  height: 4px;
  -webkit-appearance: none;
  appearance: none;
  border-radius: 999px;
  background: linear-gradient(to right, var(--med-accent) 0%, var(--med-accent) 50%, var(--border) 50%);
  outline: none;
  cursor: pointer;
}
.med-volume-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 18px; height: 18px;
  border-radius: 50%;
  background: var(--med-accent);
  box-shadow: 0 0 8px rgba(96,165,250,0.5);
  cursor: pointer;
}
.med-volume-slider::-moz-range-thumb {
  width: 18px; height: 18px;
  border-radius: 50%;
  background: var(--med-accent);
  border: none;
  cursor: pointer;
}

/* Timer area */
.med-timer-area {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 20px 0 24px;
}
.med-ring-wrap {
  position: relative;
  width: 220px;
  height: 220px;
  margin-bottom: 20px;
}
.med-ring-svg {
  transform: rotate(-90deg);
  width: 100%;
  height: 100%;
}
.med-ring-bg { fill: none; stroke: var(--bg-card2); stroke-width: 6; }
.med-ring-fill {
  fill: none;
  stroke: url(#ringGrad);
  stroke-width: 6;
  stroke-linecap: round;
  transition: stroke-dashoffset 1s linear;
  filter: drop-shadow(0 0 8px rgba(96,165,250,0.5));
}
.med-ring-center {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
}
.med-time-display {
  font-size: 40px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.02em;
  line-height: 1;
}
.med-phase-label {
  font-size: 13px;
  color: var(--med-accent);
  font-weight: 600;
  transition: opacity 0.3s;
}

/* Breathing animation */
.med-breath-wrap {
  position: relative;
  width: 80px;
  height: 80px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 12px;
}
.med-breath-ring {
  position: absolute;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  border: 2px solid rgba(96,165,250,0.3);
  animation: none;
}
.med-breath-core {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--med-accent);
  opacity: 0.8;
  animation: none;
}
@keyframes breathIn {
  from { transform: scale(1); opacity: 0.5; }
  to   { transform: scale(1.6); opacity: 1; }
}
@keyframes breathOut {
  from { transform: scale(1.6); opacity: 1; }
  to   { transform: scale(1); opacity: 0.5; }
}
@keyframes breathHold {
  from, to { transform: scale(1.6); opacity: 1; }
}
@keyframes breathHoldSmall {
  from, to { transform: scale(1); opacity: 0.5; }
}

.med-breath-text {
  font-size: 14px;
  color: var(--txt-muted);
  text-align: center;
  min-height: 20px;
  margin-bottom: 20px;
}

/* Timer controls */
.med-ctrl-row {
  display: flex;
  gap: 12px;
  align-items: center;
}
.med-start-btn {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: linear-gradient(135deg, #60a5fa, #818cf8);
  color: #fff;
  font-size: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform var(--t), box-shadow var(--t);
  box-shadow: 0 4px 24px rgba(96,165,250,0.4), 0 0 0 0 rgba(96,165,250,0.3);
}
.med-start-btn:hover { transform: scale(1.08); box-shadow: 0 8px 32px rgba(96,165,250,0.5); }
.med-start-btn.running {
  animation: pulseRing 2s ease infinite;
}
@keyframes pulseRing {
  0%   { box-shadow: 0 4px 24px rgba(96,165,250,0.4), 0 0 0 0 rgba(96,165,250,0.3); }
  70%  { box-shadow: 0 4px 24px rgba(96,165,250,0.4), 0 0 0 16px rgba(96,165,250,0); }
  100% { box-shadow: 0 4px 24px rgba(96,165,250,0.4), 0 0 0 0 rgba(96,165,250,0); }
}
.med-reset-btn {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--bg-card);
  border: 1px solid var(--border-hi);
  color: var(--txt-muted);
  font-size: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background var(--t), color var(--t);
}
.med-reset-btn:hover { background: var(--bg-hover); color: var(--txt); }

/* Med stats */
.med-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 24px;
}
.med-stat-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 14px;
  text-align: center;
}
.med-stat-val {
  font-size: 24px;
  font-weight: 800;
  color: var(--med-accent);
  line-height: 1;
  margin-bottom: 4px;
}
.med-stat-label { font-size: 11px; color: var(--txt-muted); }

/* ════════════════════════════
   YOGA PAGE
════════════════════════════ */
.yoga-page { --yoga-accent: #fb923c; }

.yoga-header-section {
  text-align: center;
  padding: calc(var(--hdr) + 48px) 20px 0;
}
.yoga-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 5px 16px;
  border-radius: 999px;
  background: rgba(251,146,60,0.1);
  border: 1px solid rgba(251,146,60,0.25);
  font-size: 11px;
  font-weight: 700;
  color: #fdba74;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 16px;
}
.yoga-title {
  font-family: var(--serif);
  font-size: clamp(26px, 6vw, 36px);
  font-weight: 900;
  margin-bottom: 10px;
  background: linear-gradient(135deg, #fff 30%, #fdba74 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.yoga-sub {
  font-size: 14px;
  color: var(--txt-muted);
  line-height: 1.8;
  margin-bottom: 28px;
}

/* Filters */
.yoga-filter-section {
  max-width: 680px;
  margin: 0 auto;
  padding: 0 20px 20px;
}
.yoga-filter-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--txt-muted);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: 8px;
}
.yoga-filter-row {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: 14px;
}
.yoga-filter-btn {
  padding: 7px 14px;
  border-radius: 999px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  font-size: 12px;
  font-weight: 500;
  color: var(--txt-muted);
  transition: all var(--t);
}
.yoga-filter-btn.active {
  border-color: var(--yoga-accent);
  color: var(--yoga-accent);
  background: rgba(251,146,60,0.1);
}

/* Yoga grid */
.yoga-grid-wrap {
  max-width: 960px;
  margin: 0 auto;
  padding: 0 20px 80px;
}
.yoga-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 14px;
}
.yoga-pose-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  cursor: pointer;
  transition: border-color var(--t), transform var(--t), box-shadow var(--t);
}
.yoga-pose-card:hover {
  border-color: var(--border-hi);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.25);
}
.yoga-pose-card.expanded {
  border-color: rgba(251,146,60,0.4);
}
.yoga-card-top {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 18px 16px;
}
.yoga-pose-icon {
  width: 52px;
  height: 52px;
  border-radius: var(--r-sm);
  background: rgba(251,146,60,0.1);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 26px;
  flex-shrink: 0;
}
.yoga-pose-info { flex: 1; min-width: 0; }
.yoga-pose-name { font-size: 15px; font-weight: 700; margin-bottom: 2px; }
.yoga-pose-sanskrit { font-size: 11px; color: var(--txt-muted); margin-bottom: 6px; }
.yoga-level-badge {
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 999px;
  letter-spacing: 0.03em;
}
.level-beginner  { background: rgba(74,222,128,0.15); color: #4ade80; border: 1px solid rgba(74,222,128,0.3); }
.level-middle    { background: rgba(234,179,8,0.15);  color: #eab308; border: 1px solid rgba(234,179,8,0.3); }
.level-advanced  { background: rgba(239,68,68,0.15);  color: #ef4444; border: 1px solid rgba(239,68,68,0.3); }

.yoga-benefit-tags {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
  padding: 0 16px 16px;
}
.yoga-benefit-tag {
  font-size: 10px;
  padding: 3px 8px;
  border-radius: 999px;
  background: var(--bg-card2);
  border: 1px solid var(--border);
  color: var(--txt-muted);
}

/* Expanded pose detail */
.yoga-expand-body {
  display: none;
  padding: 0 16px 20px;
  border-top: 1px solid var(--border);
  animation: fadeUp 0.25s var(--ease) both;
}
.yoga-pose-card.expanded .yoga-expand-body { display: block; }
.yoga-expand-desc {
  font-size: 13px;
  color: var(--txt-muted);
  line-height: 1.75;
  margin: 14px 0 12px;
}
.yoga-steps-title {
  font-size: 12px;
  font-weight: 700;
  color: var(--txt);
  letter-spacing: 0.04em;
  margin-bottom: 10px;
}
.yoga-steps {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.yoga-step {
  display: flex;
  gap: 10px;
  font-size: 13px;
  color: var(--txt-muted);
  line-height: 1.6;
}
.yoga-step-num {
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: rgba(251,146,60,0.15);
  border: 1px solid rgba(251,146,60,0.3);
  color: var(--yoga-accent);
  font-size: 11px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
}
.yoga-duration-info {
  display: flex;
  gap: 16px;
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px solid var(--border);
}
.yoga-dur-item { font-size: 12px; color: var(--txt-muted); }
.yoga-dur-val { font-weight: 700; color: var(--yoga-accent); }

.yoga-video-wrap {
  margin-top: 16px;
}
.yoga-video-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 11px 16px;
  border-radius: var(--r-md);
  background: rgba(251,146,60,0.1);
  border: 1px solid rgba(251,146,60,0.35);
  color: var(--yoga-accent);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: all var(--t);
}
.yoga-video-toggle:hover {
  background: rgba(251,146,60,0.2);
  border-color: var(--yoga-accent);
}
.yoga-video-box {
  margin-top: 10px;
  border-radius: var(--r-md);
  overflow: hidden;
  background: #000;
}
.yoga-video-player {
  width: 100%;
  display: block;
  max-height: 280px;
  border-radius: var(--r-md);
}
.yoga-no-video {
  color: var(--txt-muted);
  font-size: 13px;
  text-align: center;
  padding: 20px;
  margin: 0;
}

/* ── Responsive ── */

/* Hub grid: 2-col on medium, 1-col on small */
@media (max-width: 680px) {
  .services-grid {
    grid-template-columns: 1fr;
  }
  .hub-main {
    padding: calc(var(--hdr) + 48px) 16px 80px;
  }
  .hub-title {
    font-size: clamp(32px, 9vw, 48px);
  }
  .svc-card {
    padding: 20px 16px;
  }
}
@media (min-width: 481px) and (max-width: 680px) {
  .services-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* Tablet (521px – 768px) */
@media (min-width: 521px) and (max-width: 768px) {
  .cw {
    padding: 0 24px 60px;
  }
  .form-wrap {
    max-width: 100%;
  }
  .ohaeng-viz-row {
    flex-direction: row;
    align-items: flex-start;
  }
  .radar-container {
    flex: 0 0 220px;
  }
  .sipsung-grid {
    grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
  }
  .lucky-grid {
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  }
  .pers-hero {
    padding: 24px 20px;
  }
  .pers-char-big {
    font-size: 54px;
  }
}

/* Mobile ≤ 520px */
@media (max-width: 520px) {
  .pillar-card { flex: 0 0 calc(25% - 9px); min-width: 80px; }
  .pillar-stem { font-size: 32px; }
  .pillar-branch { font-size: 24px; }
  .ohaeng-viz-row { flex-direction: column; }
  .radar-container { flex: none; width: 100%; max-width: 280px; margin: 0 auto; }
  .yong-row { grid-template-columns: 1fr; }
  .pers-grid { grid-template-columns: 1fr; }
  .pers-hero { flex-direction: column; text-align: center; }

  /* Flow card: stack label + tabs on small screens */
  .flow-card-top {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
    padding: 14px 16px 10px;
  }
  .flow-tabs {
    width: 100%;
  }
  .ft {
    flex: 1;
    text-align: center;
    padding: 7px 8px;
  }

  /* Deep tab bar: 2-column grid */
  .deep-tab-bar {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }
  .dtb {
    text-align: center;
  }

  /* Larger touch targets */
  .tog-btn {
    padding: 11px 14px;
    min-height: 44px;
  }
  .tb {
    padding: 14px 12px;
    min-height: 44px;
  }

  /* Lucky grid 2-column */
  .lucky-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  /* Ohaeng desc 3-column */
  .ohaeng-desc-grid {
    grid-template-columns: repeat(auto-fill, minmax(90px, 1fr));
  }
}

/* Very small screens ≤ 360px */
@media (max-width: 360px) {
  .form-card { padding: 20px 16px; }
  .sel-row.three-col { grid-template-columns: 1fr 1fr; }
  .flow-tabs {
    flex-wrap: wrap;
  }
  .ft {
    min-width: calc(50% - 2px);
  }
  .pers-char-big { font-size: 48px; }
  .lucky-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* ── Reduced Motion ── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}

/* ── Safe Area ── */
@supports (padding: max(0px)) {
  .toast { bottom: max(28px, calc(env(safe-area-inset-bottom) + 16px)); }
}
