* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  min-height: 100%;
  background: var(--bg-canvas);
  color: var(--fg-primary);
  font-family: "Noto Sans SC", sans-serif;
}

body {
  position: relative;
  overflow-x: hidden;
}

button {
  font: inherit;
}

.app-backdrop {
  position: fixed;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
  background: var(--md-sys-color-surface);
}

.paper {
  display: none;
}

.paper-left {
  inset: -10% auto auto -10%;
  width: 18rem;
  height: 18rem;
  background: radial-gradient(circle, color-mix(in oklch, var(--md-sys-color-primary-container) 22%, transparent), transparent 70%);
}

.paper-right {
  inset: auto -8% 15% auto;
  width: 16rem;
  height: 16rem;
  background: radial-gradient(circle, color-mix(in oklch, var(--md-sys-color-tertiary-container) 20%, transparent), transparent 68%);
}

.phone-shell {
  position: relative;
  z-index: 1;
  width: min(100%, 28rem);
  min-height: 100vh;
  margin: 0 auto;
  padding: 1.15rem var(--space-4) calc(7.4rem + env(safe-area-inset-bottom));
  overflow-x: clip;
  background: var(--md-sys-color-surface);
}

.shell-topbar,
.section-head,
.voice-stage-head,
.calendar-grid__head,
.calendar-header,
.settings-item,
.inline-actions,
.confirm-card__actions,
.confirm-card__meta,
.brand-lockup,
.quick-actions,
.bottom-nav {
  display: flex;
  align-items: center;
}

.shell-topbar,
.section-head,
.voice-stage-head,
.calendar-header,
.settings-item {
  justify-content: space-between;
}

.shell-topbar {
  margin-bottom: var(--space-3);
}

.context-header {
  margin: 0;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-3);
}

.context-header__identity {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 0.78rem;
}

.context-header__avatar {
  width: 3.25rem;
  height: 3.25rem;
  flex: 0 0 auto;
  display: grid;
  place-items: center;
  border-radius: 1.15rem;
  overflow: hidden;
  border: 1px solid var(--md-sys-color-outline-variant);
  background: var(--md-sys-color-primary-container);
  box-shadow:
    0 2px 6px oklch(0.28 0.018 54 / 0.08),
    inset 0 1px 0 color-mix(in oklch, white 64%, transparent);
  color: var(--md-sys-color-on-primary-container);
  font-family: "Noto Serif SC", serif;
  font-size: 1.25rem;
  font-weight: var(--weight-bold);
}

.context-header__avatar-image {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.context-header__name {
  margin: 0;
  font-family: "Noto Serif SC", serif;
  font-size: 1.7rem;
  font-weight: var(--weight-bold);
}

.context-header__meta {
  margin: 0;
  color: var(--fg-muted);
  font-size: var(--text-sm);
}

.context-header__status {
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
  width: fit-content;
  margin: 0.25rem 0 0;
  padding: 0.4rem 0.75rem;
  border-radius: var(--radius-pill);
  background: var(--md-sys-color-secondary-container);
  color: var(--md-sys-color-on-secondary-container);
  font-size: 0.8rem;
  line-height: 1.4;
}

.brand-lockup {
  gap: var(--space-3);
}

.brand-dot {
  width: 12px;
  height: 12px;
  border-radius: var(--radius-pill);
  background: color-mix(in oklch, var(--accent-brick) 62%, var(--accent-peach));
  box-shadow: 0 0 0 5px color-mix(in oklch, var(--accent-peach) 20%, transparent);
}

.eyebrow {
  margin: 0 0 var(--space-1);
  color: var(--fg-muted);
  font-size: var(--text-xs);
  letter-spacing: 0.08em;
}

h1,
h2,
h3,
.event-card__title,
.settings-item__title {
  margin: 0;
  font-family: "Noto Serif SC", serif;
  font-weight: var(--weight-bold);
}

h1 {
  font-size: 1.35rem;
}

h2 {
  font-size: 1.5rem;
}

h3 {
  font-size: 1.2rem;
}

.support-text {
  margin: var(--space-2) 0 0;
  color: var(--fg-secondary);
  font-size: var(--text-sm);
  line-height: 1.65;
}

.section-note {
  margin: 0;
  color: var(--fg-muted);
  font-size: var(--text-sm);
  line-height: 1.5;
}

.page {
  display: none;
  animation: page-in var(--motion-base) var(--ease-soft-out);
}

.page-active {
  display: block;
}

.page[data-page="record"].page-active {
  display: grid;
  gap: var(--space-3);
  align-content: start;
}

.page[data-page="calendar"].page-active,
.page[data-page="mine"].page-active {
  display: grid;
  gap: var(--space-3);
  align-content: start;
}

.page[data-page="calendar"] {
  min-width: 0;
  overflow-x: clip;
  padding-bottom: calc(6.2rem + env(safe-area-inset-bottom));
}

.page[data-page="calendar"] .section-block {
  margin-top: 0;
}

.hero-card,
.card-surface,
.snapshot-card,
.pending-card,
.event-card,
.calendar-grid,
.settings-item {
  background: var(--md-sys-color-surface-container-lowest);
  border: 1px solid var(--md-sys-color-outline-variant);
  box-shadow: var(--shadow-card);
}

.hero-card,
.card-surface,
.calendar-grid {
  border-radius: var(--radius-lg);
}

.hero-card,
.card-surface {
  padding: var(--space-5);
}

.baby-status-card,
.settings-card {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--space-4);
}

.companion-mark {
  width: 4.8rem;
  height: 4.8rem;
  border-radius: 38% 62% 57% 43%;
  background: var(--md-sys-color-secondary-container);
  position: relative;
  align-self: start;
}

.companion-mark span {
  position: absolute;
  inset: 0;
}

.companion-mark span:first-child::before,
.companion-mark span:first-child::after {
  content: "";
  position: absolute;
  top: 1.7rem;
  width: 6px;
  height: 6px;
  border-radius: var(--radius-pill);
  background: var(--fg-primary);
}

.companion-mark span:first-child::before {
  left: 1.45rem;
}

.companion-mark span:first-child::after {
  right: 1.45rem;
}

.companion-mark span:last-child::before {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 1.3rem;
  width: 1rem;
  height: 0.55rem;
  border-bottom: 2px solid var(--fg-primary);
  border-radius: 0 0 1rem 1rem;
  transform: translateX(-50%);
}

.voice-stage {
  margin-top: 0;
  text-align: center;
}

.voice-stage-floating {
  position: fixed;
  left: 50%;
  bottom: calc(5.9rem + env(safe-area-inset-bottom));
  transform: translateX(-50%);
  z-index: 8;
  width: min(calc(100% - 1rem), 25.6rem);
  display: grid;
  gap: 0.75rem;
  padding: 0.95rem;
  border-radius: 1.65rem;
  background: var(--md-sys-color-surface-container-high);
  border: 1px solid var(--md-sys-color-outline-variant);
  box-shadow: var(--shadow-floating);
}

.voice-orb {
  position: relative;
  width: 4.45rem;
  height: 4.45rem;
  margin: 0;
  border: 0;
  border-radius: 50%;
  background: transparent;
  cursor: pointer;
}

.voice-orb-nav {
  position: relative;
  left: auto;
  bottom: auto;
  transform: none;
  z-index: 1;
  justify-self: start;
}

.voice-orb__halo,
.voice-orb__core,
.voice-orb__icon {
  position: absolute;
  inset: 0;
  border-radius: 50%;
}

.voice-orb__halo {
  inset: -0.46rem;
  background: radial-gradient(circle, color-mix(in oklch, var(--md-sys-color-primary) 22%, transparent) 0%, transparent 70%);
  animation: pulse var(--motion-voice) ease-in-out infinite;
}

.voice-orb__core {
  background: var(--md-sys-color-primary);
  box-shadow: var(--shadow-floating);
  overflow: hidden;
}

.voice-orb__activity {
  position: absolute;
  inset: 0.9rem;
  display: grid;
  grid-auto-flow: column;
  align-items: end;
  justify-content: center;
  gap: 0.22rem;
  opacity: 0;
  transform: scale(0.92);
  transition:
    opacity var(--motion-fast) var(--ease-standard),
    transform var(--motion-fast) var(--ease-standard);
}

.voice-orb__bar {
  width: 0.28rem;
  border-radius: 999px;
  background: var(--md-sys-color-on-primary);
  box-shadow: inset 0 1px 0 color-mix(in oklch, white 54%, transparent);
  transform-origin: center bottom;
}

.voice-orb__bar-1 {
  height: 1.05rem;
}

.voice-orb__bar-2 {
  height: 1.48rem;
}

.voice-orb__bar-3 {
  height: 1.18rem;
}

.voice-orb__icon {
  inset: 1.08rem;
  border-radius: 0;
  background: center / contain no-repeat url("../assets/icons/voice-mic.svg");
  filter: drop-shadow(0 5px 8px oklch(0.48 0.03 55 / 0.12));
  transition:
    opacity var(--motion-fast) var(--ease-standard),
    transform var(--motion-fast) var(--ease-standard);
}

.voice-orb.is-listening .voice-orb__halo {
  animation-duration: 760ms;
}

.voice-orb.is-listening .voice-orb__activity {
  opacity: 1;
  transform: scale(1);
}

.voice-orb.is-listening .voice-orb__icon {
  opacity: 0.24;
  transform: scale(0.92);
}

.voice-orb.is-listening .voice-orb__bar-1 {
  animation: orb-bar 680ms ease-in-out infinite;
}

.voice-orb.is-listening .voice-orb__bar-2 {
  animation: orb-bar 540ms ease-in-out infinite 80ms;
}

.voice-orb.is-listening .voice-orb__bar-3 {
  animation: orb-bar 760ms ease-in-out infinite 120ms;
}

.voice-caption {
  margin: 0;
  font-size: 0.84rem;
  color: var(--fg-secondary);
  text-align: left;
  line-height: 1.45;
}

.voice-status-row {
  display: flex;
  gap: 0.45rem;
  justify-content: flex-start;
  flex-wrap: wrap;
  margin-top: 0.1rem;
}

.voice-status-chip {
  display: inline-flex;
  align-items: center;
  padding: 0.32rem 0.62rem;
  border-radius: var(--radius-pill);
  background: var(--md-sys-color-primary-container);
  color: var(--md-sys-color-on-primary-container);
  font-size: var(--text-xs);
}

.voice-status-chip-muted {
  background: var(--md-sys-color-surface-container);
  color: var(--fg-secondary);
}

.transcript-rail {
  margin: 0;
  padding: 0.68rem 0.88rem;
  min-height: 2.45rem;
  border-radius: 1.05rem;
  background: var(--md-sys-color-surface-container-low);
  color: var(--fg-primary);
  font-size: var(--text-sm);
  line-height: 1.6;
  text-align: left;
  transition: all var(--motion-base) var(--ease-standard);
}

.voice-debug-log {
  display: grid;
  gap: 0.32rem;
  max-height: 7.8rem;
  padding: 0.72rem 0.78rem;
  border-radius: 1rem;
  overflow: auto;
  background: var(--md-sys-color-surface-container);
  color: var(--fg-secondary);
  font-size: 0.74rem;
  line-height: 1.45;
}

.voice-debug-log__item {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.45rem;
}

.voice-debug-log__time {
  color: var(--fg-muted);
  font-variant-numeric: tabular-nums;
}

.confirm-card {
  margin-top: var(--space-2);
  padding: 0.82rem 0.9rem;
  text-align: left;
  border-radius: var(--radius-md);
  background: var(--md-sys-color-primary-container);
  border: 1px solid color-mix(in oklch, var(--md-sys-color-primary) 20%, var(--md-sys-color-outline-variant));
}

.confirm-card__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
}

.confirm-card__time {
  margin: 0;
  color: var(--fg-muted);
  font-size: var(--text-xs);
}

.confirm-card h3 {
  margin-top: 0.4rem;
  font-size: 1.08rem;
}

.confirm-card__spoken {
  margin-top: 0.78rem;
  padding: 0.72rem 0.8rem;
  border-radius: 0.95rem;
  background: color-mix(in oklch, white 80%, var(--accent-blue) 20%);
}

.confirm-card__spoken .eyebrow {
  margin-bottom: 0.22rem;
}

.confirm-card__spoken-text {
  margin: 0;
  color: var(--fg-primary);
  font-size: var(--text-sm);
  line-height: 1.6;
}

.confirm-card__summary {
  margin: 0.72rem 0 0;
  color: var(--fg-secondary);
  font-size: var(--text-sm);
  line-height: 1.6;
}

.query-card {
  margin-top: var(--space-2);
  padding: 0.9rem;
  text-align: left;
  border-radius: var(--radius-md);
  background: color-mix(in oklch, var(--accent-blue) 14%, white);
  border: 1px solid color-mix(in oklch, var(--accent-blue) 18%, var(--border-soft));
}

.query-card__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
}

.query-card h3 {
  margin: 0.38rem 0 0;
  font-size: 1.04rem;
}

.query-card .support-text {
  margin: 0.3rem 0 0;
}

.query-card__list {
  display: grid;
  gap: 0.42rem;
  margin-top: 0.72rem;
}

.query-card__item {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 0.5rem;
  padding: 0.62rem 0.74rem;
  border-radius: 0.85rem;
  background: color-mix(in oklch, var(--bg-surface) 84%, white);
  font-size: var(--text-sm);
  color: var(--fg-primary);
}

.query-card__item-icon {
  width: 1.12rem;
  height: 1.12rem;
  opacity: 0.9;
}

.clarify-card,
.voice-guide {
  margin-top: var(--space-2);
  padding: 0.9rem;
  text-align: left;
  border-radius: var(--radius-md);
  background: color-mix(in oklch, var(--accent-oat) 14%, white);
  border: 1px solid color-mix(in oklch, var(--accent-oat) 18%, var(--border-soft));
}

.clarify-card__head,
.voice-guide__head {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: var(--space-2);
}

.clarify-card h3,
.voice-guide h3 {
  margin: 0.35rem 0 0;
  font-size: 1rem;
}

.clarify-card__actions {
  display: flex;
  gap: 0.5rem;
  margin-top: 0.75rem;
}

.clarify-card__actions .primary-button,
.clarify-card__actions .ghost-button {
  flex: 1;
  justify-content: center;
}

.voice-guide__list {
  display: grid;
  gap: 0.55rem;
  margin-top: 0.8rem;
}

.voice-guide__item {
  display: grid;
  grid-template-columns: auto auto 1fr;
  align-items: center;
  column-gap: 0.48rem;
  row-gap: 0.24rem;
  padding: 0.62rem 0.72rem;
  border-radius: 0.85rem;
  background: color-mix(in oklch, var(--bg-surface) 86%, white);
}

.voice-guide__icon {
  width: 1.22rem;
  height: 1.22rem;
  opacity: 0.92;
}

.voice-guide__item p {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--fg-primary);
  grid-column: 1 / -1;
}

.hidden {
  display: none;
}

.chip {
  display: inline-flex;
  align-items: center;
  padding: 0.35rem 0.7rem;
  border-radius: var(--radius-pill);
  background: var(--md-sys-color-secondary-container);
  color: var(--md-sys-color-on-secondary-container);
  font-size: var(--text-xs);
}

.chip-soft {
  background: var(--md-sys-color-tertiary-container);
  color: var(--md-sys-color-on-tertiary-container);
}

.chip-eat {
  background: color-mix(in oklch, var(--event-eat) 30%, var(--md-sys-color-surface-container-lowest));
}

.chip-drink {
  background: color-mix(in oklch, var(--event-drink) 28%, var(--md-sys-color-surface-container-lowest));
}

.chip-elimination {
  background: color-mix(in oklch, var(--event-elimination) 28%, var(--md-sys-color-surface-container-lowest));
}

.chip-outdoor {
  background: color-mix(in oklch, var(--event-outdoor) 28%, var(--md-sys-color-surface-container-lowest));
}

.chip-vaccine {
  background: color-mix(in oklch, var(--event-vaccine) 26%, var(--md-sys-color-surface-container-lowest));
}

.primary-button,
.ghost-button,
.quick-pill,
.nav-tab {
  border: 0;
  cursor: pointer;
}

.primary-button {
  padding: 0.9rem 1.05rem;
  border-radius: var(--radius-pill);
  background: var(--md-sys-color-primary);
  color: var(--md-sys-color-on-primary);
  box-shadow: none;
  transition: background var(--motion-fast) var(--ease-standard), box-shadow var(--motion-fast) var(--ease-standard), transform var(--motion-fast) var(--ease-standard);
}

.primary-button:hover {
  background: color-mix(in oklch, var(--md-sys-color-primary) 92%, var(--md-sys-color-on-primary) 8%);
  box-shadow: var(--shadow-soft);
}

.primary-button:active {
  transform: translateY(1px);
}

.ghost-button {
  padding: 0.8rem 1rem;
  border-radius: var(--radius-pill);
  background: var(--md-sys-color-secondary-container);
  color: var(--md-sys-color-on-secondary-container);
  box-shadow: none;
  transition: background var(--motion-fast) var(--ease-standard), transform var(--motion-fast) var(--ease-standard);
}

.ghost-button:hover {
  background: color-mix(in oklch, var(--md-sys-color-secondary-container) 92%, var(--md-sys-color-on-secondary-container) 8%);
}

.ghost-button:active {
  transform: translateY(1px);
}

.compact {
  padding: 0.55rem 0.85rem;
  font-size: var(--text-sm);
}

.compact-button {
  padding: 0.75rem 0.95rem;
  font-size: var(--text-sm);
}

.record-reminders {
  margin-top: 0;
}

.section-block {
  margin-top: var(--space-5);
  min-width: 0;
}

.page[data-page="record"] .section-block {
  margin-top: 0;
}

.record-manual-dock {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 0.72rem;
  margin-top: var(--space-4);
  padding: 0.78rem 0.82rem 0.78rem 1rem;
  border: 1px solid var(--md-sys-color-outline-variant);
  border-radius: var(--radius-pill);
  background: var(--md-sys-color-surface-container-low);
  box-shadow: var(--shadow-card);
}

.record-manual-dock .support-text {
  margin: 0;
  font-size: var(--text-sm);
}

.record-manual-dock .primary-button {
  min-height: 2.55rem;
  padding: 0.72rem 1.05rem;
  white-space: nowrap;
}

.snapshot-strip {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: 78%;
  gap: var(--space-3);
  overflow-x: auto;
  padding-bottom: var(--space-2);
}

.snapshot-card {
  padding: var(--space-4);
  border-radius: var(--radius-lg);
}

.snapshot-card-primary {
  background: color-mix(in oklch, var(--accent-peach) 18%, white);
}

.snapshot-card-plan {
  background: color-mix(in oklch, var(--accent-sage) 18%, white);
}

.pending-stack,
.settings-list {
  display: grid;
  gap: var(--space-3);
  min-width: 0;
}

.calendar-overview {
  display: grid;
  gap: 0.72rem;
  padding: 0.72rem 0.76rem 0.78rem;
  background: var(--md-sys-color-surface-container-lowest);
  box-shadow: none;
}

.calendar-overview__head {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

.calendar-overview__actions {
  display: flex;
  align-items: center;
  gap: 0.68rem;
}

.calendar-picker-button {
  width: 2.18rem;
  height: 2.18rem;
  padding: 0;
  border: 1px solid color-mix(in oklch, var(--border-soft) 82%, white 18%);
  border-radius: 0.78rem;
  background: color-mix(in oklch, white 99%, var(--accent-sage) 1%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: 0 4px 14px oklch(0.54 0.02 60 / 0.035);
}

.calendar-manual-button {
  min-width: 4.7rem;
  justify-content: center;
}

.calendar-picker-button__icon {
  position: relative;
  width: 1rem;
  height: 0.92rem;
  display: block;
  border: 1.6px solid color-mix(in oklch, var(--fg-primary) 76%, transparent);
  border-radius: 0.25rem;
  opacity: 0.82;
}

.calendar-picker-button__icon::before,
.calendar-picker-button__icon::after {
  content: "";
  position: absolute;
}

.calendar-picker-button__icon::before {
  left: -1.6px;
  right: -1.6px;
  top: 0.16rem;
  border-top: 1.6px solid color-mix(in oklch, var(--fg-primary) 76%, transparent);
}

.calendar-picker-button__icon::after {
  left: 0.18rem;
  right: 0.18rem;
  top: -0.18rem;
  height: 0.16rem;
  border-left: 1.6px solid color-mix(in oklch, var(--fg-primary) 76%, transparent);
  border-right: 1.6px solid color-mix(in oklch, var(--fg-primary) 76%, transparent);
}

.recent-days-strip {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(3.95rem, 1fr);
  gap: 0.48rem;
  overflow-x: auto;
  padding-bottom: 0.14rem;
  scrollbar-width: none;
}

.recent-days-strip::-webkit-scrollbar {
  display: none;
}

.daily-summary-section {
  padding: 0.2rem 0.1rem 0.1rem;
}

.recent-day-pill {
  border: 1px solid var(--md-sys-color-outline-variant);
  border-radius: 0.88rem;
  background: var(--md-sys-color-surface-container-low);
  padding: 0.58rem 0.4rem 0.52rem;
  display: grid;
  gap: 0.1rem;
  justify-items: center;
  min-height: 3.95rem;
  cursor: pointer;
}

.recent-day-pill.is-active {
  background: var(--md-sys-color-primary);
  border-color: transparent;
  box-shadow: none;
}

.recent-day-pill__weekday {
  color: var(--fg-muted);
  font-size: 0.66rem;
}

.recent-day-pill.is-active .recent-day-pill__weekday,
.recent-day-pill.is-active .recent-day-pill__date {
  color: var(--md-sys-color-on-primary);
}

.recent-day-pill__date {
  font-family: "Noto Serif SC", serif;
  font-size: 0.96rem;
  color: var(--fg-primary);
}

.recent-day-pill__meta {
  display: inline-flex;
  align-items: center;
  gap: 0.22rem;
  min-height: 0.34rem;
}

.recent-dot {
  width: 0.34rem;
  height: 0.34rem;
  border-radius: 999px;
  display: inline-block;
}

.recent-dot-feed {
  background: var(--event-eat);
}

.recent-dot-care {
  background: var(--event-elimination);
}

.recent-dot-plan {
  background: var(--md-sys-color-primary);
}

.recent-dot-sleep {
  background: var(--accent-blue);
}

.daily-summary__bar {
  padding: 0.1rem 0;
}

.daily-summary__list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  column-gap: 0.6rem;
  row-gap: 0.6rem;
}

.daily-summary__value small {
  margin-left: 0.14rem;
  font-size: 0.48em;
  color: var(--fg-secondary);
}

.daily-summary__item {
  display: flex;
  align-items: center;
  min-height: 4.8rem;
  padding: 0.78rem 0.82rem 0.74rem;
  border: 1px solid var(--md-sys-color-outline-variant);
  border-radius: 0.95rem;
  background: var(--md-sys-color-surface-container-low);
  box-shadow: none;
  text-align: left;
}

.daily-summary__item[type="button"],
button.daily-summary__item {
  appearance: none;
  width: 100%;
  cursor: pointer;
  font: inherit;
}

button.daily-summary__item {
  text-align: left;
}

.daily-summary__value {
  margin: 0;
  font-family: "Noto Sans SC", sans-serif;
  font-size: 1.22rem;
  font-weight: 700;
  color: var(--fg-primary);
  line-height: 1.05;
  white-space: nowrap;
  text-align: right;
}

.daily-summary__value small {
  margin-left: 0.14rem;
  font-size: 0.54em;
  font-weight: 400;
  color: var(--fg-secondary);
}

.daily-summary__item-icon {
  width: 1.62rem;
  height: 1.62rem;
  display: inline-block;
  flex: 0 0 1.62rem;
  border-radius: 0;
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  filter: drop-shadow(0 4px 8px oklch(0.54 0.02 60 / 0.06));
}

.daily-summary__item-content {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.8rem;
  width: 100%;
}

.daily-summary__item-left {
  display: flex;
  align-items: center;
  gap: 0.52rem;
  min-height: 2.4rem;
  flex: 0 1 auto;
  min-width: 0;
}

.daily-summary__item-copy {
  display: grid;
  gap: 0.18rem;
  align-content: center;
  min-width: 0;
}

.daily-summary__label {
  margin: 0;
  color: var(--fg-primary);
  font-size: 0.92rem;
  line-height: 1.08;
  font-weight: 400;
}

.daily-summary__meta {
  margin: 0;
  color: var(--fg-muted);
  font-size: 0.76rem;
  line-height: 1.16;
  min-height: 0;
  text-align: left;
}

.daily-summary__meta-empty {
  visibility: hidden;
}

.daily-summary__item .daily-summary__value {
  margin-left: auto;
  align-self: center;
}

.daily-summary__item-top .daily-summary__value {
  margin-left: auto;
}

.daily-summary__item-feed .daily-summary__value,
.daily-summary__item-care .daily-summary__value {
  font-size: 0.96rem;
}

.pet-empty-state {
  position: relative;
  display: grid;
  grid-template-columns: minmax(6.8rem, 7.8rem) 1fr;
  gap: 0.8rem;
  align-items: end;
  min-height: 10.25rem;
  padding: 0.15rem 0.1rem 0;
  isolation: isolate;
}

.pet-empty-state__pet {
  display: grid;
  place-items: center;
  min-height: 8.8rem;
}

.pet-empty-state__pet-static {
  align-self: stretch;
  background: radial-gradient(circle at 50% 52%, color-mix(in oklch, var(--md-sys-color-primary-container) 24%, transparent), transparent 62%);
}

.pet-empty-state__pet-image {
  width: 100%;
  max-width: 7.2rem;
  height: auto;
  object-fit: contain;
  filter: drop-shadow(0 16px 20px oklch(0.54 0.02 48 / 0.12));
}

.pet-empty-state__pet-badge {
  padding: 0.42rem 0.72rem;
  border-radius: 999px;
  background: var(--md-sys-color-secondary-container);
  color: var(--md-sys-color-on-secondary-container);
  font-size: 0.78rem;
}

.pet-empty-state__bubble {
  display: grid;
  gap: 0.42rem;
  align-self: center;
  margin-bottom: 0.7rem;
  padding: 0.92rem 0.96rem 0.92rem 1rem;
  border-radius: 1.45rem 1.45rem 1.45rem 0.7rem;
  background: var(--md-sys-color-surface-container-low);
  border: 1px solid var(--md-sys-color-outline-variant);
  box-shadow: var(--shadow-card);
  position: relative;
}

.pet-empty-state__bubble::before {
  content: "";
  position: absolute;
  left: -0.62rem;
  bottom: 1rem;
  width: 1.2rem;
  height: 1.15rem;
  border-radius: 0.3rem 0.2rem 0.8rem 0.2rem;
  background: inherit;
  border-left: 1px solid color-mix(in oklch, var(--border-soft) 84%, white 16%);
  border-bottom: 1px solid color-mix(in oklch, var(--border-soft) 84%, white 16%);
  transform: rotate(18deg);
}

.pet-empty-state__badge-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
}

.pet-empty-state__signal {
  color: var(--fg-muted);
  font-size: 0.72rem;
  letter-spacing: 0.03em;
}

.pet-empty-state__line {
  margin: 0;
  font-family: "Noto Serif SC", serif;
  font-size: 0.98rem;
  line-height: 1.42;
}

.pet-empty-state__hint {
  margin: 0;
  color: var(--fg-secondary);
  font-size: 0.8rem;
  line-height: 1.55;
}

.tiger-buddy {
  position: relative;
  width: 7.4rem;
  height: 8.9rem;
  transform-origin: center bottom;
  animation: tiger-breathe 3.2s ease-in-out infinite;
}

.tiger-buddy__wind,
.tiger-buddy__body,
.tiger-buddy__head,
.tiger-buddy__arm,
.tiger-buddy__leg,
.tiger-buddy__ear,
.tiger-buddy__tail,
.tiger-buddy__belly,
.tiger-buddy__cheek,
.tiger-buddy__eye,
.tiger-buddy__brow,
.tiger-buddy__muzzle,
.tiger-buddy__nose,
.tiger-buddy__mouth,
.tiger-buddy__fang,
.tiger-buddy__stripe {
  position: absolute;
  display: block;
}

.tiger-buddy__wind {
  border-radius: 999px;
  background: linear-gradient(90deg, color-mix(in oklch, var(--md-sys-color-primary-container) 42%, transparent), transparent);
  opacity: 0.5;
}

.tiger-buddy__wind-1 {
  left: 0.25rem;
  top: 2.2rem;
  width: 1.65rem;
  height: 0.36rem;
  animation: tiger-wind 3.2s ease-in-out infinite;
}

.tiger-buddy__wind-2 {
  right: 0.1rem;
  top: 3.3rem;
  width: 1.38rem;
  height: 0.3rem;
  animation: tiger-wind 3.2s ease-in-out infinite reverse;
}

.tiger-buddy__body {
  left: 1.48rem;
  bottom: 1.15rem;
  width: 4.1rem;
  height: 4.05rem;
  border-radius: 44% 44% 32% 32%;
  background:
    radial-gradient(circle at 50% 18%, color-mix(in oklch, white 90%, transparent), transparent 30%),
    linear-gradient(180deg, color-mix(in oklch, #f6f7fb 92%, white 8%), color-mix(in oklch, #e7ebf1 94%, white 6%));
  border: 1px solid color-mix(in oklch, #d9dde4 84%, white 16%);
  box-shadow:
    inset 0 -0.32rem 0 color-mix(in oklch, #d5d9df 86%, transparent),
    0 10px 18px oklch(0.84 0.02 250 / 0.14);
}

.tiger-buddy__body::before,
.tiger-buddy__body::after {
  content: "";
  position: absolute;
  top: 0.72rem;
  width: 0.3rem;
  height: 1.8rem;
  border-radius: 999px;
  background: color-mix(in oklch, #7d8794 78%, transparent);
  opacity: 0.82;
}

.tiger-buddy__body::before {
  left: 0.85rem;
  transform: rotate(9deg);
}

.tiger-buddy__body::after {
  right: 0.84rem;
  transform: rotate(-9deg);
}

.tiger-buddy__belly {
  left: 1rem;
  top: 1rem;
  width: 2.1rem;
  height: 2.45rem;
  border-radius: 50%;
  background: color-mix(in oklch, white 92%, #fff8f1 8%);
}

.tiger-buddy__tail {
  right: 0.88rem;
  bottom: 2.25rem;
  width: 2.3rem;
  height: 0.7rem;
  border-radius: 999px;
  background: linear-gradient(90deg, color-mix(in oklch, #eceff5 88%, white 12%), color-mix(in oklch, #dde2ea 94%, white 6%));
  border: 1px solid color-mix(in oklch, #d8dde4 84%, white 16%);
  transform-origin: left center;
  transform: rotate(16deg);
  animation: tiger-tail 2.4s ease-in-out infinite;
}

.tiger-buddy__tail::after {
  content: "";
  position: absolute;
  right: 0.15rem;
  top: 0.12rem;
  width: 0.62rem;
  height: 0.42rem;
  border-radius: 50%;
  background: color-mix(in oklch, #929cab 78%, transparent);
  box-shadow:
    -0.68rem 0 0 color-mix(in oklch, #929cab 72%, transparent),
    -1.34rem 0 0 color-mix(in oklch, #929cab 66%, transparent);
}

.tiger-buddy__arm,
.tiger-buddy__leg {
  border-radius: 999px;
  background: linear-gradient(180deg, color-mix(in oklch, #f3f5fa 92%, white 8%), color-mix(in oklch, #e1e6ee 95%, white 5%));
  border: 1px solid color-mix(in oklch, #d7dce3 84%, white 16%);
}

.tiger-buddy__arm::after,
.tiger-buddy__leg::after {
  content: "";
  position: absolute;
  inset: auto 0.08rem 0.05rem;
  height: 0.32rem;
  border-radius: 999px;
  background: color-mix(in oklch, white 85%, transparent);
}

.tiger-buddy__arm {
  top: 0.92rem;
  width: 1rem;
  height: 2.05rem;
}

.tiger-buddy__arm-left {
  left: 0.62rem;
  transform-origin: top center;
  animation: tiger-wave 3.2s ease-in-out infinite;
}

.tiger-buddy__arm-right {
  right: 0.62rem;
  transform: rotate(-14deg);
}

.tiger-buddy__leg {
  bottom: -0.3rem;
  width: 1.12rem;
  height: 1.8rem;
}

.tiger-buddy__leg-left {
  left: 1rem;
}

.tiger-buddy__leg-right {
  right: 1rem;
}

.tiger-buddy__head {
  left: 0.94rem;
  top: 0.28rem;
  width: 4.55rem;
  height: 4.45rem;
  border-radius: 46% 46% 42% 42%;
  background:
    radial-gradient(circle at 50% 24%, color-mix(in oklch, white 94%, transparent), transparent 28%),
    linear-gradient(180deg, color-mix(in oklch, #fbfcfe 92%, white 8%), color-mix(in oklch, #eef2f8 96%, white 4%));
  border: 1px solid color-mix(in oklch, #dde1e8 84%, white 16%);
  box-shadow:
    inset 0 -0.22rem 0 color-mix(in oklch, #dde2ea 84%, transparent),
    0 10px 16px oklch(0.86 0.02 250 / 0.14);
}

.tiger-buddy__ear {
  top: -0.26rem;
  width: 1.22rem;
  height: 1.36rem;
  background: color-mix(in oklch, #eef2f8 95%, white 5%);
  clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
  border: 1px solid color-mix(in oklch, #d9dee6 84%, white 16%);
}

.tiger-buddy__ear::after {
  content: "";
  position: absolute;
  left: 0.22rem;
  top: 0.28rem;
  width: 0.66rem;
  height: 0.58rem;
  background: color-mix(in oklch, #f4dce4 90%, white 10%);
  clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
}

.tiger-buddy__ear-left {
  left: 0.35rem;
  transform: rotate(-10deg);
}

.tiger-buddy__ear-right {
  right: 0.35rem;
  transform: rotate(10deg);
}

.tiger-buddy__cheek {
  bottom: 1.05rem;
  width: 0.62rem;
  height: 0.34rem;
  border-radius: 999px;
  background: color-mix(in oklch, #f5cfd7 66%, transparent);
  opacity: 0.85;
}

.tiger-buddy__cheek-left {
  left: 0.94rem;
}

.tiger-buddy__cheek-right {
  right: 0.94rem;
}

.tiger-buddy__eye {
  top: 1.74rem;
  width: 0.3rem;
  height: 0.52rem;
  border-radius: 999px;
  background: color-mix(in oklch, #49505b 90%, transparent);
  transform-origin: center center;
  animation: tiger-blink 4.6s ease-in-out infinite;
}

.tiger-buddy__eye-left {
  left: 1.48rem;
}

.tiger-buddy__eye-right {
  right: 1.48rem;
}

.tiger-buddy__brow {
  top: 1.42rem;
  width: 0.68rem;
  height: 0.16rem;
  border-radius: 999px;
  background: color-mix(in oklch, #aab2be 72%, transparent);
}

.tiger-buddy__brow-left {
  left: 1.22rem;
  transform: rotate(-10deg);
}

.tiger-buddy__brow-right {
  right: 1.22rem;
  transform: rotate(10deg);
}

.tiger-buddy__muzzle {
  left: 1.18rem;
  bottom: 0.58rem;
  width: 2.18rem;
  height: 1.72rem;
  border-radius: 52% 52% 48% 48%;
  background: color-mix(in oklch, #fff8f0 94%, white 6%);
}

.tiger-buddy__nose {
  left: 1.96rem;
  top: 2.28rem;
  width: 0.54rem;
  height: 0.38rem;
  border-radius: 44% 44% 60% 60%;
  background: color-mix(in oklch, #7f8694 88%, transparent);
}

.tiger-buddy__mouth {
  left: 1.64rem;
  top: 2.72rem;
  width: 1.18rem;
  height: 0.74rem;
  border-bottom: 2px solid color-mix(in oklch, #6d7482 78%, transparent);
  border-radius: 0 0 999px 999px;
}

.tiger-buddy__fang {
  top: 2.92rem;
  width: 0.14rem;
  height: 0.28rem;
  border-radius: 999px;
  background: color-mix(in oklch, white 96%, transparent);
  opacity: 0;
}

.tiger-buddy__fang-left {
  left: 1.94rem;
}

.tiger-buddy__fang-right {
  right: 1.94rem;
}

.tiger-buddy__stripe {
  width: 0.28rem;
  height: 0.94rem;
  border-radius: 999px;
  background: color-mix(in oklch, #8c95a3 76%, transparent);
  opacity: 0.84;
}

.tiger-buddy__stripe-1 {
  left: 0.94rem;
  top: 1.06rem;
  transform: rotate(-26deg);
}

.tiger-buddy__stripe-2 {
  right: 0.94rem;
  top: 1.06rem;
  transform: rotate(26deg);
}

.tiger-buddy__stripe-3 {
  left: 2.14rem;
  top: 0.7rem;
  height: 1.02rem;
}

.tiger-buddy__stripe-4 {
  left: 2.15rem;
  top: 2.76rem;
  width: 0.16rem;
  height: 0.48rem;
}

.tiger-buddy[data-mood="wink"] .tiger-buddy__eye-left {
  height: 0.1rem;
  width: 0.62rem;
  border-radius: 999px;
}

.tiger-buddy[data-mood="wink"] .tiger-buddy__mouth {
  width: 1.34rem;
  height: 0.62rem;
}

.tiger-buddy[data-mood="awoo"] .tiger-buddy__mouth {
  left: 1.77rem;
  top: 2.56rem;
  width: 0.92rem;
  height: 0.92rem;
  border: 2px solid color-mix(in oklch, #6d7482 76%, transparent);
  border-top: 0;
  border-radius: 0 0 999px 999px;
  background: color-mix(in oklch, #f0b4bf 52%, white 48%);
}

.tiger-buddy[data-mood="awoo"] .tiger-buddy__fang {
  opacity: 1;
}

.tiger-buddy[data-mood="proud"] .tiger-buddy__brow-left {
  transform: rotate(-24deg);
}

.tiger-buddy[data-mood="proud"] .tiger-buddy__brow-right {
  transform: rotate(24deg);
}

.tiger-buddy[data-mood="proud"] .tiger-buddy__arm-left {
  transform: rotate(-28deg);
}

.tiger-buddy[data-mood="calm"] .tiger-buddy__mouth {
  height: 0.56rem;
}

.pending-card,
.settings-item,
.event-card {
  padding: var(--space-4);
  border-radius: var(--radius-md);
}

.pending-card {
  background: var(--md-sys-color-surface-container-low);
  min-height: 8.55rem;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  scroll-snap-align: start;
}

.pending-card-plan {
  background: var(--md-sys-color-secondary-container);
}

.pending-card-lite {
  min-height: auto;
  background: var(--md-sys-color-surface-container);
}

.pending-card-backfill {
  background: var(--md-sys-color-primary-container);
}

.pending-card__title {
  margin: 0;
  font-family: "Noto Sans SC", sans-serif;
  font-weight: var(--weight-semibold);
  font-size: 1.02rem;
}

.pending-card__topline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-2);
  gap: 0.75rem;
}

.pending-card__tag {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  min-width: 0;
}

.pending-card__tag-icon {
  width: 1.5rem;
  height: 1.5rem;
  opacity: 0.92;
}

.pending-card__hint {
  flex: 0 0 auto;
  padding: 0.28rem 0.52rem;
  border-radius: 999px;
  background: color-mix(in oklch, var(--md-sys-color-surface-container-highest) 78%, transparent);
  color: var(--md-sys-color-on-surface-variant);
  font-size: 0.72rem;
  line-height: 1;
}

.calendar-plans .pending-card {
  min-height: auto;
  padding: 0.88rem 0.9rem;
}

.calendar-plans .pending-card__title {
  font-size: 0.96rem;
}

.calendar-plans .support-text {
  margin-top: 0.3rem;
  font-size: 0.82rem;
}

.calendar-plans .inline-actions {
  margin-top: 0.65rem;
}

.calendar-plans .primary-button,
.calendar-plans .ghost-button {
  padding: 0.56rem 0.76rem;
  font-size: 0.82rem;
}

.calendar-plans .pending-card__topline {
  margin-bottom: 0.38rem;
}

.calendar-plans .chip {
  padding: 0.22rem 0.5rem;
  font-size: 0.68rem;
}

.event-card-band {
  background: var(--md-sys-color-surface-container-low);
}

.chip-backfill {
  background: var(--md-sys-color-primary-container);
  color: var(--md-sys-color-on-primary-container);
}

.filter-row {
  display: flex;
  gap: var(--space-2);
  overflow-x: auto;
  padding-bottom: var(--space-1);
  min-width: 0;
  overscroll-behavior-x: contain;
}

.filter-row-inline {
  margin-bottom: var(--space-3);
}

.filter-chip {
  border: 1px solid var(--md-sys-color-outline-variant);
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.62rem 0.72rem;
  border-radius: var(--radius-pill);
  background: var(--md-sys-color-surface-container-low);
  color: var(--md-sys-color-on-surface-variant);
  font-size: 0.8rem;
  white-space: nowrap;
  cursor: pointer;
}

.filter-chip-active {
  border-color: transparent;
  background: var(--md-sys-color-secondary-container);
  color: var(--md-sys-color-on-secondary-container);
  box-shadow: var(--shadow-soft);
}

.filter-chip__icon {
  width: 1.12rem;
  height: 1.12rem;
  flex: 0 0 auto;
  border-radius: 0;
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  filter: drop-shadow(0 2px 4px oklch(0.62 0.02 75 / 0.06));
}

.sheet-modal {
  position: fixed;
  inset: 0;
  z-index: 30;
}

.sheet-modal__scrim {
  position: absolute;
  inset: 0;
  background: oklch(0.2 0.01 120 / 0.24);
}

.sheet-modal__panel {
  position: absolute;
  left: 50%;
  right: 0;
  bottom: 0;
  width: min(calc(100% - 1rem), 27rem);
  transform: translateX(-50%);
  padding: 1rem 1rem calc(1.1rem + env(safe-area-inset-bottom));
  border-radius: 1.35rem 1.35rem 0 0;
  background: color-mix(in oklch, white 97%, var(--accent-sage) 3%);
  border: 1px solid color-mix(in oklch, var(--border-soft) 84%, white 16%);
  box-shadow: 0 -16px 40px oklch(0.4 0.02 120 / 0.12);
}

.sheet-modal__panel-calendar {
  padding: 0.92rem 1rem calc(1.2rem + env(safe-area-inset-bottom));
}

.sheet-modal__panel-calendar::before {
  content: "";
  display: block;
  width: 2.6rem;
  height: 0.24rem;
  margin: 0 auto 0.9rem;
  border-radius: 999px;
  background: color-mix(in oklch, var(--border-soft) 70%, white 30%);
}

.sheet-modal__grabber {
  width: 2.15rem;
  height: 0.22rem;
  margin: -0.35rem auto 0.85rem;
  border-radius: 999px;
  background: color-mix(in oklch, var(--fg-muted) 34%, transparent);
}

.sheet-modal__panel-duration {
  padding-top: 0.86rem;
}

.calendar-modal__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.9rem;
}

.calendar-modal__title {
  font-size: 1.18rem;
  color: color-mix(in oklch, var(--fg-primary) 88%, var(--accent-sage) 12%);
}

.calendar-modal__nav {
  width: 2.1rem;
  height: 2.1rem;
  border: 1px solid color-mix(in oklch, var(--border-soft) 84%, white 16%);
  border-radius: 999px;
  background: color-mix(in oklch, white 99%, var(--accent-sage) 1%);
  color: color-mix(in oklch, var(--fg-primary) 84%, var(--accent-sage) 16%);
  font-size: 1.36rem;
  line-height: 1;
}

.calendar-modal__nav:disabled {
  opacity: 0.28;
}

.calendar-modal__weekdays,
.calendar-modal__grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
}

.calendar-modal__weekdays {
  margin-bottom: 0.62rem;
}

.calendar-modal__weekdays span {
  text-align: center;
  color: var(--fg-muted);
  font-size: 0.72rem;
}

.calendar-modal__grid {
  gap: 0.42rem;
}

.calendar-modal__cell {
  aspect-ratio: 1;
  border: 0;
  border-radius: 999px;
  background: color-mix(in oklch, white 93%, var(--accent-sage) 7%);
  color: color-mix(in oklch, var(--fg-primary) 82%, var(--accent-sage) 18%);
  font-size: 0.98rem;
}

.calendar-modal__cell.is-selected {
  background: oklch(0.34 0.04 150);
  color: white;
}

.calendar-modal__cell.is-today:not(.is-selected) {
  box-shadow: inset 0 0 0 2px color-mix(in oklch, oklch(0.34 0.04 150) 72%, white 28%);
}

.calendar-modal__cell:disabled {
  opacity: 0.24;
}

.calendar-modal__cell-empty {
  aspect-ratio: 1;
}

.sheet-modal__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
}

.manual-entry {
  display: grid;
  gap: 0.9rem;
}

.manual-entry__input {
  width: 100%;
  min-height: 7.8rem;
  padding: 0.92rem 1rem;
  resize: vertical;
  border-radius: 1.05rem;
  border: 1px solid color-mix(in oklch, var(--border-soft) 86%, white 14%);
  background: color-mix(in oklch, white 99%, var(--accent-blue) 1%);
  color: var(--fg-primary);
  font: inherit;
  line-height: 1.7;
  box-shadow: inset 0 1px 0 oklch(1 0 0 / 0.6);
}

.manual-entry__input::placeholder {
  color: var(--fg-muted);
}

.manual-entry__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

.manual-entry__actions {
  display: flex;
  gap: 0.72rem;
}

.manual-entry__actions .primary-button,
.manual-entry__actions .ghost-button {
  flex: 1;
}

.sheet-modal__body {
  margin-top: 0.9rem;
}

.sheet-stat-list {
  display: grid;
  gap: 0.6rem;
}

.sheet-stat-item {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.75rem 0.8rem;
  border-radius: 1rem;
  border: 1px solid color-mix(in oklch, var(--border-soft) 84%, white 16%);
  background: color-mix(in oklch, white 99%, var(--accent-sage) 1%);
}

.sheet-stat-item__text {
  display: grid;
  gap: 0.15rem;
}

.sheet-stat-item__title,
.sheet-stat-item__meta,
.sheet-stat-item__submeta {
  margin: 0;
}

.sheet-stat-item__title {
  font-size: 0.92rem;
  color: var(--fg-primary);
}

.sheet-stat-item__meta {
  font-size: 0.76rem;
  color: var(--fg-muted);
}

.sheet-stat-item__submeta {
  font-size: 0.72rem;
  color: color-mix(in oklch, var(--fg-muted) 88%, white 12%);
}

.icon-feed-breast {
  background-image: url("../assets/icons/feed-breast.svg");
}

.icon-feed-formula {
  background-image: url("../assets/icons/feed-formula.svg");
}

.icon-summary-feed {
  background-image: url("../assets/icons/summary-feed-bottle.svg");
}

.icon-feed-solid {
  background-image: url("../assets/icons/feed-solid.svg");
}

.icon-feed-supplement {
  background-image: url("../assets/icons/feed-supplement.svg");
}

.icon-poop {
  background-image: url("../assets/icons/poop.svg");
}

.icon-pee {
  background-image: url("../assets/icons/pee.svg");
}

.icon-diaper {
  background-image: url("../assets/icons/diaper.svg");
}

.icon-summary-care {
  background-image: url("../assets/icons/summary-care-diaper.svg");
}

.icon-sleep {
  background-image: url("../assets/icons/sleep.svg");
}

.icon-summary-sleep {
  background-image: url("../assets/icons/summary-sleep-moon.svg");
}

.icon-outdoor {
  background-image: url("../assets/icons/outdoor.svg");
}

.icon-vaccine {
  background-image: url("../assets/icons/vaccine.svg");
}

.icon-reminder-plan {
  background-image: url("../assets/icons/reminder-plan.svg");
}

.icon-action-backfill {
  background-image: url("../assets/icons/action-backfill.svg");
}

.icon-status-time {
  background-image: url("../assets/icons/status-time.svg");
}

.icon-voice-mic {
  background-image: url("../assets/icons/voice-mic.svg");
}

.icon-action-confirm {
  background-image: url("../assets/icons/action-confirm.svg");
}

.icon-action-delete {
  background-image: url("../assets/icons/action-delete.svg");
}

.icon-action-edit {
  background-image: url("../assets/icons/action-edit.svg");
}

.icon-action-search {
  background-image: url("../assets/icons/action-search.svg");
}

.inline-actions,
.confirm-card__actions {
  gap: var(--space-2);
  flex-wrap: wrap;
  margin-top: var(--space-2);
}

.confirm-card__actions .primary-button,
.confirm-card__actions .ghost-button {
  padding: 0.7rem 0.92rem;
  font-size: var(--text-sm);
}

.timeline {
  display: grid;
  gap: var(--space-2);
  min-width: 0;
}

.event-card {
  display: grid;
  gap: 0.48rem;
  padding: 0.82rem 0.9rem;
  border-radius: 1rem;
  border: 1px solid color-mix(in oklch, var(--border-soft) 82%, white);
  box-shadow: none;
}

.event-card__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
}

.event-card time {
  display: inline-flex;
  align-items: center;
  color: var(--fg-secondary);
  font-size: 0.74rem;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.01em;
}

.event-time__value {
  display: inline-flex;
  align-items: center;
  padding: 0.18rem 0.02rem;
  line-height: 1;
}

.event-card__meta {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  flex-wrap: wrap;
}

.event-type-tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.45rem;
  height: 1.45rem;
  border-radius: 999px;
  background: color-mix(in oklch, var(--bg-surface) 82%, white 18%);
  border: 1px solid color-mix(in oklch, var(--border-soft) 82%, white);
}

.event-card__content {
  min-width: 0;
}

.event-card__title {
  font-size: 1rem;
}

.event-card-eat {
  background: color-mix(in oklch, var(--event-eat) 7%, white);
}

.event-card-outdoor {
  background: color-mix(in oklch, var(--event-outdoor) 7%, white);
}

.event-card-elimination {
  background: color-mix(in oklch, var(--event-elimination) 7%, white);
}

.event-card-vaccine {
  background: color-mix(in oklch, var(--event-vaccine) 6%, white);
}

.timeline-section {
  padding: 0.9rem 0.9rem 1rem;
}

.timeline-section__head {
  display: flex;
  justify-content: space-between;
  gap: var(--space-3);
  align-items: start;
  margin-bottom: 0.7rem;
}

.timeline-section .timeline {
  margin-top: var(--space-1);
}

.timeline-flow {
  display: grid;
  gap: 0.42rem;
}

.timeline-group {
  display: grid;
  grid-template-columns: 3.2rem 1fr;
  gap: 0.72rem;
  align-items: start;
}

.timeline-group__cards {
  display: grid;
  gap: 0.42rem;
  align-items: stretch;
}

.timeline-group__cards-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.timeline-group__cards-3 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.timeline-group__cards-3 .timeline-card:last-child {
  grid-column: 1 / -1;
}

.timeline-card {
  min-width: 0;
  height: 100%;
}

.timeline-card__time {
  position: relative;
  display: grid;
  justify-items: end;
  gap: 0.18rem;
  padding-top: 0.18rem;
  min-height: 100%;
}

.timeline-card__rail {
  position: absolute;
  top: 1.18rem;
  right: 0.46rem;
  bottom: -0.68rem;
  width: 1px;
  background: linear-gradient(180deg, var(--md-sys-color-outline-variant), transparent);
}

.timeline-group-last .timeline-card__rail {
  display: none;
}

.timeline-card__time-text {
  display: inline-block;
  min-width: auto;
  padding: 0;
  font-size: 0.78rem;
  color: var(--fg-muted);
  font-variant-numeric: tabular-nums;
  background: transparent;
  border: 0;
  box-shadow: none;
}

.timeline-card__dot {
  display: inline-block;
  width: 0.56rem;
  height: 0.56rem;
  border-radius: 999px;
  background: color-mix(in oklch, white 84%, var(--accent-sage) 16%);
  border: 1px solid color-mix(in oklch, var(--border-soft) 76%, white 24%);
  box-shadow: 0 0 0 4px color-mix(in oklch, white 88%, transparent);
}

.timeline-card__body {
  position: relative;
  padding: 0.8rem 0.88rem 0.78rem;
  border-radius: 1rem;
  min-height: 3.58rem;
  background: color-mix(in oklch, white 99%, var(--accent-sage) 1%);
  border: 1px solid var(--timeline-card-border);
  box-shadow: 0 6px 18px oklch(0.54 0.02 60 / 0.035);
  overflow: hidden;
}

.timeline-card__body::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 0.16rem;
  background: color-mix(in oklch, var(--accent-sage) 18%, transparent);
  opacity: 0.6;
}

.timeline-card__head {
  display: flex;
  align-items: start;
  gap: 0.34rem;
}

.timeline-card__title-row {
  display: inline-flex;
  align-items: center;
  gap: 0.46rem;
  min-width: 0;
  flex: 1;
}

.timeline-card__title-row .filter-chip__icon {
  width: 1.32rem;
  height: 1.32rem;
  filter: drop-shadow(0 3px 6px oklch(0.58 0.02 135 / 0.1));
}

.timeline-card__title {
  margin: 0;
  font-size: 0.94rem;
  font-weight: 400;
  color: var(--fg-primary);
  line-height: 1.2;
  word-break: break-word;
}

.timeline-card__detail {
  margin: 0.28rem 0 0;
  font-size: 0.8rem;
  line-height: 1.34;
  color: color-mix(in oklch, var(--fg-secondary) 94%, var(--fg-primary) 6%);
}

.timeline-card__meta {
  margin: 0.28rem 0 0;
  font-size: 0.72rem;
  line-height: 1.4;
  color: var(--fg-muted);
}

.timeline-card-session .timeline-card__detail {
  margin-top: 0.34rem;
  font-size: 0.84rem;
  font-weight: 400;
  font-variant-numeric: tabular-nums;
  color: var(--fg-primary);
}

.timeline-card-point .timeline-card__body {
  min-height: 3.35rem;
}

.timeline-card-tone-feed .timeline-card__body {
  background: var(--timeline-tone-feed);
}

.timeline-card-tone-feed .timeline-card__body::before {
  background: color-mix(in oklch, var(--event-eat) 42%, white 58%);
}

.timeline-card-tone-sleep .timeline-card__body {
  background: var(--timeline-tone-sleep);
}

.timeline-card-tone-sleep .timeline-card__body::before {
  background: color-mix(in oklch, var(--accent-blue) 42%, white 58%);
}

.timeline-card-tone-care .timeline-card__body {
  background: var(--timeline-tone-care);
}

.timeline-card-tone-care .timeline-card__body::before {
  background: color-mix(in oklch, var(--event-elimination) 42%, white 58%);
}

.timeline-card-tone-outdoor .timeline-card__body {
  background: var(--timeline-tone-outdoor);
}

.timeline-card-tone-outdoor .timeline-card__body::before {
  background: color-mix(in oklch, var(--event-outdoor) 42%, white 58%);
}

.timeline-card-tone-health .timeline-card__body {
  background: var(--timeline-tone-health);
}

.timeline-card-tone-health .timeline-card__body::before {
  background: color-mix(in oklch, var(--event-vaccine) 42%, white 58%);
}

.settings-item__title {
  font-size: var(--text-md);
  font-family: "Noto Sans SC", sans-serif;
}

.settings-item > div {
  display: grid;
  grid-template-columns: auto 1fr;
  column-gap: 0.7rem;
  row-gap: 0.12rem;
  align-items: center;
}

.settings-item > div .support-text,
.settings-item > div .settings-item__title {
  grid-column: 2;
}

.settings-item__icon {
  grid-row: 1 / span 2;
  width: 3rem;
  height: 3rem;
  border-radius: 1.02rem;
  background-position: center;
  background-repeat: no-repeat;
  background-size: 1.9rem;
  background-color: color-mix(in oklch, white 80%, var(--accent-sage) 20%);
  box-shadow:
    inset 0 1px 0 color-mix(in oklch, white 88%, transparent),
    0 8px 16px oklch(0.56 0.02 48 / 0.08);
}

.settings-item__icon-baby {
  background-image: url("../assets/illustrations/baby.svg");
}

.settings-item__icon-growth {
  background-image: url("../assets/icons/status-done.svg");
}

.settings-chevron {
  color: var(--fg-muted);
  font-size: 1.5rem;
  line-height: 1;
}

.settings-hub {
  display: grid;
  gap: var(--space-4);
}

.settings-menu {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.92rem;
}

.settings-menu.hidden,
.settings-form.hidden,
.settings-panel.hidden,
.settings-form__actions.hidden {
  display: none;
}

.settings-entry {
  width: 100%;
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: auto 1fr;
  align-items: start;
  gap: 0.86rem;
  min-height: 10.3rem;
  padding: 1.05rem 1rem 0.98rem;
  border: 1px solid var(--md-sys-color-outline-variant);
  border-radius: 1.25rem;
  background: var(--md-sys-color-surface-container-low);
  box-shadow: var(--shadow-card);
  text-align: left;
}

.settings-entry__icon {
  width: 3.2rem;
  height: 3.2rem;
  border-radius: 1.08rem;
  background-position: center;
  background-repeat: no-repeat;
  background-size: 2rem;
  background-color: var(--md-sys-color-secondary-container);
  box-shadow: none;
}

.settings-entry__icon-baby,
.settings-entry-baby .settings-entry__icon {
  background-image: url("../assets/illustrations/baby.svg");
}

.settings-entry__icon-reminder,
.settings-entry-reminder .settings-entry__icon {
  background-image: url("../assets/icons/reminder-plan.svg");
}

.settings-entry__icon-caregiver,
.settings-entry-caregiver .settings-entry__icon {
  background-image: url("../assets/illustrations/baby.svg");
}

.settings-entry__icon-voice,
.settings-entry-voice .settings-entry__icon {
  background-image: url("../assets/icons/voice-mic.svg");
}

.settings-entry__copy {
  display: grid;
  align-self: end;
  gap: 0.26rem;
}

.settings-entry__title {
  font-size: 1.06rem;
  color: var(--fg-primary);
}

.settings-entry__desc {
  font-size: 0.8rem;
  color: var(--fg-muted);
  line-height: 1.6;
}

.settings-form {
  display: grid;
  gap: var(--space-3);
}

.settings-panel {
  display: grid;
  gap: 1rem;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.settings-panel__head {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: var(--space-2);
  min-height: 2.75rem;
}

.settings-panel__head h3 {
  font-size: 1.08rem;
}

.settings-fields {
  display: grid;
  gap: 0.95rem;
}

.settings-field {
  display: grid;
  gap: 0.48rem;
}

.settings-field__label {
  font-size: 0.84rem;
  color: var(--fg-secondary);
}

.settings-section-intro {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.86rem 0.95rem;
  border: 1px solid var(--md-sys-color-outline-variant);
  border-radius: 1rem;
  background: var(--md-sys-color-surface-container-low);
}

.settings-section-intro__label {
  color: var(--fg-secondary);
  font-size: 0.84rem;
}

.settings-section-intro__value {
  padding: 0.25rem 0.65rem;
  border-radius: 999px;
  background: var(--md-sys-color-primary-container);
  color: var(--md-sys-color-on-primary-container);
  font-size: 0.78rem;
}

.settings-note-card {
  display: grid;
  gap: 0.42rem;
  padding: 0.9rem 0.95rem;
  border: 1px solid var(--md-sys-color-outline-variant);
  border-radius: 1rem;
  background: var(--md-sys-color-primary-container);
}

.settings-note-card-calm {
  border-color: var(--md-sys-color-outline-variant);
  background: var(--md-sys-color-secondary-container);
}

.settings-note-card__badge {
  width: fit-content;
  padding: 0.22rem 0.58rem;
  border-radius: 999px;
  background: var(--md-sys-color-surface-container-lowest);
  color: var(--md-sys-color-on-surface);
  font-size: 0.72rem;
}

.settings-note-card p {
  margin: 0;
  color: var(--fg-secondary);
  font-size: 0.82rem;
  line-height: 1.65;
}

.settings-delivery-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 0.46rem;
}

.settings-delivery-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.32rem;
  min-height: 2rem;
  padding: 0.42rem 0.72rem;
  border: 1px solid var(--md-sys-color-outline-variant);
  border-radius: 999px;
  background: var(--md-sys-color-surface-container-low);
  color: var(--fg-muted);
  font-size: 0.78rem;
}

.settings-delivery-chip-on {
  border-color: transparent;
  background: var(--md-sys-color-primary);
  color: var(--md-sys-color-on-primary);
  box-shadow: none;
}

.settings-delivery-chip-on::before {
  content: "";
  width: 0.42rem;
  height: 0.42rem;
  border-radius: 999px;
  background: color-mix(in oklch, white 92%, var(--accent-peach) 8%);
}

.settings-delivery-chip-pending {
  border-color: var(--md-sys-color-outline-variant);
  background: var(--md-sys-color-surface-container-low);
  color: var(--fg-muted);
}

.settings-input {
  width: 100%;
  padding: 0.9rem 0.92rem;
  border: 1px solid var(--md-sys-color-outline-variant);
  border-radius: 1rem;
  background: var(--md-sys-color-surface-container-lowest);
  color: var(--fg-primary);
  font: inherit;
}

.settings-input-inline {
  min-width: 0;
}

.settings-time-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.52rem;
}

.settings-scale-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.72rem;
}

.settings-value-row {
  width: 100%;
  min-height: 3.25rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.72rem;
  padding: 0.82rem 0.86rem;
  border: 1px solid var(--md-sys-color-outline-variant);
  border-radius: 1rem;
  background: var(--md-sys-color-surface-container-lowest);
  color: inherit;
  font: inherit;
  text-align: left;
  cursor: pointer;
}

.settings-value-row::after {
  content: "›";
  flex: 0 0 auto;
  color: color-mix(in oklch, var(--fg-muted) 72%, white 28%);
  font-size: 1.2rem;
}

.settings-scale-value {
  flex: 0 0 auto;
  padding: 0.28rem 0.62rem;
  border-radius: 999px;
  background: var(--md-sys-color-secondary-container);
  color: var(--md-sys-color-on-secondary-container);
  font-size: 0.78rem;
}

.settings-duration-modal__body {
  display: grid;
  gap: 1rem;
}

.settings-duration-modal__value {
  justify-self: center;
  padding: 0.36rem 0.82rem;
  border-radius: 999px;
  background: var(--md-sys-color-secondary-container);
  color: var(--md-sys-color-on-secondary-container);
  font-size: 0.84rem;
}

.settings-duration-wheel {
  position: relative;
  min-height: 9.65rem;
  padding: 0.35rem 0.55rem;
  border: 1px solid var(--md-sys-color-outline-variant);
  border-radius: 1.18rem;
  background: var(--md-sys-color-surface-container-lowest);
  overflow: hidden;
}

.settings-duration-wheel::before,
.settings-duration-wheel::after {
  content: "";
  pointer-events: none;
  position: absolute;
  left: 0;
  right: 0;
  z-index: 3;
  height: 2.7rem;
}

.settings-duration-wheel::before {
  top: 0;
  background: linear-gradient(180deg, var(--md-sys-color-surface-container-lowest), transparent);
}

.settings-duration-wheel::after {
  bottom: 0;
  background: linear-gradient(0deg, var(--md-sys-color-surface-container-lowest), transparent);
}

.settings-duration-wheel__frame {
  pointer-events: none;
  position: absolute;
  left: 0.8rem;
  right: 0.8rem;
  top: 50%;
  z-index: 1;
  height: 2.35rem;
  transform: translateY(-50%);
  border-radius: 0.72rem;
  background: color-mix(in oklch, white 66%, var(--accent-sage) 8%);
  box-shadow:
    inset 0 1px 0 oklch(1 0 0 / 0.72),
    0 10px 24px oklch(0.5 0.035 135 / 0.08);
}

.settings-duration-wheel__columns {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  align-items: stretch;
  gap: 0.22rem;
}

.settings-duration-wheel__column {
  height: 8.95rem;
  overflow-y: auto;
  overscroll-behavior: contain;
  scroll-snap-type: y mandatory;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
  touch-action: pan-y;
}

.settings-duration-wheel__column::-webkit-scrollbar {
  display: none;
}

.settings-duration-wheel__spacer {
  height: 3.3rem;
}

.settings-duration-wheel__option {
  width: 100%;
  min-height: 2.35rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.22rem;
  border: 0;
  border-radius: 0.72rem;
  background: transparent;
  color: color-mix(in oklch, var(--fg-muted) 78%, white 22%);
  font: inherit;
  scroll-snap-align: center;
}

.settings-duration-wheel__option strong {
  min-width: 1.85rem;
  font-size: 1rem;
  font-weight: var(--weight-medium);
  line-height: 1;
}

.settings-duration-wheel__option span {
  font-size: 0.68rem;
}

.settings-duration-wheel__option-active {
  color: var(--fg-primary);
}

.settings-duration-wheel__option-active strong {
  font-size: 1.28rem;
  font-weight: var(--weight-bold);
}

.settings-duration-wheel__divider {
  align-self: center;
  width: 1px;
  height: 2.1rem;
  background: color-mix(in oklch, var(--border-soft) 70%, transparent);
}

.settings-chip-inline {
  justify-self: start;
}

.settings-date-trigger {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  padding: 0.9rem 0.92rem;
  border: 1px solid var(--md-sys-color-outline-variant);
  border-radius: 1rem;
  background: var(--md-sys-color-surface-container-lowest);
  color: var(--fg-primary);
}

.settings-date-trigger__icon {
  width: 1.2rem;
  height: 1.2rem;
  border-radius: 0.4rem;
  background: url("../assets/icons/status-time.svg") center/1rem no-repeat;
  opacity: 0.7;
}

.settings-choice-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.46rem;
}

.settings-choice-row-tight {
  gap: 0.42rem;
}

.settings-provider-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.62rem;
}

.settings-chip {
  border: 1px solid var(--md-sys-color-outline-variant);
  border-radius: 999px;
  padding: 0.48rem 0.78rem;
  background: var(--md-sys-color-surface-container-low);
  color: var(--fg-muted);
  font-size: 0.78rem;
  cursor: pointer;
}

.settings-chip-active {
  border-color: transparent;
  background: var(--md-sys-color-primary);
  color: var(--md-sys-color-on-primary);
  box-shadow: none;
}

.settings-provider-card {
  width: 100%;
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 0.68rem;
  padding: 0.8rem 0.84rem;
  border: 1px solid color-mix(in oklch, var(--border-soft) 82%, white 18%);
  border-radius: 1rem;
  background: color-mix(in oklch, white 97%, var(--bg-surface) 3%);
  text-align: left;
}

.settings-provider-card-active {
  border-color: transparent;
  background: var(--md-sys-color-primary-container);
  box-shadow: none;
}

.settings-provider-card__icon {
  width: 2.2rem;
  height: 2.2rem;
  border-radius: 0.82rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.95rem;
  font-weight: 700;
  color: white;
}

.settings-provider-card__copy {
  display: grid;
  gap: 0.12rem;
}

.settings-provider-card__title {
  color: var(--fg-primary);
  font-size: 0.9rem;
  font-weight: 600;
}

.settings-provider-card__meta {
  color: var(--fg-muted);
  font-size: 0.72rem;
}

.settings-provider-card-qwen .settings-provider-card__icon {
  background: linear-gradient(180deg, #43b883, #258f69);
}

.settings-provider-card-deepseek .settings-provider-card__icon {
  background: linear-gradient(180deg, #3d7eff, #2452d1);
}

.settings-runtime-card {
  display: grid;
  gap: 0.62rem;
  padding: 0.88rem;
  border-radius: 1.08rem;
  border: 1px solid color-mix(in oklch, var(--border-soft) 82%, white 18%);
  background: color-mix(in oklch, white 98%, var(--accent-sage) 2%);
}

.settings-runtime-card__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
}

.settings-runtime-card__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 1.85rem;
  padding: 0.28rem 0.68rem;
  border-radius: 999px;
  background: color-mix(in oklch, white 72%, var(--accent-sage) 28%);
  color: var(--fg-primary);
  font-size: 0.74rem;
}

.settings-runtime-card__provider {
  color: var(--fg-muted);
  font-size: 0.78rem;
}

.settings-runtime-card__text {
  margin: 0;
  color: var(--fg-secondary);
  font-size: 0.8rem;
  line-height: 1.6;
}

.settings-runtime-card__grid {
  display: grid;
  gap: 0.48rem;
}

.settings-runtime-card__item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.65rem;
  padding: 0.66rem 0.72rem;
  border-radius: 0.86rem;
  background: color-mix(in oklch, white 91%, var(--accent-sage) 9%);
}

.settings-runtime-card__item-label {
  color: var(--fg-muted);
  font-size: 0.7rem;
}

.settings-runtime-card__item-value {
  color: var(--fg-primary);
  font-size: 0.82rem;
  text-align: right;
}

.voice-permission-body {
  display: grid;
  gap: 0.9rem;
}

.voice-permission-actions {
  display: flex;
  justify-content: flex-end;
}

.settings-switch {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding: 0.8rem 0.86rem;
  border-radius: 0.88rem;
  background: color-mix(in oklch, white 97%, var(--bg-surface) 3%);
  border: 1px solid color-mix(in oklch, var(--border-soft) 82%, white 18%);
}

.settings-switch input[type="checkbox"] {
  appearance: none;
  flex: 0 0 auto;
  width: 2.8rem;
  height: 1.55rem;
  border-radius: 999px;
  background: color-mix(in oklch, var(--bg-surface) 78%, var(--accent-blue) 22%);
  box-shadow: inset 0 0 0 1px color-mix(in oklch, var(--border-soft) 70%, white 30%);
  position: relative;
  transition: background var(--motion-fast) var(--ease-soft-out);
}

.settings-switch input[type="checkbox"]::before {
  content: "";
  position: absolute;
  top: 0.18rem;
  left: 0.18rem;
  width: 1.18rem;
  height: 1.18rem;
  border-radius: 999px;
  background: color-mix(in oklch, white 94%, var(--accent-sage) 6%);
  box-shadow: 0 3px 8px oklch(0.4 0.02 130 / 0.18);
  transition: transform var(--motion-fast) var(--ease-soft-out);
}

.settings-switch input[type="checkbox"]:checked {
  background: color-mix(in oklch, var(--accent-sage) 62%, var(--accent-peach) 38%);
}

.settings-switch input[type="checkbox"]:checked::before {
  transform: translateX(1.24rem);
}

.settings-toggle-target {
  transition:
    opacity var(--motion-fast) var(--ease-soft-out),
    filter var(--motion-fast) var(--ease-soft-out);
}

.settings-toggle-target-disabled {
  opacity: 0.42;
  filter: saturate(0.65);
}

.settings-toggle-target-disabled .settings-duration-wheel,
.settings-toggle-target-disabled .settings-input {
  pointer-events: none;
}

.settings-profile-card {
  display: grid;
  grid-template-columns: minmax(6.8rem, 0.9fr) 1.25fr;
  gap: 0.85rem;
  padding: 0.9rem;
  border: 1px solid var(--md-sys-color-outline-variant);
  border-radius: 1.2rem;
  background: var(--md-sys-color-surface-container-low);
}

.settings-profile-card__photo {
  position: relative;
}

.settings-profile-card__fields {
  display: grid;
  align-content: center;
  gap: 0.75rem;
}

.settings-photo__preview {
  position: relative;
  min-height: 9.2rem;
  height: 100%;
  padding: 0.9rem;
  border-radius: 1rem;
  border: 1px solid var(--md-sys-color-outline-variant);
  background: var(--md-sys-color-surface-container);
  overflow: hidden;
}

.settings-photo__preview-empty {
  display: grid;
  place-items: center;
  color: var(--fg-muted);
  font-size: 0.84rem;
}

.settings-photo__empty-copy {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.settings-photo__image {
  width: 100%;
  height: 100%;
  min-height: 9.2rem;
  object-fit: cover;
  display: block;
}

.settings-photo__upload {
  position: absolute;
  left: 50%;
  bottom: 0.58rem;
  transform: translateX(-50%);
  min-height: 1.95rem;
  padding: 0.32rem 0.72rem;
  border: 1px solid color-mix(in oklch, white 58%, transparent);
  border-radius: 999px;
  background: var(--md-sys-color-surface-container-lowest);
  color: var(--fg-primary);
  font: inherit;
  font-size: 0.76rem;
  box-shadow: var(--shadow-card);
}

.settings-input-plain {
  background: color-mix(in oklch, white 98%, var(--bg-surface) 2%);
}

.settings-caregiver-list {
  display: grid;
  gap: 0.78rem;
}

.settings-caregiver-actions {
  display: flex;
  justify-content: stretch;
  padding-top: 0.1rem;
}

.settings-caregiver-add {
  width: 100%;
}

.settings-caregiver-card {
  display: grid;
  gap: 0.82rem;
  padding: 0.94rem;
  border-radius: 1.12rem;
  background: var(--md-sys-color-surface-container-low);
  border: 1px solid var(--md-sys-color-outline-variant);
}

.settings-caregiver-card__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
}

.settings-caregiver-card__identity {
  flex: 1;
  min-width: 0;
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 0.7rem;
}

.settings-caregiver-card__avatar {
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: color-mix(in oklch, var(--accent-sage) 66%, var(--fg-primary) 16%);
  color: white;
  font-size: 0.88rem;
}

.settings-caregiver-card__name {
  margin: 0;
  color: var(--fg-primary);
  font-weight: var(--weight-semibold);
  font-size: 0.94rem;
}

.settings-caregiver-card__meta {
  margin: 0.12rem 0 0;
  color: var(--fg-muted);
  font-size: 0.76rem;
  line-height: 1.45;
}

.settings-caregiver-card__fields {
  display: grid;
  gap: 0.62rem;
}

.settings-voice-card {
  display: grid;
  border: 1px solid color-mix(in oklch, var(--border-soft) 82%, white 18%);
  border-radius: 1.08rem;
  background: color-mix(in oklch, white 98%, var(--accent-sage) 2%);
}

.settings-switch-flat {
  border: 0;
  background: transparent;
  box-shadow: none;
}

@media (max-width: 420px) {
  .settings-entry {
    min-height: 9.5rem;
    padding: 0.98rem 0.92rem 0.92rem;
  }

  .settings-profile-card {
    grid-template-columns: 1fr;
  }

  .settings-photo__preview,
  .settings-photo__image {
    min-height: 11rem;
  }

  .settings-time-row {
    grid-template-columns: 1fr;
  }
}

.settings-form__actions {
  display: flex;
  justify-content: flex-end;
}

.quick-config {
  display: grid;
  gap: var(--space-3);
  padding: 0.95rem;
  border-radius: 1rem;
  border: 1px solid color-mix(in oklch, var(--border-soft) 82%, white);
  background: color-mix(in oklch, var(--bg-surface) 90%, white);
  box-shadow: var(--shadow-card);
  animation: page-in var(--motion-base) var(--ease-soft-out);
}

.quick-config__head {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: var(--space-2);
}

.quick-config__head h3 {
  font-size: 1.05rem;
}

.quick-config__body {
  display: grid;
  gap: 0.6rem;
}

.quick-row {
  display: grid;
  gap: 0.46rem;
  padding: 0.7rem;
  border-radius: 0.8rem;
  background: color-mix(in oklch, var(--bg-surface) 80%, white);
}

.quick-row--split {
  grid-template-columns: 1fr auto;
  align-items: center;
}

.quick-row__title {
  margin: 0;
  font-size: 0.92rem;
  font-weight: var(--weight-semibold);
}

.quick-input {
  width: 100%;
  padding: 0.72rem 0.82rem;
  border: 1px solid color-mix(in oklch, var(--border-soft) 82%, white);
  border-radius: 0.8rem;
  background: color-mix(in oklch, white 96%, var(--bg-surface) 4%);
  color: var(--fg-primary);
  font: inherit;
}

.quick-input-inline + .quick-input-inline {
  margin-top: 0.36rem;
}

.quick-hidden-input {
  display: none;
}

.quick-photo-preview {
  width: 100%;
  min-height: 9rem;
  border-radius: 1rem;
  object-fit: cover;
  background: color-mix(in oklch, var(--bg-elevated) 80%, white);
  border: 1px solid color-mix(in oklch, var(--border-soft) 82%, white 18%);
}

.quick-photo-preview-empty {
  display: grid;
  place-items: center;
  color: var(--fg-muted);
  font-size: 0.84rem;
}

.quick-toggle {
  justify-self: end;
  border: 0;
  border-radius: var(--radius-pill);
  padding: 0.42rem 0.66rem;
  background: color-mix(in oklch, var(--border-soft) 84%, white);
  color: var(--fg-secondary);
  font-size: 0.76rem;
  cursor: pointer;
  transition: background var(--motion-fast) var(--ease-standard), color var(--motion-fast) var(--ease-standard);
}

.quick-toggle.is-on {
  background: color-mix(in oklch, var(--accent-sage) 32%, white);
  color: var(--fg-primary);
}

.quick-options {
  display: flex;
  flex-wrap: wrap;
  gap: 0.38rem;
}

.quick-option {
  border: 1px solid color-mix(in oklch, var(--border-soft) 82%, white 18%);
  border-radius: var(--radius-pill);
  padding: 0.38rem 0.64rem;
  background: color-mix(in oklch, white 96%, var(--bg-surface) 4%);
  color: var(--fg-muted);
  font-size: 0.74rem;
  cursor: pointer;
}

.quick-option-active {
  border-color: color-mix(in oklch, var(--accent-sage) 72%, var(--fg-primary) 28%);
  background: color-mix(in oklch, var(--accent-sage) 70%, var(--fg-primary) 16%);
  color: white;
}

.quick-config__actions {
  display: flex;
  justify-content: end;
  gap: var(--space-2);
}

.quick-chip-set {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
}

.quick-chip {
  border: 0;
  border-radius: var(--radius-pill);
  padding: 0.38rem 0.62rem;
  background: color-mix(in oklch, var(--bg-surface) 76%, var(--accent-peach) 24%);
  color: var(--fg-secondary);
  font-size: 0.74rem;
}

.quick-chip-active {
  background: color-mix(in oklch, var(--accent-peach) 34%, white);
  color: var(--fg-primary);
}

.quick-person-list {
  display: grid;
  gap: 0.45rem;
}

.quick-person {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 0.6rem;
  padding: 0.55rem 0.5rem;
  border-radius: 0.7rem;
  background: color-mix(in oklch, var(--bg-elevated) 80%, white);
}

.quick-person__avatar {
  width: 1.62rem;
  height: 1.62rem;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.7rem;
  font-weight: var(--weight-semibold);
  color: var(--fg-primary);
  background: color-mix(in oklch, var(--accent-blue) 22%, white);
}

.quick-person__name {
  margin: 0;
  font-size: 0.86rem;
  font-weight: var(--weight-semibold);
}

.settings-group {
  display: grid;
  gap: var(--space-2);
}

.settings-group-muted {
  opacity: 0.9;
}

.settings-group__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.bottom-nav {
  position: fixed;
  left: 50%;
  bottom: max(0.42rem, env(safe-area-inset-bottom));
  transform: translateX(-50%);
  width: min(calc(100% - 1rem), 24.8rem);
  display: grid;
  grid-template-columns: 4.7rem minmax(0, 1fr);
  align-items: center;
  gap: 0.6rem;
  padding: 0;
}

.bottom-nav__tabs {
  min-width: 0;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 4px;
  padding: 5px;
  border: 1px solid var(--md-sys-color-outline-variant);
  border-radius: var(--radius-pill);
  background: var(--md-sys-color-surface-container);
  box-shadow: var(--shadow-floating);
}

.site-footer {
  margin: var(--space-7) 0 0;
  padding: var(--space-4) 0 0;
  text-align: center;
  font-size: 0.72rem;
  color: var(--fg-muted);
}

.site-footer a {
  color: inherit;
  text-decoration: none;
}

.site-footer a:focus-visible,
.site-footer a:hover {
  color: var(--fg-secondary);
  text-decoration: underline;
  text-underline-offset: 0.18rem;
}

.record-reminders .section-head {
  margin-bottom: var(--space-2);
}

.voice-stage-head h2 {
  font-size: 1.28rem;
}

.voice-stage-head .ghost-button {
  flex-shrink: 0;
}

.voice-stage .support-text {
  margin-top: var(--space-1);
}

.page[data-page="record"] .context-header {
  margin-bottom: var(--space-1);
}

.voice-stage.is-confirming .voice-stage-head {
  margin-bottom: 0;
}

.voice-stage.is-confirming .transcript-rail {
  min-height: 2.1rem;
  padding: 0.55rem 0.8rem;
  font-size: var(--text-xs);
}

.voice-stage.is-query-result .voice-status-row,
.voice-stage.is-query-result .transcript-rail {
  display: none;
}

.voice-stage.is-query-result .voice-caption {
  color: var(--fg-primary);
}

.nav-tab {
  position: relative;
  display: grid;
  justify-items: center;
  gap: 2px;
  width: 100%;
  min-height: 3.45rem;
  padding: 0.42rem 0.4rem 0.5rem;
  border-radius: 999px;
  background: transparent;
  color: var(--fg-secondary);
  transition:
    transform var(--motion-fast) var(--ease-standard),
    background var(--motion-fast) var(--ease-standard),
    color var(--motion-fast) var(--ease-standard),
    box-shadow var(--motion-fast) var(--ease-standard);
}

.nav-tab-active {
  background: var(--md-sys-color-secondary-container);
  color: var(--md-sys-color-on-secondary-container);
  box-shadow: none;
  transform: translateY(-1px);
}

.nav-icon {
  width: 1.26rem;
  height: 1.26rem;
  border-radius: 0;
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  opacity: 0.86;
  filter: none;
  transition:
    transform var(--motion-fast) var(--ease-standard),
    opacity var(--motion-fast) var(--ease-standard);
}

.nav-label {
  font-size: 0.7rem;
  line-height: 1;
  letter-spacing: 0.01em;
}

.nav-tab-active .nav-icon {
  opacity: 1;
}

.nav-tab:active {
  transform: scale(0.985);
}

.toast {
  position: fixed;
  left: 50%;
  bottom: 6.6rem;
  transform: translateX(-50%) translateY(1rem);
  padding: 0.85rem 1rem;
  max-width: calc(100% - 3rem);
  border-radius: var(--radius-pill);
  background: color-mix(in oklch, var(--fg-primary) 88%, black 12%);
  color: white;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--motion-fast) var(--ease-standard), transform var(--motion-fast) var(--ease-standard);
}

.toast.toast-visible {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

@keyframes pulse {
  0%,
  100% {
    transform: scale(0.97);
    opacity: 0.72;
  }
  50% {
    transform: scale(1.04);
    opacity: 1;
  }
}

@keyframes orb-bar {
  0%,
  100% {
    transform: scaleY(0.58);
    opacity: 0.76;
  }
  45% {
    transform: scaleY(1.16);
    opacity: 1;
  }
  70% {
    transform: scaleY(0.82);
    opacity: 0.88;
  }
}

@keyframes page-in {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes tiger-breathe {
  0%,
  100% {
    transform: translateY(0) scale(1);
  }
  50% {
    transform: translateY(-3px) scale(1.015);
  }
}

@keyframes tiger-tail {
  0%,
  100% {
    transform: rotate(16deg);
  }
  50% {
    transform: rotate(34deg);
  }
}

@keyframes tiger-blink {
  0%,
  44%,
  52%,
  100% {
    transform: scaleY(1);
  }
  48% {
    transform: scaleY(0.14);
  }
}

@keyframes tiger-wave {
  0%,
  100% {
    transform: rotate(9deg);
  }
  50% {
    transform: rotate(-22deg);
  }
}

@keyframes tiger-wind {
  0%,
  100% {
    transform: translateX(0);
    opacity: 0.38;
  }
  50% {
    transform: translateX(0.4rem);
    opacity: 0.72;
  }
}

@media (min-width: 900px) {
  .phone-shell {
    margin-top: 2.5rem;
    margin-bottom: 2.5rem;
    min-height: auto;
    border-radius: 2.25rem;
    border: 1px solid color-mix(in oklch, var(--border-soft) 82%, white);
    box-shadow: 0 35px 60px oklch(0.5 0.02 45 / 0.14);
  }
}

@media (max-width: 420px) {
  .timeline-group {
    grid-template-columns: 2.7rem 1fr;
    gap: 0.58rem;
  }

  .timeline-card__time-text {
    font-size: 0.72rem;
  }

  .daily-summary__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .daily-summary__metric {
    min-height: auto;
  }

  .pet-empty-state {
    grid-template-columns: 1fr;
    gap: 0.35rem;
    justify-items: center;
  }

  .pet-empty-state__bubble {
    margin-bottom: 0;
  }

  .pet-empty-state__bubble::before {
    left: 1rem;
    bottom: auto;
    top: -0.48rem;
    transform: rotate(118deg);
  }

  .record-manual-dock {
    grid-template-columns: 1fr;
  }

  .record-manual-dock .primary-button {
    justify-content: center;
  }
}
