/* ============================================================
   GRUPO HACIENDA COYOTES · Home global · Fase 3
   Sistema visual: branding board HC
   #3E3E3B carbón · #4F4534 olivo · #4C586F azul · #EBECED
   #A2AAB0 · #CBC5C1 · #FFC61B amarillo
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@300;400;500;600;700;800&family=IBM+Plex+Mono:wght@400;500&display=swap');

@font-face {
  font-family: "Huvet";
  src: url("../assets/fonts/Huvet.otf") format("opentype");
  font-weight: 400; font-display: swap;
}
@font-face {
  font-family: "Aeonik";
  src: url("../assets/fonts/Aeonik-RegularItalic.otf") format("opentype");
  font-weight: 400; font-style: italic; font-display: swap;
}

:root {
  --carbon:  #3E3E3B;
  --olivo:   #4F4534;
  --azul:    #4C586F;
  --niebla:  #EBECED;
  --acero:   #A2AAB0;
  --piedra:  #CBC5C1;
  --amarillo:#FFC61B;
  --oro:     #C9A24B;
  --naranja: #D2622A;
  --paper:   #F5F4F1;
  --ink:     #2C2C29;
  --ink2:    #54534D;
  --ink3:    #71706A;
  --line:    #DCDAD4;
  --wa:      #2E7D4F;
  --ff-body: "Manrope", -apple-system, sans-serif;
  --ff-display: "Huvet", Georgia, serif;
  --ff-ed: "Aeonik", Georgia, serif;
  --ff-mono: "IBM Plex Mono", ui-monospace, monospace;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--ff-body);
  font-size: 16px; line-height: 1.6;
  color: var(--ink); background: var(--paper);
  -webkit-font-smoothing: antialiased;
}
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
h1, h2, h3 { margin: 0; font-family: var(--ff-display); font-weight: 400; letter-spacing: 0.005em; text-wrap: balance; }
p { margin: 0; text-wrap: pretty; }
::selection { background: var(--amarillo); color: var(--carbon); }

.shell { max-width: 1220px; margin: 0 auto; padding: 0 28px; }
@media (max-width: 720px) { .shell { padding: 0 20px; } }

.kicker { font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; }
.ed { font-family: var(--ff-ed); font-style: italic; font-weight: 400; }

/* ---------- Botones ---------- */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 9px; font-family: var(--ff-body); font-size: 15px; font-weight: 700; padding: 14px 28px; border-radius: 999px; border: none; cursor: pointer; transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease; min-height: 48px; }
.btn:hover { transform: translateY(-1px); }
.btn-sun { background: var(--amarillo); color: #3A2E06; box-shadow: 0 8px 24px -10px rgba(255,198,27,0.65); }
.btn-sun:hover { background: #EAB200; }
.btn-ghost { background: transparent; border: 1.5px solid currentColor; font-weight: 600; }
.btn-wa { background: var(--wa); color: #F0FAF3; }
.btn-dark { background: var(--carbon); color: var(--niebla); }
.btn-dark:hover { background: #2C2C29; }

/* ---------- Zigzag HC ---------- */
.zig { height: 8px; width: 120px; background:
  linear-gradient(135deg, var(--zc, var(--amarillo)) 50%, transparent 50%) 0 0 / 16px 100%,
  linear-gradient(45deg, transparent 50%, var(--zc, var(--amarillo)) 50%) 8px 0 / 16px 100%; }

/* ---------- NAV ---------- */
.nav { position: sticky; top: 0; z-index: 50; background: rgba(62,62,59,0.92); backdrop-filter: blur(14px) saturate(140%); -webkit-backdrop-filter: blur(14px) saturate(140%); border-bottom: 1px solid rgba(255,255,255,0.08); }
.nav .inner { max-width: 1220px; margin: 0 auto; padding: 0 28px; display: flex; align-items: center; gap: 28px; height: 76px; }
.nav .logo img { height: 52px; width: auto; }
.nav .links { display: flex; gap: 24px; margin-left: auto; align-items: center; }
.nav .links a { font-size: 14px; font-weight: 600; color: rgba(235,236,237,0.85); }
.nav .links a:hover, .nav .links a.on { color: var(--amarillo); }
.nav .links .btn { font-size: 14px; padding: 10px 22px; min-height: 42px; }
@media (max-width: 920px) {
  .nav .links a:not(.btn) { display: none; }
}

/* ---------- HERO ---------- */
.hero { position: relative; min-height: 86vh; display: flex; align-items: flex-end; color: var(--niebla); isolation: isolate; }
.hero .bg { position: absolute; inset: 0; z-index: -1; }
.hero .bg img, .hero .bg video { width: 100%; height: 100%; object-fit: cover; }
.hero .bg::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(62,62,59,0.42) 0%, rgba(62,62,59,0.18) 38%, rgba(44,44,41,0.86) 100%); }
.hero .content { width: 100%; padding: 140px 28px 64px; }
@media (max-width: 720px) { .hero .content { padding: 100px 20px 48px; } }
.hero .kicker { color: var(--amarillo); display: inline-flex; align-items: center; gap: 10px; }
.hero .kicker::before { content: ""; width: 26px; height: 2px; background: var(--amarillo); }
.hero h1 { font-size: clamp(42px, 6.4vw, 88px); line-height: 1.0; color: #F8F6EE; margin-top: 18px; max-width: 18ch; }
.hero h1 em { font-family: var(--ff-ed); color: var(--amarillo); }
.hero .sub { font-size: clamp(16px, 1.6vw, 19px); color: rgba(235,236,237,0.88); max-width: 56ch; margin-top: 18px; line-height: 1.65; }

/* Intent chips */
.intent { margin-top: 36px; }
.intent .q { font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: rgba(235,236,237,0.7); margin-bottom: 14px; }
.intent .chips { display: flex; flex-wrap: wrap; gap: 10px; }
.intent .chips a { display: inline-flex; align-items: center; gap: 10px; font-size: 14.5px; font-weight: 600; padding: 12px 22px; border-radius: 999px; border: 1.5px solid rgba(235,236,237,0.4); color: #F2F1EC; background: rgba(44,44,41,0.35); backdrop-filter: blur(6px); transition: all 0.15s ease; min-height: 46px; }
.intent .chips a:hover { background: var(--amarillo); border-color: var(--amarillo); color: #3A2E06; }
.intent .chips a .e { font-family: var(--ff-ed); font-style: italic; opacity: 0.85; }

/* ---------- Secciones ---------- */
.sec { padding: 96px 0; }
.sec.tight { padding: 72px 0; }
.sec.dark { background: var(--carbon); color: var(--niebla); }
.sec.olivo { background: var(--olivo); color: var(--niebla); }
.sec.niebla { background: var(--niebla); }
.sechead { max-width: 720px; margin-bottom: 52px; }
.sechead .kicker { color: var(--naranja); display: inline-flex; align-items: center; gap: 10px; }
.sechead .kicker::before { content: ""; width: 24px; height: 2px; background: var(--naranja); }
.sec.dark .sechead .kicker, .sec.olivo .sechead .kicker { color: var(--amarillo); }
.sec.dark .sechead .kicker::before, .sec.olivo .sechead .kicker::before { background: var(--amarillo); }
.sechead h2 { font-size: clamp(30px, 4vw, 52px); line-height: 1.05; margin-top: 14px; }
.sechead h2 em { font-family: var(--ff-ed); }
.sec h2 em { color: var(--naranja); }
.sec.dark h2 em, .sec.olivo h2 em { color: var(--amarillo); }
.sechead .lead { font-size: 17px; color: var(--ink2); margin-top: 16px; line-height: 1.65; }
.sec.dark .sechead .lead, .sec.olivo .sechead .lead { color: rgba(235,236,237,0.78); }

/* ---------- Puertas (unidades) ---------- */
.units { display: grid; grid-template-columns: repeat(2, 1fr); gap: 26px; }
@media (max-width: 860px) { .units { grid-template-columns: 1fr; } }
.unit { position: relative; display: grid; grid-template-rows: 260px auto; background: #FFFFFF; border: 1px solid var(--line); border-radius: 20px; overflow: hidden; transition: transform 0.18s ease, box-shadow 0.18s ease; }
.unit:hover { transform: translateY(-3px); box-shadow: 0 22px 48px -22px rgba(44,44,41,0.35); }
.unit.wide { grid-column: 1 / -1; grid-template-rows: auto; grid-template-columns: 1.1fr 1fr; }
@media (max-width: 860px) { .unit.wide { grid-template-columns: 1fr; grid-template-rows: 260px auto; } }
.unit .ph { position: relative; overflow: hidden; }
.unit .ph img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s ease; }
.unit:hover .ph img { transform: scale(1.04); }
.unit .ph .flag { position: absolute; top: 16px; left: 16px; font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; background: rgba(44,44,41,0.78); color: var(--amarillo); padding: 6px 13px; border-radius: 999px; backdrop-filter: blur(4px); }
.unit .body { padding: 26px 28px 28px; display: flex; flex-direction: column; gap: 10px; }
.unit .body h3 { font-size: clamp(22px, 2.4vw, 30px); }
.unit .body .desc { font-size: 14.5px; color: var(--ink2); line-height: 1.6; }
.unit .body .meta { display: flex; flex-wrap: wrap; gap: 6px 18px; font-family: var(--ff-mono); font-size: 10.5px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink3); margin-top: 2px; }
.unit .body .go { margin-top: auto; padding-top: 14px; display: inline-flex; align-items: center; gap: 8px; font-size: 14px; font-weight: 700; color: var(--naranja); }
.unit .body .go:hover { color: #B5511F; }
.unit .body .go.soon { color: var(--ink3); cursor: default; font-weight: 600; }

/* ---------- Experiencias ---------- */
.exps { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 20px; }
@media (max-width: 560px) { .exps { grid-template-columns: repeat(2, 1fr); } }
.exp { position: relative; border-radius: 16px; overflow: hidden; aspect-ratio: 3 / 4; color: #F2F1EC; isolation: isolate; }
.exp img { position: absolute; inset: 0; z-index: -1; width: 100%; height: 100%; object-fit: cover; }
.exp::after { content: ""; position: absolute; inset: 0; z-index: -1; background: linear-gradient(180deg, transparent 35%, rgba(44,44,41,0.88) 100%); }
.exp .inner { position: absolute; inset: auto 0 0 0; padding: 20px; }
.exp h3 { font-size: 22px; }
.exp .pr { font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--amarillo); margin-top: 6px; }
.exp-note { margin-top: 22px; font-family: var(--ff-mono); font-size: 10.5px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink3); }

/* ---------- Historia ---------- */
.story { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
@media (max-width: 860px) { .story { grid-template-columns: 1fr; gap: 40px; } }
.story .ph { border-radius: 20px; overflow: hidden; }
.story .ph img { width: 100%; height: 100%; object-fit: cover; aspect-ratio: 4 / 5; }
.story .glyph { width: 64px; opacity: 0.9; margin-bottom: 22px; }
.story h2 { font-size: clamp(30px, 3.6vw, 46px); line-height: 1.08; }
.story p { font-size: 16.5px; line-height: 1.7; color: rgba(235,236,237,0.82); margin-top: 18px; max-width: 52ch; }
.story .vals { display: flex; gap: 28px; margin-top: 30px; flex-wrap: wrap; }
.story .vals div { font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--amarillo); }

/* ---------- Recorrido 360 ---------- */
.tour360 { border-radius: 20px; overflow: hidden; border: 1px solid var(--line); box-shadow: 0 24px 60px -30px rgba(44,44,41,0.4); background: var(--carbon); }
.tour360 iframe { display: block; width: 100%; }
@media (max-width: 720px) { .tour360 iframe { height: 420px; } }

/* ---------- Mapa / 360 ---------- */
.map360 { position: relative; border-radius: 20px; overflow: hidden; isolation: isolate; min-height: 440px; display: grid; place-items: center; text-align: center; color: #F2F1EC; }
.map360 img { position: absolute; inset: 0; z-index: -1; width: 100%; height: 100%; object-fit: cover; }
.map360::after { content: ""; position: absolute; inset: 0; z-index: -1; background: rgba(44,44,41,0.55); }
.map360 .inner { padding: 48px 24px; max-width: 520px; }
.map360 h3 { font-size: clamp(26px, 3vw, 38px); }
.map360 p { font-size: 15px; color: rgba(235,236,237,0.85); margin-top: 12px; }
.map360 .btn { margin-top: 22px; }

/* ---------- Eventos teaser ---------- */
.evt-teaser { display: grid; grid-template-columns: 1fr 1fr; gap: 0; border-radius: 20px; overflow: hidden; background: var(--olivo); color: var(--niebla); }
@media (max-width: 860px) { .evt-teaser { grid-template-columns: 1fr; } }
.evt-teaser .ph img { width: 100%; height: 100%; object-fit: cover; min-height: 300px; }
.evt-teaser .body { padding: clamp(32px, 4vw, 56px); display: flex; flex-direction: column; justify-content: center; gap: 16px; }
.evt-teaser h2 { font-size: clamp(28px, 3.4vw, 44px); line-height: 1.08; }
.evt-teaser h2 em { font-family: var(--ff-ed); color: var(--amarillo); }
.evt-teaser p { font-size: 15.5px; color: rgba(235,236,237,0.82); line-height: 1.65; max-width: 48ch; }
.evt-teaser .ctas { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 8px; }

/* ---------- Reseñas ---------- */
.quotes { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
@media (max-width: 860px) { .quotes { grid-template-columns: 1fr; } }
.quote { background: #FFFFFF; border: 1px solid var(--line); border-radius: 16px; padding: 26px; display: flex; flex-direction: column; gap: 14px; }
.quote .stars { color: var(--amarillo); font-size: 15px; letter-spacing: 3px; }
.quote p { font-size: 14.5px; line-height: 1.65; color: var(--ink2); font-style: italic; }
.quote .who { font-family: var(--ff-mono); font-size: 10.5px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink3); margin-top: auto; }

/* ---------- FAQ ---------- */
.faq-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0 32px; align-items: start; }
@media (max-width: 860px) { .faq-grid { grid-template-columns: 1fr; } }
.faq-col details { border-bottom: 1px solid var(--line); }
.faq-col summary { cursor: pointer; list-style: none; display: flex; align-items: baseline; justify-content: space-between; gap: 18px; padding: 18px 0; font-size: 16px; font-weight: 700; color: var(--ink); }
.faq-col summary::-webkit-details-marker { display: none; }
.faq-col summary::after { content: "+"; font-family: var(--ff-mono); font-size: 18px; color: var(--naranja); flex: none; transition: transform 0.15s ease; }
.faq-col details[open] summary::after { content: "–"; }
.faq-col .a { font-size: 14.5px; color: var(--ink2); line-height: 1.65; padding: 0 28px 18px 0; max-width: 60ch; }
.faq-col .a a { font-weight: 700; color: var(--naranja); }

/* ---------- Cómo llegar ---------- */
.llegar { display: grid; grid-template-columns: 1fr 1.1fr; gap: 48px; align-items: start; }
@media (max-width: 860px) { .llegar { grid-template-columns: 1fr; } }
.llegar .map { border-radius: 18px; overflow: hidden; border: 1px solid var(--line); min-height: 380px; }
.llegar .map iframe { width: 100%; height: 100%; min-height: 380px; border: 0; display: block; }
.llegar dl { margin: 0; display: grid; gap: 22px; }
.llegar dt { font-family: var(--ff-mono); font-size: 10.5px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink3); margin-bottom: 5px; }
.llegar dd { margin: 0; font-size: 15.5px; color: var(--ink); line-height: 1.6; }
.llegar dd a { font-weight: 700; color: var(--naranja); }
.llegar .ctas { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 26px; }

/* ---------- Bolsa de trabajo ---------- */
.demo-note { display: inline-block; font-family: var(--ff-mono); font-size: 10.5px; letter-spacing: 0.12em; text-transform: uppercase; color: #8A6D00; background: #FFF3CC; border: 1px solid #EAD489; border-radius: 999px; padding: 7px 16px; margin-bottom: 24px; }
.jobs { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
@media (max-width: 860px) { .jobs { grid-template-columns: 1fr; } }
.job { background: #FFFFFF; border: 1px solid var(--line); border-radius: 18px; padding: 28px; display: flex; flex-direction: column; gap: 12px; }
.job h3 { font-size: 23px; }
.job .meta { display: flex; flex-wrap: wrap; gap: 6px 16px; font-family: var(--ff-mono); font-size: 10.5px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink3); margin-top: 8px; }
.job .desc { font-size: 14.5px; color: var(--ink2); line-height: 1.6; }
.job .req { font-size: 13.5px; color: var(--ink3); line-height: 1.6; }
.job .req strong { color: var(--ink2); font-weight: 700; }
.job .apply { margin-top: auto; align-self: flex-start; font-size: 13.5px; padding: 10px 22px; min-height: 42px; }
.jobs-empty { font-size: 15.5px; color: var(--ink2); background: #FFFFFF; border: 1px dashed var(--piedra); border-radius: 14px; padding: 28px; text-align: center; }

.apply-grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: 56px; align-items: start; }
@media (max-width: 860px) { .apply-grid { grid-template-columns: 1fr; gap: 36px; } }
.apply-aside { display: grid; gap: 18px; }
.apply-aside .t { display: block; font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--amarillo); margin-bottom: 3px; }
.apply-aside .d { font-size: 14.5px; color: rgba(235,236,237,0.85); }
.apply-aside .d a { font-weight: 700; color: var(--amarillo); }
.apply-form { background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.14); border-radius: 18px; padding: 30px; display: grid; gap: 18px; }
.apply-form label { display: grid; gap: 7px; }
.apply-form label span { font-family: var(--ff-mono); font-size: 10.5px; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(235,236,237,0.7); }
.apply-form input, .apply-form select, .apply-form textarea { font-family: var(--ff-body); font-size: 15px; color: var(--ink); background: #FDFCFA; border: 1px solid rgba(255,255,255,0.2); border-radius: 10px; padding: 13px 15px; width: 100%; }
.apply-form textarea { resize: vertical; }
.apply-form input:focus, .apply-form select:focus, .apply-form textarea:focus { outline: 2px solid var(--amarillo); outline-offset: 1px; }
.apply-form .btn { justify-self: start; }
.apply-form .fine { font-size: 12px; color: rgba(235,236,237,0.6); line-height: 1.5; }

/* ---------- FOOTER ---------- */
.footer { background: var(--carbon); color: var(--piedra); padding: 64px 0 40px; }
.footer .top { display: flex; align-items: flex-start; justify-content: space-between; gap: 32px; flex-wrap: wrap; padding-bottom: 36px; border-bottom: 1px solid rgba(255,255,255,0.12); }
.footer .top img { height: 84px; width: auto; }
.footer .cols { display: flex; gap: 64px; flex-wrap: wrap; }
.footer .col h4 { margin: 0 0 12px; font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--acero); font-weight: 500; }
.footer .col a { display: block; font-size: 14px; color: var(--piedra); padding: 4px 0; }
.footer .col a:hover { color: var(--amarillo); }
.footer .base { display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap; padding-top: 26px; font-size: 12.5px; color: var(--acero); }

/* ---------- CTA BAR MÓVIL ---------- */
.ctabar { display: none; }
@media (max-width: 720px) {
  .ctabar { display: flex; position: fixed; bottom: 0; left: 0; right: 0; z-index: 60; gap: 10px; padding: 12px 16px calc(12px + env(safe-area-inset-bottom)); background: rgba(44,44,41,0.96); backdrop-filter: blur(12px); }
  .ctabar .btn { flex: 1; font-size: 14px; padding: 12px 10px; }
  body { padding-bottom: 76px; }
}

/* ============================================================
   PÁGINAS INTERIORES (eventos / contacto)
   ============================================================ */
.page-head { background: var(--olivo); color: var(--niebla); padding: 72px 0 56px; }
.page-head .kicker { color: var(--amarillo); display: inline-flex; align-items: center; gap: 10px; }
.page-head .kicker::before { content: ""; width: 24px; height: 2px; background: var(--amarillo); }
.page-head h1 { font-size: clamp(38px, 5.4vw, 68px); line-height: 1.02; color: #F8F6EE; margin-top: 16px; }
.page-head h1 em { font-family: var(--ff-ed); color: var(--amarillo); }
.page-head .lead { font-size: 17px; color: rgba(235,236,237,0.82); max-width: 58ch; margin-top: 16px; line-height: 1.65; }

/* Eventos hub */
.evt-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 26px; }
@media (max-width: 860px) { .evt-grid { grid-template-columns: 1fr; } }
.evt { display: grid; grid-template-rows: 230px auto; background: #FFFFFF; border: 1px solid var(--line); border-radius: 20px; overflow: hidden; }
.evt .ph { position: relative; overflow: hidden; }
.evt .ph img { width: 100%; height: 100%; object-fit: cover; }
.evt .ph .flag { position: absolute; top: 16px; left: 16px; font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; background: rgba(44,44,41,0.78); color: var(--amarillo); padding: 6px 13px; border-radius: 999px; }
.evt .body { padding: 26px 28px 28px; display: flex; flex-direction: column; gap: 10px; }
.evt .body h3 { font-size: clamp(21px, 2.2vw, 27px); }
.evt .body .desc { font-size: 14.5px; color: var(--ink2); line-height: 1.6; }
.evt .body .feats { display: flex; flex-wrap: wrap; gap: 6px 16px; font-family: var(--ff-mono); font-size: 10.5px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink3); }
.evt .body .ctas { display: flex; gap: 10px; flex-wrap: wrap; margin-top: auto; padding-top: 16px; }
.evt .body .ctas .btn { font-size: 13.5px; padding: 10px 20px; min-height: 42px; }

/* Pasos */
.steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
@media (max-width: 860px) { .steps { grid-template-columns: 1fr; } }
.step { background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.14); border-radius: 16px; padding: 26px; }
.step .n { font-family: var(--ff-display); font-size: 36px; color: var(--amarillo); }
.step h3 { font-size: 19px; margin-top: 10px; }
.step p { font-size: 14px; color: rgba(235,236,237,0.78); line-height: 1.6; margin-top: 8px; }

/* Contacto */
.con-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 26px; }
@media (max-width: 860px) { .con-grid { grid-template-columns: 1fr; } }
.con-card { background: #FFFFFF; border: 1px solid var(--line); border-radius: 18px; padding: 28px; display: flex; flex-direction: column; gap: 8px; }
.con-card h3 { font-size: 22px; }
.con-card .sub { font-family: var(--ff-mono); font-size: 10.5px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink3); }
.con-card p { font-size: 14.5px; color: var(--ink2); line-height: 1.6; }
.con-card .ctas { display: flex; gap: 10px; flex-wrap: wrap; margin-top: auto; padding-top: 14px; }
.con-card .ctas .btn { font-size: 13.5px; padding: 10px 20px; min-height: 42px; }
.hours { width: 100%; border-collapse: collapse; }
.hours td { padding: 9px 0; font-size: 14.5px; border-top: 1px solid var(--line); vertical-align: top; }
.hours tr:first-child td { border-top: 0; }
.hours td:last-child { text-align: right; font-family: var(--ff-mono); font-size: 12.5px; color: var(--ink2); white-space: nowrap; padding-left: 18px; }
