:root{
  --fondo:#fffafc;
  --superficie:#ffffff;
  --superficie-suave:#fff7fc;
  --linea:#eadcf1;
  --texto:#2f1f3d;
  --texto-suave:#6e5a7d;
  --principal:#662d91;
  --principal-fuerte:#662d91;
  --destacado:#c8008a;
  --destacado-suave:#fde8f7;
  --acento:#ffde59;
  --acento-suave:#fff8d6;
  --exito:#1f7a4a;
  --advertencia:#9b6b00;
  --peligro:#b42318;
  --radio:22px;
  --radio-sm:14px;
  --sombra-sm:0 8px 22px rgba(102,45,145,.08);
  --sombra-md:0 18px 46px rgba(102,45,145,.12);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:"Glacial Indifference","Montserrat",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:var(--fondo);color:var(--texto);line-height:1.55}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button,input,textarea,select{font:inherit}

/* Layout public */
.encabezado-sitio{position:sticky;top:0;z-index:20;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--linea)}
.contenedor{max-width:1200px;margin:0 auto;padding:0 24px}
.navegacion-sitio,.barra-pie{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:18px 0}
.marca,.marca-admin{display:flex;align-items:center;gap:14px}
.marca-sello{width:44px;height:44px;border-radius:14px;background:var(--principal);color:#fff;display:grid;place-items:center;font-weight:800;font-size:1.15rem;box-shadow:var(--sombra-sm);font-family:"Montserrat",system-ui,sans-serif}
.copia-marca strong,.marca-admin strong{display:block;font-size:1rem;font-family:"Montserrat",system-ui,sans-serif;font-weight:700}
.copia-marca span,.marca-admin span{display:block;color:var(--texto-suave);font-size:.9rem}
.links-navegacion,.acciones-superiores,.acciones-hero,.acciones-tabla,.acciones-inline,.acciones-hero-publico{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.link-navegacion{color:var(--texto-suave);font-weight:600;font-family:"Montserrat",system-ui,sans-serif}

.boton-menu-movil,.boton-menu-panel{display:none;align-items:center;justify-content:center;gap:8px;padding:10px 14px;border-radius:14px;border:1px solid var(--linea);background:#fff;color:var(--principal);font-family:"Montserrat",system-ui,sans-serif;font-weight:700;cursor:pointer}
.icono-menu{font-size:1rem;line-height:1}
.overlay-menu{display:none}
body.menu-publico-abierto, body.menu-abierto{overflow:hidden}
.cabecera-admin-principal{display:grid;gap:12px}

.seccion{padding:48px 0}
.hero{padding:56px 0 30px}
.grilla-hero,.grilla-admin,.grilla-soporte-admin,.grilla-kpis,.resumen-pagos-admin,.bloque-detalle-pago,.grilla-contenido,.grilla-cards-front{display:grid;gap:20px}
.grilla-hero{grid-template-columns:1.4fr .8fr}
.columna-hero,.columna-admin{display:grid;gap:20px}
.tarjeta-hero,.tarjeta-hero-publica,.panel-destacado,.kpi,.tarjeta-admin,.card-front,.mini-estadistica,.tarjeta-metrica,.mini-resumen-pago{background:var(--superficie);border:1px solid var(--linea);border-radius:var(--radio);box-shadow:var(--sombra-sm)}
.tarjeta-hero,.tarjeta-hero-publica{padding:34px}
.titulo-hero,.titulo-seccion,.titulo-hero-publico{margin:0 0 14px;font-size:clamp(2rem,3.4vw,3.3rem);line-height:1.08;letter-spacing:-.05em}
.titulo-seccion{font-size:clamp(1.7rem,2.6vw,2.5rem)}
.hero-texto,.subtitulo-seccion,.texto-hero-publico,.texto-base{color:var(--texto-suave)}
.frase-destacada{padding:16px 18px;border-left:4px solid var(--destacado);background:var(--destacado-suave);border-radius:16px;margin:20px 0;font-weight:600;font-family:"Playfair Display",serif;font-style:italic;color:var(--principal)}
.chapa,.chapa-destacada,.pildora,.badge-inline,.chapa-estado,.chapa-principal,.chapa-exito,.chapa-advertencia,.chapa-peligro,.chapa-secundaria,.chapa-destacado{display:inline-flex;align-items:center;gap:8px;padding:7px 12px;border-radius:999px;font-size:.8rem;font-weight:700}
.chapa,.pildora,.chapa-principal,.chapa-secundaria{background:rgba(102,45,145,.10);color:var(--principal)}
.chapa-destacada,.chapa-destacado{background:var(--destacado-suave);color:var(--destacado)}
.chapa-exito{background:#ecfdf3;color:var(--exito)}
.chapa-advertencia{background:#fffaeb;color:var(--advertencia)}
.chapa-peligro{background:#fef3f2;color:var(--peligro)}
.badge-inline{padding:4px 8px;background:var(--destacado);color:#fff;font-size:.72rem;font-family:"Montserrat",system-ui,sans-serif}
.micro-hero,.lista-destacada,.lista-notas-admin,.lista-reciente,.lista-registros-admin,.detalle-pago-admin,.panel-plan-dashboard,.cuerpo-tarjeta-admin,.contenido-item-admin,.card-front-body{display:grid;gap:14px}
.mini-pill,.nota-admin,.item-reciente,.item-registro-admin,.item-soporte-admin{padding:16px;border:1px solid var(--linea);border-radius:18px;background:var(--superficie-suave)}
.mini-pill strong,.nota-admin strong,.item-reciente h4,.item-registro-admin h4{display:block;margin:0 0 4px}
.mini-pill span,.nota-admin span,.meta,.archivo-recurso-admin{color:var(--texto-suave);font-size:.92rem}
.panel-destacado,.kpi{padding:24px}
.kpi strong{font-size:1.8rem;display:block;margin:6px 0}
.kpi-etiqueta,.sobretitulo{letter-spacing:.12em;text-transform:uppercase;color:var(--texto-suave);font-size:.78rem;font-weight:800;margin:0 0 10px}
.grilla-servicios{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px}
.tarjeta-servicio{padding:28px;background:var(--superficie);border-radius:var(--radio);border:1px solid var(--linea);box-shadow:var(--sombra-sm)}
.icono-servicio{width:52px;height:52px;border-radius:16px;background:var(--acento);color:var(--principal);display:grid;place-items:center;font-weight:800;margin-bottom:16px;font-family:"Montserrat",system-ui,sans-serif}
.boton{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;cursor:pointer;padding:12px 18px;border-radius:14px;font-weight:700;transition:transform .15s ease, box-shadow .15s ease}
.boton:hover{transform:translateY(-1px)}
.boton-principal{background:var(--principal);color:#fff;box-shadow:var(--sombra-sm)}
.boton-secundario{background:#fff;color:var(--principal);border:1px solid rgba(102,45,145,.22)}
.boton-destacado{background:var(--destacado);color:#fff}
.boton-sm{padding:9px 13px;font-size:.88rem}
.link-texto{font-weight:700;color:var(--principal-fuerte)}

/* Admin / subscriber layout */
.cuerpo-admin{background:#fff8fc}
.esqueleto-admin{display:grid;grid-template-columns:280px 1fr;min-height:100vh}
.barra-lateral-admin{padding:24px 18px;border-right:1px solid var(--linea);background:#fff;display:flex;flex-direction:column;gap:22px}
.grupo-navegacion-admin{display:grid;gap:10px}
.titulo-navegacion-admin{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--texto-suave);font-weight:800;padding:0 10px}
.link-lateral{display:flex;align-items:flex-start;gap:12px;padding:12px;border-radius:16px;color:var(--texto)}
.link-lateral:hover,.link-lateral.activo{background:rgba(102,45,145,.08)}
.link-lateral strong{display:block;font-size:.95rem}
.link-lateral span{color:var(--texto-suave);font-size:.84rem}
.punto{width:10px;height:10px;border-radius:50%;background:#dcb8eb;margin-top:7px;flex:0 0 auto}
.link-lateral.activo .punto{background:var(--destacado)}
.pie-lateral-admin{margin-top:auto;display:grid;gap:14px}
.tarjeta-usuario{display:flex;gap:12px;align-items:center;padding:14px;border-radius:18px;background:#f8fafc;border:1px solid var(--linea)}
.avatar-usuario{width:42px;height:42px;border-radius:12px;background:var(--principal);color:#fff;display:grid;place-items:center;font-weight:800;font-family:"Montserrat",system-ui,sans-serif}
.contenido-admin{padding:28px;display:grid;gap:22px}
.barra-superior-admin{display:flex;justify-content:space-between;gap:20px;align-items:flex-start}
.barra-superior-admin h1{margin:4px 0 8px;font-size:2rem;letter-spacing:-.04em}
.barra-superior-admin p{margin:0;color:var(--texto-suave)}
.acciones-superiores-verticales{display:grid;gap:12px;justify-items:end}
.buscador-superior{display:flex;gap:10px;min-width:min(100%,420px)}

.hero-admin{padding:30px;border-radius:28px;background:var(--principal);color:#fff;display:grid;grid-template-columns:1.2fr .9fr;gap:24px;box-shadow:var(--sombra-md)}
.hero-admin p{color:rgba(255,255,255,.86)}
.columna-mini-estadisticas{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.mini-estadistica,.mini-resumen-pago{padding:20px}
.mini-estadistica small,.mini-resumen-pago small,.tarjeta-metrica small,.panel-plan-dashboard small{display:block;color:var(--texto-suave);text-transform:uppercase;letter-spacing:.08em;font-size:.75rem;font-weight:800;font-family:"Montserrat",system-ui,sans-serif}
.mini-estadistica strong,.mini-resumen-pago strong,.tarjeta-metrica strong,.panel-plan-dashboard strong,.precio-plan{display:block;font-size:2rem;letter-spacing:-.05em;margin:8px 0 4px}
.hero-admin .mini-estadistica,.hero-admin .mini-resumen-pago{background:rgba(255,255,255,.98);border-color:rgba(255,255,255,.46);color:var(--texto)}
.hero-admin .mini-estadistica strong,.hero-admin .mini-resumen-pago strong{color:var(--principal)}
.hero-admin .mini-estadistica small,.hero-admin .mini-resumen-pago small{color:var(--texto-suave)}
.grilla-kpis{grid-template-columns:repeat(4,minmax(0,1fr))}
.grilla-kpis-extendida{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}
.tarjeta-metrica{padding:22px}
.metrica-a{border-top:4px solid var(--principal)}.metrica-b{border-top:4px solid var(--destacado)}.metrica-c{border-top:4px solid var(--acento)}.metrica-d{border-top:4px solid var(--principal)}.metrica-e{border-top:4px solid var(--destacado)}.metrica-f{border-top:4px solid var(--acento)}
.tarjeta-admin{overflow:hidden}
.encabezado-tarjeta-admin{padding:22px 22px 0;display:flex;justify-content:space-between;gap:18px;align-items:flex-start}
.encabezado-con-filtros{flex-wrap:wrap}
.encabezado-tarjeta-admin h3{margin:0 0 6px;font-size:1.2rem}
.encabezado-tarjeta-admin p{margin:0;color:var(--texto-suave)}
.cuerpo-tarjeta-admin{padding:22px}
.formulario-admin,.filtros-inline-admin,.filtros-inline-admin-anchos{display:grid;gap:14px}
.filtros-inline-admin{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));align-items:end}
.filtros-inline-admin-anchos{grid-template-columns:minmax(260px,2fr) repeat(2,minmax(180px,1fr)) auto}
.grilla-campos-admin{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.grilla-campos-admin-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.campo-formulario{display:grid;gap:8px}
.campo-formulario label{font-weight:700;font-size:.93rem}
.campo-amplio{grid-column:1/-1}
.input-formulario{width:100%;padding:12px 14px;border:1px solid var(--linea);border-radius:14px;background:#fff;color:var(--texto)}
textarea.input-formulario{min-height:110px;resize:vertical}
.ayuda-campo{color:var(--texto-suave);font-size:.82rem}
.campo-checkbox-admin{align-content:end}
.preview-imagen-admin{margin-top:10px;border:1px solid var(--linea);background:#fff;padding:14px;border-radius:18px}
.preview-imagen-admin img{width:100%;max-height:260px;object-fit:cover;border-radius:14px}
.acciones-formulario,.acciones-formulario-admin{display:flex;gap:12px;flex-wrap:wrap}
.barra-acciones-formulario{padding-top:8px}
.lista-cards-con-imagen{gap:18px}
.item-registro-con-imagen{display:grid;grid-template-columns:220px 1fr;gap:18px}
.media-item-admin img,.card-front img,.item-reciente-con-media img,.hero-lectura-premium img,.imagen-cabecera-lectura{width:100%;height:100%;object-fit:cover;border-radius:18px}
.media-item-admin{min-height:160px}
.item-registro-cabecera,.item-soporte-admin-cabecera{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
.resumen-recurso-admin{display:grid;gap:8px}
.tabla-contenedor{overflow:auto}
.tabla-admin{width:100%;border-collapse:collapse;min-width:720px}
.tabla-admin th,.tabla-admin td{padding:14px 12px;border-bottom:1px solid var(--linea);text-align:left;vertical-align:top}
.tabla-admin th{font-size:.82rem;text-transform:uppercase;letter-spacing:.06em;color:var(--texto-suave)}
.alerta,.alerta-admin{padding:14px 16px;border-radius:16px;border:1px solid transparent}
.alerta-exito{background:#ecfdf3;color:var(--exito);border-color:#abefc6}
.alerta-error{background:#fef3f2;color:var(--peligro);border-color:#fecdca}
.alerta-ok{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe}

/* Soporte */
.grilla-soporte-admin{grid-template-columns:340px 1fr}
.lista-soporte-admin{gap:12px}
.item-soporte-admin{display:grid;gap:8px;color:inherit}
.item-soporte-admin.activo{border-color:var(--principal);background:#fff;box-shadow:var(--sombra-sm)}
.hilo-soporte{display:grid;gap:14px;margin-bottom:20px}
.burbuja-soporte{padding:18px;border-radius:20px;display:grid;gap:10px;max-width:90%}
.burbuja-soporte small{font-weight:800;color:var(--texto-suave);text-transform:uppercase;letter-spacing:.06em}
.burbuja-soporte-usuario{background:#f8fafc;border:1px solid var(--linea)}
.burbuja-soporte-admin{background:var(--destacado-suave);border:1px solid rgba(200,0,138,.18);margin-left:auto}
.meta-soporte-detalle{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px}

/* Cards front inside dashboard */
.grilla-cards-front{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.card-front{overflow:hidden}
.card-front img{height:180px;border-radius:0}
.card-front-body{padding:18px}
.card-front-body h3{margin:0;font-size:1.08rem}
.card-front-body p{margin:0;color:var(--texto-suave)}
.item-reciente-resumen{display:flex;justify-content:space-between;align-items:center;gap:12px}
.item-reciente-con-media{grid-template-columns:74px 1fr;align-items:center}
.item-reciente-con-media img{height:74px}

/* Reading */
.contenedor-lectura-publica{max-width:980px}
.lectura-publica-pro,.lectura-articulo-premium{display:grid;gap:22px}
.imagen-cabecera-lectura{height:360px;border-radius:18px}
.contenido-html p,.contenido-html ul,.contenido-html ol,.contenido-html blockquote,.contenido-html h2,.contenido-html h3,.contenido-html h4{margin:0 0 16px}
.contenido-html-lectura{font-size:1.06rem;line-height:1.9;color:var(--texto)}
.contenido-html-lectura h2,.contenido-html-lectura h3,.contenido-html-lectura h4{color:#101828;line-height:1.2}
.contenido-html-lectura blockquote{padding:18px 20px;border-left:4px solid var(--destacado);background:var(--destacado-suave);border-radius:14px;font-family:"Playfair Display",serif;font-style:italic;color:var(--principal)}
.cta-final-lectura{margin-top:24px;padding:24px;border-radius:18px;background:#f8fafc;border:1px solid var(--linea)}
.hero-lectura-premium{display:grid;grid-template-columns:340px 1fr;gap:22px;padding:22px}
.hero-lectura-premium h1{margin:0;font-size:2.2rem;letter-spacing:-.04em}

/* Search and dashboard extras */
.hero-suscriptor{padding:30px;border-radius:28px;background:var(--superficie);border:1px solid var(--linea);display:grid;grid-template-columns:1.2fr .8fr;gap:24px;box-shadow:var(--sombra-sm)}
.panel-plan-dashboard{padding:24px;border:1px solid var(--linea);background:#fff;border-radius:22px}
.hero-suscriptor p{color:var(--texto-suave)}

/* Legacy payment-specific classes */
.detalle-pago-admin{display:grid;gap:20px}
.bloque-detalle-pago{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.bloque-detalle-pago>div{background:var(--superficie-suave);border:1px solid var(--linea);border-radius:18px;padding:16px;display:grid;gap:8px}
.bloque-detalle-pago strong{font-weight:800}
.bloque-detalle-pago span{color:var(--texto-suave);line-height:1.5}
.resumen-pagos-admin{grid-template-columns:repeat(4,minmax(0,1fr))}

/* Footer */
.pie-sitio{margin-top:30px;border-top:1px solid var(--linea);background:#fff}


h1,h2,h3,h4,h5,h6,.titulo-hero,.titulo-seccion,.titulo-hero-publico,.sobretitulo,.kpi-etiqueta,.link-lateral strong,.titulo-navegacion-admin,.boton,.campo-formulario label,.tabla-admin th,.barra-superior-admin h1,.encabezado-tarjeta-admin h3{font-family:"Montserrat",system-ui,sans-serif}

p,span,li,input,textarea,select,.hero-texto,.subtitulo-seccion,.texto-hero-publico,.texto-base,.copia-marca span,.marca-admin span,.pie-texto,.pie-inferior,.link-lateral span,.barra-superior-admin p,.card-front-body p,.nota-admin span,.mini-pill span,.item-reciente p,.item-registro-admin p{font-family:"Glacial Indifference","Montserrat",sans-serif}

.texto-emotivo,.cita-emotiva,.playfair,blockquote em,.frase-destacada em{font-family:"Playfair Display",serif;font-style:italic}

.encabezado-sitio{position:sticky;top:0;z-index:20;background:rgba(255,255,255,.96);backdrop-filter:blur(10px);border-bottom:1px solid var(--linea)}
.link-navegacion:hover{color:var(--principal)}
.boton-secundario:hover{border-color:rgba(102,45,145,.4)}
.chapa-advertencia{background:var(--acento-suave);color:var(--advertencia)}
.marca,.marca-admin,.barra-superior-admin .sobretitulo{color:var(--principal)}
.hero-admin .sobretitulo,.hero-admin h1,.hero-admin h2,.hero-admin h3,.hero-admin small{color:#fff}
.hero-suscriptor{border-top:4px solid var(--principal)}
.tarjeta-servicio,.tarjeta-servicio-publica,.tarjeta-estatica-publica,.tarjeta-contacto-publica,.tarjeta-admin,.card-front,.panel-plan-dashboard,.mini-estadistica,.tarjeta-metrica,.mini-resumen-pago,.tarjeta-hero,.tarjeta-hero-publica{background:var(--superficie)}
.test-badge-acento{background:var(--acento);color:var(--principal)}

/* Responsive */
@media (max-width: 1100px){
  .esqueleto-admin{grid-template-columns:1fr}
  .barra-lateral-admin{position:fixed;top:0;left:0;bottom:0;width:min(86vw,320px);height:100vh;overflow:auto;transform:translateX(-102%);transition:transform .24s ease;z-index:60;border-right:1px solid var(--linea);border-bottom:none;box-shadow:var(--sombra-md)}
  body.menu-abierto .barra-lateral-admin{transform:translateX(0)}
  .overlay-menu{display:block;position:fixed;inset:0;background:rgba(47,31,61,.35);opacity:0;visibility:hidden;pointer-events:none;transition:opacity .24s ease, visibility .24s ease;z-index:50}
  body.menu-abierto .overlay-menu{opacity:1;visibility:visible;pointer-events:auto}
  .boton-menu-panel{display:inline-flex;width:max-content}
  .grilla-hero,.hero-admin,.hero-suscriptor,.grilla-soporte-admin,.item-registro-con-imagen,.hero-lectura-premium{grid-template-columns:1fr}
}
@media (max-width: 860px){
  .navegacion-sitio,.barra-pie,.barra-superior-admin{align-items:flex-start}
  .navegacion-sitio{padding:14px 0;flex-wrap:wrap}
  .boton-menu-movil{display:inline-flex;margin-left:auto}
  .links-navegacion{display:none;width:100%;padding-top:12px;flex-direction:column;align-items:stretch;gap:10px}
  body.menu-publico-abierto .links-navegacion{display:flex}
  .links-navegacion .boton,.links-navegacion .link-navegacion{width:100%;justify-content:flex-start}
  .grilla-servicios,.grilla-kpis,.resumen-pagos-admin{grid-template-columns:1fr 1fr}
  .grilla-campos-admin,.grilla-campos-admin-2,.filtros-inline-admin,.filtros-inline-admin-anchos{grid-template-columns:1fr}
  .contenedor,.contenido-admin{padding-left:18px;padding-right:18px}
}
@media (max-width: 560px){
  .grilla-servicios,.grilla-kpis,.resumen-pagos-admin,.columna-mini-estadisticas{grid-template-columns:1fr}
  .tarjeta-hero,.tarjeta-hero-publica,.tarjeta-admin,.tarjeta-servicio{padding:22px}
  .titulo-hero,.titulo-seccion,.titulo-hero-publico{font-size:1.85rem}
}


/* Public footer and static/contact pages */
.pie-sitio{margin-top:56px;border-top:1px solid var(--linea);background:var(--superficie)}
.pie-contenido{padding-top:34px;padding-bottom:28px}
.pie-grid{display:grid;grid-template-columns:minmax(260px,1.5fr) repeat(4,minmax(150px,1fr));gap:28px;padding-bottom:24px}
.pie-columna{display:grid;align-content:start;gap:12px}
.pie-columna h3{margin:0;font-size:.95rem;letter-spacing:.04em;text-transform:uppercase;color:var(--principal);font-family:"Montserrat",system-ui,sans-serif;font-weight:700}
.pie-columna a{color:var(--texto-suave);font-weight:500;font-family:"Glacial Indifference","Montserrat",sans-serif}
.pie-columna a:hover{color:var(--principal)}
.pie-columna-marca{gap:16px}
.pie-texto{margin:0;color:var(--texto-suave);max-width:34ch}
.pie-inferior{display:flex;justify-content:space-between;gap:16px;padding-top:18px;border-top:1px solid var(--linea);color:var(--texto-suave);font-size:.95rem}

.contacto-shell{max-width:920px}
.contacto-head-simple{margin-bottom:20px}
.tarjeta-contacto-publica,.tarjeta-estatica-publica,.tarjeta-servicio-publica{background:var(--superficie);border:1px solid var(--linea);border-radius:var(--radio);box-shadow:var(--sombra-sm)}
.tarjeta-contacto-publica{padding:28px}
.formulario-contacto-publico{display:grid;gap:18px}
.grilla-campos-contacto-publica{grid-template-columns:repeat(2,minmax(0,1fr))}
.textarea-contacto-publica{min-height:180px}
.contacto-acciones-publicas{padding-top:6px}
.contenido-estatico-publico{display:grid;gap:22px}
.tarjeta-estatica-publica{padding:28px}
.tarjeta-estatica-publica p{margin:0 0 14px;color:var(--texto-suave)}
.tarjeta-estatica-publica p:last-child{margin-bottom:0}
.grilla-metodologia-publica,.grilla-servicios-publica{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.tarjeta-servicio-publica{padding:26px;display:grid;gap:12px}
.tarjeta-servicio-publica h2,.tarjeta-estatica-publica h2{margin:0;font-size:1.25rem;letter-spacing:-.03em}
.tarjeta-servicio-publica p{margin:0;color:var(--texto-suave)}

@media (max-width: 980px){
  .pie-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width: 760px){
  .pie-grid,.grilla-metodologia-publica,.grilla-servicios-publica,.grilla-campos-contacto-publica{grid-template-columns:1fr}
  .pie-inferior{flex-direction:column;align-items:flex-start}
}


/* Commercial week */
.hero-comercial{padding-bottom:34px}
.grilla-hero-comercial{align-items:stretch}
.tarjeta-hero-comercial{display:grid;gap:20px}
.micro-hero-comercial{margin-top:4px}
.columna-hero-comercial{display:grid;gap:18px}
.panel-resultado{height:100%}
.kpi-precio strong{font-size:2rem;letter-spacing:-.04em}
.encabezado-centrado{text-align:center;justify-content:center}
.section-alt{background:linear-gradient(180deg,#fff 0%,#fbf7ff 100%)}
.section-alt-soft{padding:6px 0}
.proof-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.proof-card{padding:28px;display:grid;gap:12px}
.proof-card h3{margin:0;font-size:1.16rem;letter-spacing:-.03em}
.journey-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.journey-step{background:var(--superficie);border:1px solid var(--linea);border-radius:var(--radio);padding:26px;box-shadow:var(--sombra-sm);display:grid;gap:12px}
.journey-step h3{margin:0;font-size:1.14rem}
.journey-step p{margin:0;color:var(--texto-suave)}
.journey-step-number{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:999px;background:rgba(102,45,145,.1);color:var(--principal);font-weight:800}
.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}
.pricing-grid-home{align-items:stretch}
.pricing-card{position:relative;background:var(--superficie);border:1px solid var(--linea);border-radius:var(--radio);box-shadow:var(--sombra-sm);padding:28px;display:grid;gap:18px}
.pricing-card-featured{border-color:rgba(200,0,138,.25);box-shadow:0 18px 44px rgba(102,45,145,.12)}
.pricing-card-full{grid-column:1/-1}
.pricing-badge{position:absolute;top:18px;right:18px;display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;background:var(--destacado-suave);color:var(--destacado);font-weight:800;font-size:.82rem}
.pricing-head{display:grid;gap:8px}
.pricing-head h3{margin:0;font-size:1.36rem;letter-spacing:-.04em}
.pricing-head p{margin:0;color:var(--texto-suave)}
.pricing-price-wrap{display:grid;gap:6px}
.pricing-price{font-size:2.35rem;line-height:1;letter-spacing:-.06em;color:#101828}
.pricing-period{color:var(--texto-suave);font-weight:700}
.pricing-list{display:grid;gap:10px;margin:0;padding-left:18px;color:var(--texto-suave)}
.pricing-list li{line-height:1.6}
.faq-preview{max-width:980px}
.faq-preview-card{padding:28px;display:grid;gap:18px}
.faq-list{display:grid;gap:14px}
.faq-list-wide{grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.faq-item{display:grid;gap:8px}
.faq-item h3{margin:0;font-size:1.04rem}
.faq-item p{margin:0;color:var(--texto-suave);line-height:1.7}
.cta-band{display:flex;justify-content:space-between;gap:22px;align-items:center;padding:30px;border-radius:28px;background:linear-gradient(135deg,var(--principal) 0%,#7d3cb3 100%);color:#fff;box-shadow:var(--sombra-md)}
.cta-band h2{margin:8px 0 0;font-size:2rem;letter-spacing:-.05em;color:#fff}
.cta-band p{margin:10px 0 0;color:rgba(255,255,255,.86);max-width:60ch}
.tarjeta-hero-publica-larga{padding:34px}
.tarjeta-servicio-destacada{border-color:rgba(200,0,138,.22)}
.contacto-shell-wide{max-width:1100px}
.contacto-layout{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(280px,.85fr);gap:20px;align-items:start}
.contacto-beneficios{display:grid;gap:18px}

.acciones-stack-mobile{align-items:flex-start}
@media (max-width: 980px){
  .proof-grid,.journey-grid,.faq-list-wide,.contacto-layout{grid-template-columns:1fr}
  .cta-band{flex-direction:column;align-items:flex-start}
}
@media (max-width: 760px){
  .pricing-price{font-size:2rem}
  .cta-band h2{font-size:1.7rem}
}


/* Visual premium upgrade */
body{
  background:
    radial-gradient(circle at top left, rgba(200,0,138,.05), transparent 28%),
    radial-gradient(circle at top right, rgba(255,222,89,.14), transparent 24%),
    linear-gradient(180deg,#fffafc 0%,#fff 34%,#fbf7ff 100%);
}
.encabezado-sitio{box-shadow:0 12px 30px rgba(102,45,145,.05)}
.link-navegacion{position:relative;transition:color .18s ease}
.link-navegacion::after{content:"";position:absolute;left:0;right:0;bottom:-8px;height:2px;border-radius:999px;background:var(--destacado);transform:scaleX(0);transform-origin:center;transition:transform .18s ease}
.link-navegacion:hover::after{transform:scaleX(1)}
.boton{font-family:"Montserrat",system-ui,sans-serif;letter-spacing:-.01em}
.boton-principal,.boton-destacado{box-shadow:0 16px 34px rgba(102,45,145,.16)}
.boton-principal:hover,.boton-destacado:hover{box-shadow:0 20px 38px rgba(102,45,145,.2)}
.tarjeta-servicio,.pricing-card,.proof-card,.journey-step,.tarjeta-servicio-publica,.tarjeta-estatica-publica,.tarjeta-contacto-publica{transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease}
.tarjeta-servicio:hover,.pricing-card:hover,.proof-card:hover,.journey-step:hover,.tarjeta-servicio-publica:hover,.tarjeta-estatica-publica:hover,.tarjeta-contacto-publica:hover{transform:translateY(-4px);box-shadow:0 22px 44px rgba(102,45,145,.12);border-color:rgba(102,45,145,.20)}
.hero-comercial{position:relative;overflow:hidden}
.hero-comercial::before{
  content:"";
  position:absolute;inset:0;
  background:
    radial-gradient(circle at 10% 20%, rgba(255,222,89,.22), transparent 22%),
    radial-gradient(circle at 92% 15%, rgba(200,0,138,.12), transparent 18%),
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,0));
  pointer-events:none;
}
.grilla-hero-comercial{position:relative;z-index:1}
.tarjeta-hero-comercial{
  position:relative;
  overflow:hidden;
  background:
    linear-gradient(180deg, rgba(255,255,255,.94), rgba(255,255,255,.98)),
    var(--superficie);
  box-shadow:0 24px 56px rgba(102,45,145,.10);
}
.tarjeta-hero-comercial::after{
  content:"";
  position:absolute;right:-80px;top:-90px;
  width:220px;height:220px;border-radius:50%;
  background:radial-gradient(circle, rgba(200,0,138,.12), rgba(200,0,138,0));
}
.panel-resumen-premium{
  background:linear-gradient(180deg, rgba(102,45,145,.96), #54257a 100%);
  color:#fff;border:none;box-shadow:0 24px 56px rgba(102,45,145,.18)
}
.panel-resumen-premium small,.panel-resumen-premium p,.panel-resumen-premium li{color:rgba(255,255,255,.86)}
.panel-resumen-premium h3{margin:8px 0 0;font-size:1.45rem;letter-spacing:-.04em}
.lista-destacada-premium{display:grid;gap:12px}
.lista-destacada-premium .item-premium{
  padding:14px 16px;border-radius:18px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12)
}
.quick-facts-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.quick-fact-card{
  padding:22px;border-radius:22px;background:#fff;border:1px solid var(--linea);
  box-shadow:var(--sombra-sm);display:grid;gap:10px
}
.quick-fact-card strong{font-size:1.1rem;letter-spacing:-.03em}
.quick-fact-card span{color:var(--texto-suave);line-height:1.6}
.compare-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.compare-card{
  position:relative;padding:26px;border-radius:24px;background:#fff;border:1px solid var(--linea);box-shadow:var(--sombra-sm);display:grid;gap:14px
}
.compare-card h3{margin:0;font-size:1.22rem;letter-spacing:-.03em}
.compare-card p{margin:0;color:var(--texto-suave);line-height:1.7}
.compare-card ul{margin:0;padding-left:18px;color:var(--texto-suave);display:grid;gap:8px}
.compare-card-featured{
  background:linear-gradient(180deg,#fff 0%,#fff7fc 100%);
  border-color:rgba(200,0,138,.28);
  box-shadow:0 22px 54px rgba(102,45,145,.12)
}
.compare-chip,.summary-chip{
  display:inline-flex;align-items:center;justify-content:center;
  width:max-content;padding:7px 12px;border-radius:999px;
  background:rgba(102,45,145,.1);color:var(--principal);font-size:.82rem;font-weight:800
}
.summary-chip-light{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.16)}
.plan-highlight-strip{
  display:flex;justify-content:space-between;gap:20px;align-items:center;
  padding:22px 24px;border-radius:24px;background:linear-gradient(135deg,#fff 0%,#fff5fb 100%);
  border:1px solid rgba(200,0,138,.18);box-shadow:var(--sombra-sm)
}
.plan-highlight-strip p{margin:6px 0 0;color:var(--texto-suave)}
.plan-highlight-strip strong{font-size:1.25rem;letter-spacing:-.03em}
.hero-dual-grid{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(290px,.95fr);gap:20px;align-items:stretch}
.summary-card{
  padding:28px;border-radius:28px;background:linear-gradient(160deg,var(--principal) 0%, #7b37af 100%);color:#fff;box-shadow:0 24px 56px rgba(102,45,145,.18);display:grid;gap:18px
}
.summary-card h2,.summary-card h3,.summary-card strong{color:#fff}
.summary-card p,.summary-card li{color:rgba(255,255,255,.86)}
.summary-list{display:grid;gap:12px;margin:0;padding:0;list-style:none}
.summary-list li{padding:14px 16px;border-radius:18px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12)}
.pricing-card{padding:30px}
.pricing-card-featured{transform:translateY(-4px);background:linear-gradient(180deg,#fff 0%,#fff7fc 100%)}
.pricing-card-featured .pricing-price{color:var(--destacado)}
.pricing-head p{line-height:1.65}
.pricing-list{padding-left:20px}
.pricing-list li::marker{color:var(--destacado)}
.faq-preview-card,.cta-band,.summary-card,.panel-resumen-premium{border-radius:30px}
.contacto-layout .tarjeta-contacto-publica{padding:30px}
.section-title-tight{max-width:720px}
@media (max-width: 980px){
  .quick-facts-grid,.compare-grid,.hero-dual-grid{grid-template-columns:1fr}
  .plan-highlight-strip{flex-direction:column;align-items:flex-start}
}
@media (max-width: 760px){
  .plan-highlight-strip,.summary-card,.panel-resumen-premium{padding:20px}
}


/* Refuerzo visual comercial home */
.compare-grid,
.journey-grid,
.pricing-grid-home{
  position:relative;
  padding:24px;
  border-radius:32px;
  border:1px solid rgba(102,45,145,.12);
  background:linear-gradient(180deg,#ffffff 0%,#fff8fd 100%);
  box-shadow:0 24px 60px rgba(102,45,145,.10);
}
.compare-grid::before,
.journey-grid::before,
.pricing-grid-home::before{
  content:"";
  position:absolute;
  right:-70px;
  top:-70px;
  width:180px;
  height:180px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(200,0,138,.12), rgba(200,0,138,0) 72%);
  pointer-events:none;
}
.compare-grid::after,
.journey-grid::after,
.pricing-grid-home::after{
  content:"";
  position:absolute;
  left:-60px;
  bottom:-90px;
  width:170px;
  height:170px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(255,222,89,.18), rgba(255,222,89,0) 72%);
  pointer-events:none;
}
.compare-grid > *,
.journey-grid > *,
.pricing-grid-home > *{position:relative;z-index:1}
.compare-grid{gap:22px}
.compare-card{
  position:relative;
  padding:30px;
  border-radius:28px;
  background:linear-gradient(180deg,#fff 0%,#fffbfe 100%);
  border:1px solid rgba(102,45,145,.12);
  box-shadow:0 18px 44px rgba(102,45,145,.10);
  overflow:hidden;
}
.compare-card::before{
  content:"";
  position:absolute;
  inset:0 auto auto 0;
  width:100%;
  height:6px;
  background:linear-gradient(90deg,var(--principal) 0%, var(--destacado) 100%);
}
.compare-card::after{
  content:"";
  position:absolute;
  right:-36px;
  bottom:-36px;
  width:110px;
  height:110px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(102,45,145,.08), rgba(102,45,145,0) 70%);
}
.compare-card-test::before{background:linear-gradient(90deg,var(--principal) 0%, #8d59b7 100%)}
.compare-card-consulta::before{background:linear-gradient(90deg,var(--acento) 0%, #ffc400 100%)}
.compare-card-membresia::before{background:linear-gradient(90deg,var(--destacado) 0%, var(--principal) 100%)}
.compare-card-featured{
  transform:translateY(-6px);
  background:linear-gradient(180deg,#fff 0%,#fff2fa 100%);
  border-color:rgba(200,0,138,.28);
  box-shadow:0 26px 56px rgba(102,45,145,.16);
}
.compare-card h3{font-size:1.24rem}
.compare-chip{box-shadow:inset 0 0 0 1px rgba(102,45,145,.08)}
.journey-grid{
  background:linear-gradient(180deg,#fff 0%,#fcf7ff 100%);
  gap:22px;
}
.journey-step{
  position:relative;
  padding:30px;
  border-radius:28px;
  background:linear-gradient(180deg,#fff 0%,#fffbff 100%);
  border:1px solid rgba(102,45,145,.12);
  box-shadow:0 18px 42px rgba(102,45,145,.10);
  overflow:hidden;
}
.journey-step::before{
  content:"";
  position:absolute;
  inset:auto 0 0 0;
  height:5px;
  background:linear-gradient(90deg,var(--principal) 0%, var(--destacado) 100%);
}
.journey-step-2::before{background:linear-gradient(90deg,var(--acento) 0%, #ffc400 100%)}
.journey-step-3::before{background:linear-gradient(90deg,var(--destacado) 0%, var(--principal) 100%)}
.journey-step-number{
  width:52px;
  height:52px;
  border-radius:18px;
  background:rgba(102,45,145,.10);
  box-shadow:inset 0 0 0 1px rgba(102,45,145,.08);
}
.pricing-grid-home{
  background:linear-gradient(180deg,#fff 0%,#fff4fb 100%);
  border-color:rgba(200,0,138,.18);
  gap:22px;
}
.pricing-grid-home .pricing-card{
  border-radius:30px;
  border:1px solid rgba(102,45,145,.12);
  background:linear-gradient(180deg,#fff 0%,#fffbfd 100%);
  box-shadow:0 20px 52px rgba(102,45,145,.10);
}
.pricing-grid-home .pricing-card-featured{
  transform:translateY(-8px);
  background:linear-gradient(180deg,#fff 0%,#fff1fa 100%);
  border-color:rgba(200,0,138,.28);
  box-shadow:0 28px 60px rgba(102,45,145,.16);
}
.plan-highlight-strip{
  padding:24px 26px;
  border-radius:28px;
  background:linear-gradient(135deg,#fff 0%,#fff0f9 100%);
  border:1px solid rgba(200,0,138,.20);
  box-shadow:0 20px 48px rgba(102,45,145,.10);
}
@media (max-width: 980px){
  .compare-grid,
  .journey-grid,
  .pricing-grid-home{padding:20px}
}
@media (max-width: 760px){
  .compare-grid,
  .journey-grid,
  .pricing-grid-home{padding:16px;border-radius:24px}
  .compare-card,
  .journey-step,
  .pricing-grid-home .pricing-card{padding:22px;border-radius:22px}
}


/* TinyMCE local */
.tox.tox-tinymce{
  border:1px solid var(--linea);
  border-radius:18px;
  box-shadow:var(--sombra-sm);
}
.tox .tox-editor-header{
  border-bottom:1px solid var(--linea) !important;
  box-shadow:none !important;
}
.tox .tox-toolbar-overlord,
.tox .tox-toolbar,
.tox .tox-toolbar__primary,
.tox:not(.tox-tinymce-inline) .tox-editor-header{
  background:#fff !important;
}
.tox .tox-tbtn:hover,
.tox .tox-tbtn--enabled,
.tox .tox-tbtn--enabled:hover{
  background:rgba(102,45,145,.10) !important;
}
.tox .tox-tbtn svg,
.tox .tox-statusbar a,
.tox .tox-statusbar__wordcount,
.tox .tox-statusbar__path-item,
.tox .tox-statusbar__branding{
  color:var(--principal) !important;
  fill:var(--principal) !important;
}
.tox .tox-edit-area::before{
  border-radius:0 0 18px 18px !important;
}
.tox .tox-statusbar{
  border-top:1px solid var(--linea) !important;
}


/* Auth pages */
.pagina-auth{position:relative;min-height:100vh;background:radial-gradient(circle at top left,rgba(200,0,138,.08),transparent 30%),radial-gradient(circle at top right,rgba(255,222,89,.26),transparent 28%),linear-gradient(135deg,#fffafc 0%,#fff7fc 48%,#fff8d6 100%);overflow-x:hidden}
.pagina-auth::before,.pagina-auth::after{content:"";position:fixed;z-index:0;border-radius:999px;filter:blur(12px);opacity:.75;pointer-events:none}
.pagina-auth::before{width:240px;height:240px;left:-90px;top:120px;background:rgba(102,45,145,.09)}
.pagina-auth::after{width:280px;height:280px;right:-100px;bottom:40px;background:rgba(200,0,138,.07)}
.auth-shell{position:relative;z-index:1;max-width:1120px;margin:0 auto;padding:56px 24px 72px}
.auth-grid{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:24px;align-items:stretch}
.tarjeta-formulario{max-width:none;margin:0;padding:36px;background:rgba(255,255,255,.94);border:1px solid rgba(102,45,145,.12);border-radius:30px;box-shadow:0 26px 70px rgba(102,45,145,.12);backdrop-filter:blur(10px);display:grid;gap:18px}
.tarjeta-formulario h1{margin:0;font-size:clamp(2rem,3.2vw,2.9rem);line-height:1.02;letter-spacing:-.06em}
.tarjeta-formulario p{margin:0;color:var(--texto-suave)}
.auth-subtitulo{max-width:58ch;font-size:1.02rem}
.auth-panel-lateral{display:grid;align-content:start;gap:18px;padding:30px;border-radius:30px;background:linear-gradient(180deg,rgba(102,45,145,.98),rgba(82,35,120,.98));border:1px solid rgba(255,255,255,.18);box-shadow:0 26px 70px rgba(61,19,90,.20);color:#fff;overflow:hidden;position:relative}
.auth-panel-lateral::before{content:"";position:absolute;inset:auto -40px -40px auto;width:180px;height:180px;border-radius:999px;background:radial-gradient(circle,rgba(255,222,89,.35),rgba(255,222,89,0) 65%)}
.auth-panel-lateral > *{position:relative;z-index:1}
.auth-panel-lateral h2{margin:0;font-size:clamp(1.5rem,2.2vw,2rem);line-height:1.06;letter-spacing:-.05em}
.auth-panel-lateral p{margin:0;color:rgba(255,255,255,.82)}
.auth-beneficios{display:grid;gap:12px}
.auth-beneficio{display:grid;gap:4px;padding:14px 16px;border:1px solid rgba(255,255,255,.14);border-radius:18px;background:rgba(255,255,255,.08)}
.auth-beneficio strong{font-family:"Montserrat",system-ui,sans-serif;font-size:.95rem}
.auth-beneficio span{color:rgba(255,255,255,.78);font-size:.92rem}
.auth-panel-acciones{display:grid;gap:10px;padding-top:4px}
.auth-panel-link{display:inline-flex;align-items:center;gap:8px;font-weight:700;color:#fff}
.auth-panel-link::after{content:"→";font-size:1rem}
.seccion-formulario{display:grid;gap:16px}
.grilla-doble-auth{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.campo{display:grid;gap:8px}
.campo label{font-weight:700;font-family:"Montserrat",system-ui,sans-serif;font-size:.94rem;color:var(--principal)}
.entrada{width:100%;padding:15px 16px;border:1px solid rgba(102,45,145,.16);border-radius:16px;background:#fff;color:var(--texto);outline:none;transition:border-color .18s ease, box-shadow .18s ease, transform .18s ease;box-shadow:0 1px 0 rgba(102,45,145,.02)}
.entrada::placeholder{color:#9b8ba8}
.entrada:hover{border-color:rgba(102,45,145,.30)}
.entrada:focus{border-color:rgba(102,45,145,.46);box-shadow:0 0 0 4px rgba(102,45,145,.10)}
.acciones-auth{display:flex;align-items:center;gap:12px;flex-wrap:wrap;padding-top:6px}
.acciones-auth .boton{min-width:148px}
.auth-links-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:2px}
.tarjeta-formulario-comercial{max-width:none}
.tarjeta-formulario .alerta{font-weight:700}
.auth-nota{padding:14px 16px;border-radius:18px;background:rgba(102,45,145,.06);border:1px solid rgba(102,45,145,.10);color:var(--texto-suave)}

@media (max-width:960px){
  .auth-grid{grid-template-columns:1fr}
  .auth-panel-lateral{order:-1}
}

@media (max-width:640px){
  .auth-shell{padding:28px 16px 40px}
  .tarjeta-formulario,.auth-panel-lateral{padding:24px;border-radius:24px}
  .acciones-auth,.auth-links-grid,.grilla-doble-auth{display:grid;grid-template-columns:1fr}
  .acciones-auth .boton,.auth-links-grid .boton{width:100%}
}

/* Reading */
.contenedor-lectura-publica{max-width:980px}
.lectura-publica-pro,.lectura-articulo-premium{display:grid;gap:22px}
.imagen-cabecera-lectura{height:360px;border-radius:18px}
.contenido-html p,.contenido-html ul,.contenido-html ol,.contenido-html blockquote,.contenido-html h2,.contenido-html h3,.contenido-html h4{margin:0 0 16px}
.contenido-html-lectura{font-size:1.06rem;line-height:1.9;color:var(--texto)}
.contenido-html-lectura h2,.contenido-html-lectura h3,.contenido-html-lectura h4{color:#101828;line-height:1.2}
.contenido-html-lectura blockquote{padding:18px 20px;border-left:4px solid var(--destacado);background:var(--destacado-suave);border-radius:14px;font-family:"Playfair Display",serif;font-style:italic;color:var(--principal)}
.cta-final-lectura{margin-top:24px;padding:24px;border-radius:18px;background:#f8fafc;border:1px solid var(--linea)}
.hero-lectura-premium{display:grid;grid-template-columns:340px 1fr;gap:22px;padding:22px}
.hero-lectura-premium h1{margin:0;font-size:2.2rem;letter-spacing:-.04em}

/* Search and dashboard extras */
.hero-suscriptor{padding:30px;border-radius:28px;background:var(--superficie);border:1px solid var(--linea);display:grid;grid-template-columns:1.2fr .8fr;gap:24px;box-shadow:var(--sombra-sm)}
.panel-plan-dashboard{padding:24px;border:1px solid var(--linea);background:#fff;border-radius:22px}
.hero-suscriptor p{color:var(--texto-suave)}

/* Legacy payment-specific classes */
.detalle-pago-admin{display:grid;gap:20px}
.bloque-detalle-pago{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.bloque-detalle-pago>div{background:var(--superficie-suave);border:1px solid var(--linea);border-radius:18px;padding:16px;display:grid;gap:8px}
.bloque-detalle-pago strong{font-weight:800}
.bloque-detalle-pago span{color:var(--texto-suave);line-height:1.5}
.resumen-pagos-admin{grid-template-columns:repeat(4,minmax(0,1fr))}

/* Footer */
.pie-sitio{margin-top:30px;border-top:1px solid var(--linea);background:#fff}


h1,h2,h3,h4,h5,h6,.titulo-hero,.titulo-seccion,.titulo-hero-publico,.sobretitulo,.kpi-etiqueta,.link-lateral strong,.titulo-navegacion-admin,.boton,.campo-formulario label,.tabla-admin th,.barra-superior-admin h1,.encabezado-tarjeta-admin h3{font-family:"Montserrat",system-ui,sans-serif}

p,span,li,input,textarea,select,.hero-texto,.subtitulo-seccion,.texto-hero-publico,.texto-base,.copia-marca span,.marca-admin span,.pie-texto,.pie-inferior,.link-lateral span,.barra-superior-admin p,.card-front-body p,.nota-admin span,.mini-pill span,.item-reciente p,.item-registro-admin p{font-family:"Glacial Indifference","Montserrat",sans-serif}

.texto-emotivo,.cita-emotiva,.playfair,blockquote em,.frase-destacada em{font-family:"Playfair Display",serif;font-style:italic}

.encabezado-sitio{position:sticky;top:0;z-index:20;background:rgba(255,255,255,.96);backdrop-filter:blur(10px);border-bottom:1px solid var(--linea)}
.link-navegacion:hover{color:var(--principal)}
.boton-secundario:hover{border-color:rgba(102,45,145,.4)}
.chapa-advertencia{background:var(--acento-suave);color:var(--advertencia)}
.marca,.marca-admin,.barra-superior-admin .sobretitulo{color:var(--principal)}
.hero-admin .sobretitulo,.hero-admin h1,.hero-admin h2,.hero-admin h3,.hero-admin small{color:#fff}
.hero-suscriptor{border-top:4px solid var(--principal)}
.tarjeta-servicio,.tarjeta-servicio-publica,.tarjeta-estatica-publica,.tarjeta-contacto-publica,.tarjeta-admin,.card-front,.panel-plan-dashboard,.mini-estadistica,.tarjeta-metrica,.mini-resumen-pago,.tarjeta-hero,.tarjeta-hero-publica{background:var(--superficie)}
.test-badge-acento{background:var(--acento);color:var(--principal)}

/* Responsive */
@media (max-width: 1100px){
  .esqueleto-admin{grid-template-columns:1fr}
  .barra-lateral-admin{position:fixed;top:0;left:0;bottom:0;width:min(86vw,320px);height:100vh;overflow:auto;transform:translateX(-102%);transition:transform .24s ease;z-index:60;border-right:1px solid var(--linea);border-bottom:none;box-shadow:var(--sombra-md)}
  body.menu-abierto .barra-lateral-admin{transform:translateX(0)}
  .overlay-menu{display:block;position:fixed;inset:0;background:rgba(47,31,61,.35);opacity:0;visibility:hidden;pointer-events:none;transition:opacity .24s ease, visibility .24s ease;z-index:50}
  body.menu-abierto .overlay-menu{opacity:1;visibility:visible;pointer-events:auto}
  .boton-menu-panel{display:inline-flex;width:max-content}
  .grilla-hero,.hero-admin,.hero-suscriptor,.grilla-soporte-admin,.item-registro-con-imagen,.hero-lectura-premium{grid-template-columns:1fr}
}
@media (max-width: 860px){
  .navegacion-sitio,.barra-pie,.barra-superior-admin{align-items:flex-start}
  .navegacion-sitio{padding:14px 0;flex-wrap:wrap}
  .boton-menu-movil{display:inline-flex;margin-left:auto}
  .links-navegacion{display:none;width:100%;padding-top:12px;flex-direction:column;align-items:stretch;gap:10px}
  body.menu-publico-abierto .links-navegacion{display:flex}
  .links-navegacion .boton,.links-navegacion .link-navegacion{width:100%;justify-content:flex-start}
  .grilla-servicios,.grilla-kpis,.resumen-pagos-admin{grid-template-columns:1fr 1fr}
  .grilla-campos-admin,.grilla-campos-admin-2,.filtros-inline-admin,.filtros-inline-admin-anchos{grid-template-columns:1fr}
  .contenedor,.contenido-admin{padding-left:18px;padding-right:18px}
}
@media (max-width: 560px){
  .grilla-servicios,.grilla-kpis,.resumen-pagos-admin,.columna-mini-estadisticas{grid-template-columns:1fr}
  .tarjeta-hero,.tarjeta-hero-publica,.tarjeta-admin,.tarjeta-servicio{padding:22px}
  .titulo-hero,.titulo-seccion,.titulo-hero-publico{font-size:1.85rem}
}


/* Public footer and static/contact pages */
.pie-sitio{margin-top:56px;border-top:1px solid var(--linea);background:var(--superficie)}
.pie-contenido{padding-top:34px;padding-bottom:28px}
.pie-grid{display:grid;grid-template-columns:minmax(260px,1.5fr) repeat(4,minmax(150px,1fr));gap:28px;padding-bottom:24px}
.pie-columna{display:grid;align-content:start;gap:12px}
.pie-columna h3{margin:0;font-size:.95rem;letter-spacing:.04em;text-transform:uppercase;color:var(--principal);font-family:"Montserrat",system-ui,sans-serif;font-weight:700}
.pie-columna a{color:var(--texto-suave);font-weight:500;font-family:"Glacial Indifference","Montserrat",sans-serif}
.pie-columna a:hover{color:var(--principal)}
.pie-columna-marca{gap:16px}
.pie-texto{margin:0;color:var(--texto-suave);max-width:34ch}
.pie-inferior{display:flex;justify-content:space-between;gap:16px;padding-top:18px;border-top:1px solid var(--linea);color:var(--texto-suave);font-size:.95rem}

.contacto-shell{max-width:920px}
.contacto-head-simple{margin-bottom:20px}
.tarjeta-contacto-publica,.tarjeta-estatica-publica,.tarjeta-servicio-publica{background:var(--superficie);border:1px solid var(--linea);border-radius:var(--radio);box-shadow:var(--sombra-sm)}
.tarjeta-contacto-publica{padding:28px}
.formulario-contacto-publico{display:grid;gap:18px}
.grilla-campos-contacto-publica{grid-template-columns:repeat(2,minmax(0,1fr))}
.textarea-contacto-publica{min-height:180px}
.contacto-acciones-publicas{padding-top:6px}
.contenido-estatico-publico{display:grid;gap:22px}
.tarjeta-estatica-publica{padding:28px}
.tarjeta-estatica-publica p{margin:0 0 14px;color:var(--texto-suave)}
.tarjeta-estatica-publica p:last-child{margin-bottom:0}
.grilla-metodologia-publica,.grilla-servicios-publica{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.tarjeta-servicio-publica{padding:26px;display:grid;gap:12px}
.tarjeta-servicio-publica h2,.tarjeta-estatica-publica h2{margin:0;font-size:1.25rem;letter-spacing:-.03em}
.tarjeta-servicio-publica p{margin:0;color:var(--texto-suave)}

@media (max-width: 980px){
  .pie-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width: 760px){
  .pie-grid,.grilla-metodologia-publica,.grilla-servicios-publica,.grilla-campos-contacto-publica{grid-template-columns:1fr}
  .pie-inferior{flex-direction:column;align-items:flex-start}
}


/* Commercial week */
.hero-comercial{padding-bottom:34px}
.grilla-hero-comercial{align-items:stretch}
.tarjeta-hero-comercial{display:grid;gap:20px}
.micro-hero-comercial{margin-top:4px}
.columna-hero-comercial{display:grid;gap:18px}
.panel-resultado{height:100%}
.kpi-precio strong{font-size:2rem;letter-spacing:-.04em}
.encabezado-centrado{text-align:center;justify-content:center}
.section-alt{background:linear-gradient(180deg,#fff 0%,#fbf7ff 100%)}
.section-alt-soft{padding:6px 0}
.proof-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.proof-card{padding:28px;display:grid;gap:12px}
.proof-card h3{margin:0;font-size:1.16rem;letter-spacing:-.03em}
.journey-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.journey-step{background:var(--superficie);border:1px solid var(--linea);border-radius:var(--radio);padding:26px;box-shadow:var(--sombra-sm);display:grid;gap:12px}
.journey-step h3{margin:0;font-size:1.14rem}
.journey-step p{margin:0;color:var(--texto-suave)}
.journey-step-number{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:999px;background:rgba(102,45,145,.1);color:var(--principal);font-weight:800}
.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}
.pricing-grid-home{align-items:stretch}
.pricing-card{position:relative;background:var(--superficie);border:1px solid var(--linea);border-radius:var(--radio);box-shadow:var(--sombra-sm);padding:28px;display:grid;gap:18px}
.pricing-card-featured{border-color:rgba(200,0,138,.25);box-shadow:0 18px 44px rgba(102,45,145,.12)}
.pricing-card-full{grid-column:1/-1}
.pricing-badge{position:absolute;top:18px;right:18px;display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;background:var(--destacado-suave);color:var(--destacado);font-weight:800;font-size:.82rem}
.pricing-head{display:grid;gap:8px}
.pricing-head h3{margin:0;font-size:1.36rem;letter-spacing:-.04em}
.pricing-head p{margin:0;color:var(--texto-suave)}
.pricing-price-wrap{display:grid;gap:6px}
.pricing-price{font-size:2.35rem;line-height:1;letter-spacing:-.06em;color:#101828}
.pricing-period{color:var(--texto-suave);font-weight:700}
.pricing-list{display:grid;gap:10px;margin:0;padding-left:18px;color:var(--texto-suave)}
.pricing-list li{line-height:1.6}
.faq-preview{max-width:980px}
.faq-preview-card{padding:28px;display:grid;gap:18px}
.faq-list{display:grid;gap:14px}
.faq-list-wide{grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.faq-item{display:grid;gap:8px}
.faq-item h3{margin:0;font-size:1.04rem}
.faq-item p{margin:0;color:var(--texto-suave);line-height:1.7}
.cta-band{display:flex;justify-content:space-between;gap:22px;align-items:center;padding:30px;border-radius:28px;background:linear-gradient(135deg,var(--principal) 0%,#7d3cb3 100%);color:#fff;box-shadow:var(--sombra-md)}
.cta-band h2{margin:8px 0 0;font-size:2rem;letter-spacing:-.05em;color:#fff}
.cta-band p{margin:10px 0 0;color:rgba(255,255,255,.86);max-width:60ch}
.tarjeta-hero-publica-larga{padding:34px}
.tarjeta-servicio-destacada{border-color:rgba(200,0,138,.22)}
.contacto-shell-wide{max-width:1100px}
.contacto-layout{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(280px,.85fr);gap:20px;align-items:start}
.contacto-beneficios{display:grid;gap:18px}

.acciones-stack-mobile{align-items:flex-start}
@media (max-width: 980px){
  .proof-grid,.journey-grid,.faq-list-wide,.contacto-layout{grid-template-columns:1fr}
  .cta-band{flex-direction:column;align-items:flex-start}
}
@media (max-width: 760px){
  .pricing-price{font-size:2rem}
  .cta-band h2{font-size:1.7rem}
}


/* Visual premium upgrade */
body{
  background:
    radial-gradient(circle at top left, rgba(200,0,138,.05), transparent 28%),
    radial-gradient(circle at top right, rgba(255,222,89,.14), transparent 24%),
    linear-gradient(180deg,#fffafc 0%,#fff 34%,#fbf7ff 100%);
}
.encabezado-sitio{box-shadow:0 12px 30px rgba(102,45,145,.05)}
.link-navegacion{position:relative;transition:color .18s ease}
.link-navegacion::after{content:"";position:absolute;left:0;right:0;bottom:-8px;height:2px;border-radius:999px;background:var(--destacado);transform:scaleX(0);transform-origin:center;transition:transform .18s ease}
.link-navegacion:hover::after{transform:scaleX(1)}
.boton{font-family:"Montserrat",system-ui,sans-serif;letter-spacing:-.01em}
.boton-principal,.boton-destacado{box-shadow:0 16px 34px rgba(102,45,145,.16)}
.boton-principal:hover,.boton-destacado:hover{box-shadow:0 20px 38px rgba(102,45,145,.2)}
.tarjeta-servicio,.pricing-card,.proof-card,.journey-step,.tarjeta-servicio-publica,.tarjeta-estatica-publica,.tarjeta-contacto-publica{transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease}
.tarjeta-servicio:hover,.pricing-card:hover,.proof-card:hover,.journey-step:hover,.tarjeta-servicio-publica:hover,.tarjeta-estatica-publica:hover,.tarjeta-contacto-publica:hover{transform:translateY(-4px);box-shadow:0 22px 44px rgba(102,45,145,.12);border-color:rgba(102,45,145,.20)}
.hero-comercial{position:relative;overflow:hidden}
.hero-comercial::before{
  content:"";
  position:absolute;inset:0;
  background:
    radial-gradient(circle at 10% 20%, rgba(255,222,89,.22), transparent 22%),
    radial-gradient(circle at 92% 15%, rgba(200,0,138,.12), transparent 18%),
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,0));
  pointer-events:none;
}
.grilla-hero-comercial{position:relative;z-index:1}
.tarjeta-hero-comercial{
  position:relative;
  overflow:hidden;
  background:
    linear-gradient(180deg, rgba(255,255,255,.94), rgba(255,255,255,.98)),
    var(--superficie);
  box-shadow:0 24px 56px rgba(102,45,145,.10);
}
.tarjeta-hero-comercial::after{
  content:"";
  position:absolute;right:-80px;top:-90px;
  width:220px;height:220px;border-radius:50%;
  background:radial-gradient(circle, rgba(200,0,138,.12), rgba(200,0,138,0));
}
.panel-resumen-premium{
  background:linear-gradient(180deg, rgba(102,45,145,.96), #54257a 100%);
  color:#fff;border:none;box-shadow:0 24px 56px rgba(102,45,145,.18)
}
.panel-resumen-premium small,.panel-resumen-premium p,.panel-resumen-premium li{color:rgba(255,255,255,.86)}
.panel-resumen-premium h3{margin:8px 0 0;font-size:1.45rem;letter-spacing:-.04em}
.lista-destacada-premium{display:grid;gap:12px}
.lista-destacada-premium .item-premium{
  padding:14px 16px;border-radius:18px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12)
}
.quick-facts-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.quick-fact-card{
  padding:22px;border-radius:22px;background:#fff;border:1px solid var(--linea);
  box-shadow:var(--sombra-sm);display:grid;gap:10px
}
.quick-fact-card strong{font-size:1.1rem;letter-spacing:-.03em}
.quick-fact-card span{color:var(--texto-suave);line-height:1.6}
.compare-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.compare-card{
  position:relative;padding:26px;border-radius:24px;background:#fff;border:1px solid var(--linea);box-shadow:var(--sombra-sm);display:grid;gap:14px
}
.compare-card h3{margin:0;font-size:1.22rem;letter-spacing:-.03em}
.compare-card p{margin:0;color:var(--texto-suave);line-height:1.7}
.compare-card ul{margin:0;padding-left:18px;color:var(--texto-suave);display:grid;gap:8px}
.compare-card-featured{
  background:linear-gradient(180deg,#fff 0%,#fff7fc 100%);
  border-color:rgba(200,0,138,.28);
  box-shadow:0 22px 54px rgba(102,45,145,.12)
}
.compare-chip,.summary-chip{
  display:inline-flex;align-items:center;justify-content:center;
  width:max-content;padding:7px 12px;border-radius:999px;
  background:rgba(102,45,145,.1);color:var(--principal);font-size:.82rem;font-weight:800
}
.summary-chip-light{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.16)}
.plan-highlight-strip{
  display:flex;justify-content:space-between;gap:20px;align-items:center;
  padding:22px 24px;border-radius:24px;background:linear-gradient(135deg,#fff 0%,#fff5fb 100%);
  border:1px solid rgba(200,0,138,.18);box-shadow:var(--sombra-sm)
}
.plan-highlight-strip p{margin:6px 0 0;color:var(--texto-suave)}
.plan-highlight-strip strong{font-size:1.25rem;letter-spacing:-.03em}
.hero-dual-grid{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(290px,.95fr);gap:20px;align-items:stretch}
.summary-card{
  padding:28px;border-radius:28px;background:linear-gradient(160deg,var(--principal) 0%, #7b37af 100%);color:#fff;box-shadow:0 24px 56px rgba(102,45,145,.18);display:grid;gap:18px
}
.summary-card h2,.summary-card h3,.summary-card strong{color:#fff}
.summary-card p,.summary-card li{color:rgba(255,255,255,.86)}
.summary-list{display:grid;gap:12px;margin:0;padding:0;list-style:none}
.summary-list li{padding:14px 16px;border-radius:18px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12)}
.pricing-card{padding:30px}
.pricing-card-featured{transform:translateY(-4px);background:linear-gradient(180deg,#fff 0%,#fff7fc 100%)}
.pricing-card-featured .pricing-price{color:var(--destacado)}
.pricing-head p{line-height:1.65}
.pricing-list{padding-left:20px}
.pricing-list li::marker{color:var(--destacado)}
.faq-preview-card,.cta-band,.summary-card,.panel-resumen-premium{border-radius:30px}
.contacto-layout .tarjeta-contacto-publica{padding:30px}
.section-title-tight{max-width:720px}
@media (max-width: 980px){
  .quick-facts-grid,.compare-grid,.hero-dual-grid{grid-template-columns:1fr}
  .plan-highlight-strip{flex-direction:column;align-items:flex-start}
}
@media (max-width: 760px){
  .plan-highlight-strip,.summary-card,.panel-resumen-premium{padding:20px}
}


/* Refuerzo visual comercial home */
.compare-grid,
.journey-grid,
.pricing-grid-home{
  position:relative;
  padding:24px;
  border-radius:32px;
  border:1px solid rgba(102,45,145,.12);
  background:linear-gradient(180deg,#ffffff 0%,#fff8fd 100%);
  box-shadow:0 24px 60px rgba(102,45,145,.10);
}
.compare-grid::before,
.journey-grid::before,
.pricing-grid-home::before{
  content:"";
  position:absolute;
  right:-70px;
  top:-70px;
  width:180px;
  height:180px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(200,0,138,.12), rgba(200,0,138,0) 72%);
  pointer-events:none;
}
.compare-grid::after,
.journey-grid::after,
.pricing-grid-home::after{
  content:"";
  position:absolute;
  left:-60px;
  bottom:-90px;
  width:170px;
  height:170px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(255,222,89,.18), rgba(255,222,89,0) 72%);
  pointer-events:none;
}
.compare-grid > *,
.journey-grid > *,
.pricing-grid-home > *{position:relative;z-index:1}
.compare-grid{gap:22px}
.compare-card{
  position:relative;
  padding:30px;
  border-radius:28px;
  background:linear-gradient(180deg,#fff 0%,#fffbfe 100%);
  border:1px solid rgba(102,45,145,.12);
  box-shadow:0 18px 44px rgba(102,45,145,.10);
  overflow:hidden;
}
.compare-card::before{
  content:"";
  position:absolute;
  inset:0 auto auto 0;
  width:100%;
  height:6px;
  background:linear-gradient(90deg,var(--principal) 0%, var(--destacado) 100%);
}
.compare-card::after{
  content:"";
  position:absolute;
  right:-36px;
  bottom:-36px;
  width:110px;
  height:110px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(102,45,145,.08), rgba(102,45,145,0) 70%);
}
.compare-card-test::before{background:linear-gradient(90deg,var(--principal) 0%, #8d59b7 100%)}
.compare-card-consulta::before{background:linear-gradient(90deg,var(--acento) 0%, #ffc400 100%)}
.compare-card-membresia::before{background:linear-gradient(90deg,var(--destacado) 0%, var(--principal) 100%)}
.compare-card-featured{
  transform:translateY(-6px);
  background:linear-gradient(180deg,#fff 0%,#fff2fa 100%);
  border-color:rgba(200,0,138,.28);
  box-shadow:0 26px 56px rgba(102,45,145,.16);
}
.compare-card h3{font-size:1.24rem}
.compare-chip{box-shadow:inset 0 0 0 1px rgba(102,45,145,.08)}
.journey-grid{
  background:linear-gradient(180deg,#fff 0%,#fcf7ff 100%);
  gap:22px;
}
.journey-step{
  position:relative;
  padding:30px;
  border-radius:28px;
  background:linear-gradient(180deg,#fff 0%,#fffbff 100%);
  border:1px solid rgba(102,45,145,.12);
  box-shadow:0 18px 42px rgba(102,45,145,.10);
  overflow:hidden;
}
.journey-step::before{
  content:"";
  position:absolute;
  inset:auto 0 0 0;
  height:5px;
  background:linear-gradient(90deg,var(--principal) 0%, var(--destacado) 100%);
}
.journey-step-2::before{background:linear-gradient(90deg,var(--acento) 0%, #ffc400 100%)}
.journey-step-3::before{background:linear-gradient(90deg,var(--destacado) 0%, var(--principal) 100%)}
.journey-step-number{
  width:52px;
  height:52px;
  border-radius:18px;
  background:rgba(102,45,145,.10);
  box-shadow:inset 0 0 0 1px rgba(102,45,145,.08);
}
.pricing-grid-home{
  background:linear-gradient(180deg,#fff 0%,#fff4fb 100%);
  border-color:rgba(200,0,138,.18);
  gap:22px;
}
.pricing-grid-home .pricing-card{
  border-radius:30px;
  border:1px solid rgba(102,45,145,.12);
  background:linear-gradient(180deg,#fff 0%,#fffbfd 100%);
  box-shadow:0 20px 52px rgba(102,45,145,.10);
}
.pricing-grid-home .pricing-card-featured{
  transform:translateY(-8px);
  background:linear-gradient(180deg,#fff 0%,#fff1fa 100%);
  border-color:rgba(200,0,138,.28);
  box-shadow:0 28px 60px rgba(102,45,145,.16);
}
.plan-highlight-strip{
  padding:24px 26px;
  border-radius:28px;
  background:linear-gradient(135deg,#fff 0%,#fff0f9 100%);
  border:1px solid rgba(200,0,138,.20);
  box-shadow:0 20px 48px rgba(102,45,145,.10);
}
@media (max-width: 980px){
  .compare-grid,
  .journey-grid,
  .pricing-grid-home{padding:20px}
}
@media (max-width: 760px){
  .compare-grid,
  .journey-grid,
  .pricing-grid-home{padding:16px;border-radius:24px}
  .compare-card,
  .journey-step,
  .pricing-grid-home .pricing-card{padding:22px;border-radius:22px}
}


/* TinyMCE local */
.tox.tox-tinymce{
  border:1px solid var(--linea);
  border-radius:18px;
  box-shadow:var(--sombra-sm);
}
.tox .tox-editor-header{
  border-bottom:1px solid var(--linea) !important;
  box-shadow:none !important;
}
.tox .tox-toolbar-overlord,
.tox .tox-toolbar,
.tox .tox-toolbar__primary,
.tox:not(.tox-tinymce-inline) .tox-editor-header{
  background:#fff !important;
}
.tox .tox-tbtn:hover,
.tox .tox-tbtn--enabled,
.tox .tox-tbtn--enabled:hover{
  background:rgba(102,45,145,.10) !important;
}
.tox .tox-tbtn svg,
.tox .tox-statusbar a,
.tox .tox-statusbar__wordcount,
.tox .tox-statusbar__path-item,
.tox .tox-statusbar__branding{
  color:var(--principal) !important;
  fill:var(--principal) !important;
}
.tox .tox-edit-area::before{
  border-radius:0 0 18px 18px !important;
}
.tox .tox-statusbar{
  border-top:1px solid var(--linea) !important;
}


/* Auth pages */
.pagina-auth{min-height:100vh;background:linear-gradient(135deg,#fffafc 0%,#fff7fc 48%,#fff8d6 100%)}
.auth-shell{max-width:640px;margin:0 auto;padding:56px 24px 72px}
.tarjeta-formulario{max-width:560px;margin:0 auto;padding:34px;background:rgba(255,255,255,.92);border:1px solid var(--linea);border-radius:28px;box-shadow:var(--sombra-md);backdrop-filter:blur(8px);display:grid;gap:18px}
.tarjeta-formulario h1{margin:0;font-size:clamp(2rem,3.2vw,2.7rem);line-height:1.08;letter-spacing:-.05em}
.tarjeta-formulario p{margin:0;color:var(--texto-suave)}
.seccion-formulario{display:grid;gap:16px}
.campo{display:grid;gap:8px}
.campo label{font-weight:700;font-family:"Montserrat",system-ui,sans-serif;font-size:.94rem}
.entrada{width:100%;padding:14px 16px;border:1px solid var(--linea);border-radius:16px;background:#fff;color:var(--texto);outline:none;transition:border-color .18s ease, box-shadow .18s ease, transform .18s ease;box-shadow:0 1px 0 rgba(102,45,145,.02)}
.entrada:hover{border-color:rgba(102,45,145,.28)}
.entrada:focus{border-color:rgba(102,45,145,.42);box-shadow:0 0 0 4px rgba(102,45,145,.10)}
.acciones-auth{display:flex;align-items:center;gap:12px;flex-wrap:wrap;padding-top:4px}
.acciones-auth .boton{min-width:132px}
.auth-links-grid{display:grid;gap:12px;margin-top:2px}
.tarjeta-formulario-comercial{max-width:620px}

@media (max-width: 640px){
  .auth-shell{padding:28px 16px 40px}
  .tarjeta-formulario{padding:24px;border-radius:24px}
  .acciones-auth{display:grid;grid-template-columns:1fr}
  .acciones-auth .boton,.auth-links-grid .boton{width:100%}
}

/* --- Study assistant chat-first module --- */
.asistente-shell{display:grid;grid-template-columns:280px minmax(0,1fr) 320px;gap:24px;align-items:start}
.asistente-sidebar,.asistente-main,.asistente-contexto{min-height:720px}
.asistente-sidebar-body{display:flex;flex-direction:column;gap:10px;max-height:780px;overflow:auto}
.asistente-conversacion-item{display:block;padding:14px 16px;border:1px solid rgba(102,45,145,.12);border-radius:18px;background:#fff;text-decoration:none;color:inherit;box-shadow:0 12px 30px rgba(17,24,39,.05);transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease}
.asistente-conversacion-item strong{display:block;font-family:Montserrat,sans-serif;font-size:.98rem;margin-bottom:4px}
.asistente-conversacion-item span,.asistente-conversacion-item small{display:block;color:#64748b}
.asistente-conversacion-item:hover{transform:translateY(-2px);box-shadow:0 18px 34px rgba(17,24,39,.08);border-color:rgba(102,45,145,.22)}
.asistente-conversacion-item.activo{background:linear-gradient(180deg,rgba(102,45,145,.08),rgba(200,0,138,.05));border-color:rgba(102,45,145,.3)}
.asistente-main{display:flex;flex-direction:column;overflow:hidden}
.asistente-main-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}
.asistente-head-actions{display:flex;gap:10px;align-items:center}
.chip-contexto{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:rgba(102,45,145,.12);color:#4b1f6f;font-size:.82rem;font-weight:700;margin-right:6px}
.chip-contexto-suave{background:rgba(255,222,89,.28);color:#7a5c00}
.asistente-mensajes{flex:1;overflow:auto;padding:22px;background:linear-gradient(180deg,#fcfbff 0%,#f7f4fb 100%);border:1px solid rgba(102,45,145,.12);border-radius:24px;display:flex;flex-direction:column;gap:16px;min-height:420px;max-height:680px}
.mensaje-chat{display:flex}
.mensaje-chat.mensaje-usuario{justify-content:flex-end}
.mensaje-burbuja{max-width:min(760px,82%);padding:16px 18px;border-radius:22px;background:#fff;border:1px solid rgba(102,45,145,.12);box-shadow:0 14px 34px rgba(17,24,39,.06)}
.mensaje-usuario .mensaje-burbuja{background:linear-gradient(180deg,#662d91,#7b33b0);color:#fff;border-color:transparent}
.mensaje-usuario .mensaje-burbuja p,.mensaje-usuario .mensaje-burbuja li{color:#fff}
.mensaje-asistente .mensaje-burbuja{border-top-left-radius:8px}
.mensaje-usuario .mensaje-burbuja{border-top-right-radius:8px}
.mensaje-bienvenida .mensaje-burbuja{max-width:100%;background:linear-gradient(180deg,rgba(102,45,145,.06),rgba(200,0,138,.03));border-color:rgba(102,45,145,.18)}
.mensaje-pendiente .mensaje-burbuja{opacity:.78}
.mensaje-burbuja p:last-child,.mensaje-burbuja ul:last-child{margin-bottom:0}
.asistente-composer-wrap{margin-top:18px}
.asistente-composer{display:flex;align-items:flex-end;gap:14px;padding:16px;border-radius:24px;background:#fff;border:1px solid rgba(102,45,145,.12);box-shadow:0 20px 42px rgba(17,24,39,.06)}
.asistente-textarea{min-height:58px;max-height:220px;resize:none;border-radius:18px!important;padding:16px 18px!important;font-size:1rem;line-height:1.5}
.asistente-composer-actions{display:flex;flex-direction:column;gap:10px;flex-shrink:0}
.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}
.asistente-archivo-preview{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.asistente-contexto .cuerpo-tarjeta-admin{display:flex;flex-direction:column;gap:20px}
.asistente-materiales-box{padding:18px;border-radius:20px;background:linear-gradient(180deg,rgba(102,45,145,.05),rgba(255,255,255,.88));border:1px solid rgba(102,45,145,.12)}
.encabezado-inline{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.encabezado-inline h4{margin:0;font-family:Montserrat,sans-serif}
.asistente-materiales-lista{display:flex;flex-direction:column;gap:12px}
.asistente-material-item{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;border-radius:16px;background:#fff;border:1px solid rgba(102,45,145,.12)}
.asistente-material-item strong{display:block}
.asistente-material-item span{display:block;color:#64748b;font-size:.88rem}
.asistente-material-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.boton-link-peligro{background:none;border:none;padding:0;color:#b42318;font:inherit;font-weight:700;cursor:pointer}
.estudio-chat-hero .panel-plan-dashboard{min-width:280px}
@media (max-width: 1180px){.asistente-shell{grid-template-columns:1fr}.asistente-sidebar,.asistente-contexto{min-height:auto}.asistente-mensajes{max-height:none}.asistente-main{order:1}.asistente-sidebar{order:2}.asistente-contexto{order:3}}
@media (max-width: 720px){.asistente-main-head,.asistente-composer{flex-direction:column;align-items:stretch}.asistente-composer-actions{flex-direction:row;justify-content:space-between}.mensaje-burbuja{max-width:100%}}

.bloque-codigo-admin{
    margin-top:12px;
    padding:14px 16px;
    border-radius:16px;
    background:#0f172a;
    color:#e2e8f0;
    overflow:auto;
    white-space:pre-wrap;
    word-break:break-word;
    font-size:.92rem;
    line-height:1.5;
    border:1px solid rgba(148,163,184,.24);
}
