/* ============================================================
   My Day — Components
   ============================================================ */

/* ---------- Card ---------- */
.card {
  background: var(--bg-elevated);
  border-radius: var(--r-lg);
  padding: var(--s-5);
  box-shadow: var(--sh-sm);
  border: 1px solid var(--line);
  transition: transform var(--dur) var(--ease-spring), box-shadow var(--dur) var(--ease-out);
}
.card--hover:hover { transform: translateY(-3px); box-shadow: var(--sh-md); }
.card__title { display: flex; align-items: center; gap: var(--s-3); margin-bottom: var(--s-4); }
.card__icon {
  width: 44px; height: 44px; border-radius: 14px;
  display: grid; place-items: center; flex: none;
}

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--s-2);
  padding: var(--s-3) var(--s-5);
  border-radius: var(--r-pill);
  font-weight: 700; font-size: var(--fs-sm);
  background: var(--bg-sunken); color: var(--text);
  transition: transform var(--dur-fast) var(--ease-spring),
              box-shadow var(--dur) var(--ease-out),
              background var(--dur-fast) var(--ease-out);
  white-space: nowrap;
}
.btn:hover { transform: translateY(-1px); }
.btn:active { transform: translateY(1px) scale(0.98); }
.btn svg { width: 18px; height: 18px; }
.btn--primary {
  background: linear-gradient(120deg, var(--pink-400), var(--pink-300));
  color: #fff;
  box-shadow: var(--sh-sm);
}
.btn--primary:hover { box-shadow: var(--sh-md); }
.btn--ghost { background: transparent; border: 1.5px solid var(--line); }
.btn--ghost:hover { background: var(--pink-50); border-color: var(--pink-200); }
.btn--sm { padding: var(--s-2) var(--s-3); font-size: var(--fs-xs); }
.btn--icon { padding: var(--s-2); width: 38px; height: 38px; border-radius: 50%; }

/* round add / step buttons */
.stepper { display: inline-flex; align-items: center; gap: var(--s-3); }
.stepper__btn {
  width: 40px; height: 40px; border-radius: 50%;
  display: grid; place-items: center;
  background: var(--white); box-shadow: var(--sh-sm);
  border: 1px solid var(--line);
  font-size: 1.4rem; font-weight: 700; color: var(--accent-strong);
  transition: transform var(--dur-fast) var(--ease-spring), background var(--dur-fast);
}
.stepper__btn:hover { transform: scale(1.08); background: var(--pink-50); }
.stepper__btn:active { transform: scale(0.92); }
.stepper__val { min-width: 80px; text-align: center; font-family: var(--font-display); font-size: var(--fs-lg); }

/* ---------- Inputs ---------- */
.field { display: flex; flex-direction: column; gap: var(--s-2); }
.field__label { font-size: var(--fs-sm); font-weight: 700; color: var(--text-soft); }
.input, .select, .textarea {
  padding: var(--s-3) var(--s-4);
  border-radius: var(--r-md);
  border: 1.5px solid var(--line);
  background: var(--cream);
  transition: border-color var(--dur-fast), box-shadow var(--dur-fast);
  width: 100%;
}
.input:focus, .select:focus, .textarea:focus {
  border-color: var(--pink-300);
  box-shadow: 0 0 0 4px var(--pink-100);
  outline: none;
}
.textarea { resize: vertical; min-height: 64px; font-family: var(--font-body); line-height: 1.5; }
.input--inline { width: 90px; }

/* ---------- Progress ---------- */
.bar {
  height: 12px; border-radius: var(--r-pill);
  background: var(--bg-sunken);
  overflow: hidden; position: relative;
  box-shadow: var(--sh-inset);
}
.bar__fill {
  height: 100%; border-radius: var(--r-pill);
  width: 0%;
  transition: width var(--dur-slow) var(--ease-spring);
  background: linear-gradient(90deg, var(--accent), var(--accent-strong));
  position: relative;
}
.bar__fill::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.45), transparent);
  transform: translateX(-100%);
  animation: shimmer 2.6s var(--ease-out) infinite;
}
@keyframes shimmer { to { transform: translateX(100%); } }

.bar__row { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: var(--s-2); }
.bar__pct { font-family: var(--font-display); font-weight: 600; font-size: var(--fs-lg); }
.bar--done .bar__fill { background: linear-gradient(90deg, var(--good), #7be0a8); }

/* Progress ring */
.ring { --p: 0; --size: 96px; --track: var(--bg-sunken); --col: var(--accent); }
.ring { width: var(--size); height: var(--size); position: relative; flex: none; }
.ring__svg { transform: rotate(-90deg); width: 100%; height: 100%; }
.ring__bg { stroke: var(--track); }
.ring__fg {
  stroke: var(--col); stroke-linecap: round;
  transition: stroke-dashoffset var(--dur-slow) var(--ease-spring);
}
.ring__label {
  position: absolute; inset: 0; display: grid; place-items: center;
  font-family: var(--font-display); font-weight: 600; font-size: var(--fs-lg);
}

/* ---------- Chips / pills / tags ---------- */
.chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px var(--s-3);
  border-radius: var(--r-pill);
  font-size: var(--fs-xs); font-weight: 800;
  background: var(--bg-sunken); color: var(--text-soft);
}
.streak-chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px var(--s-3);
  border-radius: var(--r-pill);
  font-size: var(--fs-sm); font-weight: 800;
  background: var(--white); box-shadow: var(--sh-sm);
  border: 1px solid var(--line);
}
.streak-chip__dot { width: 18px; height: 18px; border-radius: 6px; flex: none; }
.streak-chip__n { font-family: var(--font-display); }
.streak-chip.is-hot { animation: pulseHot 1.8s var(--ease-out) infinite; }
@keyframes pulseHot {
  0%, 100% { box-shadow: var(--sh-sm); }
  50% { box-shadow: 0 0 0 6px var(--pink-100); }
}

.tag {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 3px 10px; border-radius: var(--r-pill);
  font-size: var(--fs-xs); font-weight: 800;
  border: 1px solid rgba(0,0,0,0.04);
}

/* ---------- Tickbox ---------- */
.tick {
  display: flex; align-items: center; gap: var(--s-3);
  padding: var(--s-3) var(--s-4);
  border-radius: var(--r-md);
  background: var(--cream);
  border: 1.5px solid var(--line);
  transition: background var(--dur-fast), border-color var(--dur-fast), transform var(--dur-fast) var(--ease-spring);
  cursor: pointer; width: 100%; text-align: left;
}
.tick:hover { transform: translateX(2px); border-color: var(--pink-200); }
.tick__box {
  width: 26px; height: 26px; border-radius: 9px; flex: none;
  border: 2px solid var(--ink-300);
  display: grid; place-items: center;
  transition: all var(--dur-fast) var(--ease-spring);
  background: var(--white);
}
.tick__box svg { width: 16px; height: 16px; opacity: 0; transform: scale(0.4); transition: all var(--dur) var(--ease-spring); color: #fff; }
.tick__label { font-weight: 600; flex: 1; }
.tick.is-done { background: var(--good-bg); border-color: var(--mint-300); }
.tick.is-done .tick__box { background: var(--good); border-color: var(--good); }
.tick.is-done .tick__box svg { opacity: 1; transform: scale(1); }
.tick.is-done .tick__label { color: var(--text-muted); text-decoration: line-through; text-decoration-color: var(--mint-300); }

/* ---------- Toast ---------- */
.toasts {
  position: fixed; right: var(--s-5); bottom: var(--s-5); z-index: 200;
  display: flex; flex-direction: column; gap: var(--s-2); align-items: flex-end;
  pointer-events: none;
}
.toast {
  background: var(--white);
  border: 1px solid var(--line);
  box-shadow: var(--sh-lg);
  border-radius: var(--r-md);
  padding: var(--s-3) var(--s-4);
  display: flex; align-items: center; gap: var(--s-3);
  font-weight: 700; max-width: 340px;
  animation: toastIn var(--dur) var(--ease-spring);
}
.toast.out { animation: toastOut var(--dur) var(--ease-out) forwards; }
.toast__emoji { font-size: 1.4rem; }
@keyframes toastIn { from { opacity: 0; transform: translateY(20px) scale(0.9); } to { opacity: 1; transform: none; } }
@keyframes toastOut { to { opacity: 0; transform: translateX(40px); } }

@media (max-width: 520px) { .toasts { left: var(--s-3); right: var(--s-3); bottom: 84px; align-items: stretch; } .toast { max-width: none; } }

/* ---------- Modal / sheet ---------- */
.modal-backdrop {
  position: fixed; inset: 0; z-index: 150;
  background: rgba(74, 51, 64, 0.32);
  backdrop-filter: blur(4px);
  display: grid; place-items: center;
  padding: var(--s-4);
  animation: fade var(--dur) var(--ease-out);
}
@keyframes fade { from { opacity: 0; } to { opacity: 1; } }
.modal {
  background: var(--bg-elevated);
  border-radius: var(--r-xl);
  box-shadow: var(--sh-lg);
  width: min(480px, 100%);
  max-height: 90vh; overflow-y: auto;
  padding: var(--s-6);
  animation: modalIn var(--dur-slow) var(--ease-spring);
}
@keyframes modalIn { from { opacity: 0; transform: translateY(24px) scale(0.96); } to { opacity: 1; transform: none; } }
.modal__head { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--s-4); }
.modal__body { display: flex; flex-direction: column; gap: var(--s-4); }
.modal__foot { display: flex; gap: var(--s-3); justify-content: flex-end; margin-top: var(--s-5); }

/* ---------- Colour swatch picker ---------- */
.swatches { display: flex; gap: var(--s-2); flex-wrap: wrap; }
.swatch {
  width: 34px; height: 34px; border-radius: 11px;
  border: 2px solid transparent;
  transition: transform var(--dur-fast) var(--ease-spring);
  position: relative;
}
.swatch:hover { transform: scale(1.12); }
.swatch[aria-pressed="true"] { border-color: var(--ink-900); transform: scale(1.08); }
.swatch[aria-pressed="true"]::after {
  content: "✓"; position: absolute; inset: 0; display: grid; place-items: center;
  color: var(--ink-900); font-weight: 900; font-size: 0.9rem;
}

/* ---------- Empty state ---------- */
.empty {
  text-align: center; padding: var(--s-7) var(--s-4);
  color: var(--text-muted);
}
.empty__art { font-size: 3rem; margin-bottom: var(--s-3); animation: bob 3s var(--ease-out) infinite; }
@keyframes bob { 0%,100% { transform: translateY(0);} 50% { transform: translateY(-8px);} }

/* ---------- Misc ---------- */
.row { display: flex; align-items: center; gap: var(--s-3); }
.row--between { justify-content: space-between; }
.row--wrap { flex-wrap: wrap; }
.muted { color: var(--text-muted); }
.soft { color: var(--text-soft); }
.center { text-align: center; }
.stack { display: flex; flex-direction: column; gap: var(--s-3); }
.stack--lg { gap: var(--s-5); }
.delta-up { color: var(--good); font-weight: 800; }
.pop { animation: pop var(--dur) var(--ease-spring); }
@keyframes pop { 0% { transform: scale(1);} 40% { transform: scale(1.18);} 100% { transform: scale(1);} }

/* ---------- Habit 7-day history strip ---------- */
.histstrip {
  display: flex; gap: 6px; margin-top: var(--s-4);
  padding-top: var(--s-3); border-top: 1px dashed var(--line);
  justify-content: space-between;
}
.hist-dot {
  flex: 1; aspect-ratio: 1; max-width: 34px;
  border-radius: 9px; background: var(--bg-sunken);
  display: grid; place-items: center;
  font-size: 0.6rem; font-weight: 800; color: var(--text-muted);
  position: relative; transition: transform var(--dur-fast) var(--ease-spring);
}
.hist-dot:hover { transform: translateY(-2px); }
.hist-dot.is-met { background: var(--good); color: #fff; }
.hist-dot.is-miss { background: var(--coral-100); color: var(--coral-300); }
.hist-dot.is-rest { background: var(--lilac-100); color: var(--lilac-300); }
.hist-dot.is-today { box-shadow: 0 0 0 2px var(--accent); }
.hist-dot__d { pointer-events: none; }

/* ---------- Sync status pill ---------- */
.sync-pill {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 0.66rem; font-weight: 800; color: var(--text-muted);
  padding: 4px 10px; border-radius: var(--r-pill);
  background: var(--bg-sunken);
}
.sync-pill__dot { width: 8px; height: 8px; border-radius: 50%; background: var(--ink-300); }
.sync-pill.is-on .sync-pill__dot { background: var(--good); box-shadow: 0 0 0 3px var(--good-bg); }
.sync-pill.is-syncing .sync-pill__dot { background: var(--gold); animation: pulseHot 1s infinite; }

/* ---------- Insights mini-stats ---------- */
.insight-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(130px, 1fr)); gap: var(--s-3); }
.insight {
  padding: var(--s-4); border-radius: var(--r-md);
  background: var(--cream); border: 1px solid var(--line); text-align: center;
}
.insight__big { font-family: var(--font-display); font-size: 1.8rem; line-height: 1; }
.insight__label { font-size: var(--fs-xs); font-weight: 700; color: var(--text-muted); margin-top: 4px; }

/* ---------- Segmented control (range toggle) ---------- */
.seg { display: inline-flex; background: var(--bg-sunken); border-radius: var(--r-pill); padding: 3px; gap: 2px; }
.seg__btn {
  padding: 6px 14px; border-radius: var(--r-pill);
  font-size: var(--fs-xs); font-weight: 800; color: var(--text-muted);
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast), transform var(--dur-fast) var(--ease-spring);
}
.seg__btn:hover { color: var(--text); }
.seg__btn.is-active { background: var(--white); color: var(--accent-strong); box-shadow: var(--sh-sm); }

/* ---------- Trends ---------- */
.trend-row { padding: var(--s-3) 0; border-bottom: 1px dashed var(--line); }
.trend-row:last-child { border-bottom: none; }
.trend-row__top { display: flex; align-items: center; justify-content: space-between; gap: var(--s-3); margin-bottom: var(--s-2); }
.trend-pct { font-family: var(--font-display); font-weight: 700; font-size: 1.05rem; }

.trend-note {
  margin-top: var(--s-4); padding: var(--s-3) var(--s-4);
  background: var(--lilac-100); border-radius: var(--r-md);
  font-size: var(--fs-sm); font-weight: 600; color: var(--text-soft);
  display: flex; align-items: center; gap: 4px;
}

/* heatmap: fixed-width cells wrapping into rows of 7 (week per row) */
.heatmap {
  display: grid;
  grid-template-columns: repeat(15, 1fr);
  gap: 3px; margin-top: var(--s-2);
}
@media (max-width: 520px) { .heatmap { grid-template-columns: repeat(10, 1fr); } }
.hm-cell {
  aspect-ratio: 1; border-radius: 4px; background: var(--bg-sunken);
  transition: transform var(--dur-fast) var(--ease-spring);
}
.hm-cell:hover { transform: scale(1.25); }
.hm-cell.is-met { background: var(--good); }
.hm-cell.is-miss { background: var(--coral-200); }
.hm-cell.is-rest { background: var(--lilac-200); }
.hm-cell.is-empty { background: var(--bg-sunken); opacity: 0.5; }

/* sparkline */
.sparkwrap { position: relative; margin-top: var(--s-2); }
.spark { width: 100%; height: 46px; display: block; }
.spark__trend {
  position: absolute; right: 0; top: -2px;
  font-weight: 900; font-size: 1rem; color: var(--text-muted);
}
