:root{
  --bg0:#FFF7F0;
  --bg1:#FFF3FA;
  --card:#FFFFFF;
  --text:#1f2937;
  --muted:#6b7280;
  --border:rgba(31,41,55,.12);
  --shadow:0 18px 50px rgba(31,41,55,.10);
  --accent:#ff8fb1; /* coral */
  --accent2:#7fb9ff; /* sky */
  --radius:22px;
  --radius-lg:28px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  color:var(--text);
  font:16px/1.55 system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  background:
    radial-gradient(900px 520px at 15% 10%, rgba(255,143,177,.25), transparent 60%),
    radial-gradient(900px 520px at 85% 10%, rgba(127,185,255,.22), transparent 60%),
    radial-gradient(900px 520px at 65% 85%, rgba(233,215,255,.25), transparent 60%),
    linear-gradient(180deg, var(--bg1), var(--bg0));
}

a{color:inherit}
img{max-width:100%; height:auto}
.small{font-size:.94rem; color:var(--muted)}
.notice{padding:10px 12px;border:1px dashed var(--border);border-radius:12px;background:rgba(255,255,255,.75)}
.kicker{
  font-size:.78rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(31,41,55,.55);
  font-weight:700;
}

.container{max-width:1240px;margin:0 auto;padding:0 18px}

.skip{position:absolute;left:-999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip:focus{left:12px;top:12px;width:auto;height:auto;padding:10px 12px;background:#fff;border-radius:12px;box-shadow:var(--shadow);z-index:9999}

.nav{
  position:sticky;
  top:0;
  z-index:20;
  background:rgba(255,255,255,.82);
  backdrop-filter:saturate(130%) blur(10px);
  border-bottom:1px solid var(--border);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 0}
.brand{
  display:flex;align-items:center;gap:12px;
  text-decoration:none;
}
.brand span{font-size:1.55rem;font-weight:900;letter-spacing:.2px}
.logo{
  width:68px;height:68px;border-radius:16px;
  box-shadow:0 10px 26px rgba(31,41,55,.14);
  transform-origin:center;
}
.logo.float{animation:float 4.5s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-3px)}}

.nav-links{display:flex;gap:18px;align-items:center}
.nav-links a{
  text-decoration:none;
  font-weight:700;
  color:rgba(31,41,55,.75);
  padding:8px 10px;
  border-radius:12px;
  transition:transform .18s ease, background .18s ease, color .18s ease;
}
.nav-links a:hover{background:rgba(255,143,177,.14);color:rgba(31,41,55,.95);transform:translateY(-1px)}
.nav-links a:focus-visible{outline:3px solid rgba(127,185,255,.45);outline-offset:2px}

.hero{padding:28px 0 10px}
.hero-banner{
  border-radius:var(--radius-lg);
  background:rgba(255,255,255,.70);
  border:1px solid var(--border);
  box-shadow:var(--shadow);
  overflow:hidden;
}
.hero-banner-inner{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap:18px;
  padding:24px;
  align-items:center;
}
.hero-copy h1{margin:.25rem 0 .6rem;font-size:2.45rem;line-height:1.06;letter-spacing:-.02em}
.lead{margin:0 0 14px;font-size:1.06rem;color:rgba(31,41,55,.78)}
.hero-illus{display:flex;justify-content:center;align-items:center}
.hero-illus img{max-width:100%;filter:drop-shadow(0 18px 38px rgba(31,41,55,.14))}

.btn-row{display:flex;flex-wrap:wrap;gap:10px;margin:10px 0 14px}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.85);
  text-decoration:none;
  font-weight:800;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 14px 30px rgba(31,41,55,.10)}
.btn.primary{
  background:linear-gradient(135deg, rgba(255,143,177,.95), rgba(127,185,255,.95));
  color:#0b0f14;
  border-color:rgba(31,41,55,.10);
}
.btn.primary:hover{box-shadow:0 16px 34px rgba(255,143,177,.22)}
.small-btn{padding:8px 12px;font-size:.92rem}

.search-block{
  margin-top:10px;
  padding:12px 14px;
  border-radius:18px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.70);
}
.search-label{font-weight:900;color:rgba(31,41,55,.78);margin-bottom:8px}
.search input{
  width:100%;
  padding:12px 14px;
  border-radius:16px;
  border:1px solid rgba(31,41,55,.14);
  background:#fff;
  outline:none;
  font-size:1rem;
}
.search input:focus{border-color:rgba(127,185,255,.55);box-shadow:0 0 0 4px rgba(127,185,255,.22)}
.hint{margin-top:8px}

.pill-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.pill{
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(31,41,55,.12);
  background:rgba(255,255,255,.70);
  font-weight:800;
  font-size:.92rem;
  color:rgba(31,41,55,.75);
}

.hero-cards{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:16px;
  margin-top:16px;
}
.card{
  border-radius:var(--radius);
  border:1px solid var(--border);
  background:rgba(255,255,255,.74);
  box-shadow:0 10px 34px rgba(31,41,55,.07);
  padding:18px;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
}
.card:hover{transform:translateY(-3px);box-shadow:0 18px 44px rgba(31,41,55,.10);background:rgba(255,255,255,.86)}
.card:focus-within{outline:3px solid rgba(255,143,177,.32);outline-offset:2px}

.badge{display:inline-flex;align-items:center;gap:8px;font-weight:900;color:rgba(31,41,55,.75)}
.dot{width:8px;height:8px;border-radius:50%;background:var(--accent)}
.bullets{margin:10px 0 0;padding-left:18px}
.bullets li{margin:6px 0}
.cta-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}

.section{padding:26px 0}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}

.post-card{
  position:relative;
  border-radius:var(--radius);
  overflow:hidden;
  border:1px solid var(--border);
  background:rgba(255,255,255,.82);
  box-shadow:0 10px 34px rgba(31,41,55,.06);
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
}
.post-card:hover{transform:translateY(-4px);box-shadow:0 18px 44px rgba(31,41,55,.10)}
.card-link{display:block;text-decoration:none;color:inherit}
.thumb{height:150px;background:linear-gradient(135deg, rgba(255,143,177,.14), rgba(127,185,255,.14))}
.thumb img{width:100%;height:100%;object-fit:cover;display:block}
.post-card .content{padding:14px 14px 16px}
.post-card h3{margin:6px 0 8px;font-size:1.08rem;line-height:1.22}
.post-card .meta{font-size:.86rem;color:rgba(31,41,55,.60);font-weight:800}

.article{max-width:860px;margin:0 auto;padding:28px 18px}
.article h1{line-height:1.12}
.post-hero{margin:14px 0 18px}
.post-hero img{
  width:100%;
  border-radius:var(--radius);
  border:1px solid var(--border);
  background:#fff;
  box-shadow:0 18px 46px rgba(31,41,55,.10);
}

.footer{padding:26px 0;margin-top:18px;border-top:1px solid var(--border);background:rgba(255,255,255,.70)}


.brand:hover .logo{transform:scale(1.04)}
.brand:focus-visible{outline:3px solid rgba(127,185,255,.45);outline-offset:4px;border-radius:16px}

.brand-hero{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.brand-hero-logo{
  width:72px;height:72px;border-radius:18px;
  box-shadow:0 14px 30px rgba(31,41,55,.14);
  animation:float 4.5s ease-in-out infinite;
}
.brand-hero-name{font-size:1.35rem;font-weight:950;letter-spacing:.2px}
.brand-hero-tag{font-size:.86rem;color:rgba(31,41,55,.62);font-weight:800;text-transform:uppercase;letter-spacing:.12em}

.post-card:focus-within{outline:3px solid rgba(127,185,255,.38);outline-offset:2px}
.card-link:focus-visible{outline:none}

.hero-copy h1{font-size:2.1rem}
  .hero-cards{grid-template-columns:1fr}
  .grid{grid-template-columns:1fr}
.logo{width:48px;height:48px}
}


/* Para familias: imagen + interacción */
.pf-illus{
  margin:12px 0 14px;
  border-radius:18px;
  background:linear-gradient(135deg, rgba(253,231,239,.9), rgba(243,232,255,.9));
  padding:14px;
  box-shadow:0 12px 30px rgba(31,41,55,.10);
  overflow:hidden;
}
.pf-illus img{
  width:100%;
  height:auto;
  display:block;
  border-radius:14px;
  transform:translateZ(0);
  transition:transform .25s ease;
}
.card.feature:hover .pf-illus img{
  transform:scale(1.04);
}

.hero-copy h1{font-size:2.1rem}
  .hero-cards{grid-template-columns:1fr}
  .grid{grid-template-columns:1fr}
.logo{width:48px;height:48px}

  /* Mejor contraste en móvil */
  .lead, .small, .hint, .kicker{color:var(--text)}
  .pill{background:rgba(255,255,255,.92); border-color:rgba(31,41,55,.14); color:var(--text)}

  /* Para familias: imagen más contenida en móvil */
  #para-familias .pf-illus{padding:10px}
  #para-familias .pf-illus img{max-height:240px; width:100%; object-fit:contain}
}

@media (max-width: 980px){
  .nav{position:sticky; top:0; z-index:60}
  .nav .container{position:relative}

  /* Header (móvil): marca a la izquierda + botón menú + lista desplegable */
  .nav-inner{flex-direction:row !important; align-items:center !important; justify-content:space-between !important; gap:10px !important; padding:12px 0 !important}
  .nav-toggle{display:inline-flex !important; align-items:center; justify-content:center}
  .nav-links{
    display:none !important;
    position:absolute;
    top:64px;
    right:12px;
    left:auto;
    max-width: calc(100vw - 24px);

    flex-direction:column;
    gap:6px;
    padding:10px;
    background:rgba(255,255,255,.92);
    border:1px solid var(--border);
    border-radius:18px;
    box-shadow:0 14px 34px rgba(31,41,55,.12);
    z-index:50;
  }
  .nav-links a{white-space:nowrap; font-size:1rem; padding:10px 12px; border-radius:14px}
  .nav-links a:hover{background:rgba(243,232,255,.8)}

  /* Layout hero/cards en móvil */
  .hero-banner-inner{grid-template-columns:1fr !important; padding:18px !important}
  .hero-cards{grid-template-columns:1fr !important}
.nav-links::-webkit-scrollbar{display:none}
  .nav-links a{white-space:nowrap; font-size:.98rem; padding:8px 10px}

  /* Mejor contraste en móvil */
  .lead, .small, .hint, .kicker{color:var(--text)}
  .pill{background:rgba(255,255,255,.92); border-color:rgba(31,41,55,.14); color:var(--text)}

  /* Para familias: imagen más contenida en móvil */
  #para-familias .pf-illus{padding:10px}
  #para-familias .pf-illus img{max-height:240px; width:100%; object-fit:contain}
}


/* Afiliados (posts) */
.note.affiliate-note{
  background:rgba(255,255,255,.75);
  border:1px solid var(--border);
  padding:12px 14px;
  border-radius:14px;
  margin:12px 0 16px;
}
.aff-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:14px;
  margin:14px 0 18px;
}
.aff-card{
  background:rgba(255,255,255,.82);
  border:1px solid var(--border);
  border-radius:18px;
  padding:14px;
  box-shadow:0 12px 28px rgba(31,41,55,.08);
}
.aff-card h3{font-size:1.02rem; margin:8px 0 8px}
.aff-top{display:flex; align-items:center; justify-content:space-between; gap:10px}
.aff-price{font-weight:800; color:rgba(31,41,55,.9)}
.muted{color:rgba(31,41,55,.68)}
.table-wrap{overflow:auto; border-radius:16px; border:1px solid var(--border); background:rgba(255,255,255,.75)}
.aff-table{width:100%; border-collapse:separate; border-spacing:0}
.aff-table th, .aff-table td{padding:12px 12px; text-align:left; vertical-align:top}
.aff-table thead th{font-size:.92rem; color:rgba(31,41,55,.7); background:rgba(255,255,255,.75)}
.aff-table tbody tr + tr td{border-top:1px solid var(--border)}
.price{font-weight:800; white-space:nowrap}
.smallbtn{padding:8px 10px; border-radius:12px; font-size:.95rem}
.tag{display:inline-flex; align-items:center; gap:6px; padding:6px 10px; border-radius:999px; font-weight:800; font-size:.82rem}
.tag-economica{background:rgba(253,231,239,.95); border:1px solid rgba(245,158,190,.55)}
.tag-recomendada{background:rgba(243,232,255,.95); border:1px solid rgba(167,139,250,.55)}
.tag-premium{background:rgba(224,242,254,.95); border:1px solid rgba(56,189,248,.55)}

@media (max-width: 980px){
  .aff-grid{grid-template-columns:1fr}
}


/* Luces: picks y alineación CTA */
.pick-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:14px;
  margin:14px 0 18px;
}
.pick-card{
  display:flex;
  gap:12px;
  background:rgba(255,255,255,.82);
  border:1px solid var(--border);
  border-radius:18px;
  padding:14px;
  box-shadow:0 12px 28px rgba(31,41,55,.08);
}
.pick-media{
  width:84px; flex:0 0 84px;
  display:flex; align-items:center; justify-content:center;
  background:rgba(255,255,255,.7);
  border:1px solid var(--border);
  border-radius:16px;
  overflow:hidden;
}
.pick-media img{width:72px;height:72px}
.pick-body{display:flex; flex-direction:column; min-height:160px; width:100%}
.pick-top{display:flex; align-items:center; justify-content:space-between; gap:10px}
.pick-price{font-weight:900; white-space:nowrap}
.pick-btn{margin-top:auto}

/* Tabla comparativa con thumbnails */
.aff-table .thumb{width:72px}
.aff-table .thumb img{width:56px; height:56px; display:block}
/* Alinea botones de la tabla (misma altura) */
.aff-table a.btn{display:inline-flex; align-items:center; justify-content:center; min-height:40px}

/* Alinea botones de tarjetas (misma altura) */
.aff-card{display:flex; flex-direction:column}
.aff-card .btn{margin-top:auto; min-height:44px; display:inline-flex; align-items:center; justify-content:center}

@media (max-width: 980px){
  .pick-grid{grid-template-columns:1fr}
  .pick-media{width:72px; flex:0 0 72px}
  .pick-media img{width:60px;height:60px}
}

/* Luces: imágenes de producto */
.aff-media{
  width:100%;
  background:rgba(255,255,255,.7);
  border:1px solid var(--border);
  border-radius:16px;
  overflow:hidden;
  margin:10px 0 10px;
}
.aff-media img{
  width:100%;
  height:170px;
  object-fit:contain;
  display:block;
}
.pick-media img{
  object-fit:contain;
  background:#fff;
}
@media (max-width: 980px){
  .aff-media img{height:160px}
}


/* Mobile nav toggle */
.nav-toggle{
  display:none;
  border:1px solid var(--border);
  background:rgba(255,255,255,.72);
  border-radius:14px;
  padding:10px 12px;
  font-size:18px;
  line-height:1;
}
.nav-links.is-open{
  display:flex !important;
}

/* Evita scroll horizontal en móvil */
html, body{overflow-x:hidden}
img, svg{max-width:100%; height:auto}

/* Mobile overrides (authoritative) */
@media (max-width: 1100px){
  .nav .container{position:relative}
  .nav-inner{flex-direction:row !important; align-items:center !important; justify-content:space-between !important; gap:10px !important; padding:12px 0 !important}
  .nav-toggle{display:inline-flex !important; margin-left:auto !important}
  .nav-links{
    display:none !important;
    position:absolute !important;
    top:64px !important;
    left:16px !important;
    right:16px !important;
    flex-direction:column !important;
    gap:6px !important;
    padding:10px !important;
    background:rgba(255,255,255,.92) !important;
    border:1px solid var(--border) !important;
    border-radius:18px !important;
    box-shadow:0 14px 34px rgba(31,41,55,.12) !important;
    z-index:80 !important;
  }
  .nav-links.is-open{display:flex !important}
  .nav-links a{white-space:nowrap !important}

  /* Hero: apila (para que "Para familias" quede debajo) */
  .hero-banner-inner{display:flex !important; flex-direction:column !important; gap:16px !important}
  #para-familias{order:2 !important}
  .hero-copy{order:1 !important}
}


/* --- V14 additions --- */
.work-list{margin:10px 0 0; padding-left:18px}
.work-list li{margin:6px 0}

.carousel{margin-top:14px}
.carousel-card{
  border:1px solid rgba(0,0,0,.08);
  border-radius:18px;
  padding:18px;
  background: rgba(255,255,255,.65);
  box-shadow: 0 12px 28px rgba(0,0,0,.08);
}
.carousel-dots{display:flex; gap:8px; margin-top:12px}
.carousel-dots .dot{
  width:10px; height:10px; border-radius:999px;
  border:1px solid rgba(0,0,0,.18);
  background: transparent;
}
.carousel-dots .dot.is-active{background: rgba(0,0,0,.45)}

/* Prevent page horizontal scrolling on mobile */
html, body{max-width:100%; overflow-x:hidden; overscroll-behavior-x:none}
body{touch-action: pan-y}

.table-wrap{overflow-x:auto; max-width:100%; -webkit-overflow-scrolling:touch}
.cmp-table{width:100%; border-collapse:collapse; min-width:760px}
.cmp-table th, .cmp-table td{border:1px solid rgba(0,0,0,.08); padding:10px; text-align:center; background: rgba(255,255,255,.75)}
.cmp-table thead th{background: rgba(255,255,255,.9); font-weight:700}
.cmp-prod{padding:10px; text-align:left}
.cmp-prod-inner{display:flex; gap:10px; align-items:center}
.cmp-prod-inner img{width:52px; height:52px; object-fit:cover; border-radius:12px; border:1px solid rgba(0,0,0,.08)}
.cmp-tag{font-size:12px; color:#6b7280}
.cmp-name a{text-decoration:none}
.cmp-name a:hover{text-decoration:underline}

img, video{max-width:100%; height:auto}



/* Prevent horizontal scroll on mobile */
html, body { overflow-x: hidden; }
.nav-open body { overflow: hidden; }

/* Carousel */
.carousel{margin-top:12px}
.carousel-card{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);background:rgba(255,255,255,.82);box-shadow:0 12px 36px rgba(31,41,55,.08)}
.carousel-dots{display:flex;gap:8px;justify-content:center;margin-top:10px}
.carousel-dots .dot{width:10px;height:10px;border-radius:999px;border:1px solid rgba(31,41,55,.25);background:rgba(255,255,255,.8);cursor:pointer}
.carousel-dots .dot.active{background:rgba(255,143,177,.75);border-color:rgba(255,143,177,.9)}

/* Productos (cards compactas) */
.prod-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:14px}
@media (max-width: 820px){.prod-grid{grid-template-columns:1fr}}
.prod-card{display:flex;gap:12px;align-items:flex-start;border:1px solid var(--border);background:rgba(255,255,255,.82);border-radius:var(--radius);padding:12px;box-shadow:0 10px 30px rgba(31,41,55,.06)}
.prod-card img{width:72px;height:72px;border-radius:14px;object-fit:cover;flex:0 0 auto;border:1px solid rgba(31,41,55,.10);background:#fff}
.prod-meta{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.prod-meta .tag{font-weight:900;font-size:.78rem}
.prod-meta .price{font-weight:900;font-size:.82rem;color:rgba(31,41,55,.78)}
.prod-card h3{margin:6px 0 6px;font-size:1.0rem;line-height:1.18}
.prod-card p{margin:0 0 10px}
.prod-card .btn{padding:8px 10px;font-size:.86rem}

/* Tabla pros/contras (compacta) */
.matrix{width:100%;border-collapse:separate;border-spacing:0;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:rgba(255,255,255,.82)}
.matrix th,.matrix td{padding:8px 8px;border-bottom:1px solid rgba(31,41,55,.08);border-right:1px solid rgba(31,41,55,.08);font-size:.88rem}
.matrix th:last-child,.matrix td:last-child{border-right:none}
.matrix tr:last-child td{border-bottom:none}
.matrix thead th{background:rgba(255,143,177,.10);font-weight:900;vertical-align:bottom}
.matrix .c{ text-align:center; font-weight:900 }
.matrix .pcell{display:flex;gap:10px;align-items:center}
.matrix .pcell img{width:36px;height:36px;border-radius:10px;object-fit:cover;border:1px solid rgba(31,41,55,.10);background:#fff}
.matrix .pname{font-weight:900;line-height:1.15}
.matrix .ptype{font-size:.78rem;color:rgba(31,41,55,.60);font-weight:900}


@media (min-width: 981px){
  .matrix-wrap{margin-left:-18px;margin-right:-18px}
  .matrix td:first-child{width:340px}
  .matrix .pname{white-space:normal}
}
.matrix-note{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.matrix-note .pill{margin:0}

@media (max-width: 980px){
  .matrix-wrap{display:none}
  .matrix-mobile{display:block}
}
@media (min-width: 981px){
  .matrix-mobile{display:none}
}


.matrix-mobile .mcards{display:flex;flex-direction:column;gap:12px;margin-top:10px}
.matrix-mobile .mcard{border:1px solid var(--border);border-radius:var(--radius);background:rgba(255,255,255,.82);box-shadow:var(--shadow);padding:12px}
.matrix-mobile .mhead{display:grid;grid-template-columns:52px 1fr auto;gap:10px;align-items:center}
.matrix-mobile .mhead img{width:52px;height:52px;border-radius:14px;object-fit:cover;border:1px solid rgba(31,41,55,.10);background:#fff}
.matrix-mobile .mname{font-weight:900;line-height:1.2}
.matrix-mobile .mtype{font-size:.85rem;color:rgba(31,41,55,.60);font-weight:900;margin-top:2px}
.matrix-mobile .btn.small{padding:8px 10px;font-size:.85rem;border-radius:12px;white-space:nowrap}
.matrix-mobile .mrow{margin-top:10px;border-top:1px dashed rgba(31,41,55,.12);padding-top:10px;display:grid;grid-template-columns:70px 1fr;gap:10px;align-items:start}
.matrix-mobile .mrow-title{font-weight:900;color:rgba(31,41,55,.70);font-size:.85rem}
.matrix-mobile .micons{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}
.matrix-mobile .mrow:last-child .micons{grid-template-columns:repeat(4,1fr)}
.matrix-mobile .micon{display:flex;flex-direction:column;align-items:center;justify-content:center;background:rgba(255,143,177,.08);border:1px solid rgba(31,41,55,.08);border-radius:12px;padding:6px 4px}
.matrix-mobile .micon .mlab{font-size:.72rem;font-weight:900;color:rgba(31,41,55,.65)}
.matrix-mobile .micon .mval{font-size:1rem;line-height:1}
@media (max-width: 420px){
  .matrix-mobile .mhead{grid-template-columns:52px 1fr}
  .matrix-mobile .mhead .btn{grid-column:1/-1;justify-self:stretch;text-align:center}
  .matrix-mobile .mrow{grid-template-columns:60px 1fr}
}

.matrix-mobile details{border:1px solid var(--border);border-radius:var(--radius);background:rgba(255,255,255,.82);padding:12px;margin:10px 0}
.matrix-mobile summary{font-weight:900;cursor:pointer}
.matrix-mobile ul{margin:10px 0 0;padding-left:18px}

/* V18: menú móvil estable */
@media (max-width: 980px){
  .nav-inner{position:relative !important}
  .nav-toggle{display:inline-flex !important; margin-left:auto !important}
  .nav-links{
    display:none !important;
    position:absolute !important;
    top:calc(100% + 10px) !important;
    right:12px !important;
    left:auto !important;
    width:min(340px, calc(100vw - 24px)) !important;
    flex-direction:column !important;
    gap:6px !important;
    padding:10px !important;
    background:rgba(255,255,255,.95) !important;
    border:1px solid var(--border) !important;
    border-radius:18px !important;
    box-shadow:0 14px 34px rgba(31,41,55,.12) !important;
    z-index:200 !important;
  }
  .nav-links.is-open{display:flex !important}
}

/* V18: Productos compactos */
.prod-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap:12px;
  margin-top:12px;
}
.prod-card{
  display:flex;
  gap:12px;
  align-items:center;
  padding:12px;
  border:1px solid var(--border);
  border-radius:18px;
  background:rgba(255,255,255,.82);
  box-shadow:0 12px 28px rgba(31,41,55,.06);
}
.prod-img{
  width:72px; height:72px;
  object-fit:cover;
  border-radius:16px;
  border:1px solid rgba(0,0,0,.08);
  flex:0 0 auto;
}
.prod-body{min-width:0}
.prod-top{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  margin-bottom:6px;
}
.prod-title{
  font-size:15px;
  margin:0 0 10px;
  line-height:1.2;
  overflow:hidden;
  text-overflow:ellipsis;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
}
.prod-price{font-weight:700; font-size:13px}
.btn-mini{padding:9px 10px; border-radius:14px; font-size:13px}
@media (max-width: 980px){
  .prod-grid{grid-template-columns:1fr}
}

/* V18: Tabla comparativa compacta */
.cmp-table{
  table-layout:fixed;
  width:100%;
  min-width:0 !important;
  font-size:12px;
}
.cmp-table th, .cmp-table td{padding:6px !important}
.cmp-prod-inner img{width:44px !important; height:44px !important}
.cmp-name{font-size:12px}
@media (max-width: 980px){
  /* en móvil, permitimos scroll dentro del wrapper sin romper la página */
  .table-wrap{overflow-x:auto}
}


/* V21: Hero con logo grande a la izquierda */
.hero-banner-inner{
  grid-template-columns: .85fr 1.15fr;
  align-items: start;
}
.hero-left{
  display:flex;
  justify-content:center;
  align-items:center;
  padding: 6px 0;
  /* Fondo suave para mejorar el contraste del logo (texto integrado en la imagen) */
  background: radial-gradient(120% 120% at 40% 35%, rgba(88,64,150,.26) 0%, rgba(255,143,177,.10) 45%, rgba(127,185,255,.08) 100%);
  border-radius: 26px;
  min-height: 340px;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.55);
}
.hero-big-logo{
  width:min(360px, 90%);
  height:auto;
  filter: drop-shadow(0 18px 30px rgba(15,23,42,.12));
}
.hero-right{
  display:grid;
  grid-template-columns: 1fr;
  gap: 18px;
}

/* Leyenda abreviaturas: solo móvil */
.legend-inline{display:none}
@media (max-width: 980px){
  .legend-inline{display:inline}
}

/* Tabla PC: más aire para texto completo */
@media (min-width: 981px){
  .matrix-wrap{overflow:visible}
  table.matrix{width:100%}
  table.matrix th, table.matrix td{white-space:nowrap}
  table.matrix th:first-child, table.matrix td:first-child{white-space:normal; min-width: 420px;}
}

/* Móvil: títulos de producto más legibles */
@media (max-width: 980px){
  .mname{font-size:18px; line-height:1.15;}
  .mtype{font-size:14px;}
}

/* === V22 tweaks === */
.hero-big-logo{
  filter: drop-shadow(0 10px 26px rgba(0,0,0,.18)) drop-shadow(0 0 1px rgba(0,0,0,.35));
}

.hero-banner-inner #para-familias{
  grid-column: 1 / -1;
  width: 100%;
}

.hero-cards{
  grid-template-columns: 1fr;
}

/* Mobile comparison cards: remove Pros/Contras labels (chips only) */
@media (max-width: 720px){
  .mrow-title{ display:none !important; }
}


/* V23 tweaks */
.hero-big-logo{
  max-width: 520px;
  width: 100%;
  height: auto;
  object-fit: contain;
  display:block;
  margin: 0 auto;
  /* Sin subir demasiado el brillo: el texto del logo tiene tonos claros */
  filter: contrast(1.18) saturate(1.08) drop-shadow(0 10px 24px rgba(0,0,0,.14));
}

/* Para familias: mostrar imagen completa */
.pf-illus{
  overflow: hidden;
  display:flex;
  justify-content:center;
  align-items:center;
}
.pf-illus img{
  width: 100%;
  height: auto;
  max-width: 640px;
  max-height: 320px;
  object-fit: contain;
}

/* Top 3 guías: carrusel centrado + imagen cuadrada y completa */
#top-guides .carousel{
  justify-content: center;
}
#top-guides .carousel-card{
  flex: 0 0 300px;
  max-width: 300px;
}
#top-guides .thumb{
  height: auto !important;
  aspect-ratio: 1 / 1;
  border-radius: 18px;
  overflow: hidden;
  background: rgba(255,255,255,.65);
  display:flex;
  align-items:center;
  justify-content:center;
}
#top-guides .thumb img{
  width: 100%;
  height: 100%;
  object-fit: contain !important;
}

/* Móvil: comparativa en tarjetas sin Pros/Contras, simétrica */
@media (max-width: 980px){
  .matrix-mobile .micons-all{
    margin-top: 12px;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
  }
  .matrix-mobile .micon{
    border: 1px solid rgba(31,41,55,.10);
    border-radius: 14px;
    background: rgba(255,255,255,.75);
    padding: 10px 8px;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    min-height: 74px;
  }
  .matrix-mobile .mlab{
    font-size: .75rem;
    font-weight: 900;
    color: rgba(31,41,55,.70);
    text-align:center;
    line-height: 1.05;
    margin-bottom: 6px;
  }
  .matrix-mobile .mval{
    font-size: 1.45rem;
    line-height: 1;
  }
}


@media (max-width: 980px){
  .matrix-mobile .mname{font-size: 1.05rem;}
}
#para-familias{margin-left:auto;margin-right:auto;}

/* V25: Apilado + centrado paneles Home + carrusel cuadrado (PC) */
.home-panels .panels{
  display:flex;
  flex-direction:column;
  gap:18px;
  align-items:center;
}

/* Home: bloque Selecciones (3 cards en PC) */
@media (min-width: 981px){
  #selecciones .prod-grid{grid-template-columns:repeat(3,minmax(0,1fr));}
  #selecciones .prod-card{height:100%;}
}
.home-panels #para-familias,
.home-panels #como-trabajamos{
  width:100%;
  max-width: 980px;
  margin:0 auto;
  text-align:center;
}
.home-panels #para-familias .pf-illus{max-height: 300px; margin-left:auto; margin-right:auto;}

/* Home: centra el contenido dentro de los dos posts (PC + móvil) */
.home-panels #para-familias p,
.home-panels #como-trabajamos p{
  margin-left:auto;
  margin-right:auto;
  max-width: 62ch;
  width: min(62ch, 100%);
}

/* Listas centradas (contenedor centrado, texto legible) */
.home-panels #para-familias ul,
.home-panels #como-trabajamos ul{
  list-style-position: inside;
  padding-left:0;
  margin-left:auto;
  margin-right:auto;
  display:inline-block;
  text-align:left;
  max-width: 66ch;
  width: min(66ch, 100%);
}

.home-panels #para-familias .badge{justify-content:center;}
.home-panels #para-familias .cta-row{justify-content:center;}
.home-panels #como-trabajamos .work-list{padding-left:0;}

/* Carrusel top 3: una slide visible + miniatura cuadrada (sin imagen gigante) */
#guias .carousel{
  max-width: 980px;
  margin-left:auto;
  margin-right:auto;
}
#guias .carousel-viewport{
  overflow:hidden;
  width:100%;
}
#guias .carousel-track{
  display:flex;
  width:100%;
  transition:transform .55s ease;
  will-change: transform;
}
#guias .carousel-card{
  flex: 0 0 100% !important;
  width:100%;
}
#guias .carousel-card .card-link{
  display:flex;
  flex-direction:column;
  gap:12px;
}
#guias .carousel-card .thumb{
  /* Más grande, con ligero recorte y esquinas redondeadas */
  width: min(560px, 100%);
  aspect-ratio: 16 / 9;
  margin: 0 auto;
  border-radius: 26px;
  overflow:hidden;
  background: rgba(255,255,255,.65);
  display:flex;
  align-items:center;
  justify-content:center;
}
#guias .carousel-card .thumb img{
  width:100%;
  height:100%;
  object-fit: cover;
  object-position: center;
  display:block;
}
#guias .carousel-card .card-meta,
#guias .carousel-card h3,
#guias .carousel-card p{
  text-align:center;
}
#guias .carousel-dots{
  display:flex;
  justify-content:center;
  gap:8px;
  margin-top:10px;
}
#guias .carousel-dot{
  width:10px;
  height:10px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.25);
  background: rgba(255,255,255,.7);
  cursor:pointer;
}
#guias .carousel-dot.active{
  background: rgba(0,0,0,.35);
}

@media (max-width: 720px){
  /* En móvil el carrusel ocupa el ancho, pero mantiene miniatura controlada */
  #guias .carousel-card .thumb{width:100%;}
}

/* V6: Home — Para familias imagen un poco más grande + bordes redondeados */
.home-panels #para-familias .pf-illus{
  max-height: none;
}
.home-panels #para-familias .pf-illus img{
  max-width: 740px;
  max-height: 400px;
  width: 100%;
  height: auto;
  object-fit: cover;
  border-radius: 18px;
}
@media (max-width: 980px){
  .home-panels #para-familias .pf-illus img{ max-height: 320px; }
}
@media (max-width: 720px){
  .home-panels #para-familias .pf-illus img{ max-height: 300px; }
}
