/* =========================================================
   三藏閣 — 坐禪 · 명상
   ---------------------------------------------------------
   한지·잉크 톤을 그대로 잇는 명상 화면.
   타이머가 화면 중심. 시간 프리셋·음원 선택은 절제된 칩으로.
   모바일 우선. 데스크톱에서도 동일 레이아웃이 자연히 펼쳐진다.
   ========================================================= */

.meditate {
  flex: 1;
  position: relative;
  background:
    radial-gradient(circle at 50% 30%, rgba(160, 130, 80, 0.06) 0%, transparent 55%),
    radial-gradient(circle at 50% 100%, rgba(120, 90, 50, 0.04) 0%, transparent 60%),
    var(--paper);
  display: flex;
  flex-direction: column;
  min-height: calc(100vh - 64px);
}

.meditate__inner {
  max-width: 720px;
  width: 100%;
  margin: 0 auto;
  padding: var(--s7) var(--s5) var(--s9);
  display: flex;
  flex-direction: column;
  align-items: center;
  flex: 1;
}

/* ---------- 머리말 ---------- */
.meditate__head {
  text-align: center;
  margin-bottom: var(--s7);
}
.meditate__head-label {
  font-family: var(--font-en);
  font-size: 10.5px;
  letter-spacing: 0.4em;
  color: var(--ink-mute);
  text-transform: uppercase;
  margin-bottom: var(--s3);
}
.meditate__head-sub {
  font-size: 13px;
  letter-spacing: 0.04em;
  color: var(--ink-mute);
}

/* ============================================================
   중앙 타이머 다이얼
   - 큰 원 안에 시간 표시.
   - 진행 중에는 외곽 링이 시계 반대 방향으로 비워진다.
   ============================================================ */
.dial {
  position: relative;
  width: 320px;
  height: 320px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--s7);
}
.dial__ring {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  transform: rotate(-90deg);
  overflow: visible;
}
.dial__ring-track {
  fill: none;
  stroke: var(--rule-soft);
  stroke-width: 1;
}
.dial__ring-progress {
  fill: none;
  stroke: var(--ink);
  stroke-width: 1.5;
  stroke-linecap: round;
  transition: stroke-dashoffset 950ms linear;
}

/* 한지 카드 (다이얼 안쪽) — 옅은 종이감 */
.dial__face {
  position: relative;
  width: calc(100% - 24px);
  height: calc(100% - 24px);
  border-radius: 50%;
  overflow: hidden;
  background:
    radial-gradient(circle at 30% 30%, rgba(255, 248, 226, 0.7) 0%, transparent 55%),
    radial-gradient(circle at 70% 70%, rgba(240, 226, 195, 0.5) 0%, transparent 60%),
    var(--paper-soft);
  border: 0.5px solid var(--rule-soft);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.6),
    inset 0 0 80px rgba(140, 110, 70, 0.06),
    0 12px 30px -16px rgba(60, 40, 20, 0.18);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
}

/* 시간 디스플레이 */
.dial__time {
  font-family: var(--font-en);
  font-variant-numeric: tabular-nums;
  font-weight: 200;
  font-size: 64px;
  letter-spacing: 0.02em;
  color: var(--ink);
  line-height: 1;
  z-index: 1;
}
.dial__time-sec {
  color: var(--ink-mute);
  font-weight: 300;
}
.dial__time-sub {
  font-family: var(--font-en);
  font-size: 10.5px;
  letter-spacing: 0.32em;
  color: var(--ink-mute);
  text-transform: uppercase;
  margin-top: 6px;
  z-index: 1;
}

/* 진행 중 — 호흡 점 (들숨/날숨 시각화) */
.dial__breath {
  position: absolute;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--ink);
  bottom: 28px;
  opacity: 0.55;
  animation: breath 8s ease-in-out infinite;
}
@keyframes breath {
  0%, 100% { transform: scale(0.7); opacity: 0.30; }
  50%      { transform: scale(1.25); opacity: 0.65; }
}
@media (prefers-reduced-motion: reduce) {
  .dial__breath { animation: none; opacity: 0.45; }
}

/* 완료 표시 */
.dial--done .dial__face {
  border-color: var(--ink-soft);
  box-shadow:
    inset 0 0 0 1px var(--ink-soft),
    inset 0 1px 0 rgba(255, 255, 255, 0.6),
    inset 0 0 80px rgba(140, 110, 70, 0.06);
}
.dial__done-zh {
  font-family: var(--font-kr);
  font-size: 42px;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--ink);
  line-height: 1;
  z-index: 1;
}
.dial__done-sub {
  font-size: 13px;
  letter-spacing: 0.04em;
  color: var(--ink-soft);
  margin-top: 8px;
  z-index: 1;
}

/* ============================================================
   섹션 라벨 (시간 / 음원)
   ============================================================ */
.meditate__section {
  width: 100%;
  margin-bottom: var(--s5);
}
.meditate__section-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: var(--s4);
  padding-bottom: var(--s2);
  border-bottom: 1px solid var(--rule-faint);
}
.meditate__section-label {
  font-family: var(--font-en);
  font-size: 10.5px;
  letter-spacing: 0.4em;
  color: var(--ink-mute);
  text-transform: uppercase;
}
.meditate__section-zh {
  font-family: var(--font-kr);
  font-size: 13px;
  letter-spacing: 0.04em;
  color: var(--ink-soft);
}

/* ============================================================
   시간 롤러 픽커 — iOS-스타일 스크롤 스냅
   ------------------------------------------------------------
   가운데 한 칸이 활성, 위·아래는 옅게 흐려져 한지 위 잉크가
   먹리에 스며들 듯 사라진다.
   ============================================================ */
.roller {
  position: relative;
  width: 100%;
  height: 220px; /* 5 × ITEM_H */
  overflow: hidden;
  outline: none;
}
.roller:focus-visible {
  outline: 1px solid var(--rule);
  outline-offset: 4px;
  border-radius: 4px;
}
.roller__viewport {
  height: 100%;
  width: 100%;
  overflow-y: scroll;
  overflow-x: hidden;
  scroll-snap-type: y mandatory;
  scrollbar-width: none;
  -ms-overflow-style: none;
  -webkit-overflow-scrolling: touch;
  position: relative;
  z-index: 1;
}
.roller__viewport::-webkit-scrollbar { display: none; width: 0; height: 0; }
.roller__pad { height: 44px; pointer-events: none; }
.roller__item {
  height: 44px;
  width: 100%;
  background: transparent;
  border: 0;
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 10px;
  scroll-snap-align: center;
  scroll-snap-stop: always;
  cursor: pointer;
  font-family: inherit;
  color: var(--ink);
  transition: opacity 220ms ease, color 180ms ease;
  padding: 0;
}
.roller__item .roller__num {
  font-family: var(--font-en);
  font-variant-numeric: tabular-nums;
  font-weight: 300;
  font-size: 26px;
  letter-spacing: 0.005em;
  line-height: 1;
}
.roller__item .roller__unit {
  font-family: var(--font-kr);
  font-size: 12px;
  letter-spacing: 0.18em;
  color: var(--ink-mute);
}
.roller__item.is-near { opacity: 0.42; }
.roller__item.is-far  { opacity: 0.18; }
.roller__item.is-active { opacity: 1; }
.roller__item.is-active .roller__num { font-weight: 400; }
.roller__item.is-active .roller__unit { color: var(--ink-soft); }
/* 위·아래 페이드 마스크 */
.roller__mask {
  position: absolute;
  left: 0; right: 0;
  height: 88px;
  pointer-events: none;
  z-index: 3;
}
.roller__mask--top {
  top: 0;
  background: linear-gradient(to bottom,
    var(--paper) 0%,
    rgba(255,255,255,0) 100%);
}
.roller__mask--bot {
  bottom: 0;
  background: linear-gradient(to top,
    var(--paper) 0%,
    rgba(255,255,255,0) 100%);
}
/* 중앙 가로선 — 잉크 한 줄 */
.roller__center {
  position: absolute;
  left: 12%;
  right: 12%;
  top: 50%;
  height: 44px;
  transform: translateY(-50%);
  border-top: 0.5px solid var(--rule-soft);
  border-bottom: 0.5px solid var(--rule-soft);
  pointer-events: none;
  z-index: 2;
}

/* ------------------------------------------------------------
   다이얼 안 변형 — 더 크고 무게감 있게, 가운데가 시계 디스플레이
   ------------------------------------------------------------ */
.roller--dial {
  position: absolute;
  inset: 0;
  width: auto;
  height: auto;
  z-index: 2;
}
.roller--dial .roller__pad { height: 56px; }
.roller--dial .roller__item {
  height: 56px;
  gap: 6px;
  align-items: baseline;
  color: var(--ink);
  transition: opacity 240ms ease, color 200ms ease;
}
.roller--dial .roller__item .roller__num {
  font-family: var(--font-en);
  font-variant-numeric: tabular-nums;
  font-weight: 200;
  font-size: 22px;
  letter-spacing: 0.005em;
  line-height: 1;
  color: var(--ink);
}
.roller--dial .roller__item .roller__unit {
  font-family: var(--font-kr);
  font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--ink-mute);
  display: none;
}
/* 가까이/멀리 농담 */
.roller--dial .roller__item.is-near { opacity: 0.55; }
.roller--dial .roller__item.is-near .roller__num { font-size: 26px; font-weight: 250; }
.roller--dial .roller__item.is-mid  { opacity: 0.30; }
.roller--dial .roller__item.is-mid  .roller__num { font-size: 22px; }
.roller--dial .roller__item.is-far  { opacity: 0.14; }
.roller--dial .roller__item.is-far  .roller__num { font-size: 20px; }
/* 활성 = 다이얼 시계 디스플레이 */
.roller--dial .roller__item.is-active {
  opacity: 1;
  gap: 10px;
}
.roller--dial .roller__item.is-active .roller__num {
  font-size: 64px;
  font-weight: 200;
  letter-spacing: 0.005em;
  color: var(--ink);
}
.roller--dial .roller__item.is-active .roller__unit {
  display: inline-block;
  font-size: 13px;
  letter-spacing: 0.32em;
  color: var(--ink-mute);
  text-transform: none;
  transform: translateY(-6px);
}
/* 위·아래 페이드 — 다이얼 종이톤에 맞춰 */
.roller--dial .roller__mask { height: 40%; }
.roller--dial .roller__mask--top {
  background: linear-gradient(to bottom,
    var(--paper-soft) 0%,
    rgba(245, 240, 226, 0.92) 40%,
    rgba(245, 240, 226, 0) 100%);
}
.roller--dial .roller__mask--bot {
  background: linear-gradient(to top,
    var(--paper-soft) 0%,
    rgba(245, 240, 226, 0.92) 40%,
    rgba(245, 240, 226, 0) 100%);
}
/* 다이얼 내부에서는 중앙 라인을 그리지 않는다 — 다이얼 자체가 프레임 */
.roller--dial .roller__center { display: none; }

/* 칩 — 시간 외 다른 쓰임 유지 */
.chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.chip {
  flex: 0 0 calc(25% - 6px);
  min-height: 52px;
  padding: 8px 10px;
  border-radius: 4px;
  background: var(--chrome);
  border: 1px solid var(--rule-soft);
  color: var(--ink-soft);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  transition: border-color 120ms ease, background 120ms ease, color 120ms ease, transform 120ms ease;
  font-family: var(--font-kr);
  cursor: pointer;
  text-align: center;
}
.chip:hover { border-color: var(--rule); background: var(--paper-soft); color: var(--ink); }
.chip__num {
  font-family: var(--font-en);
  font-variant-numeric: tabular-nums;
  font-weight: 500;
  font-size: 18px;
  letter-spacing: -0.005em;
  color: var(--ink);
  line-height: 1.1;
}
.chip__unit {
  font-size: 10.5px;
  letter-spacing: 0.12em;
  color: var(--ink-mute);
}
.chip.is-active {
  background: var(--ink);
  border-color: var(--ink);
  color: var(--paper);
}
.chip.is-active .chip__num,
.chip.is-active .chip__unit { color: var(--paper); }

/* ------------------------------------------------------------
   음원 칩 — 사대 + 무음. 다섯 칸 균등.
   ------------------------------------------------------------ */
.chips--sound { gap: 10px; }
.chips--sound .chip--sound {
  flex: 1 1 0;
  min-width: 0;
  min-height: 86px;
  padding: 12px 8px;
  gap: 8px;
}
.chip--sound .chip__icon {
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ink-soft);
  transition: color 120ms ease, transform 220ms ease;
}
.chip--sound:hover .chip__icon { color: var(--ink); }
.chip--sound.is-active .chip__icon {
  color: var(--paper);
  transform: scale(1.04);
}
.chip--sound.is-active { background: var(--ink); border-color: var(--ink); }

/* 칩 라벨 */
.chip__label {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1px;
  line-height: 1.05;
}
.chip__label-kr {
  font-family: var(--font-kr);
  font-size: 12px;
  letter-spacing: 0.04em;
  color: var(--ink-soft);
}
.chip--sound.is-active .chip__label-kr { color: var(--paper); }

/* 무음 칩 — 아이콘 없이 텍스트만 */
.chip--sound-silence {
  font-family: var(--font-kr);
}
.chip__silence-text {
  font-size: 16px;
  letter-spacing: 0.18em;
  color: var(--ink-soft);
}
.chip--sound-silence:hover .chip__silence-text { color: var(--ink); }
.chip--sound-silence.is-active .chip__silence-text { color: var(--paper); }

/* 접근성용 시각적 숨김 */
.sr-only {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0 0 0 0);
  white-space: nowrap; border: 0;
}

/* ============================================================
   액션 행 (시작 / 일시정지·끝내기 / 다시·마치기)
   ============================================================ */
.meditate__actions {
  width: 100%;
  display: flex;
  gap: 12px;
  margin-top: var(--s5);
}
.med-btn {
  flex: 1;
  height: 56px;
  border-radius: 4px;
  font-family: var(--font-kr);
  font-size: 15px;
  font-weight: 500;
  letter-spacing: 0.04em;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  cursor: pointer;
  transition: background 120ms ease, color 120ms ease, border-color 120ms ease, transform 120ms ease;
}
.med-btn--primary {
  background: var(--ink);
  color: var(--paper);
  border: 1px solid var(--ink);
}
.med-btn--primary:hover { background: #000; }
.med-btn--primary:active { transform: translateY(1px); }
.med-btn--ghost {
  background: var(--chrome);
  border: 1px solid var(--rule);
  color: var(--ink);
}
.med-btn--ghost:hover { background: var(--paper-soft); border-color: var(--ink-mute); }
.med-btn--danger {
  background: transparent;
  border: 1px solid var(--rule);
  color: var(--ink-soft);
}
.med-btn--danger:hover { color: var(--c-daisho); border-color: var(--c-daisho); }

/* ============================================================
   진행 중 안내 (음원 표시 + 작은 안내 한 줄)
   ============================================================ */
.meditate__running-meta {
  margin-bottom: var(--s5);
  text-align: center;
  font-size: 13px;
  color: var(--ink-mute);
  letter-spacing: 0.04em;
}
.meditate__running-meta b {
  font-weight: 500;
  color: var(--ink-soft);
  margin: 0 4px;
}
.meditate__running-sound {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--ink);
}
.meditate__running-sound-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--ink-soft);
}
.meditate__running-mute {
  margin-top: 12px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-en);
  font-size: 10.5px;
  letter-spacing: 0.32em;
  color: var(--ink-mute);
  text-transform: uppercase;
  cursor: pointer;
}
.meditate__running-mute:hover { color: var(--ink); }
.meditate__running-mute .dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--ink-soft);
}
.meditate__running-mute.is-muted .dot { background: var(--rule); }

/* ============================================================
   완료 화면 — 회기록
   ============================================================ */
.meditate__done-summary {
  display: flex;
  gap: var(--s5);
  justify-content: center;
  padding: var(--s4) var(--s5);
  margin-bottom: var(--s5);
  background: var(--chrome);
  border: 1px solid var(--rule-soft);
  border-radius: 4px;
}
.meditate__done-cell { text-align: center; }
.meditate__done-cell-key {
  font-family: var(--font-en);
  font-size: 10px;
  letter-spacing: 0.32em;
  color: var(--ink-dim);
  text-transform: uppercase;
  margin-bottom: 4px;
}
.meditate__done-cell-val {
  font-family: var(--font-en);
  font-variant-numeric: tabular-nums;
  font-weight: 500;
  font-size: 18px;
  color: var(--ink);
}
.meditate__done-cell-val-han {
  font-family: var(--font-cn);
  font-size: 16px;
  font-weight: 400;
  letter-spacing: 0.08em;
}
.meditate__done-cell-val-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--ink);
  min-height: 22px;
}

/* ============================================================
   반응형
   ============================================================ */
@media (max-width: 767px) {
  .meditate__inner {
    padding: var(--s5) 18px calc(80px + var(--s5));
  }
  .meditate__head { margin-bottom: var(--s5); }
  .dial { width: 280px; height: 280px; margin-bottom: var(--s5); }
  .dial__time { font-size: 54px; }
  .roller--dial .roller__pad { height: 48px; }
  .roller--dial .roller__item { height: 48px; }
  .roller--dial .roller__item.is-active .roller__num { font-size: 54px; }
  .roller--dial .roller__item.is-active .roller__unit { font-size: 11px; }
  .roller--dial .roller__item.is-near .roller__num { font-size: 22px; }
  .roller--dial .roller__item.is-mid  .roller__num { font-size: 18px; }
  .roller--dial .roller__item.is-far  .roller__num { font-size: 16px; }
  .roller { height: 180px; }
  .roller__pad { height: 36px; }
  .roller__item { height: 36px; }
  .roller__center { height: 36px; }
  .roller__item .roller__num { font-size: 22px; }
  .roller__mask { height: 72px; }
  .chips--sound { gap: 8px; }
  .chips--sound .chip--sound { min-height: 64px; padding: 12px 6px; }
  .chip--sound .chip__icon { width: 24px; height: 24px; }
  .meditate__actions { flex-direction: column; gap: 10px; }
  .med-btn { width: 100%; }
}

@media (max-width: 380px) {
  .dial { width: 240px; height: 240px; }
  .dial__time { font-size: 48px; }
  .roller--dial .roller__item.is-active .roller__num { font-size: 48px; }
}

/* 모바일 하단 탭바가 5에서 6칸으로 변경된 경우 — 시각 보정 */
@media (max-width: 767px) {
  .mobile-tabbar { grid-template-columns: repeat(6, 1fr) !important; }
  .mobile-tabbar__btn { font-size: 10px !important; }
  .app[data-route="meditate"] { padding-bottom: 60px; }
}
