/* =========================================================
   Metaly — Rediseño premium. Tipografía única: Google Sans Flex (autoalojada).
   ========================================================= */
@font-face{font-family:'Google Sans Flex';
  src:url('/assets/fonts/google-sans-flex-latin.woff2') format('woff2');
  font-weight:100 1000;font-stretch:75% 125%;font-display:swap;
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@font-face{font-family:'Google Sans Flex';
  src:url('/assets/fonts/google-sans-flex-latin-ext.woff2') format('woff2');
  font-weight:100 1000;font-stretch:75% 125%;font-display:swap;
  unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20CF,U+2113,U+2C60-2C7F,U+A720-A7FF}

:root{
  --ff-display:'Google Sans Flex', system-ui, sans-serif;
  --steel-ink:#1a1a1d;
  --hair:rgba(24,24,27,.09);
  --hair-2:rgba(24,24,27,.14);
  --soft:#f6f7f9;
  --soft-2:#eef1f4;
  --glow:rgba(249,115,22,.12);
  --glow-2:rgba(249,115,22,.05);
  --shadow-soft:0 2px 10px rgba(24,24,27,.04),0 8px 30px rgba(24,24,27,.06);
  --shadow-pop:0 18px 50px rgba(24,24,27,.13);
  --shadow-accent:0 8px 24px rgba(249,115,22,.28);
}

/* ---------- Tipografía editorial ---------- */
.hero-h1,
.section-heading,
.cta-banner h2,
.stat-number,
.proj-meta .t,
.why-badge-num,
.proc-num{
  font-family:var(--ff-display);
  letter-spacing:-.015em;
  font-weight:800;
}
.section-heading{font-size:clamp(1.75rem,3.8vw,2.8rem);line-height:1.1;font-weight:700}
.section-heading em{color:var(--accent);font-style:normal;font-weight:800}
.hero-h1{font-weight:800;line-height:1.04;letter-spacing:-.035em}
.hero-h1 em{font-style:normal;color:var(--accent);font-weight:800}
.section-sub{color:var(--ink-3);font-size:clamp(1rem,1.6vw,1.12rem);line-height:1.75;max-width:62ch}

/* ---------- Eyebrow tipo pill (aplica a .label-eyebrow y .hero .eyebrow) ---------- */
.label-eyebrow,
.hero--light .eyebrow{display:inline-flex;align-items:center;gap:.55rem;
  font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);
  background:#fff;padding:.5rem 1rem;border-radius:999px;border:1px solid var(--hair);
  box-shadow:var(--shadow-soft);margin-bottom:1.4rem}
.label-eyebrow::before,
.hero--light .eyebrow::before{content:"";width:6px;height:6px;background:var(--accent);border-radius:50%;
  box-shadow:0 0 0 4px var(--glow);flex-shrink:0}

/* ---------- Botones premium ---------- */
.btn-primary{box-shadow:var(--shadow-accent)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(249,115,22,.42)}
.btn-ghost{background:#fff;border:1px solid var(--hair-2);color:var(--steel-ink)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent);background:#fff;transform:translateY(-2px)}

/* ---------- HERO foto de fondo, clave blanca ---------- */
.hero.hero--photo{position:relative;overflow:hidden;color:var(--ink-2);border-bottom:1px solid var(--hair);
  background:#fff;padding-top:clamp(2.5rem,6vw,4.5rem);padding-bottom:clamp(2.5rem,6vw,4.5rem)}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center right}
.hero-bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(100deg,rgba(255,255,255,.97) 0%,rgba(255,255,255,.92) 30%,rgba(255,255,255,.7) 50%,rgba(255,255,255,.52) 72%,rgba(255,255,255,.46) 100%)}
.hero--photo .container{position:relative;z-index:1}
.hero--photo .hero-h1{color:var(--steel-ink);font-size:clamp(2rem,5.2vw,4rem);line-height:1.06;
  hyphens:none;-webkit-hyphens:none;overflow-wrap:break-word;word-break:normal}
/* Trust pills: envolver sin cortarse en móvil */
.hero-trust{flex-wrap:wrap}
.hero-trust span{white-space:normal;max-width:100%;align-items:flex-start}
.hero--photo .hero-sub{color:var(--ink-2);max-width:38ch}
.hero--photo .hero-trust span{color:var(--ink-2)}
.hero--photo .form-card{box-shadow:var(--shadow-pop);border:1px solid var(--hair);background:#fff}
@media(max-width:900px){
  .hero-bg img{object-position:center}
  .hero-bg::after{background:linear-gradient(180deg,rgba(255,255,255,.93) 0%,rgba(255,255,255,.97) 40%,#fff 100%)}
}

/* ---------- STATS (claro, números naranja) ---------- */
.stats-block{background:var(--soft);border-top:1px solid var(--hair);border-bottom:1px solid var(--hair);
  padding:clamp(2.6rem,5vw,3.6rem) 0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.stat-item{text-align:center;padding:.8rem 1.5rem;position:relative}
.stat-item + .stat-item::before{content:"";position:absolute;left:0;top:18%;bottom:18%;width:1px;background:var(--hair-2)}
.stat-number{display:block;font-size:clamp(2.1rem,4.4vw,3.3rem);color:var(--accent);line-height:1}
.stat-number .u{color:var(--steel-ink)}
.stat-label{display:block;font-size:.78rem;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-3);font-weight:600;margin-top:.5rem}
@media(max-width:640px){.stats-grid{grid-template-columns:1fr 1fr;gap:1.6rem 0}
  .stat-item:nth-child(3)::before,.stat-item:nth-child(odd)::before{display:none}}

/* ---------- Tira de certificaciones ---------- */
.certs{border:1px solid var(--hair);border-radius:18px;background:#fff;padding:1.4rem 1.6rem;box-shadow:var(--shadow-soft)}
.certs-title{text-align:center;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-4);margin-bottom:1.1rem}
.certs-row{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:.85rem 1.9rem}
.certs-row span{display:inline-flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:600;color:var(--steel-ink)}
.certs-row svg{color:var(--accent);flex-shrink:0}

/* ---------- Servicios premium ---------- */
.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.service-card{background:#fff;border:1px solid var(--hair);border-radius:20px;padding:2rem 1.8rem;
  box-shadow:var(--shadow-soft);transition:transform .28s ease,box-shadow .28s ease,border-color .28s ease;
  position:relative;overflow:hidden}
.service-card::before{content:"";position:absolute;left:0;top:0;height:3px;width:100%;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  transform:scaleX(0);transform-origin:left;transition:transform .35s ease}
.service-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-pop);border-color:transparent}
.service-card:hover::before{transform:scaleX(1)}
.service-icon{width:54px;height:54px;border-radius:15px;display:grid;place-items:center;
  background:var(--accent-soft);color:var(--accent);margin-bottom:1.3rem;transition:background .28s ease,color .28s ease}
.service-card:hover .service-icon{background:var(--accent);color:#fff}
.service-card h3{font-size:1.2rem;margin-bottom:.55rem;color:var(--steel-ink)}
.service-card p{color:var(--ink-3);font-size:.94rem;line-height:1.65;margin-bottom:1.1rem}
.service-card .more{color:var(--accent);font-weight:700;font-size:.88rem;display:inline-flex;align-items:center;gap:.35rem;transition:gap .2s}
.service-card .more:hover{gap:.6rem}
@media(max-width:900px){.service-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.service-grid{grid-template-columns:1fr}}

/* ---------- Por qué (imagen + badge) ---------- */
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.why-visual{position:relative}
.why-image{border-radius:22px;overflow:hidden;aspect-ratio:4/3;box-shadow:var(--shadow-pop)}
.why-image img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.why-visual:hover .why-image img{transform:scale(1.05)}
.why-badge{position:absolute;bottom:-1.4rem;right:-1.2rem;background:var(--accent);color:#fff;
  padding:1.2rem 1.6rem;border-radius:18px;box-shadow:var(--shadow-accent);text-align:center;line-height:1.1}
.why-badge-num{font-size:2rem;display:block}
.why-badge-text{font-size:.68rem;font-weight:600;opacity:.92;text-transform:uppercase;letter-spacing:.08em}
.why-features{display:flex;flex-direction:column;gap:.9rem;margin-top:1.8rem}
.why-feat{display:flex;gap:1rem;padding:1.15rem 1.35rem;border:1px solid var(--hair);border-radius:14px;
  background:#fff;transition:border-color .2s,box-shadow .2s,transform .2s}
.why-feat:hover{border-color:var(--accent);box-shadow:var(--shadow-soft);transform:translateX(3px)}
.why-feat .feat-icon{width:44px;height:44px;border-radius:11px;background:var(--accent-soft);color:var(--accent);
  display:grid;place-items:center;flex-shrink:0}
.why-feat h4{color:var(--steel-ink);margin-bottom:.2rem;font-size:.98rem}
.why-feat p{color:var(--ink-3);font-size:.86rem;line-height:1.55}
@media(max-width:860px){.why-grid{grid-template-columns:1fr;gap:3rem}.why-badge{right:1rem;bottom:-1.2rem}}

/* ---------- Proceso ---------- */
.proc-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;position:relative;margin-top:3rem}
.proc-row::before{content:"";position:absolute;top:28px;left:12%;right:12%;height:1px;
  background:linear-gradient(90deg,var(--accent),var(--hair-2));z-index:0}
.proc-step{text-align:center;position:relative;z-index:1}
.proc-num{width:58px;height:58px;border-radius:50%;background:#fff;border:1px solid var(--hair-2);
  display:grid;place-items:center;font-size:1.3rem;color:var(--accent);margin:0 auto 1.2rem;
  transition:background .25s,border-color .25s,color .25s,box-shadow .25s}
.proc-step:hover .proc-num{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 0 24px var(--glow)}
.proc-step h4{color:var(--steel-ink);font-size:1rem;margin-bottom:.4rem}
.proc-step p{color:var(--ink-3);font-size:.86rem;line-height:1.6}
@media(max-width:760px){.proc-row{grid-template-columns:1fr 1fr;gap:2rem 1rem}.proc-row::before{display:none}}
@media(max-width:420px){.proc-row{grid-template-columns:1fr}}

/* ---------- Proyectos (galería con fotos) ---------- */
.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.proj-card{position:relative;border-radius:20px;overflow:hidden;aspect-ratio:4/3;
  box-shadow:var(--shadow-soft);background:var(--steel-ink);display:block;border:1px solid var(--hair)}
.proj-card img{width:100%;height:100%;object-fit:cover;filter:brightness(.96);transition:transform .6s ease,filter .45s ease}
.proj-card:hover img{transform:scale(1.07);filter:brightness(1.02)}
.proj-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 42%,rgba(26,26,29,.8))}
.proj-meta{position:absolute;left:0;bottom:0;z-index:2;padding:1.2rem 1.3rem;color:#fff}
.proj-meta .k{font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:#ffba80;font-weight:700}
.proj-meta .t{font-size:1.15rem;font-weight:700;line-height:1.2;margin-top:.2rem}
.proj-card.tall{grid-row:span 2;aspect-ratio:auto}
@media(max-width:820px){.proj-grid{grid-template-columns:1fr 1fr}.proj-card.tall{grid-row:auto;aspect-ratio:4/3}}
@media(max-width:520px){.proj-grid{grid-template-columns:1fr}}

/* ---------- Por qué elegirnos (grid de items) ---------- */
.trust-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem}
.trust-item{background:#fff;border:1px solid var(--hair);border-radius:16px;padding:1.5rem;
  display:flex;gap:.9rem;align-items:flex-start;box-shadow:var(--shadow-soft);transition:transform .2s ease,box-shadow .2s ease}
.trust-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-pop)}
.trust-item svg{color:var(--accent);flex-shrink:0;margin-top:2px}
.trust-item h4{color:var(--steel-ink);margin-bottom:.25rem;font-size:1.02rem}
.trust-item p{color:var(--ink-3);font-size:.9rem;line-height:1.55}
@media(max-width:820px){.trust-grid{grid-template-columns:1fr 1fr}}
@media(max-width:540px){.trust-grid{grid-template-columns:1fr}}

/* ---------- Testimonios premium ---------- */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem}
.testi-card{background:#fff;border:1px solid var(--hair);border-radius:20px;padding:1.8rem 1.7rem;
  box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:1rem;position:relative;
  transition:transform .2s,box-shadow .2s}
.testi-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-pop)}
.testi-card::before{content:"\201C";position:absolute;top:.6rem;right:1.2rem;
  font-family:var(--ff-display);font-size:4.5rem;line-height:1;color:var(--accent-soft)}
.testi-stars{display:flex;gap:.15rem;color:var(--accent);letter-spacing:2px}
.testi-quote{color:var(--ink-2);font-size:.97rem;line-height:1.7;position:relative;z-index:1}
.testi-author{display:flex;align-items:center;gap:.75rem;margin-top:auto;padding-top:1.1rem;border-top:1px solid var(--hair)}
.testi-avatar{width:44px;height:44px;border-radius:50%;flex-shrink:0;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;font-weight:800;font-size:1rem}
.testi-name{font-weight:700;color:var(--steel-ink);font-size:.92rem;line-height:1.2}
.testi-role{color:var(--ink-4);font-size:.8rem}
@media(max-width:820px){.testi-grid{grid-template-columns:1fr}}

/* ---------- FAQ ---------- */
.faq-block{max-width:820px;margin:0 auto}
.faq details{background:#fff;border:1px solid var(--hair);border-radius:14px;margin-bottom:.7rem;
  padding:0 1.3rem;box-shadow:var(--shadow-soft);transition:border-color .2s,box-shadow .2s}
.faq details[open]{border-color:var(--accent);box-shadow:var(--shadow-soft)}
.faq summary{cursor:pointer;list-style:none;padding:1.1rem 0;font-weight:700;color:var(--steel-ink);
  display:flex;justify-content:space-between;align-items:center;gap:1rem;font-size:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.4rem;color:var(--accent);transition:transform .2s;flex-shrink:0}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq-body{padding:0 0 1.15rem;color:var(--ink-3);line-height:1.7;font-size:.95rem}

/* ---------- CTA banner premium ---------- */
.cta-banner{position:relative;overflow:hidden;
  background:radial-gradient(620px 320px at 85% 0%, rgba(249,115,22,.24), transparent 60%),
    linear-gradient(135deg,#1a1a1d,#2a2a2e);
  color:#fff;border-radius:26px;padding:clamp(2.2rem,5vw,3.4rem);
  display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;box-shadow:var(--shadow-pop)}
.cta-banner h2{color:#fff;font-size:clamp(1.6rem,3vw,2.2rem)}
.cta-banner p{color:#d4d4d8;margin-top:.5rem;max-width:48ch}

/* ---------- FIX CRÍTICO: legibilidad del texto en los formularios ---------- */
/* styles.css no define color en los inputs (hereda 'inherit' y en el hero salía blanco sobre blanco). */
.form-card .field input,
.form-card .field select,
.form-card .field textarea,
.field input, .field select, .field textarea,
.hero .form-card input, .hero .form-card select, .hero .form-card textarea{
  color:var(--steel-ink) !important;
  -webkit-text-fill-color:var(--steel-ink) !important;
  background:#fff !important;
  caret-color:var(--accent);
  opacity:1 !important;
}
.field input::placeholder, .field textarea::placeholder{
  color:#a1a1aa !important; -webkit-text-fill-color:#a1a1aa !important; opacity:1;
}
.field select option{color:var(--steel-ink);background:#fff}
/* Autofill de Chrome: evita el texto blanco/azulado ilegible */
.field input:-webkit-autofill,
.field input:-webkit-autofill:hover,
.field input:-webkit-autofill:focus{
  -webkit-text-fill-color:var(--steel-ink) !important;
  -webkit-box-shadow:0 0 0 1000px #fff inset !important;
  caret-color:var(--steel-ink);
}
.form-card .field label{color:var(--steel-ink)}

/* ---------- Anti-desbordamiento global ---------- */
html,body{max-width:100%;overflow-x:hidden}
img,svg,video,table{max-width:100%}
.hero-h1,.section-heading{overflow-wrap:break-word}
*{min-width:0}

/* ---------- Hero responsive (los fixes estaban bajo .hero--dark; los portamos a hero--photo/light) ---------- */
@media (max-width:900px){
  .hero--photo, .hero--light{padding-top:2rem;padding-bottom:2.4rem}
  .hero--photo .hero-grid, .hero--light .hero-grid{grid-template-columns:1fr;display:grid;gap:1.5rem}
  .hero--photo .hero-grid > div, .hero--light .hero-grid > div{min-width:0;max-width:100%}
  .hero--photo .form-card, .hero--light .form-card{width:100%;max-width:100%;margin:0}
  .hero .btn-row{flex-direction:column;gap:.6rem;margin-top:1.2rem}
  .hero .btn-row .btn{width:100%;justify-content:center;white-space:normal}
  .hero .field input, .hero .field select, .hero .field textarea{font-size:16px} /* evita zoom iOS */
  .hero .field-row{grid-template-columns:1fr}
  .hero-trust{margin-top:1.1rem;gap:.45rem .9rem}
  .hero-trust span{font-size:.78rem}
}

/* ============================================================
   HEADER / NAVEGACIÓN — oscuro premium, idéntico en todas las páginas e idiomas
   ============================================================ */
.site-header{
  background:rgba(20,20,23,.78) !important;
  backdrop-filter:blur(16px) saturate(140%) !important;
  -webkit-backdrop-filter:blur(16px) saturate(140%) !important;
  border-bottom:1px solid rgba(255,255,255,.08) !important;
}
.site-header.scrolled{
  background:rgba(14,14,16,.92) !important;
  border-bottom-color:rgba(255,255,255,.1) !important;
  box-shadow:0 8px 30px rgba(0,0,0,.35) !important;
}
.site-header .header-inner{padding-top:.55rem !important;padding-bottom:.55rem !important}
.site-header .logo-name{color:#fff !important}
.site-header .logo-name em{color:var(--accent) !important}
.site-header .logo-mark{background:#0e0e10 !important;border:1px solid rgba(255,255,255,.14) !important;border-radius:9px}
/* Nav links claros con subrayado naranja */
.nav{gap:.05rem}
.nav-link{position:relative;padding:.5rem .85rem;font-size:.89rem;font-weight:500;color:#cfcfd4 !important;border-radius:9px;transition:color .18s}
.nav-link svg{opacity:.6;transition:transform .2s}
.nav-item:hover .nav-link svg{transform:rotate(180deg);opacity:1}
.nav-link::after{content:"";position:absolute;left:.85rem;right:.85rem;bottom:.28rem;height:2px;
  background:var(--accent);border-radius:2px;transform:scaleX(0);transform-origin:left;transition:transform .25s ease}
/* Hover: fondo translúcido oscuro (NO el claro de styles.css) + texto blanco visible */
.nav-link:hover, .nav-item:hover > .nav-link, .nav-link.active{
  color:#fff !important; background:rgba(255,255,255,.08) !important}
.nav-link:hover::after,.nav-item:hover .nav-link::after{transform:scaleX(1)}
/* Selector de idioma sobre header oscuro */
.lang-switch{padding:2px;gap:.1rem;background:rgba(255,255,255,.06) !important;border:1px solid rgba(255,255,255,.1) !important}
.lang-link{padding:.32rem .5rem;font-size:.68rem;min-width:28px;color:#a1a1aa !important}
.lang-link:hover{color:#fff !important}
.lang-link.active{background:var(--accent) !important;color:#fff !important;box-shadow:none !important}
.nav-cta{padding:.55rem 1.15rem !important;font-size:.86rem !important;font-weight:600 !important;
  border-radius:999px !important;box-shadow:var(--shadow-accent) !important;transition:transform .18s,box-shadow .18s !important}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(249,115,22,.4) !important}
.hamburger{width:40px;height:40px;background:rgba(255,255,255,.08) !important;border:1px solid rgba(255,255,255,.14) !important}
.hamburger span{background:#fff !important}
/* Dropdown de Servicios (escritorio): se mantiene en claro para legibilidad */

/* ============================================================
   MENÚ MÓVIL — oscuro premium, compacto (idéntico en todas las páginas)
   ============================================================ */
@media (max-width:900px){ .lang-switch{display:none !important} }
.mobile-nav{background:linear-gradient(180deg,#1d1d21 0%,#141416 100%) !important;color:#e9e9ec !important}
.mobile-nav::before{display:none !important}
.mn-bar{background:rgba(20,20,23,.82) !important;border-bottom:1px solid rgba(255,255,255,.08) !important;backdrop-filter:blur(14px) !important;padding:.75rem 1.1rem !important}
.mn-brand-name{color:#fff !important}
.mn-brand-name em{color:var(--accent) !important}
.mn-brand-mark{background:#0e0e10 !important;border-color:rgba(255,255,255,.14) !important}
.mn-close{background:rgba(255,255,255,.06) !important;border:1px solid rgba(255,255,255,.12) !important}
.mn-close:hover{background:rgba(255,255,255,.12) !important}
.mn-close span{background:#fff !important}
.mn-body{background:transparent !important}
.mn-section-tag{color:#ffb784 !important}
.mn-section-tag::before{background:var(--accent) !important}

/* Navegación: links limpios, SIN números ni descripciones */
.mn-main-num{display:none !important}
.mn-main-desc{display:none !important}
.mn-main{background:rgba(255,255,255,.045) !important;border:1px solid rgba(255,255,255,.08) !important;color:#fff !important;border-radius:12px !important}
.mn-main:active{background:rgba(249,115,22,.16) !important;border-color:rgba(249,115,22,.5) !important}
.mn-main-title{color:#fff !important;font-size:.98rem !important;font-weight:600 !important}
.mn-main-arrow{color:#71717a !important}

/* Categorías de servicio: solo el nombre */
.mn-svc-desc{display:none !important}
.mn-svc-list a{color:#cfcfd4 !important;border-left:2px solid transparent !important}
.mn-svc-list a:active{background:rgba(255,255,255,.05) !important;border-left-color:var(--accent) !important;color:#fff !important}
.mn-svc-name{color:#eaeaee !important;font-weight:600 !important}

/* Zonas */
.mn-cities a{background:rgba(255,255,255,.045) !important;border:1px solid rgba(255,255,255,.08) !important;color:#e3e3e7 !important}
.mn-cities a:active{background:rgba(249,115,22,.14) !important;border-color:var(--accent) !important;color:#fff !important}
.mn-cities-all{color:#ffb784 !important}

/* Idioma (oscuro premium, compacto) */
.mn-lang{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;margin-top:.2rem}
.mn-lang a{display:flex;flex-direction:column;align-items:center;gap:.12rem;
  padding:.62rem .35rem;border:1px solid rgba(255,255,255,.1) !important;border-radius:12px;
  background:rgba(255,255,255,.045) !important;text-decoration:none;transition:background .2s,border-color .2s}
.mn-lang a .code{font-size:.88rem;font-weight:800;color:#fff !important;letter-spacing:.05em}
.mn-lang a .name{font-size:.65rem;color:#9a9aa2 !important}
.mn-lang a.active{background:rgba(249,115,22,.16) !important;border-color:var(--accent) !important}
.mn-lang a.active .code{color:#ffb784 !important}

/* Pie legal */
.mn-foot{border-top:1px solid rgba(255,255,255,.08) !important}
.mn-foot a{color:#a1a1aa !important}
.mn-foot a:active{color:var(--accent) !important}
.mn-dot{color:#52525b !important}

/* Barra CTA inferior */
.mn-cta-bar{background:rgba(14,14,16,.9) !important;border-top:1px solid rgba(255,255,255,.08) !important;backdrop-filter:blur(14px) !important}
.mn-cta-mail{color:#a1a1aa !important}
.mn-cta-btn{background:linear-gradient(135deg,var(--accent),var(--accent-2)) !important;color:#fff !important;box-shadow:var(--shadow-accent) !important}

/* Compactación (más ajustado en móvil) */
.mn-body{padding:.9rem .95rem 0 !important}
.mn-section{margin-bottom:.85rem !important}
.mn-section-tag{margin-bottom:.6rem !important}
.mn-main{padding:.62rem .9rem !important;margin-bottom:.28rem !important}
.mn-svc-list li{margin-bottom:.06rem !important}
.mn-svc-list a{padding:.45rem 1rem !important}
.mn-cities{gap:.38rem !important;margin-bottom:.5rem !important}
.mn-cities a{padding:.5rem .8rem !important}
.mn-pad{height:.5rem !important}

/* ---------- Página de contacto (rediseño claro paso a paso) ---------- */
.ctc-grid{display:grid;grid-template-columns:1fr 1.02fr;gap:3rem;align-items:start}
.ctc-steps{display:flex;flex-direction:column;gap:1.15rem;margin:1.4rem 0 1.8rem}
.ctc-step{display:flex;gap:1rem;align-items:flex-start;position:relative}
.ctc-step:not(:last-child)::before{content:"";position:absolute;left:21px;top:46px;bottom:-1.15rem;width:2px;background:var(--hair-2)}
.ctc-num{flex-shrink:0;width:44px;height:44px;border-radius:13px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;font-weight:800;font-size:1.15rem;
  box-shadow:var(--shadow-accent);position:relative;z-index:1}
.ctc-step h3{font-size:1.06rem;color:var(--steel-ink);margin-bottom:.2rem;font-weight:700}
.ctc-step p{color:var(--ink-3);font-size:.92rem;line-height:1.55}
.ctc-data{display:grid;gap:.9rem;border-top:1px solid var(--hair);padding-top:1.6rem;margin-top:.4rem}
.ctc-data-item{display:flex;align-items:center;gap:.85rem;color:var(--ink-2);font-size:.95rem;text-decoration:none}
.ctc-data-item .ico{flex-shrink:0;width:42px;height:42px;border-radius:11px;display:grid;place-items:center;
  background:var(--accent-soft);color:var(--accent)}
.ctc-data-item .k{display:block;font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-4);font-weight:600}
.ctc-data-item .v{display:block;color:var(--steel-ink);font-weight:600;font-size:.98rem}
a.ctc-data-item:hover .v{color:var(--accent)}
.ctc-form-col{position:sticky;top:90px}
.ctc-form-col .form-card{box-shadow:var(--shadow-pop);border:1px solid var(--hair)}
.ctc-form-col .form-head{margin-bottom:1.2rem}
.ctc-badge{display:inline-flex;align-items:center;gap:.45rem;background:var(--accent-soft);color:var(--accent);
  font-weight:700;font-size:.78rem;padding:.4rem .85rem;border-radius:999px;margin-bottom:.8rem}
@media(max-width:880px){.ctc-grid{grid-template-columns:1fr;gap:2.2rem}.ctc-form-col{position:static}}

/* ---------- Helpers ---------- */
.section--editorial{background:var(--soft)}
.text-center{text-align:center}
.mx-auto{margin-left:auto;margin-right:auto}
.maxw-60{max-width:62ch}
