/* ═══════════════════════════════════════════════════════════════
   Menú Cocina – Estilos del formulario front-end  v2
   ═══════════════════════════════════════════════════════════════ */

:root {
  --mc-primary:    #e74c3c;
  --mc-primary-dk: #c0392b;
  --mc-secondary:  #2c3e50;
  --mc-accent:     #27ae60;
  --mc-bg:         #f8f9fa;
  --mc-border:     #dee2e6;
  --mc-text:       #333;
  --mc-muted:      #888;
  --mc-radius:     10px;
  --mc-shadow:     0 2px 14px rgba(0,0,0,.09);
}

.mc-form-wrap {
  max-width: 800px;
  margin: 0 auto;
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  color: var(--mc-text);
}

.mc-form-title {
  font-size: 1.6rem;
  text-align: center;
  margin-bottom: 18px;
  color: var(--mc-secondary);
}

/* ─── Cabecera día de la semana ───────────────────────────────── */
.mc-semana-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  background: var(--mc-secondary);
  color: #fff;
  border-radius: var(--mc-radius);
  padding: 16px 22px;
  margin-bottom: 16px;
}

.mc-semana-dia {
  display: flex;
  align-items: center;
  gap: 14px;
}

.mc-semana-icon { font-size: 2rem; line-height: 1; }

.mc-semana-label {
  font-size: .78rem;
  opacity: .75;
  text-transform: uppercase;
  letter-spacing: .6px;
}

.mc-semana-nombre {
  font-size: 1.5rem;
  font-weight: 800;
  line-height: 1.1;
}

.mc-aviso-hora {
  background: rgba(255,255,255,.15);
  border: 1px solid rgba(255,255,255,.3);
  border-radius: 8px;
  padding: 8px 14px;
  font-size: .85rem;
}

/* ─── Carta del día (preview) ─────────────────────────────────── */
.mc-carta-preview {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 20px;
}
@media (max-width: 500px) { .mc-carta-preview { grid-template-columns: 1fr; } }

.mc-carta-col {
  background: #fff;
  border: 1px solid var(--mc-border);
  border-radius: var(--mc-radius);
  padding: 14px 16px;
  box-shadow: var(--mc-shadow);
}

.mc-carta-col-title {
  font-size: .8rem;
  font-weight: 700;
  color: var(--mc-secondary);
  text-transform: uppercase;
  letter-spacing: .4px;
  margin-bottom: 8px;
}

.mc-carta-lista {
  list-style: none;
  margin: 0;
  padding: 0;
}

.mc-carta-lista li {
  padding: 4px 0;
  font-size: .9rem;
  border-bottom: 1px dashed #eee;
  color: #444;
}

.mc-carta-lista li:last-child { border-bottom: none; }
.mc-carta-lista li::before { content: '•'; color: var(--mc-primary); margin-right: 7px; }
.mc-carta-vacia { color: var(--mc-muted); font-style: italic; font-size: .85rem; }
.mc-carta-vacia::before { display: none; }

/* ─── Fieldsets ───────────────────────────────────────────────── */
.mc-fieldset {
  border: 1px solid var(--mc-border);
  border-radius: var(--mc-radius);
  padding: 20px 24px;
  margin-bottom: 18px;
  background: #fff;
  box-shadow: var(--mc-shadow);
}

.mc-fieldset legend {
  font-size: 1rem;
  font-weight: 700;
  color: var(--mc-secondary);
  padding: 0 10px;
}

/* ─── Grid de campos ─────────────────────────────────────────── */
.mc-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
@media (max-width: 540px) { .mc-grid-2 { grid-template-columns: 1fr; } }

/* ─── Campos ─────────────────────────────────────────────────── */
.mc-field { display: flex; flex-direction: column; gap: 5px; }
.mc-field label { font-size: .85rem; font-weight: 600; color: #555; }

.mc-input,
.mc-select {
  padding: 10px 13px;
  border: 1.5px solid var(--mc-border);
  border-radius: 7px;
  font-size: .95rem;
  width: 100%;
  box-sizing: border-box;
  background: #fff;
  transition: border-color .2s;
}
.mc-input:focus,
.mc-select:focus {
  border-color: var(--mc-primary);
  outline: none;
  box-shadow: 0 0 0 3px rgba(231,76,60,.12);
}
textarea.mc-input { resize: vertical; min-height: 80px; }

.mc-req { color: var(--mc-primary); }

.mc-field-hint {
  font-size: .8rem;
  color: var(--mc-muted);
  margin: 4px 0 0;
}

/* ─── Stepper ─────────────────────────────────────────────────── */
.mc-field-num { margin-top: 14px; max-width: 220px; }

.mc-num-stepper {
  display: flex;
  align-items: center;
  border: 1.5px solid var(--mc-border);
  border-radius: 7px;
  overflow: hidden;
}

.mc-step-btn {
  background: var(--mc-bg);
  border: none;
  width: 42px;
  height: 44px;
  font-size: 1.4rem;
  cursor: pointer;
  color: var(--mc-primary);
  transition: background .15s;
  flex-shrink: 0;
}
.mc-step-btn:hover { background: #f0f0f0; }

.mc-num-stepper input[type=number] {
  border: none;
  text-align: center;
  font-size: 1.2rem;
  font-weight: 700;
  width: 100%;
  padding: 0;
  -moz-appearance: textfield;
}
.mc-num-stepper input::-webkit-inner-spin-button { display: none; }
.mc-num-stepper input:focus { outline: none; box-shadow: none; }

/* ─── Bloque de menú individual ─────────────────────────────── */
.mc-menu-bloque {
  border: 2px solid #e8e8e8;
  border-radius: var(--mc-radius);
  padding: 20px 24px;
  margin-bottom: 16px;
  background: #fff;
  box-shadow: var(--mc-shadow);
}

.mc-menu-bloque legend {
  font-size: 1rem;
  font-weight: 800;
  color: var(--mc-primary);
  padding: 0 10px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.mc-menu-num-badge {
  background: var(--mc-primary);
  color: #fff;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: .85rem;
  font-weight: 800;
}

.mc-curso-label {
  font-size: .82rem;
  font-weight: 700;
  color: var(--mc-secondary);
  text-transform: uppercase;
  letter-spacing: .4px;
  margin-bottom: 8px;
}

/* ─── Cards de platos ────────────────────────────────────────── */
.mc-opciones-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(190px,1fr));
  gap: 10px;
  margin-top: 6px;
}

.mc-opcion-card { cursor: pointer; display: block; }
.mc-opcion-card input[type=radio] { display: none; }

.mc-opcion-inner {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border: 2px solid var(--mc-border);
  border-radius: 9px;
  background: var(--mc-bg);
  transition: all .18s;
  min-height: 50px;
}

.mc-opcion-card:hover .mc-opcion-inner { border-color: var(--mc-primary); background: #fff5f5; }
.mc-opcion-card input:checked + .mc-opcion-inner {
  border-color: var(--mc-primary);
  background: #fff0ef;
  box-shadow: 0 0 0 3px rgba(231,76,60,.15);
}

.mc-opcion-check {
  width: 24px; height: 24px;
  border-radius: 50%;
  border: 2px solid var(--mc-border);
  display: flex; align-items: center; justify-content: center;
  font-size: .8rem; color: #fff;
  flex-shrink: 0;
  transition: all .18s;
}
.mc-opcion-card input:checked + .mc-opcion-inner .mc-opcion-check {
  background: var(--mc-primary); border-color: var(--mc-primary);
}
.mc-opcion-nombre { font-size: .9rem; font-weight: 600; line-height: 1.3; }
.mc-no-platos { color: var(--mc-muted); font-style: italic; font-size: .9rem; }

/* ─── Botón enviar ───────────────────────────────────────────── */
.mc-submit-wrap { text-align: center; margin-top: 10px; }

.mc-btn-submit {
  background: var(--mc-primary);
  color: #fff;
  border: none;
  padding: 15px 44px;
  border-radius: 50px;
  font-size: 1.05rem;
  font-weight: 700;
  cursor: pointer;
  transition: background .2s, transform .12s;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  box-shadow: 0 4px 14px rgba(231,76,60,.35);
}
.mc-btn-submit:hover  { background: var(--mc-primary-dk); transform: translateY(-1px); }
.mc-btn-submit:active { transform: translateY(0); }
.mc-btn-submit:disabled { opacity: .6; cursor: not-allowed; }

/* ─── Mensajes ───────────────────────────────────────────────── */
.mc-mensaje { padding: 14px 18px; border-radius: 8px; margin-bottom: 18px; font-size: .92rem; }
.mc-mensaje.mc-error   { background: #fdecea; border: 1px solid #f5c6cb; color: #721c24; }
.mc-mensaje.mc-success { background: #d4edda; border: 1px solid #c3e6cb; color: #155724; }

/* ─── Confirmación ───────────────────────────────────────────── */
.mc-confirmacion { text-align: center; padding: 50px 30px; background: #fff; border-radius: var(--mc-radius); box-shadow: var(--mc-shadow); }
.mc-confirm-icon { font-size: 4rem; margin-bottom: 10px; }
.mc-confirmacion h2 { font-size: 1.8rem; color: var(--mc-accent); margin: 0 0 10px; }
.mc-confirm-num { font-size: 2.2rem; font-weight: 900; color: var(--mc-primary); letter-spacing: 2px; margin: 8px 0 16px; }
.mc-confirm-sub { color: var(--mc-muted); margin-bottom: 24px; }
.mc-btn-nuevo { background: var(--mc-secondary); color: #fff; border: none; padding: 12px 30px; border-radius: 50px; font-size: .95rem; cursor: pointer; transition: opacity .2s; }
.mc-btn-nuevo:hover { opacity: .85; }

/* ─── Franjas horarias (cabecera del formulario) ──────────────── */
.mc-franjas-estado { text-align: right; }

.mc-franja-badge {
  display: inline-block;
  padding: 6px 14px;
  border-radius: 20px;
  font-size: .88rem;
  font-weight: 600;
}

.mc-franja-abierta {
  background: rgba(39,174,96,.25);
  color: #d4edda;
  border: 1px solid rgba(39,174,96,.4);
}

.mc-franja-cerrada {
  background: rgba(231,76,60,.25);
  color: #f8d7da;
  border: 1px solid rgba(231,76,60,.4);
}

.mc-franja-tope {
  font-size: .78rem;
  color: rgba(255,255,255,.7);
  margin-top: 4px;
  text-align: right;
}

/* ─── Pantalla "pedidos cerrados" ─────────────────────────────── */
.mc-sin-franjas {
  background: #fff;
  border: 2px solid #f5c6cb;
  border-radius: var(--mc-radius);
  padding: 40px 30px;
  text-align: center;
  margin-bottom: 20px;
  box-shadow: var(--mc-shadow);
}

.mc-sin-franjas-icon { font-size: 3.5rem; margin-bottom: 10px; }
.mc-sin-franjas h3   { font-size: 1.4rem; color: #721c24; margin: 0 0 10px; }
.mc-sin-franjas p    { color: #856404; font-size: .95rem; max-width: 480px; margin: 0 auto; }
