:root {
  --jojo-red: #b52c24;
  --jojo-orange: #ef7c1a;
  --jojo-cream: #fff7eb;
  --jojo-dark: #2f201b;
  --jojo-muted: #76635d;
  --jojo-green: #2e8b57;
}

body {
  background: linear-gradient(145deg, #fff7eb 0%, #fff2dd 45%, #ffe8ce 100%);
  color: var(--jojo-dark);
  min-height: 100vh;
}

.navbar-brand {
  font-weight: 800;
  letter-spacing: 0.02em;
}

.card-jojo {
  border: 1px solid #efddc6;
  border-radius: 1rem;
  box-shadow: 0 0.5rem 1.5rem rgba(47, 32, 27, 0.08);
}

.metric-card {
  background: #fff;
  border: 1px solid #f2dec2;
  border-radius: 1rem;
  padding: 1rem;
}

.metric-value {
  font-size: 1.5rem;
  font-weight: 700;
}

.btn-primary {
  --bs-btn-bg: var(--jojo-red);
  --bs-btn-border-color: var(--jojo-red);
  --bs-btn-hover-bg: #94231d;
  --bs-btn-hover-border-color: #94231d;
  --bs-btn-active-bg: #7f1e18;
  --bs-btn-active-border-color: #7f1e18;
}

.btn-warning {
  --bs-btn-bg: var(--jojo-orange);
  --bs-btn-border-color: var(--jojo-orange);
  --bs-btn-hover-bg: #d86d14;
  --bs-btn-hover-border-color: #d86d14;
  --bs-btn-color: #fff;
}

.badge-role {
  background: #ffe2bf;
  color: #6a3b14;
}

.login-brand-logo {
  width: 58%;
  max-width: 202px;
  min-width: 88px;
  height: auto;
  display: block;
  margin-inline: auto;
}

.pwa-install-btn {
  font-weight: 700;
  white-space: nowrap;
}

.product-card {
  height: 100%;
  border-radius: 1rem;
  border: 1px solid #ecd8bb;
  overflow: hidden;
}

.product-card img {
  width: 100%;
  height: 140px;
  object-fit: cover;
}

.product-card .card-body {
  padding: 0.75rem;
}

.touch-btn {
  min-height: 46px;
  font-size: 1rem;
  font-weight: 700;
}

.table-status {
  border-radius: 0.9rem;
  padding: 0.8rem;
  border: 2px solid transparent;
}

.mesa-circle.table-status {
  width: 2.5rem;
  height: 2.5rem;
  padding: 0;
  border-width: 1px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.72rem;
  font-weight: 700;
  line-height: 1;
}

.mesa-list {
  max-height: 170px;
  overflow-y: auto;
  align-content: flex-start;
}

.status-free {
  background: #e7f8ee;
  border-color: #bde8cb;
}

.status-occupied {
  background: #fff6db;
  border-color: #ffdb82;
}

.status-closed {
  background: #f5e9e8;
  border-color: #dfb8b4;
}

.order-panel {
  position: sticky;
  top: 0.8rem;
}

.item-row {
  border-bottom: 1px dashed #dbc4a6;
  padding-bottom: 0.75rem;
  margin-bottom: 0.75rem;
}

.table td,
.table th {
  vertical-align: middle;
}

.form-label {
  font-weight: 600;
}

.small-muted {
  color: var(--jojo-muted);
  font-size: 0.875rem;
}

.open-order-btn {
  min-width: 4.4rem;
  padding: 0.3rem 0.45rem;
  line-height: 1.05;
  text-align: center;
}

.open-order-btn .order-sub-tag {
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  opacity: 0.85;
}

@media (max-width: 992px) {
  .order-panel {
    position: static;
  }

  .product-card img {
    height: 120px;
  }

  .mesa-list {
    max-height: 140px;
  }

  .open-order-btn {
    min-width: 4rem;
    padding: 0.28rem 0.35rem;
  }
}
