/* =========================================================
   Estructuras Metálicas — Estética industrial premium
   Mobile-first · Sin frameworks · Bajo peso
   ========================================================= */

:root{
  --bg:#ffffff;
  --bg-2:#f5f6f8;
  --surface:#ffffff;
  --surface-2:#f1f3f5;
  --surface-3:#e6e8ec;
  --border:rgba(15,23,42,.08);
  --border-2:rgba(15,23,42,.14);
  --ink:#0c1320;
  --ink-2:#1f2937;
  --ink-3:#475569;
  --ink-4:#94a3b8;
  --steel:#1e3a5f;
  --steel-2:#2c4f7c;
  --accent:#f97316;
  --accent-2:#ea580c;
  --accent-glow:rgba(249,115,22,.18);
  --accent-soft:rgba(249,115,22,.08);
  --max:1180px;
  --px:clamp(0.95rem,4vw,2rem);
  --r-sm:8px;
  --r-md:12px;
  --r-lg:18px;
  --r-pill:999px;
  --shadow-1:0 2px 6px rgba(15,23,42,.05),0 6px 18px rgba(15,23,42,.06);
  --shadow-2:0 10px 30px rgba(15,23,42,.10);
  --shadow-cta:0 6px 18px rgba(249,115,22,.30);
  --t:.2s ease;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink-2);background:var(--bg);
  line-height:1.65;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
button,input,textarea,select{font:inherit;color:inherit}
button{cursor:pointer;border:none;background:none}
::selection{background:var(--accent);color:#fff}

h1,h2,h3,h4{
  font-family:'Inter',sans-serif;
  color:var(--ink);
  line-height:1.18;
  letter-spacing:-.02em;
  font-weight:700;
}
h1{font-size:clamp(1.7rem,5.2vw,3.4rem);font-weight:800;letter-spacing:-.025em;overflow-wrap:break-word;hyphens:auto}
h2{font-size:clamp(1.4rem,3.6vw,2.4rem);overflow-wrap:break-word}
h3{font-size:clamp(1.05rem,2.2vw,1.45rem);overflow-wrap:break-word}
h4{font-size:1.02rem}
p{color:var(--ink-2);overflow-wrap:break-word}

.container{width:100%;max-width:var(--max);margin:0 auto;padding:0 var(--px)}
.section{padding:clamp(3.5rem,7vw,6rem) 0}
.section--tight{padding:clamp(2.5rem,5vw,4rem) 0}
.section--dark{background:var(--ink);color:#cbd5e1}
.section--dark h2,.section--dark h3{color:#fff}
.section--soft{background:var(--bg-2)}
.eyebrow{
  display:inline-flex;align-items:center;gap:.55rem;
  font-size:.74rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--accent);margin-bottom:1rem;
}
.eyebrow::before{content:"";width:22px;height:2px;background:var(--accent);border-radius:2px}
.lead{font-size:clamp(1rem,1.6vw,1.12rem);color:var(--ink-3);max-width:65ch;line-height:1.75}

/* Botones -------------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  padding:.95rem 1.6rem;border-radius:var(--r-md);
  font-weight:600;font-size:.95rem;letter-spacing:.005em;
  white-space:nowrap;transition:transform var(--t),background var(--t),box-shadow var(--t),color var(--t),border-color var(--t);
}
.btn-primary{background:var(--accent);color:#fff;box-shadow:var(--shadow-cta)}
.btn-primary:hover{background:var(--accent-2);transform:translateY(-2px);box-shadow:0 10px 28px rgba(249,115,22,.45)}
.btn-ghost{background:#fff;color:var(--ink);border:1px solid var(--border-2)}
.btn-ghost:hover{border-color:var(--ink);background:var(--surface-2)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:var(--steel);transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--accent);border:1px solid var(--accent)}
.btn-outline:hover{background:var(--accent);color:#fff}
.btn-lg{padding:1.05rem 2rem;font-size:1rem}
.btn svg{width:18px;height:18px;flex-shrink:0}
.btn-row{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.6rem}

/* Header -------------------------------------------------- */
.site-header{
  position:sticky;top:0;z-index:80;
  background:rgba(255,255,255,.92);backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;
  transition:background .25s ease, border-color .25s ease, box-shadow .25s ease;
}
.site-header.scrolled{
  background:rgba(255,255,255,.97);
  border-bottom-color:var(--border);
  box-shadow:0 1px 0 rgba(0,0,0,.02);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:.75rem var(--px);max-width:var(--max);margin:0 auto;
}
/* ============== LOGO MINIMAL (Metaly) ==============
   Marca cuadrada antracita con monograma M geométrico naranja.
   Wordmark de una línea con "y" cursiva en degradado.
   No gradientes pesados, no animaciones, no micro-texto.
   ===================================================== */
.logo{
  display:inline-flex;align-items:center;gap:.7rem;
  color:var(--ink);text-decoration:none;
}
.logo:focus-visible{outline:2px solid var(--accent);outline-offset:4px;border-radius:6px}

.logo-mark{
  width:38px;height:38px;border-radius:9px;
  background:var(--ink);
  display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:transform .25s ease, background .25s ease;
}
.logo-mark svg{width:22px;height:22px;display:block}
.logo:hover .logo-mark{transform:rotate(-3deg)}

.logo-name{
  font-family:'Inter',sans-serif;
  font-size:1.45rem;font-weight:800;letter-spacing:-.03em;line-height:1;
  color:var(--ink);
}
.logo-name em{
  font-style:italic;font-weight:800;
  color:var(--accent);
  margin-left:1px;
}

/* Footer (fondo oscuro) */
.site-footer .logo{color:#fff}
.site-footer .logo-name{color:#fff}
.site-footer .logo-mark{background:#fff}
.site-footer .logo-mark svg path{stroke:var(--ink)}

@media (max-width: 520px){
  .logo-name{font-size:1.25rem}
  .logo-mark{width:34px;height:34px}
  .logo-mark svg{width:20px;height:20px}
}
.nav{display:flex;align-items:center;gap:.25rem}
.nav-item{position:relative}
.nav-link{
  display:inline-flex;align-items:center;gap:.3rem;
  padding:.55rem .95rem;border-radius:var(--r-pill);
  font-size:.9rem;font-weight:500;color:var(--ink-3);
  transition:color var(--t),background var(--t);
}
.nav-link:hover,.nav-link.active{color:var(--ink);background:var(--surface-2)}
.nav-link svg{width:11px;height:11px;opacity:.6;transition:transform .2s}
.nav-item:hover .nav-link svg{transform:rotate(180deg);opacity:1}
.nav-dropdown{
  position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(-6px);
  background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);
  padding:.5rem;min-width:520px;box-shadow:var(--shadow-2);
  display:grid;grid-template-columns:1fr 1fr;gap:.15rem;
  opacity:0;visibility:hidden;transition:all .2s;z-index:90;
}
.nav-item:hover .nav-dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.nav-dd-item{display:flex;gap:.7rem;padding:.65rem .8rem;border-radius:var(--r-sm);transition:background var(--t)}
.nav-dd-item:hover{background:var(--surface-2)}
.nav-dd-icon{
  width:34px;height:34px;border-radius:var(--r-sm);flex-shrink:0;
  background:var(--accent-soft);color:var(--accent);
  display:inline-flex;align-items:center;justify-content:center;transition:all var(--t);
}
.nav-dd-item:hover .nav-dd-icon{background:var(--accent);color:#fff}
.nav-dd-icon svg{width:18px;height:18px}
.nav-dd-title{font-size:.86rem;font-weight:600;color:var(--ink);line-height:1.2;margin-bottom:.1rem}
.nav-dd-desc{font-size:.74rem;color:var(--ink-3);line-height:1.4}
.nav-cta{
  background:var(--accent);color:#fff;padding:.55rem 1.1rem;border-radius:var(--r-pill);
  font-weight:600;font-size:.86rem;box-shadow:var(--shadow-cta);
  display:inline-flex;align-items:center;gap:.35rem;transition:all var(--t);
}
.nav-cta:hover{background:var(--accent-2);transform:translateY(-1px)}
.hamburger{
  display:none;width:42px;height:42px;border-radius:var(--r-sm);
  background:var(--surface-2);align-items:center;justify-content:center;flex-direction:column;gap:5px;
}
.hamburger span{display:block;width:20px;height:2px;background:var(--ink);border-radius:2px;transition:all var(--t)}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* =========================================================
   MOBILE NAV PREMIUM v2 — full-screen, agrupado, útil
   ========================================================= */
.mobile-nav{
  position:fixed;inset:0;z-index:90;
  background:
    radial-gradient(800px 500px at 80% 10%, rgba(249,115,22,.18), transparent 65%),
    radial-gradient(700px 400px at 0% 90%, rgba(30,58,95,.45), transparent 70%),
    linear-gradient(180deg,#0c1320 0%,#06091a 100%);
  color:#fff;
  display:none;flex-direction:column;
  overflow:hidden;
  /* viewport real en iOS */
  height:100dvh;
}
.mobile-nav.open{display:flex;animation:mn-fade .35s ease}
@keyframes mn-fade{from{opacity:0}to{opacity:1}}

/* fondo grid sutil */
.mobile-nav::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:32px 32px;pointer-events:none;
}

/* === Barra superior con marca + cerrar === */
.mn-bar{
  position:relative;z-index:1;
  display:flex;align-items:center;justify-content:space-between;
  padding:.9rem 1.1rem;
  border-bottom:1px solid rgba(255,255,255,.08);
  background:rgba(12,19,32,.5);backdrop-filter:blur(12px);
}
.mn-brand{display:inline-flex;align-items:center;gap:.6rem;text-decoration:none}
.mn-brand-mark{
  width:34px;height:34px;border-radius:8px;background:#0c1320;
  position:relative;flex-shrink:0;
  border:1px solid rgba(255,255,255,.12);
}
.mn-brand-mark::after{
  content:"";position:absolute;inset:6px;
  background:linear-gradient(135deg,transparent 35%,#f97316 35% 65%,transparent 65%);
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M5 19 L5 6 L12 14 L19 6 L19 19' fill='none' stroke='black' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'/></svg>") center/contain no-repeat;
          mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M5 19 L5 6 L12 14 L19 6 L19 19' fill='none' stroke='black' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'/></svg>") center/contain no-repeat;
}
.mn-brand-name{
  font-family:'Inter',sans-serif;
  font-size:1.15rem;font-weight:800;letter-spacing:-.025em;color:#fff;
}
.mn-brand-name em{font-style:italic;font-weight:800;color:#f97316;margin-left:1px}
.mn-close{
  width:42px;height:42px;border-radius:10px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  display:inline-flex;flex-direction:column;align-items:center;justify-content:center;
  position:relative;cursor:pointer;transition:background .2s, border-color .2s;
}
.mn-close:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.2)}
.mn-close span{
  position:absolute;width:18px;height:2px;background:#fff;border-radius:1px;
}
.mn-close span:nth-child(1){transform:rotate(45deg)}
.mn-close span:nth-child(2){transform:rotate(-45deg)}

/* === Cuerpo scrollable === */
.mn-body{
  position:relative;z-index:1;
  flex:1 1 auto;min-height:0;
  overflow-y:auto;-webkit-overflow-scrolling:touch;
  padding:1.4rem 1.1rem 0;
  scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.15) transparent;
}
.mn-body::-webkit-scrollbar{width:6px}
.mn-body::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:3px}

.mn-section{margin-bottom:1.6rem;animation:mn-up .4s ease both}
.mn-section:nth-child(2){animation-delay:.05s}
.mn-section:nth-child(3){animation-delay:.1s}
.mn-section:nth-child(4){animation-delay:.15s}
@keyframes mn-up{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

.mn-section-tag{
  display:inline-flex;align-items:center;gap:.45rem;
  font-size:.66rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:#ffba80;margin:0 0 .9rem .25rem;
}
.mn-section-tag::before{content:"";width:18px;height:1.5px;background:#f97316;border-radius:1px}

/* === Items principales === */
.mn-main{
  display:flex;align-items:center;gap:.9rem;
  padding:.95rem 1rem;
  border-radius:14px;text-decoration:none;color:#fff;
  border:1px solid rgba(255,255,255,.07);background:rgba(255,255,255,.02);
  margin-bottom:.45rem;
  transition:background .2s, border-color .2s, transform .2s;
}
.mn-main:active{background:rgba(249,115,22,.14);border-color:rgba(249,115,22,.45);transform:scale(.99)}
.mn-main-num{
  flex-shrink:0;width:34px;height:34px;border-radius:9px;
  display:inline-flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);
  font-size:.72rem;font-weight:800;color:#94a3b8;letter-spacing:.02em;
}
.mn-main-text{flex:1;min-width:0;display:flex;flex-direction:column;gap:.1rem}
.mn-main-title{font-size:1.02rem;font-weight:700;color:#fff;letter-spacing:-.01em;line-height:1.2}
.mn-main-desc{font-size:.78rem;color:#94a3b8;line-height:1.35}
.mn-main-arrow{
  flex-shrink:0;font-size:1.05rem;color:#475569;
  transition:color .2s, transform .2s;
}
.mn-main:active .mn-main-arrow{color:#f97316;transform:translateX(2px)}

/* === Lista de servicios === */
.mn-svc-list{list-style:none;padding:0;margin:0}
.mn-svc-list li{margin-bottom:.3rem}
.mn-svc-list a{
  display:flex;flex-direction:column;gap:.1rem;
  padding:.75rem 1rem;
  border-radius:10px;text-decoration:none;color:#cbd5e1;
  border-left:2px solid transparent;
  transition:all .2s;
}
.mn-svc-list a:active{background:rgba(255,255,255,.05);border-left-color:#f97316;color:#fff}
.mn-svc-name{font-size:.95rem;font-weight:600;color:#fff;letter-spacing:-.005em}
.mn-svc-desc{font-size:.74rem;color:#64748b;line-height:1.35}

/* === Ciudades === */
.mn-cities{
  display:grid;grid-template-columns:repeat(2,1fr);gap:.45rem;
  margin-bottom:.9rem;
}
.mn-cities a{
  padding:.7rem .9rem;
  border:1px solid rgba(255,255,255,.08);border-radius:10px;
  background:rgba(255,255,255,.02);
  font-size:.86rem;font-weight:500;color:#e2e8f0;text-decoration:none;
  text-align:left;
  transition:all .2s;
}
.mn-cities a:active{background:rgba(249,115,22,.12);border-color:rgba(249,115,22,.35);color:#fff}
.mn-cities-all{
  display:inline-flex;align-items:center;gap:.4rem;
  padding:.55rem 0 0 .25rem;
  font-size:.82rem;font-weight:600;color:#f97316;text-decoration:none;
  transition:gap .2s;
}
.mn-cities-all:active{gap:.6rem}

/* === Footer legal === */
.mn-foot{
  display:flex;flex-wrap:wrap;align-items:center;gap:.4rem .55rem;
  padding:.7rem .25rem;
  border-top:1px solid rgba(255,255,255,.06);
  margin-top:1rem;
}
.mn-foot a{
  font-size:.78rem;color:#94a3b8;text-decoration:none;
  padding:.25rem 0;
  transition:color .2s;
}
.mn-foot a:active{color:#f97316}
.mn-dot{color:#475569;font-size:.7rem}

.mn-pad{height:1.2rem}

/* === CTA fija abajo === */
.mn-cta-bar{
  position:relative;z-index:1;
  border-top:1px solid rgba(255,255,255,.08);
  background:rgba(6,9,21,.85);backdrop-filter:blur(12px);
  padding:.9rem 1.1rem calc(.9rem + env(safe-area-inset-bottom));
  display:flex;align-items:center;gap:.7rem;
}
.mn-cta-mail{
  flex:1;min-width:0;
  font-size:.78rem;color:#94a3b8;text-decoration:none;
  font-weight:500;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.mn-cta-mail:active{color:#fff}
.mn-cta-btn{
  display:inline-flex;align-items:center;gap:.45rem;
  padding:.85rem 1.3rem;border-radius:999px;
  background:linear-gradient(135deg,#f97316,#ea580c);
  color:#fff;font-weight:700;font-size:.92rem;letter-spacing:-.005em;
  text-decoration:none;flex-shrink:0;
  box-shadow:0 8px 20px rgba(249,115,22,.4);
}
.mn-cta-btn:active{transform:translateY(1px)}

/* Bloquear scroll del body cuando menú abierto */
body.mn-locked{overflow:hidden;height:100vh;height:100dvh}

/* Hero ---------------------------------------------------- */
.hero{
  position:relative;padding:clamp(3rem,7vw,5.5rem) 0 clamp(3rem,6vw,5rem);
  background:
    radial-gradient(1200px 500px at 90% -10%,var(--accent-soft),transparent 60%),
    radial-gradient(900px 500px at 5% 20%,rgba(30,58,95,.06),transparent 60%),
    linear-gradient(180deg,#ffffff 0%,#f8fafc 100%);
  overflow:hidden;
}
.hero--dark{
  background:
    radial-gradient(900px 500px at 80% -10%,rgba(249,115,22,.20),transparent 60%),
    radial-gradient(700px 400px at 10% 20%,rgba(30,58,95,.4),transparent 60%),
    linear-gradient(180deg,#0c1320 0%,#0a1326 100%);
  color:#fff;
}
.hero--dark::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:32px 32px;
  pointer-events:none;
}
.hero--dark .container{position:relative;z-index:1}
.hero--dark h1,.hero--dark .hero-h1{color:#fff}
.hero--dark .hero-h1 em,.hero--dark h1 em{color:var(--accent-2)}
.hero--dark .hero-sub,.hero--dark .lead{color:#cbd5e1}
.hero--dark .eyebrow{color:#ffba80}
.hero--dark .hero-trust{color:#cbd5e1}
.hero--dark .btn-ghost{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.2);backdrop-filter:blur(6px)}
.hero--dark .btn-ghost:hover{background:rgba(255,255,255,.18);border-color:#fff}
.hero-grid{
  display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:center;
}
.hero-h1{margin-bottom:1.1rem}
.hero-h1 em{color:var(--accent);font-style:normal}
.hero-sub{font-size:clamp(1rem,1.6vw,1.12rem);color:var(--ink-3);max-width:60ch;margin-bottom:1.6rem;line-height:1.75}
.hero-trust{
  display:flex;flex-wrap:wrap;gap:.4rem 1.2rem;margin-top:1.8rem;
  font-size:.82rem;color:var(--ink-3);
}
.hero-trust span{display:inline-flex;align-items:center;gap:.4rem}
.hero-trust svg{width:16px;height:16px;color:var(--accent)}

/* Form card ----------------------------------------------- */
.form-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);
  padding:1.5rem;box-shadow:var(--shadow-2);
}
.form-card h3{font-size:1.2rem;margin-bottom:.35rem}
.form-card p{font-size:.86rem;color:var(--ink-3);margin-bottom:1rem}
.field{margin-bottom:.85rem}
.field label{display:block;font-size:.78rem;font-weight:600;color:var(--ink);margin-bottom:.35rem}
.field input,.field select,.field textarea{
  width:100%;padding:.78rem .9rem;border:1px solid var(--border-2);border-radius:var(--r-sm);
  background:#fff;font-size:.92rem;transition:border-color var(--t),box-shadow var(--t);
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);
}
.field textarea{resize:vertical;min-height:88px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
.checkbox{display:flex;gap:.55rem;align-items:flex-start;font-size:.74rem;color:var(--ink-3);line-height:1.5;margin:.7rem 0}
.checkbox input{margin-top:.2rem;flex-shrink:0;accent-color:var(--accent)}
.form-card .btn{width:100%;justify-content:center}
.form-error{
  background:#fef2f2;border:1px solid #fecaca;color:#991b1b;
  padding:.6rem .8rem;border-radius:var(--r-sm);font-size:.82rem;margin-bottom:.7rem;
}
input:invalid:not(:placeholder-shown),select:invalid:not(:focus),textarea:invalid:not(:placeholder-shown){
  border-color:#fca5a5;
}

/* Service cards ------------------------------------------- */
.service-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.1rem}
.service-card{
  display:flex;flex-direction:column;gap:.7rem;
  padding:1.5rem;background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);
  transition:transform var(--t),box-shadow var(--t),border-color var(--t);
  position:relative;overflow:hidden;
}
.service-card::after{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  transform:scaleX(0);transform-origin:left;transition:transform .35s ease;
}
.service-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-1);border-color:var(--border-2)}
.service-card:hover::after{transform:scaleX(1)}
.service-icon{
  width:54px;height:54px;border-radius:14px;
  background:linear-gradient(135deg,var(--accent-soft) 0%,rgba(249,115,22,.04) 100%);
  color:var(--accent);
  display:inline-flex;align-items:center;justify-content:center;
  position:relative;transition:all .3s ease;
}
.service-icon svg{width:28px;height:28px;position:relative;z-index:1}
.service-icon::before{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  opacity:0;transition:opacity .3s;
}
.service-card:hover .service-icon{transform:rotate(-4deg)}
.service-card:hover .service-icon::before{opacity:1}
.service-card:hover .service-icon{color:#fff}
.service-card h3{font-size:1.08rem;letter-spacing:-.01em}
.service-card p{font-size:.9rem;color:var(--ink-3)}
.service-card a.more{
  margin-top:auto;font-size:.85rem;font-weight:600;color:var(--accent);
  display:inline-flex;align-items:center;gap:.3rem;transition:gap var(--t);
}
.service-card a.more:hover{gap:.55rem}

/* ====== CONTACTO premium v4 — solo CSS, sin iconos (ct-) ====== */
.ct-hero{
  padding:clamp(4rem,9vw,7rem) 0 clamp(2.5rem,5vw,4rem);
  background:#fafbfc;
  position:relative;border-bottom:1px solid var(--border);
}
.ct-hero-tag{
  font-size:.78rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent);margin-bottom:1.4rem;
}
.ct-hero-h1{
  font-size:clamp(2.2rem,6vw,4.4rem);
  font-weight:800;letter-spacing:-.035em;line-height:1.04;
  color:var(--ink);max-width:18ch;margin-bottom:1.6rem;
}
.ct-hero-h1 .ct-hl{
  position:relative;display:inline-block;font-style:italic;font-weight:800;
  color:var(--accent);
}
.ct-hero-h1 .ct-hl::after{
  content:"";position:absolute;left:0;right:0;bottom:.05em;height:.18em;
  background:rgba(249,115,22,.18);z-index:-1;border-radius:2px;
}
.ct-hero-h1 strong{font-weight:800;color:var(--ink)}
.ct-hero-sub{
  font-size:clamp(1rem,1.5vw,1.18rem);color:var(--ink-3);
  max-width:62ch;line-height:1.7;margin-bottom:2.2rem;
}
.ct-hero-quick{display:flex;gap:1.4rem;align-items:center;flex-wrap:wrap}
.ct-hero-cta{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:1.05rem 2rem;border-radius:999px;
  background:var(--ink);color:#fff;
  font-weight:600;font-size:.98rem;letter-spacing:-.005em;
  transition:all .25s ease;
  box-shadow:0 8px 22px rgba(15,23,42,.18);
}
.ct-hero-cta:hover{background:var(--accent);transform:translateY(-2px);box-shadow:0 12px 28px rgba(249,115,22,.32)}
.ct-hero-link{display:inline-flex;flex-direction:column;line-height:1.2}
.ct-hero-link-label{font-size:.78rem;color:var(--ink-3);font-weight:500;letter-spacing:-.005em}
.ct-hero-link-mail{
  font-size:1.05rem;font-weight:600;color:var(--ink);
  border-bottom:1px solid var(--ink);padding-bottom:1px;
  transition:color .2s, border-color .2s;
}
.ct-hero-link:hover .ct-hero-link-mail{color:var(--accent);border-color:var(--accent)}

/* FORMULARIO + SIDEBAR */
.ct-form-section{
  padding:clamp(3.5rem,7vw,5.5rem) 0;
  background:linear-gradient(180deg,#fafbfc 0%,#fff 100%);
}
.ct-form-wrap{
  display:grid;grid-template-columns:1fr 1.2fr;gap:clamp(2rem,4vw,4rem);
  align-items:start;
}
.ct-form-side{position:sticky;top:80px}
.ct-side-tag{
  display:inline-block;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  font-weight:700;color:var(--accent);
  padding:.4rem .85rem;border:1px solid var(--accent);border-radius:999px;
  margin-bottom:1.2rem;
}
.ct-side-title{
  font-size:clamp(1.6rem,3vw,2.2rem);font-weight:800;letter-spacing:-.025em;line-height:1.1;
  color:var(--ink);margin-bottom:1rem;
}
.ct-side-text{font-size:1rem;color:var(--ink-3);line-height:1.7;margin-bottom:2rem;max-width:42ch}

.ct-side-list{
  border-top:1px solid var(--border);padding-top:1.6rem;margin-bottom:2rem;
}
.ct-side-list h3{
  font-size:.7rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-3);margin-bottom:.9rem;
}
.ct-side-list ul{padding:0;margin:0;list-style:none}
.ct-side-list li{
  padding:.55rem 0;font-size:.92rem;color:var(--ink-2);
  border-bottom:1px dashed rgba(15,23,42,.08);
  display:flex;gap:.6rem;align-items:baseline;
}
.ct-side-list li::before{
  content:"+";color:var(--accent);font-weight:700;font-size:.95rem;width:14px;flex-shrink:0;
}
.ct-side-list li b{color:var(--ink);font-weight:700;margin-right:.15em}
.ct-side-list li:last-child{border-bottom:none}

.ct-side-promise{
  background:var(--ink);color:#fff;border-radius:14px;
  padding:1.4rem 1.5rem;
  box-shadow:0 12px 32px rgba(15,23,42,.18);
  position:relative;overflow:hidden;
}
.ct-side-promise::before{
  content:"";position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
}
.ct-side-promise-row{
  display:flex;justify-content:space-between;align-items:baseline;gap:1rem;
  padding:.55rem 0;border-bottom:1px solid rgba(255,255,255,.08);
  font-size:.88rem;
}
.ct-side-promise-row:last-child{border-bottom:none}
.ct-side-promise-key{color:#94a3b8;letter-spacing:.01em}
.ct-side-promise-val{color:#fff;font-weight:600;text-align:right}

/* Form card */
.ct-form-card{
  background:#fff;border:1px solid var(--border);border-radius:20px;
  padding:clamp(1.6rem,3vw,2.6rem);
  box-shadow:0 1px 0 rgba(255,255,255,.6) inset, 0 30px 60px rgba(15,23,42,.08), 0 8px 18px rgba(15,23,42,.04);
  position:relative;
}
.ct-form-card::before{
  content:"";position:absolute;top:0;left:0;width:60px;height:3px;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  border-radius:0 0 3px 0;
}
.ct-form-card .form-card{background:transparent;border:0;padding:0;box-shadow:none}
.ct-form-card .form-card h3{
  font-size:1.35rem;font-weight:800;color:var(--ink);margin-bottom:.4rem;
  letter-spacing:-.015em;
}
.ct-form-card .form-card > p{font-size:.9rem;color:var(--ink-3);margin-bottom:1.4rem}

/* CHANNELS — solo tipografía + bordes */
.ct-channels-section{padding:clamp(2rem,4vw,3.5rem) 0;background:#fff;border-top:1px solid var(--border)}
.ct-channels{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border:1px solid var(--border);border-radius:18px;overflow:hidden;
  background:#fff;
}
.ct-channel{
  display:flex;flex-direction:column;gap:.45rem;padding:1.6rem 1.7rem;
  text-decoration:none;color:var(--ink);
  border-right:1px solid var(--border);
  position:relative;transition:background .2s ease;
}
.ct-channel:last-child{border-right:none}
.ct-channel:hover{background:var(--surface-2)}
a.ct-channel:hover{cursor:pointer}
a.ct-channel:hover .ct-channel-val{color:var(--accent)}
.ct-channel-key{
  font-size:.7rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--accent);
}
.ct-channel-val{
  font-size:1.1rem;font-weight:700;color:var(--ink);letter-spacing:-.01em;
  word-break:break-word;line-height:1.3;
  transition:color .2s;
}
.ct-channel-note{font-size:.82rem;color:var(--ink-3);line-height:1.5}

/* PROCESS / TIMELINE */
.ct-process-section{padding:clamp(3.5rem,6vw,5.5rem) 0;background:var(--bg-2)}
.ct-section-head{text-align:center;margin-bottom:3rem;max-width:620px;margin-left:auto;margin-right:auto}
.ct-section-tag{
  display:inline-block;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  font-weight:700;color:var(--accent);margin-bottom:.9rem;
}
.ct-section-head h2{
  font-size:clamp(1.8rem,3.4vw,2.6rem);font-weight:800;letter-spacing:-.025em;
  color:var(--ink);margin-bottom:.7rem;
}
.ct-section-head p{font-size:1rem;color:var(--ink-3)}

.ct-timeline{
  display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;
  max-width:980px;margin:0 auto;
}
.ct-tl-step{
  background:#fff;border:1px solid var(--border);border-radius:14px;
  padding:1.6rem 1.7rem;position:relative;overflow:hidden;
  transition:transform .25s, box-shadow .25s, border-color .25s;
  display:flex;gap:1.2rem;align-items:flex-start;
}
.ct-tl-step:hover{transform:translateY(-3px);box-shadow:0 14px 30px rgba(15,23,42,.08);border-color:var(--accent)}
.ct-tl-step::after{
  content:"";position:absolute;top:0;left:0;width:0;height:2px;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  transition:width .35s ease;
}
.ct-tl-step:hover::after{width:100%}
.ct-tl-num{
  font-size:2rem;font-weight:900;letter-spacing:-.04em;line-height:1;
  background:linear-gradient(180deg,var(--accent) 0%,var(--accent-2) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-fill-color:transparent;
  flex-shrink:0;width:46px;
}
.ct-tl-step h3{font-size:1.05rem;font-weight:700;color:var(--ink);margin-bottom:.4rem;letter-spacing:-.01em}
.ct-tl-step p{font-size:.9rem;color:var(--ink-3);line-height:1.6;margin:0 0 .6rem}
.ct-tl-meta{
  font-size:.7rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--accent);
}

/* FAQ */
.ct-faq-section{padding:clamp(3rem,5vw,4.5rem) 0;background:#fff}
.ct-faq-wrap{max-width:820px}

/* CTA FINAL */
.ct-final{
  background:var(--ink);color:#fff;border-radius:24px;
  padding:clamp(2.4rem,5vw,4rem) clamp(1.8rem,4vw,3.2rem);
  display:grid;grid-template-columns:1.4fr auto;gap:2rem;align-items:center;
  position:relative;overflow:hidden;
}
.ct-final::before{
  content:"";position:absolute;right:-100px;top:-100px;width:340px;height:340px;border-radius:50%;
  background:radial-gradient(circle,rgba(249,115,22,.32),transparent 70%);
}
.ct-final-tag{
  display:inline-block;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;
  font-weight:700;color:#ffba80;margin-bottom:.9rem;
}
.ct-final h2{color:#fff;font-size:clamp(1.6rem,3vw,2.2rem);margin-bottom:.5rem;letter-spacing:-.02em}
.ct-final p{color:#cbd5e1;font-size:1rem;max-width:50ch}
.ct-final-btn{
  display:inline-flex;align-items:center;gap:.7rem;
  padding:1.1rem 1.8rem;border-radius:999px;
  background:var(--accent);color:#fff;font-weight:700;font-size:1.02rem;
  letter-spacing:-.005em;
  transition:all .25s;
  box-shadow:0 12px 32px rgba(249,115,22,.4);
}
.ct-final-btn:hover{background:var(--accent-2);transform:translateY(-2px)}
.ct-final-btn span{font-size:1.2rem;line-height:1}

/* RESPONSIVE */
@media (max-width:900px){
  .ct-hero{padding:3rem 0 2rem}
  .ct-hero-h1{font-size:clamp(1.9rem,7vw,2.6rem);max-width:none}
  .ct-hero-sub{font-size:.98rem}
  .ct-hero-quick{flex-direction:column;align-items:flex-start;gap:1.2rem;width:100%}
  .ct-hero-cta{width:100%;justify-content:center}

  .ct-form-wrap{grid-template-columns:1fr;gap:2rem}
  .ct-form-side{position:static}

  .ct-channels{grid-template-columns:1fr}
  .ct-channel{border-right:none;border-bottom:1px solid var(--border)}
  .ct-channel:last-child{border-bottom:none}

  .ct-timeline{grid-template-columns:1fr;gap:.8rem}
  .ct-tl-step{padding:1.3rem 1.4rem;gap:1rem}
  .ct-tl-num{font-size:1.6rem;width:38px}

  .ct-final{grid-template-columns:1fr;text-align:center;padding:2rem 1.4rem;border-radius:16px}
  .ct-final-btn{justify-self:center;width:100%;justify-content:center;font-size:.95rem}
  .ct-final p{margin-left:auto;margin-right:auto}
}
@media (max-width:480px){
  .ct-form-card{padding:1.3rem 1.1rem}
  .ct-side-promise{padding:1.1rem 1.2rem}
  .ct-side-promise-row{font-size:.82rem}
  .ct-channel-val{font-size:.98rem}
  .ct-tl-step{padding:1.1rem 1.2rem;gap:.85rem;flex-direction:column}
  .ct-tl-num{width:auto}
}

/* ====== CONTACTO premium v3 (cx-) — legacy ====== */
/* HERO SPLIT */
.cx-hero{
  position:relative;overflow:hidden;
  background:
    radial-gradient(800px 400px at 90% -10%,rgba(249,115,22,.18),transparent 60%),
    radial-gradient(700px 500px at 5% 20%,rgba(30,58,95,.45),transparent 65%),
    linear-gradient(180deg,#0c1320 0%,#0a1326 100%);
  color:#fff;
  padding:clamp(3.5rem,7vw,6rem) 0 clamp(3rem,6vw,5rem);
}
.cx-hero::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:36px 36px;pointer-events:none;
}
.cx-hero-grid{
  display:grid;grid-template-columns:1.4fr 1fr;gap:3rem;align-items:center;
  position:relative;z-index:1;
}
.cx-hero-text .eyebrow{color:#ffba80}
.cx-hero-text h1{
  font-size:clamp(2rem,5vw,3.4rem);color:#fff;margin-bottom:1.2rem;
  letter-spacing:-.025em;line-height:1.1;
}
.cx-hero-text h1 em{
  font-style:italic;
  background:linear-gradient(135deg,#ffba80,#f97316 60%,#c2410c);
  -webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-fill-color:transparent;
}
.cx-hero-sub{font-size:clamp(1rem,1.5vw,1.1rem);color:#cbd5e1;line-height:1.7;max-width:55ch;margin-bottom:2rem}
.cx-metrics{display:flex;gap:2.4rem;flex-wrap:wrap;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.08)}
.cx-metrics > div{display:flex;flex-direction:column;gap:.2rem}
.cx-metric-num{
  font-size:1.7rem;font-weight:800;color:#fff;letter-spacing:-.02em;line-height:1;
  background:linear-gradient(180deg,#fff,#cbd5e1);
  -webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-fill-color:transparent;
}
.cx-metric-label{font-size:.75rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.12em;font-weight:600}

/* HERO ASIDE: tarjeta decorativa */
.cx-hero-aside{display:flex;justify-content:center;align-items:center}
.cx-card-deco{
  position:relative;width:100%;max-width:340px;aspect-ratio:1/1;
  background:linear-gradient(135deg,rgba(255,255,255,.06),rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.1);border-radius:24px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.4rem;
  padding:2rem;backdrop-filter:blur(8px);
  box-shadow:0 30px 60px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.1);
}
.cx-deco-grid{
  position:absolute;inset:0;border-radius:inherit;opacity:.4;pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:24px 24px;
}
.cx-deco-svg{position:relative;z-index:1}
.cx-deco-tag{
  position:relative;z-index:1;
  font-size:.7rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:#ffba80;
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.4rem .8rem;border:1px solid rgba(249,115,22,.3);border-radius:999px;
  background:rgba(249,115,22,.08);
}

/* CHANNELS */
.cx-channels-section{margin-top:-2rem;position:relative;z-index:5}
.cx-channels{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;
}
.cx-channel{
  display:flex;align-items:center;gap:1.1rem;
  padding:1.5rem 1.6rem;
  background:#fff;border:1px solid var(--border);border-radius:18px;
  text-decoration:none;color:var(--ink);
  box-shadow:0 4px 12px rgba(15,23,42,.06),0 18px 40px rgba(15,23,42,.06);
  transition:transform .3s cubic-bezier(.2,.9,.25,1.05), box-shadow .3s, border-color .3s;
  position:relative;overflow:hidden;
}
.cx-channel::after{
  content:"";position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(180deg,var(--accent),var(--accent-2));
  transform:scaleY(0);transform-origin:top;transition:transform .35s ease;
}
.cx-channel:hover{transform:translateY(-4px);box-shadow:0 6px 16px rgba(15,23,42,.08),0 28px 60px rgba(15,23,42,.12);border-color:var(--border-2)}
.cx-channel:hover::after{transform:scaleY(1)}
.cx-channel-icon{
  width:54px;height:54px;border-radius:14px;flex-shrink:0;
  background:linear-gradient(135deg,var(--ink),var(--steel));
  color:var(--accent);
  display:inline-flex;align-items:center;justify-content:center;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08), 0 6px 14px rgba(15,23,42,.18);
  position:relative;
}
.cx-channel-icon::after{content:"";position:absolute;inset:0;border-radius:inherit;background:linear-gradient(135deg,rgba(249,115,22,.22),transparent 60%)}
.cx-channel-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:.18rem}
.cx-channel-eyebrow{
  font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.16em;
  color:var(--ink-3);
}
.cx-channel-title{font-size:1.05rem;font-weight:700;color:var(--ink);letter-spacing:-.01em;word-break:break-word}
.cx-channel-meta{font-size:.82rem;color:var(--ink-3);line-height:1.4}
.cx-channel-arrow{
  width:36px;height:36px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;
  background:var(--surface-2);color:var(--ink-3);
  transition:all .3s;
}
.cx-channel:hover .cx-channel-arrow{background:var(--accent);color:#fff;transform:translateX(3px)}
.cx-channel--accent{
  background:linear-gradient(135deg,var(--ink) 0%,var(--steel) 100%);
  color:#fff;border-color:transparent;
}
.cx-channel--accent .cx-channel-eyebrow{color:#ffba80}
.cx-channel--accent .cx-channel-title{color:#fff}
.cx-channel--accent .cx-channel-meta{color:#cbd5e1}
.cx-channel--accent .cx-channel-icon{background:rgba(249,115,22,.15);color:var(--accent)}
.cx-channel--accent .cx-channel-arrow{background:rgba(255,255,255,.12);color:#fff}
.cx-channel--accent:hover .cx-channel-arrow{background:var(--accent)}

/* FORMULARIO PREMIUM */
.cx-form-section{background:linear-gradient(180deg,#fff 0%,var(--bg-2) 100%)}
.cx-form-wrap{max-width:760px;margin:0 auto}
.cx-form-head{text-align:center;margin-bottom:2.4rem}
.cx-form-head h2{font-size:clamp(1.8rem,3.2vw,2.4rem);margin-bottom:.6rem;letter-spacing:-.02em}
.cx-form-head p{color:var(--ink-3);max-width:55ch;margin:0 auto;font-size:.96rem}
.cx-dot{display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--accent);margin:0 .3rem;vertical-align:middle}
.cx-form-card{
  background:#fff;border:1px solid var(--border);border-radius:22px;
  padding:2.5rem;
  box-shadow:0 1px 0 rgba(255,255,255,.6) inset, 0 30px 60px rgba(15,23,42,.08), 0 8px 16px rgba(15,23,42,.05);
  position:relative;
}
.cx-form-card::before{
  content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:60%;height:1px;
  background:linear-gradient(90deg,transparent,var(--accent),transparent);
  opacity:.7;
}
.cx-form-card .form-card{
  background:transparent;border:0;padding:0;box-shadow:none;
}
.cx-form-card .form-card h3{display:none}
.cx-form-card .form-card > p{display:none}

/* TIMELINE PROCESO */
.cx-section-head{text-align:center;margin-bottom:3rem}
.cx-section-head h2{font-size:clamp(1.8rem,3.2vw,2.4rem);margin-bottom:.6rem;letter-spacing:-.02em}
.cx-section-head .lead{margin:0 auto;max-width:55ch;font-size:.96rem}

.cx-timeline{
  list-style:none;padding:0;margin:0 auto;max-width:780px;
  position:relative;
}
.cx-timeline::before{
  content:"";position:absolute;left:38px;top:18px;bottom:18px;width:2px;
  background:linear-gradient(180deg,var(--accent) 0%,var(--accent-2) 100%);
  opacity:.18;
}
.cx-timeline li{
  display:grid;grid-template-columns:80px 1fr;gap:1.4rem;
  padding:1rem 0 1.6rem;position:relative;
}
.cx-timeline li:last-child{padding-bottom:0}
.cx-tl-num{
  width:76px;height:76px;border-radius:50%;
  background:linear-gradient(135deg,var(--accent) 0%,var(--accent-2) 100%);
  color:#fff;font-size:1.4rem;font-weight:800;letter-spacing:-.02em;
  display:inline-flex;align-items:center;justify-content:center;
  box-shadow:0 10px 24px rgba(249,115,22,.32),inset 0 1px 0 rgba(255,255,255,.25);
  flex-shrink:0;position:relative;z-index:1;
}
.cx-tl-content{
  background:#fff;border:1px solid var(--border);border-radius:16px;
  padding:1.4rem 1.6rem;
  box-shadow:0 4px 14px rgba(15,23,42,.05);
  transition:transform .25s, box-shadow .25s, border-color .25s;
}
.cx-timeline li:hover .cx-tl-content{transform:translateX(4px);box-shadow:0 8px 24px rgba(15,23,42,.08);border-color:var(--accent)}
.cx-tl-content h3{font-size:1.05rem;margin-bottom:.4rem;color:var(--ink);letter-spacing:-.01em}
.cx-tl-content p{font-size:.92rem;color:var(--ink-3);line-height:1.65;margin:0}

/* STATS */
.cx-stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;
  max-width:980px;margin:0 auto;
}
.cx-stat{
  text-align:center;padding:2rem 1.4rem;
  background:#fff;border:1px solid var(--border);border-radius:18px;
  position:relative;overflow:hidden;
  transition:transform .3s, box-shadow .3s;
}
.cx-stat:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(15,23,42,.08)}
.cx-stat::after{
  content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:30px;height:2px;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  border-radius:0 0 2px 2px;
}
.cx-stat-num{
  display:block;font-size:1.8rem;font-weight:900;letter-spacing:-.03em;line-height:1;
  background:linear-gradient(135deg,var(--ink) 0%,var(--steel) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-fill-color:transparent;
  margin-bottom:.6rem;
}
.cx-stat-label{font-size:.84rem;color:var(--ink-3);line-height:1.4;display:block}

/* RESPONSIVE */
@media (max-width:900px){
  .cx-hero{padding:2.5rem 0 2rem}
  .cx-hero-grid{grid-template-columns:1fr;gap:1.8rem}
  .cx-hero-aside{order:-1;display:none}
  .cx-hero-text h1{font-size:clamp(1.7rem,7vw,2.4rem)}
  .cx-metrics{gap:1.4rem;padding-top:1rem}
  .cx-metric-num{font-size:1.4rem}
  .cx-metrics > div{flex:1;min-width:90px}

  .cx-channels-section{margin-top:-1rem}
  .cx-channels{grid-template-columns:1fr;gap:.7rem}
  .cx-channel{padding:1.1rem 1.2rem;gap:.9rem}
  .cx-channel-icon{width:46px;height:46px}
  .cx-channel-arrow{width:32px;height:32px}

  .cx-form-card{padding:1.6rem 1.3rem;border-radius:18px}
  .cx-section-head{margin-bottom:2rem}
  .cx-section-head h2{font-size:1.6rem}

  .cx-timeline::before{left:28px}
  .cx-timeline li{grid-template-columns:60px 1fr;gap:1rem;padding-bottom:1.2rem}
  .cx-tl-num{width:56px;height:56px;font-size:1.05rem}
  .cx-tl-content{padding:1.1rem 1.2rem}
  .cx-tl-content h3{font-size:.98rem}
  .cx-tl-content p{font-size:.86rem}

  .cx-stats{grid-template-columns:repeat(2,1fr);gap:.7rem}
  .cx-stat{padding:1.4rem 1rem}
  .cx-stat-num{font-size:1.4rem}
}
@media (max-width:480px){
  .cx-stats{grid-template-columns:1fr}
  .cx-form-card{padding:1.3rem 1.1rem}
  .cx-channel-meta{font-size:.78rem}
  .cx-channel-title{font-size:.96rem}
}

/* ====== CONTACTO premium v2 (legacy, ya no se usa) ====== */
/* Tarjetas info — fila simple, sin solape */
.info-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;
  margin-top:-2rem;position:relative;z-index:5;
}
.info-tile{
  background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);
  padding:1.3rem 1.4rem;
  display:flex;align-items:center;gap:1rem;
  box-shadow:var(--shadow-1);
  transition:transform .25s, box-shadow .25s, border-color .25s;
}
.info-tile:hover{transform:translateY(-3px);box-shadow:var(--shadow-2);border-color:var(--border-2)}
.info-tile-icon{
  width:46px;height:46px;border-radius:12px;flex-shrink:0;
  background:linear-gradient(135deg,var(--ink),var(--steel));
  color:var(--accent);
  display:inline-flex;align-items:center;justify-content:center;
}
.info-tile-icon svg{width:22px;height:22px}
.info-tile-label{
  font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-3);margin-bottom:.2rem;
}
.info-tile-value{
  display:block;font-size:1rem;font-weight:600;color:var(--ink);
  text-decoration:none;line-height:1.3;
}
a.info-tile-value:hover{color:var(--accent)}

/* Stepper proceso */
.stepper{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;
  position:relative;
}
.stepper::before{
  content:"";position:absolute;top:32px;left:8%;right:8%;height:2px;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  opacity:.25;border-radius:2px;z-index:0;
}
.stepper-item{
  position:relative;z-index:1;
  background:#fff;border:1px solid var(--border);border-radius:var(--r-md);
  padding:1.4rem 1.3rem;text-align:left;
  transition:transform .25s, box-shadow .25s, border-color .25s;
}
.stepper-item:hover{transform:translateY(-3px);box-shadow:var(--shadow-1);border-color:var(--accent)}
.stepper-num{
  display:inline-flex;align-items:center;justify-content:center;
  width:42px;height:42px;border-radius:50%;
  background:linear-gradient(135deg,var(--accent) 0%,var(--accent-2) 100%);
  color:#fff;font-weight:800;font-size:.95rem;letter-spacing:.02em;
  margin-bottom:1rem;
  box-shadow:0 4px 12px rgba(249,115,22,.32);
}
.stepper-item h4{font-size:1rem;margin-bottom:.4rem;color:var(--ink)}
.stepper-item p{font-size:.85rem;color:var(--ink-3);margin:0;line-height:1.55}

/* Check grid (qué información) */
.check-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:.8rem;
}
.check-item{
  display:flex;gap:.8rem;align-items:flex-start;
  padding:.95rem 1.1rem;background:#fff;border:1px solid var(--border);
  border-radius:var(--r-md);font-size:.9rem;
  transition:border-color .2s;
}
.check-item:hover{border-color:var(--accent)}
.check-item .chk{
  flex-shrink:0;width:22px;height:22px;border-radius:6px;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  position:relative;margin-top:.05em;
  box-shadow:0 2px 6px rgba(249,115,22,.3);
}
.check-item .chk::after{
  content:"";position:absolute;top:5px;left:7px;
  width:6px;height:10px;border:solid #fff;border-width:0 2px 2px 0;
  transform:rotate(45deg);
}
.check-item strong{color:var(--ink);font-weight:600;font-size:.92rem}
.check-item span{color:var(--ink-3);font-size:.84rem;line-height:1.45}

/* Form en página de contacto: misma form-card pero ancho completo */
section[id="form"] .form-card{
  padding:2rem 2.2rem;border-radius:var(--r-lg);box-shadow:var(--shadow-2);
}
section[id="form"] .form-card h3{display:none}
section[id="form"] .form-card > p{display:none}

/* Responsive */
@media (max-width:900px){
  .info-grid{grid-template-columns:1fr;margin-top:-1.5rem}
  .stepper{grid-template-columns:1fr;gap:.8rem}
  .stepper::before{display:none}
  .check-grid{grid-template-columns:1fr}
  section[id="form"] .form-card{padding:1.5rem}
}
@media (max-width:600px){
  .info-tile{padding:1.1rem 1.2rem;gap:.9rem}
  .info-tile-icon{width:42px;height:42px}
}

/* Trust strip --------------------------------------------- */
.trust-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}
.trust-item{
  display:flex;gap:.85rem;padding:1.1rem 1.2rem;background:#fff;border:1px solid var(--border);
  border-radius:var(--r-md);
}
.trust-item svg{width:26px;height:26px;color:var(--accent);flex-shrink:0}
.trust-item h4{font-size:.95rem;margin-bottom:.15rem}
.trust-item p{font-size:.82rem;color:var(--ink-3)}

/* City grid ----------------------------------------------- */
.city-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.55rem;
}
.city-grid a{
  display:flex;align-items:center;gap:.5rem;padding:.7rem .85rem;
  background:#fff;border:1px solid var(--border);border-radius:var(--r-sm);
  font-size:.86rem;font-weight:500;color:var(--ink);
  transition:all var(--t);
}
.city-grid a:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}
.city-grid a svg{width:14px;height:14px;color:var(--accent)}

/* CTA banner ---------------------------------------------- */
.cta-banner{
  background:linear-gradient(135deg,var(--ink) 0%,var(--steel) 100%);
  color:#fff;padding:clamp(2.5rem,5vw,4rem) clamp(1.5rem,4vw,3rem);
  border-radius:var(--r-lg);
  display:grid;grid-template-columns:1.5fr auto;gap:1.5rem;align-items:center;
  position:relative;overflow:hidden;
}
.cta-banner::before{
  content:"";position:absolute;right:-50px;top:-50px;width:300px;height:300px;
  border-radius:50%;background:radial-gradient(circle,var(--accent-glow),transparent 70%);
}
.cta-banner h2{color:#fff;margin-bottom:.6rem;position:relative}
.cta-banner p{color:#cbd5e1;font-size:1rem;max-width:55ch;position:relative}
.cta-banner .btn{position:relative}

/* FAQ ----------------------------------------------------- */
.faq{display:flex;flex-direction:column;gap:.6rem;max-width:850px;margin:0 auto}
.faq details{
  background:#fff;border:1px solid var(--border);border-radius:var(--r-md);
  overflow:hidden;transition:border-color var(--t);
}
.faq details[open]{border-color:var(--border-2)}
.faq summary{
  list-style:none;cursor:pointer;padding:1.1rem 1.3rem;
  display:flex;justify-content:space-between;align-items:center;gap:1rem;
  font-weight:600;color:var(--ink);font-size:.98rem;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+";font-size:1.4rem;color:var(--accent);transition:transform .25s;line-height:1;
}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .faq-body{padding:0 1.3rem 1.2rem;color:var(--ink-3);font-size:.92rem;line-height:1.7}

/* Article body (servicio / local) ------------------------- */
.article{display:grid;grid-template-columns:1fr 360px;gap:clamp(1.5rem,4vw,3rem);align-items:start}
.article-main{min-width:0}
.article-main h2{margin:2.4rem 0 .8rem}
.article-main h2:first-child{margin-top:0}
.article-main p{margin-bottom:.95rem;color:var(--ink-2)}
.article-main ul{margin:.4rem 0 1.2rem;padding-left:0}
.article-main ul li{
  position:relative;padding-left:1.5rem;margin-bottom:.5rem;color:var(--ink-2);font-size:.95rem;
}
.article-main ul li::before{
  content:"";position:absolute;left:0;top:.55rem;width:8px;height:8px;
  background:var(--accent);border-radius:2px;
}
.aside-cta{
  position:sticky;top:90px;background:#fff;border:1px solid var(--border);
  border-radius:var(--r-lg);padding:1.4rem;box-shadow:var(--shadow-1);
}
.aside-cta h4{font-size:1.05rem;margin-bottom:.4rem}
.aside-cta p{font-size:.85rem;color:var(--ink-3);margin-bottom:1rem}

/* Inline CTA inside article ------------------------------- */
.inline-cta{
  margin:2rem 0;padding:1.4rem 1.6rem;background:var(--accent-soft);
  border:1px solid var(--accent-glow);border-left:3px solid var(--accent);
  border-radius:var(--r-md);
  display:flex;flex-wrap:wrap;gap:1rem;align-items:center;justify-content:space-between;
}
.inline-cta strong{color:var(--ink);font-size:1rem}
.inline-cta p{font-size:.88rem;color:var(--ink-3);margin:.15rem 0 0}

/* Breadcrumbs (legacy – top of page, ya no se usa) -------- */
.breadcrumbs{padding:1rem 0;font-size:.8rem;color:var(--ink-3)}
.breadcrumbs a:hover{color:var(--accent)}
.breadcrumbs span{margin:0 .35rem;color:var(--ink-4)}

/* Breadcrumbs premium centradas, justo bajo el footer ----- */
.crumbs-bar{
  background:#06090f;
  border-top:1px solid rgba(255,255,255,.06);
}
.crumbs-bar .crumbs{
  display:flex;align-items:center;justify-content:center;flex-wrap:wrap;
  gap:.55rem .9rem;
  max-width:var(--max);margin:0 auto;
  padding:1.4rem var(--px);
  font-family:'Inter',sans-serif;
  font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;
  color:#64748b;
}
.crumbs a{
  color:#cbd5e1;font-weight:500;
  transition:color .2s ease;position:relative;padding-bottom:2px;
}
.crumbs a::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:1px;
  background:var(--accent);transform:scaleX(0);transform-origin:center;
  transition:transform .25s ease;
}
.crumbs a:hover{color:#fff}
.crumbs a:hover::after{transform:scaleX(1)}
.crumbs .sep{
  display:inline-block;width:18px;height:1px;
  background:linear-gradient(90deg,transparent,#475569 30%,#475569 70%,transparent);
  vertical-align:middle;
}
.crumbs .here{
  color:#fff;font-weight:600;
  display:inline-flex;align-items:center;gap:.5rem;
}
.crumbs .here::before{
  content:"";display:inline-block;width:5px;height:5px;border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 0 3px rgba(249,115,22,.18);
}
@media (max-width: 520px){
  .crumbs-bar .crumbs{font-size:.68rem;letter-spacing:.12em;gap:.4rem .55rem}
  .crumbs .sep{width:12px}
}

/* Footer -------------------------------------------------- */
.site-footer{background:var(--ink);color:#94a3b8;padding:3.5rem 0 1.5rem;margin-top:3rem}
.footer-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:2rem;margin-bottom:2.5rem}
.footer-col h5{color:#fff;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:1rem;font-weight:700}
.footer-col a{display:block;font-size:.88rem;padding:.25rem 0;color:#94a3b8;transition:color var(--t)}
.footer-col a:hover{color:var(--accent)}
.footer-about p{font-size:.87rem;line-height:1.7;color:#94a3b8;margin-bottom:1rem}
.footer-bottom{
  padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.08);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;
  font-size:.8rem;color:#64748b;
}
.footer-bottom a:hover{color:var(--accent)}

/* Floating mobile CTA ------------------------------------- */
.mobile-cta{
  position:fixed;bottom:.85rem;left:.85rem;right:.85rem;z-index:60;
  background:var(--accent);color:#fff;
  padding:.95rem 1rem;border-radius:var(--r-md);
  font-weight:700;text-align:center;font-size:.95rem;
  box-shadow:0 8px 24px rgba(249,115,22,.45);
  display:none;
}
.mobile-cta:hover{background:var(--accent-2)}

/* Responsive ---------------------------------------------- */
@media (max-width: 900px){
  .nav{display:none}
  .nav-cta{display:none}
  .hamburger{display:flex}
  .hero-grid{grid-template-columns:1fr}
  .article{grid-template-columns:1fr}
  .aside-cta{position:static}
  .footer-grid{grid-template-columns:1fr 1fr;gap:1.6rem}
  .cta-banner{grid-template-columns:1fr;text-align:center}
  .cta-banner .btn{justify-self:center}
  .field-row{grid-template-columns:1fr}
  .mobile-cta{display:block}
  body{padding-bottom:5rem}
}
@media (max-width: 520px){
  .footer-grid{grid-template-columns:1fr}
  .nav-dropdown{min-width:280px}
}

/* 404 ----------------------------------------------------- */
.error-page{
  min-height:60vh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:4rem 1rem;
}
.error-page .code{font-size:clamp(5rem,15vw,9rem);font-weight:900;color:var(--accent);line-height:1;letter-spacing:-.04em}
.error-page h1{margin:.5rem 0 .8rem}

/* Tabla precios ------------------------------------------- */
.price-table{
  border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;background:#fff;
  margin:1.6rem 0;
}
.price-row{display:grid;grid-template-columns:1.4fr 1fr;gap:1rem;padding:.95rem 1.2rem;border-bottom:1px solid var(--border);font-size:.92rem}
.price-row:last-child{border-bottom:none}
.price-row.head{background:var(--surface-2);font-weight:700;color:var(--ink)}

/* Project / proyectos cards ------------------------------- */
.proj-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.2rem}
.proj-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;
  display:flex;flex-direction:column;transition:transform .3s, box-shadow .3s, border-color .3s;
}
.proj-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-1);border-color:var(--border-2)}
.proj-thumb{
  aspect-ratio:16/10;position:relative;overflow:hidden;
  background:
    radial-gradient(120% 80% at 30% 20%, #1e2a44 0%, #0c1320 60%, #06091a 100%);
  display:flex;align-items:center;justify-content:center;color:#fff;
}
.proj-thumb::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:24px 24px;
  opacity:.7;
}
.proj-thumb::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(400px 200px at 75% 25%, rgba(249,115,22,.18), transparent 60%);
}
.proj-thumb svg{
  width:64px;height:64px;position:relative;z-index:1;
  color:#fff;opacity:.95;
  filter:drop-shadow(0 4px 12px rgba(249,115,22,.35));
  transition:transform .4s ease;
}
.proj-card:hover .proj-thumb svg{transform:scale(1.1) rotate(-3deg)}
.proj-tag{
  position:absolute;top:.75rem;left:.75rem;z-index:2;
  font-size:.65rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:#ffba80;background:rgba(0,0,0,.4);backdrop-filter:blur(8px);
  padding:.25rem .55rem;border-radius:var(--r-sm);
  border:1px solid rgba(249,115,22,.3);
}
.proj-body{padding:1.2rem 1.3rem}
.proj-body h3{font-size:1.05rem;margin-bottom:.4rem}
.proj-body p{font-size:.85rem;color:var(--ink-3)}
.proj-meta{margin-top:.7rem;font-size:.74rem;color:var(--ink-4);text-transform:uppercase;letter-spacing:.1em}

/* Skip link / accesibilidad ------------------------------ */
.skip-link{position:absolute;left:-9999px;top:0;background:var(--ink);color:#fff;padding:.6rem 1rem;border-radius:0 0 8px 0;z-index:200}
.skip-link:focus{left:0}

/* =========================================================
   MOBILE FIXES — overrides finales para que NADA se rompa
   ========================================================= */
@media (max-width: 900px){
  /* botones que tendían a wrap raro: ahora apilan limpios */
  .btn-row{flex-direction:column;align-items:stretch;gap:.6rem}
  .btn-row .btn{width:100%;justify-content:center}
  /* hero más compacto */
  .hero{padding:2.4rem 0 2.2rem}
  .hero-h1, .hero h1{font-size:clamp(1.6rem,7vw,2.4rem)}
  .hero-sub{font-size:.96rem;line-height:1.6}
  .hero-trust{gap:.4rem .9rem;font-size:.78rem}
  /* secciones más compactas */
  .section{padding:2.5rem 0}
  .section--tight{padding:2rem 0}
  /* containers article ya 1col */
  .article{gap:1.5rem}
  /* eyebrow más compacto */
  .eyebrow{font-size:.65rem;letter-spacing:.16em;margin-bottom:.7rem}
  /* faq menos padding */
  .faq summary{padding:.95rem 1rem;font-size:.92rem}
  .faq .faq-body{padding:0 1rem 1rem;font-size:.88rem}
  /* CTA banner: padding razonable, evita texto pegado a borde */
  .cta-banner{padding:2rem 1.4rem;border-radius:var(--r-md);text-align:center}
  .cta-banner h2{font-size:1.4rem}
  .cta-banner p{font-size:.92rem}
  .cta-banner .btn{width:100%;justify-content:center}
  /* inline-cta apila */
  .inline-cta{flex-direction:column;align-items:stretch;text-align:left;padding:1.2rem 1.3rem}
  .inline-cta .btn{width:100%;justify-content:center;margin-top:.5rem}
  /* trust grid 1 col */
  .trust-grid{grid-template-columns:1fr;gap:.7rem}
  .trust-item{padding:.95rem 1.1rem}
  /* service grid: forzar 1col en pequeño */
  .service-grid{grid-template-columns:1fr;gap:.85rem}
  .service-card{padding:1.3rem}
  /* city grid más denso */
  .city-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.5rem}
  .city-grid a{padding:.6rem .7rem;font-size:.82rem}
  /* proyectos 1 col */
  .proj-grid{grid-template-columns:1fr;gap:1rem}
  .proj-thumb svg{width:54px;height:54px}
  /* Tabla de precios — apila cada fila */
  .price-row{grid-template-columns:1fr;gap:.2rem;padding:.8rem 1rem;font-size:.88rem}
  .price-row.head{display:none}
  .price-row > span:first-child{font-weight:700;color:var(--ink)}
  .price-row > span:last-child{color:var(--accent);font-weight:600}
  /* Header */
  .header-inner{padding:.7rem var(--px);gap:.6rem}
  .logo-name{font-size:1.18rem}
  .logo-mark{width:34px;height:34px;border-radius:8px}
  .logo-mark svg{width:20px;height:20px}
  /* Footer 1 col, alineación izquierda */
  .footer-grid{grid-template-columns:1fr;gap:1.6rem}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:.45rem;text-align:left}
  /* Crumbs más compactas */
  .crumbs-bar .crumbs{padding:1rem var(--px);font-size:.65rem;letter-spacing:.12em;gap:.35rem .5rem}
  .crumbs .sep{width:10px}
  /* Form en mobile: padding razonable, textarea no se desborda */
  .form-card{padding:1.3rem}
  .field input,.field select,.field textarea{font-size:16px;padding:.75rem .85rem}  /* 16px evita zoom iOS */
  .field-row{grid-template-columns:1fr;gap:.5rem}
  .checkbox{font-size:.78rem}
  /* Aside CTA — sin sticky en móvil */
  .aside-cta{position:static;padding:1.3rem;margin-top:1rem}
  /* Breadcrumb superior interno (si quedó alguno) */
  .breadcrumbs{font-size:.75rem;padding:.7rem 0}
  /* Mobile CTA flotante — un poco más bajo y compacto */
  .mobile-cta{padding:.85rem 1rem;font-size:.92rem;left:.6rem;right:.6rem;bottom:.6rem;border-radius:10px}
  body{padding-bottom:4.5rem}
  /* Contacto — sin solape negativo en móvil */
  .info-grid{margin-top:0;grid-template-columns:1fr;gap:.7rem}
  .info-tile{padding:1rem 1.15rem;gap:.85rem}
  .info-tile-icon{width:42px;height:42px}
  .check-grid{grid-template-columns:1fr;gap:.55rem}
  .check-item{padding:.8rem .95rem}
  /* Stepper apilado limpio */
  .stepper{grid-template-columns:1fr;gap:.7rem}
  .stepper::before{display:none}
  .stepper-item{padding:1.15rem 1.2rem}
  .stepper-num{margin-bottom:.6rem;width:36px;height:36px;font-size:.85rem}
  /* Article ul/ol indent */
  .article-main ul li{padding-left:1.3rem;font-size:.9rem}
  .article-main p{font-size:.94rem;line-height:1.7}
  .article-main h2{margin:1.8rem 0 .6rem}
  /* Lead más pequeño */
  .lead{font-size:.96rem;line-height:1.65}
  /* Form-card en sección formulario centrada */
  section[id="form"] .form-card{padding:1.3rem}
}

@media (max-width: 480px){
  :root{--px:1rem}
  .hero{padding:2rem 0 1.8rem}
  .hero-h1,.hero h1{font-size:clamp(1.5rem,8vw,1.95rem)}
  .section{padding:2rem 0}
  .section--tight{padding:1.5rem 0}
  .nav-cta{display:none}
  .logo-name{font-size:1.05rem}
  .footer-grid{margin-bottom:1.6rem}
  .footer-col h5{font-size:.78rem;margin-bottom:.7rem}
  .footer-col a{font-size:.85rem;padding:.2rem 0}
  .city-grid{grid-template-columns:repeat(2,1fr)}
  .city-grid a{font-size:.78rem}
  .container{padding:0 var(--px)}
  .form-card{padding:1.15rem}
  .cta-banner{padding:1.6rem 1.1rem}
  .cta-banner h2{font-size:1.25rem}
  .stepper-item{padding:1rem 1.1rem}
  .stepper-item h4{font-size:.95rem}
  .stepper-item p{font-size:.82rem}
  .crumbs-bar .crumbs{padding:.8rem var(--px);font-size:.6rem;letter-spacing:.1em}
  .error-page .code{font-size:6rem}
  .info-tile{flex-direction:row;align-items:center}
  .info-tile-value{font-size:.95rem;word-break:break-all}
  /* article main: tipos más pequeños */
  .article-main h2{font-size:1.25rem}
  .faq summary{font-size:.88rem;padding:.85rem .95rem}
}

/* Evita scroll horizontal en cualquier viewport */
html,body{max-width:100vw;overflow-x:hidden}
img,iframe,video{max-width:100%;height:auto}
table,pre{overflow-x:auto;max-width:100%}
/* SVG: nunca dejar que se desborde, pero NO forzar height:auto que hace que crezcan */
svg{max-width:100%;flex-shrink:0}
