/* ===== EVENING WIND-DOWN ===== */

.ev-main { padding: 2rem 0 5rem; }

/* ---- Steps ---- */
.ev-steps {
  max-width: 580px;
  margin: 0 auto;
}

.ev-step { display: none; }
.ev-step.active { display: block; }

.ev-step-inner {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 2.2rem 2rem;
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
  animation: evFade 0.45s ease;
}

@keyframes evFade {
  from { opacity:0; transform:translateY(14px); }
  to   { opacity:1; transform:none; }
}

.ev-step-icon { font-size: 2.4rem; color: var(--accent); }
.ev-step-number { font-size: 0.75rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent); }

.ev-step h2 { font-family: var(--font-serif); font-size: 1.8rem; line-height: 1.2; }
.ev-step-desc { color: var(--muted); font-size: 0.9rem; line-height: 1.6; }

/* ---- Stages list ---- */
.ev-stages { display: flex; flex-direction: column; gap: 0.7rem; }
.ev-stage-row { display: flex; align-items: flex-start; gap: 0.8rem; font-size: 0.88rem; color: var(--muted); line-height: 1.5; }
.ev-stage-row span:first-child { font-size: 1rem; flex-shrink: 0; margin-top: 0.05rem; }

/* ---- Progress dots ---- */
.ev-dots {
  display: flex;
  gap: 0.6rem;
  justify-content: center;
  margin-bottom: 1.5rem;
}

.ev-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--border);
  transition: background 0.3s, transform 0.3s;
}

.ev-dot.done    { background: rgba(139,124,248,0.4); }
.ev-dot.current { background: var(--accent); transform: scale(1.4); }

/* ---- Gratitude inputs ---- */
.ev-gratitude-inputs { display: flex; flex-direction: column; gap: 0.7rem; }

.ev-grat-row {
  display: flex;
  align-items: center;
  gap: 0.7rem;
}

.ev-grat-num {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: rgba(139,124,248,0.15);
  color: var(--accent);
  font-size: 0.72rem;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.ev-grat-input {
  flex: 1;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  color: var(--text);
  font-size: 0.92rem;
  padding: 0.6rem 0.9rem;
  transition: border-color 0.2s;
}

.ev-grat-input:focus { outline: none; border-color: rgba(139,124,248,0.5); }

/* ---- Body check grid ---- */
.ev-body-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.6rem;
}

.ev-body-btn {
  padding: 0.6rem;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: transparent;
  color: var(--text);
  font-size: 0.84rem;
  cursor: pointer;
  transition: border-color 0.2s, background 0.2s, color 0.2s;
}

.ev-body-btn.tapped {
  border-color: var(--accent);
  background: rgba(139,124,248,0.1);
  color: var(--accent);
}

.ev-body-confirm {
  font-size: 0.85rem;
  color: var(--muted);
  font-style: italic;
  padding: 0.8rem 1rem;
  background: var(--surface2);
  border-radius: var(--radius);
}

/* ---- 4-7-8 ring ---- */
.ev-ring-wrap {
  position: relative;
  width: 150px;
  height: 150px;
  margin: 0 auto;
}

.ev-ring { width: 100%; height: 100%; transform: rotate(-90deg); }

.ev-ring-bg   { fill: none; stroke: rgba(255,255,255,0.06); stroke-width: 6; }
.ev-ring-fill {
  fill: none;
  stroke: var(--accent);
  stroke-width: 6;
  stroke-linecap: round;
  stroke-dasharray: 326.7;
  stroke-dashoffset: 326.7;
  transition: stroke-dashoffset 0.1s linear;
}

.ev-ring-label {
  position: absolute;
  top: 44%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-family: var(--font-serif);
  font-size: 0.95rem;
  color: var(--accent);
  text-align: center;
}

.ev-ring-sub {
  position: absolute;
  top: 62%;
  left: 50%;
  transform: translateX(-50%);
  font-size: 0.72rem;
  color: var(--muted);
  white-space: nowrap;
}

/* ---- Sleep sounds ---- */
.ev-sleep-inner { align-items: stretch; }

.ev-sound-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.7rem;
}

.ev-sound-btn {
  padding: 0.8rem;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: transparent;
  color: var(--text);
  font-size: 0.88rem;
  cursor: pointer;
  transition: border-color 0.2s, background 0.2s, color 0.2s;
}

.ev-sound-btn:hover   { border-color: rgba(139,124,248,0.4); background: rgba(139,124,248,0.06); }
.ev-sound-btn.playing { border-color: var(--accent); background: rgba(139,124,248,0.12); color: var(--accent); }

.ev-sleep-vol {
  display: flex;
  align-items: center;
  gap: 0.8rem;
  font-size: 0.82rem;
  color: var(--muted);
}

.ev-sleep-vol input { flex: 1; accent-color: var(--accent); }

.ev-sleep-note {
  font-size: 0.8rem;
  color: var(--muted);
  font-style: italic;
}

.ev-done-link { align-self: flex-start; }

/* ---- Actions row ---- */
.ev-step-actions { display: flex; gap: 0.7rem; align-items: center; }
.ev-skip { font-size: 0.8rem; padding: 0.4rem 0.8rem; }

@media (max-width: 600px) {
  .ev-step-inner { padding: 1.5rem 1.1rem; }
  .ev-sound-grid { grid-template-columns: 1fr; }
  .ev-body-grid  { grid-template-columns: repeat(3, 1fr); }
}
