/* =============================================================
   ProtegeHogar 360 — CSS Premium · v2
   Estética moderna · enfoque conversión · móvil-first
   ============================================================= */

:root{
  /* Paleta principal */
  --azul-noche:#0a1929;
  --azul-noche-2:#06111e;
  --azul-acero:#11335c;
  --azul-acero-2:#1c4f8f;
  --azul-claro:#3477c4;
  --acento:#ffb302;
  --acento-2:#ffce5a;
  --acento-3:#ffeab8;
  --rojo:#e23b3b;
  --rojo-2:#c12828;
  --verde:#1aa66b;
  --verde-2:#138a55;
  --gris-0:#fbfcfe;
  --gris-1:#f4f6fa;
  --gris-2:#e7ecf3;
  --gris-3:#d3dae6;
  --gris-4:#8a94a6;
  --texto:#0d1626;
  --texto-suave:#475063;
  --blanco:#ffffff;

  /* Sombras refinadas */
  --sombra-xs:0 1px 2px rgba(11,31,58,.04);
  --sombra-sm:0 2px 8px rgba(11,31,58,.06),0 1px 2px rgba(11,31,58,.04);
  --sombra:0 8px 24px rgba(11,31,58,.08),0 2px 6px rgba(11,31,58,.04);
  --sombra-lg:0 24px 60px rgba(11,31,58,.16),0 10px 24px rgba(11,31,58,.08);
  --sombra-xl:0 40px 80px rgba(11,31,58,.22);

  --radio-xs:6px;
  --radio-sm:10px;
  --radio:14px;
  --radio-lg:20px;
  --radio-xl:28px;

  --max:1200px;
  --max-prosa:880px;
  --transicion:.28s cubic-bezier(.4,0,.2,1);
  --transicion-rapida:.18s ease;
}

*,*::before,*::after{box-sizing:border-box}

/* ── Accesibilidad: skip-link y sr-only ── */
.sr-only{
  position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  font-size:16px;
  line-height:1.7;
  color:var(--texto);
  background:var(--blanco);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  font-feature-settings:"cv02","cv03","cv04","cv11";
}
img,svg,video{max-width:100%;height:auto;display:block}
a{color:var(--azul-acero-2);text-decoration:none;transition:color var(--transicion-rapida)}
a:hover{color:var(--azul-noche)}
button{font-family:inherit;cursor:pointer;border:0;background:none}

/* ── Tipografía premium ── */
h1,h2,h3,h4,h5{
  font-family:'Inter',sans-serif;
  color:var(--texto);
  line-height:1.18;
  margin:0 0 .55em;
  font-weight:800;
  letter-spacing:-.022em;
}
h1{font-size:clamp(2.1rem,4.6vw,3.4rem);letter-spacing:-.028em}
h2{font-size:clamp(1.55rem,3.1vw,2.25rem);letter-spacing:-.024em;margin-top:0}
h3{font-size:clamp(1.18rem,2vw,1.4rem);font-weight:700}
h4{font-size:1.05rem;font-weight:700}
p{margin:0 0 1em}
ul,ol{padding-left:1.2em;margin:0 0 1em}
ul li,ol li{margin:.28em 0}
strong,b{font-weight:700;color:var(--texto)}

/* ── Layout base ── */
.wrap{max-width:var(--max);margin:0 auto;padding:0 24px}
.section{padding:84px 0}
.section--apretada{padding:54px 0}
.section--gris{background:linear-gradient(180deg,var(--gris-0) 0%,var(--gris-1) 100%)}
.section--azul{
  background:linear-gradient(135deg,var(--azul-noche) 0%,var(--azul-acero) 100%);
  color:#dde8f6;position:relative;overflow:hidden;
}
.section--azul::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse at 80% 10%,rgba(255,179,2,.10),transparent 50%),
    radial-gradient(ellipse at 10% 90%,rgba(52,119,196,.16),transparent 55%);
}
.section--azul > *{position:relative;z-index:1}
.section--azul h2,.section--azul h3,.section--azul h4{color:#fff}

/* ── Topbar (ultra compacta) ── */
.topbar{
  background:linear-gradient(90deg,var(--azul-noche) 0%,var(--azul-noche-2) 100%);
  color:#dee9f7;
  font-size:.74rem;
  padding:5px 0;
  border-bottom:1px solid rgba(255,255,255,.04);
  line-height:1.3;
}
.topbar .wrap{display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:space-between;min-height:22px}
.topbar a{color:#fff;display:inline-flex;align-items:center;gap:5px;font-weight:600;font-size:.74rem;white-space:nowrap}
.topbar a:hover{color:var(--acento-2)}
.topbar > .wrap > span{display:inline-flex;align-items:center;gap:5px;white-space:nowrap}
.topbar .badge{
  background:rgba(255,179,2,.16);color:var(--acento-2);
  padding:2px 9px;border-radius:999px;font-weight:600;font-size:.7rem;
  border:1px solid rgba(255,179,2,.25);display:inline-flex;align-items:center;gap:5px;
}
.topbar .ico{width:11px;height:11px}
@media (max-width:760px){.topbar .hide-mobile{display:none}.topbar .wrap{justify-content:center;gap:8px}}

/* ── Nav (azul oscuro premium + logo PNG) ── */
.nav{
  position:sticky;top:0;z-index:50;
  background:linear-gradient(180deg,var(--azul-noche) 0%,var(--azul-acero) 100%);
  border-bottom:1px solid rgba(255,255,255,.06);
  box-shadow:0 4px 18px rgba(11,31,58,.18);
}
.nav__inner{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:9px 0;min-height:58px}

.brand{
  display:inline-flex;align-items:center;gap:0;
  font-weight:800;color:#fff;font-size:.98rem;letter-spacing:-.02em;
  white-space:nowrap;flex-shrink:0;
}
.brand img.brand__logo-img{
  width:auto;height:42px;max-height:42px;display:block;
  filter:drop-shadow(0 4px 10px rgba(0,0,0,.35));
}
.brand__name{display:none}

.menu{display:flex;gap:1px;align-items:center;flex-wrap:nowrap}
.menu a{
  display:inline-block;padding:7px 12px;border-radius:8px;
  font-weight:600;color:#eef2fa;font-size:.86rem;white-space:nowrap;
  transition:all var(--transicion-rapida);
}
.menu a:hover{background:rgba(255,255,255,.08);color:#fff}
.menu .btn{padding:9px 16px;margin-left:8px;font-size:.86rem;white-space:nowrap;border-radius:9px}

.btn-burger{display:none;width:38px;height:38px;border-radius:9px;background:rgba(255,255,255,.08);align-items:center;justify-content:center;transition:background var(--transicion-rapida)}
.btn-burger:hover{background:rgba(255,255,255,.14)}
.btn-burger span{width:18px;height:2px;background:#fff;position:relative;display:block;border-radius:2px}
.btn-burger span::before,.btn-burger span::after{content:"";position:absolute;width:18px;height:2px;background:#fff;left:0;border-radius:2px;transition:transform var(--transicion-rapida)}
.btn-burger span::before{top:-5px}
.btn-burger span::after{top:5px}

@media (max-width:1080px){
  .menu a{padding:6px 10px;font-size:.82rem}
  .menu .btn{padding:8px 14px;font-size:.82rem}
}
@media (max-width:980px){
  .menu{display:none}
  .menu.open{
    display:flex;flex-direction:column;align-items:stretch;gap:2px;
    position:absolute;top:100%;left:0;right:0;
    background:linear-gradient(180deg,var(--azul-noche),var(--azul-acero));
    padding:14px 16px 18px;border-bottom:1px solid rgba(255,255,255,.06);
    box-shadow:var(--sombra-lg);
  }
  .menu.open a{padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.08);font-size:.96rem;border-radius:0;color:#eef2fa}
  .menu.open a:hover{background:rgba(255,255,255,.08);color:#fff}
  .menu.open a:last-child{border:0;margin:6px 0 0;border-radius:10px;color:#1a1300}
  .btn-burger{display:flex}
  .nav__inner{padding:7px 0;min-height:52px}
  .brand img.brand__logo-img{height:36px;max-height:36px}
}

/* ── Botones premium ── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  padding:14px 24px;border-radius:12px;font-weight:700;font-size:.95rem;
  background:linear-gradient(180deg,var(--azul-acero-2),var(--azul-acero));
  color:#fff;line-height:1.1;
  transition:all var(--transicion);
  box-shadow:0 8px 20px rgba(17,51,92,.22),inset 0 1px 0 rgba(255,255,255,.14);
  border:1px solid transparent;
  position:relative;overflow:hidden;
  letter-spacing:.005em;
}
.btn::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.16),transparent 70%);
  transform:translateX(-100%);transition:transform .6s ease;
}
.btn:hover{color:#fff;transform:translateY(-1px);box-shadow:0 14px 28px rgba(11,31,58,.28),inset 0 1px 0 rgba(255,255,255,.14)}
.btn:hover::after{transform:translateX(100%)}
.btn:active{transform:translateY(0)}
.btn--acento{
  background:linear-gradient(180deg,var(--acento-2) 0%,var(--acento) 100%);
  color:#1a1300;
  box-shadow:0 10px 24px rgba(255,179,2,.34),inset 0 1px 0 rgba(255,255,255,.34);
}
.btn--acento:hover{color:#1a1300;box-shadow:0 14px 32px rgba(255,179,2,.42)}
.btn--verde{background:linear-gradient(180deg,#26b876,var(--verde-2));box-shadow:0 10px 24px rgba(26,166,107,.32)}
.btn--verde:hover{box-shadow:0 14px 30px rgba(26,166,107,.42)}
.btn--rojo{background:linear-gradient(180deg,#ec4d4d,var(--rojo-2));box-shadow:0 10px 24px rgba(226,59,59,.32)}
.btn--rojo:hover{box-shadow:0 14px 30px rgba(226,59,59,.42)}
.btn--fantasma{background:transparent;color:var(--azul-noche);border:1.6px solid var(--gris-3);box-shadow:none}
.btn--fantasma:hover{background:var(--azul-noche);color:#fff;border-color:var(--azul-noche)}
.btn--fantasma-blanco{background:transparent;color:#fff;border:1.6px solid rgba(255,255,255,.4);box-shadow:none}
.btn--fantasma-blanco:hover{background:#fff;color:var(--azul-noche);border-color:#fff}
.btn--lg{padding:17px 30px;font-size:1.02rem}
.btn--xl{padding:20px 38px;font-size:1.1rem;border-radius:14px}
.btn--full{width:100%}

/* ── Iconos SVG ── */
.ico{width:1em;height:1em;display:inline-block;vertical-align:-3px;flex-shrink:0}
.ico--lg{width:1.4em;height:1.4em}
.ico--xl{width:2em;height:2em}
.btn .ico,.menu .btn .ico{width:18px;height:18px}
.lista-check li .ico,.hero__check .ico{width:18px;height:18px;color:var(--verde)}
.hero__check .ico{color:var(--acento)}
.testi__estrellas .ico{width:16px;height:16px;color:var(--acento);margin-right:1px}
.kit__item .ico,.card__icon .ico{width:28px;height:28px}

/* ── Hero ── */
.hero{
  position:relative;
  background:linear-gradient(135deg,var(--azul-noche) 0%,var(--azul-acero) 60%,#163e6f 100%);
  color:#eef4fb;
  overflow:hidden;
  padding:90px 0 110px;
}
.hero::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(circle at 88% 18%,rgba(255,179,2,.22),transparent 38%),
    radial-gradient(circle at 12% 85%,rgba(52,119,196,.45),transparent 50%),
    radial-gradient(circle at 50% 50%,rgba(8,24,45,.6),transparent 70%);
}
.hero::after{
  content:"";position:absolute;left:0;right:0;bottom:-1px;height:80px;pointer-events:none;
  background:linear-gradient(180deg,transparent,var(--blanco));
}
.hero__grid{position:relative;display:grid;grid-template-columns:1.15fr .95fr;gap:60px;align-items:center;z-index:1}
.hero__pretitulo{
  display:inline-flex;align-items:center;gap:9px;
  background:rgba(255,179,2,.13);color:var(--acento-2);
  padding:8px 16px;border-radius:999px;font-weight:700;font-size:.85rem;
  border:1px solid rgba(255,179,2,.3);margin-bottom:22px;
  backdrop-filter:blur(6px);
}
.hero__pretitulo .ico{width:16px;height:16px;color:var(--acento-2)}
.hero h1{color:#fff;margin-bottom:22px;text-shadow:0 2px 22px rgba(0,0,0,.25)}
.hero h1 em{color:var(--acento);font-style:normal}
.hero__sub{font-size:1.1rem;color:#cdd9ec;margin-bottom:32px;max-width:580px;line-height:1.65}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:30px}
.hero__check{display:flex;flex-wrap:wrap;gap:10px 22px;font-size:.92rem;color:#cfdaee}
.hero__check span{display:inline-flex;align-items:center;gap:7px;white-space:nowrap}
@media (max-width:560px){
  .hero__check{gap:8px 18px;font-size:.88rem}
  .hero__check span{white-space:normal}
}

/* Formulario hero */
.hero__form{
  background:#fff;color:var(--texto);
  border-radius:var(--radio-xl);
  padding:32px 30px 26px;
  box-shadow:var(--sombra-xl),0 0 0 1px rgba(255,255,255,.05);
  position:relative;
  z-index:2;
}
.hero__form__badge{
  position:absolute;top:-14px;right:24px;
  background:linear-gradient(135deg,var(--rojo-2),var(--rojo));color:#fff;font-size:.72rem;font-weight:800;
  padding:6px 14px;border-radius:8px;letter-spacing:.06em;
  box-shadow:0 6px 16px rgba(226,59,59,.32);
  text-transform:uppercase;line-height:1;white-space:nowrap;
}
.hero__form h3{color:var(--azul-noche);margin-bottom:8px;font-size:1.32rem}
.hero__form > p{color:var(--texto-suave);font-size:.95rem;margin-bottom:20px;line-height:1.55}

/* Formularios premium */
.field{margin-bottom:11px;position:relative}
.field input,.field select,.field textarea{
  width:100%;padding:14px 16px;border:1.5px solid var(--gris-3);
  border-radius:11px;font-size:.96rem;background:var(--blanco);color:var(--texto);
  font-family:inherit;transition:all var(--transicion-rapida);
  appearance:none;-webkit-appearance:none;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--azul-acero-2);
  box-shadow:0 0 0 4px rgba(28,79,143,.13);
}
.field input::placeholder{color:var(--gris-4)}
.field select{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2378818f' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");background-repeat:no-repeat;background-position:right 14px center;padding-right:42px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.legal-mini{font-size:.78rem;color:var(--texto-suave);margin-top:12px;line-height:1.55;text-align:center}
.legal-mini a{text-decoration:underline}

@media (max-width:920px){
  .hero{padding:58px 0 70px}
  .hero__grid{grid-template-columns:1fr;gap:42px}
  .hero__form{padding:26px 22px}
  .field-row{grid-template-columns:1fr}
}

/* ── Tira de confianza ── */
.tira{
  background:#fff;border-bottom:1px solid var(--gris-2);
  padding:36px 0;margin-top:-1px;position:relative;z-index:2;
}
.tira__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center}
.tira__item{display:flex;flex-direction:column;align-items:center;gap:6px}
.tira__item .num{display:block;font-size:1.85rem;color:var(--azul-noche);font-weight:800;letter-spacing:-.02em;line-height:1}
.tira__item .lbl{display:block;font-size:.83rem;color:var(--texto-suave);font-weight:600;text-transform:uppercase;letter-spacing:.06em}
.tira__item .ico-stat{
  width:46px;height:46px;border-radius:13px;padding:11px;
  background:linear-gradient(135deg,rgba(255,179,2,.18),rgba(255,179,2,.04));
  color:var(--acento);box-sizing:border-box;margin-bottom:6px;
}
@media (max-width:680px){.tira__grid{grid-template-columns:repeat(2,1fr);gap:24px}.tira__item .num{font-size:1.5rem}.tira__item .lbl{font-size:.74rem}}
@media (max-width:380px){.tira{padding:24px 0}.tira__grid{gap:18px}.tira__item .ico-stat{width:38px;height:38px;padding:9px}}

/* ── Bloques comunes ── */
.eyebrow{
  display:inline-flex;align-items:center;gap:7px;
  color:var(--azul-acero-2);font-weight:800;
  text-transform:uppercase;font-size:.76rem;letter-spacing:.12em;
  background:var(--gris-2);padding:6px 14px;border-radius:999px;margin-bottom:18px;
}
.section--azul .eyebrow{background:rgba(255,255,255,.08);color:var(--acento-2);border:1px solid rgba(255,179,2,.2)}
.lead{font-size:1.08rem;color:var(--texto-suave);max-width:760px;line-height:1.7}
.section__head{text-align:center;max-width:880px;margin:0 auto 50px}
.section__head .lead{margin:0 auto}
.section--azul .lead{color:#c8d4ea}

/* ── Cards ── */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card{
  background:#fff;border-radius:var(--radio-lg);
  padding:28px 26px;box-shadow:var(--sombra-sm);border:1px solid var(--gris-2);
  transition:all var(--transicion);
  display:flex;flex-direction:column;
  position:relative;overflow:hidden;
}
.card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--azul-acero-2),var(--acento));
  transform:scaleX(0);transform-origin:left;transition:transform var(--transicion);
}
.card:hover{transform:translateY(-4px);box-shadow:var(--sombra-lg);border-color:var(--gris-3)}
.card:hover::before{transform:scaleX(1)}
.card__icon{
  width:60px;height:60px;border-radius:16px;
  background:linear-gradient(135deg,#e7f0fc,#cfdef5);
  display:grid;place-items:center;margin-bottom:18px;color:var(--azul-acero-2);
  box-shadow:0 6px 14px rgba(28,79,143,.12);
}
.card__icon svg{width:30px;height:30px;stroke-width:1.6}
.card h3{color:var(--azul-noche);margin-bottom:10px;font-size:1.2rem}
.card p{color:var(--texto-suave);font-size:.96rem;margin:0;line-height:1.65}
.card a.more{margin-top:18px;font-weight:700;color:var(--azul-acero-2);display:inline-flex;align-items:center;gap:6px}
.card a.more:hover{color:var(--azul-noche)}
.cards--4{grid-template-columns:repeat(4,1fr)}
.cards--2{grid-template-columns:repeat(2,1fr)}
@media (max-width:980px){.cards,.cards--4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.cards,.cards--4,.cards--2{grid-template-columns:1fr}}

/* ── Listas de check ── */
.lista-check{list-style:none;padding:0}
.lista-check li{
  padding:9px 0 9px 34px;position:relative;margin:0;
  font-size:.99rem;color:var(--texto);line-height:1.6;
}
.lista-check li::before{
  content:"";position:absolute;left:0;top:13px;width:22px;height:22px;border-radius:50%;
  background:var(--verde) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'><path d='M9 16.17l-3.59-3.58L4 14l5 5 11-11-1.41-1.41z'/></svg>") center/14px no-repeat;
  box-shadow:0 2px 6px rgba(26,166,107,.32);
}
.lista-check.lista-x li::before{background:var(--rojo) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'><path d='M18.3 5.71L12 12l6.3 6.29-1.41 1.42L10.59 13.4 4.3 19.71 2.88 18.3 9.17 12 2.88 5.71 4.3 4.29l6.29 6.3 6.3-6.3z'/></svg>") center/12px no-repeat;box-shadow:0 2px 6px rgba(226,59,59,.32)}

/* ── Tabla comparativa ── */
.tabla-wrap{overflow-x:auto;margin:0 0 22px;border-radius:var(--radio);box-shadow:var(--sombra);-webkit-overflow-scrolling:touch}
.tabla-wrap::-webkit-scrollbar{height:8px}
.tabla-wrap::-webkit-scrollbar-thumb{background:var(--gris-3);border-radius:4px}
.tabla-wrap::-webkit-scrollbar-track{background:var(--gris-1)}
@media (max-width:760px){
  .tabla-wrap{margin-left:-12px;margin-right:-12px;border-radius:0}
  .tabla-comparativa,.tabla-precios{font-size:.85rem;border-radius:0}
  .tabla-comparativa th,.tabla-comparativa td,.tabla-precios th,.tabla-precios td{padding:10px 12px}
  .tabla-precios .marca-celda img{max-height:22px}
}
.tabla-comparativa{
  width:100%;border-collapse:separate;border-spacing:0;
  background:#fff;border-radius:var(--radio);overflow:hidden;
}
.tabla-comparativa th,.tabla-comparativa td{
  padding:16px 18px;text-align:left;border-bottom:1px solid var(--gris-2);font-size:.94rem;
}
.tabla-comparativa thead th{
  background:linear-gradient(180deg,var(--azul-noche),var(--azul-noche-2));
  color:#fff;font-weight:700;text-transform:uppercase;font-size:.78rem;letter-spacing:.07em;
}
.tabla-comparativa tbody tr:nth-child(even){background:var(--gris-1)}
.tabla-comparativa tbody tr:hover{background:#fdf6e3}
.tabla-comparativa tbody tr:last-child td{border-bottom:0}
.si{color:var(--verde);font-weight:700}
.no{color:var(--rojo);font-weight:700}

/* ── Precios ── */
.precios{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.precio{
  background:#fff;border-radius:var(--radio-lg);padding:30px 28px;
  border:1px solid var(--gris-2);box-shadow:var(--sombra-sm);position:relative;
  display:flex;flex-direction:column;
  transition:all var(--transicion);
}
.precio:hover{transform:translateY(-3px);box-shadow:var(--sombra)}
.precio--destacado{
  border:2px solid var(--acento);box-shadow:0 22px 50px rgba(255,179,2,.24);
  transform:translateY(-8px);background:linear-gradient(180deg,#fff,#fffdf5);
}
.precio--destacado:hover{transform:translateY(-12px);box-shadow:0 28px 60px rgba(255,179,2,.32)}
.precio__badge{
  position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:linear-gradient(135deg,var(--acento-2),var(--acento));color:#1a1300;
  padding:5px 14px;border-radius:999px;
  font-weight:800;font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;
  box-shadow:0 6px 14px rgba(255,179,2,.45),inset 0 1px 0 rgba(255,255,255,.4);
  white-space:nowrap;line-height:1;
  border:1.5px solid #fff;
}
.precio h3{color:var(--azul-noche);margin-bottom:6px;font-size:1.25rem}
.precio__sub{color:var(--texto-suave);font-size:.92rem;margin-bottom:20px;line-height:1.5}
.precio__num{font-size:2.6rem;font-weight:800;color:var(--azul-noche);line-height:1;letter-spacing:-.02em}
.precio__num small{font-size:1rem;font-weight:600;color:var(--texto-suave);letter-spacing:0}
.precio__detalle{margin:8px 0 20px;font-size:.85rem;color:var(--texto-suave)}
.precio .lista-check{flex-grow:1}
.precio .lista-check li{font-size:.93rem;padding-top:7px;padding-bottom:7px}
.precio .btn{margin-top:16px}
.section--azul .precio{background:#fff;color:var(--texto)}
.section--azul .precio h3,.section--azul .precio__num{color:var(--azul-noche)}
@media (max-width:980px){.precios{grid-template-columns:1fr;gap:18px}.precio--destacado{transform:none}.precio--destacado:hover{transform:translateY(-3px)}}

/* ── FAQ ── */
.faq{max-width:920px;margin:0 auto}
.faq details{
  background:#fff;border:1px solid var(--gris-2);border-radius:14px;
  padding:0;margin-bottom:14px;box-shadow:var(--sombra-xs);
  overflow:hidden;transition:box-shadow var(--transicion-rapida);
}
.faq details[open]{box-shadow:var(--sombra);border-color:var(--gris-3)}
.faq summary{
  list-style:none;cursor:pointer;padding:20px 60px 20px 24px;font-weight:700;color:var(--azul-noche);
  position:relative;font-size:1rem;line-height:1.4;
  transition:background var(--transicion-rapida);
}
.faq summary:hover{background:var(--gris-0)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+";position:absolute;right:22px;top:50%;transform:translateY(-50%);
  width:30px;height:30px;background:var(--gris-1);color:var(--azul-noche);border-radius:50%;
  display:grid;place-items:center;font-size:1.25rem;font-weight:700;
  transition:all var(--transicion);
}
.faq details[open] summary::after{content:"−";background:var(--azul-acero-2);color:#fff;transform:translateY(-50%) rotate(180deg)}
.faq .faq__body{padding:0 24px 22px;color:var(--texto-suave);font-size:.97rem;line-height:1.75}
.faq .faq__body p:last-child{margin-bottom:0}
.section--azul .faq details{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.1)}
.section--azul .faq details[open]{background:rgba(255,255,255,.06)}
.section--azul .faq summary{color:#fff}
.section--azul .faq summary:hover{background:rgba(255,255,255,.04)}
.section--azul .faq summary::after{background:rgba(255,255,255,.1);color:#fff}
.section--azul .faq .faq__body{color:#c4d2ea}

/* ── Breadcrumbs (debajo del footer, estilo footer oscuro) ── */
.crumbs{
  font-size:.86rem;color:#9eb0cc;text-align:center;
  padding:22px 0 24px;background:linear-gradient(180deg,#04101c,#020a14);
  border-top:1px solid rgba(255,255,255,.05);
}
.crumbs a{color:#cdd9ec;transition:color var(--transicion-rapida);font-weight:500}
.crumbs a:hover{color:var(--acento-2)}
.crumbs .wrap{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:0;line-height:1.5}
.crumbs span{display:inline-flex;align-items:center}
.crumbs span+span::before{content:"›";color:#5a6a85;margin:0 10px;font-weight:600;font-size:1.05rem}
.crumbs span:last-child{color:#fff;font-weight:600}

/* ── Banda CTA ── */
.cta-banda{
  background:linear-gradient(135deg,var(--acento) 0%,var(--acento-2) 100%);
  color:#1a1300;text-align:center;padding:60px 0;
  position:relative;overflow:hidden;
}
.cta-banda::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle at 10% 50%,rgba(255,255,255,.3),transparent 50%),
    radial-gradient(circle at 90% 50%,rgba(255,255,255,.18),transparent 50%);
}
.cta-banda > *{position:relative;z-index:1}
.cta-banda h2{color:#1a1300;margin-bottom:14px}
.cta-banda p{color:#3a2d00;font-size:1.06rem;max-width:680px;margin:0 auto 26px;line-height:1.65}
.cta-banda .btn{background:linear-gradient(180deg,var(--azul-acero-2),var(--azul-noche));color:#fff;box-shadow:0 14px 30px rgba(11,31,58,.36)}
.cta-banda .btn:hover{background:linear-gradient(180deg,var(--azul-noche),#000);color:#fff;box-shadow:0 18px 40px rgba(11,31,58,.5)}

/* ── Duo (texto + columna lateral) ── */
.duo{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.duo--inv .duo__txt{order:2}
@media (max-width:920px){.duo,.duo--inv{grid-template-columns:1fr;gap:30px}.duo--inv .duo__txt{order:0}}
.duo__txt h2{margin-bottom:16px}
.duo__txt .lead{margin-bottom:20px}

/* ── Kit dispositivos (galería) ── */
.dispositivos{
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:30px;
}
.dispositivo{
  background:#fff;border:1px solid var(--gris-2);border-radius:16px;
  padding:18px 16px;text-align:center;box-shadow:var(--sombra-xs);
  transition:all var(--transicion);
}
.dispositivo:hover{transform:translateY(-4px);box-shadow:var(--sombra-lg);border-color:var(--gris-3)}
.dispositivo img{
  width:100%;max-width:170px;height:140px;object-fit:contain;
  margin:0 auto 14px;display:block;
  filter:drop-shadow(0 4px 10px rgba(11,31,58,.08));
  transition:transform var(--transicion);
}
.dispositivo:hover img{transform:scale(1.06)}
.dispositivo strong{display:block;color:var(--azul-noche);font-size:.96rem;margin-bottom:4px}
.dispositivo span{display:block;color:var(--texto-suave);font-size:.82rem;line-height:1.5}
@media (max-width:880px){.dispositivos{grid-template-columns:repeat(2,1fr)}}
@media (max-width:480px){.dispositivos{grid-template-columns:1fr 1fr;gap:12px}.dispositivo img{height:120px}}

/* ── Logos de marcas: cards INDEPENDIENTES con CSS único por marca ── */
.marcas-grid{
  display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:18px;
  margin:30px auto;max-width:1180px;align-items:stretch;
}
.marca-card{
  position:relative;background:#fff;border:1px solid var(--gris-2);
  border-radius:18px;padding:24px 16px 20px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;min-height:130px;overflow:hidden;
  transition:all var(--transicion);
  box-shadow:var(--sombra-xs);
  isolation:isolate;
  text-decoration:none;color:inherit;cursor:pointer;
}
.marca-card::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:var(--m-bg, linear-gradient(180deg,#fff,#fafbfd));
  opacity:.6;transition:opacity var(--transicion);
}
.marca-card::after{
  content:"";position:absolute;top:0;left:0;right:0;height:4px;
  background:var(--m-color,var(--azul-acero-2));
  transform:scaleX(.3);transform-origin:left;transition:transform var(--transicion);
  border-radius:0 0 4px 4px;
}
.marca-card:hover{
  transform:translateY(-5px);
  border-color:var(--m-color,var(--azul-acero-2));
  box-shadow:0 18px 38px var(--m-shadow,rgba(11,31,58,.16));
}
.marca-card:hover::before{opacity:1}
.marca-card:hover::after{transform:scaleX(1)}
.marca-card img{
  max-height:46px;width:auto;max-width:100%;object-fit:contain;
  margin:0 auto 10px;display:block;
  filter:saturate(.95);
  transition:transform var(--transicion),filter var(--transicion);
}
.marca-card:hover img{transform:scale(1.08);filter:saturate(1.08)}
.marca-card .marca-card__nombre{
  font-size:.78rem;font-weight:700;color:var(--m-color,var(--azul-noche));
  letter-spacing:.02em;display:block;
  opacity:.85;transition:opacity var(--transicion-rapida);
}
.marca-card:hover .marca-card__nombre{opacity:1}
.marca-card .marca-card__rating{
  font-size:.72rem;color:var(--texto-suave);margin-top:2px;font-weight:600;
}
.marca-card .marca-card__rating strong{color:var(--acento);letter-spacing:-.01em}

/* ── Colores corporativos por marca ── */
.marca-card--adt{
  --m-color:#cd1c2e;
  --m-bg:radial-gradient(circle at 50% 0%,rgba(205,28,46,.08),transparent 60%),linear-gradient(180deg,#fff,#fff7f7);
  --m-shadow:rgba(205,28,46,.22);
}
.marca-card--securitas{
  --m-color:#003db8;
  --m-bg:radial-gradient(circle at 50% 0%,rgba(0,61,184,.08),transparent 60%),linear-gradient(180deg,#fff,#f4f7ff);
  --m-shadow:rgba(0,61,184,.22);
}
.marca-card--movistar{
  --m-color:#019df4;
  --m-bg:radial-gradient(circle at 50% 0%,rgba(1,157,244,.08),transparent 60%),linear-gradient(180deg,#fff,#f1faff);
  --m-shadow:rgba(1,157,244,.22);
}
.marca-card--segurma{
  --m-color:#e84e1a;
  --m-bg:radial-gradient(circle at 50% 0%,rgba(232,78,26,.08),transparent 60%),linear-gradient(180deg,#fff,#fff7f2);
  --m-shadow:rgba(232,78,26,.22);
}
.marca-card--sicor{
  --m-color:#005b35;
  --m-bg:radial-gradient(circle at 50% 0%,rgba(0,91,53,.08),transparent 60%),linear-gradient(180deg,#fff,#f4faf6);
  --m-shadow:rgba(0,91,53,.22);
}
.marca-card--sector{
  --m-color:#1f4280;
  --m-bg:radial-gradient(circle at 50% 0%,rgba(31,66,128,.08),transparent 60%),linear-gradient(180deg,#fff,#f5f7fc);
  --m-shadow:rgba(31,66,128,.22);
}
.marca-card--verisure{
  --m-color:#e60000;
  --m-bg:radial-gradient(circle at 50% 0%,rgba(230,0,0,.08),transparent 60%),linear-gradient(180deg,#fff,#fff6f6);
  --m-shadow:rgba(230,0,0,.22);
}

/* Responsive: 7 → 4 → 3 → 2 columnas */
@media (max-width:1100px){.marcas-grid{grid-template-columns:repeat(4,1fr);gap:16px}}
@media (max-width:760px){.marcas-grid{grid-template-columns:repeat(3,1fr);gap:14px}.marca-card{padding:18px 12px 16px;min-height:115px}.marca-card img{max-height:38px}}
@media (max-width:480px){.marcas-grid{grid-template-columns:repeat(2,1fr)}}

/* ── Tarjeta de marca premium ── */
.marca-tarjeta{
  background:#fff;border:1px solid var(--gris-2);border-radius:var(--radio-lg);
  padding:26px 24px;box-shadow:var(--sombra-sm);
  display:flex;flex-direction:column;gap:14px;
  transition:all var(--transicion);
  position:relative;overflow:hidden;
}
.marca-tarjeta::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--acento),var(--acento-2));
}
.marca-tarjeta:hover{transform:translateY(-4px);box-shadow:var(--sombra-lg)}
.marca-tarjeta__head{display:flex;align-items:center;gap:16px;border-bottom:1px solid var(--gris-2);padding-bottom:16px;padding-top:6px}
.marca-tarjeta__head img{max-height:56px;width:auto;object-fit:contain}
.marca-tarjeta__head h3{margin:0;color:var(--azul-noche);font-size:1.18rem;flex-grow:1}
.marca-tarjeta__head .puntuacion{text-align:right;font-size:.78rem;color:var(--texto-suave);line-height:1.3}
.marca-tarjeta__head .puntuacion strong{display:block;color:var(--acento);font-size:1.18rem;letter-spacing:-.02em}
.marca-tarjeta p{margin:0;color:var(--texto-suave);font-size:.95rem;line-height:1.65}
.marca-tarjeta .marca-cta{margin-top:auto;padding-top:8px;font-weight:700;color:var(--azul-acero-2);font-size:.92rem;display:inline-flex;align-items:center;gap:5px}

/* ── Testimonios ── */
.testi{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.testi__item{
  background:rgba(255,255,255,.04);
  border-radius:var(--radio-lg);padding:28px 26px;
  border:1px solid rgba(255,255,255,.08);
  backdrop-filter:blur(8px);
}
.testi__estrellas{display:flex;gap:1px;color:var(--acento);margin-bottom:14px}
.testi__txt{font-style:italic;color:#cfdaea;margin-bottom:14px;font-size:.96rem;line-height:1.65}
.testi__autor{font-weight:700;color:#fff;font-size:.94rem}
.testi__autor span{display:block;color:#9eb2cf;font-weight:500;font-size:.82rem;margin-top:2px}
@media (max-width:880px){.testi{grid-template-columns:1fr}}

/* ── Enlazado interno (grid de tarjetas-enlace) ── */
.links-internos{display:grid;grid-template-columns:repeat(3,1fr);gap:12px 20px}
.links-internos a{
  display:flex;align-items:center;gap:8px;
  padding:13px 16px;border-radius:11px;background:#fff;border:1px solid var(--gris-2);
  font-weight:600;color:var(--azul-noche);font-size:.93rem;
  transition:all var(--transicion-rapida);
}
.links-internos a:hover{border-color:var(--azul-acero-2);background:var(--gris-0);transform:translateX(3px);color:var(--azul-acero-2);box-shadow:var(--sombra-xs)}
@media (max-width:880px){.links-internos{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.links-internos{grid-template-columns:1fr}}

/* ── Bloque madre (artículos) ── */
.bloque-madre{
  background:transparent;
}
.bloque-madre h2{
  position:relative;padding-bottom:14px;margin-bottom:20px;
  color:var(--azul-noche);
}
.bloque-madre h2::after{
  content:"";position:absolute;left:0;bottom:0;width:50px;height:3px;
  background:linear-gradient(90deg,var(--acento),var(--azul-acero-2));border-radius:3px;
}
.bloque-madre p{font-size:1rem;line-height:1.75;margin-bottom:16px;color:var(--texto)}
.bloque-madre p:last-child{margin-bottom:0}

/* ── Bloque destacado azul de stats (home "Cómo trabajamos") ── */
.duo-stats-box{
  background:linear-gradient(135deg,var(--azul-acero-2),var(--azul-noche));
  border-radius:24px;padding:38px;color:#fff;box-shadow:var(--sombra-xl);
}
.duo-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.duo-stat-card{
  background:rgba(255,255,255,.08);border-radius:14px;padding:20px;text-align:center;
  border:1px solid rgba(255,255,255,.06);
}
.duo-stat-card strong{
  font-size:2.2rem;display:block;color:var(--acento);letter-spacing:-.02em;line-height:1.05;margin-bottom:4px;
}
.duo-stat-card span{font-size:.85rem;color:#cdd9ee;line-height:1.45}
.duo-stats-box > p{margin:24px 0 0;color:#cdd9ee;font-size:.95rem;line-height:1.6}
@media (max-width:480px){
  .duo-stats-box{padding:24px}
  .duo-stat-card strong{font-size:1.8rem}
}

/* ── Pasos de instalación ── */
.pasos-instalacion{list-style:none;padding:0;counter-reset:step}
.pasos-instalacion li{
  position:relative;padding:24px 24px 24px 80px;
  background:#fff;border:1px solid var(--gris-2);border-radius:14px;
  margin-bottom:16px;box-shadow:var(--sombra-xs);
  counter-increment:step;
}
.pasos-instalacion li::before{
  content:counter(step);
  position:absolute;left:22px;top:24px;width:42px;height:42px;border-radius:50%;
  background:linear-gradient(135deg,var(--azul-acero-2),var(--azul-noche));
  color:#fff;display:grid;place-items:center;font-weight:800;font-size:1.1rem;
  box-shadow:0 6px 14px rgba(28,79,143,.28);
}
.pasos-instalacion h4{color:var(--azul-noche);margin:0 0 8px;font-size:1.08rem}
.pasos-instalacion p{margin:0;color:var(--texto-suave);font-size:.96rem;line-height:1.65}

/* ── Aviso ── */
.aviso{
  background:linear-gradient(135deg,#fffbe8,#fff5d1);
  border-left:4px solid var(--acento);
  padding:18px 22px;border-radius:12px;color:#5a4500;font-size:.95rem;
  margin:28px 0;box-shadow:var(--sombra-xs);
}
.aviso strong{color:#3a2d00}

/* ── Footer ── */
.footer{
  background:linear-gradient(180deg,var(--azul-noche-2),#04101c);
  color:#cad6ea;padding:64px 0 26px;font-size:.93rem;
}
.footer a{color:#dee6f5}
.footer a:hover{color:var(--acento-2);text-decoration:underline}
.footer__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:42px;margin-bottom:42px}
.footer__brand{display:inline-block;margin-bottom:18px}
.footer__logo{
  width:auto;height:54px;max-height:54px;display:block;
  filter:drop-shadow(0 4px 14px rgba(0,0,0,.35));
  transition:transform var(--transicion-rapida),filter var(--transicion-rapida);
}
.footer__brand:hover .footer__logo{transform:scale(1.04);filter:drop-shadow(0 6px 18px rgba(255,179,2,.32))}
.footer h4{color:#fff;font-size:1rem;margin-bottom:14px;letter-spacing:.01em}
.footer ul{list-style:none;padding:0;margin:0}
.footer ul li{margin:8px 0}
.footer .brand{color:#fff;margin-bottom:16px}
.footer__legal{
  border-top:1px solid rgba(255,255,255,.08);padding-top:22px;
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:14px;
  color:#9eb0cc;font-size:.82rem;
}
.footer__legal a{color:#cad6ea}
@media (max-width:880px){.footer__grid{grid-template-columns:1fr 1fr;gap:30px}}
@media (max-width:560px){.footer__grid{grid-template-columns:1fr}}

/* ──────────────────────────────────────────────────
   BANNER DE COOKIES · diseño premium glassmorphism
   ────────────────────────────────────────────────── */
.cookies-banner{
  position:fixed;left:16px;right:16px;bottom:16px;z-index:9999;
  max-width:1080px;margin:0 auto;
  background:linear-gradient(135deg,rgba(255,255,255,.92) 0%,rgba(255,255,255,.86) 100%);
  -webkit-backdrop-filter:saturate(180%) blur(22px);
  backdrop-filter:saturate(180%) blur(22px);
  border:1px solid rgba(255,255,255,.5);
  border-radius:20px;
  box-shadow:
    0 30px 80px rgba(11,31,58,.30),
    0 12px 28px rgba(11,31,58,.14),
    inset 0 1px 0 rgba(255,255,255,.7);
  padding:18px 22px;
  animation:cookiesUp .55s cubic-bezier(.4,0,.2,1) backwards;
  isolation:isolate;
}
.cookies-banner::before{
  content:"";position:absolute;inset:0;border-radius:inherit;z-index:-1;
  background:linear-gradient(135deg,rgba(255,179,2,.06) 0%,transparent 50%,rgba(28,79,143,.06) 100%);
  pointer-events:none;
}
@keyframes cookiesUp{
  from{opacity:0;transform:translateY(40px) scale(.96)}
  to{opacity:1;transform:translateY(0) scale(1)}
}

.cookies-banner__inner{
  display:flex;gap:18px;align-items:center;flex-wrap:wrap;
}

.cookies-banner__icono{
  width:42px;height:42px;flex-shrink:0;
  color:var(--acento);
  filter:drop-shadow(0 4px 10px rgba(255,179,2,.35));
  animation:cookieSpin 14s linear infinite;
}
@keyframes cookieSpin{
  from{transform:rotate(0)}
  to{transform:rotate(360deg)}
}
@media (prefers-reduced-motion:reduce){
  .cookies-banner__icono{animation:none}
  .cookies-banner{animation:none}
}

.cookies-banner__txt{
  flex:1 1 320px;min-width:0;
  font-size:.92rem;line-height:1.5;color:var(--texto-suave);
}
.cookies-banner__txt strong{
  display:block;color:var(--azul-noche);font-weight:800;
  font-size:1rem;margin-bottom:3px;letter-spacing:-.01em;
}
.cookies-banner__txt span{display:block}
.cookies-banner__txt a{color:var(--azul-acero-2);font-weight:600;text-decoration:underline;text-underline-offset:2px}
.cookies-banner__txt a:hover{color:var(--azul-noche)}

.cookies-banner__btns{
  display:flex;gap:8px;align-items:center;flex-wrap:nowrap;
}

.cookies-banner__btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:10px 18px;border-radius:11px;font-weight:700;font-size:.88rem;
  border:1.5px solid transparent;cursor:pointer;
  transition:all .22s cubic-bezier(.4,0,.2,1);
  white-space:nowrap;font-family:inherit;line-height:1.1;
}
.cookies-banner__btn--ghost{
  background:rgba(255,255,255,.6);color:var(--texto-suave);border-color:var(--gris-3);
}
.cookies-banner__btn--ghost:hover{
  background:#fff;color:var(--azul-noche);border-color:var(--azul-noche);
  transform:translateY(-1px);
}
.cookies-banner__btn--primary{
  background:linear-gradient(135deg,var(--acento-2),var(--acento));
  color:#1a1300;border-color:transparent;
  box-shadow:0 8px 18px rgba(255,179,2,.36),inset 0 1px 0 rgba(255,255,255,.35);
}
.cookies-banner__btn--primary:hover{
  box-shadow:0 12px 24px rgba(255,179,2,.45),inset 0 1px 0 rgba(255,255,255,.35);
  transform:translateY(-2px);
}

.cookies--hidden{display:none!important}

/* ───── Tablet (820px) ───── */
@media (max-width:820px){
  .cookies-banner{
    left:12px;right:12px;bottom:12px;
    padding:14px 16px;border-radius:18px;
  }
  .cookies-banner__inner{gap:14px}
  .cookies-banner__icono{width:34px;height:34px}
  .cookies-banner__txt{font-size:.86rem}
  .cookies-banner__txt strong{font-size:.94rem}
  .cookies-banner__btn{padding:9px 14px;font-size:.84rem}
}

/* ───── Móvil (640px) — ULTRA SUTIL ───── */
@media (max-width:640px){
  .cookies-banner{
    left:10px;right:10px;bottom:10px;
    padding:12px 14px;border-radius:16px;
    box-shadow:0 14px 32px rgba(11,31,58,.22),0 5px 12px rgba(11,31,58,.10);
  }
  .cookies-banner__inner{
    display:grid;
    grid-template-columns:auto 1fr;
    grid-template-areas:
      "icono texto"
      "btns btns";
    gap:10px 12px;align-items:center;
  }
  .cookies-banner__icono{
    grid-area:icono;width:32px;height:32px;
  }
  .cookies-banner__txt{
    grid-area:texto;font-size:.78rem;line-height:1.4;
    display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
    overflow:hidden;
  }
  .cookies-banner__txt strong{font-size:.84rem;margin-bottom:1px}
  .cookies-banner__txt span{font-size:.74rem}
  .cookies-banner__txt span a{font-size:.74rem}

  .cookies-banner__btns{
    grid-area:btns;
    display:flex;gap:6px;justify-content:flex-end;align-items:center;
    border-top:1px solid var(--gris-2);padding-top:9px;
  }
  .cookies-banner__btn{padding:8px 14px;font-size:.78rem;border-radius:9px}

  /* "Configurar" oculto en móvil (accesible desde footer) */
  #ck-config{display:none}

  /* "Rechazar" estilo text-link ultra sutil */
  #ck-rechazar{
    background:transparent;border:0;box-shadow:none;
    color:var(--texto-suave);font-weight:600;
    padding:6px 10px;font-size:.76rem;text-decoration:underline;text-underline-offset:3px;
  }
  #ck-rechazar:hover{background:transparent;color:var(--azul-noche);transform:none;border:0}

  /* "Aceptar" botón principal compacto */
  #ck-aceptar{padding:9px 18px;font-size:.82rem;flex-shrink:0}

  /* Evitar tapar la sticky-cta inferior */
  body:has(.sticky-cta) .cookies-banner{bottom:84px}
}

/* ───── Móvil pequeño (380px) ───── */
@media (max-width:380px){
  .cookies-banner{left:8px;right:8px;bottom:8px;padding:10px 12px;border-radius:14px}
  .cookies-banner__icono{width:28px;height:28px}
  .cookies-banner__txt strong{font-size:.78rem}
  .cookies-banner__txt span{font-size:.7rem;-webkit-line-clamp:2}
  #ck-aceptar{padding:8px 14px;font-size:.78rem}
  #ck-rechazar{padding:4px 8px;font-size:.72rem}
}

/* ── Modal de configuración avanzada de cookies ── */
.cookies-modal{
  position:fixed;inset:0;z-index:10000;
  display:grid;place-items:center;padding:20px;
  animation:cookiesFade .25s ease backwards;
}
@keyframes cookiesFade{from{opacity:0}to{opacity:1}}
.cookies-modal__backdrop{
  position:absolute;inset:0;background:rgba(10,25,41,.65);
  backdrop-filter:blur(4px);
}
.cookies-modal__inner{
  position:relative;z-index:1;
  background:#fff;border-radius:20px;padding:32px 28px 26px;
  max-width:540px;width:100%;
  box-shadow:var(--sombra-xl);
  max-height:calc(100vh - 40px);overflow-y:auto;
}
.cookies-modal__inner h3{
  font-size:1.4rem;color:var(--azul-noche);margin-bottom:8px;
}
.cookies-modal__inner > p{
  color:var(--texto-suave);font-size:.95rem;margin-bottom:20px;
}
.cookies-modal__close{
  position:absolute;top:14px;right:18px;
  width:36px;height:36px;border-radius:50%;
  background:var(--gris-1);color:var(--azul-noche);
  font-size:1.4rem;font-weight:700;line-height:1;
  display:grid;place-items:center;cursor:pointer;border:0;
  transition:background var(--transicion-rapida);
}
.cookies-modal__close:hover{background:var(--gris-2)}
.cookies-opcion{
  background:var(--gris-0);border:1px solid var(--gris-2);
  border-radius:12px;padding:14px 16px;margin-bottom:10px;
}
.cookies-opcion label{
  display:flex;align-items:flex-start;gap:12px;cursor:pointer;
  font-size:.95rem;color:var(--texto);line-height:1.5;
}
.cookies-opcion input[type="checkbox"]{
  width:20px;height:20px;flex-shrink:0;margin-top:1px;accent-color:var(--azul-acero-2);
}
.cookies-opcion strong{color:var(--azul-noche);font-weight:700;display:inline-block;margin-right:6px}
.cookies-opcion span{display:block;color:var(--texto-suave);font-size:.85rem;margin-top:4px}
.cookies-modal__btns{
  display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap;margin-top:18px;
}
.cookies-modal__btns .btn{padding:11px 18px;font-size:.92rem}
@media (max-width:560px){
  .cookies-modal__inner{padding:26px 20px 20px;border-radius:16px}
  .cookies-modal__btns{flex-direction:column-reverse}
  .cookies-modal__btns .btn{width:100%}
}

/* ── Sticky CTA móvil ── */
.sticky-cta{
  display:none;position:fixed;bottom:14px;left:14px;right:14px;z-index:60;
}
.sticky-cta a{
  flex:1;display:flex;align-items:center;justify-content:center;gap:8px;
  padding:16px;border-radius:14px;font-weight:700;font-size:.98rem;
  color:#1a1300;background:linear-gradient(180deg,var(--acento-2),var(--acento));
  box-shadow:0 14px 32px rgba(255,179,2,.45),0 4px 10px rgba(0,0,0,.12);
}
@media (max-width:920px){
  .sticky-cta{display:flex}
  body{padding-bottom:90px}
}

/* ── Centro de página (gracias) ── */
.center-page{
  min-height:65vh;display:grid;place-items:center;text-align:center;padding:60px 24px;
}
.center-page h1{font-size:clamp(2rem,5vw,3.2rem);color:var(--azul-noche)}
.center-page p{color:var(--texto-suave);max-width:580px;margin:0 auto 22px;font-size:1.05rem;line-height:1.7}

/* ── Página 404 PREMIUM ── */
.error-404{
  position:relative;padding:60px 0 80px;
  background:linear-gradient(180deg,var(--gris-0) 0%,#fff 60%);
  overflow:hidden;
}
.error-404::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(circle at 85% 8%,rgba(255,179,2,.08),transparent 40%),
    radial-gradient(circle at 12% 92%,rgba(28,79,143,.06),transparent 45%);
}
.error-404 > .wrap{position:relative;z-index:1;max-width:1100px;text-align:center}

.error-404__visual{
  display:inline-flex;align-items:center;justify-content:center;gap:28px;
  margin:0 auto 32px;position:relative;
}
.error-404__shield{
  width:120px;height:120px;border-radius:32px;
  background:linear-gradient(135deg,var(--azul-acero-2),var(--azul-noche));
  display:grid;place-items:center;color:#fff;
  box-shadow:0 22px 50px rgba(11,31,58,.30),inset 0 1px 0 rgba(255,255,255,.18);
  position:relative;
  animation:float404 5s ease-in-out infinite;
}
.error-404__shield::after{
  content:"";position:absolute;top:30%;left:-12px;right:-12px;height:3px;
  background:linear-gradient(90deg,transparent,var(--rojo) 35%,var(--rojo) 65%,transparent);
  transform:rotate(-18deg);border-radius:3px;
  box-shadow:0 2px 8px rgba(226,59,59,.4);
}
.error-404__shield .ico{width:62px;height:62px;stroke-width:1.4;color:#fff;opacity:.9}
.error-404__code{
  font-size:clamp(4rem,12vw,7rem);font-weight:800;color:var(--azul-noche);
  letter-spacing:-.04em;line-height:1;
  background:linear-gradient(180deg,var(--azul-noche),var(--azul-acero-2));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
@keyframes float404{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-8px)}
}

.error-404__content{max-width:740px;margin:0 auto}
.error-404__content h1{
  font-size:clamp(1.8rem,4vw,2.8rem);color:var(--azul-noche);
  margin-bottom:14px;
}
.error-404__content .lead{margin:0 auto 28px;font-size:1.06rem}

.error-404__cta{
  display:flex;justify-content:center;gap:14px;flex-wrap:wrap;margin-bottom:38px;
}

.error-404__buscador{
  max-width:560px;margin:0 auto;
  background:#fff;border:1px solid var(--gris-2);border-radius:20px;
  padding:24px 26px;box-shadow:var(--sombra-sm);
  text-align:left;
}
.error-404__buscador label{
  display:block;font-weight:700;color:var(--azul-noche);font-size:.95rem;margin-bottom:10px;
}
.error-404__search-wrap{position:relative}
.error-404__buscador input{
  width:100%;padding:14px 16px 14px 46px;border:1.5px solid var(--gris-3);
  border-radius:11px;font-size:1rem;
  background:#fff url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231c4f8f' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><circle cx='11' cy='11' r='7'/><line x1='21' y1='21' x2='16.65' y2='16.65'/></svg>") no-repeat 16px center;
  background-size:18px;
}
.error-404__buscador input:focus{outline:none;border-color:var(--azul-acero-2);box-shadow:0 0 0 4px rgba(28,79,143,.13)}

.error-404__sugerencias{
  margin-top:12px;background:var(--gris-0);border-radius:12px;overflow:hidden;
  border:1px solid var(--gris-2);
  max-height:340px;overflow-y:auto;
}
.error-404__sugerencias a{
  display:block;padding:12px 16px;border-bottom:1px solid var(--gris-2);
  text-decoration:none;transition:background var(--transicion-rapida);
}
.error-404__sugerencias a:last-child{border-bottom:0}
.error-404__sugerencias a:hover{background:#fff}
.error-404__sugerencias a strong{display:block;color:var(--azul-noche);font-size:.96rem}
.error-404__sugerencias a span{display:block;color:var(--texto-suave);font-size:.82rem;margin-top:2px}

.error-404__populares{margin-top:60px}
.error-404__populares h2{
  font-size:1.5rem;color:var(--azul-noche);margin-bottom:24px;
}
.error-404__populares .card{text-decoration:none;color:inherit;text-align:left}

@media (max-width:680px){
  .error-404__visual{gap:18px;margin-bottom:24px}
  .error-404__shield{width:88px;height:88px;border-radius:22px}
  .error-404__shield .ico{width:44px;height:44px}
  .error-404__code{font-size:4rem}
  .error-404__buscador{padding:18px 20px}
}

/* ── Localidades (columna múltiple) ── */
.localidades{column-count:4;column-gap:30px;margin:0;padding:0;list-style:none}
.localidades li{break-inside:avoid;margin-bottom:8px}
.localidades a{font-size:.92rem;color:var(--azul-acero-2)}
.localidades a:hover{color:var(--azul-noche)}
@media (max-width:980px){.localidades{column-count:3}}
@media (max-width:680px){.localidades{column-count:2}}

/* ── Cobertura (página índice) ── */
.cobertura-buscador{
  background:#fff;padding:26px 28px;border-radius:var(--radio-lg);
  box-shadow:var(--sombra);border:1px solid var(--gris-2);
  max-width:680px;margin:0 auto 50px;text-align:left;
}
.cobertura-buscador label{display:block;font-weight:700;color:var(--azul-noche);margin-bottom:8px;font-size:.95rem}
.cobertura-buscador input{
  width:100%;padding:14px 18px 14px 46px;border:1.5px solid var(--gris-3);
  border-radius:11px;font-size:1rem;background:#fff url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231c4f8f' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><circle cx='11' cy='11' r='7'/><line x1='21' y1='21' x2='16.65' y2='16.65'/></svg>") no-repeat 16px center;
  background-size:18px;
}
.cobertura-buscador input:focus{outline:none;border-color:var(--azul-acero-2);box-shadow:0 0 0 4px rgba(28,79,143,.13)}
.cobertura-buscador .meta{display:flex;justify-content:space-between;gap:10px;margin-top:10px;font-size:.85rem;color:var(--texto-suave)}
.cobertura-buscador .meta strong{color:var(--azul-noche)}

.cobertura-ccaa{
  margin-bottom:46px;
}
.cobertura-ccaa > h2{
  padding:18px 0;margin-bottom:0;
  color:var(--azul-noche);border-bottom:2px solid var(--gris-2);
  font-size:1.5rem;
}
.cobertura-provincias{display:grid;grid-template-columns:repeat(2,1fr);gap:30px;margin-top:24px}
@media (max-width:760px){.cobertura-provincias{grid-template-columns:1fr}}
.cobertura-prov{
  background:#fff;border:1px solid var(--gris-2);border-radius:var(--radio-lg);
  padding:24px 26px;box-shadow:var(--sombra-xs);
  transition:box-shadow var(--transicion-rapida);
}
.cobertura-prov:hover{box-shadow:var(--sombra-sm)}
.cobertura-prov h3{
  margin:0 0 14px;font-size:1.12rem;color:var(--azul-noche);
  display:flex;align-items:center;gap:8px;padding-bottom:10px;border-bottom:1px solid var(--gris-2);
}
.cobertura-prov h3 .badge{
  margin-left:auto;background:var(--gris-1);color:var(--texto-suave);
  padding:3px 10px;border-radius:999px;font-size:.74rem;font-weight:700;border:0;
}
.cobertura-prov ul{column-count:2;column-gap:18px;list-style:none;padding:0;margin:0}
.cobertura-prov ul li{break-inside:avoid;margin:4px 0;font-size:.91rem}
.cobertura-prov ul li a{color:var(--azul-acero-2);font-weight:500}
.cobertura-prov ul li a:hover{color:var(--azul-noche);text-decoration:underline}
.cobertura-prov ul li a.alt-link{color:var(--texto-suave);font-size:.78rem;font-weight:500}
.cobertura-prov ul li a.alt-link:hover{color:var(--acento);text-decoration:underline}
.cobertura-prov ul li[hidden]{display:none}
.cobertura-prov[hidden]{display:none}
@media (max-width:480px){.cobertura-prov ul{column-count:1}}

/* ── Utilidades ── */
.text-center{text-align:center}
.mt-0{margin-top:0}.mb-0{margin-bottom:0}
.mt-20{margin-top:20px}.mb-20{margin-bottom:20px}
.muted{color:var(--texto-suave)}
.hide-mobile{display:initial}
@media (max-width:680px){.hide-mobile{display:none}}

/* ── Página de PRECIOS · cajas y tablas premium ── */
.precios-resumen{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:30px 0;
}
.precios-resumen .resumen-card{
  background:#fff;border:1px solid var(--gris-2);border-radius:var(--radio-lg);
  padding:24px;box-shadow:var(--sombra-xs);text-align:center;
  display:flex;flex-direction:column;align-items:center;
  position:relative;overflow:hidden;
  transition:all var(--transicion);
}
.precios-resumen .resumen-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--azul-acero-2),var(--acento));
}
.precios-resumen .resumen-card:hover{transform:translateY(-3px);box-shadow:var(--sombra)}
.precios-resumen .resumen-card .lbl{font-size:.78rem;color:var(--texto-suave);text-transform:uppercase;letter-spacing:.1em;font-weight:700;margin-bottom:8px}
.precios-resumen .resumen-card .num{font-size:1.95rem;font-weight:800;color:var(--azul-noche);letter-spacing:-.02em;line-height:1.05}
.precios-resumen .resumen-card .num small{font-size:1rem;font-weight:600;color:var(--texto-suave);margin-left:2px}
.precios-resumen .resumen-card .desc{font-size:.86rem;color:var(--texto-suave);margin-top:8px;line-height:1.5}
@media (max-width:760px){.precios-resumen{grid-template-columns:1fr;gap:14px}}

.tabla-precios{
  width:100%;border-collapse:separate;border-spacing:0;
  background:#fff;border-radius:var(--radio-lg);overflow:hidden;
  box-shadow:var(--sombra);border:1px solid var(--gris-2);
  font-size:.93rem;
}
.tabla-precios thead th{
  background:linear-gradient(180deg,var(--azul-noche),var(--azul-noche-2));
  color:#fff;font-weight:700;text-align:left;padding:14px 16px;
  font-size:.78rem;letter-spacing:.07em;text-transform:uppercase;
}
.tabla-precios thead th:first-child{border-top-left-radius:var(--radio-lg)}
.tabla-precios thead th:last-child{border-top-right-radius:var(--radio-lg)}
.tabla-precios tbody td{padding:14px 16px;border-bottom:1px solid var(--gris-2);vertical-align:top;line-height:1.5}
.tabla-precios tbody tr:last-child td{border-bottom:0}
.tabla-precios tbody tr:nth-child(even){background:var(--gris-0)}
.tabla-precios tbody tr:hover{background:#fdf6e3}
.tabla-precios .marca-celda{font-weight:700;color:var(--azul-noche);min-width:160px}
.tabla-precios .marca-celda img{max-height:32px;width:auto;margin-bottom:6px;display:block}
.tabla-precios .precio-celda{font-weight:800;color:var(--azul-noche);white-space:nowrap}
.tabla-precios .precio-celda small{font-weight:500;color:var(--texto-suave);display:block;font-size:.78rem;margin-top:2px}
.tabla-precios .total-celda{font-weight:800;color:var(--acento);font-size:1.05rem;white-space:nowrap}
.tabla-precios .pack-celda{color:var(--texto-suave);font-style:italic}
.tabla-precios tbody tr.destacado{background:linear-gradient(90deg,rgba(255,179,2,.08),rgba(255,179,2,.02))!important}
.tabla-precios tbody tr.destacado .marca-celda{position:relative}
.tabla-precios tbody tr.destacado .marca-celda::after{
  content:"Mejor precio";position:absolute;right:8px;top:50%;transform:translateY(-50%);
  background:var(--acento);color:#1a1300;font-size:.65rem;font-weight:800;
  padding:3px 8px;border-radius:6px;letter-spacing:.05em;text-transform:uppercase;
}
.tabla-leyenda{font-size:.82rem;color:var(--texto-suave);margin-top:12px;line-height:1.55}
.tabla-leyenda strong{color:var(--texto)}

.precios-bloque{
  background:#fff;border:1px solid var(--gris-2);border-radius:var(--radio-lg);
  padding:30px 32px;box-shadow:var(--sombra-xs);margin-bottom:22px;
}
.precios-bloque > h3{
  color:var(--azul-noche);margin:0 0 6px;font-size:1.32rem;
  display:flex;align-items:center;gap:10px;
}
.precios-bloque > h3 .badge-pack{
  font-size:.7rem;background:var(--azul-acero-2);color:#fff;
  padding:4px 10px;border-radius:999px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;
}
.precios-bloque > p.lead{margin-bottom:18px;font-size:.98rem}

.ahorro-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:24px}
.ahorro-card{
  background:#fff;border:1px solid var(--gris-2);border-radius:var(--radio);
  padding:22px 22px 22px 70px;box-shadow:var(--sombra-xs);position:relative;
  transition:all var(--transicion-rapida);
}
.ahorro-card:hover{border-color:var(--acento);box-shadow:var(--sombra)}
.ahorro-card::before{
  content:counter(ahorro);position:absolute;left:18px;top:22px;
  width:38px;height:38px;border-radius:10px;
  background:linear-gradient(135deg,var(--acento-2),var(--acento));
  color:#1a1300;display:grid;place-items:center;font-weight:800;font-size:1.05rem;
  box-shadow:0 6px 14px rgba(255,179,2,.32);
  counter-increment:ahorro;
}
.ahorro-list{counter-reset:ahorro;display:contents}
.ahorro-card h4{margin:0 0 6px;color:var(--azul-noche);font-size:1.02rem}
.ahorro-card p{margin:0;color:var(--texto-suave);font-size:.92rem;line-height:1.6}
@media (max-width:760px){.ahorro-cards{grid-template-columns:1fr}}

.precio-mini-comparacion{
  display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:18px;
}
.precio-mini-comparacion > div{
  background:var(--gris-0);border:1px solid var(--gris-2);
  border-radius:var(--radio);padding:18px;
}
.precio-mini-comparacion h4{margin:0 0 8px;font-size:1rem;color:var(--azul-noche)}
.precio-mini-comparacion .calc{font-size:1.4rem;font-weight:800;color:var(--azul-noche);letter-spacing:-.02em}
.precio-mini-comparacion .calc small{font-size:.82rem;color:var(--texto-suave);font-weight:500;display:block;margin-top:2px}
@media (max-width:560px){.precio-mini-comparacion{grid-template-columns:1fr}}

/* ── REVEAL ON SCROLL (premium dynamics) ── */
@media (prefers-reduced-motion: no-preference){
  .reveal{
    opacity:0;transform:translateY(28px);
    transition:opacity .7s cubic-bezier(.4,0,.2,1),transform .7s cubic-bezier(.4,0,.2,1);
    will-change:opacity,transform;
  }
  .reveal.is-in{opacity:1;transform:translateY(0)}
}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1;transform:none}
}

/* ── Tilt sutil en cards (variables setadas por JS) ── */
@media (hover:hover) and (prefers-reduced-motion: no-preference){
  .card,.marca-card,.precio,.dispositivo{
    transform:perspective(900px) rotateX(var(--tilt-x,0)) rotateY(var(--tilt-y,0));
    transition:transform .35s cubic-bezier(.4,0,.2,1),box-shadow var(--transicion),border-color var(--transicion);
  }
}

/* ── Nav: estados scrolled / oculto ── */
.nav{transition:transform var(--transicion),box-shadow var(--transicion-rapida)}
.nav--scrolled{box-shadow:0 6px 24px rgba(0,0,0,.32)}
.nav--oculto{transform:translateY(-100%)}

/* ── Form button: spinner de loading ── */
.btn-spinner{
  width:16px;height:16px;display:inline-block;vertical-align:-3px;
  border:2px solid rgba(255,255,255,.35);border-top-color:#fff;
  border-radius:50%;animation:btnSpin .8s linear infinite;margin-right:6px;
}
@keyframes btnSpin{to{transform:rotate(360deg)}}
.btn:disabled{opacity:.78;cursor:wait}

/* ── Parallax sutil del hero ── */
.hero::before{transform:translateY(var(--parallax-y,0))}

/* ── Glassmorphism sutil en hero form ── */
.hero__form{
  background:linear-gradient(135deg,rgba(255,255,255,.98),rgba(255,255,255,.94));
  backdrop-filter:saturate(180%) blur(20px);
  -webkit-backdrop-filter:saturate(180%) blur(20px);
}

/* ── Hover refinado en botones acento (brillo dorado) ── */
.btn--acento{position:relative;overflow:hidden}
.btn--acento::before{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background:radial-gradient(circle at var(--mx,50%) var(--my,50%),rgba(255,255,255,.35),transparent 50%);
  opacity:0;transition:opacity var(--transicion);pointer-events:none;
}
.btn--acento:hover::before{opacity:1}

/* ── Card: efecto de glow lateral del color de marca al hover ── */
.marca-card{will-change:transform}

/* ── Animaciones de entrada sutiles ── */
@media (prefers-reduced-motion:no-preference){
  .hero h1,.hero__sub,.hero__cta,.hero__check,.hero__form{
    animation:fadeUp .8s cubic-bezier(.4,0,.2,1) backwards;
  }
  .hero h1{animation-delay:.05s}
  .hero__sub{animation-delay:.15s}
  .hero__cta{animation-delay:.25s}
  .hero__check{animation-delay:.35s}
  .hero__form{animation:fadeIn 1s ease backwards;animation-delay:.2s}
  @keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
  @keyframes fadeIn{from{opacity:0}to{opacity:1}}
}

/* ── Mejoras de accesibilidad ── */
*:focus-visible{outline:3px solid rgba(255,179,2,.4);outline-offset:2px;border-radius:6px}
.btn:focus-visible{outline-offset:4px}

/* ── Selección de texto ── */
::selection{background:var(--azul-acero-2);color:#fff}
