@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@600;700;800&family=Poppins:wght@500;600;700;800&display=swap');
/* =====================================================================
   Casa Domótica — Hoja de estilos global
   ===================================================================== */

:root {
  --azul: #e0337a;
  --azul-osc: #7B3FBE;
  --acento: #e0337a;
  --acento-osc: #c0206a;
  --verde: #7B3FBE;
  --tinta: #0f172a;
  --gris: #475569;
  --gris-cl: #94a3b8;
  --linea: #e2e8f0;
  --fondo: #f8fafc;
  --blanco: #ffffff;
  --sombra: 0 1px 3px rgba(15,23,42,.08), 0 4px 12px rgba(15,23,42,.06);
  --sombra-hover: 0 8px 28px rgba(15,23,42,.14);
  --radio: 14px;
  --ancho: 1120px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  color: var(--tinta);
  background: var(--fondo);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}

img { max-width: 12em; display: block; }

a { color: var(--azul); text-decoration: none; }
a:hover { text-decoration: underline; }

.contenedor { max-width: var(--ancho); margin: 0 auto; padding: 0 20px; }

/* ---------- Cabecera / navegación ---------- */
.cabecera {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255,255,255,.92);
  backdrop-filter: saturate(180%) blur(10px);
  border-bottom: 1px solid var(--linea);
}
.nav {
  display: flex; align-items: center; justify-content: space-between;
  height: 66px;
}
.logo { max-width:12em; }
.logo span { color: var(--azul); }
.logo img { max-width:12em; }
.logo:hover { text-decoration: none; }
.menu { display: flex; gap: 26px; list-style: none; align-items: center; }
.menu a { color: var(--gris); font-weight: 600; font-size: .95rem; }
.menu a:hover { color: var(--azul); text-decoration: none; }
.menu-btn { display: none; background: none; border: 0; font-size: 1.6rem; cursor: pointer; color: var(--tinta); }

@media (max-width: 820px) {
  .menu {
    position: absolute; top: 66px; left: 0; right: 0;
    flex-direction: column; gap: 0; background: var(--blanco);
    border-bottom: 1px solid var(--linea); padding: 8px 0;
    transform: translateY(-150%); transition: transform .25s ease;
  }
  .menu.abierto { transform: translateY(0); }
  .menu li { width: 100%; }
  .menu a { display: block; padding: 12px 20px; }
  .menu-btn { display: block; }
}

/* ---------- Hero ---------- */
.hero {
  background: linear-gradient(135deg, var(--azul-osc), var(--azul));
  color: #fff; padding: 70px 0 80px; text-align: center;
}
.hero h1 { font-size: clamp(1.9rem, 5vw, 3rem); line-height: 1.15; letter-spacing: -.03em; }
.hero p { font-size: 1.15rem; max-width: 640px; margin: 18px auto 0; color: #dbeafe; }
.hero .cta { margin-top: 30px; }

/* ---------- Botones ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-weight: 700; border-radius: 10px; padding: 13px 22px;
  cursor: pointer; border: 0; font-size: 1rem; transition: .18s;
}
.btn:hover { text-decoration: none; transform: translateY(-1px); }
.btn-amazon { background: var(--acento); color: #1a1300; box-shadow: 0 4px 14px rgba(245,158,11,.4); }
.btn-amazon:hover { background: #fbbf24; color:#1a1300; }
.btn-claro { background: #fff; color: var(--azul-osc); }
.btn-line { background: transparent; border: 2px solid #fff; color: #fff; }
.btn-azul { background: var(--azul); color:#fff; }
.btn-azul:hover { background: var(--azul-osc); color:#fff; }

/* ---------- Secciones ---------- */
section { padding: 56px 0; }
.titulo-sec { font-size: clamp(1.5rem,3vw,2rem); text-align:center; letter-spacing:-.02em; }
.subtitulo-sec { text-align:center; color: var(--gris); max-width: 620px; margin: 12px auto 0; }

/* ---------- Rejilla de categorías ---------- */
.grid { display: grid; gap: 22px; margin-top: 38px; }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
@media (max-width: 820px){ .grid-3,.grid-2 { grid-template-columns: 1fr; } }

.tarjeta {
  background: var(--blanco); border: 1px solid var(--linea); border-radius: var(--radio);
  padding: 26px; box-shadow: var(--sombra); transition: .2s; height: 100%;
}
.tarjeta:hover { box-shadow: var(--sombra-hover); transform: translateY(-3px); }
.tarjeta .emoji { font-size: 2.2rem; }
.tarjeta h3 { margin: 12px 0 8px; font-size: 1.2rem; }
.tarjeta p { color: var(--gris); font-size: .96rem; }
.tarjeta a.mas { display:inline-block; margin-top:14px; font-weight:700; }

/* ---------- Contenido editorial ---------- */
.articulo { background:#fff; }
.articulo .contenedor { max-width: 860px; }
.articulo h1 { font-size: clamp(1.7rem,4vw,2.4rem); line-height:1.2; letter-spacing:-.02em; margin-bottom: 10px; }
.articulo h2 { font-size: 1.5rem; margin: 40px 0 14px; letter-spacing:-.01em; }
.articulo h3 { font-size: 1.2rem; margin: 26px 0 10px; }
.articulo p { margin: 14px 0; }
.articulo ul, .articulo ol { margin: 14px 0 14px 22px; }
.articulo li { margin: 6px 0; }
.meta-art { color: var(--gris-cl); font-size: .9rem; margin-bottom: 24px; }

/* ---------- Migas de pan ---------- */
.migas { font-size:.85rem; color: var(--gris-cl); padding: 16px 0; }
.migas a { color: var(--gris); }

/* ---------- Aviso de afiliados ---------- */
.aviso-afi {
  background: #fffbeb; border: 1px solid #fde68a; color: #92400e;
  border-radius: 10px; padding: 12px 16px; font-size: .88rem; margin: 22px 0;
}

/* ---------- Tarjeta de producto (ranking) ---------- */
.producto {
  display: grid; grid-template-columns: 64px 1.4fr 1fr auto; gap: 18px;
  align-items: center; background:#fff; border:1px solid var(--linea);
  border-radius: var(--radio); padding: 22px; margin: 18px 0; box-shadow: var(--sombra);
  position: relative; transition:.2s;
}
.producto:hover { box-shadow: var(--sombra-hover); }
.producto.top { border-color: var(--acento); border-width: 2px; }
.rank {
  width: 46px; height: 46px; border-radius: 50%; background: var(--azul);
  color:#fff; display:flex; align-items:center; justify-content:center;
  font-weight:800; font-size:1.2rem;
}
.producto.top .rank { background: var(--acento); color:#1a1300; }
.badge {
  position:absolute; top:-12px; left:22px; background:var(--acento); color:#1a1300;
  font-size:.72rem; font-weight:800; padding:4px 10px; border-radius:20px; text-transform:uppercase; letter-spacing:.04em;
}
.producto h3 { font-size: 1.15rem; }
.producto .desc { color: var(--gris); font-size:.92rem; margin-top:4px; }
.estrellas { color: var(--acento); letter-spacing:1px; font-size:.95rem; }
.especs { list-style:none; margin:8px 0 0; padding:0; font-size:.86rem; color:var(--gris); }
.especs li::before { content:"✓ "; color: var(--verde); font-weight:700; }
@media (max-width: 760px){
  .producto { grid-template-columns: 46px 1fr; }
  .producto .col-precio { grid-column: 1 / -1; }
}

/* ---------- Tabla comparativa ---------- */
.tabla-wrap { overflow-x:auto; margin: 26px 0; }
table.comparativa { width:100%; border-collapse: collapse; background:#fff; border-radius: var(--radio); overflow:hidden; box-shadow: var(--sombra); font-size:.92rem; }
table.comparativa th, table.comparativa td { padding: 13px 14px; text-align:left; border-bottom:1px solid var(--linea); }
table.comparativa th { background: var(--azul-osc); color:#fff; font-weight:700; }
table.comparativa tr:nth-child(even) td { background:#f8fafc; }
table.comparativa td:first-child { font-weight:700; }

/* ---------- FAQ ---------- */
.faq details {
  background:#fff; border:1px solid var(--linea); border-radius:10px;
  padding: 4px 18px; margin:12px 0; box-shadow: var(--sombra);
}
.faq summary { cursor:pointer; font-weight:700; padding:14px 0; list-style:none; }
.faq summary::-webkit-details-marker { display:none; }
.faq summary::after { content:"+"; float:right; color:var(--azul); font-weight:800; }
.faq details[open] summary::after { content:"–"; }
.faq details p { padding-bottom:14px; color: var(--gris); }

/* ---------- Slot AdSense ---------- */
.ad-slot {
  margin: 30px auto; text-align:center; min-height: 90px;
  display:flex; align-items:center; justify-content:center;
  background: repeating-linear-gradient(45deg,#f1f5f9,#f1f5f9 10px,#f8fafc 10px,#f8fafc 20px);
  border:1px dashed #cbd5e1; border-radius:10px; color:#94a3b8; font-size:.8rem;
}
.ad-slot.activo { background:none; border:0; min-height:auto; }

/* ---------- Pie ---------- */
.pie { background: var(--tinta); color: #cbd5e1; padding: 50px 0 24px; margin-top: 40px; }
.pie-grid { display:grid; grid-template-columns: 2fr 1fr 1fr; gap: 30px; }
@media (max-width:760px){ .pie-grid{ grid-template-columns:1fr; } }
.pie h4 { color:#fff; margin-bottom:12px; font-size:1rem; }
.pie a { color:#cbd5e1; }
.pie a:hover { color:#fff; }
.pie ul { list-style:none; }
.pie ul li { margin:7px 0; }
.pie-bottom { border-top:1px solid #1e293b; margin-top:34px; padding-top:20px; font-size:.85rem; color:#94a3b8; text-align:center; }

/* ---------- Banner de cookies (RGPD) ---------- */
#cookie-banner {
  position: fixed; bottom: 16px; left: 16px; right: 16px; max-width: 620px; margin: 0 auto;
  background: var(--tinta); color:#e2e8f0; padding: 18px 20px; border-radius: 12px;
  box-shadow: 0 10px 40px rgba(0,0,0,.35); z-index: 100; font-size:.9rem; display:none;
}
#cookie-banner.show { display:block; }
#cookie-banner .acciones { margin-top:12px; display:flex; gap:10px; flex-wrap:wrap; }
#cookie-banner button { font-size:.85rem; padding:8px 16px; }

.box-info { background:#eff6ff; border:1px solid #bfdbfe; border-radius:10px; padding:16px 18px; margin:20px 0; }
.centro { text-align:center; }
.mt { margin-top: 30px; }

/* ===== CRO: veredicto rápido + barra fija de compra ===== */
.veredicto-cta{display:flex;align-items:center;justify-content:space-between;gap:18px;
  background:linear-gradient(135deg,#fffbeb,#fef3c7);border:2px solid #f59e0b;border-radius:14px;
  padding:18px 22px;margin:22px 0;flex-wrap:wrap;}
.veredicto-cta .vc-label{display:block;font-size:.78rem;font-weight:800;text-transform:uppercase;
  letter-spacing:.05em;color:#b45309;}
.veredicto-cta strong{font-size:1.22rem;line-height:1.25;}
.veredicto-cta .vc-sub{display:block;color:#92400e;font-size:.9rem;margin-top:2px;}
#sticky-cta{position:fixed;left:0;right:0;bottom:-90px;background:#0f172a;color:#fff;
  display:flex;align-items:center;justify-content:center;gap:16px;padding:10px 16px;z-index:90;
  transition:bottom .3s ease;box-shadow:0 -4px 20px rgba(0,0,0,.25);}
#sticky-cta.show{bottom:0;}
#sticky-cta .btn{padding:9px 18px;font-size:.92rem;white-space:nowrap;}
#sticky-cta .sc-name{font-size:.95rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:46vw;}
@media (max-width:540px){ #sticky-cta .sc-name{display:none;} }

/* =====================================================================
   TEMA: DEPIMIL  (Rosa → Morado · gradiente de marca)
   ===================================================================== */
:root{
  --azul: #e0337a;
  --azul-osc: #7B3FBE;
  --acento: #e0337a;
  --acento-osc: #c0206a;
  --depimil-rosa: #FF3D8B;
  --depimil-morado: #7B3FBE;
  --depimil-grad: linear-gradient(90deg, #FF3D8B, #7B3FBE);
}
body{ font-family: 'Poppins', system-ui, sans-serif; }
h1, h2, h3, h4,
.titulo-sec, .hero h1, .articulo h1, .articulo h2{
  font-family: 'Playfair Display', Georgia, serif;
}
.hero h1{ font-weight: 800; }

/* Logo imagen */
.logo-img {
  height: 44px;
  width: auto;
  display: block;
}
.logo { display: inline-flex; align-items: center; }

/* Hero con gradiente Depimil */
.hero {
  background: var(--depimil-grad);
}

/* Botones principales con color Depimil */
.btn-amazon { background: var(--depimil-grad); color: #fff; box-shadow: 0 4px 14px rgba(255,61,139,.35); }
.btn-amazon:hover { background: linear-gradient(90deg, #ff5fa3, #9055d4); color:#fff; }
.btn-azul { background: var(--depimil-grad); color:#fff; }
.btn-azul:hover { background: linear-gradient(90deg, #ff5fa3, #9055d4); color:#fff; }

/* Ranking / estrellas */
.estrellas { background: var(--depimil-grad); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }

/* Veredicto CTA con colores Depimil */
.veredicto-cta {
  background: linear-gradient(135deg, #fff0f6, #f5eeff);
  border-color: var(--depimil-rosa);
}
.veredicto-cta .vc-label { color: var(--depimil-morado); }
.veredicto-cta .vc-sub { color: #6b21a8; }
