/* =============================================
   GASTRUM - Sistema Completo
   Cores da Logo + Design Intuitivo
   ============================================= */

:root {
  /* Cores da Logo */
  --verde-escuro: #1a472a;
  --verde: #2d6a4f;
  --verde-claro: #d8f3dc;
  --laranja: #e85d04;
  --laranja-claro: #fff4ed;

  /* Status */
  --vermelho: #dc2626;
  --vermelho-claro: #fef2f2;
  --amarelo: #f59e0b;
  --amarelo-claro: #fffbeb;

  /* Neutros - Modo Claro */
  --branco: #ffffff;
  --cinza-50: #fafafa;
  --cinza-100: #f4f4f5;
  --cinza-200: #e4e4e7;
  --cinza-300: #d4d4d8;
  --cinza-500: #71717a;
  --cinza-700: #3f3f46;
  --cinza-900: #18181b;

  /* Cores dinâmicas (mudam no dark mode) */
  --bg-body: #fafafa;
  --bg-card: #ffffff;
  --bg-input: #ffffff;
  --texto-primario: #18181b;
  --texto-secundario: #71717a;
  --borda: #e4e4e7;
  --borda-input: #e4e4e7;

  /* Layout */
  --sidebar: 260px;
  --raio: 12px;
  --raio-sm: 8px;
  --sombra: 0 2px 8px rgba(0,0,0,0.08);
  --sombra-hover: 0 4px 16px rgba(0,0,0,0.12);
}

/* =============================================
   Dark Mode
   ============================================= */

body.dark-theme {
  --bg-body: #0f1419;
  --bg-card: #1c2128;
  --bg-input: #22272e;
  --texto-primario: #f0f3f6;
  --texto-secundario: #9ca3af;
  --borda: #2d333b;
  --borda-input: #3d444d;

  /* Ajustes para cores claras no dark mode */
  --verde-claro: rgba(45, 106, 79, 0.2);
  --laranja-claro: rgba(232, 93, 4, 0.15);
  --vermelho-claro: rgba(220, 38, 38, 0.15);
  --amarelo-claro: rgba(245, 158, 11, 0.15);
  --cinza-50: #1c2128;
  --cinza-100: #22272e;
  --cinza-200: #2d333b;
  --cinza-300: #3d444d;

  --sombra: 0 2px 8px rgba(0,0,0,0.3);
  --sombra-hover: 0 4px 16px rgba(0,0,0,0.4);
}

/* Dark mode - Elementos específicos */
body.dark-theme .summary-card,
body.dark-theme .alert-card,
body.dark-theme .menu-today-card,
body.dark-theme .dish-card,
body.dark-theme .cart-list,
body.dark-theme .payment-btn,
body.dark-theme .channel-btn,
body.dark-theme .filter-chip,
body.dark-theme .stock-item,
body.dark-theme .recipe-card-new,
body.dark-theme .production-card-new,
body.dark-theme .purchase-card,
body.dark-theme .day-card,
body.dark-theme .week-btn,
body.dark-theme .modal-content-new {
  background: var(--bg-card);
}

body.dark-theme .card-value,
body.dark-theme .stock-info strong,
body.dark-theme .recipe-title strong,
body.dark-theme .prod-title strong,
body.dark-theme .purchase-info strong {
  color: var(--texto-primario);
}

body.dark-theme .card-label,
body.dark-theme .menu-prices,
body.dark-theme .cart-item-info span,
body.dark-theme .stock-min,
body.dark-theme .prod-time,
body.dark-theme .recipe-cat,
body.dark-theme .alert-info span {
  color: var(--texto-secundario);
}

body.dark-theme .select-new,
body.dark-theme .input-new,
body.dark-theme .select-small-new,
body.dark-theme .input-small-new {
  background: var(--bg-input);
  border-color: var(--borda-input);
  color: var(--texto-primario);
}

body.dark-theme .modal-header-new,
body.dark-theme .modal-footer-new {
  background: var(--bg-input);
  border-color: var(--borda);
}

body.dark-theme .ing-row {
  border-bottom-color: var(--borda);
}

body.dark-theme .ing-row.header {
  background: var(--bg-input);
}

body.dark-theme .ficha-info-item,
body.dark-theme .ficha-rendimento-item,
body.dark-theme .cost-item,
body.dark-theme .prod-number,
body.dark-theme .items-add-list,
body.dark-theme .production-preview,
body.dark-theme .marmita-cost-card {
  background: var(--bg-input);
}

body.dark-theme .rendimento-qtd {
  color: var(--texto-primario);
}

body.dark-theme .rendimento-icon.pequena {
  background: rgba(0, 166, 81, 0.2);
}

body.dark-theme .rendimento-icon.grande {
  background: rgba(255, 153, 0, 0.2);
}

body.dark-theme .day-header-simple {
  border-bottom-color: var(--borda);
}

body.dark-theme .day-dish {
  background: var(--bg-input);
}

body.dark-theme .size-btn,
body.dark-theme .qty-btn {
  background: var(--bg-card);
  border-color: var(--borda);
  color: var(--texto-primario);
}

body.dark-theme .size-btn:hover,
body.dark-theme .qty-btn:hover {
  background: var(--verde-claro);
  border-color: var(--verde);
}

body.dark-theme .recipe-card-new.add-recipe {
  background: var(--bg-input);
  border-color: var(--borda);
}

body.dark-theme .add-item-btn {
  background: var(--bg-card);
  border-color: var(--borda);
}

body.dark-theme .btn-secondary,
body.dark-theme .alert-action,
body.dark-theme .view-btn,
body.dark-theme .stock-action {
  background: var(--bg-input);
  color: var(--texto-primario);
}

body.dark-theme .modal-close {
  background: var(--bg-input);
  color: var(--texto-primario);
}

body.dark-theme .logo-showcase {
  background: transparent;
}

body.dark-theme .sale-total-display {
  background: var(--verde-claro);
}

body.dark-theme .purchase-items,
body.dark-theme .recipe-footer {
  border-top-color: var(--borda);
}

body.dark-theme h2 {
  color: var(--texto-primario);
}

body.dark-theme .page-header-simple h1 {
  color: var(--texto-primario);
}

body.dark-theme .dishes-section h2,
body.dark-theme .cart-section h2,
body.dark-theme .payment-section h2,
body.dark-theme .channel-section h2 {
  color: var(--texto-secundario);
}

/* Dark mode - Textos adicionais para melhor contraste */
body.dark-theme .dish-name,
body.dark-theme .menu-info strong,
body.dark-theme .alert-info strong,
body.dark-theme .cart-item-info strong,
body.dark-theme .week-label,
body.dark-theme .day-num,
body.dark-theme .day-name,
body.dark-theme .filter-chip,
body.dark-theme .number-value,
body.dark-theme .number-label,
body.dark-theme .info-value,
body.dark-theme .info-label,
body.dark-theme .ing-row span,
body.dark-theme .purchase-total,
body.dark-theme .item-row-total,
body.dark-theme .purchase-summary strong,
body.dark-theme .marmita-total,
body.dark-theme .marmita-details span,
body.dark-theme .preview-items span,
body.dark-theme .input-hint,
body.dark-theme .form-group-new label,
body.dark-theme .ficha-section h3,
body.dark-theme .modal-header-new h2,
body.dark-theme .production-preview h4 {
  color: var(--texto-primario);
}

body.dark-theme .size-label,
body.dark-theme .size-price {
  color: var(--texto-primario);
}

body.dark-theme .payment-btn span,
body.dark-theme .channel-btn span {
  color: var(--texto-primario);
}

body.dark-theme .payment-btn i,
body.dark-theme .channel-btn i {
  color: var(--texto-secundario);
}

body.dark-theme .payment-btn.active i,
body.dark-theme .channel-btn.active i {
  color: var(--verde);
}

body.dark-theme .stock-current {
  color: var(--texto-primario);
}

body.dark-theme .recipe-footer {
  color: var(--texto-secundario);
}

body.dark-theme .day-dishes.empty span {
  color: var(--texto-secundario);
}

body.dark-theme .prod-cost {
  color: var(--texto-secundario);
}

body.dark-theme .prod-cost strong {
  color: var(--verde);
}

body.dark-theme .cost-label {
  color: var(--texto-primario);
}

body.dark-theme .purchase-items span {
  color: var(--texto-secundario);
}

body.dark-theme .purchase-info span {
  color: var(--texto-secundario);
}

body.dark-theme .card-trend {
  color: var(--verde);
}

body.dark-theme .card-detail {
  color: var(--texto-secundario);
}

body.dark-theme .sale-total-display {
  color: var(--texto-primario);
}

body.dark-theme .sale-total-display strong {
  color: var(--verde);
}

body.dark-theme .today-badge {
  background: var(--verde);
  color: white;
}

body.dark-theme .day-card.today {
  background: rgba(45, 106, 79, 0.15);
  border-color: var(--verde);
}

body.dark-theme .day-card.today .day-header-simple {
  border-bottom-color: var(--verde);
}

body.dark-theme .menu-status.available {
  background: var(--verde-claro);
  color: var(--verde);
}

body.dark-theme .prod-status.good {
  background: var(--verde-claro);
  color: #4ade80;
}

body.dark-theme .prod-status.warning {
  background: var(--amarelo-claro);
  color: #fbbf24;
}

body.dark-theme .ingredients-table {
  background: var(--bg-input);
}

body.dark-theme .ing-row.total {
  background: var(--verde-claro);
}

body.dark-theme .ing-row.total strong {
  color: var(--verde);
}

body.dark-theme .purchase-summary {
  background: var(--verde-claro);
  color: var(--texto-primario);
}

body.dark-theme .cart-item {
  color: var(--texto-primario);
  background: var(--bg-card);
  border-color: var(--borda);
}

body.dark-theme .cart-item:hover {
  border-color: var(--verde);
  box-shadow: 0 2px 12px rgba(0, 166, 81, 0.2);
}

body.dark-theme .cart-select-group {
  background: var(--cinza-900);
  border-color: var(--borda);
}

body.dark-theme .cart-select {
  background: var(--cinza-900);
  color: var(--texto-primario);
}

body.dark-theme .cart-select option {
  background: var(--cinza-800);
  color: var(--texto-primario);
}

body.dark-theme .cart-qty {
  background: var(--cinza-900);
  border-color: var(--borda);
}

body.dark-theme .qty-btn {
  background: var(--cinza-800);
  color: var(--texto-primario);
}

body.dark-theme .qty-btn:hover {
  background: var(--verde);
  color: white;
}

body.dark-theme .qty-value {
  color: var(--texto-primario);
}

body.dark-theme .cart-item-total {
  color: var(--verde);
  background: rgba(0, 166, 81, 0.15);
}

body.dark-theme .cart-empty {
  color: var(--cinza-500);
}

body.dark-theme .finish-sale-btn {
  background: var(--verde);
  color: white;
}

body.dark-theme .header-action-btn {
  background: var(--verde);
  color: white;
}

body.dark-theme .btn-primary {
  background: var(--verde);
  color: white;
}

body.dark-theme .day-dish.special {
  background: var(--laranja-claro);
  color: var(--laranja);
}

body.dark-theme .nav-alert {
  background: var(--vermelho);
  color: white;
}

body.dark-theme .stock-status.critical {
  color: #f87171;
}

body.dark-theme .stock-status.warning {
  color: #fbbf24;
}

body.dark-theme .stock-status.ok {
  color: #4ade80;
}

body.dark-theme .cost-margin.good {
  background: var(--verde-claro);
  color: #4ade80;
}

body.dark-theme .motivational-quote,
body.dark-theme .motivational-author,
body.dark-theme #greetingText,
body.dark-theme .current-date {
  color: white;
}

body.dark-theme .add-icon,
body.dark-theme .recipe-card-new.add-recipe span {
  color: var(--texto-secundario);
}

body.dark-theme .recipe-card-new.add-recipe:hover {
  border-color: var(--verde);
  color: var(--verde);
}

body.dark-theme .recipe-card-new.add-recipe:hover .add-icon,
body.dark-theme .recipe-card-new.add-recipe:hover span {
  color: var(--verde);
}

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

img, video, iframe, embed, object {
  max-width: 100%;
  height: auto;
}

/* Prevenir quebra de palavras longas */
p, h1, h2, h3, h4, h5, h6, span, a, li, td, th, label {
  word-wrap: break-word;
  overflow-wrap: break-word;
}

html {
  overflow-x: hidden;
  width: 100%;
  max-width: 100vw;
}

body {
  font-family: 'Inter', -apple-system, sans-serif;
  background: var(--bg-body);
  color: var(--texto-primario);
  font-size: 16px;
  line-height: 1.5;
  transition: background 0.3s ease, color 0.3s ease;
  overflow-x: hidden;
  width: 100%;
  max-width: 100vw;
}

/* =============================================
   Layout Principal
   ============================================= */

.app {
  display: flex;
  min-height: 100vh;
}

/* =============================================
   Sidebar - Menu Lateral
   ============================================= */

.sidebar {
  width: var(--sidebar);
  background: linear-gradient(180deg, var(--verde-escuro) 0%, var(--verde) 100%);
  position: fixed;
  height: 100vh;
  display: flex;
  flex-direction: column;
  z-index: 100;
}

.sidebar-header {
  padding: 20px;
}

.logo-showcase {
  background: transparent;
  padding: 12px;
  display: flex;
  justify-content: center;
}

.logo-img-large {
  max-width: 220px;
  height: auto;
}

/* Theme Toggle Button - Flutuante */
.theme-toggle {
  position: fixed;
  bottom: 24px;
  right: 24px;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: none;
  background: var(--verde);
  color: white;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  transition: all 0.3s ease;
  box-shadow: 0 4px 12px rgba(0,0,0,0.2);
  z-index: 999;
}

.theme-toggle:hover {
  background: var(--verde-escuro);
  transform: scale(1.1);
}

body.dark-theme .theme-toggle {
  background: var(--laranja);
}

body.dark-theme .theme-toggle:hover {
  background: #d45403;
}

/* Navegação com Grupos */
.sidebar-nav {
  flex: 1;
  padding: 12px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  overflow-y: auto;
}

.nav-group {
  border-radius: var(--raio);
  padding: 8px;
  margin-bottom: 6px;
  background: rgba(232, 93, 4, 0.08); /* Laranja fosco sobre verde */
  border-left: 3px solid rgba(232, 93, 4, 0.3);
}

.nav-group-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  color: rgba(255,255,255,0.6);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.nav-group-header i {
  font-size: 0.85rem;
}

.nav-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  color: rgba(255,255,255,0.9);
  text-decoration: none;
  border-radius: var(--raio-sm);
  font-weight: 500;
  font-size: 15px;
  transition: all 0.2s;
  position: relative;
}

.nav-item:hover {
  background: rgba(255,255,255,0.15);
  color: white;
  transform: translateX(4px);
}

.nav-item.active {
  background: var(--laranja);
  color: white;
  font-weight: 600;
  box-shadow: 0 2px 8px rgba(232, 93, 4, 0.4);
}

.nav-icon {
  font-size: 1.15rem;
  width: 24px;
  text-align: center;
}

.nav-alert {
  position: absolute;
  right: 12px;
  background: var(--vermelho);
  color: white;
  font-size: 11px;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  animation: pulse 2s infinite;
}

@keyframes pulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.1); }
}

/* =============================================
   Conteúdo Principal
   ============================================= */

.main-content {
  flex: 1;
  margin-left: var(--sidebar);
  min-height: 100vh;
  overflow-x: hidden;
  max-width: calc(100vw - var(--sidebar));
  width: calc(100% - var(--sidebar));
}

.header-mobile {
  display: none;
  background: var(--verde-escuro);
  color: white;
  padding: 12px 16px;
  align-items: center;
  justify-content: space-between;
  position: sticky;
  top: 0;
  z-index: 50;
}

.menu-btn, .header-btn {
  background: none;
  border: none;
  color: white;
  font-size: 1.4rem;
  cursor: pointer;
  padding: 8px;
  border-radius: var(--raio-sm);
  transition: background 0.2s;
}

.menu-btn:hover, .header-btn:hover {
  background: rgba(255,255,255,0.1);
}

.header-logo-mobile {
  height: 36px;
  background: white;
  padding: 6px 16px;
  border-radius: var(--raio-sm);
}

.header-logo-text {
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: 1px;
}

.logo-gastr {
  color: var(--verde);
}

.logo-um {
  color: var(--laranja);
}

.header-btn {
  position: relative;
}

.notif-dot {
  position: absolute;
  top: 6px;
  right: 6px;
  width: 10px;
  height: 10px;
  background: var(--vermelho);
  border-radius: 50%;
  border: 2px solid var(--verde-escuro);
}

.page-content {
  padding: 32px;
  max-width: 1400px;
  width: 100%;
  overflow-x: hidden;
}

.page {
  display: none;
}

.page.active {
  display: block;
}

/* =============================================
   Página Inicial - Seção Motivacional
   ============================================= */

.motivational-section {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 32px;
  padding: 28px 32px;
  background: linear-gradient(135deg, var(--verde-escuro) 0%, var(--verde) 50%, #3d8b6a 100%);
  border-radius: var(--raio);
  color: white;
  position: relative;
  overflow: hidden;
  max-width: 100%;
  flex-wrap: wrap;
}

.motivational-section::before {
  content: '';
  position: absolute;
  top: -50%;
  right: -10%;
  width: 300px;
  height: 300px;
  background: rgba(255,255,255,0.05);
  border-radius: 50%;
}

.motivational-content {
  flex: 1;
  position: relative;
}

.quote-icon {
  font-size: 1.5rem;
  opacity: 0.4;
  margin-bottom: 8px;
  display: block;
}

.motivational-quote {
  font-size: 1.15rem;
  line-height: 1.6;
  font-style: italic;
  margin-bottom: 12px;
  max-width: 600px;
}

.motivational-author {
  font-size: 0.9rem;
  opacity: 0.8;
  font-weight: 500;
}

.motivational-author::before {
  content: '— ';
}

.greeting-time {
  text-align: right;
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding-left: 32px;
  border-left: 2px solid rgba(255,255,255,0.2);
  margin-left: 32px;
}

#greetingText {
  font-size: 1.6rem;
  font-weight: 700;
}

.current-date {
  font-size: 0.95rem;
  opacity: 0.8;
}

/* =============================================
   Resumo do Dia
   ============================================= */

.day-summary {
  margin-bottom: 32px;
}

.day-summary h2,
.alerts-section h2,
.today-menu h2 {
  font-size: 1rem;
  color: var(--cinza-700);
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  gap: 10px;
}

.day-summary h2 i { color: var(--verde); }
.alerts-section h2 i { color: var(--laranja); }
.today-menu h2 i { color: var(--verde); }

.summary-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  max-width: 100%;
}

.summary-card {
  background: white;
  border-radius: var(--raio);
  padding: 24px;
  display: flex;
  align-items: center;
  gap: 16px;
  box-shadow: var(--sombra);
  position: relative;
  overflow: hidden;
  transition: all 0.2s;
}

.summary-card:hover {
  box-shadow: var(--sombra-hover);
  transform: translateY(-2px);
}

.summary-card .card-icon {
  width: 56px;
  height: 56px;
  border-radius: var(--raio);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
}

.summary-card.money .card-icon {
  background: var(--verde-claro);
  color: var(--verde);
}

.summary-card.plates .card-icon {
  background: var(--laranja-claro);
  color: var(--laranja);
}

.summary-card.profit .card-icon {
  background: var(--verde-claro);
  color: var(--verde);
}

.summary-card.profit-per-unit .card-icon {
  background: var(--laranja-claro);
  color: var(--laranja);
}

.summary-card.profit-per-unit .card-info {
  flex: 1;
}

.summary-card.profit-per-unit .card-label {
  margin-bottom: 8px;
}

.profit-breakdown {
  display: flex;
  gap: 12px;
}

.profit-item {
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--cinza-50);
  padding: 8px 12px;
  border-radius: var(--raio-sm);
}

.profit-size {
  width: 28px;
  height: 28px;
  background: var(--verde);
  color: white;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 14px;
}

.profit-value {
  font-weight: 700;
  color: var(--verde);
  font-size: 1.1rem;
}

/* Dark mode - Lucro por marmita */
body.dark-theme .profit-item {
  background: var(--bg-input);
}

body.dark-theme .profit-value {
  color: #4ade80;
}

.card-info {
  flex: 1;
}

.card-value {
  display: block;
  font-size: 1.8rem;
  font-weight: 700;
  color: var(--cinza-900);
}

.card-label {
  font-size: 14px;
  color: var(--cinza-500);
}

.card-trend {
  position: absolute;
  top: 16px;
  right: 16px;
  padding: 4px 10px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 600;
}

.card-trend.up {
  background: var(--verde-claro);
  color: var(--verde);
}

.card-detail {
  position: absolute;
  bottom: 16px;
  right: 16px;
  font-size: 13px;
  color: var(--cinza-500);
}

/* =============================================
   Alertas
   ============================================= */

.alerts-section {
  margin-bottom: 32px;
}

.alert-cards {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.alert-card {
  background: white;
  border-radius: var(--raio);
  padding: 16px 20px;
  display: flex;
  align-items: center;
  gap: 16px;
  box-shadow: var(--sombra);
  transition: all 0.2s;
}

.alert-card:hover {
  box-shadow: var(--sombra-hover);
}

.alert-card.danger {
  border-left: 4px solid var(--vermelho);
}

.alert-card.warning {
  border-left: 4px solid var(--amarelo);
}

.alert-card .alert-icon {
  width: 48px;
  height: 48px;
  border-radius: var(--raio);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
}

.alert-card.danger .alert-icon {
  background: var(--vermelho-claro);
  color: var(--vermelho);
}

.alert-card.warning .alert-icon {
  background: var(--amarelo-claro);
  color: var(--amarelo);
}

.alert-info {
  flex: 1;
}

.alert-info strong {
  display: block;
  margin-bottom: 2px;
}

.alert-info span {
  font-size: 14px;
  color: var(--cinza-500);
}

.alert-action {
  background: var(--cinza-100);
  border: none;
  padding: 10px 20px;
  border-radius: var(--raio);
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
}

.alert-action:hover {
  background: var(--verde);
  color: white;
}

/* =============================================
   Cardápio de Hoje (Início)
   ============================================= */

.today-menu {
  margin-bottom: 32px;
}

.menu-today-cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(280px, 100%), 1fr));
  gap: 16px;
  max-width: 100%;
}

.menu-today-card {
  background: white;
  border-radius: var(--raio);
  padding: 20px;
  display: flex;
  align-items: center;
  gap: 16px;
  box-shadow: var(--sombra);
  transition: all 0.2s;
}

.menu-today-card:hover {
  box-shadow: var(--sombra-hover);
}

.menu-icon {
  width: 52px;
  height: 52px;
  background: var(--verde-claro);
  border-radius: var(--raio);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  color: var(--verde);
}

.menu-info {
  flex: 1;
}

.menu-info strong {
  display: block;
  margin-bottom: 4px;
}

.menu-prices {
  font-size: 14px;
  color: var(--cinza-500);
}

.menu-status {
  padding: 6px 12px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 600;
}

.menu-status.available {
  background: var(--verde-claro);
  color: var(--verde);
}

/* =============================================
   Página de Vendas
   ============================================= */

.page-header-simple {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 24px;
}

.page-header-simple h1 {
  font-size: 1.6rem;
  display: flex;
  align-items: center;
  gap: 12px;
}

.page-header-simple h1 i {
  color: var(--laranja);
}

.header-buttons {
  display: flex;
  gap: 12px;
}

.sale-total-display {
  background: var(--verde-claro);
  padding: 12px 24px;
  border-radius: var(--raio);
  font-size: 1.1rem;
}

.sale-total-display strong {
  color: var(--verde);
  font-size: 1.4rem;
}

.header-action-btn {
  background: var(--verde);
  color: white;
  border: none;
  padding: 12px 24px;
  border-radius: var(--raio);
  font-weight: 600;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 8px;
  transition: all 0.2s;
}

.header-action-btn:hover {
  background: var(--verde-escuro);
}

/* Seção de Pratos */
.dishes-section {
  margin-bottom: 32px;
}

.dishes-section h2 {
  font-size: 1rem;
  color: var(--cinza-700);
  margin-bottom: 16px;
}

.dishes-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(200px, 100%), 1fr));
  gap: 16px;
  max-width: 100%;
}

.dish-card {
  background: white;
  border-radius: var(--raio);
  padding: 24px 20px;
  text-align: center;
  cursor: pointer;
  border: 2px solid transparent;
  transition: all 0.2s;
  box-shadow: var(--sombra);
  position: relative;
}

.dish-card:hover {
  border-color: var(--verde);
  box-shadow: var(--sombra-hover);
}

/* Botão Remover do Cardápio */
.dish-card-remove {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  border: none;
  background: var(--cinza-100);
  color: var(--cinza-500);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  opacity: 0;
  transition: all 0.2s ease;
}

.dish-card:hover .dish-card-remove {
  opacity: 1;
}

.dish-card-remove:hover {
  background: var(--vermelho);
  color: white;
  transform: scale(1.1);
}

.dish-icon {
  width: 72px;
  height: 72px;
  background: var(--verde-claro);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 16px;
  font-size: 1.8rem;
  color: var(--verde);
}

.dish-name {
  font-weight: 600;
  margin-bottom: 16px;
  display: block;
  font-size: 1.05rem;
}

.dish-sizes {
  display: flex;
  gap: 10px;
}

.size-btn {
  flex: 1;
  padding: 12px 8px;
  border: 2px solid var(--cinza-200);
  background: white;
  border-radius: var(--raio);
  cursor: pointer;
  transition: all 0.2s;
}

.size-btn:hover {
  border-color: var(--verde);
  background: var(--verde-claro);
}

.size-label {
  font-size: 1.2rem;
  font-weight: 700;
  display: block;
  color: var(--cinza-700);
}

.size-price {
  font-size: 13px;
  color: var(--cinza-500);
}

/* Carrinho */
.cart-section {
  margin-bottom: 24px;
}

.cart-section h2 {
  font-size: 1rem;
  color: var(--cinza-700);
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 10px;
}

.cart-list {
  background: white;
  border-radius: var(--raio);
  overflow: hidden;
  box-shadow: var(--sombra);
}

/* Carrinho vazio */
.cart-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 48px 24px;
  color: var(--cinza-400);
  gap: 12px;
}

.cart-empty i {
  font-size: 2.5rem;
  opacity: 0.4;
}

.cart-empty span {
  font-size: 0.95rem;
}

/* Item do carrinho */
.cart-item {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 16px;
  background: var(--cinza-50);
  margin: 8px;
  border-radius: var(--raio-sm);
  border: 1px solid var(--borda);
  transition: all 0.2s;
}

.cart-item:hover {
  border-color: var(--verde);
  box-shadow: 0 2px 8px rgba(0, 166, 81, 0.1);
}

.cart-item-row {
  display: flex;
  align-items: center;
  gap: 12px;
}

.cart-icon {
  width: 36px;
  height: 36px;
  background: var(--verde-claro);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--verde);
  font-size: 0.95rem;
}

.cart-item-info {
  flex: 1;
}

.cart-item-controls {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

/* Selects no carrinho */
.cart-select-group {
  display: flex;
  align-items: center;
  gap: 4px;
  background: var(--bg-card);
  padding: 4px 8px;
  border-radius: 6px;
  border: 1px solid var(--borda);
}

.cart-select-group i {
  font-size: 0.75rem;
  color: var(--texto-secundario);
}

.cart-select-group.pagamento i {
  color: var(--verde);
}

.cart-select-group.canal i {
  color: var(--laranja);
}

.cart-select {
  padding: 4px 6px;
  border: none;
  border-radius: 4px;
  font-size: 0.8rem;
  background: transparent;
  color: var(--texto-primario);
  cursor: pointer;
  font-weight: 500;
}

.cart-select:focus {
  outline: none;
}

.cart-item-info strong {
  display: block;
  font-size: 15px;
}

.cart-item-info span {
  font-size: 13px;
  color: var(--cinza-500);
}

.cart-qty {
  display: flex;
  align-items: center;
  gap: 6px;
  background: var(--bg-card);
  padding: 4px;
  border-radius: 6px;
  border: 1px solid var(--borda);
}

.qty-btn {
  width: 28px;
  height: 28px;
  border: none;
  background: var(--cinza-100);
  border-radius: 4px;
  font-size: 1rem;
  cursor: pointer;
  transition: all 0.2s;
  font-weight: 600;
  color: var(--texto-primario);
}

.qty-btn:hover {
  background: var(--verde);
  color: white;
}

.qty-value {
  font-weight: 700;
  min-width: 24px;
  text-align: center;
  font-size: 0.95rem;
}

.cart-item-total {
  font-weight: 700;
  color: var(--verde);
  font-size: 1rem;
  background: var(--verde-claro);
  padding: 6px 12px;
  border-radius: 6px;
  margin-left: auto;
}

/* Pagamento */
.payment-section {
  margin-bottom: 24px;
}

.payment-section h2,
.channel-section h2 {
  font-size: 1rem;
  color: var(--cinza-700);
  margin-bottom: 12px;
}

.payment-options {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.payment-btn {
  flex: 1;
  min-width: 120px;
  padding: 16px 12px;
  background: white;
  border: 2px solid var(--cinza-200);
  border-radius: var(--raio);
  cursor: pointer;
  font-weight: 500;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  transition: all 0.2s;
  box-shadow: var(--sombra);
}

.payment-btn i {
  font-size: 1.5rem;
  color: var(--cinza-500);
}

.payment-btn:hover {
  border-color: var(--verde);
}

.payment-btn.active {
  border-color: var(--verde);
  background: var(--verde-claro);
}

.payment-btn.active i {
  color: var(--verde);
}

/* Canal de Venda */
.channel-section {
  margin-bottom: 32px;
}

.channel-options {
  display: flex;
  gap: 12px;
}

.channel-btn {
  flex: 1;
  padding: 14px 16px;
  background: white;
  border: 2px solid var(--cinza-200);
  border-radius: var(--raio);
  cursor: pointer;
  font-weight: 500;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  transition: all 0.2s;
  box-shadow: var(--sombra);
}

.channel-btn i {
  font-size: 1.2rem;
}

.channel-btn:hover {
  border-color: var(--verde);
}

.channel-btn.active {
  border-color: var(--verde);
  background: var(--verde-claro);
  color: var(--verde);
}

/* Botão Finalizar Venda */
.finish-sale-btn {
  width: 100%;
  background: var(--verde);
  color: white;
  border: none;
  padding: 20px;
  border-radius: var(--raio);
  font-size: 1.2rem;
  font-weight: 700;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  transition: all 0.2s;
  box-shadow: 0 4px 12px rgba(45, 106, 79, 0.3);
}

.finish-sale-btn:hover {
  background: var(--verde-escuro);
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(45, 106, 79, 0.4);
}

/* =============================================
   Página de Estoque
   ============================================= */

.simple-filters {
  display: flex;
  gap: 10px;
  margin-bottom: 24px;
  flex-wrap: wrap;
}

.filter-chip {
  padding: 10px 20px;
  border: none;
  border-radius: 25px;
  background: white;
  cursor: pointer;
  font-weight: 500;
  transition: all 0.2s;
  box-shadow: var(--sombra);
}

.filter-chip.active {
  background: var(--verde);
  color: white;
}

.filter-chip.danger-chip.active {
  background: var(--vermelho);
}

.filter-chip.warning-chip.active {
  background: var(--amarelo);
  color: var(--cinza-900);
}

.filter-chip.success-chip.active {
  background: var(--verde);
}

.filter-chip:not(.active):hover {
  background: var(--cinza-100);
}

.stock-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.stock-item {
  background: white;
  border-radius: var(--raio);
  padding: 16px 20px;
  display: flex;
  align-items: center;
  gap: 16px;
  box-shadow: var(--sombra);
  transition: all 0.2s;
}

.stock-item:hover {
  box-shadow: var(--sombra-hover);
}

.stock-item.critical {
  border-left: 4px solid var(--vermelho);
}

.stock-item.warning {
  border-left: 4px solid var(--amarelo);
}

.stock-item.ok {
  border-left: 4px solid var(--verde);
}

.stock-visual {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}

.stock-icon {
  width: 48px;
  height: 48px;
  border-radius: var(--raio);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
}

.stock-item.critical .stock-icon {
  background: var(--vermelho-claro);
  color: var(--vermelho);
}

.stock-item.warning .stock-icon {
  background: var(--amarelo-claro);
  color: var(--amarelo);
}

.stock-item.ok .stock-icon {
  background: var(--verde-claro);
  color: var(--verde);
}

.stock-bar-mini {
  width: 48px;
  height: 6px;
  background: var(--cinza-200);
  border-radius: 3px;
  overflow: hidden;
}

.stock-bar-fill {
  height: 100%;
  border-radius: 3px;
  transition: width 0.3s;
}

.stock-item.critical .stock-bar-fill {
  background: var(--vermelho);
}

.stock-item.warning .stock-bar-fill {
  background: var(--amarelo);
}

.stock-item.ok .stock-bar-fill {
  background: var(--verde);
}

.stock-info {
  flex: 1;
}

.stock-info strong {
  display: block;
  font-size: 1.05rem;
}

.stock-status {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.stock-status.critical { color: var(--vermelho); }
.stock-status.warning { color: var(--amarelo); }
.stock-status.ok { color: var(--verde); }

.stock-numbers {
  text-align: right;
  min-width: 80px;
}

.stock-current {
  display: block;
  font-size: 1.2rem;
  font-weight: 700;
}

.stock-min {
  font-size: 12px;
  color: var(--cinza-500);
}

.stock-action {
  width: 44px;
  height: 44px;
  background: var(--cinza-100);
  border: none;
  border-radius: var(--raio);
  cursor: pointer;
  font-size: 1.1rem;
  color: var(--cinza-700);
  transition: all 0.2s;
}

.stock-action:hover {
  background: var(--verde);
  color: white;
}

/* Botões de ação do estoque (novo layout) */
.stock-actions {
  display: flex;
  gap: 8px;
  margin-left: auto;
}

.stock-action-btn {
  width: 40px;
  height: 40px;
  border: none;
  border-radius: var(--raio-sm);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
  font-size: 0.95rem;
}

.stock-action-btn.ajustar {
  background: var(--verde-claro);
  color: var(--verde);
}

.stock-action-btn.ajustar:hover {
  background: var(--verde);
  color: white;
  transform: scale(1.05);
}

.stock-action-btn.comprar {
  background: var(--laranja-claro);
  color: var(--laranja);
}

.stock-action-btn.comprar:hover {
  background: var(--laranja);
  color: white;
  transform: scale(1.05);
}

.stock-action-btn.deletar {
  background: rgba(239, 68, 68, 0.1);
  color: #ef4444;
}

.stock-action-btn.deletar:hover {
  background: #ef4444;
  color: white;
  transform: scale(1.05);
}

/* Dark mode - Botões de ação do estoque */
body.dark-theme .stock-action-btn.ajustar {
  background: rgba(45, 106, 79, 0.2);
  color: #4ade80;
}

body.dark-theme .stock-action-btn.ajustar:hover {
  background: var(--verde);
  color: white;
}

body.dark-theme .stock-action-btn.comprar {
  background: rgba(232, 93, 4, 0.2);
  color: #fb923c;
}

body.dark-theme .stock-action-btn.comprar:hover {
  background: var(--laranja);
  color: white;
}

body.dark-theme .stock-action-btn.deletar {
  background: rgba(239, 68, 68, 0.2);
  color: #f87171;
}

body.dark-theme .stock-action-btn.deletar:hover {
  background: #ef4444;
  color: white;
}

/* Ajuste do layout do stock-item para acomodar os botões */
.stock-item {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

@media (max-width: 768px) {
  /* Card de estoque compacto para mobile */
  .stock-item {
    display: grid;
    grid-template-columns: 1fr auto auto;
    grid-template-rows: auto auto;
    gap: 8px 12px;
    padding: 14px 16px;
    align-items: center;
  }

  .stock-info {
    grid-column: 1;
    grid-row: 1;
  }

  .stock-info strong {
    font-size: 0.95rem;
  }

  .stock-info .stock-qty {
    font-size: 0.8rem;
  }

  .stock-numbers {
    grid-column: 2;
    grid-row: 1;
    text-align: right;
    min-width: auto;
  }

  .stock-numbers .stock-current {
    font-size: 1.1rem;
    font-weight: 700;
  }

  .stock-numbers .stock-min {
    font-size: 0.75rem;
  }

  .stock-status {
    grid-column: 3;
    grid-row: 1;
    font-size: 0.7rem;
    padding: 4px 8px;
    border-radius: 4px;
    background: var(--verde-claro);
  }

  .stock-status.critico {
    background: var(--vermelho-claro);
  }

  .stock-status.baixo {
    background: var(--amarelo-claro);
  }

  .stock-actions {
    grid-column: 1 / -1;
    grid-row: 2;
    display: flex;
    gap: 8px;
    margin-top: 4px;
  }

  .stock-action-btn {
    flex: 1;
    padding: 10px;
    font-size: 0.9rem;
  }

  .stock-action-btn.ajustar {
    max-width: none;
  }

  .stock-action-btn.deletar {
    max-width: none;
  }
}

@media (max-width: 480px) {
  .stock-item {
    padding: 12px 14px;
  }

  .stock-info strong {
    font-size: 0.9rem;
  }

  .stock-numbers .stock-current {
    font-size: 1rem;
  }

  .stock-action-btn {
    padding: 12px;
    min-height: 44px;
  }
}

/* =============================================
   Página de Receitas
   ============================================= */

.recipes-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(320px, 100%), 1fr));
  gap: 20px;
  max-width: 100%;
}

.recipe-card-new {
  background: white;
  border-radius: var(--raio);
  padding: 24px;
  box-shadow: var(--sombra);
  cursor: pointer;
  transition: all 0.2s;
}

.recipe-card-new:hover {
  box-shadow: var(--sombra-hover);
  transform: translateY(-2px);
}

.recipe-card-new.add-recipe {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 200px;
  border: 2px dashed var(--cinza-300);
  background: var(--cinza-50);
  color: var(--cinza-500);
}

.recipe-card-new.add-recipe:hover {
  border-color: var(--verde);
  color: var(--verde);
  background: var(--verde-claro);
}

.add-icon {
  font-size: 2.5rem;
  margin-bottom: 12px;
}

.recipe-header {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 20px;
}

.recipe-icon {
  width: 56px;
  height: 56px;
  background: var(--laranja-claro);
  border-radius: var(--raio);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  color: var(--laranja);
}

.recipe-title {
  flex: 1;
}

.recipe-title strong {
  display: block;
  font-size: 1.1rem;
  margin-bottom: 4px;
}

.recipe-cat {
  font-size: 13px;
  color: var(--cinza-500);
  background: var(--cinza-100);
  padding: 2px 10px;
  border-radius: 12px;
}

.recipe-costs {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 16px;
}

.cost-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  background: var(--cinza-50);
  border-radius: var(--raio-sm);
}

.cost-label {
  font-weight: 600;
  min-width: 80px;
}

.cost-value {
  flex: 1;
  font-weight: 700;
  color: var(--verde);
}

.cost-margin {
  font-size: 13px;
  padding: 4px 10px;
  border-radius: 12px;
}

.cost-margin.good {
  background: var(--verde-claro);
  color: var(--verde);
}

.recipe-footer {
  color: var(--cinza-500);
  font-size: 14px;
  display: flex;
  align-items: center;
  gap: 8px;
  padding-top: 16px;
  border-top: 1px solid var(--cinza-100);
}

/* =============================================
   Página de Produção
   ============================================= */

.production-today {
  margin-bottom: 32px;
}

.production-today h2 {
  font-size: 1rem;
  color: var(--cinza-700);
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  gap: 10px;
}

.production-today h2 i {
  color: var(--laranja);
}

.production-card-new {
  background: white;
  border-radius: var(--raio);
  padding: 24px;
  margin-bottom: 16px;
  box-shadow: var(--sombra);
}

.prod-header {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 20px;
}

.prod-icon {
  width: 52px;
  height: 52px;
  background: var(--verde-claro);
  border-radius: var(--raio);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  color: var(--verde);
}

.prod-title {
  flex: 1;
}

.prod-title strong {
  display: block;
  font-size: 1.1rem;
}

.prod-time {
  font-size: 13px;
  color: var(--cinza-500);
}

.prod-numbers {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100px, 100%), 1fr));
  gap: 16px;
  margin-bottom: 16px;
  max-width: 100%;
}

.prod-number {
  text-align: center;
  padding: 16px;
  background: var(--cinza-50);
  border-radius: var(--raio);
}

.number-value {
  display: block;
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--verde);
}

.number-label {
  font-size: 13px;
  color: var(--cinza-500);
}

.prod-status {
  padding: 12px 16px;
  border-radius: var(--raio);
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 500;
  margin-bottom: 12px;
}

.prod-status.good {
  background: var(--verde-claro);
  color: var(--verde);
}

.prod-status.warning {
  background: var(--amarelo-claro);
  color: var(--amarelo);
}

.prod-cost {
  text-align: right;
  color: var(--cinza-500);
}

.prod-cost strong {
  color: var(--verde);
  font-size: 1.1rem;
}

/* =============================================
   Página de Compras
   ============================================= */

.purchases-list h2 {
  font-size: 1rem;
  color: var(--cinza-700);
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  gap: 10px;
}

.purchase-card {
  background: white;
  border-radius: var(--raio);
  padding: 20px;
  margin-bottom: 12px;
  box-shadow: var(--sombra);
  transition: all 0.2s;
}

.purchase-card:hover {
  box-shadow: var(--sombra-hover);
}

.purchase-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 12px;
}

.purchase-info strong {
  display: block;
  font-size: 1.05rem;
  margin-bottom: 4px;
}

.purchase-info span {
  font-size: 13px;
  color: var(--cinza-500);
}

.purchase-total {
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--verde);
}

.purchase-items {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 12px;
  border-top: 1px solid var(--cinza-100);
}

.purchase-items span {
  color: var(--cinza-500);
  font-size: 14px;
}

.view-btn {
  background: var(--cinza-100);
  border: none;
  padding: 8px 16px;
  border-radius: var(--raio-sm);
  cursor: pointer;
  font-size: 14px;
  display: flex;
  align-items: center;
  gap: 6px;
  transition: all 0.2s;
}

.view-btn:hover {
  background: var(--verde);
  color: white;
}

/* =============================================
   Página de Cardápio Semanal
   ============================================= */

.week-nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  margin-bottom: 24px;
}

.week-btn {
  width: 44px;
  height: 44px;
  background: white;
  border: 2px solid var(--cinza-200);
  border-radius: var(--raio);
  cursor: pointer;
  font-size: 1rem;
  transition: all 0.2s;
}

.week-btn:hover {
  border-color: var(--verde);
  color: var(--verde);
}

.week-label {
  font-size: 1.1rem;
  font-weight: 600;
}

.calendar-simple {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 12px;
  max-width: 100%;
  overflow-x: auto;
}

.day-card {
  background: white;
  border-radius: var(--raio);
  padding: 16px;
  box-shadow: var(--sombra);
  transition: all 0.2s;
  min-height: 200px;
  position: relative;
  overflow: visible;
}

.day-card:hover {
  box-shadow: var(--sombra-hover);
}

.day-card.today {
  border: 2px solid var(--verde);
  background: var(--verde-claro);
}

.day-card.weekend {
  opacity: 0.6;
}

.day-header-simple {
  text-align: center;
  margin-bottom: 12px;
  padding-bottom: 12px;
  padding-top: 8px;
  border-bottom: 1px solid var(--cinza-100);
  position: relative;
}

.day-card.today .day-header-simple {
  border-bottom-color: var(--verde);
}

.day-name {
  display: block;
  font-size: 12px;
  font-weight: 600;
  color: var(--cinza-500);
  text-transform: uppercase;
  margin-bottom: 4px;
}

.day-num {
  font-size: 1.4rem;
  font-weight: 700;
}

.today-badge {
  position: absolute;
  top: -8px;
  right: -8px;
  background: var(--verde);
  color: white;
  font-size: 10px;
  padding: 3px 8px;
  border-radius: 10px;
  font-weight: 700;
}

.day-dishes {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.day-dish {
  padding: 8px 12px;
  background: var(--cinza-50);
  border-radius: var(--raio-sm);
  font-size: 13px;
  font-weight: 500;
}

.day-dish.special {
  background: var(--laranja-claro);
  color: var(--laranja);
}

.day-dishes.empty {
  color: var(--cinza-500);
  font-style: italic;
  text-align: center;
  padding: 20px 0;
}

/* =============================================
   Cardápio Semanal - Melhorias
   ============================================= */

/* Card do dia - clicável */
.day-card {
  cursor: pointer;
  display: flex;
  flex-direction: column;
}

.day-card:hover {
  border-color: var(--verde);
}

/* Indicador HOJE melhorado */
.today-indicator {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 10;
}

.today-badge-new {
  background: linear-gradient(135deg, var(--verde) 0%, var(--verde-escuro) 100%);
  color: white;
  font-size: 11px;
  font-weight: 700;
  padding: 4px 12px;
  border-radius: 12px;
  box-shadow: 0 2px 8px rgba(45, 106, 79, 0.4);
  animation: todayPulse 2s ease-in-out infinite;
}

@keyframes todayPulse {
  0%, 100% { box-shadow: 0 2px 8px rgba(45, 106, 79, 0.4); }
  50% { box-shadow: 0 4px 16px rgba(45, 106, 79, 0.6); }
}

/* Contador de itens do dia */
.day-count {
  display: block;
  font-size: 11px;
  color: var(--verde);
  font-weight: 600;
  margin-top: 4px;
  background: var(--verde-claro);
  padding: 2px 8px;
  border-radius: 10px;
}

/* Lista de pratos do dia */
.day-dishes-list {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 12px;
  min-height: 60px;
}

/* Card do prato individual */
.day-dish-card {
  padding: 10px 12px;
  border-radius: var(--raio-sm);
  position: relative;
  transition: all 0.2s;
  border-left: 3px solid transparent;
}

.day-dish-card:hover {
  transform: translateX(2px);
}

/* Cores por categoria */
.day-dish-card.verde {
  background: var(--verde-claro);
  border-left-color: var(--verde);
}

.day-dish-card.laranja {
  background: var(--laranja-claro);
  border-left-color: var(--laranja);
}

.day-dish-card.verde-claro {
  background: rgba(216, 243, 220, 0.5);
  border-left-color: #40916c;
}

.day-dish-card.rosa {
  background: #fce7f3;
  border-left-color: #ec4899;
}

.day-dish-card.azul {
  background: #dbeafe;
  border-left-color: #3b82f6;
}

.day-dish-card.amarelo {
  background: var(--amarelo-claro);
  border-left-color: var(--amarelo);
}

.day-dish-card.marrom {
  background: #fef3c7;
  border-left-color: #d97706;
}

.day-dish-card.cinza {
  background: var(--cinza-100);
  border-left-color: var(--cinza-500);
}

/* Header do card do prato */
.dish-card-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
}

.dish-cat-icon {
  font-size: 12px;
  opacity: 0.7;
}

.dish-card-name {
  font-weight: 600;
  font-size: 13px;
  flex: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Preços do prato */
.dish-card-prices {
  display: flex;
  gap: 8px;
  margin-bottom: 6px;
}

.dish-price {
  font-size: 11px;
  font-weight: 600;
  color: var(--verde);
  background: rgba(255,255,255,0.6);
  padding: 2px 6px;
  border-radius: 4px;
}

/* Expectativa inline no card */
.dish-card-expectativa {
  display: flex;
  gap: 6px;
  margin-bottom: 6px;
  justify-content: center;
}

.expectativa-mini-group {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
}

.expectativa-mini-group label {
  font-size: 9px;
  font-weight: 700;
  width: 100%;
  text-align: center;
  padding: 2px 0;
  border-radius: 3px 3px 0 0;
}

.expectativa-mini-group label.label-p {
  background: var(--laranja);
  color: white;
}

.expectativa-mini-group label.label-g {
  background: var(--verde);
  color: white;
}

.expectativa-mini-input {
  width: 36px;
  padding: 4px 2px;
  border: 1px solid var(--borda);
  border-top: none;
  border-radius: 0 0 4px 4px;
  text-align: center;
  font-size: 12px;
  font-weight: 600;
  background: rgba(255,255,255,0.9);
  color: var(--texto-primario);
}

.expectativa-mini-input:focus {
  outline: none;
  border-color: var(--verde);
  box-shadow: 0 0 0 2px rgba(45, 106, 79, 0.15);
}

.expectativa-mini-input::-webkit-inner-spin-button,
.expectativa-mini-input::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.expectativa-mini-input[type="number"] {
  -moz-appearance: textfield;
}

body.dark-theme .expectativa-mini-input {
  background: rgba(0,0,0,0.3);
  border-color: var(--borda);
  color: var(--texto-primario);
}

/* Ações do card do prato */
.dish-card-actions {
  display: flex;
  gap: 6px;
  justify-content: flex-end;
}

.dish-action-btn {
  width: 28px;
  height: 28px;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
  font-size: 12px;
}

.dish-action-btn.toggle-disp {
  background: rgba(255,255,255,0.7);
  color: var(--cinza-700);
}

.dish-action-btn.toggle-disp:hover {
  background: var(--amarelo);
  color: white;
}

.dish-action-btn.remove {
  background: rgba(255,255,255,0.7);
  color: var(--vermelho);
}

.dish-action-btn.remove:hover {
  background: var(--vermelho);
  color: white;
}

/* Prato esgotado */
.day-dish-card.esgotado {
  opacity: 0.6;
  filter: grayscale(50%);
}

.esgotado-badge {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(-15deg);
  background: var(--vermelho);
  color: white;
  font-size: 10px;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 4px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* Estado vazio melhorado */
.day-dishes-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 20px 10px;
  color: var(--cinza-500);
  font-style: italic;
  text-align: center;
}

.day-dishes-empty .empty-icon {
  font-size: 1.5rem;
  opacity: 0.4;
}

.day-dishes-empty span {
  font-size: 12px;
}

/* Botão adicionar no dia */
.add-dish-btn {
  width: 100%;
  padding: 10px;
  background: transparent;
  border: 2px dashed var(--cinza-300);
  border-radius: var(--raio-sm);
  cursor: pointer;
  font-size: 13px;
  font-weight: 500;
  color: var(--cinza-500);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  transition: all 0.2s;
  margin-top: auto;
}

.add-dish-btn:hover {
  border-color: var(--verde);
  color: var(--verde);
  background: var(--verde-claro);
}

/* Dark mode - Cardápio Semanal Melhorado */
body.dark-theme .day-dish-card.verde {
  background: rgba(45, 106, 79, 0.2);
}

body.dark-theme .day-dish-card.laranja {
  background: rgba(232, 93, 4, 0.2);
}

body.dark-theme .day-dish-card.verde-claro {
  background: rgba(64, 145, 108, 0.2);
}

body.dark-theme .day-dish-card.rosa {
  background: rgba(236, 72, 153, 0.2);
}

body.dark-theme .day-dish-card.azul {
  background: rgba(59, 130, 246, 0.2);
}

body.dark-theme .day-dish-card.amarelo {
  background: rgba(245, 158, 11, 0.2);
}

body.dark-theme .day-dish-card.marrom {
  background: rgba(217, 119, 6, 0.2);
}

body.dark-theme .day-dish-card.cinza {
  background: rgba(113, 113, 122, 0.2);
}

body.dark-theme .dish-card-name {
  color: var(--texto-primario);
}

body.dark-theme .dish-card-remove {
  background: rgba(255,255,255,0.1);
  color: var(--texto-secundario);
}

body.dark-theme .dish-card-remove:hover {
  background: var(--vermelho);
  color: white;
}

body.dark-theme .dish-price {
  background: rgba(0,0,0,0.2);
  color: #4ade80;
}

body.dark-theme .dish-action-btn.toggle-disp {
  background: rgba(0,0,0,0.2);
  color: var(--texto-secundario);
}

body.dark-theme .dish-action-btn.remove {
  background: rgba(0,0,0,0.2);
}

body.dark-theme .day-count {
  background: var(--verde-claro);
  color: #4ade80;
}

body.dark-theme .add-dish-btn {
  border-color: var(--borda);
  color: var(--texto-secundario);
}

body.dark-theme .add-dish-btn:hover {
  border-color: var(--verde);
  color: var(--verde);
  background: var(--verde-claro);
}

body.dark-theme .day-dishes-empty {
  color: var(--texto-secundario);
}

/* Responsivo - Cardápio melhorado */
@media (max-width: 1200px) {
  .calendar-simple {
    grid-template-columns: repeat(4, 1fr);
  }
}

@media (max-width: 900px) {
  .calendar-simple {
    grid-template-columns: repeat(3, 1fr);
  }

  .dish-card-prices {
    flex-direction: column;
    gap: 4px;
  }
}

@media (max-width: 600px) {
  .calendar-simple {
    grid-template-columns: repeat(2, 1fr);
  }

  .day-card.weekend {
    display: block;
  }
}

/* =============================================
   Modais
   ============================================= */

.modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 1000;
  align-items: center;
  justify-content: center;
  padding: 20px;
}

.modal.active {
  display: flex;
}

.modal-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.5);
  backdrop-filter: blur(4px);
}

.modal-content-new {
  position: relative;
  background: white;
  border-radius: var(--raio);
  width: 100%;
  max-width: min(560px, calc(100vw - 40px));
  max-height: 90vh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: 0 20px 40px rgba(0,0,0,0.2);
}

.modal-header-new {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 24px;
  border-bottom: 1px solid var(--cinza-100);
  background: var(--cinza-50);
}

.modal-header-new .modal-icon {
  width: 52px;
  height: 52px;
  background: var(--verde-claro);
  border-radius: var(--raio);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  color: var(--verde);
}

.modal-header-new h2 {
  flex: 1;
  font-size: 1.3rem;
}

.modal-close {
  background: var(--cinza-100);
  border: none;
  width: 40px;
  height: 40px;
  border-radius: var(--raio-sm);
  cursor: pointer;
  font-size: 1.1rem;
  transition: all 0.2s;
}

.modal-close:hover {
  background: var(--vermelho-claro);
  color: var(--vermelho);
}

.modal-body-new {
  padding: 24px;
  overflow-y: auto;
  flex: 1;
}

.modal-footer-new {
  padding: 20px 24px;
  border-top: 1px solid var(--cinza-100);
  display: flex;
  gap: 12px;
  justify-content: flex-end;
  background: var(--cinza-50);
}

/* Ficha Técnica */
.ficha-section {
  margin-bottom: 24px;
}

.ficha-section h3 {
  font-size: 0.85rem;
  color: var(--cinza-500);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 12px;
}

.ficha-info-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(120px, 100%), 1fr));
  gap: 12px;
  max-width: 100%;
}

.ficha-info-item {
  background: var(--cinza-50);
  padding: 12px 16px;
  border-radius: var(--raio-sm);
  text-align: center;
}

.info-label {
  display: block;
  font-size: 12px;
  color: var(--cinza-500);
  margin-bottom: 4px;
}

.info-value {
  font-weight: 700;
  color: var(--verde);
}

.info-value.highlight {
  color: var(--laranja);
  font-size: 1.1rem;
}

.info-hint {
  display: block;
  font-size: 0.7rem;
  color: var(--cinza-400);
  margin-top: 2px;
  font-style: italic;
}

/* Rendimento por tamanho */
.ficha-rendimento-grid {
  display: flex;
  gap: 16px;
}

.ficha-rendimento-item {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 12px;
  background: var(--cinza-50);
  padding: 16px;
  border-radius: var(--raio-sm);
  border: 1px solid var(--borda);
}

.rendimento-icon {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 1.2rem;
  flex-shrink: 0;
}

.rendimento-icon.pequena {
  background: var(--verde-claro);
  color: var(--verde);
}

.rendimento-icon.grande {
  background: var(--laranja-claro);
  color: var(--laranja);
}

.rendimento-info {
  display: flex;
  flex-direction: column;
}

.rendimento-qtd {
  font-weight: 700;
  font-size: 1.1rem;
  color: var(--texto-primario);
}

.rendimento-desc {
  font-size: 0.85rem;
  color: var(--cinza-500);
}

.ingredients-table {
  background: var(--cinza-50);
  border-radius: var(--raio);
  overflow: hidden;
  max-width: 100%;
  overflow-x: auto;
}

.ing-row {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  padding: 12px 16px;
  border-bottom: 1px solid white;
}

.ing-row.header {
  background: var(--cinza-100);
  font-size: 12px;
  font-weight: 600;
  color: var(--cinza-500);
  text-transform: uppercase;
}

.ing-row.total {
  background: var(--verde-claro);
}

.marmita-costs {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(200px, 100%), 1fr));
  gap: 16px;
  max-width: 100%;
}

.marmita-cost-card {
  background: var(--cinza-50);
  border-radius: var(--raio);
  padding: 16px;
  display: flex;
  align-items: center;
  gap: 16px;
}

.marmita-size {
  width: 48px;
  height: 48px;
  background: var(--verde);
  color: white;
  border-radius: var(--raio);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  font-weight: 700;
}

.marmita-details {
  flex: 1;
}

.marmita-details span {
  display: block;
  font-size: 13px;
  color: var(--cinza-500);
  margin-bottom: 2px;
}

.marmita-total {
  color: var(--verde);
  font-size: 1.1rem;
}

/* Formulários nos Modais */
.form-group-new {
  margin-bottom: 20px;
}

.form-group-new label {
  display: block;
  font-weight: 600;
  margin-bottom: 8px;
  font-size: 14px;
}

.select-new,
.input-new {
  width: 100%;
  max-width: 100%;
  padding: 14px 16px;
  border: 2px solid var(--cinza-200);
  border-radius: var(--raio);
  font-size: 16px;
  font-family: inherit;
  transition: all 0.2s;
  background: white;
}

.select-new:focus,
.input-new:focus {
  outline: none;
  border-color: var(--verde);
}

.form-row-new {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

/* Input com botão ao lado */
.input-with-btn {
  display: flex;
  gap: 10px;
  align-items: stretch;
}

.input-with-btn .select-new,
.input-with-btn .input-new {
  flex: 1;
}

.btn-add-inline {
  width: 48px;
  height: 48px;
  min-width: 48px;
  border: 2px solid var(--verde);
  background: var(--verde);
  color: white;
  border-radius: var(--raio);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  transition: all 0.2s;
}

.btn-add-inline:hover {
  background: var(--verde-escuro);
  border-color: var(--verde-escuro);
  transform: scale(1.05);
}

.input-hint {
  display: block;
  font-size: 13px;
  color: var(--cinza-500);
  margin-top: 6px;
}

/* Input com seletor de unidade */
.input-with-unit {
  display: flex;
  gap: 8px;
  align-items: stretch;
}

.input-with-unit .input-new {
  flex: 1;
}

.select-unit {
  width: 80px;
  min-width: 80px;
  padding: 12px 8px;
  border: 1px solid var(--borda-input);
  border-radius: var(--raio);
  background: var(--bg-input);
  color: var(--texto-primario);
  font-size: 14px;
  cursor: pointer;
  text-align: center;
}

.select-unit:focus {
  outline: none;
  border-color: var(--verde);
  box-shadow: 0 0 0 3px rgba(45, 106, 79, 0.1);
}

/* Select de unidade nos itens de compra */
.compra-unidade {
  width: 65px;
  min-width: 65px;
  padding: 8px 4px;
  border: 1px solid var(--borda-input);
  border-radius: var(--raio-sm);
  background: var(--bg-input);
  color: var(--texto-primario);
  font-size: 13px;
  cursor: pointer;
  text-align: center;
}

.items-add-list {
  background: var(--cinza-50);
  border-radius: var(--raio);
  padding: 12px;
  border: 1px solid var(--borda);
}

body.dark-theme .items-add-list {
  background: var(--bg-input);
}

.item-add-row {
  display: flex;
  gap: 8px;
  align-items: center;
  margin-bottom: 8px;
  padding: 10px 12px;
  background: var(--bg-card);
  border: 1px solid var(--borda);
  border-radius: var(--raio-sm);
}

body.dark-theme .item-add-row {
  background: var(--bg-input);
}

.insumo-select-wrapper {
  display: flex;
  flex-direction: column;
  gap: 3px;
  flex: 2;
  min-width: 180px;
  max-width: 280px;
}

.insumo-select-wrapper .select-row {
  display: flex;
  align-items: center;
  gap: 6px;
}

.insumo-select-wrapper .select-small-new {
  flex: 1;
  min-width: 120px;
  font-size: 13px;
  padding: 8px 10px;
  height: 36px;
}

/* Label do produto OCR - pequeno e discreto */
.produto-ocr-label {
  font-size: 10px;
  padding: 2px 8px;
  border-radius: 3px;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 200px;
}

.produto-ocr-label i {
  font-size: 9px;
  flex-shrink: 0;
}

/* Insumo será criado automaticamente (laranja) */
.produto-ocr-label.auto-create {
  color: var(--laranja);
  background: var(--laranja-claro);
}

.produto-ocr-label.auto-create .auto-badge {
  background: var(--laranja);
  color: white;
  font-size: 8px;
  padding: 1px 4px;
  border-radius: 2px;
  font-weight: 600;
  flex-shrink: 0;
}

/* Insumo encontrado (verde) */
.produto-ocr-label.matched {
  color: var(--verde);
  background: var(--verde-claro);
}

body.dark-theme .produto-ocr-label.auto-create {
  background: rgba(232, 93, 4, 0.15);
  color: #f97316;
}

body.dark-theme .produto-ocr-label.auto-create .auto-badge {
  background: #f97316;
}

body.dark-theme .produto-ocr-label.matched {
  background: rgba(45, 106, 79, 0.2);
  color: #4ade80;
}

/* Mensagem de auto-create (substitui o select) */
.auto-create-message {
  display: flex;
  align-items: center;
  gap: 6px;
  color: var(--verde);
  font-size: 12px;
  font-weight: 500;
  padding: 0 10px;
  background: var(--verde-claro);
  border-radius: var(--raio-sm);
  flex: 1;
  min-width: 120px;
  height: 36px;
}

.auto-create-message i {
  font-size: 12px;
  flex-shrink: 0;
}

body.dark-theme .auto-create-message {
  background: rgba(45, 106, 79, 0.15);
  color: #4ade80;
}

.btn-add-insumo-inline {
  width: 32px;
  height: 32px;
  min-width: 32px;
  border: 1px solid var(--verde);
  background: var(--bg-card);
  color: var(--verde);
  border-radius: var(--raio-sm);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  transition: all 0.2s;
  flex-shrink: 0;
}

.btn-add-insumo-inline:hover {
  background: var(--verde);
  color: white;
}

.select-small-new,
.input-small-new {
  padding: 8px 10px;
  border: 1px solid var(--borda);
  border-radius: var(--raio-sm);
  font-size: 13px;
  font-family: inherit;
  background: var(--bg-input);
  color: var(--texto-primario);
  height: 36px;
  box-sizing: border-box;
}

.select-small-new:focus,
.input-small-new:focus {
  outline: none;
  border-color: var(--verde);
}

.select-small-new {
  flex: 2;
  min-width: 120px;
}

.input-small-new {
  flex: 1;
  width: 70px;
  min-width: 70px;
  max-width: 90px;
  text-align: center;
}

.item-row-total {
  font-weight: 700;
  color: var(--verde);
  min-width: 85px;
  text-align: right;
  font-size: 13px;
  white-space: nowrap;
}

.add-item-btn {
  width: 100%;
  padding: 10px;
  background: var(--bg-card);
  border: 2px dashed var(--borda);
  border-radius: var(--raio-sm);
  cursor: pointer;
  font-size: 13px;
  color: var(--texto-secundario);
  transition: all 0.2s;
  margin-top: 4px;
}

.add-item-btn:hover {
  border-color: var(--verde);
  color: var(--verde);
  background: var(--verde-claro);
}

.btn-remove-item {
  background: var(--vermelho-claro);
  color: var(--vermelho);
  border: none;
  border-radius: var(--raio-sm);
  width: 32px;
  height: 32px;
  min-width: 32px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
  font-size: 12px;
  flex-shrink: 0;
}

.btn-remove-item:hover {
  background: var(--vermelho);
  color: white;
}

/* Botão X discreto para remover item */
.btn-remove-item-x {
  background: transparent;
  color: var(--texto-secundario);
  border: none;
  width: 24px;
  height: 24px;
  min-width: 24px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
  font-size: 14px;
  flex-shrink: 0;
  opacity: 0.4;
  border-radius: 50%;
}

.btn-remove-item-x:hover {
  opacity: 1;
  color: var(--vermelho);
  background: var(--vermelho-claro);
}

.purchase-summary {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 20px;
  background: var(--verde-claro);
  border-radius: var(--raio);
  font-size: 1.1rem;
}

.purchase-summary strong {
  font-size: 1.3rem;
  color: var(--verde);
}

.production-preview {
  background: var(--cinza-50);
  border-radius: var(--raio);
  padding: 16px;
}

.production-preview h4 {
  font-size: 14px;
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.preview-items {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.preview-items span {
  font-size: 14px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.preview-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 12px;
  background: var(--bg-card);
  border-radius: var(--raio-sm);
  font-size: 13px;
}

.preview-item.disponivel {
  border-left: 3px solid var(--verde);
}

.preview-item.indisponivel {
  border-left: 3px solid var(--vermelho);
  background: var(--vermelho-claro);
}

.preview-item-nome {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--texto-primario);
}

.preview-item-nome i {
  font-size: 12px;
}

.preview-item.disponivel .preview-item-nome i {
  color: var(--verde);
}

.preview-item.indisponivel .preview-item-nome i {
  color: var(--vermelho);
}

.preview-item-qtd {
  font-weight: 500;
  color: var(--texto-secundario);
  text-align: right;
}

.preview-item-qtd small {
  display: block;
  color: var(--vermelho);
  font-size: 11px;
}

.preview-custo {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--borda);
  text-align: right;
  font-size: 14px;
  color: var(--verde);
}

/* Botões Padrão */
.btn-secondary {
  padding: 14px 24px;
  background: var(--cinza-100);
  border: none;
  border-radius: var(--raio);
  font-weight: 600;
  cursor: pointer;
  font-family: inherit;
  transition: all 0.2s;
}

.btn-secondary:hover {
  background: var(--cinza-200);
}

.btn-primary {
  padding: 14px 24px;
  background: var(--verde);
  color: white;
  border: none;
  border-radius: var(--raio);
  font-weight: 600;
  cursor: pointer;
  font-family: inherit;
  display: flex;
  align-items: center;
  gap: 8px;
  transition: all 0.2s;
}

.btn-primary:hover {
  background: var(--verde-escuro);
}

/* =============================================
   Toast
   ============================================= */

.toast-new {
  position: fixed;
  bottom: 32px;
  left: 50%;
  transform: translateX(-50%) translateY(100px);
  background: var(--verde-escuro);
  color: white;
  padding: 18px 32px;
  border-radius: var(--raio);
  display: flex;
  align-items: center;
  gap: 14px;
  font-weight: 500;
  font-size: 1.05rem;
  opacity: 0;
  transition: all 0.3s;
  z-index: 2000;
  box-shadow: 0 8px 24px rgba(0,0,0,0.2);
}

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

.toast-icon {
  font-size: 1.3rem;
}

/* =============================================
   Responsivo
   ============================================= */

@media (max-width: 1024px) {
  .summary-cards {
    grid-template-columns: repeat(2, 1fr);
  }

  .calendar-simple {
    grid-template-columns: repeat(4, 1fr);
  }
}

/* Overlay do menu mobile */
.sidebar-overlay {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
  z-index: 99;
  opacity: 0;
  transition: opacity 0.3s;
}

.sidebar-overlay.active {
  opacity: 1;
}

body.menu-open {
  overflow: hidden;
}

@media (max-width: 768px) {
  /* Overlay visível apenas em mobile */
  .sidebar-overlay {
    display: block;
    pointer-events: none;
  }

  .sidebar-overlay.active {
    pointer-events: auto;
  }

  .sidebar {
    transform: translateX(-100%);
    transition: transform 0.3s;
    z-index: 100;
  }

  .sidebar.open {
    transform: translateX(0);
  }

  /* Logo no sidebar mobile */
  .logo-showcase {
    padding: 12px;
  }

  .logo-img-large {
    max-width: 180px;
  }

  /* Sidebar-nav com scroll */
  .sidebar-nav {
    overflow-y: auto;
    flex: 1;
    min-height: 0;
  }

  /* Nav items mais compactos */
  .nav-item {
    padding: 10px 12px;
    font-size: 14px;
  }

  .nav-group {
    padding: 6px;
    margin-bottom: 4px;
  }

  .nav-group-header {
    padding: 6px 10px;
    font-size: 10px;
  }

  .main-content {
    margin-left: 0;
    max-width: 100vw;
    width: 100%;
  }

  .header-mobile {
    display: flex;
  }

  .page-content {
    padding: 16px;
    max-width: 100%;
  }

  .motivational-section {
    flex-direction: column;
    text-align: center;
    gap: 16px;
    padding: 20px 16px;
  }

  .motivational-content {
    order: 1;
  }

  .quote-icon {
    font-size: 1.5rem;
    margin-bottom: 8px;
  }

  .motivational-quote {
    font-size: 0.95rem;
    line-height: 1.5;
    margin-bottom: 6px;
  }

  .motivational-author {
    font-size: 0.85rem;
  }

  .greeting-time {
    order: 2;
    border-left: none;
    padding-left: 0;
    margin-left: 0;
    border-top: 1px solid rgba(255,255,255,0.2);
    padding-top: 14px;
    margin-top: 4px;
    text-align: center;
    align-items: center;
  }

  #greetingText {
    font-size: 1.4rem;
  }

  .current-date {
    font-size: 0.85rem;
  }

  .summary-cards {
    grid-template-columns: 1fr;
  }

  .profit-breakdown {
    flex-direction: row;
    gap: 8px;
  }

  .profit-item {
    flex: 1;
    justify-content: center;
  }

  /* ===== TELA DE ESTOQUE MOBILE ===== */

  /* Header do estoque empilhado */
  #page-estoque .page-header-simple {
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
  }

  #page-estoque .page-header-simple h1 {
    font-size: 1.1rem;
    justify-content: flex-start;
  }

  /* Botões do header de estoque em linha com scroll */
  #page-estoque .header-buttons {
    display: flex;
    gap: 8px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 4px;
  }

  #page-estoque .header-buttons .btn-primary,
  #page-estoque .header-buttons .btn-camera {
    flex-shrink: 0;
    padding: 10px 14px;
    font-size: 0.8rem;
    white-space: nowrap;
  }

  /* Filtros de estoque em scroll horizontal */
  .filter-tabs {
    display: flex;
    gap: 6px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 4px;
    margin-bottom: 12px;
  }

  .filter-chip {
    flex-shrink: 0;
    padding: 8px 14px;
    font-size: 0.8rem;
  }

  /* Lista de estoque */
  .stock-list {
    gap: 10px;
  }

  .dishes-grid {
    grid-template-columns: repeat(2, 1fr);
  }

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

  .payment-btn {
    flex: 1 1 45%;
    min-height: 48px;
  }

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

  .channel-btn {
    flex: 1 1 45%;
    min-height: 48px;
  }

  .calendar-simple {
    grid-template-columns: repeat(2, 1fr);
  }

  .day-card.weekend {
    display: none;
  }

  .recipes-list {
    grid-template-columns: 1fr;
  }

  .prod-numbers {
    grid-template-columns: repeat(3, 1fr);
  }

  .ficha-info-grid {
    grid-template-columns: 1fr;
  }

  .marmita-costs {
    grid-template-columns: 1fr;
  }

  .form-row-new {
    grid-template-columns: 1fr;
  }

  /* Carrinho - layout empilhado */
  .cart-item {
    padding: 14px;
  }

  .cart-item-controls {
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
  }

  .cart-select-group {
    flex: 1;
    justify-content: center;
  }

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

  /* Ficha técnica - rendimento empilhado */
  .ficha-rendimento-grid {
    flex-direction: column;
  }

  /* Touch targets maiores */
  .size-btn {
    min-height: 44px;
    min-width: 70px;
    font-size: 0.9rem;
  }

  .qty-btn {
    width: 36px;
    height: 36px;
    font-size: 1.2rem;
  }

  /* Tabela de ingredientes - layout empilhado mobile */
  .ingredients-table {
    display: flex;
    flex-direction: column;
  }

  .ing-row {
    display: flex;
    flex-direction: column;
    padding: 12px 14px;
    gap: 6px;
  }

  .ing-row.header {
    display: none; /* Esconde header pois vamos mostrar labels inline */
  }

  .ing-row:not(.header):not(.total) {
    border-left: 3px solid var(--verde);
    margin-bottom: 8px;
    border-radius: var(--raio-sm);
  }

  .ing-row span:first-child {
    font-weight: 600;
    color: var(--texto-primario);
    font-size: 0.95rem;
  }

  .ing-row span:nth-child(2),
  .ing-row span:nth-child(3) {
    font-size: 0.85rem;
    color: var(--texto-secundario);
  }

  .ing-row span:nth-child(2)::before {
    content: "Qtd: ";
    font-weight: 500;
    color: var(--cinza-500);
  }

  .ing-row span:nth-child(3)::before {
    content: "Custo: ";
    font-weight: 500;
    color: var(--cinza-500);
  }

  .ing-row.total {
    flex-direction: row;
    justify-content: space-between;
    border-top: 1px solid var(--borda);
    margin-top: 8px;
    padding-top: 12px;
  }

  .ing-row.total span:nth-child(2) {
    display: none;
  }

  .ing-row.total span:nth-child(3)::before {
    content: none;
  }

  /* Modais mais espaçosos */
  .modal-body-new {
    padding: 20px 16px;
  }

  .modal-footer-new {
    padding: 16px;
    flex-direction: column;
    gap: 10px;
  }

  .modal-footer-new .btn-cancel,
  .modal-footer-new .btn-secondary,
  .modal-footer-new .btn-primary {
    width: 100%;
    min-height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  /* Inputs maiores */
  .form-group input,
  .form-group select,
  .form-group textarea {
    min-height: 48px;
    font-size: 16px;
  }

  /* Produção responsiva */
  .production-summary {
    grid-template-columns: 1fr;
  }

  .prod-card {
    padding: 16px;
  }

  /* Expectativas - scroll horizontal */
  .expectativa-table-wrapper {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .expectativa-table {
    min-width: 600px;
  }
}

@media (max-width: 480px) {
  .page-content {
    padding: 12px;
  }

  /* ===== TELA DE VENDAS MOBILE ===== */

  /* Header da página mais compacto */
  .page-header-simple {
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    margin-bottom: 12px;
  }

  .page-header-simple h1 {
    font-size: 1.2rem;
    margin: 0;
  }

  /* Total destacado */
  .sale-total-display {
    padding: 10px 16px;
    font-size: 0.9rem;
    border-radius: 20px;
  }

  .sale-total-display .total-value {
    font-size: 1.1rem;
  }

  /* Seção de pratos */
  .dishes-section h2 {
    font-size: 0.9rem;
    margin-bottom: 10px;
  }

  .dishes-grid {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  /* Card do prato - layout horizontal compacto */
  .dish-card-new {
    display: flex;
    flex-direction: row;
    align-items: center;
    padding: 12px;
    gap: 12px;
  }

  .dish-icon-new {
    width: 50px;
    height: 50px;
    font-size: 1.3rem;
    flex-shrink: 0;
  }

  .dish-info-new {
    flex: 1;
    text-align: left;
  }

  .dish-name-new {
    font-size: 1rem;
    margin-bottom: 8px;
  }

  /* Botões P e G lado a lado com cores */
  .size-buttons {
    flex-direction: row;
    gap: 8px;
  }

  .size-btn {
    flex: 1;
    padding: 10px 8px;
    border-radius: 8px;
    font-weight: 600;
    font-size: 0.85rem;
  }

  .size-btn[data-size="PEQUENA"] {
    background: var(--verde-claro);
    border-color: var(--verde);
    color: var(--verde-escuro);
  }

  .size-btn[data-size="GRANDE"] {
    background: var(--laranja-claro);
    border-color: var(--laranja);
    color: #8B4513;
  }

  /* Seção do carrinho */
  .cart-section {
    margin-top: 16px;
    padding-bottom: 80px;
  }

  .cart-section h2 {
    font-size: 0.9rem;
    margin-bottom: 10px;
  }

  .cart-list {
    border-radius: 12px;
    overflow: hidden;
  }

  /* Carrinho vazio mais bonito */
  .cart-empty {
    padding: 32px 20px;
    background: var(--bg-card);
    border-radius: 12px;
    border: 2px dashed var(--borda);
  }

  .cart-empty i {
    font-size: 2rem;
    color: var(--cinza-400);
  }

  .cart-empty span {
    color: var(--cinza-500);
    font-size: 0.9rem;
  }

  /* Item do carrinho compacto */
  .cart-item {
    margin: 0;
    border-radius: 0;
    border: none;
    border-bottom: 1px solid var(--borda);
    padding: 12px;
  }

  .cart-item:last-child {
    border-bottom: none;
  }

  .cart-item-row {
    gap: 10px;
  }

  .cart-icon {
    width: 32px;
    height: 32px;
    font-size: 0.85rem;
  }

  .cart-item-info strong {
    font-size: 0.9rem;
  }

  .cart-item-info span {
    font-size: 0.75rem;
  }

  .cart-item-total {
    font-size: 0.85rem;
    padding: 4px 10px;
  }

  /* Controles do carrinho em linha */
  .cart-item-controls {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: space-between;
  }

  .cart-select-group {
    flex: 1;
    min-width: 90px;
    padding: 6px 8px;
  }

  .cart-select-group i {
    font-size: 0.7rem;
  }

  .cart-select {
    font-size: 0.75rem;
  }

  .cart-qty {
    padding: 4px 6px;
  }

  .qty-btn {
    width: 30px;
    height: 30px;
    font-size: 1rem;
  }

  .qty-value {
    font-size: 0.9rem;
    min-width: 20px;
  }

  /* Botão finalizar venda fixo */
  .finish-sale-btn {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    margin: 0;
    border-radius: 0;
    z-index: 50;
    padding: 14px 20px;
    font-size: 1rem;
    font-weight: 600;
    box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.2);
  }

  .payment-btn {
    flex: 1 1 100%;
  }

  .channel-btn {
    flex: 1 1 100%;
  }

  /* Produção cards */
  .prod-numbers {
    grid-template-columns: 1fr 1fr;
  }

  /* Modal mais compacto */
  .modal-content-new {
    margin: 8px;
    max-height: calc(100vh - 16px);
  }

  .modal-header-new {
    padding: 16px;
  }

  .modal-header-new h2 {
    font-size: 1.1rem;
  }

  /* Ficha info compacta */
  .ficha-info-item {
    padding: 10px 12px;
  }

  .info-value {
    font-size: 1rem;
  }

  /* Rendimento icons menores */
  .rendimento-icon {
    width: 40px;
    height: 40px;
    font-size: 1rem;
  }

  .rendimento-qtd {
    font-size: 1rem;
  }

  /* Theme toggle */
  .theme-toggle {
    width: 42px;
    height: 42px;
    bottom: 16px;
    right: 16px;
    font-size: 1rem;
  }

  /* ===== TELA DE CARDÁPIO MOBILE ===== */

  /* Header do cardápio - layout empilhado */
  #page-cardapio .page-header-simple {
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
  }

  #page-cardapio .page-header-simple h1 {
    font-size: 1.1rem;
    justify-content: center;
  }

  /* Botões do header em linha, scroll se necessário */
  .header-buttons {
    display: flex;
    gap: 8px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 4px;
  }

  .header-buttons .btn-primary,
  .header-buttons .header-action-btn {
    flex-shrink: 0;
    padding: 10px 14px;
    font-size: 0.8rem;
    white-space: nowrap;
  }

  /* Navegação da semana compacta */
  .week-nav {
    gap: 10px;
    margin-bottom: 16px;
  }

  .week-btn {
    width: 36px;
    height: 36px;
    font-size: 0.9rem;
  }

  .week-label {
    font-size: 0.9rem;
  }

  /* Calendário em coluna única */
  .calendar-simple {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  /* Day card compacto e horizontal */
  .day-card {
    display: flex;
    flex-direction: column;
    padding: 12px;
  }

  .day-header-simple {
    display: flex;
    align-items: center;
    gap: 12px;
    text-align: left;
    padding-bottom: 10px;
    margin-bottom: 10px;
  }

  .day-name {
    font-size: 0.75rem;
    margin-bottom: 0;
  }

  .day-num {
    font-size: 1.3rem;
  }

  /* Conteúdo do dia mais compacto */
  .day-dishes {
    min-height: auto;
  }

  .day-dish {
    padding: 8px 10px;
    font-size: 0.85rem;
  }

  .day-empty {
    padding: 16px;
  }

  .day-empty i {
    font-size: 1.2rem;
  }

  .day-empty span {
    font-size: 0.8rem;
  }

  /* Botão adicionar mais compacto */
  .add-dish-btn {
    padding: 10px;
    font-size: 0.8rem;
  }

  /* ===== MODAL DE PRODUÇÃO ===== */

  /* Botões do modal alinhados */
  .production-modal-actions {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 16px;
  }

  .production-modal-actions .btn-cancel,
  .production-modal-actions .btn-primary {
    width: 100%;
    min-height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  /* Botão finalizar venda fixo */
  .finish-sale-btn {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    margin: 0;
    border-radius: 0;
    z-index: 50;
    padding: 16px;
  }

  .cart-section {
    padding-bottom: 70px;
  }

  /* ===== MODAL DE RECEITA MOBILE ===== */

  /* Modal de receita mais compacto */
  #modal-receita .modal-content-new {
    max-width: 100%;
    margin: 0;
    border-radius: 0;
    max-height: 100vh;
    height: 100vh;
  }

  #modal-receita .modal-body-new {
    padding: 16px;
    overflow-y: auto;
  }

  /* Labels mais visíveis */
  .form-group-new label {
    font-size: 0.85rem;
    margin-bottom: 6px;
    display: block;
  }

  /* Inputs maiores */
  .input-new,
  .select-new {
    padding: 14px 12px;
    font-size: 16px;
  }

  /* Form row em coluna */
  .form-row-new {
    flex-direction: column;
    gap: 16px;
  }

  /* Seção de ingredientes */
  .items-add-list {
    padding: 10px;
  }

  /* Linha de ingrediente empilhada */
  .item-add-row {
    flex-wrap: wrap;
    padding: 12px;
    gap: 10px;
  }

  /* Select de insumo em largura total */
  .item-add-row .select-small-new.ingrediente-select,
  .item-add-row .insumo-select-wrapper {
    flex: 1 1 100%;
    min-width: 100%;
  }

  .item-add-row .select-small-new.ingrediente-select {
    width: 100%;
  }

  /* Quantidade e unidade lado a lado */
  .item-add-row .input-small-new.ingrediente-qtd {
    flex: 1;
    min-width: 80px;
    max-width: none;
  }

  .item-add-row .select-small-new.ingrediente-unidade {
    flex: 1;
    min-width: 80px;
    width: auto;
  }

  /* Botão remover */
  .item-add-row .btn-icon-danger {
    width: 44px;
    height: 44px;
    flex-shrink: 0;
  }

  /* Inputs pequenos maiores */
  .select-small-new,
  .input-small-new {
    height: 44px;
    font-size: 15px;
    padding: 10px 12px;
  }

  /* Botão adicionar ingrediente */
  .add-item-btn {
    padding: 14px;
    font-size: 0.9rem;
  }

  /* Seção de tamanhos */
  .form-row-new.tamanhos-row {
    gap: 12px;
  }

  /* Seção de sugestão de preço */
  .sugestao-preco-container {
    padding: 12px;
  }

  .sugestao-preco-grid {
    flex-direction: column;
    gap: 12px;
  }

  .sugestao-item {
    flex-direction: row;
    justify-content: space-between;
  }
}

/* =============================================
   Login Overlay
   ============================================= */

.login-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, var(--verde-escuro) 0%, var(--verde) 100%);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s;
}

.login-overlay.active {
  opacity: 1;
  visibility: visible;
}

.login-container {
  background: var(--branco);
  border-radius: 28px;
  padding: 0;
  width: 100%;
  max-width: min(440px, calc(100vw - 32px));
  box-shadow: 0 25px 80px rgba(0,0,0,0.4);
  text-align: center;
  overflow: hidden;
}

.login-header {
  text-align: center;
  padding: 40px 40px 32px;
  background: linear-gradient(180deg, rgba(26, 71, 42, 0.03) 0%, transparent 100%);
  border-bottom: 1px solid var(--cinza-200);
}

/* Logo com destaque - MAIOR */
.login-logo {
  width: 140px;
  height: 140px;
  border-radius: 50%;
  margin-bottom: 20px;
  object-fit: cover;
  border: 5px solid var(--laranja);
  box-shadow:
    0 0 0 10px rgba(249, 115, 22, 0.12),
    0 0 0 20px rgba(249, 115, 22, 0.06),
    0 15px 50px rgba(249, 115, 22, 0.35);
  animation: logoGlow 3s ease-in-out infinite;
}

@keyframes logoGlow {
  0%, 100% {
    box-shadow:
      0 0 0 10px rgba(249, 115, 22, 0.12),
      0 0 0 20px rgba(249, 115, 22, 0.06),
      0 15px 50px rgba(249, 115, 22, 0.35);
  }
  50% {
    box-shadow:
      0 0 0 14px rgba(249, 115, 22, 0.15),
      0 0 0 24px rgba(249, 115, 22, 0.08),
      0 20px 60px rgba(249, 115, 22, 0.45);
  }
}

.login-header h1 {
  font-size: 2.4rem;
  color: var(--verde-escuro);
  margin-bottom: 8px;
  font-weight: 700;
  letter-spacing: -0.5px;
}

.login-header p {
  color: var(--cinza-500);
  font-size: 1rem;
}

.login-form {
  display: flex;
  flex-direction: column;
  gap: 20px;
  text-align: left;
  align-items: stretch;
  padding: 36px 40px 40px;
}

.login-form .form-group {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.login-form label {
  font-weight: 600;
  font-size: 0.8rem;
  color: var(--verde-escuro);
  text-transform: uppercase;
  letter-spacing: 0.8px;
}

.login-form input {
  padding: 16px 18px;
  border: 2px solid var(--cinza-200);
  border-radius: 12px;
  font-size: 1rem;
  font-family: inherit;
  transition: all 0.2s;
  background: var(--cinza-50);
}

.login-form input:focus {
  outline: none;
  border-color: var(--verde);
  background: var(--branco);
  box-shadow: 0 0 0 4px rgba(34, 197, 94, 0.1);
}

.login-form input::placeholder {
  color: var(--cinza-400);
}

.login-error {
  background: var(--vermelho-claro);
  color: var(--vermelho);
  padding: 14px;
  border-radius: 12px;
  font-size: 0.9rem;
  text-align: center;
  font-weight: 500;
}

.login-btn {
  padding: 18px 24px;
  background: linear-gradient(135deg, var(--verde) 0%, var(--verde-escuro) 100%);
  color: white;
  border: none;
  border-radius: 14px;
  font-size: 1.1rem;
  font-weight: 700;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  transition: all 0.3s;
  font-family: inherit;
  text-transform: uppercase;
  letter-spacing: 1px;
  box-shadow: 0 8px 24px rgba(34, 197, 94, 0.35);
  margin-top: 8px;
}

.login-btn:hover {
  background: linear-gradient(135deg, var(--verde-escuro) 0%, #166534 100%);
  transform: translateY(-2px);
  box-shadow: 0 12px 32px rgba(34, 197, 94, 0.45);
}

.login-btn:active {
  transform: translateY(0);
}

.login-btn:disabled {
  background: var(--cinza-300);
  cursor: not-allowed;
  box-shadow: none;
  transform: none;
}

/* Dark Mode Login */
body.dark-theme .login-container {
  background: var(--bg-card);
  box-shadow: 0 25px 80px rgba(0,0,0,0.6);
}

body.dark-theme .login-header h1 {
  color: var(--texto-primario);
}

body.dark-theme .login-form label {
  color: var(--texto-secundario);
}

body.dark-theme .login-form input {
  background: var(--bg-input);
  border-color: var(--borda);
  color: var(--texto-primario);
}

body.dark-theme .login-form input:focus {
  background: var(--bg-card);
  border-color: var(--verde);
  box-shadow: 0 0 0 4px rgba(34, 197, 94, 0.15);
}

body.dark-theme .login-logo {
  box-shadow:
    0 0 0 10px rgba(249, 115, 22, 0.15),
    0 0 0 20px rgba(249, 115, 22, 0.08),
    0 15px 50px rgba(249, 115, 22, 0.4);
}

body.dark-theme .login-header {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.02) 0%, transparent 100%);
  border-bottom-color: var(--borda);
}

body.dark-theme .login-link {
  border-top-color: var(--borda);
}

/* Link criar conta / voltar login */
.login-link {
  text-align: center;
  margin-top: 20px;
  padding-top: 20px;
  border-top: 1px solid var(--cinza-200);
  color: var(--texto-secundario);
  font-size: 0.9rem;
}

.login-link a {
  color: var(--laranja);
  text-decoration: none;
  font-weight: 700;
  transition: all 0.2s;
}

.login-link a:hover {
  color: var(--verde-escuro);
  text-decoration: underline;
}

/* User Info na Sidebar */
.nav-bottom {
  margin-top: auto;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,0.15);
  background: rgba(0,0,0,0.1);
  border-radius: var(--raio);
}

.user-info {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  color: rgba(255,255,255,0.9);
  font-size: 0.875rem;
  font-weight: 500;
}

.user-info i {
  font-size: 1.25rem;
  color: var(--laranja);
}

.logout-btn {
  color: rgba(255,200,200,0.95) !important;
}

.logout-btn:hover {
  background: rgba(220, 38, 38, 0.2) !important;
}

.logout-btn .nav-icon {
  color: rgba(255,200,200,0.95) !important;
}

/* Empty State */
.empty-state {
  text-align: center;
  padding: 32px 16px;
  color: var(--texto-secundario);
  font-size: 0.95rem;
}

.empty-state a {
  color: var(--verde);
  text-decoration: none;
  font-weight: 500;
}

.empty-state a:hover {
  text-decoration: underline;
}

/* Botão remover item */
.btn-remove-item {
  width: 36px;
  height: 36px;
  background: var(--vermelho-claro);
  border: none;
  border-radius: var(--raio-sm);
  color: var(--vermelho);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
}

.btn-remove-item:hover {
  background: var(--vermelho);
  color: white;
}

body.dark-theme .btn-remove-item {
  background: rgba(220, 38, 38, 0.2);
}

body.dark-theme .btn-remove-item:hover {
  background: var(--vermelho);
}

body.dark-theme .btn-add-insumo-inline {
  background: rgba(34, 197, 94, 0.15);
  border-color: var(--verde);
  color: var(--verde);
}

body.dark-theme .btn-add-insumo-inline:hover {
  background: var(--verde);
  color: white;
}

@media (max-width: 480px) {
  .login-container {
    margin: 16px;
    padding: 32px 24px;
    border-radius: 20px;
  }

  .login-logo {
    width: 100px;
    height: 100px;
  }

  .login-header h1 {
    font-size: 1.75rem;
  }

  .login-btn {
    padding: 16px 20px;
    font-size: 1rem;
  }
}

/* ==================== IMPORTAR LISTA COM IA ==================== */
.modal-large {
  max-width: 600px;
  width: 95%;
}

.upload-area {
  border: 2px dashed var(--cinza-300);
  border-radius: var(--raio);
  padding: 40px 20px;
  text-align: center;
  cursor: pointer;
  transition: all 0.3s;
  background: var(--cinza-50);
}

.upload-area:hover {
  border-color: #8b5cf6;
  background: #f5f3ff;
}

.upload-content i {
  font-size: 48px;
  color: #8b5cf6;
  margin-bottom: 16px;
}

.upload-content h3 {
  font-size: 1.1rem;
  margin-bottom: 8px;
  color: var(--texto-primario);
}

.upload-content p {
  font-size: 0.9rem;
  color: var(--texto-secundario);
  margin-bottom: 16px;
}

.btn-upload {
  background: #8b5cf6;
  color: white;
  border: none;
  padding: 12px 24px;
  border-radius: var(--raio-sm);
  cursor: pointer;
  font-size: 0.95rem;
  font-weight: 500;
  transition: all 0.2s;
}

.btn-upload:hover {
  background: #7c3aed;
}

.image-preview-container {
  position: relative;
  margin-bottom: 20px;
  border-radius: var(--raio);
  overflow: hidden;
}

.image-preview-container img {
  width: 100%;
  max-height: 200px;
  object-fit: cover;
  border-radius: var(--raio);
}

.btn-remove-image {
  position: absolute;
  top: 10px;
  right: 10px;
  background: rgba(0,0,0,0.6);
  color: white;
  border: none;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}

.btn-remove-image:hover {
  background: var(--vermelho);
}

.ai-loading {
  text-align: center;
  padding: 40px 20px;
}

.ai-loading-spinner {
  width: 50px;
  height: 50px;
  border: 4px solid var(--cinza-200);
  border-top-color: #8b5cf6;
  border-radius: 50%;
  animation: spin 1s linear infinite;
  margin: 0 auto 16px;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

.ai-loading p {
  color: var(--texto-secundario);
  font-size: 0.95rem;
}

.ai-result {
  background: #f5f3ff;
  border: 1px solid #e9d5ff;
  border-radius: var(--raio);
  overflow: hidden;
}

.ai-result-header {
  background: #8b5cf6;
  color: white;
  padding: 12px 16px;
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 500;
}

.ai-items-table {
  padding: 16px;
  overflow-x: auto;
}

.ai-items-table table {
  width: 100%;
  border-collapse: collapse;
}

.ai-items-table th {
  text-align: left;
  padding: 8px;
  font-size: 0.8rem;
  color: var(--texto-secundario);
  border-bottom: 1px solid var(--cinza-200);
}

.ai-items-table td {
  padding: 8px;
  border-bottom: 1px solid var(--cinza-100);
}

.ai-items-table input {
  width: 100%;
  padding: 8px;
  border: 1px solid var(--cinza-200);
  border-radius: 4px;
  font-size: 0.9rem;
}

.ai-items-table input:focus {
  outline: none;
  border-color: #8b5cf6;
}

.ai-items-table .input-produto {
  min-width: 120px;
}

.ai-items-table .input-num {
  width: 70px;
  text-align: right;
}

.ai-items-table .item-total {
  font-weight: 500;
  color: var(--verde);
  min-width: 80px;
}

.ai-items-table .btn-remove-ai-item {
  background: transparent;
  border: none;
  color: var(--vermelho);
  cursor: pointer;
  padding: 4px 8px;
  border-radius: 4px;
}

.ai-items-table .btn-remove-ai-item:hover {
  background: var(--vermelho-claro, #ffe5e5);
}

.ai-result-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px;
  background: #ede9fe;
  font-size: 1.1rem;
}

.ai-result-footer strong {
  color: #8b5cf6;
  font-size: 1.3rem;
}

.api-key-config {
  margin-top: 20px;
}

.api-key-config details {
  background: var(--cinza-50);
  border-radius: var(--raio-sm);
  padding: 12px 16px;
}

.api-key-config summary {
  cursor: pointer;
  font-size: 0.9rem;
  color: var(--texto-secundario);
  display: flex;
  align-items: center;
  gap: 8px;
}

.api-key-input {
  display: flex;
  gap: 8px;
  margin-top: 12px;
}

.api-key-input input {
  flex: 1;
  padding: 10px 12px;
  border: 1px solid var(--cinza-200);
  border-radius: var(--raio-sm);
  font-size: 0.9rem;
}

.api-key-input button {
  background: #8b5cf6;
  color: white;
  border: none;
  padding: 10px 16px;
  border-radius: var(--raio-sm);
  cursor: pointer;
}

.api-key-config small {
  display: block;
  margin-top: 8px;
  color: var(--texto-secundario);
  font-size: 0.8rem;
}

/* Dark mode para importar lista */
body.dark-theme .upload-area {
  background: var(--bg-card);
  border-color: var(--borda);
}

body.dark-theme .upload-area:hover {
  background: rgba(139, 92, 246, 0.1);
  border-color: #8b5cf6;
}

body.dark-theme .upload-content h3 {
  color: var(--texto-primario);
}

body.dark-theme .ai-result {
  background: rgba(139, 92, 246, 0.1);
  border-color: rgba(139, 92, 246, 0.3);
}

body.dark-theme .ai-items-table input {
  background: var(--bg-input);
  border-color: var(--borda);
  color: var(--texto-primario);
}

body.dark-theme .ai-result-footer {
  background: rgba(139, 92, 246, 0.2);
}

body.dark-theme .api-key-config details {
  background: var(--bg-card);
}

body.dark-theme .api-key-input input {
  background: var(--bg-input);
  border-color: var(--borda);
  color: var(--texto-primario);
}

/* =============================================
   Expectativa de Vendas
   ============================================= */

.expectativa-info {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  background: var(--verde-claro);
  border-radius: var(--raio);
  margin-bottom: 20px;
  color: var(--verde-escuro);
  font-size: 13px;
}

.expectativa-info i {
  font-size: 18px;
  color: var(--verde);
}

body.dark-theme .expectativa-info {
  background: rgba(45, 106, 79, 0.2);
  color: #a7f3d0;
}

/* Info box para estoque mínimo automático */
.info-box-estoque {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 14px 16px;
  background: linear-gradient(135deg, #ede9fe 0%, #ddd6fe 100%);
  border-radius: var(--raio);
  margin-top: 8px;
  border: 1px solid #c4b5fd;
}

.info-box-estoque i {
  font-size: 20px;
  color: #7c3aed;
  flex-shrink: 0;
  margin-top: 2px;
}

.info-box-content strong {
  display: block;
  font-size: 13px;
  color: #5b21b6;
  margin-bottom: 4px;
}

.info-box-content p {
  font-size: 12px;
  color: #6d28d9;
  line-height: 1.4;
  margin: 0;
}

body.dark-theme .info-box-estoque {
  background: linear-gradient(135deg, rgba(124, 58, 237, 0.15) 0%, rgba(139, 92, 246, 0.1) 100%);
  border-color: rgba(139, 92, 246, 0.3);
}

body.dark-theme .info-box-estoque i {
  color: #a78bfa;
}

body.dark-theme .info-box-content strong {
  color: #c4b5fd;
}

body.dark-theme .info-box-content p {
  color: #a78bfa;
}

.expectativa-grid-container {
  overflow-x: auto;
  background: var(--bg-card);
  border-radius: var(--raio);
  box-shadow: var(--sombra);
  width: 100%;
}

.expectativa-table {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
}

.expectativa-table th {
  background: var(--verde);
  color: white;
  padding: 12px 8px;
  font-weight: 600;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  text-align: center;
}

.expectativa-table th:first-child {
  border-radius: var(--raio) 0 0 0;
  text-align: left;
  padding-left: 16px;
}

.expectativa-table th:last-child {
  border-radius: 0 var(--raio) 0 0;
}

.expectativa-table th.day-col {
  width: 11%;
}

.expectativa-table td {
  padding: 12px 10px;
  border-bottom: 1px solid var(--borda);
  vertical-align: middle;
  text-align: center;
}

.expectativa-table td:first-child {
  text-align: left;
  padding-left: 20px;
}

.expectativa-table tr:last-child td {
  border-bottom: none;
}

.expectativa-table tr:hover {
  background: var(--cinza-50);
}

body.dark-theme .expectativa-table tr:hover {
  background: rgba(255,255,255,0.03);
}

.expectativa-recipe-cell {
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.expectativa-recipe-name {
  font-weight: 600;
  color: var(--texto-primario);
  font-size: 14px;
  line-height: 1.3;
}

.expectativa-recipe-category {
  font-size: 11px;
  color: var(--texto-secundario);
  text-transform: uppercase;
  letter-spacing: 0.3px;
}

.expectativa-inputs {
  display: flex;
  flex-direction: row;
  gap: 8px;
  justify-content: center;
  align-items: center;
}

.expectativa-input-group {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
  flex: 1;
  max-width: 55px;
}

.expectativa-input-group label {
  font-size: 10px;
  font-weight: 700;
  width: 100%;
  text-align: center;
  padding: 3px 0;
  border-radius: 4px 4px 0 0;
}

.expectativa-input-group label.label-p {
  background: var(--laranja);
  color: white;
}

.expectativa-input-group label.label-g {
  background: var(--verde);
  color: white;
}

.expectativa-input {
  width: 100%;
  padding: 8px 4px;
  border: 1px solid var(--borda);
  border-top: none;
  border-radius: 0 0 4px 4px;
  text-align: center;
  font-size: 15px;
  font-weight: 600;
  background: var(--bg-input);
  color: var(--texto-primario);
  transition: all 0.2s;
}

.expectativa-input:focus {
  outline: none;
  border-color: var(--verde);
  box-shadow: 0 0 0 2px rgba(45, 106, 79, 0.15);
}

.expectativa-input::-webkit-inner-spin-button,
.expectativa-input::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.expectativa-input[type="number"] {
  -moz-appearance: textfield;
}

.expectativa-total-cell {
  background: var(--verde-claro) !important;
  padding: 12px 8px !important;
}

body.dark-theme .expectativa-total-cell {
  background: rgba(45, 106, 79, 0.2) !important;
}

.expectativa-total-breakdown {
  display: flex;
  flex-direction: column;
  gap: 4px;
  align-items: center;
}

.expectativa-total-breakdown .total-p {
  font-size: 14px;
  font-weight: 700;
  color: var(--laranja);
}

.expectativa-total-breakdown .total-g {
  font-size: 14px;
  font-weight: 700;
  color: var(--verde);
}

.expectativa-table th.recipe-col {
  width: 16%;
}

.expectativa-table th.total-col {
  width: 7%;
  background: var(--verde-escuro);
}

/* Responsive para telas menores */
@media (max-width: 1200px) {
  .expectativa-table th.recipe-col {
    width: 18%;
  }

  .expectativa-input-group {
    max-width: 45px;
  }

  .expectativa-input {
    padding: 6px 2px;
    font-size: 13px;
  }
}

/* Ingredientes Modal */

.ingredientes-resumo {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 24px;
}

.resumo-card {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px;
  background: var(--cinza-50);
  border-radius: var(--raio-sm);
  border: 1px solid var(--borda);
}

.resumo-card i {
  font-size: 20px;
  color: var(--texto-secundario);
}

.resumo-card.ok i { color: var(--verde); }
.resumo-card.baixo i { color: var(--amarelo); }
.resumo-card.critico i { color: var(--vermelho); }

.resumo-card.ok { background: var(--verde-claro); border-color: var(--verde); }
.resumo-card.baixo { background: var(--amarelo-claro); border-color: var(--amarelo); }
.resumo-card.critico { background: var(--vermelho-claro); border-color: var(--vermelho); }

.resumo-label {
  display: block;
  font-size: 11px;
  color: var(--texto-secundario);
  text-transform: uppercase;
  letter-spacing: 0.3px;
}

.resumo-value {
  display: block;
  font-size: 18px;
  font-weight: 700;
  color: var(--texto-primario);
}

.ingredientes-lista {
  max-height: 400px;
  overflow-y: auto;
}

.ingrediente-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px;
  border-bottom: 1px solid var(--borda);
  gap: 16px;
}

.ingrediente-item:last-child {
  border-bottom: none;
}

.ingrediente-info {
  flex: 1;
}

.ingrediente-nome {
  font-weight: 600;
  color: var(--texto-primario);
  margin-bottom: 4px;
}

.ingrediente-unidade {
  font-size: 12px;
  color: var(--texto-secundario);
}

.ingrediente-valores {
  display: flex;
  gap: 24px;
  align-items: center;
}

.ingrediente-col {
  text-align: center;
  min-width: 80px;
}

.ingrediente-col-label {
  font-size: 10px;
  color: var(--texto-secundario);
  text-transform: uppercase;
  display: block;
  margin-bottom: 2px;
}

.ingrediente-col-value {
  font-weight: 600;
  font-size: 14px;
  color: var(--texto-primario);
}

.ingrediente-status {
  padding: 4px 12px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
}

.ingrediente-status.ok {
  background: var(--verde-claro);
  color: var(--verde);
}

.ingrediente-status.baixo {
  background: var(--amarelo-claro);
  color: #92400e;
}

.ingrediente-status.critico {
  background: var(--vermelho-claro);
  color: var(--vermelho);
}

/* Responsive */

@media (max-width: 768px) {
  .ingredientes-resumo {
    grid-template-columns: repeat(2, 1fr);
  }

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

  .ingrediente-valores {
    width: 100%;
    justify-content: space-between;
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px dashed var(--borda);
  }
}

/* Dark Mode */

body.dark-theme .expectativa-grid-container {
  background: var(--bg-card);
}

body.dark-theme .expectativa-table th {
  background: var(--verde);
}

body.dark-theme .expectativa-table th.total-col {
  background: var(--verde-escuro);
}

body.dark-theme .resumo-card {
  background: var(--bg-input);
}

body.dark-theme .resumo-card.ok {
  background: rgba(45, 106, 79, 0.2);
}

body.dark-theme .resumo-card.baixo {
  background: rgba(245, 158, 11, 0.15);
}

body.dark-theme .resumo-card.critico {
  background: rgba(220, 38, 38, 0.15);
}

body.dark-theme .ingrediente-status.ok {
  background: rgba(45, 106, 79, 0.3);
  color: #6ee7b7;
}

body.dark-theme .ingrediente-status.baixo {
  background: rgba(245, 158, 11, 0.2);
  color: #fcd34d;
}

body.dark-theme .ingrediente-status.critico {
  background: rgba(220, 38, 38, 0.2);
  color: #fca5a5;
}

/* =============================================
   Sugestão de Preço - Modal Cardápio
   ============================================= */

.sugestao-preco-container {
  background: var(--verde-claro);
  border: 1px solid var(--verde);
  border-radius: var(--raio-sm);
  padding: 16px;
  margin-bottom: 16px;
}

.sugestao-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 12px;
  color: var(--verde-escuro);
  font-weight: 600;
  font-size: 14px;
}

.sugestao-header i {
  color: var(--verde);
}

.sugestao-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 12px;
}

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

.sugestao-label {
  font-size: 11px;
  color: var(--texto-secundario);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.sugestao-valor {
  font-size: 14px;
  font-weight: 600;
  color: var(--texto-primario);
}

.sugestao-item.sugestao-destaque {
  background: var(--bg-card);
  padding: 8px 10px;
  border-radius: var(--raio-sm);
}

.sugestao-valor.sugestao-preco {
  color: var(--verde);
  font-size: 16px;
}

.btn-aplicar-sugestao {
  width: 100%;
  padding: 10px 16px;
  background: var(--verde);
  color: white;
  border: none;
  border-radius: var(--raio-sm);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: all 0.2s ease;
}

.btn-aplicar-sugestao:hover {
  background: var(--verde-escuro);
  transform: translateY(-1px);
}

/* Dark mode - Sugestão de Preço */
body.dark-theme .sugestao-preco-container {
  background: rgba(45, 106, 79, 0.15);
  border-color: rgba(45, 106, 79, 0.4);
}

body.dark-theme .sugestao-header {
  color: #6ee7b7;
}

body.dark-theme .sugestao-header i {
  color: #6ee7b7;
}

body.dark-theme .sugestao-item.sugestao-destaque {
  background: rgba(0, 0, 0, 0.2);
}

body.dark-theme .sugestao-valor.sugestao-preco {
  color: #6ee7b7;
}

/* =============================================
   Tela de Produção - Novo Design
   ============================================= */

/* Resumo de Produção */
.production-summary {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 16px;
  margin-bottom: 24px;
}

.production-summary-card {
  background: var(--bg-card);
  border-radius: var(--raio);
  padding: 20px;
  display: flex;
  align-items: center;
  gap: 16px;
  box-shadow: var(--sombra);
}

.production-summary-icon {
  width: 56px;
  height: 56px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
}

.production-summary-icon.laranja {
  background: var(--laranja-claro);
  color: var(--laranja);
}

.production-summary-icon.verde {
  background: var(--verde-claro);
  color: var(--verde);
}

.production-summary-icon.azul {
  background: rgba(59, 130, 246, 0.1);
  color: #3b82f6;
}

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

.production-summary-value {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--texto-primario);
}

.production-summary-label {
  font-size: 0.85rem;
  color: var(--texto-secundario);
}

/* Seção de Produção */
.production-section {
  background: var(--bg-card);
  border-radius: var(--raio);
  padding: 24px;
  box-shadow: var(--sombra);
}

.production-section-header {
  margin-bottom: 20px;
}

.production-section-header h2 {
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--texto-primario);
  display: flex;
  align-items: center;
  gap: 10px;
}

.production-section-header h2 i {
  color: var(--laranja);
}

/* Grid de Produções */
.production-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 16px;
}

/* Card de Produção Novo */
.production-card-new {
  background: var(--cinza-50);
  border-radius: var(--raio-sm);
  padding: 16px;
  border: 1px solid var(--borda);
  transition: all 0.2s ease;
}

.production-card-new:hover {
  border-color: var(--laranja);
  box-shadow: var(--sombra-hover);
}

.production-card-header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--borda);
}

.production-card-icon {
  width: 44px;
  height: 44px;
  background: var(--laranja-claro);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--laranja);
  font-size: 1.2rem;
}

.production-card-title {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.production-card-title strong {
  font-size: 1rem;
  color: var(--texto-primario);
}

.production-card-time {
  font-size: 0.8rem;
  color: var(--texto-secundario);
  display: flex;
  align-items: center;
  gap: 4px;
}

.production-card-body {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}

.production-card-quantities {
  display: flex;
  gap: 16px;
}

.production-qty-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}

.production-qty-label {
  font-size: 0.7rem;
  color: var(--texto-secundario);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.production-qty-value {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--texto-primario);
  background: var(--bg-card);
  padding: 6px 14px;
  border-radius: 8px;
  min-width: 50px;
  text-align: center;
}

.production-qty-item.total .production-qty-value {
  background: var(--laranja-claro);
  color: var(--laranja);
}

.production-card-cost {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 4px;
}

.production-cost-label {
  font-size: 0.7rem;
  color: var(--texto-secundario);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.production-cost-value {
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--verde);
}

/* Empty State de Produção */
.empty-state-production {
  grid-column: 1 / -1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 48px 24px;
  text-align: center;
}

.empty-state-production i {
  font-size: 3rem;
  color: var(--cinza-300);
  margin-bottom: 16px;
}

.empty-state-production p {
  color: var(--texto-secundario);
  margin-bottom: 16px;
}

.btn-primary-sm {
  background: var(--verde);
  color: white;
  border: none;
  padding: 10px 20px;
  border-radius: var(--raio-sm);
  font-size: 0.9rem;
  font-weight: 500;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 8px;
  transition: all 0.2s ease;
}

.btn-primary-sm:hover {
  background: var(--verde-escuro);
  transform: translateY(-1px);
}

/* Dark Mode - Produção */
body.dark-theme .production-summary-card {
  background: var(--bg-card);
}

body.dark-theme .production-section {
  background: var(--bg-card);
}

body.dark-theme .production-card-new {
  background: var(--bg-input);
  border-color: var(--borda);
}

body.dark-theme .production-card-new:hover {
  border-color: var(--laranja);
}

body.dark-theme .production-card-icon {
  background: rgba(232, 93, 4, 0.15);
}

body.dark-theme .production-qty-value {
  background: rgba(0, 0, 0, 0.2);
}

body.dark-theme .production-qty-item.total .production-qty-value {
  background: rgba(232, 93, 4, 0.15);
  color: #fb923c;
}

body.dark-theme .production-cost-value {
  color: #4ade80;
}

body.dark-theme .production-summary-icon.azul {
  background: rgba(59, 130, 246, 0.15);
}

body.dark-theme .empty-state-production i {
  color: var(--cinza-500);
}

/* Responsivo */
@media (max-width: 768px) {
  .production-summary {
    grid-template-columns: 1fr;
  }

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

  .production-card-body {
    flex-direction: column;
    align-items: stretch;
    gap: 16px;
  }

  .production-card-quantities {
    justify-content: space-around;
  }

  .production-card-cost {
    align-items: center;
    padding-top: 12px;
    border-top: 1px solid var(--borda);
  }
}

/* =============================================
   Modal Venda em Lote
   ============================================= */

.modal-large {
  max-width: 700px;
  width: 95%;
}

.header-action-btn.secondary {
  background: var(--cinza-700);
}

.header-action-btn.secondary:hover {
  background: var(--cinza-900);
}

/* Info do Prato */
.lote-prato-info {
  background: var(--verde-claro);
  border: 1px solid var(--verde);
  border-radius: var(--raio-sm);
  padding: 16px;
  margin-bottom: 16px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.lote-prato-nome {
  font-weight: 600;
  font-size: 1.1rem;
  color: var(--verde-escuro);
}

.lote-prato-precos {
  display: flex;
  gap: 16px;
}

.lote-preco {
  font-size: 0.9rem;
  color: var(--texto-secundario);
}

.lote-preco strong {
  color: var(--verde);
  font-size: 1rem;
}

/* Seção de Itens */
.lote-section {
  margin-bottom: 16px;
}

.lote-section-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
}

.lote-section-header h3 {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--texto-primario);
  display: flex;
  align-items: center;
  gap: 8px;
}

.lote-section-header h3 i {
  color: var(--laranja);
}

.btn-add-lote-item {
  background: var(--verde);
  color: white;
  border: none;
  padding: 8px 14px;
  border-radius: var(--raio-sm);
  font-size: 0.85rem;
  font-weight: 500;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 6px;
  transition: all 0.2s;
}

.btn-add-lote-item:hover {
  background: var(--verde-escuro);
}

/* Lista de Itens */
.lote-items-list {
  background: var(--cinza-50);
  border: 1px solid var(--borda);
  border-radius: var(--raio-sm);
  min-height: 120px;
  max-height: 300px;
  overflow-y: auto;
}

.lote-empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 32px;
  color: var(--texto-secundario);
  text-align: center;
}

.lote-empty-state i {
  font-size: 2rem;
  margin-bottom: 8px;
  opacity: 0.5;
}

/* Item do Lote */
.lote-item {
  display: grid;
  grid-template-columns: 100px 80px 1fr 1fr auto auto;
  gap: 12px;
  align-items: center;
  padding: 12px 16px;
  border-bottom: 1px solid var(--borda);
}

.lote-item:last-child {
  border-bottom: none;
}

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

.lote-item-label {
  font-size: 0.7rem;
  color: var(--texto-secundario);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.lote-item select,
.lote-item input {
  padding: 8px 10px;
  border: 1px solid var(--borda-input);
  border-radius: 6px;
  font-size: 0.9rem;
  background: var(--bg-input);
  color: var(--texto-primario);
}

.lote-item input[type="number"] {
  width: 60px;
  text-align: center;
}

.lote-item-subtotal {
  font-weight: 600;
  color: var(--verde);
  font-size: 0.95rem;
  text-align: right;
  min-width: 80px;
}

.lote-item-remove {
  background: none;
  border: none;
  color: var(--vermelho);
  cursor: pointer;
  padding: 8px;
  border-radius: 6px;
  transition: all 0.2s;
}

.lote-item-remove:hover {
  background: var(--vermelho-claro);
}

/* Resumo */
.lote-resumo {
  background: var(--cinza-50);
  border: 1px solid var(--borda);
  border-radius: var(--raio-sm);
  padding: 16px;
}

.lote-resumo-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 0;
  color: var(--texto-secundario);
}

.lote-resumo-row.total {
  border-top: 1px solid var(--borda);
  margin-top: 8px;
  padding-top: 16px;
  font-size: 1.1rem;
}

.lote-resumo-row.total strong {
  color: var(--verde);
  font-size: 1.3rem;
}

/* Dark Mode - Venda em Lote */
body.dark-theme .lote-prato-info {
  background: rgba(45, 106, 79, 0.15);
  border-color: rgba(45, 106, 79, 0.4);
}

body.dark-theme .lote-prato-nome {
  color: #6ee7b7;
}

body.dark-theme .lote-preco strong {
  color: #6ee7b7;
}

body.dark-theme .lote-items-list {
  background: var(--bg-input);
}

body.dark-theme .lote-item select,
body.dark-theme .lote-item input {
  background: var(--bg-card);
  border-color: var(--borda);
}

body.dark-theme .lote-resumo {
  background: var(--bg-input);
}

body.dark-theme .lote-item-subtotal {
  color: #4ade80;
}

body.dark-theme .lote-resumo-row.total strong {
  color: #4ade80;
}

/* Responsivo - Lote */
@media (max-width: 768px) {
  .lote-item {
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }

  .lote-item-field:nth-child(1) {
    grid-column: 1 / 2;
  }

  .lote-item-field:nth-child(2) {
    grid-column: 2 / 3;
  }

  .lote-item-field:nth-child(3),
  .lote-item-field:nth-child(4) {
    grid-column: span 1;
  }

  .lote-item-subtotal {
    grid-column: 1 / 2;
    text-align: left;
  }

  .lote-item-remove {
    grid-column: 2 / 3;
    justify-self: end;
  }
}

/* =============================================
   Modal de Alertas de Estoque
   ============================================= */

.modal-icon.alerta {
  background: var(--laranja-claro, rgba(232, 93, 4, 0.15));
  color: var(--laranja);
}

.alertas-empty {
  text-align: center;
  padding: 40px 20px;
}

.alertas-empty i {
  font-size: 3rem;
  color: var(--verde);
  margin-bottom: 16px;
}

.alertas-empty p {
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--texto-primario);
  margin-bottom: 8px;
}

.alertas-empty span {
  color: var(--texto-secundario);
  font-size: 0.9rem;
}

.alertas-grupo {
  margin-bottom: 20px;
}

.alertas-grupo:last-child {
  margin-bottom: 0;
}

.alertas-grupo h4 {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.85rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--borda);
}

.alertas-grupo.critico h4 {
  color: var(--vermelho);
}

.alertas-grupo.baixo h4 {
  color: var(--amarelo);
}

.alertas-lista {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.alerta-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 14px;
  border-radius: var(--raio-sm);
  background: var(--cinza-50);
}

.alerta-item.critico {
  border-left: 3px solid var(--vermelho);
  background: var(--vermelho-claro);
}

.alerta-item.baixo {
  border-left: 3px solid var(--amarelo);
  background: var(--amarelo-claro);
}

.alerta-item-info strong {
  display: block;
  font-size: 0.95rem;
  color: var(--texto-primario);
}

.alerta-item-info span {
  font-size: 0.85rem;
  color: var(--texto-secundario);
}

.alerta-item-min {
  font-size: 0.8rem;
  color: var(--texto-secundario);
  text-align: right;
}

/* Dark theme */
body.dark-theme .alerta-item {
  background: var(--bg-input);
}

body.dark-theme .alerta-item.critico {
  background: rgba(220, 38, 38, 0.15);
}

body.dark-theme .alerta-item.baixo {
  background: rgba(245, 158, 11, 0.15);
}

body.dark-theme .alertas-empty i {
  color: #4ade80;
}

/* Bolinha de notificação */
.notif-dot {
  position: absolute;
  top: 6px;
  right: 6px;
  width: 8px;
  height: 8px;
  background: var(--vermelho);
  border-radius: 50%;
  display: none;
}

.header-btn {
  position: relative;
}
