/* ═══════════════════════════════════════════════════════
   Cuyes Lima — Stylesheet
   Paleta del logo: naranja #f29e00 | dorado #fcca1d | marrón #c87814
   ═══════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;600;700&family=Jost:wght@300;400;500&display=swap');

:root {
  --color-primario:  #f29e00;
  --color-secundario:#c87814;
  --color-dorado:    #fcca1d;
  --color-oscuro:    #3d2400;
  --color-crema:     #fff8ec;
  --color-crema2:    #fef3db;
  --color-borde:     #f0d9a8;
  --color-texto:     #2e1a00;
  --color-muted:     #9a6f2e;
  --font-display:    'Cormorant Garamond', Georgia, serif;
  --font-body:       'Jost', sans-serif;
}

* { box-sizing: border-box; }

/* Base más grande: 17px en desktop, 16px en móvil */
html { font-size: 17px; }
@media (max-width: 768px) { html { font-size: 16px; } }

body { font-family: var(--font-body); color: var(--color-texto); background: #fff; font-size: 1rem; line-height: 1.65; }

/* ── NAV ─────────────────────────────────────────────── */
.brand-logo { font-family: var(--font-display); font-size: 1.45rem; font-weight: 700; color: var(--color-secundario) !important; letter-spacing: -0.02em; }
.navbar { box-shadow: 0 1px 0 var(--color-borde); background: #fff !important; }
.nav-link { font-size: .95rem; font-weight: 400; letter-spacing: .02em; color: var(--color-texto) !important; }
.nav-link:hover { color: var(--color-primario) !important; }

/* ── HERO ────────────────────────────────────────────── */
.hero { background: linear-gradient(135deg, var(--color-crema) 0%, var(--color-crema2) 100%); padding: 80px 0 72px; border-bottom: 1px solid var(--color-borde); position: relative; overflow: hidden; }
.hero::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse at 70% 50%, rgba(242,158,0,0.10) 0%, transparent 70%); pointer-events: none; }
.hero-tag { display: inline-block; font-size: .82rem; font-weight: 500; letter-spacing: .12em; text-transform: uppercase; color: var(--color-secundario); border: 1px solid var(--color-borde); padding: 4px 14px; border-radius: 100px; margin-bottom: 20px; background: rgba(255,255,255,.6); }
.hero h1 { font-family: var(--font-display); font-size: clamp(2.4rem, 5vw, 4rem); font-weight: 700; line-height: 1.1; color: var(--color-secundario); margin-bottom: 16px; }
.hero p { font-size: 1.05rem; color: var(--color-muted); max-width: 480px; line-height: 1.7; }
.hero-logo-img { width: 220px; height: 220px; object-fit: contain; filter: drop-shadow(0 12px 28px rgba(200,120,20,.25)); }

/* ── SECCIÓN ─────────────────────────────────────────── */
.seccion-titulo { font-family: var(--font-display); font-size: 2.1rem; font-weight: 600; color: var(--color-secundario); margin-bottom: 6px; }
.seccion-sub { color: var(--color-muted); font-size: .95rem; margin-bottom: 36px; }

/* ── TARJETAS PRECIO ─────────────────────────────────── */
.precio-card { border: 1px solid var(--color-borde); border-radius: 10px; padding: 28px 22px; text-align: center; transition: all .2s ease; background: #fff; }
.precio-card:hover { border-color: var(--color-primario); transform: translateY(-3px); box-shadow: 0 8px 24px rgba(242,158,0,.15); }
.precio-card.destacado { background: var(--color-secundario); color: #fff; border-color: var(--color-secundario); }
.precio-card.destacado .precio-badge { background: rgba(255,255,255,.18); color: #fff; }
.precio-card.destacado .precio-monto,
.precio-card.destacado .precio-cant  { color: #fff; }
.precio-card.destacado .precio-sub   { color: rgba(255,255,255,.75); }
.precio-badge { display: inline-block; font-size: .78rem; letter-spacing: .1em; text-transform: uppercase; background: var(--color-crema); color: var(--color-secundario); padding: 3px 10px; border-radius: 100px; margin-bottom: 12px; }
.precio-cant  { font-family: var(--font-display); font-size: 2.6rem; font-weight: 700; color: var(--color-secundario); line-height: 1; margin-bottom: 4px; }
.precio-monto { font-size: 1.6rem; font-weight: 500; color: var(--color-texto); }
.precio-sub   { font-size: .85rem; color: var(--color-muted); margin-top: 4px; }

/* ── BENEFICIOS ──────────────────────────────────────── */
.beneficio-icon   { font-size: 2rem; margin-bottom: 12px; }
.beneficio-titulo { font-family: var(--font-display); font-size: 1.2rem; font-weight: 600; color: var(--color-secundario); margin-bottom: 6px; }
.beneficio-texto  { font-size: .95rem; color: var(--color-muted); line-height: 1.65; }

/* ── DELIVERY TABLE ──────────────────────────────────── */
.delivery-table td, .delivery-table th { padding: 13px 16px; font-size: .95rem; }
.delivery-table th { background: var(--color-crema); font-weight: 500; color: var(--color-secundario); }

/* ── CTA BANNER ──────────────────────────────────────── */
.cta-banner { background: linear-gradient(135deg, var(--color-secundario) 0%, var(--color-oscuro) 100%); color: #fff; padding: 60px 0; }
.cta-banner h2 { font-family: var(--font-display); font-size: 2.1rem; font-weight: 700; margin-bottom: 12px; }
.cta-banner p  { color: rgba(255,255,255,.78); font-size: 1rem; margin-bottom: 28px; }

/* ── BOTONES ─────────────────────────────────────────── */
.btn-tierra { background: var(--color-primario); color: #fff; border: none; padding: 11px 28px; border-radius: 5px; font-size: .95rem; font-weight: 500; }
.btn-tierra:hover { background: var(--color-secundario); color: #fff; }
.btn-outline-tierra { border: 1.5px solid var(--color-primario); color: var(--color-secundario); background: transparent; padding: 11px 28px; border-radius: 5px; font-size: .95rem; }
.btn-outline-tierra:hover { background: var(--color-primario); color: #fff; }

/* ── FORMULARIOS ─────────────────────────────────────── */
.form-card { max-width: 480px; margin: 60px auto; padding: 40px 36px; border: 1px solid var(--color-borde); border-radius: 12px; background: #fff; }
.form-card h2 { font-family: var(--font-display); font-size: 1.9rem; color: var(--color-secundario); margin-bottom: 6px; }
.form-card .sub { font-size: .92rem; color: var(--color-muted); margin-bottom: 28px; }
.form-label { font-size: .9rem; font-weight: 500; color: var(--color-texto); margin-bottom: 4px; }
.form-control, .form-select { border: 1px solid var(--color-borde); border-radius: 5px; font-size: .95rem; padding: 11px 14px; }
.form-control:focus, .form-select:focus { border-color: var(--color-primario); box-shadow: 0 0 0 3px rgba(242,158,0,.15); }

/* ── ALERTAS ─────────────────────────────────────────── */
.alert-tierra { background: var(--color-crema); border: 1px solid var(--color-borde); color: var(--color-secundario); border-radius: 6px; padding: 13px 16px; font-size: .95rem; }

/* ── RESUMEN PEDIDO ──────────────────────────────────── */
.resumen-pedido { background: var(--color-crema); border: 1px solid var(--color-borde); border-radius: 10px; padding: 24px; }
.resumen-pedido h5 { font-family: var(--font-display); font-size: 1.3rem; color: var(--color-secundario); margin-bottom: 16px; }
.resumen-linea { display: flex; justify-content: space-between; font-size: .95rem; padding: 7px 0; border-bottom: 1px solid var(--color-borde); }
.resumen-total { display: flex; justify-content: space-between; font-weight: 600; font-size: 1.05rem; padding-top: 12px; color: var(--color-secundario); }

/* ── FOOTER ──────────────────────────────────────────── */
.footer { font-family: var(--font-body); }
.footer-brand { font-family: var(--font-display); font-size: 1.25rem; font-weight: 600; }

/* ── BLOQUE TITULO ───────────────────────────────────── */
.bloque-titulo { font-size: .88rem; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: var(--color-muted); margin-bottom: 14px; padding-bottom: 8px; border-bottom: 1px solid var(--color-borde); }

/* ── SPINNER CANTIDAD ────────────────────────────────── */
.input-group .btn-outline-secondary { border-color: var(--color-borde); color: var(--color-secundario); font-size: 1.15rem; font-weight: 500; padding: 7px 15px; background: #fff; }
.input-group .btn-outline-secondary:hover { background: var(--color-crema); border-color: var(--color-primario); color: var(--color-secundario); }
#cantidad { border-color: var(--color-borde); font-size: 1.05rem; }
#cantidad::-webkit-inner-spin-button,
#cantidad::-webkit-outer-spin-button { -webkit-appearance: none; margin: 0; }
#cantidad { -moz-appearance: textfield; }

/* ── MIS PEDIDOS ─────────────────────────────────────── */
.stat-card  { border: 1px solid var(--color-borde); border-radius: 10px; background: var(--color-crema); }
.stat-num   { font-family: var(--font-display); font-size: 2.1rem; font-weight: 700; color: var(--color-secundario); }
.stat-label { font-size: .82rem; color: var(--color-muted); text-transform: uppercase; letter-spacing: .06em; margin-top: 2px; }
.pedido-card  { border: 1px solid var(--color-borde); border-radius: 10px; padding: 22px 24px; background: #fff; transition: box-shadow .18s; }
.pedido-card:hover { box-shadow: 0 4px 16px rgba(242,158,0,.12); }
.pedido-id    { font-family: var(--font-display); font-size: 1.1rem; font-weight: 700; color: var(--color-secundario); }
.pedido-fecha { font-size: .85rem; color: var(--color-muted); }
.pedido-detalle-item { display: flex; justify-content: space-between; font-size: .92rem; padding: 6px 0; border-bottom: 1px solid var(--color-borde); }
.pedido-total-row { border-bottom: none; padding-top: 10px; font-size: .98rem; }
.pd-label { color: var(--color-muted); font-size: .88rem; }
.pedido-entrega { font-size: .92rem; }
.pe-item { display: flex; gap: 10px; padding: 6px 0; border-bottom: 1px solid var(--color-borde); }
.pe-item:last-child { border-bottom: none; }
.pe-item .pd-label { min-width: 90px; color: var(--color-muted); font-size: .88rem; flex-shrink: 0; }
.badge-estado { display: inline-block; font-size: .78rem; font-weight: 600; padding: 4px 12px; border-radius: 100px; letter-spacing: .04em; }
.badge-estado.pendiente  { background: #fff8e1; color: #b77a00; border: 1px solid #ffe082; }
.badge-estado.confirmado { background: #e8f5e9; color: #2e7d32; border: 1px solid #a5d6a7; }
.badge-estado.en-camino  { background: #e3f2fd; color: #1565c0; border: 1px solid #90caf9; }
.badge-estado.entregado  { background: #ede7f6; color: #5e3d99; border: 1px solid #ce93d8; }
.badge-estado.cancelado  { background: #fce4ec; color: #b71c1c; border: 1px solid #f48fb1; }

/* ── UTILIDADES ──────────────────────────────────────── */
.text-tierra { color: var(--color-secundario) !important; }
.bg-crema    { background: var(--color-crema) !important; }
.seccion     { padding: 72px 0; }
.divider     { height: 1px; background: var(--color-borde); margin: 0; }
