:root {
  color-scheme: light;
  --page: #fff7f8;
  --surface: #fffafb;
  --surface-strong: #ffffff;
  --ink: #33263a;
  --muted: #827488;
  --line: #ead8df;
  --primary: #f19ab4;
  --primary-dark: #a64372;
  --accent: #95c7f2;
  --warning: #d48b4a;
  --danger: #c75068;
  --fresh: #78c9bc;
  --wash: #fff0f4;
  --cream: #fffdf8;
  --label: #fff4df;
  --mint: #a5d9cb;
  --berry: #a64372;
  --periwinkle: #95c7f2;
  --glass: rgba(255, 250, 251, 0.82);
  --shadow: 0 34px 90px rgba(128, 80, 103, 0.2);
  --soft-shadow: 0 16px 40px rgba(139, 88, 111, 0.13);
  --font-ui: "Hiragino Maru Gothic ProN", "Tsukushi A Round Gothic", "Yu Gothic", "Avenir Next Rounded", "Arial Rounded MT Bold", sans-serif;
  --font-display: "Tsukushi A Round Gothic", "Hiragino Maru Gothic ProN", "Avenir Next Rounded", "Yu Gothic", sans-serif;
  --font-data: "Avenir Next Condensed", "DIN Alternate", "Hiragino Sans", "Yu Gothic", sans-serif;
  --text-xs: 0.76rem;
  --text-sm: 0.86rem;
  --text-md: 0.96rem;
  --text-lg: 1.08rem;
  --text-xl: 1.35rem;
  --text-2xl: 1.75rem;
  --text-3xl: 2.35rem;
  --radius-sm: 12px;
  --radius-md: 16px;
  --radius-lg: 22px;
  --radius-xl: 28px;
  font-family: var(--font-ui);
}

:root[data-theme="dark"] {
  --page: #14101a;
  --surface: #211927;
  --surface-strong: #2c2234;
  --ink: #fff8fb;
  --muted: #d5c7d4;
  --line: #5b465e;
  --primary: #ff9bbd;
  --primary-dark: #ffd4e2;
  --accent: #8bd7ff;
  --warning: #ffd089;
  --danger: #ff8da2;
  --fresh: #89e0ce;
  --wash: #1b1521;
  --cream: #241c2b;
  --label: #33243b;
  --mint: #89e0ce;
  --berry: #ff9bbd;
  --periwinkle: #8bd7ff;
  --glass: rgba(36, 28, 43, 0.92);
  --shadow: 0 26px 70px rgba(0, 0, 0, 0.52);
  --soft-shadow: 0 14px 34px rgba(0, 0, 0, 0.34);
}

:root[data-theme="aj"] {
  --page: #10071f;
  --surface: #1b0f31;
  --surface-strong: #291848;
  --ink: #fffaff;
  --muted: #e5d8ff;
  --line: #6e56a3;
  --primary: #1ef2d0;
  --primary-dark: #ff7cda;
  --accent: #f8f46a;
  --warning: #ffe88f;
  --danger: #ff8aa0;
  --fresh: #7df9ff;
  --wash: #170d2c;
  --cream: #21123a;
  --label: #31204f;
  --mint: #1ef2d0;
  --berry: #ff7cda;
  --periwinkle: #7df9ff;
  --glass: rgba(33, 22, 65, 0.92);
  --shadow: 0 26px 72px rgba(0, 0, 0, 0.56);
  --soft-shadow: 0 16px 38px rgba(0, 0, 0, 0.35);
}

:root[data-theme="calm"] {
  --page: #f5fbff;
  --surface: #ffffff;
  --surface-strong: #ffffff;
  --ink: #1f3345;
  --muted: #657a91;
  --line: #d7e7f4;
  --primary: #89c5f2;
  --primary-dark: #407daf;
  --accent: #b9e3f8;
  --warning: #ce8b48;
  --danger: #be5b72;
  --fresh: #8bcfbe;
  --wash: #eef8ff;
  --cream: #fbfdff;
  --label: #eef8ff;
  --mint: #a6dbcf;
  --berry: #6d8fc8;
  --periwinkle: #89c5f2;
  --glass: rgba(255, 255, 255, 0.86);
  --shadow: 0 18px 48px rgba(75, 112, 151, 0.13);
  --soft-shadow: 0 14px 34px rgba(75, 112, 151, 0.12);
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  min-height: 100vh;
  background: linear-gradient(135deg, #fff4f7 0%, #f6f8ff 54%, #f8fff8 100%);
  color: var(--ink);
  font-family: var(--font-ui);
  letter-spacing: 0;
}

:root[data-theme="dark"] body,
:root[data-theme="aj"] body {
  background: linear-gradient(135deg, var(--page) 0%, color-mix(in srgb, var(--surface) 72%, #000) 100%);
}

:root[data-theme="calm"] body {
  background: linear-gradient(135deg, #f7fbff 0%, #eef8ff 100%);
}

:root[data-theme="dark"] .mobile-column,
:root[data-theme="aj"] .mobile-column {
  border-color: color-mix(in srgb, var(--line) 70%, transparent);
  background: var(--surface);
}

:root[data-theme="dark"] .hero-band,
:root[data-theme="dark"] .today-hero,
:root[data-theme="dark"] .next-use-panel,
:root[data-theme="dark"] .quick-start-panel,
:root[data-theme="aj"] .hero-band,
:root[data-theme="aj"] .today-hero,
:root[data-theme="aj"] .next-use-panel,
:root[data-theme="aj"] .quick-start-panel {
  border-color: color-mix(in srgb, var(--line) 70%, transparent);
  background: var(--surface-strong);
}

:root[data-theme="dark"] .panel,
:root[data-theme="dark"] .entry-card,
:root[data-theme="dark"] .metric-item,
:root[data-theme="dark"] .label-preview article,
:root[data-theme="dark"] .settings-panel,
:root[data-theme="dark"] .action-menu details div,
:root[data-theme="aj"] .panel,
:root[data-theme="aj"] .entry-card,
:root[data-theme="aj"] .metric-item,
:root[data-theme="aj"] .label-preview article,
:root[data-theme="aj"] .settings-panel,
:root[data-theme="aj"] .action-menu details div {
  border-color: color-mix(in srgb, var(--line) 78%, transparent);
  background: var(--glass);
}

:root[data-theme="dark"] .app-nav,
:root[data-theme="dark"] .bottom-nav,
:root[data-theme="dark"] .secondary-action,
:root[data-theme="dark"] .ghost-button,
:root[data-theme="dark"] .action-menu summary,
:root[data-theme="dark"] input,
:root[data-theme="dark"] select,
:root[data-theme="dark"] textarea,
:root[data-theme="aj"] .app-nav,
:root[data-theme="aj"] .bottom-nav,
:root[data-theme="aj"] .secondary-action,
:root[data-theme="aj"] .ghost-button,
:root[data-theme="aj"] .action-menu summary,
:root[data-theme="aj"] input,
:root[data-theme="aj"] select,
:root[data-theme="aj"] textarea {
  border-color: color-mix(in srgb, var(--line) 82%, transparent);
  background: color-mix(in srgb, var(--surface-strong) 88%, transparent);
  color: var(--ink);
}

:root[data-theme="dark"] .app-nav button.active,
:root[data-theme="dark"] .bottom-nav button.active,
:root[data-theme="aj"] .app-nav button.active,
:root[data-theme="aj"] .bottom-nav button.active {
  background: color-mix(in srgb, var(--primary) 20%, var(--surface-strong));
  color: var(--ink);
}

:root[data-theme="dark"] .nav-count,
:root[data-theme="aj"] .nav-count {
  background: color-mix(in srgb, var(--primary) 24%, var(--surface-strong));
  color: var(--ink);
}

:root[data-theme="dark"] .status-pill,
:root[data-theme="aj"] .status-pill {
  background: color-mix(in srgb, var(--primary) 18%, var(--surface-strong));
  color: var(--ink);
}

:root[data-theme="dark"] .progress-track,
:root[data-theme="aj"] .progress-track {
  background: color-mix(in srgb, var(--line) 48%, var(--surface));
}

:root[data-theme="dark"] .appliance,
:root[data-theme="aj"] .appliance {
  border-color: color-mix(in srgb, var(--line) 68%, transparent);
  background: var(--surface-strong);
}

:root[data-theme="dark"] .mini-bag,
:root[data-theme="aj"] .mini-bag {
  background: color-mix(in srgb, var(--surface-strong) 86%, transparent);
}

:root[data-theme="dark"] .warning .status-pill,
:root[data-theme="aj"] .warning .status-pill {
  background: color-mix(in srgb, var(--warning) 28%, var(--surface-strong));
  color: var(--ink);
}

:root[data-theme="dark"] .expired .status-pill,
:root[data-theme="dark"] .discarded .status-pill,
:root[data-theme="aj"] .expired .status-pill,
:root[data-theme="aj"] .discarded .status-pill {
  background: color-mix(in srgb, var(--danger) 28%, var(--surface-strong));
  color: var(--ink);
}

:root[data-theme="dark"] .used .status-pill,
:root[data-theme="aj"] .used .status-pill {
  background: color-mix(in srgb, var(--muted) 24%, var(--surface-strong));
  color: var(--ink);
}

:root[data-theme="dark"] .alert-banner,
:root[data-theme="aj"] .alert-banner {
  border-color: color-mix(in srgb, var(--warning) 42%, var(--line));
  background: color-mix(in srgb, var(--warning) 16%, var(--surface));
}

:root[data-theme="dark"] .today-hero::after,
:root[data-theme="aj"] .today-hero::after {
  display: none;
}

:root[data-theme="aj"] .primary-action,
:root[data-theme="aj"] .use-action,
:root[data-theme="aj"] .appliance-head span {
  color: #12071f;
}

button,
input,
select,
textarea {
  font: inherit;
}

button {
  cursor: pointer;
}

.app-shell {
  width: min(1220px, calc(100% - 32px));
  min-height: 100vh;
  margin: 0 auto;
  padding: 42px 0 64px;
}

.desktop-layout {
  display: grid;
  grid-template-columns: minmax(360px, 430px) minmax(0, 1fr);
  gap: 40px;
  align-items: start;
}

.mobile-column {
  position: relative;
  overflow: visible;
  min-width: 0;
  padding: 26px 24px 24px;
  border: 1px solid rgba(255, 255, 255, 0.78);
  border-radius: 34px;
  background: var(--surface-strong);
  box-shadow: var(--shadow);
  backdrop-filter: blur(14px);
}

.mobile-column::before {
  content: "";
  position: absolute;
  top: 0;
  right: 24px;
  left: 24px;
  height: 5px;
  border-radius: 0 0 999px 999px;
  background: var(--primary);
}

.mobile-column > * {
  position: relative;
}

.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 2px 2px 22px;
}

.app-nav {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin: 0 0 18px;
  padding: 6px;
  border: 1px solid color-mix(in srgb, var(--line) 80%, transparent);
  border-radius: 20px;
  background: color-mix(in srgb, var(--surface-strong) 82%, var(--wash));
}

.app-nav button,
.bottom-nav button {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  min-height: 42px;
  border: 0;
  border-radius: 14px;
  background: transparent;
  color: var(--muted);
  font-weight: 850;
}

.app-nav button {
  flex-direction: column;
  gap: 4px;
}

.app-nav button strong {
  font-size: var(--text-sm);
}

.app-nav button.active,
.bottom-nav button.active {
  background: var(--surface-strong);
  color: var(--primary-dark);
  box-shadow: var(--soft-shadow);
}

.nav-count {
  display: inline-grid;
  min-width: 22px;
  height: 22px;
  place-items: center;
  border-radius: 999px;
  background: color-mix(in srgb, var(--primary) 12%, var(--surface-strong));
  color: var(--primary-dark);
  font-size: var(--text-xs);
}

.bottom-nav {
  display: none;
}

.top-controls,
.section-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.icon {
  width: 19px;
  height: 19px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.theme-select {
  position: relative;
  display: grid;
  width: 42px;
  height: 42px;
  place-items: center;
  border: 1px solid transparent;
  border-radius: 999px;
  color: var(--muted);
}

.theme-select:hover,
.icon-button:hover {
  border-color: var(--line);
  background: rgba(255, 255, 255, 0.72);
  color: var(--primary-dark);
}

.theme-select select {
  position: absolute;
  inset: 0;
  min-height: 42px;
  opacity: 0;
  cursor: pointer;
}

.sort-control select {
  min-height: 40px;
  padding: 8px 34px 8px 10px;
}

.icon-button {
  display: grid;
  width: 42px;
  min-height: 42px;
  place-items: center;
  border: 1px solid transparent;
  border-radius: 999px;
  background: transparent;
  color: var(--muted);
  padding: 0;
}

.icon-text-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.settings-menu {
  position: relative;
}

.settings-menu summary {
  list-style: none;
}

.settings-menu summary::-webkit-details-marker {
  display: none;
}

.settings-panel {
  position: absolute;
  z-index: 20;
  top: calc(100% + 8px);
  right: 0;
  display: grid;
  gap: 14px;
  width: 260px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: var(--surface-strong);
  box-shadow: var(--shadow);
}

.switch-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.switch-row input {
  width: 46px;
  height: 26px;
  accent-color: var(--primary);
}

.app-brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--ink);
  font-weight: 950;
  letter-spacing: 0;
  text-decoration: none;
}

.app-brand img,
.brand-mark img {
  width: 44px;
  height: 44px;
  border: 2px solid var(--surface-strong);
  border-radius: 14px;
  box-shadow: 0 10px 26px color-mix(in srgb, var(--primary) 26%, transparent);
}

.onboarding {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(320px, 0.7fr);
  gap: 48px;
  align-items: center;
  min-height: calc(100vh - 88px);
}

.brand-mark img {
  width: 76px;
  height: 76px;
  border-radius: 20px;
}

.onboarding-copy h1,
.hero-band h1,
.today-hero h1,
.edit-layout h1 {
  font-family: var(--font-display);
  margin: 6px 0 14px;
  max-width: 760px;
  font-size: var(--text-3xl);
  line-height: 1.02;
  letter-spacing: 0;
}

.onboarding-copy p:not(.eyebrow),
.hero-band p,
.today-hero p,
.edit-layout > div > p {
  max-width: 620px;
  color: var(--muted);
  font-size: var(--text-md);
  line-height: 1.55;
}

.eyebrow {
  margin: 0;
  color: color-mix(in srgb, var(--primary-dark) 78%, var(--muted));
  font-size: var(--text-xs);
  font-family: var(--font-data);
  font-weight: 850;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.panel {
  background: var(--glass);
  border: 1px solid rgba(255, 255, 255, 0.74);
  border-radius: 24px;
  box-shadow: var(--soft-shadow);
}

.form-panel {
  display: grid;
  gap: 18px;
  padding: 24px;
}

label,
fieldset {
  display: grid;
  gap: 8px;
  min-width: 0;
}

fieldset {
  margin: 0;
  padding: 0;
  border: 0;
}

label span,
legend {
  color: var(--ink);
  font-size: var(--text-sm);
  font-weight: 750;
}

input,
select,
textarea {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--surface-strong);
  color: var(--ink);
  padding: 12px 13px;
  outline: 0;
}

textarea {
  resize: vertical;
}

input:focus,
select:focus,
textarea:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--primary) 22%, transparent);
}

.segmented {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  padding: 4px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: color-mix(in srgb, var(--wash) 76%, var(--surface-strong));
}

.segmented label {
  display: block;
}

.segmented input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.segmented span {
  display: grid;
  min-height: 42px;
  place-items: center;
  border-radius: 14px;
  color: var(--muted);
  font-weight: 800;
}

.segmented input:checked + span {
  background: var(--surface-strong);
  color: var(--primary-dark);
  box-shadow: 0 6px 16px rgba(64, 54, 43, 0.12);
}

.primary-action,
.secondary-action,
.ghost-button,
.danger-action,
.use-action,
.text-button {
  min-height: 44px;
  border: 0;
  border-radius: 16px;
  font-weight: 850;
  letter-spacing: 0;
}

.primary-action {
  background: var(--primary-dark);
  color: white;
  padding: 0 20px;
  box-shadow: 0 16px 34px color-mix(in srgb, var(--primary) 34%, transparent);
}

.primary-action:hover {
  background: var(--primary-dark);
}

.secondary-action,
.ghost-button {
  background: color-mix(in srgb, var(--surface-strong) 78%, transparent);
  border: 1px solid var(--line);
  color: var(--ink);
  padding: 0 15px;
}

.danger-action {
  background: #f7e2de;
  color: var(--danger);
  padding: 0 16px;
}

.use-action {
  background: var(--primary-dark);
  color: var(--surface-strong);
  padding: 0 16px;
}

.use-action:hover {
  background: color-mix(in srgb, var(--primary-dark) 82%, var(--ink));
}

.text-button {
  min-height: 36px;
  background: transparent;
  color: var(--primary-dark);
  padding: 0;
}

.form-note,
.muted,
.stat-card p,
.entry-foot,
.entry-notes {
  color: var(--muted);
}

.form-note {
  margin: 0;
  font-size: var(--text-sm);
  line-height: 1.5;
}

.hero-band {
  display: grid;
  grid-template-columns: 1fr;
  align-items: center;
  gap: 24px;
  padding: 28px;
  border: 1px solid rgba(255, 255, 255, 0.82);
  border-radius: 30px;
  background: var(--surface-strong);
  box-shadow: var(--soft-shadow);
}

.hero-band h1 {
  font-size: var(--text-3xl);
}

.today-hero {
  position: relative;
  display: grid;
  gap: 18px;
  margin: 2px 0 18px;
  padding: 22px;
  border: 1px solid color-mix(in srgb, var(--line) 82%, transparent);
  border-radius: var(--radius-xl);
  background: var(--surface-strong);
  box-shadow: var(--soft-shadow);
}

.today-hero::after {
  display: none;
}

.today-hero-copy p:not(.eyebrow) {
  margin: 10px 0 0;
  max-width: 100%;
  font-size: var(--text-sm);
  line-height: 1.55;
}

.today-ledger {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
  gap: 10px;
  margin-top: 12px;
}

.today-total {
  display: grid;
  gap: 6px;
  min-width: 0;
  padding: 14px;
  border: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
  border-radius: 18px;
  background: color-mix(in srgb, var(--surface-strong) 72%, transparent);
}

.today-total span,
.metric-item span {
  display: inline-flex;
  align-items: center;
  gap: 7px;
}

.today-total .icon,
.metric-item .icon {
  width: 17px;
  height: 17px;
}

.today-total strong {
  font-family: var(--font-data);
  font-size: var(--text-3xl);
  line-height: 0.95;
}

.today-total small {
  color: var(--muted);
  font-size: var(--text-sm);
  line-height: 1.35;
}

.feed-time {
  background: color-mix(in srgb, var(--accent) 14%, var(--surface-strong));
}

.today-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin: 18px 0 20px;
}

.next-use-panel,
.quick-start-panel {
  position: relative;
  display: grid;
  gap: 14px;
  margin: 18px 0 26px;
  padding: 20px;
  border: 1px dashed color-mix(in srgb, var(--primary-dark) 34%, var(--line));
  border-radius: 24px;
  background: var(--surface-strong);
  box-shadow: var(--soft-shadow);
}

.next-use-panel::before,
.quick-start-panel::before {
  display: none;
}

.next-use-panel {
  grid-template-columns: minmax(0, 1fr);
}

.next-use-copy {
  display: grid;
  gap: 8px;
}

.next-use-copy > div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.next-use-copy h2,
.quick-start-panel h2,
.stash-header h1 {
  font-family: var(--font-display);
  margin: 0;
  font-size: var(--text-2xl);
  line-height: 1.08;
}

.next-use-copy h2 {
  display: inline-flex;
  align-items: center;
  gap: 9px;
}

.next-use-copy h2 .icon {
  width: 25px;
  height: 25px;
  color: var(--primary-dark);
}

.next-use-copy strong {
  color: var(--primary-dark);
  font-size: var(--text-xl);
}

.next-use-copy p,
.quick-start-panel p,
.stash-header p {
  margin: 0;
  color: var(--muted);
  line-height: 1.55;
}

.next-use-actions .action-menu {
  justify-content: stretch;
}

.next-use-actions .use-action {
  flex: 1;
}

.quick-start-panel > div {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.stash-header {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 16px;
  padding: 12px 0 8px;
}

.add-action {
  min-width: 132px;
}

.alert-banner {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  margin: 18px 0;
  padding: 15px 17px;
  border: 1px solid rgba(255, 255, 255, 0.72);
  border-radius: 20px;
  background: color-mix(in srgb, var(--warning) 12%, var(--surface-strong));
  color: var(--ink);
}

.alert-banner span {
  color: var(--muted);
}

.metric-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 9px;
  overflow: hidden;
  margin: 14px 0 26px;
  border: 0;
  border-radius: 0;
  background: transparent;
}

.metric-item {
  display: grid;
  gap: 6px;
  min-width: 0;
  padding: 14px;
  border: 1px solid color-mix(in srgb, var(--line) 74%, transparent);
  border-radius: 18px;
  background: var(--surface-strong);
  box-shadow: 0 10px 26px color-mix(in srgb, var(--primary) 9%, transparent);
}

.metric-item span,
.metric-item small {
  color: var(--muted);
  font-size: var(--text-sm);
}

.metric-item strong {
  font-family: var(--font-data);
  overflow-wrap: anywhere;
  color: var(--ink);
  font-size: var(--text-xl);
  line-height: 1;
}

.alert-banner.gentle {
  border-color: color-mix(in srgb, var(--primary) 30%, var(--line));
  background: color-mix(in srgb, var(--primary) 12%, var(--surface-strong));
  color: var(--ink);
}

.alert-banner.gentle span {
  color: var(--muted);
}

.stats-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  margin: 18px 0 34px;
}

.stat-card {
  display: grid;
  gap: 8px;
  min-height: 150px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: color-mix(in srgb, var(--surface) 84%, transparent);
}

.stat-card span {
  color: var(--muted);
  font-size: var(--text-sm);
  font-weight: 800;
}

.stat-card strong {
  overflow-wrap: anywhere;
  font-size: var(--text-2xl);
  line-height: 1.04;
}

.stat-card p {
  margin: 0;
  line-height: 1.45;
}

.list-section {
  display: grid;
  gap: 16px;
}

.attention-section {
  display: grid;
  gap: 14px;
  margin-top: 8px;
}

.view-heading {
  display: grid;
  gap: 8px;
  margin: 4px 0 20px;
}

.view-heading h1 {
  margin: 0;
  font-size: var(--text-3xl);
  line-height: 1.04;
}

.view-heading p:not(.eyebrow) {
  margin: 0;
  color: var(--muted);
  line-height: 1.55;
}

.labels-heading {
  grid-template-columns: 1fr auto;
  align-items: end;
  gap: 18px;
}

.label-preview {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.label-preview article {
  display: grid;
  gap: 6px;
  min-height: 150px;
  padding: 16px;
  border: 1px dashed color-mix(in srgb, var(--primary-dark) 42%, var(--line));
  border-radius: 18px;
  background: var(--surface-strong);
}

.label-preview strong {
  color: var(--primary-dark);
}

.label-preview span {
  color: var(--muted);
  font-size: var(--text-sm);
}

.section-heading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.section-heading.compact {
  align-items: center;
}

.section-heading.compact h2 {
  font-size: var(--text-xl);
}

.section-heading h2 {
  margin: 4px 0 0;
  font-size: var(--text-xl);
  letter-spacing: 0;
}

.sort-control {
  gap: 6px;
}

.sort-control span {
  color: var(--primary-dark);
  font-size: var(--text-xs);
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.tabs {
  display: inline-grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
  width: min(100%, 360px);
  padding: 5px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: color-mix(in srgb, var(--surface) 76%, transparent);
}

.tabs button {
  min-height: 42px;
  border: 0;
  border-radius: 6px;
  background: transparent;
  color: var(--muted);
  font-weight: 850;
}

.tabs button.active {
  background: var(--surface-strong);
  color: var(--primary-dark);
  box-shadow: 0 6px 16px rgba(64, 54, 43, 0.1);
}

.tabs span {
  display: inline-grid;
  min-width: 24px;
  height: 24px;
  margin-left: 6px;
  place-items: center;
  border-radius: 999px;
  background: color-mix(in srgb, var(--primary) 12%, var(--surface-strong));
  color: var(--primary-dark);
  font-size: var(--text-xs);
}

.entry-list {
  display: grid;
  gap: 14px;
}

.compact-list .entry-card {
  padding: 15px;
}

.compact-list .entry-card:not(.warning):not(.expired) {
  background: color-mix(in srgb, var(--surface-strong) 54%, transparent);
}

.entry-card {
  position: relative;
  overflow: visible;
  display: grid;
  gap: 12px;
  padding: 16px;
  border: 1px solid color-mix(in srgb, var(--line) 76%, transparent);
  border-left: 6px solid var(--periwinkle);
  border-radius: 22px;
  background: var(--surface-strong);
  box-shadow: 0 14px 34px color-mix(in srgb, var(--primary) 10%, transparent);
}

.entry-card:has(details[open]) {
  z-index: 30;
}

.entry-card.warning {
  border-color: color-mix(in srgb, var(--warning) 46%, rgba(255,255,255,0.74));
  border-left-color: var(--warning);
  background: color-mix(in srgb, var(--warning) 10%, var(--surface));
}

.entry-card.expired {
  border-color: color-mix(in srgb, var(--danger) 46%, rgba(255,255,255,0.74));
  border-left-color: var(--danger);
  opacity: 0.74;
}

.entry-card.used {
  border-color: color-mix(in srgb, #8f8277 22%, rgba(255,255,255,0.74));
  border-left-color: color-mix(in srgb, var(--muted) 80%, var(--line));
  background: color-mix(in srgb, #8f8277 14%, var(--surface));
}

.entry-card.discarded {
  border-color: color-mix(in srgb, var(--danger) 30%, rgba(255,255,255,0.74));
  border-left-color: var(--danger);
  background: color-mix(in srgb, var(--danger) 9%, var(--surface));
}

.entry-main,
.entry-foot,
.entry-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.entry-main > div:not(.entry-storage-icon) {
  flex: 1;
  min-width: 0;
}

.entry-storage-icon {
  display: grid;
  flex: 0 0 42px;
  width: 42px;
  height: 42px;
  place-items: center;
  border: 1px solid color-mix(in srgb, var(--line) 74%, transparent);
  border-radius: 15px;
  background: color-mix(in srgb, var(--accent) 15%, var(--surface-strong));
  color: var(--primary-dark);
}

.entry-storage-icon.freezer {
  background: color-mix(in srgb, var(--accent) 20%, var(--surface-strong));
}

.entry-storage-icon.fridge {
  background: color-mix(in srgb, var(--mint) 24%, var(--surface-strong));
}

.entry-storage-icon .icon {
  width: 22px;
  height: 22px;
}

.entry-date {
  margin: 0 0 3px;
  color: var(--muted);
  font-size: var(--text-sm);
  font-weight: 800;
}

.entry-card h3 {
  font-family: var(--font-data);
  margin: 0;
  font-size: var(--text-2xl);
  letter-spacing: 0;
}

.entry-card .muted {
  margin: 4px 0 0;
}

.status-pill {
  flex: 0 0 auto;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 22%, var(--surface-strong));
  color: var(--primary-dark);
  padding: 8px 11px;
  font-size: var(--text-sm);
  font-weight: 850;
}

.warning .status-pill {
  background: #fce3bf;
  color: #743b09;
}

.expired .status-pill {
  background: #f7d8d4;
  color: var(--danger);
}

.used .status-pill {
  background: #e6ded5;
  color: #5f5349;
}

.discarded .status-pill {
  background: #f7d8d4;
  color: var(--danger);
}

.progress-track {
  height: 8px;
  overflow: hidden;
  border-radius: 999px;
  background: color-mix(in srgb, var(--line) 62%, var(--surface-strong));
}

.progress-track span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: var(--primary);
}

.warning .progress-track span {
  background: var(--warning);
}

.expired .progress-track span {
  background: var(--danger);
}

.used .progress-track span {
  background: #8f8277;
}

.discarded .progress-track span {
  background: var(--danger);
}

.entry-foot {
  flex-wrap: wrap;
  font-size: var(--text-sm);
}

.entry-notes {
  margin: 0;
  padding-top: 2px;
  line-height: 1.5;
}

.empty-state {
  display: grid;
  place-items: center;
  min-height: 220px;
  padding: 28px;
  border: 1px dashed var(--line);
  border-radius: 24px;
  background: color-mix(in srgb, var(--surface-strong) 72%, transparent);
  text-align: center;
}

.empty-state strong {
  font-size: var(--text-lg);
}

.empty-state p {
  margin: 8px 0 0;
  color: var(--muted);
}

.edit-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.8fr) minmax(320px, 0.8fr);
  gap: 36px;
  align-items: start;
  padding-top: 34px;
}

.form-actions {
  display: flex;
  justify-content: flex-end;
  gap: 12px;
}

.action-menu {
  display: flex;
  align-items: center;
  gap: 8px;
}

.action-menu details {
  position: relative;
}

.action-menu summary {
  display: grid;
  min-height: 44px;
  place-items: center;
  padding: 0 14px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: color-mix(in srgb, var(--surface-strong) 82%, transparent);
  color: var(--ink);
  font-weight: 850;
  list-style: none;
}

.action-menu summary::-webkit-details-marker {
  display: none;
}

.action-menu details div {
  position: absolute;
  z-index: 40;
  right: 0;
  top: calc(100% + 8px);
  display: grid;
  min-width: 180px;
  padding: 8px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: var(--surface-strong);
  box-shadow: var(--shadow);
}

.entry-list > .entry-card:last-child .action-menu details div {
  top: auto;
  bottom: calc(100% + 8px);
}

.action-menu details button {
  min-height: 40px;
  border: 0;
  border-radius: 6px;
  background: transparent;
  color: var(--ink);
  text-align: left;
  font-weight: 800;
}

.action-menu details button:not(:disabled):hover {
  background: color-mix(in srgb, var(--primary) 12%, transparent);
}

.action-menu details button:disabled {
  color: var(--muted);
  cursor: default;
}

.history-stats {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}

.cold-preview {
  position: sticky;
  top: 24px;
  display: grid;
  gap: 18px;
  min-height: calc(100vh - 48px);
  align-content: start;
}

.cold-preview-copy {
  padding: 10px 4px 0;
}

.cold-preview-copy h2 {
  margin: 6px 0 8px;
  max-width: 12ch;
  font-size: var(--text-3xl);
  line-height: 1.04;
}

.cold-preview-copy p:not(.eyebrow) {
  max-width: 460px;
  color: var(--muted);
  line-height: 1.6;
}

.appliance {
  display: grid;
  gap: 0;
  overflow: hidden;
  border: 12px solid color-mix(in srgb, var(--surface-strong) 70%, transparent);
  border-radius: 36px;
  background: var(--surface-strong);
  box-shadow: var(--shadow);
}

.appliance-section {
  position: relative;
  min-height: 250px;
  padding: 24px 28px 26px 52px;
  border-bottom: 1px solid var(--line);
}

.appliance-section.fridge {
  border-bottom: 0;
}

.appliance-handle {
  position: absolute;
  left: 18px;
  top: 52px;
  width: 12px;
  height: 120px;
  border-radius: 999px;
  background: var(--primary);
}

.appliance-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 18px;
}

.appliance-head strong {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  font-size: var(--text-xl);
}

.appliance-head strong .icon {
  width: 24px;
  height: 24px;
  color: var(--primary-dark);
}

.appliance-head span {
  display: grid;
  width: 34px;
  height: 34px;
  place-items: center;
  border-radius: 999px;
  background: var(--primary-dark);
  color: white;
  font-weight: 900;
}

.appliance-shelf {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(82px, 1fr));
  gap: 10px;
}

.mini-bag {
  display: grid;
  gap: 4px;
  min-height: 78px;
  padding: 12px 10px;
  border: 1px solid color-mix(in srgb, var(--primary) 28%, var(--line));
  border-radius: 18px 18px 22px 22px;
  background: color-mix(in srgb, var(--surface-strong) 76%, transparent);
  box-shadow: 0 10px 24px color-mix(in srgb, var(--accent) 16%, transparent);
  text-align: center;
}

.mini-bag .icon {
  justify-self: center;
  width: 20px;
  height: 20px;
  color: var(--primary-dark);
}

.mini-bag.warning {
  border-color: var(--warning);
}

.mini-bag.expired {
  border-color: var(--danger);
}

.mini-bag span,
.empty-shelf {
  color: var(--muted);
  font-size: var(--text-sm);
}

.print-labels {
  display: none;
}

.print-labels > div {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.print-labels article {
  display: grid;
  gap: 5px;
  min-height: 132px;
  padding: 14px;
  border: 1px dashed #333;
  border-radius: 8px;
  color: #111;
  background: white;
}

@media (max-width: 760px) {
  .app-shell {
    width: min(100% - 20px, 1120px);
    padding-top: 12px;
    padding-bottom: 104px;
  }

  .mobile-column {
    overflow: visible;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    backdrop-filter: none;
  }

  .mobile-column::before {
    display: none;
  }

  .desktop-layout {
    grid-template-columns: 1fr;
  }

  .cold-preview {
    display: none;
  }

  .app-nav {
    display: none;
  }

  .bottom-nav {
    position: fixed;
    z-index: 30;
    right: 12px;
    bottom: 12px;
    left: 12px;
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 5px;
    padding: 6px;
    border: 1px solid color-mix(in srgb, var(--line) 72%, transparent);
    border-radius: 22px;
    background: color-mix(in srgb, var(--surface-strong) 88%, transparent);
    box-shadow: 0 18px 48px color-mix(in srgb, var(--primary) 20%, transparent);
    backdrop-filter: blur(12px);
  }

  .bottom-nav button {
    flex-direction: column;
    gap: 3px;
    min-height: 58px;
    border-radius: 16px;
    font-size: var(--text-xs);
  }

  .bottom-nav .icon {
    width: 18px;
    height: 18px;
  }

  .bottom-nav .bottom-add {
    background: var(--primary-dark);
    color: white;
    box-shadow: 0 8px 20px color-mix(in srgb, var(--primary) 35%, transparent);
  }

  .topbar,
  .top-controls,
  .section-actions {
    flex-wrap: wrap;
  }

  .topbar {
    flex-wrap: nowrap;
  }

  .top-controls {
    flex: 0 0 auto;
    flex-wrap: nowrap;
    gap: 6px;
    margin-left: auto;
  }

  .section-actions {
    width: 100%;
  }

  .theme-select,
  .settings-menu {
    flex: 0 0 42px;
  }

  .theme-select select {
    width: 42px;
  }

  .settings-panel {
    right: 0;
    left: auto;
    width: min(86vw, 280px);
  }

  .onboarding,
  .edit-layout {
    grid-template-columns: 1fr;
    gap: 24px;
    min-height: auto;
    padding-top: 18px;
  }

  .hero-band,
  .today-hero,
  .stash-header,
  .section-heading,
  .alert-banner {
    align-items: stretch;
    flex-direction: column;
  }

  .hero-band,
  .today-hero {
    padding: 24px;
    border-radius: 28px;
  }

  .today-hero {
    margin-top: 2px;
  }

  .today-ledger {
    grid-template-columns: 1fr;
  }

  .today-hero::after {
    right: 20px;
    top: 22px;
    bottom: auto;
    width: 58px;
    height: 38px;
    opacity: 0.4;
  }

  .stats-grid {
    grid-template-columns: 1fr;
  }

  .today-summary,
  .metric-strip {
    grid-template-columns: 1fr;
  }

  .entry-main {
    align-items: flex-start;
  }

  .entry-main .status-pill {
    margin-left: auto;
  }

  .stash-header {
    display: flex;
  }

  .labels-heading,
  .label-preview {
    grid-template-columns: 1fr;
  }

  .entry-actions,
  .form-actions {
    justify-content: stretch;
    flex-wrap: wrap;
  }

  .entry-actions button,
  .action-menu,
  .action-menu .use-action,
  .form-actions button,
  .add-action,
  .secondary-action {
    width: 100%;
  }

  .action-menu details,
  .action-menu summary {
    width: 100%;
  }
}

@media print {
  body {
    background: white;
  }

  .screen-content {
    display: none !important;
  }

  .app-shell {
    width: 100%;
    min-height: auto;
    padding: 0;
  }

  .desktop-layout {
    display: block;
  }

  .print-labels {
    display: grid;
    gap: 16px;
    padding: 20px;
  }
}
