/* WIO - styles.css (base limpia) */

/* ===================== TOKENS ===================== */
:root{
  --primary:#6C36F7; --secondary:#0A49DB; --accent:#12D5C9;
  --success:#17B26A; --warning:#F3A218;

  --ink:#0B1220; --ink-2:#4b5563; --bg:#FFFFFF; --border:#e5e7eb;

  --g1: linear-gradient(90deg,#6C36F7 0%,#0A49DB 100%);
  --g2: linear-gradient(90deg,#0A49DB 0%,#12D5C9 100%);

  /* Tipografías (recuerda añadir los <link> a Google Fonts en tus HTML) */
  --ff-body: 'Inter', system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Arial, sans-serif;
  --ff-head: 'Poppins', system-ui, sans-serif;

  --radius: 18px; --shadow: 0 10px 30px rgba(12,17,32,.12); --container: 1120px;

  --s1: 8px; --s2: 12px; --s3: 16px; --s4: 20px; --s5: 24px; --s6: 32px; --s7: 40px; --s8: 56px;

  /* Ayuda a navegadores a elegir esquema de color */
  color-scheme: light dark;
}
@media (prefers-color-scheme: dark){
  :root{ --bg:#0B1220; --ink:#E6F0FF; --ink-2:#b2c3ff; --border:#24304C; }
}

/* ===================== BASE ===================== */
*{ box-sizing:border-box; }
html:focus-within{ scroll-behavior:smooth; }
body{
  margin:0; font-family:var(--ff-body); background:var(--bg); color:var(--ink); line-height:1.6;
}
h1,h2,h3,h4,h5,h6{ font-family:var(--ff-head); font-weight:700; line-height:1.2; margin-top:0; }
img{ max-width:100%; height:auto; display:block; }
a{ color:inherit; }
.container{ max-width:var(--container); margin-inline:auto; padding-inline:16px; }
.small{ font-size:.9rem; }
.sr-only{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }

.skip-link{ position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden; }
.skip-link:focus{
  position:fixed; left:12px; top:12px; width:auto; height:auto; background:#fff; color:#000;
  padding:8px 12px; border-radius:8px; z-index:9999;
}
:focus{ outline:2px solid var(--accent); outline-offset:2px; }

/* ===================== HEADER ===================== */
.site-header{
  position:sticky; top:0; z-index:40;
  background:rgba(255,255,255,.75);
  backdrop-filter:saturate(120%) blur(8px);
  border-bottom:1px solid var(--border);
}
@media (prefers-color-scheme: dark){ .site-header{ background:rgba(11,18,32,.7); } }

.header-bar{
  display:flex; align-items:center; justify-content:space-between;
  gap:24px; padding-block:10px;
}

.brand{
  display:flex; align-items:center; text-decoration:none;
}

/* Logo protagonista y nítido */
.brand-logo{
  width:80px; height:80px; object-fit:contain; image-rendering:auto;
  filter: drop-shadow(0 1px 1px rgba(0,0,0,.25));
}
@media (max-width:1024px){ .brand-logo{ width:64px; height:64px; } }
@media (max-width:640px){ .brand-logo{ width:48px; height:48px; } }

.fallback-logo{
  display:inline-grid; place-items:center; width:28px; height:28px; border-radius:8px;
  color:#fff; background:var(--g1); font-weight:800;
}

/* NAV */
.primary-nav ul{
  display:none; list-style:none; gap:20px; margin:0; padding:0; align-items:center;
}
@media (min-width:768px){ .primary-nav ul{ display:flex; } }
.primary-nav a{
  text-decoration:none; padding-bottom:2px; border-bottom:2px solid transparent;
}
.primary-nav a:hover, .primary-nav a:focus{ border-bottom-color:var(--secondary); }

/* Header CTAs */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:12px 18px; border-radius:var(--radius); font-weight:700; text-decoration:none;
  border:1px solid transparent; cursor:pointer; transition:transform .2s ease, filter .2s ease;
}
.btn:active{ transform:translateY(1px); }
.btn-primary{ background:var(--g1); color:#fff; }
.btn-primary:hover{ filter:brightness(1.05); }
.btn-secondary{ color:var(--secondary); border-color:var(--secondary); background:transparent; }
.btn-secondary:hover{ background:rgba(10,73,219,.08); }

/* ===================== HERO ===================== */
.hero{ position:relative; padding-block:var(--s8); }
.hero--rich{ padding-top:calc(var(--s8) + 10px); }
.hero-grid{ display:grid; grid-template-columns:1fr; gap:var(--s6); align-items:center; }
@media (min-width:900px){ .hero-grid{ grid-template-columns:1.1fr .9fr; } }
.hero-copy h1{ font-size:clamp(2rem,2.8vw,3.25rem); margin:0 0 var(--s3); }
.lead{ font-size:1.125rem; color:var(--ink-2); margin-bottom:var(--s4); }
.microcopy{ font-size:.875rem; color:var(--ink-2); margin-top:var(--s2); }
.accent{ background:var(--g2); -webkit-background-clip:text; background-clip:text; color:transparent; }
.hero-actions{ display:flex; gap:12px; flex-wrap:wrap; }
.hero-visual{ border-radius:22px; box-shadow:var(--shadow); border:1px solid var(--border); overflow:hidden; }
.hero-visual--glass{ background:linear-gradient(180deg, rgba(255,255,255,.5), rgba(255,255,255,.25)); backdrop-filter:blur(6px); }

/* Fondo hero con partículas suaves */
.hero-bg{
  position:absolute; inset:-10% -10% auto -10%; height:70%;
  background:
    radial-gradient(600px 300px at 10% 20%, rgba(108,54,247,.20), transparent 60%),
    radial-gradient(600px 300px at 90% 30%, rgba(18,213,201,.18), transparent 60%),
    radial-gradient(700px 340px at 50% 10%, rgba(10,73,219,.16), transparent 60%);
  z-index:-1; pointer-events:none;
}
.dots::before, .dots::after{
  content:""; position:absolute; width:160px; height:160px; border-radius:50%;
  background:radial-gradient(circle at 30% 30%, rgba(255,255,255,.8), rgba(255,255,255,0));
  animation: float 9s ease-in-out infinite alternate;
}
.dots::after{ width:220px; height:220px; right:8%; bottom:12%; animation-duration:12s; }
@keyframes float{ from{ transform:translateY(-8px) } to{ transform:translateY(12px) } }

/* Pills + KPIs */
.pillbar{ display:flex; gap:8px; flex-wrap:wrap; margin-bottom:12px; }
.pill{ display:inline-block; padding:6px 10px; border-radius:999px; font-size:.85rem; border:1px solid var(--border); background:rgba(255,255,255,.6); }
.kpis{
  list-style:none; padding:0; margin:16px 0 0; display:grid; gap:10px;
  grid-template-columns:repeat(3,1fr); max-width:540px;
}
.kpis li{ background:#fff; border:1px solid var(--border); border-radius:14px; padding:10px 12px; box-shadow:var(--shadow); display:flex; flex-direction:column; }
.kpis strong{ font-size:1.05rem; }
.kpis span{ color:var(--ink-2); font-size:.9rem; }
@media (prefers-color-scheme: dark){ .pill{ background:#121B34; } .kpis li{ background:#121B34; } }

/* ===================== SECCIONES GENERALES ===================== */
.section{ padding-block:var(--s7); }
.section h2{ font-size:clamp(1.5rem,1.8vw,2rem); margin:0 0 12px; }
.muted{ color:var(--ink-2); }

/* Cards */
.cards-4{ display:grid; gap:var(--s4); grid-template-columns:1fr; }
@media (min-width:768px){ .cards-4{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:1120px){ .cards-4{ grid-template-columns:repeat(4,1fr); } }
.card{ background:#fff; border:1px solid var(--border); border-radius:var(--radius); padding:var(--s5); box-shadow:var(--shadow); }
@media (prefers-color-scheme: dark){ .card{ background:#121B34; } }
.benefit h3, .usecase h3{ margin-top:0; }

/* ===================== CÓMO FUNCIONA ===================== */
.how-grid{ display:grid; grid-template-columns:1fr; gap:var(--s4); }
@media (min-width:768px){ .how-grid{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:1120px){ .how-grid{ grid-template-columns:repeat(4,1fr); } }
.how-card{
  position:relative; background:#fff; border:1px solid var(--border); border-radius:var(--radius);
  padding:var(--s5); box-shadow:var(--shadow); overflow:hidden;
}
@media (prefers-color-scheme: dark){ .how-card{ background:#121B34; } }
.how-card::before{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(108,54,247,.12), transparent 35%); pointer-events:none; }
.step{
  display:inline-grid; place-items:center; width:40px; height:40px; border-radius:999px; color:#fff;
  background:var(--g1); font-weight:800; box-shadow:0 6px 20px rgba(108,54,247,.35); margin-bottom:10px;
}

/* ===================== INTEGRACIONES ===================== */
.integrations .logos{
  display:grid; grid-template-columns:repeat(2,1fr); gap:14px; list-style:none; padding:0; margin:12px 0 0;
}
@media (min-width:640px){ .integrations .logos{ grid-template-columns:repeat(3,1fr); } }
@media (min-width:960px){ .integrations .logos{ grid-template-columns:repeat(6,1fr); } }
.logo-item{
  height:56px; border:1px dashed var(--border); border-radius:12px;
  background:linear-gradient(90deg, rgba(108,54,247,.07), rgba(10,73,219,.07));
  box-shadow: inset 0 0 0 2px rgba(255,255,255,.4);
}

/* ===================== FORMULARIO ===================== */
.form{
  background:#fff; border:1px solid var(--border); border-radius:var(--radius);
  padding:var(--s5); box-shadow:var(--shadow);
}
@media (prefers-color-scheme: dark){ .form{ background:#121B34; } }
.form label{ display:inline-block; margin-bottom:6px; font-weight:600; }
.form input, .form select, .form textarea{
  width:100%; padding:12px; border:1px solid var(--border); border-radius:12px; background:transparent; color:inherit;
}
.grid-2{ display:grid; grid-template-columns:1fr; gap:var(--s4); }
.grid-2 .full{ grid-column:1/-1; }
@media (min-width:768px){ .grid-2{ grid-template-columns:repeat(2,1fr); } }
.consents{ display:flex; flex-direction:column; gap:8px; margin:var(--s3) 0; }
.form-actions{ display:flex; gap:12px; flex-wrap:wrap; }

/* ===================== FOOTER ===================== */
.site-footer{ border-top:1px solid var(--border); padding-block:24px 40px; font-size:.95rem; }

/* ===================== REVEALS ===================== */
.reveal{ opacity:0; transform:translateY(12px); }
.reveal.in{ opacity:1; transform:none; transition:opacity .6s ease, transform .6s ease; }
@media (prefers-reduced-motion: reduce){
  .reveal, .reveal.in{ opacity:1 !important; transform:none !important; transition:none !important; }
}

/* ===================== BLOG (profesional con skeleton) ===================== */
.blog-hero{ position:relative; padding:56px 0; }
.blog-hero__wrap{ display:grid; gap:24px; align-items:end; grid-template-columns:1fr; }
@media (min-width:900px){ .blog-hero__wrap{ grid-template-columns:1.2fr .8fr; } }
.eyebrow{ letter-spacing:.06em; font-weight:700; text-transform:uppercase; font-size:.85rem; color:var(--secondary); margin:0 0 8px; }
.blog-search{ display:flex; gap:10px; align-items:center; justify-self:end; }
.blog-search input{ flex:1; min-width:220px; padding:12px 14px; border:1px solid var(--border); border-radius:12px; background:transparent; }

.filterbar{ display:flex; gap:8px; flex-wrap:wrap; }
.pill{ display:inline-block; padding:6px 10px; border-radius:999px; font-size:.9rem; border:1px solid var(--border); background:rgba(255,255,255,.7); }
.pill.is-active{ border-color:transparent; background:var(--g2); color:#fff; }
@media (prefers-color-scheme: dark){ .pill{ background:#121B34; } }

.blog-grid__wrap{ display:grid; gap:24px; grid-template-columns:1fr; align-items:start; }
@media (min-width:992px){ .blog-grid__wrap{ grid-template-columns:minmax(0,1fr) 320px; } }

.posts{ display:grid; gap:24px; grid-template-columns:1fr; }
@media (min-width:640px){ .posts{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:1120px){ .posts{ grid-template-columns:repeat(3,1fr); } }

.post-card{
  border:1px solid var(--border); border-radius:18px; background:#fff; box-shadow:var(--shadow);
  overflow:hidden; display:flex; flex-direction:column;
}
@media (prefers-color-scheme: dark){ .post-card{ background:#121B34; } }
.post-thumb{ aspect-ratio:16/9; background:#eef3ff; }
.post-body{ padding:16px; display:grid; gap:10px; }
.post-title{ margin:0; font-size:1.15rem; line-height:1.3; }
.post-meta{ color:var(--ink-2); font-size:.9rem; margin:0; }
.post-excerpt{ color:var(--ink-2); margin:0; }

.sidebar{ display:grid; gap:16px; }
.list-clean{ list-style:none; margin:0; padding:0; }

.pagination{ padding:24px 0 56px; }
.pagination__wrap{ display:flex; align-items:center; justify-content:center; gap:14px; }
.pages{ display:flex; gap:8px; list-style:none; margin:0; padding:0; }
.page, .page-link{
  display:inline-flex; align-items:center; justify-content:center;
  min-width:40px; height:40px; padding:0 12px;
  border:1px solid var(--border); border-radius:12px; text-decoration:none;
}
.page.is-active{ background:var(--g1); color:#fff; border-color:transparent; }
.page-link.is-disabled{ opacity:.5; pointer-events:none; }

/* Skeletons */
.skeleton{ position:relative; overflow:hidden; }
.skel-thumb{ background:rgba(108,54,247,.12); }
.skel-body .skel-line{ display:block; height:12px; border-radius:6px; background:rgba(0,0,0,.06); margin-bottom:10px; }
.skel-line.wide{ width:90%; } .skel-line.mid{ width:70%; } .skel-line.short{ width:40%; }
@media (prefers-color-scheme: dark){
  .skel-thumb{ background:rgba(108,54,247,.18); }
  .skel-body .skel-line{ background:rgba(255,255,255,.08); }
}
/* shimmer */
.skeleton::after{
  content:""; position:absolute; inset:0; transform:translateX(-100%);
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.6), transparent);
  animation: shimmer 1.6s infinite;
}
@keyframes shimmer{ 100% { transform:translateX(100%); } }


/* === WIO: Phone field layout fixes === */
.form .phone-field{
  display:flex;
  gap:12px;
  align-items:center;
}
.form .phone-field select,
.form .phone-field input[type="tel"]{
  height: 48px;
  padding: 10px 14px;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  background: #fff;
  outline: none;
  font: inherit;
  line-height: 1.2;
}
.form .phone-field select{
  width: 160px;
  min-width: 140px;
}
.form .phone-field input[type="tel"]{
  flex:1;
}
.form .phone-field select:focus,
.form .phone-field input[type="tel"]:focus{
  border-color:#6ee7f8; /* similar to cyan focus used */
  box-shadow: 0 0 0 3px rgba(110,231,248,.35);
}
@media (max-width: 640px){
  .form .phone-field{ flex-direction:column; }
  .form .phone-field select,
  .form .phone-field input[type="tel"]{ width:100%; }
}


/* === WIO: intl-tel-input polish === */
.iti{ width:100%; }
.iti--allow-dropdown input#telefono{
  width:100%;
  height:48px;
  padding:10px 14px 10px 52px;
  border:1px solid #e5e7eb;
  border-radius:12px;
  background:#fff;
  outline:none;
  font:inherit;
}
.iti--allow-dropdown input#telefono:focus{
  border-color:#6ee7f8;
  box-shadow:0 0 0 3px rgba(110,231,248,.35);
}


/* === WIO: Mobile nav toggle === */
.nav-toggle{
  display:inline-flex; align-items:center; justify-content:center;
  width:42px; height:42px; border:1px solid var(--border); border-radius:10px;
  background:#fff; cursor:pointer; font-size:20px;
}
@media (min-width:768px){
  .nav-toggle{ display:none; }
}
.primary-nav ul{ display:none; }
.primary-nav.open ul{ display:block; }
.primary-nav ul{ list-style:none; margin:0; padding:0; }
.primary-nav ul li{ margin:8px 0; }
@media (min-width:768px){
  .primary-nav ul{ display:flex; gap:20px; }
  .primary-nav ul li{ margin:0; }
}


/* === WIO: Header layout & mobile dropdown (robusto) === */
.site-header .container.header-bar{
  display:flex; align-items:center; gap:16px; justify-content:space-between;
}
.site-header .brand{ display:inline-flex; align-items:center; gap:10px; }


.primary-nav{ margin-left:auto; position:relative; }
.nav-toggle{
  display:inline-flex; align-items:center; justify-content:center;
  width:42px; height:42px; border:1px solid var(--border); border-radius:10px;
  background:#fff; cursor:pointer; font-size:20px;
}
@media (min-width:768px){ .nav-toggle{ display:none; } }

/* Oculto por defecto en móvil */
.primary-nav ul{ display:none; list-style:none; margin:0; padding:0; }

/* Dropdown alineado a la derecha cuando está abierto */
.primary-nav.open ul{
  display:block;
  position:absolute; right:0; top:calc(100% + 10px);
  background:#fff;
  border:1px solid var(--border); border-radius:12px;
  box-shadow:0 10px 30px rgba(0,0,0,.08);
  min-width:240px; padding:8px;
  z-index:10000;
}
.primary-nav.open ul li{ margin:0; }
.primary-nav.open ul li a{ display:block; padding:10px 12px; border-radius:10px; text-decoration:none; color:inherit; }
.primary-nav.open ul li a:hover{ background:#f5f7fb; }

/* En escritorio: menú en línea */
@media (min-width:768px){
  .primary-nav{ position:static; }
  .primary-nav ul{ display:flex; gap:24px; position:static; box-shadow:none; border:none; padding:0; }
  .primary-nav ul li a{ padding:0; }
}

/* === WIO: Simplified header nav (no hamburger) === */
.nav-toggle{ display:none !important; }
.primary-nav{ margin-left:auto; }
.primary-nav ul{
  display:flex !important;
  gap:18px;
  list-style:none;
  margin:0;
  padding:0;
  flex-wrap:wrap;
  align-items:center;
}
@media (max-width:768px){
  .primary-nav{ width:100%; }
  .primary-nav ul{ justify-content:flex-end; overflow-x:auto; }
}

/* === WIO: Form compact sizing & phone full row === */
.form .grid-2{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  column-gap:20px;
  row-gap:14px;
}
.form input[type="text"],
.form input[type="email"],
.form input[type="tel"],
.form select,
.form textarea{
  height:44px;
  padding:8px 12px;
  border-radius:10px;
}
.form .phone-field{ display:flex; gap:10px; align-items:center; }
.form .phone-field select{ width:200px; min-width:180px; height:44px; }
.form .phone-field input[type="tel"]{ height:44px; }
#telefono{ width:100%; }

/* Force Teléfono to occupy full width row */
.form p.phone-full{ grid-column:1 / -1; }

@media (max-width:768px){
  .form .grid-2{ grid-template-columns: 1fr; }
  .form .phone-field{ flex-direction:column; align-items:stretch; }
  .form .phone-field select{ width:100%; min-width:0; }
}

/* === WIO: Removed nav menu === */
.primary-nav{ display:none !important; }
\n
/* === WIO: Nav visibility preference === */
@media (max-width: 768px){
  .primary-nav{ display:none !important; } /* Hide menu on mobile as requested */
}
@media (min-width: 769px){
  .primary-nav{ display:block; margin-left:auto; }
  .primary-nav ul{ display:flex; gap:24px; align-items:center; }
}

/* === WIO: Form final spacing === */
.form .grid-2{ row-gap: 18px; }

/* === WIO v1.2.6: header/logo/menu === */

@media (max-width: 768px){
  .primary-nav{ display:none !important; }
}
@media (min-width: 769px){
  .primary-nav{ display:block; margin-left:auto; }
  .primary-nav ul{ display:flex !important; gap:28px; align-items:center; }
}

/* === WIO v1.2.6: form order === */
.form .grid-2{ grid-template-columns: repeat(2, minmax(0,1fr)); }
.form p.phone-full{ grid-column: 1 / -1; }

/* WIO v1.2.7 nav enforce */
@media (max-width: 768px){ .primary-nav{ display:none !important; } }
@media (min-width: 769px){
  .primary-nav{ display:block; margin-left:auto; }
  .primary-nav ul{ display:flex !important; gap:28px; align-items:center; }
}


/* Desktop: show nav */
@media (min-width: 769px){
  .primary-nav{ display:block !important; }
  .primary-nav ul{ display:flex !important; gap:28px; align-items:center; }
}

/* Mobile: hide nav */
@media (max-width: 768px){
  .primary-nav{ display:none !important; }
}


/* === WIO v1.2.8C2: Force-center desktop nav between logo and CTA === */
@media (min-width: 1024px){
  .site-header .container.header-bar{
    display: grid !important;
    grid-template-columns: auto 1fr auto !important;
    align-items: center !important;
  }
  .site-header .primary-nav{
    margin-left: 0 !important;
    justify-self: center !important;
  }
  .site-header .primary-nav ul{
    display: flex !important;
    gap: 28px !important;
    align-items: center !important;
  }
	
	/* Fallback duro: los modales siempre ocultos por defecto 
#modal-privacidad, #modal-marketing { 
  position: fixed; inset: 0; display: none !important; z-index: 1000;
}
#modal-privacidad.is-open, #modal-marketing.is-open { 
  display: block !important; 
}
#modal-privacidad .modal__overlay,
#modal-marketing  .modal__overlay{
  position: absolute; inset: 0; background: rgba(15,23,42,.6);
}
#modal-privacidad .modal__content,
#modal-marketing  .modal__content{
  position: relative; background:#fff; color:#0f172a;
  width:min(720px, calc(100% - 32px));
  margin: 6vh auto; border-radius:16px; padding:24px;
  max-height: 88vh; overflow:auto;
  box-shadow: 0 24px 80px rgba(2,6,23,.25);
}
#modal-privacidad .modal__close,
#modal-marketing  .modal__close{
  position:absolute; top:8px; right:12px; 
  background:transparent; border:0; font-size:28px; cursor:pointer;
}

	*/
	
	/* --- Modal genérico 
	<!--
.modal{ position: fixed; inset: 0; display: none; z-index: 1000; }
.modal.is-open{ display: block; }
.modal__overlay{ position: absolute; inset: 0; background: rgba(15,23,42,.6); }
.modal__content{
  position: relative; background: #fff; color: #0f172a;
  width: min(720px, calc(100% - 32px));
  margin: 6vh auto; border-radius: 16px; padding: 24px;
  max-height: 88vh; overflow: auto;
  box-shadow: 0 24px 80px rgba(2,6,23,.25);
}
.modal__close{
  position: absolute; top: 8px; right: 12px;
  background: transparent; border: 0; font-size: 28px; cursor: pointer;
}
.link-like{
  margin-left: .5rem; font-size: .95rem; color: #2563eb;
  background: none; border: 0; cursor: pointer; text-decoration: underline; padding: 0;
}
--- */
	
/* Opcional: alinear mejor los labels de consentimiento 
.consents .consent{
  display: flex; align-items: center; gap: .6rem; margin-block: 10px;
}
.consents .consent input[type="checkbox"]{ transform: translateY(1px); } */

/* ==== WIO · POPUPS (GENÉRICOS) ==== */
/* Ocultos por defecto */
.modal{ position: fixed; inset: 0; display: none; z-index: 1000; }
.modal.is-open{ display: block; }

/* UI */
.modal__overlay{ position: absolute; inset: 0; background: rgba(15,23,42,.6); }
.modal__content{
  position: relative; background:#fff; color:#0f172a;
  width: min(720px, calc(100% - 32px));
  margin: 6vh auto; border-radius: 16px; padding: 24px;
  max-height: 88vh; overflow: auto;
  box-shadow: 0 24px 80px rgba(2,6,23,.25);
}
.modal__close{
  position: absolute; top: 8px; right: 12px;
  background: transparent; border: 0; font-size: 28px; cursor: pointer;
}

/* Botón textual junto al checkbox */
.link-like{
  margin-left: .5rem; font-size: .95rem; color: #2563eb;
  background: none; border: 0; cursor: pointer; text-decoration: underline; padding: 0;
}

/* Alineación bonita de los consentimientos */
.consents .consent{ display: flex; align-items: center; gap: .6rem; margin-block: 10px; }
.consents .consent input[type="checkbox"]{ transform: translateY(1px); }

/* ==========================================
   INTEGRACIONES — FIX FINAL (sustituye al anterior)
   ========================================== */

/* Contenedor en grid, estable y centrado */
.section.integrations ul.logos{
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 16px;
  justify-items: center;
  align-items: stretch;
  list-style: none;
  padding: 0;
  margin: 24px 0 0;
  float: none !important;
  position: relative !important;
}

/* Tarjeta del logo */
.section.integrations ul.logos > li.logo-item{
  box-sizing: border-box;
  display: flex !important;
  align-items: center;
  justify-content: center;
  min-width: 0;
  height: 84px;
  padding: 12px 16px;
  border-radius: 16px;
  background: rgba(255,255,255,.65);
  border: 1px solid #e6edf5;
  overflow: hidden;

  /* Reset anti-solapes del tema */
  float: none !important;
  position: relative !important;
  inset: auto !important;
  clear: none !important;
  z-index: auto !important;
  margin: 0 !important;
}

/* Logos: tamaño responsivo con clamp + resets duros */
.section.integrations ul.logos > li.logo-item img,
.section.integrations ul.logos > li.logo-item svg{
  display: block !important;
  position: static !important;
  float: none !important;
  transform: none !important;
  -webkit-transform: none !important;
  width: auto !important;
  height: clamp(24px, 5.5vw, 36px) !important; /* <<< CLAVE */
  max-width: 90% !important;
  object-fit: contain !important;
  margin: 0 !important;
  opacity: 1 !important;
}

/* Fallback si no hay grid */
@supports not (display: grid){
  .section.integrations ul.logos{
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 16px !important;
    justify-content: center !important;
  }
  .section.integrations ul.logos > li.logo-item{
    flex: 1 1 45% !important; /* ~2 por fila en móviles */
  }
}



}



/* === PRO FIX: logo más grande y hero centrado, sin panel derecho === */
.brand-logo{
  width:120px !important; height:120px !important; object-fit:contain; image-rendering:auto;
  filter: drop-shadow(0 1px 1px rgba(0,0,0,.25));
}
@media (max-width:1024px){ .brand-logo{ width:96px !important; height:96px !important; } }
@media (max-width:640px){ .brand-logo{ width:64px !important; height:64px !important; } }

/* Centrado del héroe */
.hero .hero-copy{
  max-width: 980px;
  margin: 0 auto;
  text-align: center;
}
/* Quitar visual de la derecha y volver a 1 columna en desktop */
.hero .hero-visual{ display: none !important; }
@media (min-width:900px){
  .hero-grid{
    grid-template-columns: 1fr !important;
  }
}

/* Espaciado más cómodo bajo el título del héroe */
.hero-copy .lead{
  font-size: 1.05rem;
  line-height: 1.6;
  max-width: 820px;
  margin: 14px auto 0;
}

