/* 1rem = 16px; 1px = .0625rem */

:root {
  --base: #0f172a;
  --card-bg: rgba(30, 41, 59, 0.7);
  --glass-border: rgba(255, 255, 255, 0.1);
  --neon-accent: #fdba74;
  --text-dark: #f8fafc;
  --text-subtle: #94a3b8;
  --point: .0625rem;
  --double-point: .125rem;
  --four-point: .25rem;
  --eight-point: .5rem;
  --twelve-point: .75rem;
  --sixteen-point: 1rem;
  --full: 100vh;
  --black: #000;
  --gray-4: #444;
  --gray-6: #666;
  --gray-8: #888;
  --gray-9: #999;
  --gray-a: #aaa;
  --gray-b: #bbb;
  --gray-c: #ccc;
  --gray-d: #ddd;
  --gray-e: #eee;
  --light-e7: #e7e7e7;
  --light-f0: #f0f0f0;
  --light-f7: #f7f7f7;
  --light-fa: #fafafa;
  --white: #fff;
  --clear-gray-50: rgb(0 0 0 / .5);
  --clear-gray-1: rgb(0 0 0 / .0625);
  --clear-steel-50: rgb(0 0 32 / .5);
  --clear-steel-40: rgb(0 0 32 / .4);
  --clear-steel-30: rgb(0 0 32 / .3);
  --clear-steel-15: rgb(0 0 32 / .15);
  --clear-steel-5: rgb(0 0 32 / .05);
  --clear: rgb(0 0 0 / 0);
  --charcoal-gray: #1a1a1a;
  --primary-70: #1a1a1a;
  --primary-50: #333;
  --primary-20: #ccc;
  --primary-10: #eee;
  --primary-5: #f9f9f9;
  --accent-70: #ea580c;
  --accent-50: #f97316;
  --accent-20: #ffedd5;
  --accent-10: #ffedd5;
  --accent-5: #fff7ed;
  --info-70: #285a8b;
  --info-50: #4c8dcc;
  --info-20: #c3d9ee;
  --info-10: #ebf2f9;
  --success-70: #2b8869;
  --success-50: #51c8a0;
  --success-20: #c5eddf;
  --success-10: #ecf9f4;
  --warning-70: #956b1e;
  --warning-50: #d9a340;
  --warning-20: #f2e0bf;
  --warning-10: #fbf5ea;
  --danger-70: #902e23;
  --danger-50: #d25546;
  --danger-20: #f0c6c1;
  --danger-10: #faecea;
  --error-70: #902e23;
  --error-50: #d25546;
  --error-20: #f0c6c1;
  --error-10: #faecea;
  --font-weight-700: 700;
  --font-weight-600: 600;
  --font-weight-500: 500;
  --font-weight-400: 400;
  --font-size-40: 2.5rem;
  --font-size-36: 2.25rem;
  --font-size-32: 2rem;
  --font-size-28: 1.75rem;
  --font-size-24: 1.5rem;
  --font-size-22: 1.375rem;
  --font-size-20: 1.25rem;
  --font-size-18: 1.125rem;
  --font-size-16: 1rem;
  --font-size-14: .875rem;
  --font-size-12: .75rem;
  --font-size-10: .625rem;
  --font-size-9: .5625rem;
  --font-size-8: .5rem;
}

:root {
  --pt: var(--point);
  --dpt: var(--double-point);
  --radius-small: var(--eight-point);
  --radius-middle: var(--twelve-point);
  --radius-large: var(--sixteen-point);
  --radius-round: var(--full);
  --elevate-none: 0;
  --elevate-low: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
  --elevate-moderate: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
  --elevate-high: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
  --elevate-veryhigh: 0 25px 50px -12px rgb(0 0 0 / 0.25);
  --default-bold: var(--white);
  --default-dark: var(--text-dark);
  --default-disabled: var(--gray-9);
  --default-light: var(--white);
  --default-subtle: var(--text-subtle);
  --divider-default: var(--gray-d);
  --overlay-default: var(--clear-gray-50);
  --border-dark: var(--clear-steel-40);
  --border-default: var(--clear-steel-30);
  --border-subtle: var(--clear-steel-15);
  --border-light: var(--clear-steel-5);
  --tint-extradark: var(--clear-steel-50);
  --tint-dark: var(--clear-steel-40);
  --tint-moderate: var(--clear-steel-30);
  --tint-light: var(--clear-steel-15);
  --tint-extralight: var(--clear-gray-1);
  --transparent: var(--clear);
  --surface-default: var(--card-bg);
  --surface-disabled: var(--light-f0);
  --surface-disabled-light: var(--light-fa);
  --surface-hover: var(--primary-10);
  --surface-low: var(--primary-5);
  --surface-moderate: var(--primary-10);
  --surface-high: var(--primary-20);
  --surface-primary: var(--primary-20);
  --surface-accent: var(--accent-20);
  --surface-info: var(--info-20);
  --surface-success: var(--success-20);
  --surface-warning: var(--warning-20);
  --surface-danger: var(--danger-20);
  --surface-error: var(--error-20);
  --text-bold: var(--default-bold);
  --text-dark: var(--default-dark);
  --text-disabled: var(--default-disabled);
  --text-light: var(--default-light);
  --text-subtle: var(--default-subtle);
  --text-primary: var(--primary-70);
  --text-accent: var(--accent-70);
  --text-info: var(--info-70);
  --text-success: var(--success-70);
  --text-warning: var(--warning-70);
  --text-danger: var(--danger-70);
  --text-error: var(--error-70);
  --outline-none: var(--none);
  --outline-default: var(--gray-c);
  --outline-dark: var(--gray-8);
  --outline-disabled: var(--gray-d);
  --outline-highlight: var(--neon-accent);
  --outline-primary: var(--primary-20);
  --outline-accent: var(--accent-20);
  --outline-info: var(--info-20);
  --outline-success: var(--success-20);
  --outline-warning: var(--warning-20);
  --outline-danger: var(--danger-20);
  --outline-error: var(--error-20);
  --font-weight-bold: var(--font-weight-700);
  --font-weight-medium: var(--font-weight-600);
  --font-weight-regular: var(--font-weight-500);
  --font-weight-light: var(--font-weight-400);
  --font-size-jumbo: var(--font-size-40);
  --font-size-xxxhuge: var(--font-size-36);
  --font-size-xxhuge: var(--font-size-32);
  --font-size-xhuge: var(--font-size-28);
  --font-size-huge: var(--font-size-24);
  --font-size-xxxl: var(--font-size-22);
  --font-size-xxl: var(--font-size-20);
  --font-size-xl: var(--font-size-18);
  --font-size-large: var(--font-size-16);
  --font-size-medium: var(--font-size-14);
  --font-size-regular: var(--font-size-12);
  --font-size-small: var(--font-size-10);
  --font-size-xs: var(--font-size-9);
  --font-size-xxs: var(--font-size-8);
}

* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

a {
  color: inherit;
}

body {
  background-color: var(--base);
  color: var(--text-dark);
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', sans-serif;
  font-size: .875rem;
  height: 100%;
}

button,
input {
  font-family: inherit;
  font-size: inherit;
  background: rgba(255, 255, 255, 0.05);
  color: var(--text-dark);
  border: 1px solid var(--glass-border);
  padding: 8px;
  border-radius: 8px;
}

html {
  -webkit-text-size-adjust: 100%;
  height: 100%;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--text-dark);
}

ul {
  list-style: none;
}

a,
button,
div,
input,
textarea,
select {
  -webkit-tap-highlight-color: var(--transparent);
}

/* Glassmorphism Classes */
.bento-card {
  background: var(--surface-default);
  backdrop-filter: blur(10px);
  border: 1px solid var(--glass-border);
  border-radius: 20px;
  padding: 24px;
  box-shadow: var(--elevate-low);
}

/* Fonts */

@font-face {
  font-family: "Material Symbol";
  font-style: normal;
  font-weight: 400;
  src: url("/f/symbol.woff2") format("woff2");
}

.material-symbol {
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-feature-settings: "liga";
  -webkit-font-smoothing: antialiased;
  direction: ltr;
  display: inline-block;
  font-family: "Material Symbol";
  font-feature-settings: "liga";
  font-style: normal;
  font-weight: normal;
  letter-spacing: normal;
  line-height: 1;
  text-rendering: optimizeLegibility;
  text-transform: none;
  white-space: nowrap;
  word-wrap: normal;
}
.flex {
  display: flex;
}

.flex-grow {
  flex-grow: 1;
}

.flex-wrap {
  flex-wrap: wrap;
}

.align-items-center {
  align-items: center;
}

.justify-content-center {
  justify-content: center;
}

.text-align-center {
  text-align: center;
}

.hover:hover {
  background-color: var(--surface-moderate);
}

.radius-small {
  border-radius: var(--radius-small);
}

.radius-middle {
  border-radius: var(--radius-middle);
}

.radius-large {
  border-radius: var(--radius-large);
}

.radius-round {
  border-radius: var(--radius-round);
}

.gap1 {
  gap: .25rem;
}

.gap2 {
  gap: .5rem;
}

.gap3 {
  gap: 1rem;
}

.gap4 {
  gap: 1.5rem;
}

.gap5 {
  gap: 2rem;
}

.gap6 {
  gap: 3rem;
}

.mla {
  margin-left: auto;
}

.mra {
  margin-right: auto;
}

.ml1 {
  margin-left: .25rem;
}

.mr1 {
  margin-right: .25rem;
}

.mt1 {
  margin-top: .25rem;
}

.mb1 {
  margin-bottom: .25rem;
}

.ml2 {
  margin-left: .5rem;
}

.mr2 {
  margin-right: .5rem;
}

.mt2 {
  margin-top: .5rem;
}

.mb2 {
  margin-bottom: .5rem;
}

.ml3 {
  margin-left: 1rem;
}

.mr3 {
  margin-right: 1rem;
}

.mt3 {
  margin-top: 1rem;
}

.mb3 {
  margin-bottom: 1rem;
}

.ml4 {
  margin-left: 1.5rem;
}

.mr4 {
  margin-right: 1.5rem;
}

.mt4 {
  margin-top: 1.5rem;
}

.mb4 {
  margin-bottom: 1.5rem;
}

.ml5 {
  margin-left: 2rem;
}

.mr5 {
  margin-right: 2rem;
}

.mt5 {
  margin-top: 2rem;
}

.mb5 {
  margin-bottom: 2rem;
}

.ml6 {
  margin-left: 3rem;
}

.mr6 {
  margin-right: 3rem;
}

.mt6 {
  margin-top: 3rem;
}

.mb6 {
  margin-bottom: 3rem;
}

.pl1 {
  padding-left: .25rem;
}

.pr1 {
  padding-right: .25rem;
}

.pt1 {
  padding-top: .25rem;
}

.pb1 {
  padding-bottom: .25rem;
}

.pl2 {
  padding-left: .5rem;
}

.pr2 {
  padding-right: .5rem;
}

.pt2 {
  padding-top: .5rem;
}

.pb2 {
  padding-bottom: .5rem;
}

.pl3 {
  padding-left: 1rem;
}

.pr3 {
  padding-right: 1rem;
}

.pt3 {
  padding-top: 1rem;
}

.pb3 {
  padding-bottom: 1rem;
}

.pl4 {
  padding-left: 1.5rem;
}

.pr4 {
  padding-right: 1.5rem;
}

.pt4 {
  padding-top: 1.5rem;
}

.pb4 {
  padding-bottom: 1.5rem;
}

.pl5 {
  padding-left: 2rem;
}

.pr5 {
  padding-right: 2rem;
}

.pt5 {
  padding-top: 2rem;
}

.pb5 {
  padding-bottom: 2rem;
}

.pl6 {
  padding-left: 3rem;
}

.pr6 {
  padding-right: 3rem;
}

.pt6 {
  padding-top: 3rem;
}

.pb6 {
  padding-bottom: 3rem;
}
.badge {
  background-color: var(--surface-default);
  border: var(--pt) solid var(--outline-default);
  border-radius: var(--radius-round);
  color: var(--text-dark);
  display: inline-block;
  font-size: var(--font-size-small);
  padding: .25rem .625rem;
  white-space: nowrap;
}

.badge-danger {
  background-color: var(--danger-10);
  border-color: var(--outline-danger);
  color: var(--text-danger);
}

.badge-info {
  background-color: var(--info-10);
  border-color: var(--outline-info);
  color: var(--text-info);
}

.badge-neutral {
  background-color: var(--light-f0);
  border-color: var(--outline-default);
  color: var(--text-dark);
}

.badge-accent {
  background-color: var(--accent-10);
  border-color: var(--outline-accent);
  color: var(--text-accent);
}

.badge-success {
  background-color: var(--success-10);
  border-color: var(--outline-success);
  color: var(--text-success);
}

.badge-warning {
  background-color: var(--warning-10);
  border-color: var(--outline-warning);
  color: var(--text-warning);
}
.rpl-container {
  -webkit-tap-highlight-color: transparent;
  border-radius: inherit;
  bottom: 0;
  left: 0;
  outline: none;
  overflow: hidden;
  position: absolute;
  right: 0;
  top: 0;
}

.rpl-overlay {
  animation: rippleWaveEffect .75s forwards;
  backface-visibility: hidden;
  background-color: var(--tint-light);
  border-radius: 50%;
  pointer-events: none;
  position: absolute;
  transform: scale(0);
}

.rpl-overlay-dark {
  background-color: var(--tint-extradark);
}

.rpl-overlay-dim {
  background-color: var(--tint-dark);
}

.rpl-overlay-shade {
  background-color: var(--tint-moderate);
}

@keyframes rippleWaveEffect {
  to {
    opacity: 0;
    transform: scale(3);
  }
}
button {
  background-color: var(--surface-default);
  border-radius: var(--radius-round);
  border: var(--pt) solid var(--outline-default);
  color: var(--text-dark);
  cursor: pointer;
  outline: none;
  padding: .5rem 2rem;
  position: relative;
  text-decoration: none;
  transition: all .2s ease;
  white-space: nowrap;
  border-radius: 9999px; /* Ensure rounded */
}

button:disabled {
  background-color: var(--surface-disabled);
  border-color: var(--outline-disabled);
  color: var(--text-disabled);
  cursor: default;
}

.btn-danger {
  background-color: var(--danger-50);
  border-color: var(--danger-50);
  color: var(--text-light);
}

.btn-fab {
  align-items: center;
  background-color: var(--accent-50);
  border-radius: var(--radius-large);
  border: 0;
  box-shadow: var(--elevate-moderate);
  color: var(--text-dark);
  display: flex;
  font-size: 1.5rem;
  height: 3rem;
  justify-content: center;
  padding: 0;
  width: 3rem;
}

.btn-icon {
  background-color: var(--transparent);
  border: 0;
  font-size: 1rem;
  padding: .5rem;
}

.btn-primary {
  background-color: var(--primary-dark);
  border-color: var(--primary-dark);
  color: #fff;
}

.btn-secondary {
  background-color: var(--primary-10);
  border-color: var(--primary-20);
  color: var(--primary-70);
}

.btn-tretiary {
  background-color: var(--surface-default);
  border-color: var(--primary-20);
  color: var(--primary-70);
}

.btn-warning {
  background-color: var(--warning-50);
  border-color: var(--warning-50);
  color: var(--text-light);
}

@media only screen and (min-width: 56rem) {
  button:hover {
    box-shadow: var(--elevate-moderate);
  }

  button:disabled:hover {
    box-shadow: var(--elevate-none);
    cursor: default;
  }

  .btn-fab:hover {
    box-shadow: var(--elevate-high);
  }

  .btn-icon:hover {
    background-color: var(--tint-extralight);
    box-shadow: var(--elevate-none);
  }
}
.exp-toggle {
  cursor: pointer;
  user-select: none;
}
input[type="email"],
input[type="number"],
input[type="password"],
input[type="text"] {
  appearance: none;
  border-radius: var(--radius-round);
  border: var(--pt) solid var(--outline-default);
  line-height: 1rem;
  outline: none;
  padding: .5rem .875rem;
  width: 100%;
}

input:hover {
  border-color: var(--outline-dark);
}

input:focus {
  border: var(--dpt) solid var(--outline-highlight);
  padding: .4375rem .8125rem;
}
label {
  user-select: none;
  -webkit-user-select: none;
}
.pnl {
  border-radius: var(--radius-middle);
  padding: 1rem;
}

.pnl-info {
  background-color: var(--surface-moderate);
}
textarea {
  appearance: none;
  border-radius: var(--radius-large);
  border: var(--pt) solid var(--outline-default);
  line-height: 1rem;
  outline: none;
  padding: .5rem .875rem;
  width: 100%;
}

textarea:hover {
  border-color: var(--outline-dark);
}

textarea:focus {
  border: var(--dpt) solid var(--outline-highlight);
  padding: .4375rem .8125rem;
}
.tgl {
  height: 1rem;
  position: relative;
  user-select: none;
  width: 2.25rem;
}

.tgl input[type="checkbox"] {
  appearance: none;
  display: none;
}

.tgl-switch {
  background-color: var(--primary-20);
  border-radius: 1rem;
  height: .75rem;
  left: .125rem;
  position: absolute;
  top: .125rem;
  width: 2rem;
}

.tgl-switch::after {
  background-color: var(--surface-default);
  border-radius: 1rem;
  box-shadow: var(--elevate-low);
  content: "";
  height: 1.125rem;
  left: -.125rem;
  position: absolute;
  top: -.1875rem;
  transition: 150ms cubic-bezier(.4, 0, 1, 1) 0s;
  width: 1.125rem;
}

.tgl input[type="checkbox"]:checked ~ .tgl-switch::after {
  background-color: var(--primary-70);
  height: 1.25rem;
  transform: translate3d(1rem, -.0625rem, 0);
  width: 1.25rem;
}

.tgl input[type="checkbox"]:disabled ~ .tgl-switch {
  background-color: var(--surface-disabled);
}

.tgl input[type="checkbox"]:disabled ~ .tgl-switch::after {
  background-color: var(--surface-disabled-light);
  border: var(--pt) solid var(--outline-disabled);
  box-shadow: var(--elevate-none);
  height: 1.0625rem;
  top: -.1875rem;
  width: 1.0625rem;
}

.tgl input[type="checkbox"]:disabled:checked ~ .tgl-switch::after {
  top: -.125rem;
}
.nav-container {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 8px;
  padding: 16px;
  overflow-x: auto;
  /* Scroll to end */
  scroll-behavior: smooth;
}

/* On mobile, allow scrolling with wider cards */
@media (max-width: 600px) {
  .nav-container {
    grid-template-columns: repeat(7, 120px);
    justify-content: flex-start;
  }
}

.nav-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 8px 4px;
  border-radius: 12px;
  text-decoration: none;
  color: var(--text);
  background: #ffffff;
  border: 2px solid transparent;
  box-shadow: 0 1px 3px 0 rgb(0 0 0 / 0.05);
  transition: all 0.2s;
}

.nav-card:hover {
  background: #fffaf5;
}

.nav-card.active {
  border: 2px solid var(--primary);
  background: #fff7ed;
}

.card-weekday {
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--text-dim);
}

.card-date {
  font-size: 0.85rem;
  font-weight: 600;
}

.card-stats {
  font-size: 0.65rem;
  color: var(--text-dim);
  margin-top: 4px;
  opacity: 0.8;
  white-space: nowrap;
}

.main-container {
  max-width: 800px;
  margin: 0 auto;
  padding-bottom: 80px;
}

.main-card {
  margin: 1rem;
}
.modal-overlay {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-color: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(8px);
  display: flex;
  justify-content: flex-end;
  z-index: 1000;
}

.modal-content {
  background-color: var(--card-bg);
  padding: 32px;
  height: 100%;
  width: 100%;
  max-width: 400px;
  overflow-y: auto;
  box-shadow: -4px 0 32px rgba(0,0,0,0.1);
  color: var(--text);
  display: flex;
  flex-direction: column;
}

.fab {
  position: fixed;
  bottom: 24px;
  right: 24px;
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background-color: var(--primary);
  color: var(--text);
  font-size: 32px;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  font-weight: bold;
}

/* Card list styles */
.food-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
  list-style: none;
  padding: 0;
  margin: 0;
}

.food-card {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 16px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
  transition: transform 0.1s;
}

.food-card:active {
  transform: scale(0.98);
}

.food-info {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.food-name {
  font-weight: bold;
  font-size: 1.1rem;
}

.food-meta {
  font-size: 0.9rem;
  color: var(--text-dim);
}

.food-time {
  font-weight: bold;
  color: var(--primary-dark);
}

/* Enhanced Modal Inputs */
.modal-form {
  display: flex;
  flex-direction: column;
  gap: 20px;
  margin-top: 24px;
}

.modal-input-group {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.modal-label {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.modal-input {
  width: 100%;
  padding: 12px 16px;
  border-radius: 12px;
  border: 2px solid var(--border);
  font-size: 1rem;
  transition: border-color 0.2s;
  background: var(--bg);
}

.modal-input:focus {
  outline: none;
  border-color: var(--primary);
}

/* Action Area */
.modal-button-group {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: auto;
  padding-top: 32px;
}

.btn-save {
  padding: 14px;
  border-radius: 12px;
  border: none;
  background: var(--primary);
  color: var(--text);
  font-weight: 600;
  font-size: 1rem;
  cursor: pointer;
}

.btn-delete {
  padding: 14px;
  border-radius: 12px;
  border: none;
  background: #fee2e2;
  color: #ef4444;
  font-weight: 600;
  font-size: 1rem;
  cursor: pointer;
}

.btn-close {
  padding: 14px;
  border-radius: 12px;
  border: none;
  background: var(--border);
  color: var(--text);
  font-weight: 600;
  font-size: 1rem;
  cursor: pointer;
}

.food-option {
  border: 1px solid var(--border);
  padding: 16px;
  margin-bottom: 12px;
  cursor: pointer;
  border-radius: 16px;
  background: var(--card-bg);
  transition: background 0.2s;
}

.food-option:hover {
  background: #fdfaf6;
}

.food-option-name {
  font-weight: bold;
  font-size: 1.1rem;
}

.food-option-meta {
  font-size: 0.9rem;
  color: var(--text-dim);
  margin-top: 4px;
}
.banner-card {
  margin: 1rem;
  background: var(--card-bg);
  border: 1px solid var(--border);
  padding: 24px;
  border-radius: 24px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.banner-header {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.banner-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.stat-item {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.stat-value {
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--text);
}

.stat-label {
  font-size: 0.8rem;
  color: var(--text-dim);
}

.banner-progress {
  height: 8px;
  background: var(--border);
  border-radius: 4px;
  overflow: hidden;
  display: flex;
}

.progress-fill {
  height: 100%;
  background: var(--primary);
  border-radius: 4px;
}
.login-card {
  max-width: 400px;
  margin: 4rem auto;
  padding: 3rem; /* Increased padding */
  box-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1); /* Added shadow */
}

.login-field {
  margin-bottom: 1.5rem;
}

.login-input {
  width: 100%;
  margin-top: 0.5rem;
}

.login-button {
  width: 100%;
  padding: 0.75rem;
  font-weight: 600;
  border-radius: 9999px;
}
:root {
  --bg: #fdfaf6; /* Soft cream background */
  --bg-gradient: linear-gradient(180deg, #fdfaf6 0%, #f7f0e8 100%);
  --card-bg: #ffffff;
  --text: #332b26; /* Warm dark brown-grey */
  --text-dim: #8c7f76;
  --primary: #fdba74; /* Pastel orange primary */
  --primary-dark: #f97316; /* For contrast/active states */
  --primary-glow: rgba(253, 186, 116, 0.2);
  --accent: #f97316;
  --border: #f3e8dd;
  --card-header-bg: #ffffff;
  --nested-bg: #fdfaf6;
}

body {
  margin: 0;
  font-family: 'Inter', -apple-system, sans-serif;
  background: var(--bg-gradient);
  background-attachment: fixed;
  min-height: 100vh;
  color: var(--text);
  line-height: 1.6;
  transition: background 0.3s, color 0.3s;
}

.card {
  border-radius: 20px;
  border: 1px solid var(--border);
  background: var(--card-bg);
  box-shadow: 0 1px 3px 0 rgb(0 0 0 / 0.05), 0 1px 2px -1px rgb(0 0 0 / 0.05);
  padding: 1rem;
}

@media (min-width: 768px) {
  body {
    max-width: 800px;
    margin: 0 auto;
    padding: 2rem;
  }
}
