:root {
      --carbon: #111315;
      --grafito: #2e3439;
      --gris: #6f7a82;
      --gris-claro: #aab1b8;
      --humo: #eceff1;
      --marfil: #fffaf0;
      --marfil-suave: #f4efe6;
      --blanco: #ffffff;
      --verde: #667b70;
      --azul: #1c6fbd;
      --azul-profundo: #153b5f;
      --naranja: #e1841b;
      --naranja-oscuro: #b95d0b;
      --texto: #202326;
      --borde: rgba(17, 19, 21, 0.13);
      --sombra: 0 20px 50px rgba(17, 19, 21, 0.12);
      --sombra-suave: 0 16px 42px rgba(28, 52, 71, 0.1);
    }

    * { box-sizing: border-box; }

    html {
      scroll-behavior: smooth;
      scroll-padding-top: 82px;
      max-width: 100%;
      overflow-x: hidden;
    }

    body {
      margin: 0;
      width: 100%;
      max-width: 100%;
      overflow-x: hidden;
      color: var(--texto);
      background:
        radial-gradient(circle at 8% 18%, rgba(28,111,189,.055), transparent 24%),
        radial-gradient(circle at 92% 62%, rgba(225,132,27,.06), transparent 26%),
        var(--humo);
      font-family: Arial, Helvetica, sans-serif;
      line-height: 1.55;
    }

    button, a, input, select, textarea {
      -webkit-tap-highlight-color: transparent;
    }

    a { color: inherit; }

    h1, h2, h3, p { margin-top: 0; }

    .contenedor {
      width: min(1160px, calc(100% - 32px));
      margin: 0 auto;
    }

    section {
      position: relative;
      padding: 86px 0;
      scroll-margin-top: 82px;
    }

    main > section + section { border-top: 1px solid rgba(17,19,21,.055); }

    header {
      position: sticky;
      top: 0;
      z-index: 100;
      background: rgba(17, 19, 21, 0.96);
      border-bottom: 1px solid rgba(255,255,255,.1);
      box-shadow: 0 10px 35px rgba(0,0,0,.16);
      backdrop-filter: blur(14px);
    }

    .nav {
      width: min(1160px, calc(100% - 32px));
      min-height: 74px;
      margin: 0 auto;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 22px;
    }

    .logo {
      display: inline-flex;
      align-items: center;
      gap: 11px;
      color: var(--marfil);
      text-decoration: none;
      font-weight: 900;
      letter-spacing: 0.04em;
    }

    .logo-marca {
      width: 40px;
      height: 40px;
      display: grid;
      place-items: center;
      border: 1px solid rgba(255,255,255,.35);
      border-radius: 9px;
      color: var(--marfil);
      background: linear-gradient(145deg, rgba(28,111,189,.52), rgba(225,132,27,.35));
      box-shadow: inset 0 1px 0 rgba(255,255,255,.3), 0 8px 24px rgba(0,0,0,.2);
      font-size: 20px;
    }

    nav {
      display: flex;
      align-items: center;
      justify-content: flex-end;
      gap: 5px;
    }

    nav a {
      padding: 10px 11px;
      border-radius: 6px;
      color: var(--marfil);
      text-decoration: none;
      font-size: 12px;
      font-weight: 900;
      position: relative;
      transition: color 180ms ease, background 180ms ease, transform 180ms ease;
    }

    nav a:hover,
    nav a:focus-visible {
      color: var(--carbon);
      background: var(--marfil-suave);
      outline: none;
      transform: translateY(-1px);
    }

    .menu-boton {
      width: 48px;
      height: 48px;
      display: none;
      place-items: center;
      padding: 0;
      border: 1px solid rgba(255, 255, 255, 0.28);
      border-radius: 7px;
      color: var(--marfil);
      background: transparent;
      font-size: 23px;
      cursor: pointer;
    }

    .hero {
      min-height: calc(100vh - 74px);
      display: grid;
      align-items: center;
      color: var(--marfil);
      position: relative;
      isolation: isolate;
      overflow: hidden;
      background:
        radial-gradient(circle at 78% 16%, rgba(28,111,189,.34), transparent 28%),
        radial-gradient(circle at 88% 82%, rgba(225,132,27,.2), transparent 30%),
        linear-gradient(120deg, rgba(17,19,21,.99), rgba(31,43,52,.96) 56%, rgba(46,52,57,.92));
    }

    .hero::before { content: ""; position: absolute; z-index: -1; inset: 0; opacity: .22; background-image: linear-gradient(rgba(255,255,255,.08) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.08) 1px, transparent 1px); background-size: 54px 54px; mask-image: linear-gradient(to right, transparent, #000 45%, #000); }
    .hero::after { content: ""; position: absolute; z-index: -1; width: 430px; height: 430px; right: -210px; top: 12%; border: 1px solid rgba(255,255,255,.15); border-radius: 50%; box-shadow: 0 0 0 70px rgba(28,111,189,.04), 0 0 0 140px rgba(225,132,27,.025); }

    .hero-grid {
      display: grid;
      grid-template-columns: 1.04fr 0.96fr;
      align-items: center;
      gap: 48px;
    }

    .etiqueta {
      width: fit-content;
      margin-bottom: 20px;
      padding: 8px 12px;
      border: 1px solid rgba(255, 255, 255, 0.28);
      border-radius: 99px;
      color: var(--marfil-suave);
      background: rgba(255, 255, 255, 0.08);
      font-size: 12px;
      font-weight: 900;
      letter-spacing: 0.08em;
    }

    h1 {
      max-width: 780px;
      margin-bottom: 22px;
      color: var(--marfil);
      font-size: clamp(45px, 6.6vw, 78px);
      line-height: 0.98;
      letter-spacing: -0.05em;
    }

    h1 strong { color: transparent; background: linear-gradient(100deg, #bfdcff, #fff0cf 48%, #f3a64c); background-clip: text; -webkit-background-clip: text; }

    .hero-texto {
      max-width: 700px;
      color: var(--marfil-suave);
      font-size: clamp(18px, 2vw, 22px);
      font-weight: 700;
    }

    .hero-texto strong { padding: 2px 6px; border-radius: 5px; color: #fff1d8; background: rgba(225,132,27,.24); box-shadow: inset 0 0 0 1px rgba(255,196,114,.25); }

    .acciones {
      margin-top: 30px;
      display: flex;
      flex-wrap: wrap;
      gap: 12px;
    }

    .boton {
      min-height: 52px;
      padding: 14px 20px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      border: 1px solid rgba(255,255,255,.55);
      border-radius: 9px;
      color: var(--carbon);
      background: linear-gradient(120deg, var(--marfil), #ffe4ba);
      text-decoration: none;
      font-weight: 900;
      cursor: pointer;
      transition: transform 180ms ease, box-shadow 180ms ease;
    }

    .boton:hover { transform: translateY(-2px); box-shadow: 0 14px 30px rgba(0, 0, 0, 0.25); }
    .boton.secundario { color: var(--marfil); border-color: rgba(151,203,255,.42); background: rgba(28,111,189,.12); backdrop-filter: blur(8px); }

    .dashboard-mini {
      padding: 22px;
      border: 1px solid rgba(255, 255, 255, 0.2);
      border-radius: 15px;
      background: linear-gradient(145deg, rgba(255,255,255,.13), rgba(255,255,255,.065));
      box-shadow: 0 28px 70px rgba(0,0,0,.3), inset 0 1px 0 rgba(255,255,255,.18);
      backdrop-filter: blur(14px);
      transform: rotate(1deg);
    }

    .dashboard-mini-cabecera {
      margin-bottom: 16px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
      color: var(--marfil);
      font-weight: 900;
    }

    .estado {
      padding: 6px 9px;
      border-radius: 99px;
      color: var(--carbon);
      background: var(--marfil-suave);
      font-size: 10px;
    }

    .mini-kpis {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 10px;
    }

    .mini-kpi {
      padding: 15px;
      border-radius: 9px;
      color: var(--carbon);
      background: var(--marfil);
    }

    .mini-kpi span { display: block; color: var(--gris); font-size: 11px; font-weight: 900; }
    .mini-kpi strong { display: block; margin-top: 6px; font-size: 21px; }

    .mini-grafico {
      margin-top: 12px;
      padding: 14px;
      border-radius: 9px;
      background: var(--marfil);
    }

    .mini-grafico svg { width: 100%; height: auto; display: block; }

    .titulo-seccion {
      max-width: 800px;
      margin-bottom: 34px;
    }

    .titulo-seccion small {
      display: block;
      margin-bottom: 9px;
      color: var(--naranja-oscuro);
      font-size: 12px;
      font-weight: 900;
      letter-spacing: 0.1em;
    }

    h2 {
      margin-bottom: 14px;
      color: var(--carbon);
      font-size: clamp(32px, 4.5vw, 52px);
      line-height: 1.04;
      letter-spacing: -0.04em;
    }

    .titulo-seccion p {
      color: #4b5560;
      font-size: 18px;
    }

    .titulo-destacado {
      position: relative;
      isolation: isolate;
      overflow: hidden;
      width: fit-content;
      max-width: 100%;
      padding: 13px 20px;
      border: 1px solid rgba(255,255,255,.36);
      border-radius: 14px;
      color: #fff8ec;
      background: linear-gradient(125deg, rgba(18,96,178,.9) 0%, rgba(21,59,95,.92) 35%, rgba(24,26,28,.94) 58%, rgba(225,132,27,.92) 100%);
      box-shadow: 0 16px 38px rgba(18,34,50,.18), inset 0 1px 0 rgba(255,255,255,.2);
      text-shadow: 0 1px 8px rgba(0,0,0,.3);
    }

    .titulo-destacado::before {
      content: "";
      position: absolute;
      z-index: -1;
      inset: -85% -30%;
      background: linear-gradient(110deg, transparent 32%, rgba(255,255,255,.2) 48%, transparent 64%);
      transform: translateX(-45%);
      animation: brilloAviso 7s ease-in-out infinite;
    }

    .titulo-destacado::after {
      content: "";
      position: absolute;
      z-index: -1;
      width: 130px;
      height: 130px;
      right: -54px;
      bottom: -84px;
      border-radius: 50%;
      background: rgba(255,190,86,.32);
      filter: blur(3px);
    }

    .servicio-principal {
      display: grid;
      grid-template-columns: 0.85fr 1.15fr;
      gap: 26px;
    }

    .agente-identidad,
    .capacidades {
      padding: 30px;
      border-radius: 13px;
      box-shadow: var(--sombra);
    }

    .agente-identidad {
      color: var(--marfil);
      background: radial-gradient(circle at 90% 10%, rgba(28,111,189,.3), transparent 35%), linear-gradient(145deg, var(--carbon), var(--grafito));
      border-left: 7px solid var(--naranja);
    }

    .icono-grande {
      width: 68px;
      height: 68px;
      margin-bottom: 24px;
      display: grid;
      place-items: center;
      border-radius: 16px;
      color: var(--carbon);
      background: var(--marfil-suave);
    }

    .icono-grande svg,
    .fuente-icono svg {
      width: 36px;
      height: 36px;
      fill: none;
      stroke: currentColor;
      stroke-width: 2;
      stroke-linecap: round;
      stroke-linejoin: round;
    }

    .agente-identidad h3 { color: var(--marfil); font-size: 31px; }
    .agente-identidad p { color: var(--marfil-suave); font-weight: 700; }

    .capacidades { background: linear-gradient(145deg, var(--marfil), #fff); }
    .capacidades-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
    .capacidad { position: relative; isolation: isolate; overflow: hidden; padding: 18px; border: 1px solid rgba(255,255,255,.32); border-radius: 12px; color: #fff8ec; background: linear-gradient(135deg, rgba(18,96,178,.88), rgba(21,59,95,.9) 42%, rgba(225,132,27,.84)); box-shadow: 0 14px 30px rgba(18,34,50,.14), inset 0 1px 0 rgba(255,255,255,.18); transition: transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease; }
    .capacidad::before { content: ""; position: absolute; z-index: -1; inset: -90% -35%; background: linear-gradient(110deg, transparent 32%, rgba(255,255,255,.18) 48%, transparent 64%); transform: translateX(-46%); animation: brilloAviso 8s ease-in-out infinite; }
    .capacidad::after { content: ""; position: absolute; z-index: -1; width: 94px; height: 94px; right: -42px; bottom: -58px; border-radius: 50%; background: rgba(255,190,86,.25); filter: blur(3px); }
    .capacidad strong { display: block; margin-bottom: 6px; color: #fff2d8; text-shadow: 0 1px 7px rgba(0,0,0,.28); }
    .capacidad p { margin: 0; color: rgba(255,255,255,.9); font-size: 14px; text-shadow: 0 1px 5px rgba(0,0,0,.24); }

    .fuentes-seccion { background: linear-gradient(180deg, var(--marfil-suave), #f7f3eb); }
    .fuentes-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
    .mensaje-base-datos { position: relative; isolation: isolate; overflow: hidden; padding: 16px 18px; border: 1px solid rgba(255,255,255,.36); border-radius: 12px; color: #fff8ec !important; background: linear-gradient(125deg, rgba(18,96,178,.9) 0%, rgba(21,59,95,.92) 35%, rgba(24,26,28,.94) 58%, rgba(225,132,27,.92) 100%); box-shadow: 0 14px 34px rgba(18,34,50,.18), inset 0 1px 0 rgba(255,255,255,.2); font-weight: 900; text-shadow: 0 1px 7px rgba(0,0,0,.28); }
    .mensaje-base-datos::before { content: ""; position: absolute; z-index: -1; inset: -85% -30%; background: linear-gradient(110deg, transparent 32%, rgba(255,255,255,.2) 48%, transparent 64%); transform: translateX(-45%); animation: brilloAviso 7s ease-in-out infinite; }
    .mensaje-base-datos::after { content: ""; position: absolute; z-index: -1; width: 120px; height: 120px; right: -50px; bottom: -78px; border-radius: 50%; background: rgba(255,190,86,.33); filter: blur(3px); }
    .fuente-card { position: relative; overflow: hidden; padding: 26px; border: 1px solid var(--borde); border-radius: 14px; background: rgba(255,255,255,.9); box-shadow: var(--sombra-suave); transition: transform 200ms ease, box-shadow 200ms ease; }
    .fuente-card::after { content: ""; position: absolute; width: 100px; height: 100px; right: -48px; bottom: -55px; border-radius: 50%; background: rgba(225,132,27,.1); }
    .fuente-icono { width: 54px; height: 54px; margin-bottom: 18px; display: grid; place-items: center; border-radius: 13px; color: var(--marfil); background: linear-gradient(145deg, var(--azul-profundo), var(--grafito)); box-shadow: 0 10px 22px rgba(21,59,95,.22); }
    .fuente-card h3 { margin-bottom: 9px; color: var(--carbon); font-size: 23px; }
    .fuente-card p { margin: 0; color: #56616a; }
    .fuente-estado { width: fit-content; margin-bottom: 16px; padding: 6px 9px; display: block; border-radius: 99px; font-size: 9px; font-weight: 900; letter-spacing: .055em; }
    .fuente-estado.demo { color: #174c35; background: #dff3e8; border: 1px solid rgba(46,139,87,.22); }
    .fuente-estado.personalizado { color: #7d3d07; background: #fff0d9; border: 1px solid rgba(225,132,27,.3); }
    .fuente-card.especializada { border-color: rgba(225,132,27,.32); background: linear-gradient(145deg, #fffdf8, #fff5e6); }
    .seguridad-datos { position: relative; z-index: 1; margin-top: 17px; padding: 13px 14px; border: 1px solid rgba(28,111,189,.18); border-left: 4px solid var(--azul); border-radius: 9px; background: rgba(28,111,189,.065); }
    .seguridad-datos strong { display: block; margin-bottom: 5px; color: var(--azul-profundo); font-size: 10px; text-transform: uppercase; letter-spacing: .055em; }
    .seguridad-datos p { color: #53636f; font-size: 10px; line-height: 1.55; }

    .oscuro {
      color: var(--marfil);
      background: radial-gradient(circle at 16% 10%, rgba(28,111,189,.24), transparent 28%), radial-gradient(circle at 88% 90%, rgba(225,132,27,.16), transparent 25%), linear-gradient(135deg, var(--carbon), var(--grafito));
    }

    .oscuro h2,
    .oscuro .titulo-seccion small,
    .oscuro .titulo-seccion p { color: var(--marfil); }

    .proceso-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; counter-reset: proceso; }
    .paso { position: relative; min-height: 220px; padding: 58px 22px 22px; border: 1px solid rgba(255,255,255,.18); border-radius: 12px; background: linear-gradient(145deg, rgba(255,255,255,.095), rgba(255,255,255,.045)); backdrop-filter: blur(8px); transition: transform 200ms ease, border-color 200ms ease, background 200ms ease; }
    .paso::before { counter-increment: proceso; content: counter(proceso); position: absolute; top: 18px; left: 22px; width: 30px; height: 30px; display: grid; place-items: center; border-radius: 8px; color: var(--blanco); background: linear-gradient(145deg, var(--azul), var(--naranja)); font-weight: 900; box-shadow: 0 7px 18px rgba(0,0,0,.22); }
    .paso h3 { color: var(--marfil); }
    .paso p { margin: 0; color: var(--marfil-suave); }

    .demo-seccion { background: radial-gradient(circle at 95% 8%, rgba(225,132,27,.08), transparent 24%), radial-gradient(circle at 4% 76%, rgba(28,111,189,.07), transparent 23%), var(--humo); }
    .demo-layout { width: 100%; display: grid; grid-template-columns: minmax(0, .88fr) minmax(0, 1.12fr); gap: 24px; align-items: start; }
    .demo-layout > * { min-width: 0; max-width: 100%; }
    .formulario { padding: 28px; border: 1px solid rgba(255,255,255,.09); border-radius: 15px; background: radial-gradient(circle at 100% 0, rgba(28,111,189,.28), transparent 28%), linear-gradient(145deg, var(--carbon), #252c31); box-shadow: 0 24px 65px rgba(17,19,21,.2); }
    .campos { display: grid; grid-template-columns: repeat(2, 1fr); gap: 15px; }
    .campo { display: grid; gap: 7px; }
    .campo.completo { grid-column: 1 / -1; }
    .campo.oculto { display: none; }
    .campo-ayuda { color: rgba(255,255,255,.68); font-size: 10px; line-height: 1.5; }
    .opciones-alcance { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
    .opcion-alcance { min-height: 72px; padding: 13px 14px; border: 1px solid rgba(255,255,255,.18); border-radius: 10px; color: rgba(255,255,255,.78); background: rgba(255,255,255,.055); font: inherit; text-align: left; cursor: pointer; transition: transform 170ms ease, border-color 170ms ease, background 170ms ease; }
    .opcion-alcance strong, .opcion-alcance span { display: block; }
    .opcion-alcance strong { color: var(--marfil); font-size: 12px; }
    .opcion-alcance span { margin-top: 4px; color: var(--gris-claro); font-size: 9px; }
    .opcion-alcance:hover { transform: translateY(-2px); border-color: rgba(255,190,108,.42); }
    .opcion-alcance.activa { border-color: var(--naranja); color: var(--blanco); background: linear-gradient(135deg, rgba(28,111,189,.28), rgba(225,132,27,.2)); box-shadow: 0 0 0 3px rgba(225,132,27,.09); }
    .campo-especifico { padding: 14px; border: 1px solid rgba(151,203,255,.2); border-radius: 10px; background: rgba(28,111,189,.07); transition: opacity 180ms ease, border-color 180ms ease, background 180ms ease; }
    .campo-especifico.inactivo { opacity: .55; }
    .campo-especifico:not(.inactivo) { border-color: rgba(225,132,27,.42); background: rgba(225,132,27,.065); }
    .oculto-por-alcance { display: none !important; }
    label { color: var(--marfil-suave); font-size: 12px; font-weight: 900; }
    input, select, textarea { width: 100%; padding: 13px 14px; border: 2px solid transparent; border-radius: 7px; color: var(--carbon); background: var(--marfil); font: inherit; font-weight: 700; outline: none; }
    select:disabled { opacity: 1; color: var(--azul-profundo); background: #eef7ff; cursor: default; }
    input:focus, select:focus, textarea:focus { border-color: var(--naranja); box-shadow: 0 0 0 4px rgba(225,132,27,.17); }
    textarea { min-height: 116px; resize: vertical; }
    .zona-archivo { padding: 16px; border: 2px dashed rgba(255,190,108,.42); border-radius: 10px; background: rgba(255,255,255,.035); }
    .zona-archivo p { margin: 8px 0 0; color: var(--gris-claro); font-size: 12px; }
    .archivo-resumen { margin-top: 8px; color: var(--marfil-suave); font-size: 12px; font-weight: 900; }
    .archivo-resumen.correcto { color: #a9ebc2; }
    .archivo-resumen.error { color: #ffc1b8; }
    .diagnostico-archivo[hidden] { display: none; }
    .diagnostico-archivo { margin-top: 13px; padding: 14px; border: 1px solid rgba(169,235,194,.3); border-radius: 10px; color: var(--marfil-suave); background: rgba(11,28,38,.48); }
    .diagnostico-titulo { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
    .diagnostico-titulo strong { color: #a9ebc2; font-size: 13px; }
    .diagnostico-titulo span { padding: 4px 7px; border-radius: 99px; color: #dff9e8; background: rgba(79,155,115,.25); font-size: 9px; font-weight: 900; }
    .columnas-detectadas { margin: 12px 0 0; padding: 0; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 6px; list-style: none; }
    .columnas-detectadas li { min-width: 0; padding: 8px 9px; border-radius: 7px; background: rgba(255,255,255,.06); }
    .columnas-detectadas span, .columnas-detectadas strong { display: block; overflow-wrap: anywhere; }
    .columnas-detectadas span { color: var(--gris-claro); font-size: 8px; font-weight: 900; text-transform: uppercase; }
    .columnas-detectadas strong { margin-top: 3px; color: var(--blanco); font-size: 11px; }
    .advertencias-datos { margin-top: 10px; padding: 10px; border-left: 4px solid #e8ad55; border-radius: 7px; color: #fff2d7; background: rgba(225,132,27,.13); font-size: 10px; }
    .advertencias-datos ul { margin: 6px 0 0; padding-left: 17px; line-height: 1.55; }
    .datos-correctos { margin: 10px 0 0 !important; color: #bfeccb !important; font-size: 10px !important; }
    .enviar { width: 100%; min-height: 55px; margin-top: 17px; border: 0; border-radius: 9px; color: var(--carbon); background: linear-gradient(110deg, #fff5e5, #ffc978); box-shadow: 0 12px 25px rgba(225,132,27,.2); font-size: 15px; font-weight: 900; cursor: pointer; transition: transform 180ms ease, box-shadow 180ms ease; }
    .enviar:hover { transform: translateY(-2px); box-shadow: 0 16px 32px rgba(225,132,27,.3); }
    .capacidades-personalizadas { margin-top: 16px; padding: 17px; border: 1px solid rgba(151,203,255,.24); border-radius: 11px; color: var(--marfil); background: linear-gradient(135deg, rgba(28,111,189,.14), rgba(255,255,255,.045) 48%, rgba(225,132,27,.11)); }
    .capacidades-personalizadas > strong { display: block; margin-bottom: 11px; color: #ffe2b7; font-size: 12px; text-transform: uppercase; letter-spacing: .055em; }
    .capacidades-personalizadas ul { margin: 0; padding: 0; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px 12px; list-style: none; }
    .capacidades-personalizadas li { position: relative; padding-left: 17px; color: rgba(255,255,255,.88); font-size: 11px; line-height: 1.45; }
    .capacidades-personalizadas li::before { content: ""; position: absolute; left: 0; top: .46em; width: 7px; height: 7px; border-radius: 50%; background: linear-gradient(145deg, var(--azul), var(--naranja)); box-shadow: 0 0 0 3px rgba(255,255,255,.06); }
    .mensaje { min-height: 24px; margin-top: 11px; color: var(--marfil-suave); font-weight: 900; }
    .mensaje.alerta { padding: 11px; border-radius: 7px; color: #332600; background: #fff3cd; }
    .privacidad { margin: 10px 0 0; color: var(--gris-claro); font-size: 12px; }

    .reporte {
      width: 100%;
      min-width: 0;
      max-width: 100%;
      overflow: hidden;
      padding: 26px;
      border: 1px solid rgba(28,111,189,.12);
      border-radius: 15px;
      color: var(--carbon);
      background: linear-gradient(155deg, #fffdf8, var(--marfil));
      box-shadow: 0 25px 65px rgba(28,52,71,.14);
    }

    .reporte-cabecera { display: flex; align-items: start; justify-content: space-between; gap: 16px; }
    .reporte-cabecera h3 { margin-bottom: 5px; font-size: 25px; }
    .reporte-cabecera p { color: var(--gris); font-size: 13px; }
    .muestra { flex: 0 0 auto; padding: 6px 9px; border-radius: 99px; color: var(--marfil); background: var(--gris); font-size: 10px; font-weight: 900; }
    .kpis { display: grid; grid-template-columns: repeat(3, 1fr); gap: 9px; margin-top: 16px; }
    .kpi { position: relative; overflow: hidden; padding: 13px; border: 1px solid rgba(17,19,21,.07); border-radius: 10px; background: rgba(255,255,255,.92); border-top: 4px solid var(--azul); box-shadow: 0 8px 20px rgba(28,52,71,.07); font: inherit; text-align: left; cursor: pointer; transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease; }
    .kpi:nth-child(3n+2) { border-top-color: var(--naranja); }
    .kpi:nth-child(3n) { border-top-color: var(--verde); }
    .kpi.unidades { border-top-color: var(--naranja); background: #fff8ed; }
    .kpi span { display: block; color: var(--gris); font-size: 10px; font-weight: 900; text-transform: uppercase; }
    .kpi strong { display: block; margin-top: 7px; overflow-wrap: anywhere; font-size: 16px; }
    .kpi em { margin-top: 9px; display: block; color: var(--azul-profundo); font-size: 9px; font-style: normal; font-weight: 900; opacity: .68; }
    .kpi:not(:disabled):hover, .kpi:not(:disabled):focus-visible { z-index: 2; border-color: rgba(28,111,189,.32); box-shadow: 0 14px 28px rgba(28,52,71,.14); outline: none; transform: translateY(-3px); }
    .kpi:disabled { cursor: not-allowed; }
    .kpi:disabled em { display: none; }
    .detalle-kpi[hidden] { display: none; }
    .detalle-kpi { padding-top: 4px; animation: detalleEntrada 340ms ease both; }
    .volver-resumen { min-height: 42px; margin-bottom: 20px; padding: 9px 13px; border: 1px solid rgba(28,111,189,.2); border-radius: 9px; color: var(--azul-profundo); background: #edf6ff; font-weight: 900; cursor: pointer; transition: transform 160ms ease, background 160ms ease; }
    .volver-resumen:hover { background: #dfefff; transform: translateX(-3px); }
    .detalle-kpi-cabecera { padding: 22px; display: flex; align-items: flex-start; justify-content: space-between; gap: 24px; border-radius: 13px; color: var(--blanco); background: radial-gradient(circle at 90% 15%, rgba(225,132,27,.4), transparent 30%), linear-gradient(125deg, var(--azul-profundo), var(--carbon)); }
    .detalle-kpi-cabecera span { color: #ffdca8; font-size: 9px; font-weight: 900; letter-spacing: .1em; }
    .detalle-kpi-cabecera h4 { margin: 5px 0 7px; color: var(--blanco); font-size: clamp(24px, 3.5vw, 39px); line-height: 1.02; }
    .detalle-kpi-cabecera p { max-width: 650px; margin: 0; color: rgba(255,255,255,.78); font-size: 12px; }
    .detalle-kpi-cabecera > strong { flex: 0 0 auto; max-width: 250px; padding: 10px 13px; border: 1px solid rgba(255,255,255,.2); border-radius: 10px; color: #fff1da; background: rgba(255,255,255,.1); font-size: clamp(17px, 2vw, 25px); text-align: right; }
    .detalle-metricas { margin-top: 12px; display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 9px; }
    .detalle-metrica { padding: 13px; border: 1px solid rgba(17,19,21,.08); border-radius: 10px; background: var(--blanco); }
    .detalle-metrica span { display: block; color: var(--gris); font-size: 9px; font-weight: 900; text-transform: uppercase; }
    .detalle-metrica strong { display: block; margin-top: 5px; color: var(--carbon); font-size: 15px; overflow-wrap: anywhere; }
    .detalle-grafico { margin-top: 12px; padding: 18px; display: grid; gap: 11px; border: 1px solid rgba(17,19,21,.08); border-radius: 12px; background: rgba(255,255,255,.92); }
    .detalle-barra { display: grid; grid-template-columns: minmax(95px, .7fr) minmax(130px, 2fr) minmax(105px, .8fr); align-items: center; gap: 10px; }
    .detalle-barra > span { overflow: hidden; color: var(--grafito); font-size: 10px; font-weight: 900; text-overflow: ellipsis; white-space: nowrap; }
    .detalle-barra-track { height: 12px; overflow: hidden; border-radius: 99px; background: #e6eaed; }
    .detalle-barra-fill { height: 100%; min-width: 4px; border-radius: inherit; background: linear-gradient(90deg, var(--azul), #71b3ed); transform-origin: left center; animation: barraDetalle 520ms ease both; }
    .detalle-barra.destacada .detalle-barra-fill { background: linear-gradient(90deg, var(--naranja), #ffc06d); box-shadow: 0 0 15px rgba(225,132,27,.3); }
    .detalle-barra > strong { color: var(--carbon); font-size: 10px; text-align: right; }
    .detalle-explicacion { margin-top: 12px; padding: 17px 18px; border-left: 5px solid var(--naranja); border-radius: 10px; background: #fff6e8; }
    .detalle-explicacion h5 { margin: 0 0 9px; color: var(--carbon); font-size: 13px; }
    .detalle-explicacion ul { margin: 0; padding-left: 18px; color: #59646c; font-size: 11px; line-height: 1.65; }
    .reporte.modo-detalle > .reporte-cabecera, .reporte.modo-detalle > .kpis, .reporte.modo-detalle > .categorias-destacadas, .reporte.modo-detalle > .graficos, .reporte.modo-detalle > .reporte-nota, .reporte.modo-detalle > .aviso-demo, .reporte.modo-detalle > .boton-pdf { display: none; }
    @keyframes detalleEntrada { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: none; } }
    @keyframes barraDetalle { from { transform: scaleX(0); } to { transform: scaleX(1); } }
    .categorias-destacadas { margin-top: 12px; display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; }
    .categoria-destacada { padding: 15px; border-radius: 10px; color: var(--marfil); background: radial-gradient(circle at 100% 0, rgba(28,111,189,.28), transparent 40%), linear-gradient(145deg, var(--grafito), var(--carbon)); border-left: 5px solid var(--naranja); box-shadow: 0 12px 28px rgba(17,19,21,.14); }
    .categoria-destacada span { display: block; color: var(--gris-claro); font-size: 10px; font-weight: 900; text-transform: uppercase; }
    .categoria-destacada strong { display: block; margin-top: 5px; overflow-wrap: anywhere; font-size: 18px; }
    .categoria-destacada small { display: block; margin-top: 4px; color: var(--marfil-suave); font-size: 11px; line-height: 1.7; white-space: pre-line; }
    .graficos { width: 100%; display: grid; grid-template-columns: minmax(0, 1.25fr) minmax(0, .75fr); gap: 12px; margin-top: 14px; perspective: 1200px; }
    .graficos > * { min-width: 0; max-width: 100%; }
    .grafico { --cursor-x: 50%; --cursor-y: 50%; --giro-x: 0deg; --giro-y: 0deg; position: relative; min-width: 0; max-width: 100%; padding: 15px; overflow: hidden; border: 1px solid transparent; border-radius: 9px; background: var(--blanco); transform: rotateX(var(--giro-x)) rotateY(var(--giro-y)) translateZ(0); transform-style: preserve-3d; transition: transform 180ms ease, border-color 220ms ease, box-shadow 220ms ease; will-change: transform; }
    .grafico::before { content: ""; position: absolute; z-index: 3; inset: 0; pointer-events: none; opacity: 0; background: radial-gradient(circle 150px at var(--cursor-x) var(--cursor-y), rgba(225,132,27,.19), rgba(28,111,189,.08) 42%, transparent 72%); transition: opacity 220ms ease; }
    .grafico.cursor-activo { border-color: rgba(225,132,27,.36); box-shadow: 0 18px 38px rgba(25,38,50,.16); }
    .grafico.cursor-activo::before { opacity: 1; }
    .grafico.pulso { animation: pulsoGrafico 360ms ease; }
    .grafico h4 { margin: 0; }
    .grafico p { margin: 4px 0 0; color: var(--gris); font-size: 11px; }
    .grafico svg { width: 100%; height: auto; margin-top: 12px; display: block; }
    .barras-meses { height: 220px; margin-top: 16px; padding: 8px 4px 0; display: flex; align-items: stretch; gap: 7px; overflow-x: auto; border-bottom: 2px solid var(--gris-claro); }
    .barra-mes { flex: 1 0 88px; min-width: 88px; max-width: 104px; height: 100%; display: flex; flex-direction: column; justify-content: flex-end; gap: 5px; text-align: center; transform-origin: center bottom; transition: transform 180ms ease, filter 180ms ease; }
    .barra-mes strong { color: var(--carbon); font-size: 9px; white-space: nowrap; transition: color 180ms ease, transform 180ms ease; }
    .barra-mes i { width: 100%; min-height: 8px; display: block; border-radius: 6px 6px 0 0; box-shadow: 0 5px 12px rgba(17,19,21,.12); transform-origin: center bottom; transition: filter 180ms ease, transform 180ms ease, box-shadow 180ms ease; }
    .barra-mes small { min-height: 26px; display: block; overflow: hidden; color: var(--gris); font-size: 9px; font-weight: 900; line-height: 1.1; }
    .barra-mes.alto i { background: linear-gradient(#78a982, #4f8a5b); }
    .barra-mes.medio i { background: linear-gradient(#e8ad55, #d17a1f); }
    .barra-mes.bajo i { background: linear-gradient(#d87973, #b44743); }
    .leyenda-meses { margin-top: 10px; display: flex; flex-wrap: wrap; gap: 10px; color: var(--gris); font-size: 10px; font-weight: 900; }
    .leyenda-meses span::before { content: ""; width: 9px; height: 9px; margin-right: 5px; display: inline-block; border-radius: 50%; }
    .leyenda-meses .alto::before { background: #4f8a5b; }
    .leyenda-meses .medio::before { background: #d17a1f; }
    .leyenda-meses .bajo::before { background: #b44743; }
    .barras { width: 100%; max-width: 100%; height: 210px; margin-top: 16px; padding: 8px 4px 0; display: flex; align-items: stretch; justify-content: space-around; gap: 10px; overflow-x: auto; border-bottom: 2px solid var(--gris-claro); }
    .barra { flex: 1 0 92px; min-width: 92px; max-width: 110px; height: 100%; display: flex; flex-direction: column; justify-content: flex-end; align-items: stretch; gap: 5px; color: var(--gris); text-align: center; font-size: 9px; font-weight: 900; transform-origin: center bottom; transition: transform 180ms ease, filter 180ms ease; }
    .barra i { width: 100%; min-height: 8px; display: block; border-radius: 6px 6px 0 0; background: linear-gradient(var(--gris-claro), var(--carbon)); box-shadow: 0 5px 12px rgba(17,19,21,.14); transform-origin: center bottom; transition: filter 180ms ease, transform 180ms ease, box-shadow 180ms ease; }
    .barra-mes:hover, .barra-mes.cursor-cerca, .barra:hover, .barra.cursor-cerca { z-index: 4; transform: translateY(-7px) scale(1.035); filter: saturate(1.18); }
    .barra-mes:hover i, .barra-mes.cursor-cerca i, .barra:hover i, .barra.cursor-cerca i { transform: scaleX(1.045); filter: brightness(1.1); box-shadow: 0 10px 20px rgba(17,19,21,.23), 0 0 16px rgba(225,132,27,.18); }
    .barra-mes:hover strong, .barra-mes.cursor-cerca strong, .barra:hover .barra-valor, .barra.cursor-cerca .barra-valor { color: var(--naranja-oscuro); transform: translateY(-2px) scale(1.06); }
    .barra-valor { color: var(--carbon); font-size: 9px; white-space: nowrap; }
    .barra-nombre { min-height: 32px; display: -webkit-box; overflow: hidden; color: var(--gris); line-height: 1.15; -webkit-box-orient: vertical; -webkit-line-clamp: 2; }
    .boton-pdf { width: 100%; min-height: 49px; margin-top: 14px; border: 1px solid rgba(255,255,255,.12); border-radius: 9px; color: var(--marfil); background: linear-gradient(105deg, var(--azul-profundo), var(--carbon) 52%, var(--naranja-oscuro)); box-shadow: 0 12px 28px rgba(21,59,95,.18); font-weight: 900; cursor: pointer; transition: transform 180ms ease, box-shadow 180ms ease; }
    .boton-pdf:not(:disabled):hover { transform: translateY(-2px); box-shadow: 0 17px 34px rgba(21,59,95,.27); }
    .boton-pdf:disabled { opacity: .45; cursor: not-allowed; }
    .reporte.generado { animation: reporte-listo 520ms ease both; outline: 4px solid rgba(102, 123, 112, 0.22); }
    .reporte-nota { margin: 12px 0 0; padding: 10px 12px; border-radius: 7px; color: var(--grafito); background: var(--humo); font-size: 12px; font-weight: 700; }
    .aviso-demo { position: relative; isolation: isolate; overflow: hidden; margin-top: 12px; padding: 18px 19px; border: 1px solid rgba(255,255,255,.42); border-radius: 12px; color: var(--blanco); background: linear-gradient(125deg, rgba(18,96,178,.88) 0%, rgba(20,40,62,.91) 34%, rgba(24,26,28,.94) 56%, rgba(225,132,27,.9) 100%); box-shadow: 0 12px 30px rgba(18,34,50,.2), inset 0 1px 0 rgba(255,255,255,.22); backdrop-filter: blur(12px); }
    .aviso-demo::before { content: ""; position: absolute; z-index: -1; inset: -80% -30%; background: linear-gradient(110deg, transparent 32%, rgba(255,255,255,.2) 48%, transparent 64%); transform: translateX(-45%); animation: brilloAviso 7s ease-in-out infinite; }
    .aviso-demo::after { content: ""; position: absolute; z-index: -1; width: 120px; height: 120px; right: -45px; bottom: -75px; border-radius: 50%; background: rgba(255,190,86,.35); filter: blur(3px); }
    .aviso-demo strong { display: block; color: #fff2d8; font-size: 13px; text-transform: uppercase; letter-spacing: .055em; text-shadow: 0 2px 8px rgba(0,0,0,.28); }
    .aviso-demo p { margin: 7px 0 0; color: rgba(255,255,255,.94); font-size: 12px; line-height: 1.7; text-shadow: 0 1px 6px rgba(0,0,0,.3); }
    @keyframes brilloAviso { 0%, 22% { transform: translateX(-48%); } 60%, 100% { transform: translateX(48%); } }
    @keyframes pulsoGrafico { 0%, 100% { filter: brightness(1); } 45% { filter: brightness(1.07) saturate(1.12); } }
    @keyframes reporte-listo { from { opacity: .55; transform: translateY(16px) scale(.98); } to { opacity: 1; transform: none; } }

    .resultados-seccion { background: linear-gradient(180deg, var(--marfil-suave), #f5f0e6); }
    .resultados-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
    .resultado-grupo { grid-column: 1 / -1; margin-top: 18px; padding: 17px 20px; display: grid; grid-template-columns: auto auto 1fr; align-items: center; gap: 10px 16px; border: 1px solid rgba(17,19,21,.09); border-radius: 12px; background: rgba(255,255,255,.72); }
    .resultado-grupo:first-child { margin-top: 0; }
    .resultado-grupo span { padding: 6px 9px; border-radius: 99px; font-size: 9px; font-weight: 900; letter-spacing: .07em; }
    .resultado-grupo strong { color: var(--carbon); font-size: 14px; }
    .resultado-grupo p,
    .resultado-grupo p b { margin: 0; color: #111315 !important; font-size: 12px; font-weight: 900; }
    .grupo-basico { border-left: 6px solid #4f9b73; }
    .grupo-basico span { color: #174c35; background: #dff3e8; }
    .grupo-profesional { border-left: 6px solid var(--naranja); }
    .grupo-profesional span { color: #744006; background: #fff0d9; }
    .grupo-avanzado { border-left: 6px solid var(--azul); }
    .grupo-avanzado span { color: #17456d; background: #dceeff; }
    .resultado { position: relative; overflow: hidden; min-height: 170px; padding: 22px; border-radius: 12px; background: rgba(255,255,255,.9); border: 1px solid var(--borde); box-shadow: var(--sombra-suave); transition: transform 190ms ease, box-shadow 190ms ease; }
    .resultado::after { content: ""; position: absolute; width: 90px; height: 90px; right: -48px; bottom: -52px; border-radius: 50%; background: rgba(28,111,189,.08); }
    .resultado:nth-child(even)::after { background: rgba(225,132,27,.1); }
    .resultado-numero { width: 36px; height: 36px; margin-bottom: 18px; display: grid; place-items: center; border-radius: 10px; color: var(--marfil); background: linear-gradient(145deg, var(--azul-profundo), var(--naranja)); box-shadow: 0 8px 18px rgba(28,52,71,.2); font-weight: 900; }
    .resultado h3 { font-size: 17px; }
    .resultado p { margin: 0; color: var(--gris); font-size: 13px; }
    .resultado-plan { width: fit-content; margin: -3px 0 10px; padding: 5px 8px; display: block; border-radius: 99px; font-size: 8px; font-weight: 900; letter-spacing: .065em; }
    .resultado-plan.nivel-basico { color: #174c35; background: #dff3e8; }
    .resultado-plan.nivel-profesional { color: #744006; background: #fff0d9; }
    .resultado-plan.nivel-avanzado { color: #17456d; background: #dceeff; }
    .resultado.resultado-basico { border-color: rgba(38,160,103,.38); background: radial-gradient(circle at 8% 12%, rgba(106,230,162,.24), transparent 32%), linear-gradient(145deg, #f4fff8, #e2fff0 48%, #fff7e8); box-shadow: 0 18px 42px rgba(38,160,103,.15); }
    .resultado.resultado-basico::after { background: rgba(33,190,118,.2); }
    .resultado.resultado-basico .resultado-numero { background: linear-gradient(145deg, #1ba367, #26d07c 46%, var(--naranja)); box-shadow: 0 10px 24px rgba(38,160,103,.28); }
    .resultado.resultado-basico h3 { color: #0f5f3b; }
    .resultado.resultado-basico p { color: #214d3a; font-weight: 700; }
    .resultado.resultado-basico .nivel-basico { color: #063f27; background: linear-gradient(135deg, #bdf8d4, #ffe2b7); box-shadow: inset 0 0 0 1px rgba(38,160,103,.16); }
    .resultado ul { position: relative; z-index: 1; margin: 0; padding: 0; display: grid; gap: 7px; list-style: none; }
    .resultado li { position: relative; padding-left: 15px; color: var(--gris); font-size: 12px; line-height: 1.45; }
    .resultado li::before { content: ""; position: absolute; left: 0; top: .48em; width: 6px; height: 6px; border-radius: 50%; background: var(--naranja); }
    .resultado.detallado { border-color: rgba(28,111,189,.22); background: linear-gradient(145deg, rgba(255,255,255,.95), rgba(233,244,255,.72)); }
    .resultado.alerta-resultado { border-color: rgba(225,132,27,.32); background: linear-gradient(145deg, #fffdf8, #fff2df); }
    .resultado.resultado-profesional { border-color: rgba(225,132,27,.34); background: radial-gradient(circle at 8% 12%, rgba(255,196,96,.24), transparent 32%), linear-gradient(145deg, #fffaf0, #fff1d8 48%, #f3f8ff); box-shadow: 0 18px 42px rgba(177,101,18,.13); }
    .resultado.resultado-profesional::after { background: rgba(225,132,27,.18); }
    .resultado.resultado-profesional .resultado-numero { background: linear-gradient(145deg, #b95d0b, #df851f 50%, #1c6fbd); box-shadow: 0 10px 24px rgba(177,101,18,.24); }
    .resultado.resultado-profesional h3 { color: #744006; }
    .resultado.resultado-profesional p { color: #5f4828; font-weight: 700; }
    .resultado.resultado-profesional .nivel-profesional { color: #512d08; background: linear-gradient(135deg, #ffe0a6, #e6f3ff); box-shadow: inset 0 0 0 1px rgba(225,132,27,.16); }
    .resultado.resultado-avanzado { border-color: rgba(28,111,189,.34); background: radial-gradient(circle at 8% 12%, rgba(93,159,225,.22), transparent 32%), linear-gradient(145deg, #f4f9ff, #e7f1ff 48%, #f5edff); box-shadow: 0 18px 42px rgba(28,111,189,.13); }
    .resultado.resultado-avanzado::after { background: rgba(91,111,198,.17); }
    .resultado.resultado-avanzado .resultado-numero { background: linear-gradient(145deg, #174b76, #1c6fbd 50%, #7b61c8); box-shadow: 0 10px 24px rgba(28,111,189,.24); }
    .resultado.resultado-avanzado h3 { color: #17456d; }
    .resultado.resultado-avanzado p { color: #2d4960; font-weight: 700; }
    .resultado.resultado-avanzado .nivel-avanzado { color: #123958; background: linear-gradient(135deg, #cfe8ff, #eadcff); box-shadow: inset 0 0 0 1px rgba(28,111,189,.14); }

    .mensaje-impacto { position: relative; isolation: isolate; overflow: hidden; margin-top: 22px; padding: 23px 25px; border: 1px solid rgba(255,255,255,.28); border-radius: 14px; color: var(--blanco); background: radial-gradient(circle at 12% 20%, rgba(58,146,226,.55), transparent 34%), radial-gradient(circle at 90% 90%, rgba(225,132,27,.5), transparent 38%), linear-gradient(120deg, var(--azul-profundo), var(--carbon) 52%, #6f3b12); box-shadow: 0 20px 44px rgba(21,59,95,.2); }
    .mensaje-impacto::after { content: ""; position: absolute; z-index: -1; inset: 0; opacity: .2; background-image: linear-gradient(115deg, transparent 35%, rgba(255,255,255,.35) 50%, transparent 65%); transform: translateX(-70%); animation: brilloImpacto 7s ease-in-out infinite; }
    .mensaje-impacto span { display: block; margin-bottom: 5px; color: #ffdca8; font-size: 10px; font-weight: 900; letter-spacing: .14em; }
    .mensaje-impacto strong { display: block; max-width: 820px; color: #fff0d9; font-size: clamp(24px, 3.8vw, 42px); line-height: 1.06; letter-spacing: -.035em; text-wrap: balance; text-shadow: 0 2px 14px rgba(255,220,168,.18); }
    @keyframes brilloImpacto { 0%, 28% { transform: translateX(-70%); } 70%, 100% { transform: translateX(70%); } }

    .entrega { margin-top: 20px; padding: 22px; display: flex; align-items: center; justify-content: space-between; gap: 20px; border-radius: 10px; color: var(--marfil); background: var(--carbon); }
    .entrega strong { font-size: 20px; }
    .entrega p { margin: 4px 0 0; color: var(--marfil-suave); }
    .entrega-badges { min-width: 330px; display: grid; grid-template-columns: repeat(3, minmax(92px, 1fr)); gap: 8px; }
    .entrega-badges span { min-height: 68px; padding: 10px 8px; display: grid; place-items: center; border: 1px solid rgba(255,255,255,.22); border-radius: 10px; color: var(--carbon); background: linear-gradient(145deg, var(--marfil), #ffe5bc); font-size: 10px; font-weight: 900; line-height: 1.2; text-align: center; }

    .planes-seccion { background: radial-gradient(circle at 8% 12%, rgba(28,111,189,.1), transparent 26%), radial-gradient(circle at 92% 88%, rgba(225,132,27,.1), transparent 27%), #eef1f2; }
    .planes-titulo { max-width: 920px; }
    .planes-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; align-items: start; }
    .plan-card { position: relative; min-width: 0; padding: 25px; display: flex; flex-direction: column; border: 1px solid rgba(17,19,21,.11); border-radius: 16px; background: rgba(255,255,255,.93); box-shadow: 0 20px 48px rgba(28,52,71,.11); transition: transform 220ms ease, box-shadow 220ms ease, border-color 220ms ease; }
    .plan-card::before { content: ""; position: absolute; inset: 0 0 auto; height: 6px; border-radius: 16px 16px 0 0; background: var(--azul); }
    .plan-basico { border-color: rgba(38,160,103,.28); background: radial-gradient(circle at 8% 7%, rgba(106,230,162,.2), transparent 30%), linear-gradient(145deg, #f6fff9, #e9fff2 46%, #fff8ec); box-shadow: 0 20px 48px rgba(38,160,103,.12); }
    .plan-basico::before { background: linear-gradient(90deg, #1ba367, #26d07c, var(--naranja)); }
    .plan-profesional { border-color: rgba(225,132,27,.34); background: radial-gradient(circle at 8% 7%, rgba(255,196,96,.22), transparent 30%), linear-gradient(145deg, #fffaf0, #fff1d8 48%, #f3f8ff); box-shadow: 0 28px 65px rgba(177,101,18,.14); }
    .plan-profesional::before { background: linear-gradient(90deg, #b95d0b, var(--naranja), var(--azul)); }
    .plan-empresarial { border-color: rgba(28,111,189,.32); background: radial-gradient(circle at 8% 7%, rgba(93,159,225,.2), transparent 30%), linear-gradient(145deg, #f4f9ff, #e7f1ff 48%, #f5edff); box-shadow: 0 20px 48px rgba(28,111,189,.12); }
    .plan-empresarial::before { background: linear-gradient(90deg, #174b76, var(--azul), #7b61c8); }
    .plan-card.destacado { border-color: rgba(225,132,27,.42); box-shadow: 0 28px 65px rgba(28,52,71,.18); transform: translateY(-12px); }
    .plan-recomendado { position: absolute; top: -14px; right: 18px; padding: 7px 11px; border-radius: 99px; color: var(--carbon); background: linear-gradient(110deg, #fff0d6, #ffbd62); box-shadow: 0 8px 20px rgba(225,132,27,.25); font-size: 9px; font-weight: 900; letter-spacing: .07em; }
    .plan-cabecera { min-height: 145px; padding-top: 8px; }
    .plan-nivel { display: block; margin-bottom: 10px; color: var(--naranja-oscuro); font-size: 10px; font-weight: 900; letter-spacing: .08em; }
    .plan-cabecera h3 { margin-bottom: 9px; color: var(--carbon); font-size: clamp(25px, 2.5vw, 34px); line-height: 1.02; letter-spacing: -.035em; }
    .plan-cabecera p { margin: 0; color: var(--gris); font-size: 14px; }
    .plan-precios { margin: 18px 0; display: grid; gap: 8px; }
    .plan-precios div { padding: 12px 13px; border: 1px solid rgba(28,111,189,.1); border-radius: 10px; background: linear-gradient(135deg, rgba(28,111,189,.055), rgba(225,132,27,.055)); }
    .plan-basico .plan-precios div { border-color: rgba(38,160,103,.2); background: linear-gradient(135deg, rgba(38,160,103,.13), rgba(255,226,183,.42)); }
    .plan-profesional .plan-precios div { border-color: rgba(225,132,27,.22); background: linear-gradient(135deg, rgba(225,132,27,.14), rgba(207,232,255,.38)); }
    .plan-empresarial .plan-precios div { border-color: rgba(28,111,189,.2); background: linear-gradient(135deg, rgba(28,111,189,.12), rgba(234,220,255,.48)); }
    .plan-precios span { display: block; color: var(--gris); font-size: 9px; font-weight: 900; text-transform: uppercase; letter-spacing: .06em; }
    .plan-precios strong { display: block; margin-top: 3px; color: var(--carbon); font-size: 15px; line-height: 1.25; }
    .plan-basico .plan-cabecera h3, .plan-basico .plan-precios strong, .plan-basico .plan-incluye > strong { color: #0f5f3b; }
    .plan-profesional .plan-cabecera h3, .plan-profesional .plan-precios strong, .plan-profesional .plan-incluye > strong { color: #744006; }
    .plan-empresarial .plan-cabecera h3, .plan-empresarial .plan-precios strong, .plan-empresarial .plan-incluye > strong { color: #17456d; }
    .nota-implementacion { margin: -4px 0 18px; padding: 12px 13px; border-left: 4px solid var(--azul); border-radius: 8px; color: #59646c; background: rgba(28,111,189,.065); font-size: 10px; line-height: 1.55; }
    .nota-implementacion b { color: var(--azul-profundo); }
    .nota-implementacion p { margin: 6px 0 0; color: #59646c; font-size: 10px; }
    .nota-implementacion strong { color: var(--carbon); }
    .nota-implementacion small { margin-top: 7px; display: block; color: #77828a; font-size: 9px; font-style: italic; }
    .plan-empresarial .nota-implementacion { border-left-color: var(--naranja); background: rgba(225,132,27,.075); }
    .plan-incluye { min-height: 300px; }
    .plan-incluye > strong { display: block; margin-bottom: 11px; color: var(--carbon); font-size: 13px; }
    .plan-incluye ul { margin: 0; padding: 0; display: grid; gap: 9px; list-style: none; }
    .plan-incluye li { position: relative; padding-left: 20px; color: #4f5a63; font-size: 12px; line-height: 1.4; }
    .plan-incluye li::before { content: "✓"; position: absolute; left: 0; top: 0; color: var(--azul); font-weight: 900; }
    .plan-basico .plan-incluye li::before { color: #1ba367; }
    .plan-profesional .plan-incluye li::before { color: var(--naranja-oscuro); }
    .plan-empresarial .plan-incluye li::before { color: #1c6fbd; }
    .ejemplo-plan { margin-top: 18px; border: 1px solid rgba(17,19,21,.1); border-radius: 11px; background: #f8f9f9; }
    .ejemplo-plan summary { padding: 13px 14px; color: var(--azul-profundo); font-size: 12px; font-weight: 900; cursor: pointer; list-style-position: inside; }
    .ejemplo-plan[open] summary { border-bottom: 1px solid rgba(17,19,21,.08); color: var(--naranja-oscuro); }
    .ejemplo-contenido { max-height: 410px; padding: 15px; overflow-y: auto; }
    .ejemplo-contenido h4 { margin: 13px 0 5px; color: var(--carbon); font-size: 12px; text-transform: uppercase; letter-spacing: .035em; }
    .ejemplo-contenido h4:first-child { margin-top: 0; }
    .ejemplo-contenido p, .ejemplo-contenido li { color: var(--gris); font-size: 11px; line-height: 1.55; }
    .ejemplo-contenido small { color: #7a858d; font-size: 10px; font-style: italic; }
    .ejemplo-contenido ol { margin: 6px 0 0; padding-left: 20px; }
    .alerta-plan { margin-top: 14px; padding: 13px; border-left: 4px solid var(--naranja); border-radius: 8px; color: var(--carbon); background: #fff0d9; }
    .alerta-plan p { margin: 5px 0 0; color: #6c4a24; }
    .plan-cta { min-height: 49px; margin-top: 18px; padding: 12px 15px; display: flex; align-items: center; justify-content: center; border-radius: 9px; color: var(--blanco); background: linear-gradient(110deg, var(--azul-profundo), var(--carbon)); text-align: center; text-decoration: none; font-size: 12px; font-weight: 900; transition: transform 180ms ease, box-shadow 180ms ease; }
    .plan-basico .plan-cta { color: #fff0d9; background: linear-gradient(110deg, #0f5f3b, #143d2d 58%, #9a5414); text-shadow: 0 1px 8px rgba(0,0,0,.24); }
    .plan-profesional .plan-cta { color: var(--carbon); background: linear-gradient(110deg, #fff0d6, #ffbd62); }
    .plan-empresarial .plan-cta { color: #1c1408; background: linear-gradient(110deg, #fff0c4, #d7a33a 48%, #8a5a12); box-shadow: 0 12px 26px rgba(181,126,28,.22); }
    .plan-cta:hover { transform: translateY(-2px); box-shadow: 0 12px 28px rgba(28,52,71,.2); }

    .contacto { position: relative; overflow: hidden; color: var(--marfil); background: radial-gradient(circle at 8% 20%, rgba(28,111,189,.34), transparent 28%), radial-gradient(circle at 92% 80%, rgba(225,132,27,.24), transparent 30%), linear-gradient(135deg, var(--carbon), var(--grafito)); }
    .contacto-grid { display: grid; grid-template-columns: 1fr; gap: 34px; align-items: center; }
    .contacto h2 { color: var(--marfil); }
    .contacto p { color: var(--marfil-suave); font-size: 18px; }
    .contacto-panel { padding: 22px; border: 1px solid rgba(255,255,255,.16); border-radius: 14px; background: rgba(255,255,255,.055); backdrop-filter: blur(10px); }
    .contacto-panel-titulo { margin-bottom: 15px; display: flex; align-items: center; justify-content: space-between; gap: 16px; }
    .contacto-panel-titulo small { color: #ffdca8; font-size: 9px; font-weight: 900; letter-spacing: .12em; }
    .contacto-panel-titulo strong { color: var(--marfil); font-size: 18px; }
    .contacto-datos { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; }
    .contacto-datos a, .contacto-datos div { padding: 16px; border: 1px solid rgba(255,255,255,.32); border-radius: 10px; color: var(--marfil); background: rgba(255,255,255,.09); backdrop-filter: blur(10px); text-decoration: none; font-weight: 900; overflow-wrap: anywhere; transition: background 180ms ease, transform 180ms ease; }
    .contacto-datos a:hover { background: rgba(255,255,255,.16); transform: translateX(4px); }

    ::selection { color: var(--blanco); background: var(--azul); }
    footer { padding: 25px 16px; color: var(--marfil); background: #0c0f11; border-top: 1px solid rgba(255,255,255,.08); text-align: center; font-size: 13px; font-weight: 900; letter-spacing: .08em; }

    @media (hover: hover) {
      .capacidad:hover, .fuente-card:hover, .paso:hover, .resultado:hover { transform: translateY(-5px); }
      .capacidad:hover { border-color: rgba(225,132,27,.34); box-shadow: 0 14px 28px rgba(28,52,71,.1); }
      .fuente-card:hover, .resultado:hover { box-shadow: 0 22px 45px rgba(28,52,71,.15); }
      .paso:hover { border-color: rgba(255,186,95,.45); background: rgba(255,255,255,.11); }
      .plan-card:not(.destacado):hover { transform: translateY(-7px); box-shadow: 0 27px 60px rgba(28,52,71,.16); }
      .plan-card.destacado:hover { transform: translateY(-17px); }
    }

    .revelar { opacity: 0; transform: translateY(22px); transition: opacity 540ms ease, transform 540ms ease; }
    .revelar.visible { opacity: 1; transform: none; }

    @media print {
      body * { visibility: hidden !important; }
      #reporteDemo, #reporteDemo * { visibility: visible !important; }
      #reporteDemo { position: absolute; inset: 0; width: 100%; box-shadow: none; }
      #reporteDemo .boton-pdf { display: none; }
    }

    @media (max-width: 900px) {
      .menu-boton { display: grid; }
      .nav { position: relative; min-height: 66px; }
      nav { position: absolute; top: 100%; left: 0; width: 100%; max-height: calc(100vh - 76px); padding: 12px; display: none; grid-template-columns: repeat(2, 1fr); overflow-y: auto; background: rgba(17,19,21,.99); border: 1px solid rgba(255,255,255,.14); border-top: 2px solid var(--gris-claro); border-radius: 0 0 9px 9px; box-shadow: 0 20px 40px rgba(0,0,0,.3); }
      nav.abierto { display: grid; }
      nav a { min-height: 47px; display: flex; align-items: center; border: 1px solid rgba(255,255,255,.1); }
      .hero-grid, .servicio-principal, .demo-layout, .contacto-grid { grid-template-columns: 1fr; }
      .planes-grid { grid-template-columns: 1fr; }
      .plan-card.destacado { transform: none; }
      .plan-cabecera, .plan-incluye { min-height: 0; }
      .hero { min-height: auto; }
      .hero-grid { padding: 58px 0; }
      .dashboard-mini { transform: none; }
      .dashboard-mini { max-width: 680px; }
      .fuentes-grid { grid-template-columns: repeat(3, 1fr); }
      .proceso-grid { grid-template-columns: repeat(2, 1fr); }
      .kpis, .resultados-grid { grid-template-columns: repeat(2, 1fr); }
      .graficos { grid-template-columns: 1fr; }
    }

    @media (max-width: 600px) {
      section { padding: 58px 0; }
      .contenedor, .nav { width: min(100% - 24px, 1160px); }
      nav { grid-template-columns: 1fr; }
      h1 { font-size: clamp(38px, 12vw, 52px); }
      h2 { font-size: clamp(29px, 9vw, 40px); }
      .hero-grid { gap: 30px; padding: 44px 0; }
      .hero-texto, .titulo-seccion p, .contacto p { font-size: 16px; }
      .acciones { display: grid; }
      .boton { width: 100%; }
      .dashboard-mini, .agente-identidad, .capacidades, .formulario, .reporte { padding: 19px; }
      .mini-kpis, .capacidades-grid, .fuentes-grid, .proceso-grid, .campos, .kpis, .categorias-destacadas, .resultados-grid { grid-template-columns: 1fr; }
      .resultado-grupo { grid-template-columns: 1fr; gap: 7px; }
      .opciones-alcance { grid-template-columns: 1fr; }
      .columnas-detectadas { grid-template-columns: 1fr; }
      .diagnostico-titulo { align-items: flex-start; flex-direction: column; }
      .capacidades-personalizadas ul { grid-template-columns: 1fr; }
      .campo.completo { grid-column: auto; }
      input, select, textarea { font-size: 16px; }
      input[type="file"] { max-width: 100%; overflow: hidden; }
      .reporte-cabecera, .entrega { align-items: stretch; flex-direction: column; }
      .contacto-panel-titulo { align-items: flex-start; flex-direction: column; }
      .contacto-datos { grid-template-columns: 1fr; }
      .detalle-kpi-cabecera { flex-direction: column; }
      .detalle-kpi-cabecera > strong { max-width: 100%; text-align: left; }
      .detalle-metricas { grid-template-columns: 1fr; }
      .detalle-barra { grid-template-columns: minmax(0, 1fr) auto; gap: 6px 10px; }
      .detalle-barra-track { grid-column: 1 / -1; grid-row: 2; }
      .detalle-barra > strong { grid-column: 2; grid-row: 1; }
      .resultado { min-height: auto; }
      .entrega-badges { width: 100%; }
      .entrega-badges { min-width: 0; grid-template-columns: repeat(3, minmax(0, 1fr)); }
    }

    @media (prefers-reduced-motion: reduce) {
      html { scroll-behavior: auto; }
      .revelar { opacity: 1; transform: none; transition: none; }
      * { animation-duration: .01ms !important; animation-iteration-count: 1 !important; }
    }
