.elementor-4306 .elementor-element.elementor-element-0f82ee6{--display:flex;--min-height:410px;--flex-direction:column;--container-widget-width:calc( ( 1 - var( --container-widget-flex-grow ) ) * 100% );--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--justify-content:center;--align-items:center;--overlay-opacity:0.75;}.elementor-4306 .elementor-element.elementor-element-0f82ee6::before, .elementor-4306 .elementor-element.elementor-element-0f82ee6 > .elementor-background-video-container::before, .elementor-4306 .elementor-element.elementor-element-0f82ee6 > .e-con-inner > .elementor-background-video-container::before, .elementor-4306 .elementor-element.elementor-element-0f82ee6 > .elementor-background-slideshow::before, .elementor-4306 .elementor-element.elementor-element-0f82ee6 > .e-con-inner > .elementor-background-slideshow::before, .elementor-4306 .elementor-element.elementor-element-0f82ee6 > .elementor-motion-effects-container > .elementor-motion-effects-layer::before{background-color:var( --e-global-color-secondary );--background-overlay:'';}.elementor-4306 .elementor-element.elementor-element-0f82ee6:not(.elementor-motion-effects-element-type-background), .elementor-4306 .elementor-element.elementor-element-0f82ee6 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-position:center center;background-size:cover;}.elementor-4306 .elementor-element.elementor-element-60a0c46 img{width:64%;}.elementor-4306 .elementor-element.elementor-element-d3b6327{text-align:center;}.elementor-4306 .elementor-element.elementor-element-d3b6327 .elementor-heading-title{font-family:"Montserrat", Sans-serif;font-size:2.6rem;font-weight:700;line-height:1.2em;color:var( --e-global-color-accent );}.elementor-4306 .elementor-element.elementor-element-48ffb14{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:30px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}body.elementor-page-4306:not(.elementor-motion-effects-element-type-background), body.elementor-page-4306 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#0C001E;}@media(max-width:1024px){.elementor-4306 .elementor-element.elementor-element-d3b6327 .elementor-heading-title{font-size:3.2vw;}}@media(min-width:768px){.elementor-4306 .elementor-element.elementor-element-0f82ee6{--content-width:1123px;}}@media(max-width:767px){.elementor-4306 .elementor-element.elementor-element-0f82ee6{--min-height:280px;--padding-top:10px;--padding-bottom:10px;--padding-left:10px;--padding-right:10px;}.elementor-4306 .elementor-element.elementor-element-60a0c46 img{width:48%;}.elementor-4306 .elementor-element.elementor-element-d3b6327 .elementor-heading-title{font-size:1.7rem;}.elementor-4306 .elementor-element.elementor-element-48ffb14{--padding-top:20px;--padding-bottom:10px;--padding-left:10px;--padding-right:10px;}}/* Start custom CSS *//* ============================================================================
   HUB365.AI / MASTER STYLESHEET
   ============================================================================
   Sistema de diseño completo para guías Hub365.AI.
   Subir 1 vez al servidor. Cada guía solo necesita un <link> a este archivo.

   IMPORTANTE: Para cambiar la identidad visual del sistema completo,
   solo edita las variables en :root.hub365-guide. Todos los componentes
   las heredan automáticamente.

   Versión: 1.0
   Última actualización: 2026
============================================================================ */


/* ============================================================================
   1. VARIABLES / SISTEMA DE TOKENS
   ============================================================================
   Todo el sistema usa variables. Cambia aquí, se actualiza en todos lados.
============================================================================ */

.hub365-guide {

  /* --- COLORES DE FONDO --- */
  --c-bg-main:        #0c001e;   /* Fondo principal de la guía */
  --c-bg-card:        #140029;   /* Fondo de cards normales */
  --c-bg-card-deep:   #0a0018;   /* Fondo de cards destacadas */
  --c-bg-subtle:      rgba(255,255,255,.04);  /* Fondos translúcidos sutiles */

  /* --- COLORES DE MARCA --- */
  --c-fuchsia:        #ff00f6;   /* Fucsia principal */
  --c-fuchsia-soft:   #bf5af2;   /* Fucsia apagado */
  --c-fuchsia-light:  #d68fff;   /* Fucsia claro (eyebrows, labels) */

  --c-lime:           #ccff00;   /* Lima protagonista */
  --c-lime-glow:      rgba(204,255,0,.15);  /* Glow lima */

  --c-turquoise:      #40e0d0;   /* Turquesa acento */

  --c-purple:         #a825ff;   /* Morado del gradiente */
  --c-coral:          #ec935c;   /* Coral del gradiente */

  --c-whatsapp:       #25D366;   /* Verde WhatsApp (oficial) */

  /* --- TEXTOS --- */
  --c-white:          #fdfdfd;
  --c-text:           rgba(253,253,253,.92);  /* Texto principal */
  --c-text-soft:      rgba(253,253,253,.78);  /* Texto secundario */
  --c-text-mute:      rgba(253,253,253,.70);  /* Texto apagado */

  /* --- BORDES --- */
  --c-border:         rgba(191,90,242,.22);   /* Borde fucsia translúcido */
  --c-border-lime:    rgba(204,255,0,.40);    /* Borde lima */
  --c-border-turq:    rgba(64,224,208,.40);   /* Borde turquesa */
  --c-border-soft:    rgba(255,255,255,.08);  /* Borde divisor sutil */

  /* --- GLOWS / SOMBRAS DE COLOR --- */
  --glow-fuchsia:     rgba(255,0,246,.5);
  --glow-fuchsia-soft: rgba(255,0,246,.25);
  --glow-lime:        rgba(204,255,0,.5);
  --glow-lime-soft:   rgba(204,255,0,.25);
  --glow-turq:        rgba(64,224,208,.5);
  --glow-turq-soft:   rgba(64,224,208,.25);
  --glow-purple:      rgba(168,37,255,.5);
  --glow-purple-soft: rgba(168,37,255,.25);
  --glow-coral:       rgba(236,147,92,.5);
  --glow-coral-soft:  rgba(236,147,92,.25);

  /* --- GRADIENTES --- */
  --gradient-main:     linear-gradient(120deg, var(--c-purple), var(--c-fuchsia), var(--c-coral));
  --gradient-lime:     linear-gradient(120deg, var(--c-lime), var(--c-turquoise), var(--c-lime));
  --gradient-turq:     linear-gradient(120deg, var(--c-turquoise), var(--c-purple), var(--c-turquoise));
  --gradient-purple:   linear-gradient(120deg, var(--c-purple), var(--c-fuchsia), var(--c-purple));
  --gradient-coral:    linear-gradient(120deg, var(--c-coral), var(--c-fuchsia), var(--c-coral));
  --gradient-shimmer:  linear-gradient(90deg, var(--c-purple), var(--c-fuchsia), var(--c-lime), var(--c-fuchsia), var(--c-purple));

  /* --- TIPOGRAFÍAS --- */
  --font-body:        'Montserrat', -apple-system, BlinkMacSystemFont, Arial, sans-serif;
  --font-heading:     'Montserrat', -apple-system, BlinkMacSystemFont, Arial, sans-serif;
  --font-mono:        'Courier New', ui-monospace, monospace;

  /* --- TAMAÑOS DE FUENTE --- */
  --fs-display:       clamp(2.1rem, 4.5vw, 3rem);
  --fs-h2:            clamp(1.65rem, 3.4vw, 2.2rem);
  --fs-h3:            1.5rem;
  --fs-h4:            1.25rem;
  --fs-body:          1.2rem;
  --fs-small:         1.05rem;
  --fs-tiny:          0.85rem;
  --fs-micro:         0.72rem;

  /* --- PESOS --- */
  --fw-regular:       400;
  --fw-medium:        500;
  --fw-semibold:      600;
  --fw-bold:          700;
  --fw-black:         900;

  /* --- ESPACIADOS --- */
  --space-xs:         0.5rem;
  --space-sm:         0.85rem;
  --space-md:         1.25rem;
  --space-lg:         2rem;
  --space-xl:         3rem;
  --space-xxl:        4.5rem;

  /* --- BORDES (RADIOS) --- */
  --radius-sm:        6px;
  --radius-md:        10px;
  --radius-lg:        16px;
  --radius-xl:        20px;

  /* --- TRANSICIONES --- */
  --transition:       all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}


/* ============================================================================
   2. BASE / RESET DEL CONTENEDOR
============================================================================ */

.hub365-guide {
  font-family: var(--font-body);
  color: var(--c-text);
  background: var(--c-bg-main);
  padding: var(--space-xl) var(--space-md);
  border-radius: var(--radius-xl);
  line-height: 1.7;
  max-width: 920px;
  margin: 0 auto;
  overflow: hidden;
  position: relative;
}

.hub365-guide * { box-sizing: border-box; }

.hub365-guide p {
  font-size: var(--fs-body);
  color: var(--c-text);
  margin: 0 0 var(--space-md);
}

.hub365-guide strong {
  color: var(--c-white);
  font-weight: var(--fw-bold);
}

.hub365-guide em {
  font-style: italic;
  color: var(--c-text-soft);
}

.hub365-guide a {
  color: var(--c-lime);
  text-decoration: none;
  border-bottom: 1px dashed rgba(204,255,0,.4);
  transition: var(--transition);
}

.hub365-guide a:hover {
  border-bottom-color: var(--c-lime);
  text-shadow: 0 0 12px rgba(204,255,0,.4);
}


/* ============================================================================
   3. HEADINGS
============================================================================ */

.hub365-guide h2 {
  font-family: var(--font-heading);
  font-size: var(--fs-display);
  font-weight: var(--fw-black);
  line-height: 1.15;
  color: var(--c-white);
  margin: var(--space-xl) 0 var(--space-md);
  letter-spacing: -0.02em;
}

.hub365-guide h2:first-child { margin-top: 0; }

.hub365-guide h3 {
  font-family: var(--font-heading);
  font-size: var(--fs-h2);
  font-weight: var(--fw-black);
  line-height: 1.2;
  color: var(--c-white);
  margin: var(--space-xl) 0 var(--space-md);
  letter-spacing: -0.01em;
}

.hub365-guide h4 {
  font-family: var(--font-heading);
  font-size: var(--fs-h3);
  font-weight: var(--fw-bold);
  color: var(--c-white);
  margin: var(--space-lg) 0 var(--space-sm);
}

.hub365-guide h5 {
  font-family: var(--font-heading);
  font-size: var(--fs-h4);
  font-weight: var(--fw-bold);
  color: var(--c-white);
  margin: var(--space-md) 0 var(--space-sm);
}


/* ============================================================================
   4. UTILITY TEXT / Texto destacado por color
============================================================================ */

.hub365-guide .grad-text {
  background: var(--gradient-main);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  font-weight: var(--fw-black);
}

.hub365-guide .lime-text { color: var(--c-lime); font-weight: var(--fw-bold); }
.hub365-guide .fuchsia-text { color: var(--c-fuchsia); font-weight: var(--fw-bold); }
.hub365-guide .turq-text { color: var(--c-turquoise); font-weight: var(--fw-bold); }


/* ============================================================================
   5. EYEBROW / Etiqueta superior con punto pulsante
============================================================================ */

.hub365-guide .eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px 6px 12px;
  font-size: var(--fs-tiny);
  font-weight: var(--fw-bold);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--c-fuchsia-light);
  background: rgba(191,90,242,.08);
  border: 1px solid rgba(191,90,242,.28);
  border-radius: 999px;
  margin-bottom: var(--space-md);
  transition: var(--transition);
}

.hub365-guide .eyebrow::before {
  content: "";
  display: inline-block;
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--c-fuchsia-light);
  box-shadow: 0 0 6px var(--c-fuchsia-light), 0 0 12px rgba(214,143,255,.6);
  animation: dotPulse 2.2s ease-in-out infinite;
  flex-shrink: 0;
}

.hub365-guide .eyebrow.lime {
  color: var(--c-lime);
  background: rgba(204,255,0,.06);
  border-color: rgba(204,255,0,.32);
}

.hub365-guide .eyebrow.lime::before {
  background: var(--c-lime);
  box-shadow: 0 0 6px var(--c-lime), 0 0 14px rgba(204,255,0,.55);
}

.hub365-guide .eyebrow.turquoise {
  color: var(--c-turquoise);
  background: rgba(64,224,208,.06);
  border-color: rgba(64,224,208,.32);
}

.hub365-guide .eyebrow.turquoise::before {
  background: var(--c-turquoise);
  box-shadow: 0 0 6px var(--c-turquoise), 0 0 14px rgba(64,224,208,.55);
}


/* ============================================================================
   6. SHIMMER DIVIDER / Barra separadora con animación
============================================================================ */

.hub365-guide .shimmer-divider {
  display: block;
  width: 100%;
  max-width: 920px;
  height: 3px;
  margin: 0 auto var(--space-xl);
  border-radius: 999px;
  background: linear-gradient(90deg,
    transparent 0%, var(--c-purple) 15%, var(--c-fuchsia) 35%, var(--c-lime) 50%,
    var(--c-turquoise) 65%, var(--c-fuchsia) 85%, transparent 100%);
  background-size: 300% 100%;
  animation: shimmerSlide 5s linear infinite;
  position: relative;
  box-shadow: 0 0 12px rgba(255,0,246,.35), 0 0 24px rgba(204,255,0,.15);
}

.hub365-guide .shimmer-divider::after {
  content: "";
  position: absolute;
  top: 50%; left: 10%; right: 10%;
  height: 8px;
  transform: translateY(-50%);
  background: linear-gradient(90deg,
    transparent 0%, rgba(168,37,255,.4) 30%, rgba(255,0,246,.5) 50%,
    rgba(204,255,0,.4) 70%, transparent 100%);
  background-size: 300% 100%;
  animation: shimmerSlide 5s linear infinite;
  filter: blur(10px);
  z-index: -1;
  pointer-events: none;
}

.hub365-guide .shimmer-divider.thin { height: 2px; margin: var(--space-lg) auto; opacity: .85; }
.hub365-guide .shimmer-divider.short { max-width: 240px; margin: var(--space-lg) auto; }


/* ============================================================================
   7. HERO INTRO
============================================================================ */

.hub365-guide .hero-intro {
  padding: var(--space-lg) var(--space-md) var(--space-xl);
  text-align: left;
  position: relative;
}


/* ============================================================================
   8. CARDS / Tarjetas básicas
============================================================================ */

.hub365-guide .card {
  background: var(--c-bg-card);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  margin-bottom: var(--space-md);
  transition: var(--transition);
}

.hub365-guide .card-highlight {
  background: var(--c-bg-card-deep);
  border: 1px solid var(--c-border-lime);
  position: relative;
  overflow: hidden;
  animation: glowPulse 4s ease-in-out infinite;
}

.hub365-guide .card-highlight::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 3px; height: 100%;
  background: var(--c-lime);
  box-shadow: 0 0 14px var(--glow-lime);
}

.hub365-guide .card-fuchsia {
  background: rgba(55,0,80,.18);
  border: 1px solid rgba(191,90,242,.35);
}


/* ============================================================================
   9. CALLOUTS / Citas y atribuciones
============================================================================ */

.hub365-guide .callout {
  padding: var(--space-md) var(--space-md) var(--space-md) calc(var(--space-md) + 6px);
  background: var(--c-bg-subtle);
  border-left: 3px solid var(--c-fuchsia);
  border-radius: var(--radius-sm);
  margin: var(--space-md) 0;
  font-style: italic;
  color: var(--c-text-soft);
}

.hub365-guide .callout.lime { border-left-color: var(--c-lime); background: rgba(204,255,0,.05); }
.hub365-guide .callout.turquoise { border-left-color: var(--c-turquoise); background: rgba(64,224,208,.05); }

.hub365-guide .callout .attribution {
  display: block;
  font-style: normal;
  font-size: var(--fs-small);
  color: var(--c-lime);
  font-weight: var(--fw-bold);
  margin-bottom: var(--space-xs);
  letter-spacing: 0.03em;
}

.hub365-guide .callout.fuchsia .attribution { color: var(--c-fuchsia); }
.hub365-guide .callout.turquoise .attribution { color: var(--c-turquoise); }


/* ============================================================================
   10. STAT BOX / Caja con número grande destacado
============================================================================ */

.hub365-guide .stat-box {
  background: var(--c-bg-card-deep);
  border: 1px solid var(--c-border-lime);
  border-radius: var(--radius-md);
  padding: var(--space-md) var(--space-lg);
  margin: var(--space-md) 0;
  text-align: center;
  position: relative;
  overflow: hidden;
}

.hub365-guide .stat-box::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--gradient-shimmer);
  background-size: 200% 100%;
  animation: shimmerFlow 5s linear infinite;
}

.hub365-guide .stat-number {
  font-size: 2.6rem;
  font-weight: var(--fw-black);
  background: var(--gradient-main);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  line-height: 1.1;
  display: block;
  margin-bottom: var(--space-xs);
}

.hub365-guide .stat-label {
  font-size: var(--fs-small);
  color: var(--c-text-soft);
}


/* ============================================================================
   11. CODE BLOCK / Bloques de código (robots.txt, JSON, etc)
============================================================================ */

.hub365-guide .code-block {
  background: var(--c-bg-card-deep);
  border: 1px solid var(--c-border-soft);
  border-left: 3px solid var(--c-lime);
  border-radius: var(--radius-sm);
  padding: var(--space-md);
  margin: var(--space-md) 0;
  font-family: var(--font-mono);
  font-size: var(--fs-small);
  color: var(--c-text);
  overflow-x: auto;
  white-space: pre;
  line-height: 1.6;
}

.hub365-guide .code-block .code-label {
  display: block;
  font-family: var(--font-body);
  font-size: var(--fs-tiny);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--c-lime);
  font-weight: var(--fw-bold);
  margin-bottom: var(--space-sm);
}


/* ============================================================================
   12. ACTION CARDS / Cards numeradas grandes
   Usadas en: kits de acción, secuencias paso a paso
============================================================================ */

.hub365-guide .action-card {
  background: var(--c-bg-card);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  margin-bottom: var(--space-lg);
  position: relative;
  overflow: hidden;
  transition: var(--transition);
}

.hub365-guide .action-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 4px; height: 100%;
  background: var(--c-fuchsia);
  box-shadow: 0 0 14px var(--glow-fuchsia);
}

.hub365-guide .action-card.action-2::before { background: var(--c-lime); box-shadow: 0 0 14px var(--glow-lime); }
.hub365-guide .action-card.action-3::before { background: var(--c-turquoise); box-shadow: 0 0 14px var(--glow-turq); }
.hub365-guide .action-card.action-4::before { background: var(--c-purple); box-shadow: 0 0 14px var(--glow-purple); }
.hub365-guide .action-card.action-5::before { background: var(--c-coral); box-shadow: 0 0 14px var(--glow-coral); }

.hub365-guide .action-header {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  margin-bottom: var(--space-md);
  flex-wrap: wrap;
}

.hub365-guide .action-number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 52px; height: 52px;
  background: var(--gradient-main);
  border-radius: 50%;
  color: var(--c-white);
  font-weight: var(--fw-black);
  font-size: 1.4rem;
  box-shadow: 0 0 24px rgba(255,0,246,.4);
  flex-shrink: 0;
}

.hub365-guide .action-card.action-2 .action-number {
  background: var(--gradient-lime);
  box-shadow: 0 0 24px rgba(204,255,0,.4);
}
.hub365-guide .action-card.action-3 .action-number {
  background: var(--gradient-turq);
  box-shadow: 0 0 24px rgba(64,224,208,.4);
}
.hub365-guide .action-card.action-4 .action-number {
  background: var(--gradient-purple);
  box-shadow: 0 0 24px rgba(168,37,255,.4);
}
.hub365-guide .action-card.action-5 .action-number {
  background: var(--gradient-coral);
  box-shadow: 0 0 24px rgba(236,147,92,.4);
}

.hub365-guide .action-header h4 {
  margin: 0;
  flex: 1;
  min-width: 200px;
}

.hub365-guide .action-meta {
  display: flex;
  gap: var(--space-md);
  flex-wrap: wrap;
  margin-bottom: var(--space-md);
  padding: var(--space-sm) var(--space-md);
  background: var(--c-bg-card-deep);
  border-radius: var(--radius-sm);
  font-size: var(--fs-tiny);
}

.hub365-guide .action-meta .meta-item {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.hub365-guide .action-meta .meta-label {
  color: var(--c-text-mute);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-size: 0.7rem;
}

.hub365-guide .action-meta .meta-value {
  color: var(--c-white);
  font-weight: var(--fw-bold);
  font-size: var(--fs-small);
}

.hub365-guide .action-card.action-1 .meta-value { color: var(--c-fuchsia-light); }
.hub365-guide .action-card.action-2 .meta-value { color: var(--c-lime); }
.hub365-guide .action-card.action-3 .meta-value { color: var(--c-turquoise); }
.hub365-guide .action-card.action-4 .meta-value { color: var(--c-fuchsia-light); }
.hub365-guide .action-card.action-5 .meta-value { color: var(--c-coral); }


/* ============================================================================
   13. CHANGE BLOCK / Bloques numerados con círculo lateral
   Usado en: "Lo que cambió", listas de cambios o cambios numerados
============================================================================ */

.hub365-guide .change-block {
  background: var(--c-bg-card);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  margin-bottom: var(--space-md);
  position: relative;
  padding-left: calc(var(--space-md) + 50px);
}

.hub365-guide .change-block .change-num {
  position: absolute;
  left: var(--space-md);
  top: var(--space-md);
  width: 36px; height: 36px;
  background: var(--gradient-main);
  border-radius: 50%;
  color: var(--c-white);
  font-weight: var(--fw-black);
  font-size: 0.95rem;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0 18px rgba(255,0,246,.35);
  flex-shrink: 0;
}

.hub365-guide .change-block h5 { margin: 0 0 var(--space-xs); }
.hub365-guide .change-block p { font-size: var(--fs-small); margin: 0; color: var(--c-text-soft); }

/* Alias para mismos bloques con otro nombre semántico */
.hub365-guide .principle-block {
  background: var(--c-bg-card);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  margin-bottom: var(--space-md);
  position: relative;
  padding-left: calc(var(--space-md) + 50px);
}

.hub365-guide .principle-block .principle-num {
  position: absolute;
  left: var(--space-md);
  top: var(--space-md);
  width: 36px; height: 36px;
  background: var(--gradient-main);
  border-radius: 50%;
  color: var(--c-white);
  font-weight: var(--fw-black);
  font-size: 0.95rem;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0 18px rgba(255,0,246,.35);
}

.hub365-guide .principle-block h5 { margin: 0 0 var(--space-xs); }
.hub365-guide .principle-block p { font-size: var(--fs-small); margin: 0; color: var(--c-text-soft); }


/* ============================================================================
   14. LAYER BLOCK / Bloques de capa con badge grande
   Usado en: auditorías por capas (CRM 3 capas, LinkedIn 4 secciones)
============================================================================ */

.hub365-guide .layer-block {
  background: var(--c-bg-card);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  margin-bottom: var(--space-lg);
  position: relative;
  overflow: hidden;
}

.hub365-guide .layer-block::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 4px; height: 100%;
  background: var(--c-fuchsia);
  box-shadow: 0 0 14px var(--glow-fuchsia);
}

.hub365-guide .layer-block.layer-2::before { background: var(--c-lime); box-shadow: 0 0 14px var(--glow-lime); }
.hub365-guide .layer-block.layer-3::before { background: var(--c-turquoise); box-shadow: 0 0 14px var(--glow-turq); }

.hub365-guide .layer-header {
  padding: var(--space-md) var(--space-lg);
  background: var(--c-bg-card-deep);
  border-bottom: 1px solid var(--c-border-soft);
  display: flex;
  align-items: center;
  gap: var(--space-md);
  flex-wrap: wrap;
}

.hub365-guide .layer-badge {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-width: 88px;
  padding: 8px 12px;
  background: var(--gradient-main);
  border-radius: var(--radius-md);
  color: var(--c-white);
  font-weight: var(--fw-black);
  box-shadow: 0 0 24px rgba(255,0,246,.35);
  flex-shrink: 0;
  line-height: 1;
}

.hub365-guide .layer-badge .badge-points {
  font-size: 0.6rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  opacity: .85;
  margin-top: 4px;
  font-weight: var(--fw-semibold);
}

.hub365-guide .layer-badge .badge-num {
  font-size: 1.65rem;
  letter-spacing: -0.02em;
}

.hub365-guide .layer-block.layer-2 .layer-badge {
  background: var(--gradient-lime);
  box-shadow: 0 0 24px rgba(204,255,0,.4);
  color: var(--c-bg-main);
}

.hub365-guide .layer-block.layer-3 .layer-badge {
  background: var(--gradient-turq);
  box-shadow: 0 0 24px rgba(64,224,208,.4);
}

.hub365-guide .layer-info { flex: 1; min-width: 200px; }
.hub365-guide .layer-info h4 { margin: 0 0 4px; font-size: var(--fs-h3); }

.hub365-guide .layer-info .layer-question {
  font-size: var(--fs-small);
  color: var(--c-text-soft);
  font-style: italic;
}

.hub365-guide .layer-content {
  padding: var(--space-md) var(--space-lg) var(--space-lg);
}


/* ============================================================================
   15. SECTION BLOCK / Igual que layer pero con icono emoji
   Usado en: LinkedIn 4 secciones (Foundation, Content, Engagement, Lead Gen)
============================================================================ */

.hub365-guide .section-block {
  background: var(--c-bg-card);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  margin-bottom: var(--space-lg);
  position: relative;
  overflow: hidden;
}

.hub365-guide .section-block::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 4px; height: 100%;
  background: var(--c-fuchsia);
  box-shadow: 0 0 14px var(--glow-fuchsia);
}

.hub365-guide .section-block.section-2::before { background: var(--c-lime); box-shadow: 0 0 14px var(--glow-lime); }
.hub365-guide .section-block.section-3::before { background: var(--c-turquoise); box-shadow: 0 0 14px var(--glow-turq); }
.hub365-guide .section-block.section-4::before { background: var(--c-purple); box-shadow: 0 0 14px var(--glow-purple); }

.hub365-guide .section-header {
  padding: var(--space-md) var(--space-lg);
  background: var(--c-bg-card-deep);
  border-bottom: 1px solid var(--c-border-soft);
  display: flex;
  align-items: center;
  gap: var(--space-md);
  flex-wrap: wrap;
}

.hub365-guide .section-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 56px; height: 56px;
  background: var(--gradient-main);
  border-radius: var(--radius-md);
  font-size: 1.6rem;
  box-shadow: 0 0 24px rgba(255,0,246,.35);
  flex-shrink: 0;
}

.hub365-guide .section-block.section-2 .section-icon {
  background: var(--gradient-lime);
  box-shadow: 0 0 24px rgba(204,255,0,.4);
}

.hub365-guide .section-block.section-3 .section-icon {
  background: var(--gradient-turq);
  box-shadow: 0 0 24px rgba(64,224,208,.4);
}

.hub365-guide .section-block.section-4 .section-icon {
  background: var(--gradient-purple);
  box-shadow: 0 0 24px rgba(168,37,255,.4);
}

.hub365-guide .section-info { flex: 1; min-width: 200px; }
.hub365-guide .section-info h4 { margin: 0 0 4px; font-size: var(--fs-h3); }

.hub365-guide .section-info .section-meta {
  font-size: var(--fs-tiny);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--c-text-mute);
  font-weight: var(--fw-bold);
}

.hub365-guide .section-content {
  padding: var(--space-md) var(--space-lg) var(--space-lg);
}


/* ============================================================================
   16. CHECKPOINT / Punto numerado de auditoría con circle border
   Usado en: CRM (15 puntos), LinkedIn (10 puntos)
============================================================================ */

.hub365-guide .checkpoint {
  background: var(--c-bg-card-deep);
  border: 1px solid var(--c-border-soft);
  border-radius: var(--radius-md);
  padding: var(--space-md) var(--space-md) var(--space-md) calc(var(--space-md) + 50px);
  margin-bottom: var(--space-sm);
  position: relative;
  transition: var(--transition);
}

.hub365-guide .checkpoint::before {
  content: attr(data-num);
  position: absolute;
  left: var(--space-sm);
  top: var(--space-md);
  width: 36px; height: 36px;
  background: var(--c-bg-main);
  border: 2px solid var(--c-fuchsia);
  border-radius: 50%;
  color: var(--c-fuchsia);
  font-size: 0.9rem;
  font-weight: var(--fw-black);
  text-align: center;
  line-height: 32px;
  box-shadow: 0 0 12px var(--glow-fuchsia-soft);
}

/* Color por capa cuando el checkpoint está dentro de un layer-block */
.hub365-guide .layer-block.layer-2 .checkpoint::before {
  border-color: var(--c-lime);
  color: var(--c-lime);
  box-shadow: 0 0 12px var(--glow-lime-soft);
}

.hub365-guide .layer-block.layer-3 .checkpoint::before {
  border-color: var(--c-turquoise);
  color: var(--c-turquoise);
  box-shadow: 0 0 12px var(--glow-turq-soft);
}

/* Color por sección cuando está dentro de un section-block */
.hub365-guide .section-block.section-2 .checkpoint::before {
  border-color: var(--c-lime);
  color: var(--c-lime);
  box-shadow: 0 0 12px var(--glow-lime-soft);
}

.hub365-guide .section-block.section-3 .checkpoint::before {
  border-color: var(--c-turquoise);
  color: var(--c-turquoise);
  box-shadow: 0 0 12px var(--glow-turq-soft);
}

.hub365-guide .section-block.section-4 .checkpoint::before {
  border-color: var(--c-purple);
  color: var(--c-fuchsia-light);
  box-shadow: 0 0 12px var(--glow-purple-soft);
}

.hub365-guide .checkpoint .checkbox {
  position: absolute;
  right: var(--space-md);
  top: var(--space-md);
  width: 24px; height: 24px;
  border: 1.5px solid var(--c-border-lime);
  border-radius: var(--radius-sm);
  background: rgba(204,255,0,.04);
}

.hub365-guide .checkpoint h5 {
  margin: 0 0 var(--space-xs);
  padding-right: 40px;
  font-size: var(--fs-body);
  line-height: 1.4;
}

.hub365-guide .checkpoint p {
  font-size: var(--fs-small);
  margin: 0 0 var(--space-sm);
  color: var(--c-text-soft);
}

.hub365-guide .checkpoint p:last-child { margin-bottom: 0; }

/* Stat callout interno (cuando un checkpoint tiene una estadística clave) */
.hub365-guide .checkpoint .stat-callout {
  display: block;
  margin-top: var(--space-sm);
  padding: var(--space-sm);
  background: rgba(204,255,0,.06);
  border-left: 2px solid var(--c-lime);
  border-radius: var(--radius-sm);
  font-size: var(--fs-tiny);
  color: var(--c-lime);
  font-style: italic;
}

/* Test question (callout fucsia para preguntas de validación) */
.hub365-guide .checkpoint .test-question {
  display: block;
  margin-top: var(--space-sm);
  padding: var(--space-sm);
  background: rgba(255,0,246,.06);
  border-left: 2px solid var(--c-fuchsia);
  border-radius: var(--radius-sm);
  font-size: var(--fs-small);
  color: var(--c-fuchsia-light);
  font-style: italic;
}

/* Rating buttons (3-state: ✓ ~ ✗) cuando el checkpoint permite estado parcial */
.hub365-guide .checkpoint .rating-buttons {
  position: absolute;
  right: var(--space-md);
  top: var(--space-md);
  display: flex;
  gap: 4px;
}

.hub365-guide .checkpoint .rating-btn {
  width: 26px; height: 26px;
  border: 1.5px solid var(--c-border-soft);
  border-radius: 6px;
  background: var(--c-bg-main);
  font-size: 0.8rem;
  font-weight: var(--fw-bold);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.hub365-guide .checkpoint .rating-btn.ok { border-color: var(--c-border-lime); color: var(--c-lime); }
.hub365-guide .checkpoint .rating-btn.partial { border-color: rgba(236,147,92,.4); color: var(--c-coral); }
.hub365-guide .checkpoint .rating-btn.missing { border-color: rgba(255,0,246,.4); color: var(--c-fuchsia); }

/* Cuando hay rating-buttons, dejar más espacio en el título */
.hub365-guide .checkpoint:has(.rating-buttons) h5 { padding-right: 110px; }


/* ============================================================================
   17. RATING LEGEND / Leyenda de los 3 estados de rating
============================================================================ */

.hub365-guide .rating-legend {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
  padding: var(--space-md);
  background: var(--c-bg-card-deep);
  border: 1px solid var(--c-border-lime);
  border-radius: var(--radius-md);
  margin: var(--space-md) 0;
  justify-content: center;
}

.hub365-guide .rating-item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: var(--fs-small);
  color: var(--c-text);
}

.hub365-guide .rating-item .symbol {
  font-size: 1.2rem;
  font-weight: var(--fw-black);
}

.hub365-guide .rating-item.ok .symbol { color: var(--c-lime); }
.hub365-guide .rating-item.partial .symbol { color: var(--c-coral); }
.hub365-guide .rating-item.missing .symbol { color: var(--c-fuchsia); }


/* ============================================================================
   18. CHECKLIST GROUP / Lista de checklist con caja
   Usado en: matrices de decisión, listas con checkboxes
============================================================================ */

.hub365-guide .checklist-group {
  background: var(--c-bg-card);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  margin-bottom: var(--space-md);
}

.hub365-guide .checklist-group .group-label {
  display: inline-block;
  font-size: var(--fs-tiny);
  font-weight: var(--fw-bold);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--c-fuchsia-light);
  margin-bottom: var(--space-sm);
}

.hub365-guide .checklist-group.lime .group-label { color: var(--c-lime); }
.hub365-guide .checklist-group.turquoise .group-label { color: var(--c-turquoise); }

.hub365-guide .checklist-group ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.hub365-guide .checklist-group li {
  padding: 10px 0 10px 32px;
  position: relative;
  font-size: var(--fs-small);
  color: var(--c-text);
  border-bottom: 1px solid var(--c-border-soft);
}

.hub365-guide .checklist-group li:last-child { border-bottom: none; }

.hub365-guide .checklist-group li::before {
  content: "";
  position: absolute;
  left: 4px; top: 13px;
  width: 16px; height: 16px;
  border: 1.5px solid var(--c-fuchsia);
  border-radius: 3px;
}

.hub365-guide .checklist-group.lime li::before { border-color: var(--c-lime); }
.hub365-guide .checklist-group.turquoise li::before { border-color: var(--c-turquoise); }


/* ============================================================================
   19. SCORE TIER / Niveles de puntaje (0-3, 4-6, 7-10, etc)
============================================================================ */

.hub365-guide .score-tier {
  padding: var(--space-md);
  background: var(--c-bg-card);
  border: 1px solid var(--c-border-soft);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-sm);
  position: relative;
  padding-left: calc(var(--space-md) + 70px);
}

.hub365-guide .score-tier::before {
  content: attr(data-range);
  position: absolute;
  left: var(--space-sm);
  top: 50%;
  transform: translateY(-50%);
  width: 56px;
  text-align: center;
  font-weight: var(--fw-black);
  font-size: 0.95rem;
  color: var(--c-fuchsia);
  letter-spacing: -0.02em;
  line-height: 1;
}

.hub365-guide .score-tier.tier-mid::before { color: var(--c-lime); }
.hub365-guide .score-tier.tier-best::before { color: var(--c-turquoise); }

.hub365-guide .score-tier.tier-best { border-color: var(--c-border-turq); background: rgba(64,224,208,.04); }
.hub365-guide .score-tier.tier-mid { border-color: var(--c-border-lime); background: rgba(204,255,0,.04); }

.hub365-guide .score-tier h5 {
  margin: 0 0 var(--space-xs);
  font-size: var(--fs-body);
}

.hub365-guide .score-tier p {
  font-size: var(--fs-small);
  margin: 0;
  color: var(--c-text-soft);
}

/* Variante simple sin data-range (texto inline con strong al inicio) */
.hub365-guide .score-tier.simple {
  padding: var(--space-sm) var(--space-md);
  background: var(--c-bg-subtle);
  border-left: 3px solid var(--c-fuchsia);
  border-radius: var(--radius-sm);
  font-size: var(--fs-small);
  padding-left: var(--space-md);
}

.hub365-guide .score-tier.simple::before { content: none; }

.hub365-guide .score-tier.simple strong {
  color: var(--c-lime);
  display: inline-block;
  min-width: 54px;
}


/* ============================================================================
   20. FAILURE BLOCK / Bloque con ranking #1, #2, etc
============================================================================ */

.hub365-guide .failure-block {
  background: var(--c-bg-card);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  margin-bottom: var(--space-md);
  position: relative;
  padding-left: calc(var(--space-md) + 60px);
  border-left: 3px solid var(--c-fuchsia);
}

.hub365-guide .failure-block .failure-rank {
  position: absolute;
  left: var(--space-sm);
  top: var(--space-md);
  font-family: var(--font-heading);
  font-size: 1.4rem;
  font-weight: var(--fw-black);
  color: var(--c-fuchsia);
  letter-spacing: -0.05em;
  line-height: 1;
}

.hub365-guide .failure-block h5 { margin: 0 0 var(--space-xs); }
.hub365-guide .failure-block p { font-size: var(--fs-small); margin: 0; color: var(--c-text-soft); }


/* ============================================================================
   21. DAY BLOCK / Bloques por día (secuencias multi-día)
   Usado en: 7-day follow-up sequence
============================================================================ */

.hub365-guide .day-block {
  background: var(--c-bg-card);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  margin-bottom: var(--space-lg);
  position: relative;
  overflow: hidden;
}

.hub365-guide .day-block::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 4px; height: 100%;
  background: var(--c-fuchsia);
  box-shadow: 0 0 14px var(--glow-fuchsia);
}

.hub365-guide .day-block.day-0::before { background: var(--c-coral); box-shadow: 0 0 14px var(--glow-coral); }
.hub365-guide .day-block.day-1::before { background: var(--c-fuchsia); box-shadow: 0 0 14px var(--glow-fuchsia); }
.hub365-guide .day-block.day-2::before { background: var(--c-lime); box-shadow: 0 0 14px var(--glow-lime); }
.hub365-guide .day-block.day-3::before { background: var(--c-turquoise); box-shadow: 0 0 14px var(--glow-turq); }
.hub365-guide .day-block.day-4::before { background: var(--c-purple); box-shadow: 0 0 14px var(--glow-purple); }
.hub365-guide .day-block.day-5::before { background: var(--c-fuchsia); box-shadow: 0 0 14px var(--glow-fuchsia); }
.hub365-guide .day-block.day-6::before { background: var(--c-lime); box-shadow: 0 0 14px var(--glow-lime); }
.hub365-guide .day-block.day-7::before { background: var(--c-turquoise); box-shadow: 0 0 14px var(--glow-turq); }

.hub365-guide .day-header {
  padding: var(--space-md) var(--space-lg);
  background: var(--c-bg-card-deep);
  border-bottom: 1px solid var(--c-border-soft);
  display: flex;
  align-items: center;
  gap: var(--space-md);
  flex-wrap: wrap;
}

.hub365-guide .day-badge {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 64px; height: 64px;
  background: var(--gradient-main);
  border-radius: var(--radius-md);
  color: var(--c-white);
  font-weight: var(--fw-black);
  box-shadow: 0 0 24px rgba(255,0,246,.35);
  flex-shrink: 0;
  line-height: 1;
}

.hub365-guide .day-badge .day-label {
  font-size: 0.55rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  opacity: .85;
  margin-bottom: 4px;
  font-weight: var(--fw-semibold);
}

.hub365-guide .day-badge .day-num {
  font-size: 1.85rem;
  letter-spacing: -0.02em;
}

.hub365-guide .day-block.day-0 .day-badge { background: var(--gradient-coral); box-shadow: 0 0 24px rgba(236,147,92,.4); }
.hub365-guide .day-block.day-2 .day-badge { background: var(--gradient-lime); box-shadow: 0 0 24px rgba(204,255,0,.4); }
.hub365-guide .day-block.day-3 .day-badge { background: var(--gradient-turq); box-shadow: 0 0 24px rgba(64,224,208,.4); }
.hub365-guide .day-block.day-4 .day-badge { background: var(--gradient-purple); box-shadow: 0 0 24px rgba(168,37,255,.4); }
.hub365-guide .day-block.day-6 .day-badge { background: var(--gradient-lime); box-shadow: 0 0 24px rgba(204,255,0,.4); }
.hub365-guide .day-block.day-7 .day-badge { background: var(--gradient-turq); box-shadow: 0 0 24px rgba(64,224,208,.4); }

.hub365-guide .day-info { flex: 1; min-width: 200px; }
.hub365-guide .day-info h4 { margin: 0 0 4px; font-size: var(--fs-h3); }

.hub365-guide .day-info .day-meta {
  font-size: var(--fs-tiny);
  color: var(--c-text-mute);
  letter-spacing: 0.05em;
}

.hub365-guide .day-info .day-meta strong {
  color: var(--c-lime);
  font-weight: var(--fw-bold);
}

.hub365-guide .day-content {
  padding: var(--space-md) var(--space-lg) var(--space-lg);
}


/* ============================================================================
   22. MESSAGE BOX / Caja para emails y mensajes WhatsApp
   Usado en: secuencias de seguimiento
============================================================================ */

.hub365-guide .message-box {
  background: var(--c-bg-card-deep);
  border: 1px solid var(--c-border-soft);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  margin: var(--space-sm) 0 var(--space-md);
  font-size: var(--fs-small);
  line-height: 1.7;
  color: var(--c-text);
  white-space: pre-wrap;
}

.hub365-guide .message-box.whatsapp { border-left: 3px solid var(--c-whatsapp); }
.hub365-guide .message-box.email { border-left: 3px solid var(--c-fuchsia-light); }

.hub365-guide .message-box .msg-header {
  display: block;
  font-family: var(--font-body);
  font-size: var(--fs-tiny);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: var(--fw-bold);
  margin-bottom: var(--space-sm);
  padding-bottom: var(--space-xs);
  border-bottom: 1px dashed var(--c-border-soft);
}

.hub365-guide .message-box.whatsapp .msg-header { color: var(--c-whatsapp); }
.hub365-guide .message-box.email .msg-header { color: var(--c-fuchsia-light); }

.hub365-guide .message-box .msg-subject {
  display: block;
  font-weight: var(--fw-bold);
  color: var(--c-white);
  font-size: var(--fs-body);
  margin-bottom: var(--space-sm);
  font-style: normal;
}

.hub365-guide .message-box .msg-body {
  font-style: italic;
  color: var(--c-text-soft);
}

.hub365-guide .message-box .msg-body strong {
  font-style: normal;
  color: var(--c-white);
}

.hub365-guide .message-box .msg-body em {
  font-style: normal;
  color: var(--c-lime);
  font-weight: var(--fw-medium);
}


/* ============================================================================
   23. PURPOSE TAG / Tag pequeño con propósito (lima)
============================================================================ */

.hub365-guide .purpose-tag {
  display: inline-block;
  padding: 4px 10px;
  background: rgba(204,255,0,.08);
  border: 1px solid var(--c-border-lime);
  border-radius: 999px;
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--c-lime);
  font-weight: var(--fw-bold);
  margin-bottom: var(--space-sm);
}


/* ============================================================================
   24. SUB LIST / Lista con flecha →
============================================================================ */

.hub365-guide .sub-list {
  list-style: none;
  padding: 0;
  margin: var(--space-sm) 0;
}

.hub365-guide .sub-list li {
  padding: 8px 0 8px 28px;
  position: relative;
  font-size: var(--fs-small);
  color: var(--c-text);
  border-bottom: 1px solid var(--c-border-soft);
}

.hub365-guide .sub-list li:last-child { border-bottom: none; }

.hub365-guide .sub-list li::before {
  content: "→";
  position: absolute;
  left: 4px;
  top: 8px;
  color: var(--c-lime);
  font-weight: var(--fw-black);
}


/* ============================================================================
   25. PRIORITY LIST / Lista numerada en círculos
============================================================================ */

.hub365-guide .priority-list {
  list-style: none;
  padding: 0;
  margin: var(--space-md) 0;
  counter-reset: priority-counter;
}

.hub365-guide .priority-list li {
  counter-increment: priority-counter;
  padding: var(--space-sm) var(--space-md) var(--space-sm) calc(var(--space-md) + 38px);
  margin-bottom: 8px;
  background: var(--c-bg-card);
  border: 1px solid var(--c-border-soft);
  border-radius: var(--radius-sm);
  position: relative;
  font-size: var(--fs-small);
  transition: var(--transition);
}

.hub365-guide .priority-list li::before {
  content: counter(priority-counter);
  position: absolute;
  left: var(--space-sm);
  top: 50%;
  transform: translateY(-50%);
  width: 26px; height: 26px;
  background: rgba(204,255,0,.1);
  border: 1px solid var(--c-border-lime);
  border-radius: 50%;
  color: var(--c-lime);
  font-size: 0.85rem;
  font-weight: var(--fw-black);
  text-align: center;
  line-height: 24px;
}

.hub365-guide .priority-list li:hover {
  border-color: var(--c-border-lime);
  background: rgba(204,255,0,.03);
}


/* ============================================================================
   26. AUTOMATION FLOW / Mismo estilo que priority-list (alias)
============================================================================ */

.hub365-guide .automation-flow {
  list-style: none;
  padding: 0;
  margin: var(--space-md) 0;
  counter-reset: flow-counter;
}

.hub365-guide .automation-flow li {
  counter-increment: flow-counter;
  padding: var(--space-sm) var(--space-md) var(--space-sm) calc(var(--space-md) + 38px);
  margin-bottom: 8px;
  background: var(--c-bg-card);
  border: 1px solid var(--c-border-soft);
  border-radius: var(--radius-sm);
  position: relative;
  font-size: var(--fs-small);
}

.hub365-guide .automation-flow li::before {
  content: counter(flow-counter);
  position: absolute;
  left: var(--space-sm);
  top: 50%;
  transform: translateY(-50%);
  width: 26px; height: 26px;
  background: rgba(204,255,0,.1);
  border: 1px solid var(--c-border-lime);
  border-radius: 50%;
  color: var(--c-lime);
  font-size: 0.85rem;
  font-weight: var(--fw-black);
  text-align: center;
  line-height: 24px;
}


/* ============================================================================
   27. DAY PLAN / Plan de N días con badges "Day 1, Day 2"
============================================================================ */

.hub365-guide .day-plan {
  list-style: none;
  padding: 0;
  margin: var(--space-md) 0;
  counter-reset: day-counter;
}

.hub365-guide .day-plan li {
  counter-increment: day-counter;
  padding: var(--space-md) var(--space-md) var(--space-md) calc(var(--space-md) + 70px);
  margin-bottom: var(--space-sm);
  background: var(--c-bg-card);
  border: 1px solid var(--c-border-soft);
  border-radius: var(--radius-md);
  position: relative;
  transition: var(--transition);
  font-size: var(--fs-small);
}

/* Default: Day en inglés. Para español, sobrescribir con .day-plan.es */
.hub365-guide .day-plan li::before {
  content: "Day " counter(day-counter);
  position: absolute;
  left: var(--space-sm);
  top: 50%;
  transform: translateY(-50%);
  width: 56px;
  text-align: center;
  background: var(--gradient-main);
  border-radius: var(--radius-sm);
  color: var(--c-white);
  font-size: 0.7rem;
  font-weight: var(--fw-black);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 8px 0;
  box-shadow: 0 0 12px rgba(255,0,246,.3);
}

.hub365-guide .day-plan.es li::before { content: "Día " counter(day-counter); }

.hub365-guide .day-plan li strong {
  display: block;
  margin-bottom: 4px;
  color: var(--c-white);
  font-size: var(--fs-body);
}

.hub365-guide .day-plan li:hover {
  border-color: var(--c-border-lime);
  background: rgba(204,255,0,.02);
}


/* ============================================================================
   28. DM STEPS / Pasos con badge "Step 1, Paso 1" + ejemplo de mensaje
============================================================================ */

.hub365-guide .dm-steps {
  list-style: none;
  padding: 0;
  margin: var(--space-md) 0;
  counter-reset: dm-counter;
}

.hub365-guide .dm-steps li {
  counter-increment: dm-counter;
  padding: var(--space-md) var(--space-md) var(--space-md) calc(var(--space-md) + 56px);
  margin-bottom: var(--space-sm);
  background: var(--c-bg-card);
  border: 1px solid var(--c-border-soft);
  border-radius: var(--radius-md);
  position: relative;
}

/* Default: Step en inglés. Para español usar .dm-steps.es */
.hub365-guide .dm-steps li::before {
  content: "Step " counter(dm-counter);
  position: absolute;
  left: var(--space-sm);
  top: var(--space-md);
  width: 44px;
  text-align: center;
  background: var(--gradient-main);
  border-radius: var(--radius-sm);
  color: var(--c-white);
  font-size: 0.6rem;
  font-weight: var(--fw-black);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 6px 0;
  box-shadow: 0 0 12px rgba(255,0,246,.3);
}

.hub365-guide .dm-steps.es li::before { content: "Paso " counter(dm-counter); }

.hub365-guide .dm-steps strong {
  display: block;
  margin-bottom: 4px;
  color: var(--c-white);
  font-size: var(--fs-body);
}

.hub365-guide .dm-steps p {
  margin: 0 0 var(--space-xs);
  font-size: var(--fs-small);
  color: var(--c-text-soft);
}

.hub365-guide .dm-steps .dm-example {
  display: block;
  margin-top: var(--space-xs);
  padding: var(--space-sm);
  background: var(--c-bg-card-deep);
  border-left: 2px solid var(--c-lime);
  border-radius: var(--radius-sm);
  font-size: var(--fs-small);
  color: var(--c-text);
  font-style: italic;
  line-height: 1.6;
}


/* ============================================================================
   29. PARAGRAPH STRUCTURE / Lista P1, P2, P3
============================================================================ */

.hub365-guide .paragraph-structure {
  list-style: none;
  padding: 0;
  margin: var(--space-sm) 0;
  counter-reset: para-counter;
}

.hub365-guide .paragraph-structure li {
  counter-increment: para-counter;
  padding: var(--space-sm) var(--space-sm) var(--space-sm) calc(var(--space-sm) + 36px);
  margin-bottom: 6px;
  background: rgba(255,255,255,.02);
  border-radius: var(--radius-sm);
  position: relative;
  font-size: var(--fs-small);
}

.hub365-guide .paragraph-structure li::before {
  content: "P" counter(para-counter);
  position: absolute;
  left: 6px;
  top: 50%;
  transform: translateY(-50%);
  width: 28px; height: 24px;
  background: var(--c-bg-main);
  border: 1px solid var(--c-border-lime);
  border-radius: 4px;
  color: var(--c-lime);
  font-size: 0.7rem;
  font-weight: var(--fw-black);
  text-align: center;
  line-height: 22px;
  letter-spacing: 0.05em;
}


/* ============================================================================
   30. CONTENT MIX / Grid de 3 con porcentajes en gradiente
============================================================================ */

.hub365-guide .content-mix {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-sm);
  margin: var(--space-sm) 0;
}

@media (min-width: 720px) {
  .hub365-guide .content-mix { grid-template-columns: repeat(3, 1fr); }
}

.hub365-guide .mix-item {
  background: var(--c-bg-main);
  border: 1px solid var(--c-border-soft);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  position: relative;
}

.hub365-guide .mix-item .mix-pct {
  font-size: 1.6rem;
  font-weight: var(--fw-black);
  background: var(--gradient-main);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  display: block;
  line-height: 1;
  margin-bottom: 4px;
}

.hub365-guide .mix-item .mix-type {
  display: block;
  font-size: var(--fs-tiny);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--c-fuchsia-light);
  font-weight: var(--fw-bold);
  margin-bottom: var(--space-xs);
}

.hub365-guide .mix-item p {
  margin: 0;
  font-size: var(--fs-tiny);
  color: var(--c-text-soft);
  line-height: 1.5;
  font-style: italic;
}


/* ============================================================================
   31. SPLIT GRID / Grid de 2 columnas (para "lo que cambió vs no cambió")
============================================================================ */

.hub365-guide .split-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-md);
  margin: var(--space-lg) 0;
}

@media (min-width: 720px) {
  .hub365-guide .split-grid { grid-template-columns: 1fr 1fr; }
}

.hub365-guide .split-card {
  background: var(--c-bg-card);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  position: relative;
  overflow: hidden;
}

.hub365-guide .split-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 3px; height: 100%;
  background: var(--c-fuchsia);
  box-shadow: 0 0 10px var(--glow-fuchsia);
}

.hub365-guide .split-card.same::before {
  background: var(--c-turquoise);
  box-shadow: 0 0 10px var(--glow-turq);
}

.hub365-guide .split-card .split-tag {
  display: inline-block;
  font-size: var(--fs-tiny);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: var(--fw-bold);
  color: var(--c-fuchsia-light);
  margin-bottom: var(--space-xs);
}

.hub365-guide .split-card.same .split-tag { color: var(--c-turquoise); }

.hub365-guide .split-card h5 {
  margin: 0 0 var(--space-xs);
  font-size: var(--fs-body);
}

.hub365-guide .split-card p {
  font-size: var(--fs-small);
  margin: 0;
  color: var(--c-text-soft);
}


/* ============================================================================
   32. LAYER GRID / Grid de 2 columnas con tag superior
============================================================================ */

.hub365-guide .layer-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-md);
  margin: var(--space-lg) 0;
}

@media (min-width: 720px) {
  .hub365-guide .layer-grid { grid-template-columns: 1fr 1fr; }
}

.hub365-guide .layer-card {
  background: var(--c-bg-card);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  position: relative;
  transition: var(--transition);
}

.hub365-guide .layer-card .layer-tag {
  display: inline-block;
  font-size: var(--fs-tiny);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--c-fuchsia-light);
  font-weight: var(--fw-bold);
  margin-bottom: var(--space-xs);
}

.hub365-guide .layer-card.layer-2 .layer-tag { color: var(--c-turquoise); }

.hub365-guide .layer-card h5 {
  margin: 0 0 var(--space-sm);
}

.hub365-guide .layer-card ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.hub365-guide .layer-card li {
  padding: 6px 0 6px 22px;
  font-size: var(--fs-small);
  color: var(--c-text-soft);
  position: relative;
}

.hub365-guide .layer-card li::before {
  content: "→";
  position: absolute;
  left: 0;
  color: var(--c-lime);
  font-weight: var(--fw-bold);
}

.hub365-guide .layer-card.layer-2 li::before { color: var(--c-turquoise); }


/* ============================================================================
   33. STEP BLOCK / Sub-pasos dentro de acciones
============================================================================ */

.hub365-guide .step-block {
  padding: var(--space-md);
  background: var(--c-bg-subtle);
  border-radius: var(--radius-sm);
  margin-bottom: var(--space-sm);
  border-left: 2px solid var(--c-border-lime);
}

.hub365-guide .step-block .step-tag {
  display: inline-block;
  font-size: var(--fs-tiny);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--c-lime);
  font-weight: var(--fw-bold);
  margin-bottom: 6px;
}

.hub365-guide .step-block h5 {
  margin: 0 0 var(--space-xs);
  font-size: var(--fs-h4);
}

.hub365-guide .step-block p {
  font-size: var(--fs-small);
  margin: 0;
  color: var(--c-text-soft);
}


/* ============================================================================
   34. TIMELINE TABLE / Tabla con tiempos / impactos
============================================================================ */

.hub365-guide .timeline-table-wrapper {
  overflow-x: auto;
  margin: var(--space-md) 0;
  border-radius: var(--radius-md);
  border: 1px solid var(--c-border);
}

.hub365-guide .timeline-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--fs-small);
  background: var(--c-bg-card);
}

.hub365-guide .timeline-table thead th {
  background: rgba(191,90,242,.14);
  color: var(--c-fuchsia-light);
  font-weight: var(--fw-bold);
  font-size: var(--fs-tiny);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: var(--space-sm) var(--space-md);
  text-align: left;
  border-bottom: 1px solid var(--c-border);
}

.hub365-guide .timeline-table tbody td {
  padding: var(--space-sm) var(--space-md);
  border-bottom: 1px solid var(--c-border-soft);
  color: var(--c-text);
  vertical-align: top;
}

.hub365-guide .timeline-table tbody tr:last-child td { border-bottom: none; }
.hub365-guide .timeline-table tbody tr:hover td { background: rgba(204,255,0,.03); }

.hub365-guide .timeline-table .col-time { color: var(--c-lime); font-weight: var(--fw-bold); white-space: nowrap; }
.hub365-guide .timeline-table .col-impact { color: var(--c-turquoise); font-weight: var(--fw-bold); white-space: nowrap; }


/* ============================================================================
   35. SCORE TABLE / Tabla de puntajes con 4 niveles coloreados
============================================================================ */

.hub365-guide .score-table-wrapper {
  overflow-x: auto;
  margin: var(--space-md) 0;
  border-radius: var(--radius-md);
  border: 1px solid var(--c-border);
}

.hub365-guide .score-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--fs-small);
  background: var(--c-bg-card);
}

.hub365-guide .score-table thead th {
  background: rgba(191,90,242,.14);
  color: var(--c-fuchsia-light);
  font-weight: var(--fw-bold);
  font-size: var(--fs-tiny);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: var(--space-sm) var(--space-md);
  text-align: left;
  border-bottom: 1px solid var(--c-border);
}

.hub365-guide .score-table tbody td {
  padding: var(--space-sm) var(--space-md);
  border-bottom: 1px solid var(--c-border-soft);
  color: var(--c-text);
  vertical-align: middle;
}

.hub365-guide .score-table tbody tr:last-child td { border-bottom: none; }
.hub365-guide .score-table tbody tr:hover td { background: rgba(204,255,0,.03); }

.hub365-guide .score-table .col-score {
  font-family: var(--font-heading);
  font-size: 1.1rem;
  font-weight: var(--fw-black);
  color: var(--c-fuchsia);
  letter-spacing: -0.02em;
  white-space: nowrap;
}

.hub365-guide .score-table tr:nth-child(2) .col-score { color: var(--c-coral); }
.hub365-guide .score-table tr:nth-child(3) .col-score { color: var(--c-lime); }
.hub365-guide .score-table tr:nth-child(4) .col-score { color: var(--c-turquoise); }

.hub365-guide .score-table .col-status { font-weight: var(--fw-bold); color: var(--c-white); }


/* ============================================================================
   36. CTA SECTION / Sección final de llamado a la acción
============================================================================ */

.hub365-guide .cta-section {
  margin-top: var(--space-xl);
  padding: var(--space-xl) var(--space-lg);
  background: var(--c-bg-card-deep);
  border: 1px solid var(--c-border-lime);
  border-radius: var(--radius-lg);
  text-align: center;
  position: relative;
  overflow: hidden;
}

.hub365-guide .cta-section::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--gradient-shimmer);
  background-size: 200% 100%;
  animation: shimmerFlow 4s linear infinite;
}

.hub365-guide .cta-btn {
  display: inline-block;
  padding: 18px 40px;
  background: var(--gradient-main);
  background-size: 200% 200%;
  color: var(--c-white) !important;
  font-size: var(--fs-small);
  font-weight: var(--fw-bold);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-decoration: none;
  border-radius: var(--radius-md);
  border: none !important;
  margin: var(--space-sm) 8px;
  transition: var(--transition);
  animation: gradientSlide 6s ease infinite;
  box-shadow: 0 4px 24px rgba(255,0,246,.2);
}

.hub365-guide .cta-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 32px rgba(255,0,246,.4);
  border: none !important;
}

.hub365-guide .cta-btn.secondary {
  background: transparent;
  border: 1px solid var(--c-border-lime) !important;
  color: var(--c-lime) !important;
  animation: none;
  box-shadow: none;
}

.hub365-guide .cta-btn.secondary:hover {
  background: rgba(204,255,0,.06);
  border-color: var(--c-lime) !important;
  box-shadow: 0 0 24px rgba(204,255,0,.25);
}

.hub365-guide .cta-link-list {
  list-style: none;
  padding: 0;
  margin: var(--space-md) auto 0;
  text-align: left;
  max-width: 560px;
}

.hub365-guide .cta-link-list li {
  padding: var(--space-xs) 0;
  color: var(--c-text-soft);
  font-size: var(--fs-small);
}

.hub365-guide .cta-link-list li::before {
  content: "→ ";
  color: var(--c-lime);
  font-weight: var(--fw-bold);
  margin-right: 4px;
}


/* ============================================================================
   37. DIVIDERS / Separadores entre secciones
============================================================================ */

.hub365-guide .divider {
  height: 1px;
  background: var(--c-border);
  margin: var(--space-xl) 0;
  border: none;
}

.hub365-guide .divider-glow {
  height: 2px;
  background: var(--gradient-shimmer);
  background-size: 200% 100%;
  animation: shimmerFlow 6s linear infinite;
  margin: var(--space-xl) 0 !important;
  border: none;
  border-radius: 2px;
}


/* ============================================================================
   38. FOOTER / Nota final
============================================================================ */

.hub365-guide .footer-note {
  margin-top: var(--space-xl);
  padding-top: var(--space-md);
  border-top: 1px solid var(--c-border-soft);
  font-size: var(--fs-micro);
  color: var(--c-text-mute);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-align: center;
  line-height: 1.8;
}


/* ============================================================================
   39. ANIMATIONS / Keyframes y reveal-on-scroll
============================================================================ */

@keyframes shimmerSlide {
  0%   { background-position: 0% 50%; }
  100% { background-position: 300% 50%; }
}

@keyframes shimmerFlow {
  0%   { background-position: 0% 50%; }
  100% { background-position: 200% 50%; }
}

@keyframes gradientSlide {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

@keyframes dotPulse {
  0%, 100% { transform: scale(1); opacity: 1; }
  50%      { transform: scale(1.25); opacity: .75; }
}

@keyframes glowPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(204,255,0,0); }
  50%      { box-shadow: 0 0 20px 2px rgba(204,255,0,.18); }
}

@keyframes revealIn {
  to { opacity: 1; transform: translateY(0); }
}

/* SCROLL REVEAL / 100% CSS, sin JavaScript.
   Navegadores modernos (Chrome/Edge): anima al hacer scroll.
   Navegadores antiguos (Safari/Firefox): todo se ve visible por defecto. */
.hub365-guide .reveal {
  opacity: 1;
  transform: translateY(0);
}

@supports (animation-timeline: view()) {
  .hub365-guide .reveal {
    opacity: 0;
    transform: translateY(16px);
    animation: revealIn linear both;
    animation-timeline: view();
    animation-range: entry 0% entry 40%;
  }
}


/* ============================================================================
   40. RESPONSIVE / Media queries para móvil
============================================================================ */

@media (max-width: 640px) {
  .hub365-guide {
    padding: var(--space-md) var(--space-sm);
    border-radius: var(--radius-md);
  }
  .hub365-guide .action-number { width: 44px; height: 44px; font-size: 1.2rem; }
  .hub365-guide .day-badge { width: 54px; height: 54px; }
  .hub365-guide .day-badge .day-num { font-size: 1.5rem; }
  .hub365-guide .stat-number { font-size: 2.1rem; }
  .hub365-guide .layer-badge .badge-num { font-size: 1.4rem; }
  .hub365-guide .section-icon { width: 44px; height: 44px; font-size: 1.3rem; }
  .hub365-guide .checkpoint { padding-left: calc(var(--space-md) + 44px); }
  .hub365-guide .checkpoint::before { width: 30px; height: 30px; line-height: 26px; font-size: 0.8rem; }
  .hub365-guide .checkpoint h5 { padding-right: 0; padding-bottom: 36px; }
  .hub365-guide .checkpoint .rating-buttons { right: auto; left: var(--space-md); top: auto; bottom: var(--space-md); }
  .hub365-guide .timeline-table,
  .hub365-guide .score-table { font-size: 0.85rem; }
  .hub365-guide .timeline-table thead th,
  .hub365-guide .timeline-table tbody td,
  .hub365-guide .score-table thead th,
  .hub365-guide .score-table tbody td { padding: var(--space-xs) var(--space-sm); }
}


/* ============================================================================
   41. ACCESSIBILITY / Respeta prefers-reduced-motion
============================================================================ */

@media (prefers-reduced-motion: reduce) {
  .hub365-guide *,
  .hub365-guide *::before,
  .hub365-guide *::after {
    animation: none !important;
    transition: none !important;
  }
}


/* ============================================================================
   FIN DEL MASTER STYLESHEET
   Para crear una guía nueva:
   1. <link rel="stylesheet" href="/path/to/hub365-master.css">
   2. <link href="https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700;900&display=swap" rel="stylesheet">
   3. Tu HTML adentro de <div class="hub365-guide">...</div>
   4. Si necesitás algo único, agregás un <style> pequeño con CSS específico
============================================================================ *//* End custom CSS */