/* ============================================================
   RESTAURANTE HACIENDA COYOTES · Páginas de menú
   Comparte tokens y componentes con site.css
   ============================================================ */

.nav .links a.on { color: var(--terra); }

/* ---------- Encabezado ---------- */
.menu-head { color: var(--crema); padding: 64px 0 48px; }
.menu-head.olivo { background: var(--olivo); }
.menu-head.verde { background: #5E662D; }
.menu-head.noche { background: var(--noche); }
.menu-head .kicker { color: var(--oro); display: inline-flex; align-items: center; gap: 10px; }
.menu-head .kicker::before { content: ""; width: 24px; height: 2px; background: var(--oro); }
.menu-head h1 { font-size: clamp(38px, 5.6vw, 72px); line-height: 1.02; color: #F8F2E3; margin-top: 16px; }
.menu-head h1 em { font-family: var(--ff-ed); color: var(--oro); }
.menu-head .note { margin-top: 16px; font-family: var(--ff-mono); font-size: 10.5px; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(246,242,233,0.62); }
.menu-switch { display: flex; gap: 10px; margin-top: 30px; flex-wrap: wrap; }
.menu-switch a { font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; padding: 10px 22px; border-radius: 999px; border: 1.5px solid rgba(246,242,233,0.35); color: rgba(246,242,233,0.85); }
.menu-switch a:hover { border-color: var(--oro); color: var(--oro); }
.menu-switch a.on { background: var(--oro); border-color: var(--oro); color: #3A2E0B; }

/* ---------- Cuerpo ---------- */
.menu-body { padding: 24px 0 96px; }
@media (max-width: 720px) { .menu-body { padding: 8px 0 72px; } }

.mcat-head { display: flex; align-items: baseline; gap: 18px; flex-wrap: wrap; margin: 64px 0 28px; padding-bottom: 14px; border-bottom: 2px solid var(--line); }
.mcat-head h2 { font-size: clamp(26px, 3vw, 36px); }
.mcat-head .sub { font-family: var(--ff-mono); font-size: 10.5px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink3); }

.mgrid { display: grid; grid-template-columns: 1fr 1fr; gap: 28px 56px; }
@media (max-width: 760px) { .mgrid { grid-template-columns: 1fr; gap: 22px; } }

.mi .t { display: flex; align-items: baseline; gap: 12px; }
.mi .t h3 { font-size: 20px; font-weight: 400; flex: none; max-width: 70%; }
.mi .t .dots { flex: 1; border-bottom: 2px dotted #C9BFA9; transform: translateY(-4px); min-width: 24px; }
.mi .t .p { font-family: var(--ff-mono); font-size: 14.5px; font-weight: 500; color: var(--terra); white-space: nowrap; flex: none; }
.mi .d { font-size: 14px; color: var(--ink2); line-height: 1.55; margin-top: 6px; max-width: 54ch; }
.veg { font-family: var(--ff-mono); font-size: 8.5px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--wa); border: 1px solid var(--wa); padding: 2px 8px; border-radius: 999px; white-space: nowrap; }
.pic { font-size: 12px; letter-spacing: 0.1em; }

/* ---------- Destacados ---------- */
.mfeat { display: grid; grid-template-columns: 1fr auto; gap: 24px 48px; align-items: center; background: #FFFFFF; border: 1px solid var(--line); border-radius: 18px; padding: clamp(24px, 3.4vw, 40px); margin-top: 56px; }
@media (max-width: 720px) { .mfeat { grid-template-columns: 1fr; } }
.mfeat .tag { display: inline-block; background: var(--ambar); color: #4A3A06; font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; padding: 6px 14px; border-radius: 999px; }
.mfeat h2 { font-size: clamp(26px, 3vw, 36px); margin-top: 14px; }
.mfeat .d { font-size: 14.5px; color: var(--ink2); line-height: 1.6; margin-top: 12px; max-width: 60ch; }
.mfeat ul { margin: 14px 0 0; padding: 0; list-style: none; display: flex; flex-wrap: wrap; gap: 8px 18px; font-size: 14px; color: var(--ink2); }
.mfeat ul li { display: inline-flex; align-items: center; gap: 8px; }
.mfeat ul li::before { content: ""; width: 7px; height: 7px; background: var(--oro); transform: rotate(45deg); flex: none; }
.mfeat .pr { text-align: center; padding: 0 8px; }
.mfeat .pr .lbl { display: block; font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink3); }
.mfeat .pr .val { display: block; font-family: var(--ff-display); font-size: clamp(38px, 4vw, 52px); color: var(--terra); margin-top: 6px; }
.mfeat .cols { display: grid; grid-template-columns: 1fr 1fr; gap: 18px 32px; margin-top: 16px; }
@media (max-width: 560px) { .mfeat .cols { grid-template-columns: 1fr; } }
.mfeat .cols h4 { margin: 0 0 8px; font-family: var(--ff-mono); font-size: 10.5px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--verde); font-weight: 500; }
.mfeat .cols ul { display: block; }
.mfeat .cols ul li { display: flex; justify-content: flex-start; padding: 3px 0; }
.mfeat .cols ul li .x { margin-left: auto; font-family: var(--ff-mono); font-size: 13px; color: var(--terra); padding-left: 16px; }

/* ---------- Tablas (destilados / vinos) ---------- */
.mtabs-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; align-items: start; }
@media (max-width: 860px) { .mtabs-grid { grid-template-columns: 1fr; } }
.mtab { background: #FFFFFF; border: 1px solid var(--line); border-radius: 14px; overflow: hidden; }
.mtab .row { display: grid; grid-template-columns: 1fr 110px 90px; gap: 12px; padding: 9px 18px; font-size: 14px; border-top: 1px solid #EDE6D6; align-items: baseline; }
.mtab .row:first-child { border-top: 0; }
.mtab .row.head { background: #EFE9DA; border-top: 0; font-family: var(--ff-mono); font-size: 9.5px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink3); padding: 11px 18px; }
.mtab .row.head span:first-child { font-size: 12px; color: var(--ink); letter-spacing: 0.18em; }
.mtab .row span:nth-child(2), .mtab .row span:nth-child(3) { text-align: right; font-family: var(--ff-mono); font-size: 13px; color: var(--ink2); }
.mtab .row.head span:nth-child(2), .mtab .row.head span:nth-child(3) { font-family: var(--ff-mono); font-size: 9.5px; color: var(--ink3); }
.mtab.wine .row { grid-template-columns: 36px 1fr 1.1fr 76px 86px; }
@media (max-width: 640px) { .mtab.wine .row { grid-template-columns: 36px 1.2fr 1fr 64px 74px; padding: 9px 12px; font-size: 12.5px; } }
.mtab.wine .row span:nth-child(3) { font-size: 13px; color: var(--ink3); font-family: var(--ff-body); }
.mtab.wine .row span:nth-child(4), .mtab.wine .row span:nth-child(5) { text-align: right; font-family: var(--ff-mono); font-size: 13px; color: var(--ink2); }
.mtab.wine .row.head span { font-family: var(--ff-mono); font-size: 9.5px; color: var(--ink3); }
.wbadge { display: inline-grid; place-items: center; width: 22px; height: 22px; border-radius: 99px; font-family: var(--ff-mono); font-size: 10px; color: #FFF; }
.wbadge.e { background: var(--oro); color: #3A2E0B; }
.wbadge.r { background: #C77B8C; }
.wbadge.b { background: #A8A04E; }
.wbadge.t { background: #7A3B3B; }
.wine-key { display: flex; gap: 18px; flex-wrap: wrap; margin-top: 14px; font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink3); }
.wine-key span { display: inline-flex; align-items: center; gap: 8px; }

.mnote { margin-top: 56px; font-family: var(--ff-mono); font-size: 10.5px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink3); line-height: 2; text-align: center; }

/* ---------- CTA final ---------- */
.menu-cta { background: var(--paper); border-top: 1px solid var(--line); padding: 64px 0; text-align: center; }
.menu-cta h2 { font-size: clamp(26px, 3.4vw, 40px); }
.menu-cta h2 em { font-family: var(--ff-ed); color: var(--terra); }
.menu-cta .ctas { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; margin-top: 26px; }
