/* ─── Block 1 (head, lines 227-392) ─── */
    :root{
      --blue:#0279FF;--pink:#FF60EE;--dark:#080C14;--dark2:#0D1421;
      --card-bg:rgba(255,255,255,.04);--border:rgba(255,255,255,.08);
      --text-muted:rgba(255,255,255,.5);--text-dim:rgba(255,255,255,.28);
    }
    *{box-sizing:border-box}
    html,body{margin:0;padding:0;width:100%;overflow-x:hidden;background:var(--dark);color:#fff;font-family:'Inter',sans-serif;font-size:1rem}
    h1,h2,h3,h4,h5,h6{font-family:'Ubuntu',sans-serif;font-weight:700;color:#fff}
    p{line-height:1.75;color:var(--text-muted)}
    a{color:var(--blue);text-decoration:none;transition:.25s}
    img{display:block;max-width:100%;height:auto}
    [data-lucide]{width:1em;height:1em;stroke-width:1.75;vertical-align:-.125em;display:inline-block}

    /* ── NAVBAR ── */
    .navbar{background:rgba(8,12,20,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:12px 0}
    .navbar .nav-link{font-size:.875rem;font-weight:500;color:rgba(255,255,255,.7)!important;transition:color .15s}
    .navbar .nav-link:hover{color:#fff!important}
    .btn-nav-demo{background:var(--pink);border:none;border-radius:8px;font-size:.875rem;font-weight:600;padding:.45rem 1.1rem;color:#fff;transition:all .2s}
    .btn-nav-demo:hover{background:#cc00c9;color:#fff;transform:translateY(-1px)}
    .btn-nav-login{background:transparent;border:1px solid rgba(255,255,255,.18);border-radius:8px;font-size:.875rem;font-weight:600;padding:.45rem 1.1rem;color:rgba(255,255,255,.85);transition:all .2s;text-decoration:none}
    .btn-nav-login:hover{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.32);color:#fff;transform:translateY(-1px)}

    /* ── HERO ── */
    .hero{background:var(--dark);padding:5rem 0 3.5rem;position:relative;overflow:hidden;min-height:auto;display:flex;align-items:center}
    .hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(2,121,255,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(2,121,255,.07) 1px,transparent 1px);background-size:60px 60px;pointer-events:none}
    .hero-glow-1{position:absolute;top:-10%;right:0;width:600px;height:600px;background:radial-gradient(circle,rgba(2,121,255,.15) 0%,transparent 65%);pointer-events:none}
    .hero-glow-2{position:absolute;bottom:-15%;left:-5%;width:400px;height:400px;background:radial-gradient(circle,rgba(255,96,238,.1) 0%,transparent 65%);pointer-events:none}
    .aes-badge{display:inline-flex;align-items:center;gap:.5rem;border:1px solid rgba(255,96,238,.35);background:rgba(255,96,238,.08);border-radius:30px;padding:.35rem 1.1rem;font-size:.78rem;font-weight:600;color:#FF60EE;letter-spacing:.04em;margin-bottom:1.5rem;font-family:'Ubuntu',sans-serif}
    .hero h1{font-size:clamp(2.4rem,5vw,3.8rem);line-height:1.05;letter-spacing:-.02em;margin-bottom:1.5rem}
    .hero h1 .accent{color:var(--pink)}
    .hero-lead{font-size:1.1rem;color:rgba(255,255,255,.65);max-width:520px;line-height:1.7;margin-bottom:2rem}
    .btn-demo-primary{background:var(--pink);border:none;border-radius:10px;font-weight:700;font-family:'Ubuntu',sans-serif;padding:.8rem 2rem;color:#fff;transition:all .2s;font-size:.95rem;display:inline-flex;align-items:center;gap:.5rem}
    .btn-demo-primary:hover{background:#cc00c9;transform:translateY(-2px);color:#fff}
    .btn-demo-secondary{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.15);border-radius:10px;font-weight:500;padding:.8rem 1.6rem;color:rgba(255,255,255,.8);transition:all .2s;font-size:.95rem;display:inline-flex;align-items:center;gap:.5rem}
    .btn-demo-secondary:hover{background:rgba(255,255,255,.12);color:#fff}
    .hero-stats{display:flex;gap:2.5rem;margin-top:2.5rem;padding-top:2rem;border-top:1px solid var(--border)}
    .hero-stat-num{font-size:2rem;font-weight:700;font-family:'Ubuntu',sans-serif;line-height:1;color:#fff}
    .hero-stat-lbl{font-size:.78rem;color:var(--text-dim);margin-top:2px}
    .hero-visual{position:relative}
    .hero-screen{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:16px;overflow:hidden;backdrop-filter:blur(4px)}
    .hero-screen-bar{display:flex;align-items:center;gap:6px;padding:10px 14px;border-bottom:1px solid var(--border)}
    .dot{width:8px;height:8px;border-radius:50%}
    .hero-chat-bubble{background:rgba(2,121,255,.15);border:1px solid rgba(2,121,255,.25);border-radius:12px 12px 12px 2px;padding:10px 14px;font-size:.82rem;color:rgba(255,255,255,.85);max-width:80%;margin-bottom:8px;line-height:1.5}
    .hero-chat-bubble.right{background:rgba(255,96,238,.12);border-color:rgba(255,96,238,.2);border-radius:12px 12px 2px 12px;margin-left:auto;text-align:right}
    .hero-agent-row{display:flex;align-items:center;gap:8px;padding:8px 0}
    .agent-av{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;flex-shrink:0}
    .agent-av.pink{background:rgba(255,96,238,.2);color:#FF60EE}
    .agent-av.blue{background:rgba(2,121,255,.2);color:#60B4FF}
    .agent-av.green{background:rgba(16,185,129,.2);color:#34D399}
    .agent-name{font-size:.78rem;font-weight:600;color:#fff}
    .agent-status{font-size:.7rem;color:var(--text-muted)}
    .status-dot{width:6px;height:6px;border-radius:50%;background:#34D399;display:inline-block;margin-right:4px}

    /* ── FLOW STRIP ── */
    .sec-flow{background:var(--dark2);padding:3rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
    .flow-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim);margin-bottom:1.2rem;text-align:center}
    .flow-strip{display:flex;align-items:center;justify-content:center;gap:.5rem;flex-wrap:wrap}
    .flow-node{font-size:.8rem;font-weight:500;padding:7px 14px;border-radius:8px;background:rgba(255,255,255,.05);border:1px solid var(--border);color:rgba(255,255,255,.75);white-space:nowrap;font-family:'Inter',sans-serif;transition:all .2s}
    .flow-node:hover{border-color:var(--pink);color:#fff;background:rgba(255,96,238,.08)}
    .flow-node.highlight{border-color:rgba(255,96,238,.4);background:rgba(255,96,238,.08);color:#FF60EE}
    .flow-arrow{color:var(--text-dim);font-size:.9rem}
    .flow-caption{text-align:center;font-size:.8rem;color:var(--text-dim);margin-top:1rem}

    /* ── PROPUESTA DE VALOR ── */
    .sec-value{padding:6rem 0;background:var(--dark)}
    .section-eyebrow{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--pink);margin-bottom:.75rem;font-family:'Ubuntu',sans-serif}
    .section-eyebrow.blue{color:var(--blue)}
    .section-h{font-size:clamp(1.8rem,3.5vw,2.8rem);line-height:1.15;letter-spacing:-.02em;margin-bottom:1rem}
    .value-card{background:var(--card-bg);border:1px solid var(--border);border-radius:16px;padding:2rem;height:100%;transition:all .25s;position:relative;overflow:hidden}
    .value-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:transparent;transition:background .25s}
    .value-card:hover{border-color:rgba(255,255,255,.16);transform:translateY(-4px)}
    .value-card:hover::before{background:linear-gradient(90deg,var(--pink),var(--blue))}
    .value-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:1.2rem;font-size:1.1rem}
    .value-icon.pink{background:rgba(255,96,238,.12);color:#FF60EE}
    .value-icon.blue{background:rgba(2,121,255,.12);color:#60B4FF}
    .value-icon.green{background:rgba(16,185,129,.12);color:#34D399}
    .value-icon.amber{background:rgba(245,158,11,.12);color:#FCD34D}
    .value-icon.purple{background:rgba(139,92,246,.12);color:#A78BFA}
    .value-card h3{font-size:1.05rem;font-weight:700;margin-bottom:.6rem;color:#fff}
    .value-card p{font-size:.9rem;color:var(--text-muted);line-height:1.6;margin:0}

    /* ── AGENTES ── */
    .sec-agents{padding:6rem 0;background:var(--dark2)}
    .agent-card{background:var(--card-bg);border:1px solid var(--border);border-radius:14px;padding:1.25rem;display:flex;align-items:flex-start;gap:1rem;transition:all .22s}
    .agent-card:hover{border-color:rgba(255,96,238,.3);background:rgba(255,96,238,.04)}
    .agent-avatar{width:44px;height:44px;border-radius:50%;flex-shrink:0;background:rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;font-family:'Ubuntu',sans-serif;position:relative;overflow:hidden}
    .agent-avatar img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:50%;z-index:1}
    .agent-card-name{font-size:.9rem;font-weight:700;color:#fff;margin:0 0 2px;font-family:'Ubuntu',sans-serif}
    .agent-card-role{font-size:.75rem;color:var(--text-muted);margin:0 0 6px}
    .agent-modules{display:flex;flex-wrap:wrap;gap:4px}
    .module-pill{font-size:.68rem;padding:2px 7px;border-radius:4px;background:rgba(255,255,255,.06);border:1px solid var(--border);color:rgba(255,255,255,.55);white-space:nowrap}
    .voice-badge{display:inline-flex;align-items:center;gap:4px;font-size:.68rem;color:#FF60EE;background:rgba(255,96,238,.1);border:1px solid rgba(255,96,238,.2);border-radius:4px;padding:2px 6px;margin-left:4px}

    /* ── TABLAS COMPARATIVAS ── */
    .sec-compare{padding:6rem 0}
    .sec-compare.dark{background:var(--dark)}
    .sec-compare.darker{background:var(--dark2)}
    .compare-table{width:100%;border-collapse:collapse}
    .compare-table thead th{padding:1rem .9rem;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;text-align:center;color:rgba(255,255,255,.5);border-bottom:1px solid var(--border);font-family:'Ubuntu',sans-serif}
    .compare-table thead th:first-child{text-align:left;padding-left:0}
    .compare-table thead th.omb-col{color:#fff;position:relative}
    .compare-table thead th.omb-col::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--pink),var(--blue))}
    .compare-table tbody td{padding:.85rem .9rem;border-bottom:1px solid rgba(255,255,255,.04);text-align:center;font-size:.88rem;color:rgba(255,255,255,.55);vertical-align:middle}
    .compare-table tbody td:first-child{text-align:left;padding-left:0;font-weight:500;color:rgba(255,255,255,.8)}
    .compare-table tbody tr:last-child td{border-bottom:none}
    .compare-table tbody tr:hover td{background:rgba(255,255,255,.015)}
    .check-yes{color:rgba(255,255,255,.4);font-size:1rem}
    .check-no{color:rgba(255,255,255,.15);font-size:1rem}
    .check-partial{color:#F59E0B;font-size:1rem}
    .check-omb{color:var(--pink);font-size:1.2rem}
    .omb-col-cell{font-weight:700}
    .table-wrap{background:var(--card-bg);border:1px solid var(--border);border-radius:16px;overflow:hidden;padding:1.5rem}

    /* ── PILARES (3 en 1) ── */
    .sec-pillars{padding:6rem 0;background:var(--dark);position:relative;overflow:hidden}
    .sec-pillars::before{content:'';position:absolute;top:-30%;right:-10%;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(255,96,238,.08) 0%,transparent 70%);pointer-events:none}
    .pillar-card{background:var(--card-bg);border:1px solid var(--border);border-radius:16px;padding:2.5rem;height:100%;position:relative;overflow:hidden;transition:all .25s}
    .pillar-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px}
    .pillar-card.p-blue::before{background:var(--blue)}
    .pillar-card.p-pink::before{background:var(--pink)}
    .pillar-card.p-green::before{background:#10B981}
    .pillar-card:hover{border-color:rgba(255,255,255,.15);transform:translateY(-4px)}
    .pillar-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;font-size:1.3rem}
    .pillar-card h3{font-size:1.15rem;margin-bottom:.75rem;color:#fff}
    .pillar-card p{font-size:.9rem;color:var(--text-muted);line-height:1.65;margin-bottom:1.25rem}
    .pillar-link{font-size:.85rem;font-weight:600;display:inline-flex;align-items:center;gap:.4rem}

    /* ── PRUEBA SOCIAL ── */
    .sec-proof{padding:5rem 0;background:var(--dark2);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
    .proof-num{font-size:3rem;font-weight:700;font-family:'Ubuntu',sans-serif;line-height:1}
    .proof-lbl{font-size:.85rem;color:var(--text-muted);margin-top:4px;line-height:1.4}
    .proof-sep{width:1px;background:var(--border);align-self:stretch}

    /* ── CTA FINAL ── */
    .sec-cta{padding:7rem 0;background:var(--dark);position:relative;overflow:hidden}
    .sec-cta::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 100%,rgba(255,96,238,.1) 0%,transparent 60%);pointer-events:none}
    .cta-box{text-align:center;max-width:680px;margin:0 auto;position:relative;z-index:1}
    .cta-box h2{font-size:clamp(2rem,4vw,3.2rem);line-height:1.1;letter-spacing:-.02em;margin-bottom:1rem}
    .cta-box p{font-size:1.05rem;color:rgba(255,255,255,.6);margin-bottom:2.5rem}
    .btn-cta-main{background:linear-gradient(135deg,var(--pink),#cc00c9);border:none;border-radius:12px;font-weight:700;font-family:'Ubuntu',sans-serif;padding:1rem 2.5rem;color:#fff;font-size:1rem;transition:all .2s;display:inline-flex;align-items:center;gap:.6rem}
    .btn-cta-main:hover{transform:translateY(-3px);color:#fff;box-shadow:0 8px 30px rgba(255,96,238,.4)}
    .btn-cta-alt{background:transparent;border:1px solid var(--border);border-radius:12px;font-weight:500;padding:1rem 2rem;color:rgba(255,255,255,.7);font-size:1rem;transition:all .2s;display:inline-flex;align-items:center;gap:.6rem}
    .btn-cta-alt:hover{border-color:rgba(255,255,255,.3);color:#fff}

    /* ── FOOTER ── */
    .site-footer{background:var(--dark2);padding:3rem 0 2rem;border-top:1px solid var(--border)}
    .site-footer p,.site-footer a,.site-footer small{color:rgba(255,255,255,.35);font-size:.82rem}
    .site-footer a:hover{color:var(--pink)}
    .footer-links a{margin:0 .75rem}

    /* ── ANIMATIONS ── */
    .animate-up{opacity:0;transform:translateY(20px);transition:all .7s ease-out}
    .animate-up.visible{opacity:1;transform:none}


    /* ── PARALLAX ── */
    .parallax-section{position:relative;overflow:hidden;min-height:440px;display:flex;align-items:center;justify-content:center}
    .parallax-bg{position:absolute;inset:-30% 0;background-size:cover;background-position:center;background-repeat:no-repeat;will-change:transform;transition:transform .05s linear}
    .parallax-overlay{position:absolute;inset:0;z-index:1}
    .parallax-content{position:relative;z-index:2;text-align:center;padding:5rem 1rem;max-width:800px;margin:0 auto}

    @media(max-width:768px){
      .hero{padding:3.5rem 0 2.5rem}
      .hero-stats{gap:1.5rem;flex-wrap:wrap}
      .flow-strip{gap:.35rem}
      .flow-node{font-size:.72rem;padding:5px 10px}
      .compare-table{font-size:.78rem}
      .compare-table thead th,.compare-table tbody td{padding:.6rem .4rem}
    }

/* ─── Block 2 (head, line 464) ─── */
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.4)}}

/* ─── Block 3 (body 614-620) ─── */
.flow-node-wrap{display:flex;flex-direction:column;align-items:center;gap:6px;position:relative}
.flow-agent-node{width:42px;height:42px;border-radius:50%;overflow:hidden;position:relative;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:700;color:rgba(255,255,255,.6);font-family:Ubuntu,sans-serif;background:rgba(255,96,238,.15);border:1.5px solid rgba(255,96,238,.4);box-shadow:0 0 10px rgba(255,96,238,.3),0 0 20px rgba(255,96,238,.15);animation:node-glow 2.5s ease-in-out infinite}
.flow-agent-node img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:50%}
@keyframes node-glow{0%,100%{box-shadow:0 0 8px rgba(255,96,238,.3),0 0 16px rgba(255,96,238,.1)}50%{box-shadow:0 0 16px rgba(255,96,238,.6),0 0 32px rgba(255,96,238,.25),0 0 48px rgba(255,96,238,.1)}}
.flow-agent-av{width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.08);border:1.5px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;color:rgba(255,255,255,.5);font-family:Ubuntu,sans-serif;overflow:hidden;cursor:default;transition:border-color .2s;position:relative}
.flow-agent-av:hover{border-color:rgba(255,96,238,.5)}
.flow-agent-av img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:50%}

/* ─── Block 4 (body 994-1369) ─── */
.mod-item{display:flex;align-items:center;gap:9px;padding:9px 1rem 9px 1.25rem;font-size:.85rem;color:rgba(255,255,255,.55);cursor:pointer;transition:all .18s;border-left:2px solid transparent;font-family:'Inter',sans-serif;position:relative}
.mod-item:hover{color:rgba(255,255,255,.85);background:rgba(255,255,255,.03)}
.mod-item:hover::after{content:'›';position:absolute;right:12px;color:rgba(255,96,238,.6);font-size:1rem;font-weight:700}
.mod-item.active::after{content:'›';position:absolute;right:12px;color:#FF60EE;font-size:1rem;font-weight:700}
.mod-item.active{color:#fff;background:rgba(255,96,238,.06);border-left-color:#FF60EE}
.mod-icon{width:14px;height:14px;flex-shrink:0;stroke-width:1.75}
.mod-item.active .mod-icon{color:#FF60EE}
.mod-item:not(.active) .mod-icon{color:rgba(255,255,255,.35)}
.call-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:50px;font-size:.82rem;font-weight:600;cursor:pointer;border:none;font-family:'Inter',sans-serif;transition:all .2s;position:relative}
.call-btn.pink{background:rgba(255,96,238,.12);color:#FF60EE;border:1px solid rgba(255,96,238,.3)}
.call-btn.blue{background:rgba(2,121,255,.12);color:#60B4FF;border:1px solid rgba(2,121,255,.3)}
.call-btn.pink:hover{background:rgba(255,96,238,.22);box-shadow:0 0 20px rgba(255,96,238,.35)}
.call-btn.blue:hover{background:rgba(2,121,255,.22);box-shadow:0 0 20px rgba(2,121,255,.35)}
.call-btn::before{content:'';position:absolute;inset:-1px;border-radius:50px;background:inherit;filter:blur(8px);opacity:0;transition:opacity .2s;z-index:-1}
.call-btn:hover::before{opacity:.6}

/* "Try me" — botón de audio pre-grabado con pulso latente para indicar
   que es presionable. Cuando reproduce, el pulso se acelera. */
.call-btn.try-me{position:relative;overflow:visible}
.call-btn.try-me::after{content:'';position:absolute;inset:0;border-radius:50px;border:2px solid rgba(255,96,238,.55);animation:try-me-pulse 1.8s ease-out infinite;pointer-events:none}
.call-btn.try-me:hover::after{animation-duration:1.2s}
.call-btn.try-me.is-playing{background:rgba(255,96,238,.32);box-shadow:0 0 24px rgba(255,96,238,.55)}
.call-btn.try-me.is-playing::after{animation-duration:.7s;border-color:rgba(255,96,238,.85)}
@keyframes try-me-pulse{
  0%   {transform:scale(1);opacity:.85}
  70%  {transform:scale(1.18);opacity:0}
  100% {transform:scale(1.18);opacity:0}
}
/* Variante compacta dentro de las tarjetas de agentes (Your AI specialist team). */
.agent-tryme{padding:4px 10px;font-size:.66rem;border-radius:14px;margin-top:4px;line-height:1}
.agent-tryme svg{width:11px;height:11px}

/* ──────────────────────────────────────────────────────────────
   Mini-app demo layout — vista del módulo + chat overlay 40% br
   ────────────────────────────────────────────────────────────── */
.mod-demo-wrap{position:relative;height:100%;min-height:560px}
.mod-demo-view{padding:1.5rem 1.75rem;height:100%;overflow-y:auto}
.mod-demo-head{display:flex;gap:14px;align-items:flex-start;margin-bottom:1.25rem}
.mod-demo-icon{width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.mod-demo-head-text h3{font-size:1.18rem;color:#fff;margin:0 0 4px;font-family:'Ubuntu',sans-serif;font-weight:700;line-height:1.2}
.mod-demo-head-text p{font-size:.84rem;color:rgba(255,255,255,.55);margin:0;line-height:1.55}
.mod-demo-body{font-family:'Inter',sans-serif;color:rgba(255,255,255,.85)}
.mod-demo-chat{
  position:absolute;bottom:0;right:0;
  width:44%;max-width:480px;height:40%;min-height:230px;
  background:rgba(10,16,32,.92);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border-top:1px solid rgba(255,96,238,.25);
  border-left:1px solid rgba(255,96,238,.25);
  border-top-left-radius:14px;
  display:flex;flex-direction:column;
  box-shadow:-12px -12px 40px rgba(0,0,0,.45);
  overflow:hidden;
  z-index:10;
}
.mod-demo-chat-head{display:flex;align-items:center;gap:10px;padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.06)}
.mod-demo-chat-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.66rem;font-weight:700;font-family:'Ubuntu',sans-serif;overflow:hidden;position:relative;flex-shrink:0}
.mod-demo-chat-avatar img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:50%}
.mod-demo-chat-meta{flex:1;min-width:0}
.mod-demo-chat-name{font-size:.82rem;font-weight:600;color:#fff;font-family:'Ubuntu',sans-serif;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mod-demo-chat-role{font-size:.66rem;color:rgba(255,255,255,.45)}
.mod-demo-chat-body{flex:1;overflow-y:auto;padding:10px 12px;display:flex;flex-direction:column;gap:6px}
.mod-demo-chat-body .chat-bubble{font-size:.78rem}

@media (max-width:900px){
  .mod-demo-chat{position:static;width:100%;height:auto;min-height:200px;margin-top:1rem;box-shadow:none}
  .mod-demo-view{padding-bottom:1rem}
}

/* ── Estilos compartidos por todos los demos (mini-apps) ── */
.dm-row{display:grid;gap:10px;margin-bottom:14px}
.dm-row.cols-2{grid-template-columns:repeat(2,1fr)}
.dm-row.cols-3{grid-template-columns:repeat(3,1fr)}
.dm-row.cols-4{grid-template-columns:repeat(4,1fr)}
.dm-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:12px 14px}
.dm-card h4{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:rgba(255,255,255,.45);margin:0 0 8px;font-family:'Ubuntu',sans-serif;font-weight:700}
.dm-card.alert{border-color:rgba(252,211,77,.25);background:rgba(252,211,77,.05)}

/* KPI tile */
.dm-kpi-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:rgba(255,255,255,.45);font-weight:600;font-family:'Ubuntu',sans-serif;display:block;margin-bottom:4px}
.dm-kpi-val{font-size:1.4rem;font-weight:700;color:#fff;font-family:'Ubuntu',sans-serif;line-height:1.1;display:block}
.dm-kpi-delta{font-size:.7rem;color:rgba(255,255,255,.45);display:block;margin-top:4px}
.dm-kpi-delta.good{color:#34D399}
.dm-kpi-delta.warn{color:#FCD34D}
.dm-kpi-delta.bad{color:#F87171}

/* Cliente row */
.dm-cli{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.05);font-size:.82rem;color:rgba(255,255,255,.85)}
.dm-cli:last-child{border-bottom:0}
.dm-cli strong{color:#fff;font-weight:600}
.dm-cli span{font-variant-numeric:tabular-nums;color:#86C6FF}

/* Tabla simple (filas horizontales) */
.dm-table{font-size:.78rem}
.dm-table .dm-trow{display:grid;grid-template-columns:1.6fr .9fr .7fr .9fr;gap:8px;padding:7px 0;border-bottom:1px solid rgba(255,255,255,.05);align-items:center}
.dm-table .dm-trow.head{font-size:.65rem;text-transform:uppercase;letter-spacing:.06em;color:rgba(255,255,255,.4);font-weight:700;border-bottom-color:rgba(255,255,255,.12);font-family:'Ubuntu',sans-serif}
.dm-table .dm-trow span:not(:first-child){text-align:right;font-variant-numeric:tabular-nums;color:#86C6FF}
.dm-table .dm-trow strong{color:#fff;font-weight:600}

/* Progress bar */
.dm-bar{height:6px;background:rgba(255,255,255,.07);border-radius:4px;overflow:hidden;margin:6px 0}
.dm-bar-fill{height:100%;background:linear-gradient(90deg,#0279FF,#FF60EE);border-radius:4px;transition:width .4s}

/* Pills/badges */
.dm-chip{display:inline-block;font-size:.68rem;padding:3px 8px;border-radius:12px;background:rgba(2,121,255,.15);color:#86C6FF;border:1px solid rgba(2,121,255,.25);margin:2px 4px 2px 0}
.dm-chip.pink{background:rgba(255,96,238,.15);color:#FF60EE;border-color:rgba(255,96,238,.3)}
.dm-chip.green{background:rgba(52,211,153,.12);color:#34D399;border-color:rgba(52,211,153,.3)}

/* Business Profile demo */
.dm-bp-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:14px}
.dm-bp-head h4{font-size:1.05rem;color:#fff;margin:6px 0 4px;font-family:'Ubuntu',sans-serif}
.dm-bp-head p{font-size:.82rem;color:rgba(255,255,255,.55);margin:0}
.dm-bp-pct{text-align:center;flex-shrink:0;background:rgba(2,121,255,.12);border:1px solid rgba(2,121,255,.3);border-radius:12px;padding:10px 14px;min-width:84px}
.dm-bp-pct .v{font-size:1.4rem;font-weight:700;color:#86C6FF;font-family:'Ubuntu',sans-serif;line-height:1}
.dm-bp-pct .l{font-size:.62rem;text-transform:uppercase;letter-spacing:.08em;color:rgba(134,198,255,.7);margin-top:3px}
.dm-bp-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:14px}
.dm-bp-grid > div{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:10px;padding:9px 12px}
.dm-bp-grid span{font-size:.62rem;text-transform:uppercase;letter-spacing:.07em;color:rgba(255,255,255,.4);font-family:'Ubuntu',sans-serif;display:block;margin-bottom:3px}
.dm-bp-grid strong{font-size:.84rem;color:#fff;font-weight:600;line-height:1.3}

/* Digital Agency demo */
.dm-job{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:10px 12px;margin-bottom:8px}
.dm-job-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:4px;font-size:.84rem;color:#fff;font-weight:600}
.dm-job-head span{color:#86C6FF;font-size:.76rem;font-variant-numeric:tabular-nums}
.dm-job-foot{font-size:.7rem;color:rgba(255,255,255,.45);margin-top:4px}

/* App-like simulated topbar/tabs (le da sensación de "estar dentro de la app") */
.dm-topbar{display:flex;align-items:center;gap:6px;flex-wrap:wrap;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:10px;padding:6px 8px;margin-bottom:14px;font-size:.72rem}
.dm-topbar-label{color:rgba(255,255,255,.4);font-size:.62rem;text-transform:uppercase;letter-spacing:.08em;margin-right:6px;font-family:'Ubuntu',sans-serif;font-weight:700}
.dm-topbar-pill{padding:4px 10px;border-radius:14px;color:rgba(255,255,255,.55);font-weight:500;cursor:default;white-space:nowrap}
.dm-topbar-pill.active{background:rgba(255,96,238,.16);color:#FF60EE;border:1px solid rgba(255,96,238,.28)}

.dm-tabs{display:flex;gap:0;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:14px;overflow-x:auto;scrollbar-width:none}
.dm-tabs::-webkit-scrollbar{display:none}
.dm-tab{padding:9px 16px;font-size:.78rem;color:rgba(255,255,255,.5);border-bottom:2px solid transparent;cursor:default;white-space:nowrap;transition:color .15s,border-color .15s;font-weight:500}
.dm-tab.active{color:#fff;border-bottom-color:#FF60EE;font-weight:600}
.dm-tab:hover:not(.active){color:rgba(255,255,255,.85)}

/* AI Agents — grid de cards (se parece al módulo real /app/agents) */
.dm-agents-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(155px,1fr));gap:10px}
.dm-agent-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:14px 10px;display:flex;flex-direction:column;align-items:center;text-align:center;position:relative;transition:border-color .15s,transform .15s}
.dm-agent-card:hover{border-color:rgba(255,96,238,.35);transform:translateY(-2px)}
.dm-agent-av{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;font-family:'Ubuntu',sans-serif;overflow:hidden;position:relative;margin-bottom:8px;border:2px solid rgba(255,255,255,.1)}
.dm-agent-av img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:50%}
.dm-agent-name{font-size:.82rem;font-weight:600;color:#fff;font-family:'Ubuntu',sans-serif;line-height:1.2;margin-bottom:2px}
.dm-agent-role{font-size:.66rem;color:rgba(255,255,255,.45);margin-bottom:6px}
.dm-agent-stats{font-size:.66rem;color:rgba(255,255,255,.7);font-variant-numeric:tabular-nums;line-height:1.4}
.dm-agent-stats strong{color:#86C6FF;font-weight:600}
.dm-agent-active-dot{position:absolute;top:8px;right:8px;width:8px;height:8px;border-radius:50%;background:#34D399;box-shadow:0 0 0 3px rgba(52,211,153,.18)}
.dm-agent-active-dot.partial{background:#FCD34D;box-shadow:0 0 0 3px rgba(252,211,77,.2)}
.dm-agent-active-dot.offline{background:#F87171;box-shadow:0 0 0 3px rgba(248,113,113,.22)}
.dm-agents-legend{display:flex;flex-wrap:wrap;gap:14px;margin-top:10px;font-size:.66rem;color:rgba(255,255,255,.5);font-family:'Inter',sans-serif}
.dm-agents-legend .lg{display:inline-flex;align-items:center;gap:5px}
.dm-agents-legend .d{width:7px;height:7px;border-radius:50%}
.dm-agents-legend .d.gr{background:#34D399}
.dm-agents-legend .d.am{background:#FCD34D}
.dm-agents-legend .d.rd{background:#F87171}

/* CRM stat cards (mirror app's .sc/.sl/.sv) */
.dm-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:14px}
.dm-stat{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:10px 12px}
.dm-stat-l{font-size:.62rem;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.45);font-weight:600;font-family:'Ubuntu',sans-serif;margin-bottom:6px}
.dm-stat-v{font-size:1.35rem;font-weight:700;font-family:'Ubuntu',sans-serif;line-height:1.05;color:#fff}
.dm-stat-v.bl{color:#60B4FF}
.dm-stat-v.te{color:#34D399}
.dm-stat-v.am{color:#FCD34D}
.dm-stat-v.pu{color:#A78BFA}
.dm-stat-v.dim{color:rgba(255,255,255,.55)}
.dm-stat-v.rd{color:#F87171}
.dm-stat-t{font-size:.72rem;font-weight:600;color:rgba(255,255,255,.4);margin-left:2px}
.dm-stat-d{font-size:.65rem;color:rgba(255,255,255,.45);margin-top:4px}

/* CRM channel pills (level 1) — real OMB colors */
.dm-canal-row{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}
.dm-canal{display:inline-flex;align-items:center;gap:6px;padding:5px 11px;border-radius:14px;border:1px solid;font-size:.72rem;font-weight:600;font-family:'Ubuntu',sans-serif;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,filter .2s;white-space:nowrap;user-select:none}
.dm-canal i{font-style:normal;font-size:.62rem;background:rgba(0,0,0,.12);border-radius:8px;padding:1px 6px}
.dm-canal.active{box-shadow:0 4px 12px rgba(0,0,0,.25);transform:translateY(-1px);color:#fff !important}
.dm-canal.active i{background:rgba(255,255,255,.22);color:#fff}
.dm-canal.active[data-canal="email"]   {background:#1d4ed8 !important;border-color:#1d4ed8 !important}
.dm-canal.active[data-canal="silent"]  {background:#475569 !important;border-color:#475569 !important}
.dm-canal.active[data-canal="linkedin"]{background:#0369a1 !important;border-color:#0369a1 !important}
.dm-canal.active[data-canal="whatsapp"]{background:#15803d !important;border-color:#15803d !important}
.dm-canal.active[data-canal="phone"]   {background:#92400e !important;border-color:#92400e !important}
.dm-canal.active[data-canal="meeting"] {background:#854d0e !important;border-color:#854d0e !important}
.dm-canal.active[data-canal="proposal"]{background:#7c3aed !important;border-color:#7c3aed !important}
.dm-canal.active[data-canal="won"]     {background:#15803d !important;border-color:#15803d !important}
.dm-canal.active[data-canal="lost"]    {background:#be123c !important;border-color:#be123c !important}
.dm-canal:not(.active){filter:saturate(.8) opacity(.78)}
.dm-canal:not(.active):hover{filter:none}
.dm-canal.click-pulse{animation:canalPulse .65s ease}
@keyframes canalPulse{0%{transform:translateY(0) scale(1)}40%{transform:translateY(-2px) scale(1.05)}100%{transform:translateY(0) scale(1)}}

/* CRM stage columns (level 2) for the active channel */
.dm-stage-row{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}
.dm-stage{background:rgba(2,121,255,.05);border:1px solid rgba(2,121,255,.18);border-radius:10px;padding:8px;min-height:230px;transition:background-color .2s,border-color .2s}
.dm-stage-h{display:flex;justify-content:space-between;align-items:center;font-size:.62rem;text-transform:uppercase;letter-spacing:.06em;color:#86C6FF;margin-bottom:8px;font-family:'Ubuntu',sans-serif;font-weight:700}
.dm-stage-c{background:rgba(2,121,255,.22);border-radius:9px;padding:1px 6px;font-size:.6rem;color:#86C6FF;font-weight:600}
.dm-stage.over{background:rgba(255,96,238,.08);border-color:rgba(255,96,238,.45)}

/* CRM kanban (legacy 5-col layout, kept for back-compat) */
.dm-kanban{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}
.dm-kan-col{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:10px;padding:8px;min-height:240px}
.dm-kan-head{display:flex;justify-content:space-between;align-items:center;font-size:.62rem;text-transform:uppercase;letter-spacing:.07em;color:rgba(255,255,255,.55);margin-bottom:8px;font-family:'Ubuntu',sans-serif;font-weight:700}
.dm-kan-count{background:rgba(255,255,255,.08);border-radius:10px;padding:1px 7px;font-size:.62rem;color:#fff;font-weight:600}
.dm-kan-col.proposal .dm-kan-count{background:rgba(2,121,255,.25);color:#86C6FF}
.dm-kan-col.negotiation .dm-kan-count{background:rgba(255,96,238,.22);color:#FF60EE}
.dm-kan-col.won .dm-kan-count{background:rgba(52,211,153,.22);color:#34D399}
.dm-kan-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:7px 9px;margin-bottom:6px;font-size:.72rem;color:#fff;line-height:1.35}
.dm-kan-card .co{font-weight:600;display:block;margin-bottom:2px}
.dm-kan-card .meta{font-size:.65rem;color:rgba(255,255,255,.55);display:flex;justify-content:space-between;margin-top:3px}
.dm-kan-card .val{color:#86C6FF;font-variant-numeric:tabular-nums;font-weight:600}
.dm-kan-card.hot{border-left:2px solid #FF60EE}
.dm-kan-card{cursor:grab;transition:opacity .2s ease,transform .2s ease,box-shadow .25s,border-color .2s}
.dm-kan-card:active{cursor:grabbing}
.dm-kan-card.dragging{opacity:.35}
.dm-kan-col{transition:background-color .2s,border-color .2s}
.dm-kan-col.over{background:rgba(255,96,238,.07);border-color:rgba(255,96,238,.35)}
.dm-kan-card.agent-move{box-shadow:0 0 0 1.5px #FF60EE,0 14px 32px rgba(255,96,238,.45);border-color:rgba(255,96,238,.6) !important}

/* Agent auto-pilot toolbar + cursor */
.dm-kan-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;gap:10px;flex-wrap:wrap}
.dm-kan-hint{font-size:.7rem;color:rgba(255,255,255,.45)}
.dm-kan-pilot{display:inline-flex;align-items:center;gap:7px;padding:5px 11px;border-radius:14px;background:rgba(255,96,238,.1);border:1px solid rgba(255,96,238,.3);color:#FF60EE;cursor:pointer;font-weight:600;font-size:.7rem;font-family:'Ubuntu',sans-serif;letter-spacing:.02em;transition:all .2s;user-select:none}
.dm-kan-pilot:hover{background:rgba(255,96,238,.2)}
.dm-kan-pilot.live{background:rgba(255,96,238,.22)}
.dm-kan-pilot .pilot-dot{width:6px;height:6px;border-radius:50%;background:#FF60EE;display:inline-block}
.dm-kan-pilot.live .pilot-dot{animation:pilotPulse 1.1s infinite}
@keyframes pilotPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(1.7)}}
.agent-cursor{position:fixed;pointer-events:none;z-index:50;width:22px;height:22px;border-radius:50%;background:radial-gradient(circle,rgba(255,96,238,.6) 0%,rgba(255,96,238,.15) 70%);border:1.5px solid #FF60EE;box-shadow:0 0 18px rgba(255,96,238,.55);opacity:0;transition:opacity .25s}
.agent-cursor.show{opacity:1}
.agent-cursor::after{content:attr(data-name);position:absolute;top:26px;left:50%;transform:translateX(-50%);background:#FF60EE;color:#0b0e16;font-size:.6rem;font-weight:700;padding:2px 8px;border-radius:8px;white-space:nowrap;font-family:'Ubuntu',sans-serif;letter-spacing:.04em}

/* Email inbox */
.dm-mail-list{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:10px;overflow:hidden}
.dm-mail-row{display:grid;grid-template-columns:24px 150px 1fr 70px;gap:10px;padding:9px 12px;border-bottom:1px solid rgba(255,255,255,.05);align-items:center;font-size:.78rem;color:rgba(255,255,255,.7)}
.dm-mail-row:last-child{border-bottom:0}
.dm-mail-row.unread{background:rgba(255,255,255,.04);color:#fff}
.dm-mail-row.unread .from{font-weight:700}
.dm-mail-row .from{color:#fff}
.dm-mail-row .snip{color:rgba(255,255,255,.5);font-size:.74rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dm-mail-row .snip strong{color:rgba(255,255,255,.85);font-weight:600;margin-right:6px}
.dm-mail-row .when{font-size:.68rem;color:rgba(255,255,255,.45);text-align:right;white-space:nowrap}
.dm-mail-row .dot{width:8px;height:8px;border-radius:50%;background:#86C6FF;opacity:0}
.dm-mail-row.unread .dot{opacity:1}
.dm-mail-suggest{background:rgba(52,211,153,.08);border:1px dashed rgba(52,211,153,.35);border-radius:9px;padding:8px 11px;margin-top:10px;font-size:.74rem;color:rgba(255,255,255,.75);display:flex;align-items:center;gap:8px}
.dm-mail-suggest strong{color:#34D399}

/* Drive */
.dm-drive-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(115px,1fr));gap:10px}
.dm-drive-tile{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:10px;padding:14px 10px;display:flex;flex-direction:column;align-items:center;text-align:center;font-size:.74rem;color:#fff;gap:6px}
.dm-drive-tile .ico{width:38px;height:38px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:.62rem;font-weight:700;font-family:'Ubuntu',sans-serif}
.dm-drive-tile .ico.folder{background:rgba(2,121,255,.18);color:#86C6FF}
.dm-drive-tile .ico.pdf{background:rgba(239,68,68,.18);color:#FCA5A5}
.dm-drive-tile .ico.sheet{background:rgba(52,211,153,.18);color:#34D399}
.dm-drive-tile .ico.doc{background:rgba(139,92,246,.18);color:#A78BFA}
.dm-drive-tile .meta{font-size:.62rem;color:rgba(255,255,255,.45);font-variant-numeric:tabular-nums}

/* Invoices/quotes table */
.dm-doc-table{font-size:.76rem;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:10px;overflow:hidden}
.dm-doc-row{display:grid;grid-template-columns:1.4fr .9fr .9fr .8fr .9fr;gap:8px;padding:8px 12px;border-bottom:1px solid rgba(255,255,255,.05);align-items:center}
.dm-doc-row.head{background:rgba(255,255,255,.04);font-size:.62rem;text-transform:uppercase;letter-spacing:.07em;color:rgba(255,255,255,.45);font-family:'Ubuntu',sans-serif;font-weight:700}
.dm-doc-row:last-child{border-bottom:0}
.dm-doc-row strong{color:#fff;font-weight:600}
.dm-doc-row .num{color:#86C6FF;font-variant-numeric:tabular-nums}
.dm-doc-row .amt{color:#fff;font-variant-numeric:tabular-nums;font-weight:600;text-align:right}
.dm-status{font-size:.62rem;padding:2px 8px;border-radius:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;display:inline-block;font-family:'Ubuntu',sans-serif}
.dm-status.paid{background:rgba(52,211,153,.18);color:#34D399}
.dm-status.stamped{background:rgba(2,121,255,.18);color:#86C6FF}
.dm-status.pending{background:rgba(252,211,77,.18);color:#FCD34D}
.dm-status.overdue{background:rgba(239,68,68,.2);color:#FCA5A5}
.dm-status.draft{background:rgba(255,255,255,.08);color:rgba(255,255,255,.6)}
.dm-status.sent{background:rgba(2,121,255,.18);color:#86C6FF}
.dm-status.approved{background:rgba(52,211,153,.18);color:#34D399}
.dm-status.expired{background:rgba(255,255,255,.06);color:rgba(255,255,255,.4)}
.dm-status.converted{background:rgba(255,96,238,.18);color:#FF60EE}

/* Phone-call style button (CRM module only) */
.phone-call-btn{
  position:relative;display:inline-flex;align-items:center;gap:7px;
  padding:6px 12px 6px 11px;border-radius:18px;
  background:linear-gradient(135deg,#16a34a,#15803d);border:1px solid rgba(34,197,94,.6);
  color:#fff;font-size:.7rem;font-weight:700;font-family:'Ubuntu',sans-serif;letter-spacing:.02em;cursor:pointer;
  box-shadow:0 4px 12px rgba(22,163,74,.35);transition:transform .15s ease,box-shadow .2s
}
.phone-call-btn:hover{transform:translateY(-1px);box-shadow:0 6px 16px rgba(22,163,74,.5)}
.phone-call-btn .pcb-ring{position:absolute;inset:-3px;border-radius:20px;border:2px solid rgba(34,197,94,.5);animation:pcbRing 1.6s ease-out infinite;pointer-events:none}
@keyframes pcbRing{0%{opacity:.7;transform:scale(1)}100%{opacity:0;transform:scale(1.18)}}
.phone-call-btn.calling,.phone-call-btn.ended{background:linear-gradient(135deg,#dc2626,#991b1b);border-color:rgba(239,68,68,.6);box-shadow:0 4px 12px rgba(220,38,38,.45)}
.phone-call-btn.calling .pcb-ring,.phone-call-btn.ended .pcb-ring{display:none}
.phone-call-btn.ended{cursor:default;opacity:.85}
.phone-call-btn.ringing i{animation:pcbShake .4s ease-in-out infinite}
@keyframes pcbShake{0%,100%{transform:rotate(-12deg)}50%{transform:rotate(12deg)}}

/* Live caption strip — appears at the bottom of the panel during the call */
.crm-caption{position:absolute;left:0;right:0;bottom:0;padding:10px 16px;background:linear-gradient(to top,rgba(0,0,0,.8),rgba(0,0,0,.55) 70%,transparent);color:rgba(255,255,255,.92);font-size:.78rem;line-height:1.4;font-family:'Ubuntu',sans-serif;font-weight:500;text-align:center;z-index:20;pointer-events:none;transform:translateY(100%);transition:transform .35s ease;letter-spacing:.005em}
.crm-caption.show{transform:translateY(0)}
.crm-caption strong{color:#FF60EE;font-weight:700}

/* Mini email-compose modal that pops during each move */
.crm-mail-pop{position:absolute;top:50%;left:50%;transform:translate(-50%,-46%) scale(.92);width:min(380px,90%);background:#0d1426;border:1px solid rgba(255,255,255,.1);border-radius:14px;box-shadow:0 22px 60px rgba(0,0,0,.55),0 0 0 1px rgba(255,96,238,.12);overflow:hidden;z-index:25;font-family:'Inter',sans-serif;opacity:0;transition:opacity .25s ease,transform .25s cubic-bezier(.4,0,.2,1);pointer-events:none}
.crm-mail-pop.show{opacity:1;transform:translate(-50%,-50%) scale(1)}
.crm-mail-pop.bye{opacity:0;transform:translate(-50%,-54%) scale(.96)}
.cmp-head{display:flex;align-items:center;gap:8px;padding:10px 14px;background:linear-gradient(135deg,rgba(255,96,238,.15),rgba(2,121,255,.1));border-bottom:1px solid rgba(255,255,255,.07)}
.cmp-head .ai{display:inline-flex;align-items:center;gap:5px;font-size:.66rem;color:#FF60EE;font-weight:700;font-family:'Ubuntu',sans-serif;letter-spacing:.04em;text-transform:uppercase}
.cmp-head .sp{margin-left:auto;font-size:.62rem;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.06em;font-family:'Ubuntu',sans-serif}
.cmp-fld{padding:7px 14px;font-size:.74rem;color:rgba(255,255,255,.85);border-bottom:1px solid rgba(255,255,255,.05);display:flex;gap:6px}
.cmp-fld .lbl{color:rgba(255,255,255,.4);min-width:50px;font-size:.7rem}
.cmp-fld .val{flex:1;color:#fff;line-height:1.35}
.cmp-fld .var{color:#86C6FF;background:rgba(2,121,255,.14);padding:0 4px;border-radius:4px;font-family:'Ubuntu',sans-serif;font-size:.7rem}
.cmp-body{padding:10px 14px 12px;font-size:.78rem;color:rgba(255,255,255,.78);line-height:1.5;min-height:64px;position:relative}
.cmp-loading{display:flex;align-items:center;gap:8px;color:#FF60EE;font-size:.74rem;font-weight:600;font-family:'Ubuntu',sans-serif;position:absolute;inset:10px 14px}
.cmp-loading .dot{width:5px;height:5px;border-radius:50%;background:#FF60EE;animation:cmpDot 1.1s infinite ease-in-out}
.cmp-loading .dot:nth-child(2){animation-delay:.15s}.cmp-loading .dot:nth-child(3){animation-delay:.3s}
@keyframes cmpDot{0%,80%,100%{transform:scale(.4);opacity:.4}40%{transform:scale(1);opacity:1}}
.cmp-text{opacity:0;transition:opacity .35s ease}
.cmp-text.show{opacity:1}
.cmp-foot{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:8px 14px;background:rgba(0,0,0,.2);border-top:1px solid rgba(255,255,255,.05)}
.cmp-send{display:inline-flex;align-items:center;gap:5px;background:linear-gradient(135deg,#16a34a,#15803d);border:none;border-radius:8px;padding:5px 12px;color:#fff;font-size:.72rem;font-weight:700;font-family:'Ubuntu',sans-serif;cursor:default;transition:all .3s ease}
.cmp-send.sent{background:rgba(52,211,153,.18);color:#34D399;box-shadow:0 0 0 1px rgba(52,211,153,.4)}

/* Dashboard demo — mirrors /app/index.php real layout (3 stat blocks + charts + recent docs) */
.dm-dash-section{font-size:.62rem;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.4);font-family:'Ubuntu',sans-serif;font-weight:700;margin:14px 0 8px}
.dm-dash-section:first-child{margin-top:0}
.dm-dash-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:6px}
.dm-dash-charts{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:6px}
.dm-dash-chart{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:11px 12px}
.dm-dash-chart-title{font-size:.74rem;color:#fff;font-weight:600;font-family:'Ubuntu',sans-serif;margin-bottom:2px}
.dm-dash-chart-sub{font-size:.62rem;color:rgba(255,255,255,.4);margin-bottom:8px}
.dm-dash-line svg{width:100%;height:60px;display:block}
.dm-dash-line path.fill{fill:rgba(2,121,255,.18)}
.dm-dash-line path.stroke{fill:none;stroke:#60B4FF;stroke-width:2}
.dm-dash-bars{display:flex;flex-direction:column;gap:5px}
.dm-dash-bar{display:flex;align-items:center;gap:8px;font-size:.7rem;color:rgba(255,255,255,.85)}
.dm-dash-bar .name{flex:0 0 96px;color:rgba(255,255,255,.7);font-size:.68rem}
.dm-dash-bar .track{flex:1;height:8px;border-radius:4px;background:rgba(255,255,255,.06);overflow:hidden}
.dm-dash-bar .fill{height:100%;background:linear-gradient(90deg,#0279FF,#FF60EE);border-radius:4px}
.dm-dash-bar .v{flex:0 0 50px;text-align:right;font-variant-numeric:tabular-nums;color:#86C6FF;font-size:.68rem;font-weight:600}
.dm-dash-donut{display:flex;align-items:center;gap:14px}
.dm-dash-donut-svg{flex-shrink:0;width:70px;height:70px;transform:rotate(-90deg)}
.dm-dash-donut-legend{flex:1;font-size:.68rem;color:rgba(255,255,255,.75);line-height:1.5}
.dm-dash-donut-legend i{display:inline-block;width:8px;height:8px;border-radius:2px;margin-right:5px;vertical-align:middle}
.dm-dash-doc-table{font-size:.74rem;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:10px;overflow:hidden;margin-top:14px}
.dm-dash-doc-row{display:grid;grid-template-columns:.9fr .55fr 1.1fr .8fr .8fr .55fr;gap:8px;padding:7px 12px;border-bottom:1px solid rgba(255,255,255,.05);align-items:center}
.dm-dash-doc-row.head{background:rgba(255,255,255,.04);font-size:.6rem;text-transform:uppercase;letter-spacing:.07em;color:rgba(255,255,255,.45);font-family:'Ubuntu',sans-serif;font-weight:700}
.dm-dash-doc-row:last-child{border-bottom:0}
.dm-dash-doc-row strong{color:#fff;font-weight:600}
.dm-dash-doc-row .num{color:#86C6FF;font-variant-numeric:tabular-nums}
.dm-dash-doc-row .amt{color:#fff;font-variant-numeric:tabular-nums;font-weight:600;text-align:right}

/* Spotlight effect — highlight a section/card while Anna talks about it */
.dm-spot{box-shadow:0 0 0 2px rgba(255,96,238,.55),0 0 28px rgba(255,96,238,.35);border-color:rgba(255,96,238,.55) !important;transition:box-shadow .35s ease,border-color .35s}

/* Tiny "Sent" toast that flies up after the modal closes */
.crm-toast{position:absolute;bottom:84px;right:24px;background:rgba(22,163,74,.95);color:#fff;padding:8px 14px;border-radius:10px;font-size:.74rem;font-weight:700;font-family:'Ubuntu',sans-serif;box-shadow:0 12px 30px rgba(22,163,74,.4);z-index:26;opacity:0;transform:translateY(8px);transition:opacity .25s,transform .25s;display:flex;align-items:center;gap:6px;pointer-events:none}
.crm-toast.show{opacity:1;transform:translateY(0)}
.chat-bubble{background:rgba(255,255,255,.07);border-radius:12px 12px 12px 2px;padding:10px 14px;font-size:.82rem;color:rgba(255,255,255,.8);max-width:88%;line-height:1.5;margin-bottom:6px}
.chat-bubble.user{background:rgba(2,121,255,.2);border-radius:12px 12px 2px 12px;margin-left:auto;text-align:right;max-width:80%}
.call-screen{background:#12182B;border-radius:16px;padding:2rem 1.5rem;text-align:center;border:1px solid rgba(255,255,255,.08)}
.waveform{display:flex;align-items:center;justify-content:center;gap:3px;height:40px;margin:1rem 0}
.waveform span{width:3px;border-radius:2px;background:rgba(255,255,255,.35);animation:wave 1.2s ease-in-out infinite}
.waveform span:nth-child(1){height:8px;animation-delay:0s}
.waveform span:nth-child(2){height:18px;animation-delay:.1s}
.waveform span:nth-child(3){height:30px;animation-delay:.2s}
.waveform span:nth-child(4){height:38px;animation-delay:.3s}
.waveform span:nth-child(5){height:30px;animation-delay:.2s}
.waveform span:nth-child(6){height:22px;animation-delay:.1s}
.waveform span:nth-child(7){height:14px;animation-delay:0s}
.waveform span:nth-child(8){height:28px;animation-delay:.15s}
.waveform span:nth-child(9){height:36px;animation-delay:.25s}
.waveform span:nth-child(10){height:20px;animation-delay:.1s}
.waveform span:nth-child(11){height:10px;animation-delay:0s}
@keyframes wave{0%,100%{transform:scaleY(1);opacity:.4}50%{transform:scaleY(1.6);opacity:1}}
.comp-badge{display:inline-flex;align-items:center;gap:5px;background:rgba(255,255,255,.05);border:1px solid var(--border);border-radius:6px;padding:4px 8px;font-size:.72rem;color:rgba(255,255,255,.4);font-family:'Inter',sans-serif}
.panel-fade{animation:panelIn .25s ease-out}
@keyframes panelIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ─── Connect your existing tools (Email · Calendar · Drive sync) ─── */
.connect-tools{margin-top:2.5rem;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);border-radius:18px;padding:2rem 1.75rem}
.ct-head{text-align:center;max-width:680px;margin:0 auto 1.5rem}
.ct-eyebrow{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:#FF60EE;font-family:'Ubuntu',sans-serif}
.ct-head h3{font-size:1.4rem;color:#fff;margin:.4rem 0 .55rem;font-family:'Ubuntu',sans-serif;letter-spacing:-.01em}
.ct-head p{font-size:.88rem;color:rgba(255,255,255,.55);line-height:1.65;margin:0}
.ct-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:1.25rem}
@media (max-width:820px){.ct-grid{grid-template-columns:1fr}}
.ct-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:14px 16px}
.ct-card-head{display:flex;align-items:center;gap:7px;margin-bottom:10px;font-size:.85rem;color:#fff}
.ct-card-head strong{font-family:'Ubuntu',sans-serif;font-weight:600}
.ct-pills{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:10px}
.ct-pills span{font-size:.66rem;padding:3px 8px;border-radius:10px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.09);color:rgba(255,255,255,.78);font-family:'Inter',sans-serif}
.ct-cost{font-size:.74rem;color:rgba(255,255,255,.55);line-height:1.55}
.ct-cost strong{color:rgba(255,255,255,.85);font-weight:600}
.ct-foot{font-size:.8rem;color:rgba(255,255,255,.5);text-align:center;line-height:1.6;padding-top:.4rem;border-top:1px solid rgba(255,255,255,.05);margin-top:.4rem;padding-top:1rem}

/* ─── Calendar module — Calendly-style week grid ─── */
.cal-top{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:12px}
.cal-views{display:flex;gap:0;border-bottom:1px solid rgba(255,255,255,.08);padding-bottom:0}
.cal-view-tab{padding:7px 14px;font-size:.74rem;color:rgba(255,255,255,.55);border-bottom:2px solid transparent;cursor:default;font-family:'Inter',sans-serif;font-weight:500;transition:color .15s}
.cal-view-tab.active{color:#fff;border-bottom-color:#A78BFA;font-weight:600}
.cal-nav{display:flex;align-items:center;gap:10px;font-size:.78rem;color:rgba(255,255,255,.85);font-family:'Ubuntu',sans-serif}
.cal-nav strong{font-weight:600;letter-spacing:.01em}
.cal-arrow{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:6px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);color:rgba(255,255,255,.65);font-size:.85rem;cursor:default}
.cal-today{font-size:.66rem;padding:4px 10px;border-radius:14px;background:rgba(167,139,250,.15);color:#A78BFA;border:1px solid rgba(167,139,250,.3);font-family:'Ubuntu',sans-serif;font-weight:600;letter-spacing:.04em}
.cal-syncs{display:flex;gap:8px;flex-wrap:wrap}
.cal-sync{display:inline-flex;align-items:center;gap:5px;font-size:.66rem;color:rgba(255,255,255,.55);background:rgba(52,211,153,.05);border:1px solid rgba(52,211,153,.15);border-radius:10px;padding:3px 9px;font-family:'Inter',sans-serif}

.cal-grid{background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.07);border-radius:12px;overflow:hidden;margin-top:6px}
.cal-grid-head{display:grid;grid-template-columns:48px repeat(5,1fr);background:rgba(255,255,255,.03);border-bottom:1px solid rgba(255,255,255,.07)}
.cal-h-time{padding:10px 8px}
.cal-h-day{padding:9px 8px;text-align:center;border-left:1px solid rgba(255,255,255,.05);font-family:'Ubuntu',sans-serif}
.cal-h-day span{display:block;font-size:.62rem;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.4);margin-bottom:1px}
.cal-h-day strong{display:block;font-size:1rem;color:#fff;font-weight:600}
.cal-h-day.today strong{color:#A78BFA}
.cal-h-day.today span{color:#A78BFA}
.cal-grid-body{display:grid;grid-template-columns:48px 1fr;height:340px}
.cal-times{display:flex;flex-direction:column;border-right:1px solid rgba(255,255,255,.05);padding:6px 0}
.cal-times span{flex:1;font-size:.62rem;color:rgba(255,255,255,.35);text-align:right;padding-right:8px;line-height:1;font-variant-numeric:tabular-nums;font-family:'Ubuntu',sans-serif;display:flex;align-items:flex-start;justify-content:flex-end}
.cal-cols{display:grid;grid-template-columns:repeat(5,1fr);position:relative}
.cal-col{position:relative;border-left:1px solid rgba(255,255,255,.05);background:linear-gradient(to bottom,transparent 11.1%,rgba(255,255,255,.025) 11.1%,rgba(255,255,255,.025) 11.2%,transparent 11.2%);background-size:100% 11.1%}
.cal-evt{position:absolute;left:4px;right:4px;border-radius:8px;padding:7px 9px;font-size:.7rem;line-height:1.3;color:#fff;border:1px solid;overflow:hidden;cursor:default;transition:transform .15s,box-shadow .15s}
.cal-evt:hover{transform:translateY(-1px);box-shadow:0 6px 16px rgba(0,0,0,.35);z-index:2}
.cal-evt strong{display:block;font-weight:700;font-family:'Ubuntu',sans-serif;font-size:.74rem;letter-spacing:.005em}
.cal-evt span{display:block;font-size:.65rem;opacity:.85;margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cal-evt i{display:block;font-style:normal;font-size:.6rem;opacity:.65;margin-top:3px;font-variant-numeric:tabular-nums}
.cal-evt.blue{background:rgba(2,121,255,.18);border-color:rgba(2,121,255,.55);color:#cfe5ff}
.cal-evt.purple{background:rgba(167,139,250,.18);border-color:rgba(167,139,250,.55);color:#e2d8ff}
.cal-evt.amber{background:rgba(252,211,77,.16);border-color:rgba(252,211,77,.5);color:#fdeab8}
.cal-evt.pink{background:rgba(255,96,238,.18);border-color:rgba(255,96,238,.55);color:#ffd0fa}

/* ─── Module sidebar — category coloring (4 cats, palette-respecting) ─── */
.mod-cat-label{padding:.75rem 1rem .5rem;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--text-dim);font-family:'Ubuntu',sans-serif;margin-top:.5rem}
.mod-cat-label:first-child{padding-top:0;margin-top:0}
.mod-cat-label[data-cat="prod"]{color:#86C6FF}
.mod-cat-label[data-cat="mgmt"]{color:#FF60EE}
.mod-cat-label[data-cat="mkt"] {color:#60B4FF}

/* Subtle icon tint by category — non-active state only */
.mod-item[data-cat="prod"]:not(.active) .mod-icon{color:rgba(134,198,255,.5)}
.mod-item[data-cat="mgmt"]:not(.active) .mod-icon{color:rgba(255,96,238,.5)}
.mod-item[data-cat="mkt"]:not(.active)  .mod-icon{color:rgba(96,180,255,.5)}
.mod-item[data-cat="prod"]:hover:not(.active) .mod-icon{color:#86C6FF}
.mod-item[data-cat="mgmt"]:hover:not(.active) .mod-icon{color:#FF60EE}
.mod-item[data-cat="mkt"]:hover:not(.active)  .mod-icon{color:#60B4FF}

/* ─── End-to-end flow nodes — colored by phase (entry · convert · revenue) ─── */
.flow-node[data-phase="entry"]  {background:rgba(134,198,255,.08);border-color:rgba(134,198,255,.32);color:#86C6FF}
.flow-node[data-phase="entry"]:hover  {background:rgba(134,198,255,.14);border-color:#86C6FF;color:#cfe5ff}
.flow-node[data-phase="convert"]{background:rgba(255,96,238,.08);border-color:rgba(255,96,238,.3);color:#FF60EE}
.flow-node[data-phase="convert"]:hover{background:rgba(255,96,238,.14);border-color:#FF60EE;color:#ffd0fa}
.flow-node[data-phase="revenue"]{background:rgba(96,180,255,.08);border-color:rgba(96,180,255,.3);color:#60B4FF}
.flow-node[data-phase="revenue"]:hover{background:rgba(96,180,255,.14);border-color:#60B4FF;color:#cfe5ff}

/* ════════════════════════════════════════════════════════════════════════
   Theme toggle (sun ↔ moon) — mismo patrón que /app/.
   Vive en el navbar; el SVG visible depende de [data-theme] en <html>.
   ════════════════════════════════════════════════════════════════════════ */
.theme-toggle{
  background:transparent;border:1px solid rgba(255,255,255,.12);border-radius:8px;
  padding:6px 8px;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.65);transition:background .15s,color .15s,border-color .15s;
}
.theme-toggle:hover{background:rgba(255,255,255,.06);color:#fff;border-color:rgba(255,255,255,.22)}
.theme-toggle svg{width:16px;height:16px}
.theme-toggle .theme-ico{display:none}
html[data-theme="light"] .theme-toggle .theme-ico-moon{display:block}
html[data-theme="dark"]  .theme-toggle .theme-ico-sun{display:block}
html:not([data-theme]) .theme-toggle .theme-ico-moon{display:block}

/* ════════════════════════════════════════════════════════════════════════
   Dark navbar background — separated out so light mode can override it.
   La nav antes traía el bg en inline style; ahora vive en una clase para
   que [data-theme="light"] pueda invertirla sin pelear con !important.
   ════════════════════════════════════════════════════════════════════════ */
.navbar-omb{background:rgba(8,12,20,.95)}
.navbar-omb .navbar-brand-divider{border-left:1px solid rgba(255,255,255,.15)}
.navbar-omb .navbar-brand-aes{color:rgba(255,255,255,.9)}
.navbar-omb .navbar-brand-sub{color:rgba(255,255,255,.35)}
.navbar-omb .btn-lang{color:rgba(255,255,255,.6);border:1px solid var(--border)}
.navbar-omb .nav-linkedin{color:rgba(255,255,255,.4)}

/* ════════════════════════════════════════════════════════════════════════
   LIGHT THEME (data-theme="light")
   ════════════════════════════════════════════════════════════════════════
   Estrategia: redefinir tokens base + overrides en superficies con colores
   hardcoded (rgba blanco). NO se rediseñan componentes — solo se invierte
   contraste para que el mismo layout se lea sobre fondo claro.
   Paleta clara: bg #FFFFFF / #F4F6FA, texto #0F172A, muted #475569.
   Acentos (#0279FF, #FF60EE) se conservan tal cual.
   ════════════════════════════════════════════════════════════════════════ */
html[data-theme="light"]{
  --dark:#FFFFFF;
  --dark2:#F4F6FA;
  --card-bg:#FFFFFF;
  --border:rgba(15,23,42,.10);
  --text-muted:rgba(15,23,42,.62);
  --text-dim:rgba(15,23,42,.38);
  /* En light el rosa neón (#FF60EE) pierde contraste sobre fondo claro.
     Lo mapeamos a azul OMB (#0279FF). Dark queda intacto. */
  --pink:#0279FF;
}
html[data-theme="light"] body{background:#FFFFFF;color:#0F172A}
html[data-theme="light"] h1,
html[data-theme="light"] h2,
html[data-theme="light"] h3,
html[data-theme="light"] h4,
html[data-theme="light"] h5,
html[data-theme="light"] h6{color:#0F172A}
html[data-theme="light"] p{color:#475569}

/* ── Navbar ── */
html[data-theme="light"] .navbar-omb{background:rgba(255,255,255,.92);border-bottom:1px solid rgba(15,23,42,.08)}
html[data-theme="light"] .navbar-omb .navbar-brand-divider{border-left-color:rgba(15,23,42,.12)}
html[data-theme="light"] .navbar-omb .navbar-brand-aes{color:#0F172A}
html[data-theme="light"] .navbar-omb .navbar-brand-sub{color:#64748B}
html[data-theme="light"] .navbar .nav-link{color:#475569 !important}
html[data-theme="light"] .navbar .nav-link:hover{color:#0F172A !important}
html[data-theme="light"] .navbar-omb .btn-lang{color:#475569;border-color:rgba(15,23,42,.14)}
html[data-theme="light"] .navbar-omb .nav-linkedin{color:#94A3B8}
html[data-theme="light"] .navbar-omb .nav-linkedin:hover{color:#0F172A}
html[data-theme="light"] .navbar-toggler-icon{filter:invert(1) hue-rotate(180deg) brightness(.55)}
html[data-theme="light"] .theme-toggle{border-color:rgba(15,23,42,.14);color:#475569}
html[data-theme="light"] .theme-toggle:hover{background:rgba(15,23,42,.05);color:#0F172A;border-color:rgba(15,23,42,.22)}
/* Dropdown EN/ES/PT/FR — Bootstrap usa dropdown-menu-dark, lo invertimos */
html[data-theme="light"] .dropdown-menu-dark{background:#FFFFFF;border:1px solid rgba(15,23,42,.1);box-shadow:0 8px 24px rgba(15,23,42,.08)}
html[data-theme="light"] .dropdown-menu-dark .dropdown-item{color:#0F172A}
html[data-theme="light"] .dropdown-menu-dark .dropdown-item:hover,
html[data-theme="light"] .dropdown-menu-dark .dropdown-item:focus{background:rgba(2,121,255,.08);color:#0F172A}
html[data-theme="light"] .dropdown-menu-dark .dropdown-item.active{background:rgba(2,121,255,.12);color:#0F172A}

/* ── Hero ── */
html[data-theme="light"] .hero{background:#FFFFFF}
html[data-theme="light"] .hero-grid{background-image:linear-gradient(rgba(2,121,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(2,121,255,.06) 1px,transparent 1px)}
html[data-theme="light"] .hero-glow-1{background:radial-gradient(circle,rgba(2,121,255,.12) 0%,transparent 65%)}
html[data-theme="light"] .hero-glow-2{background:radial-gradient(circle,rgba(255,96,238,.09) 0%,transparent 65%)}
html[data-theme="light"] .hero-lead{color:#475569}
html[data-theme="light"] .hero-stat-num{color:#0F172A}
html[data-theme="light"] .hero-stat-lbl{color:#64748B}
html[data-theme="light"] .hero-screen{background:#FFFFFF;border:1px solid rgba(15,23,42,.08);box-shadow:0 12px 40px rgba(15,23,42,.06)}
html[data-theme="light"] .hero-chat-bubble{background:rgba(2,121,255,.08);border-color:rgba(2,121,255,.18);color:#0F172A}
html[data-theme="light"] .hero-chat-bubble.right{background:rgba(255,96,238,.08);border-color:rgba(255,96,238,.18)}
html[data-theme="light"] .agent-name{color:#0F172A}
html[data-theme="light"] .agent-status{color:#64748B}
html[data-theme="light"] .btn-demo-secondary{background:rgba(15,23,42,.04);border:1px solid rgba(15,23,42,.12);color:#0F172A}
html[data-theme="light"] .btn-demo-secondary:hover{background:rgba(15,23,42,.08);color:#0F172A}

/* ── Sections backgrounds ── */
html[data-theme="light"] .sec-flow,
html[data-theme="light"] .sec-agents,
html[data-theme="light"] .sec-proof,
html[data-theme="light"] .sec-compare.darker{background:#F4F6FA}
html[data-theme="light"] .sec-value,
html[data-theme="light"] .sec-pillars,
html[data-theme="light"] .sec-cta,
html[data-theme="light"] .sec-compare.dark{background:#FFFFFF}

/* ── Flow strip ── */
html[data-theme="light"] .flow-node{background:#FFFFFF;border-color:rgba(15,23,42,.1);color:#475569;box-shadow:0 1px 2px rgba(15,23,42,.04)}
html[data-theme="light"] .flow-node:hover{background:rgba(255,96,238,.06);color:#0F172A}
html[data-theme="light"] .flow-arrow,
html[data-theme="light"] .flow-caption{color:#64748B}

/* ── Cards (value, pillar, agent) ── */
html[data-theme="light"] .value-card,
html[data-theme="light"] .pillar-card,
html[data-theme="light"] .agent-card,
html[data-theme="light"] .table-wrap{background:#FFFFFF;border:1px solid rgba(15,23,42,.08);box-shadow:0 1px 3px rgba(15,23,42,.04)}
html[data-theme="light"] .value-card:hover,
html[data-theme="light"] .pillar-card:hover{border-color:rgba(15,23,42,.16);box-shadow:0 8px 24px rgba(15,23,42,.08)}
html[data-theme="light"] .value-card h3,
html[data-theme="light"] .pillar-card h3,
html[data-theme="light"] .agent-card-name{color:#0F172A}
html[data-theme="light"] .value-card p,
html[data-theme="light"] .pillar-card p,
html[data-theme="light"] .agent-card-role{color:#475569}
html[data-theme="light"] .agent-avatar{background:rgba(15,23,42,.05)}
html[data-theme="light"] .module-pill{background:rgba(15,23,42,.04);border-color:rgba(15,23,42,.1);color:#64748B}

/* ── Compare tables ── */
html[data-theme="light"] .compare-table thead th{color:#64748B;border-bottom-color:rgba(15,23,42,.1)}
html[data-theme="light"] .compare-table thead th.omb-col{color:#0F172A}
html[data-theme="light"] .compare-table tbody td{border-bottom-color:rgba(15,23,42,.06);color:#475569}
html[data-theme="light"] .compare-table tbody td:first-child{color:#0F172A}
html[data-theme="light"] .compare-table tbody tr:hover td{background:rgba(15,23,42,.02)}
html[data-theme="light"] .check-yes{color:rgba(15,23,42,.55)}
html[data-theme="light"] .check-no{color:rgba(15,23,42,.18)}

/* ── CTA final ── */
html[data-theme="light"] .cta-box p{color:#475569}
html[data-theme="light"] .btn-cta-alt{border-color:rgba(15,23,42,.12);color:#475569}
html[data-theme="light"] .btn-cta-alt:hover{border-color:rgba(15,23,42,.25);color:#0F172A}

/* ── Footer ── */
html[data-theme="light"] .site-footer{background:#F4F6FA;border-top-color:rgba(15,23,42,.08)}
html[data-theme="light"] .site-footer p,
html[data-theme="light"] .site-footer a,
html[data-theme="light"] .site-footer small{color:#64748B}
html[data-theme="light"] .site-footer a:hover{color:#0F172A}

/* ── Module explorer (mod-item / mini-app demo) ── */
html[data-theme="light"] .mod-item{color:#475569}
html[data-theme="light"] .mod-item:hover{color:#0F172A;background:rgba(15,23,42,.03)}
html[data-theme="light"] .mod-item.active{color:#0F172A;background:rgba(255,96,238,.08)}
html[data-theme="light"] .mod-item:not(.active) .mod-icon{color:#94A3B8}
html[data-theme="light"] .mod-demo-head-text h3,
html[data-theme="light"] .mod-demo-chat-name{color:#0F172A}
html[data-theme="light"] .mod-demo-head-text p,
html[data-theme="light"] .mod-demo-chat-role{color:#64748B}
html[data-theme="light"] .mod-demo-body{color:#0F172A}
html[data-theme="light"] .mod-demo-chat{background:rgba(255,255,255,.96);border-top-color:rgba(255,96,238,.2);border-left-color:rgba(255,96,238,.2);box-shadow:-12px -12px 40px rgba(15,23,42,.08)}

/* ── Mini-app shared cards (dm-*) ── */
html[data-theme="light"] .dm-card{background:#FFFFFF;border:1px solid rgba(15,23,42,.08);box-shadow:0 1px 2px rgba(15,23,42,.03)}
html[data-theme="light"] .dm-card h4{color:#64748B}
html[data-theme="light"] .dm-card.alert{background:rgba(252,211,77,.12);border-color:rgba(252,211,77,.35)}
html[data-theme="light"] .dm-kpi-label{color:#64748B}
html[data-theme="light"] .dm-kpi-val{color:#0F172A}
html[data-theme="light"] .dm-kpi-delta{color:#64748B}
html[data-theme="light"] .dm-cli{color:#0F172A;border-bottom-color:rgba(15,23,42,.06)}
html[data-theme="light"] .dm-cli strong{color:#0F172A}
html[data-theme="light"] .dm-cli span{color:#0279FF}
html[data-theme="light"] .dm-table .dm-trow{border-bottom-color:rgba(15,23,42,.06)}
html[data-theme="light"] .dm-table .dm-trow.head{color:#64748B;border-bottom-color:rgba(15,23,42,.12)}
html[data-theme="light"] .dm-table .dm-trow strong{color:#0F172A}
html[data-theme="light"] .dm-table .dm-trow span:not(:first-child){color:#0279FF}
html[data-theme="light"] .dm-bar{background:rgba(15,23,42,.06)}
html[data-theme="light"] .dm-bp-head h4{color:#0F172A}
html[data-theme="light"] .dm-bp-head p{color:#64748B}

/* ── Pillars card border + glow softer in light ── */
html[data-theme="light"] .sec-pillars::before{background:radial-gradient(circle,rgba(255,96,238,.05) 0%,transparent 70%)}
html[data-theme="light"] .sec-cta::before{background:radial-gradient(ellipse 80% 60% at 50% 100%,rgba(255,96,238,.07) 0%,transparent 60%)}

/* ── Proof section ── */
html[data-theme="light"] .proof-num{color:#0F172A}
html[data-theme="light"] .proof-lbl{color:#64748B}
html[data-theme="light"] .proof-sep{background:rgba(15,23,42,.1)}

/* ── Animaciones (suaves en ambos temas) ──
   Las transiciones de bg/color las maneja cada selector arriba.
   No agregamos transitions globales para evitar lag al cargar. */

/* ════════════════════════════════════════════════════════════════════════
   Surfaces base — clases que reemplazan inline rgba(255,255,255,X) que
   rompían contraste en light. Se definen aquí (en ambos temas) para que
   los .php sólo carguen una clase y el tema decida color/bg.
   ════════════════════════════════════════════════════════════════════════ */
.mh-aes{color:rgba(255,255,255,.85)}
.mh-aes-sub{color:rgba(255,255,255,.3)}
.mod-explorer{background:rgba(255,255,255,.025);border:1px solid var(--border)}
.ct-foot-strong{color:#fff}

/* Light overrides para los componentes recién pasados a clases. */
html[data-theme="light"] .mh-aes{color:#0F172A}
html[data-theme="light"] .mh-aes-sub{color:#64748B}
html[data-theme="light"] .mod-explorer{background:#FFFFFF;border:1px solid rgba(15,23,42,.08);box-shadow:0 1px 3px rgba(15,23,42,.04)}
html[data-theme="light"] #mod-sidebar{border-right-color:rgba(15,23,42,.08) !important}

/* ── Connect-tools (Email · Calendar · Drive) en light ── */
html[data-theme="light"] .connect-tools{background:#FFFFFF;border:1px solid rgba(15,23,42,.08);box-shadow:0 1px 3px rgba(15,23,42,.04)}
html[data-theme="light"] .ct-head h3{color:#0F172A}
html[data-theme="light"] .ct-head p{color:#475569}
html[data-theme="light"] .ct-card{background:#F8FAFC;border:1px solid rgba(15,23,42,.08)}
html[data-theme="light"] .ct-card-head{color:#0F172A}
html[data-theme="light"] .ct-pills span{background:#FFFFFF;border:1px solid rgba(15,23,42,.1);color:#475569}
html[data-theme="light"] .ct-cost{color:#475569}
html[data-theme="light"] .ct-cost strong{color:#0F172A}
html[data-theme="light"] .ct-foot{color:#475569;border-top-color:rgba(15,23,42,.08)}
html[data-theme="light"] .ct-foot-strong{color:#0F172A}

/* ── Modules sidebar category labels en light ──
   El "general" usa var(--text-dim) — ya flipea solo. Los con color hard-coded
   (prod azul, mgmt rosa, mkt cian) los conservamos: son acento de marca. */

/* ── Modal waitlist + modal time: tarjetas + inputs en light ── */
html[data-theme="light"] #wl-overlay .wl-card,
html[data-theme="light"] #wt-overlay .wt-card{background:#FFFFFF;border:1px solid rgba(15,23,42,.08);color:#0F172A;box-shadow:0 20px 60px rgba(15,23,42,.12)}
html[data-theme="light"] #wl-overlay h3,
html[data-theme="light"] #wt-overlay h3{color:#0F172A}
html[data-theme="light"] #wl-overlay .wl-lead,
html[data-theme="light"] #wt-overlay .wt-lead{color:#475569}
html[data-theme="light"] #wl-overlay input{background:#F4F6FA;border:1px solid rgba(15,23,42,.1);color:#0F172A}
html[data-theme="light"] #wl-overlay input::placeholder{color:#94A3B8}
html[data-theme="light"] #wl-overlay button.wl-close{background:rgba(15,23,42,.04);border-color:rgba(15,23,42,.08);color:#475569}
html[data-theme="light"] #wl-overlay .wl-x,
html[data-theme="light"] #wt-overlay .wt-x{color:#94A3B8}
html[data-theme="light"] #wl-overlay .wl-x:hover,
html[data-theme="light"] #wt-overlay .wt-x:hover{color:#0F172A}

/* ── Counter bar en light (texto blanco hardcoded) ── */
html[data-theme="light"] .counter-bar,
html[data-theme="light"] [class*="counter"]{color:inherit}

/* ── Compliance / Methodology / Time-CTA — fallback robusto ──
   Estas secciones tienen muchos inline styles con rgba(255,255,255,X).
   Les bajamos un layer por background y dejamos que h2/h3/p hereden los
   colores semánticos ya redefinidos arriba. Si quedan textos sueltos, se
   ajustan en una segunda pasada. */
html[data-theme="light"] .sec-compliance,
html[data-theme="light"] .sec-methodology,
html[data-theme="light"] .sec-time{background:#FFFFFF}

/* ── Counter bar superior (#nav-ticker) en light ──
   Tiene mucho inline color:rgba(255,255,255,X) que en light queda invisible.
   Override scoped al ticker con !important — afecta sólo este componente. */
html[data-theme="light"] #nav-ticker{background:rgba(255,255,255,.95) !important;border-bottom-color:rgba(255,96,238,.18) !important}
html[data-theme="light"] #nav-ticker [style*="color:rgba(255,255,255"]{color:#64748B !important}

/* ── Texto inline blanco (rgba blanco con cualquier opacity) ──
   Global porque algunas secciones no tienen clase en su <section>. Los botones
   pintados (.btn-*) usan color:#fff vía CSS clase, no inline, así que no se
   tocan aquí. Si un inline rgba blanco vive sobre fondo de marca, hay
   override más específico abajo. */
html[data-theme="light"] [style*="color:rgba(255,255,255"]{color:#475569 !important}

/* Headings y párrafos con color:#fff hardcoded inline → slate-900/700.
   Scope a tags de texto: NO toca <a>, <button> que sí necesitan blanco
   sobre el bg pintado. */
html[data-theme="light"] h1[style*="color:#fff"],
html[data-theme="light"] h2[style*="color:#fff"],
html[data-theme="light"] h3[style*="color:#fff"],
html[data-theme="light"] h4[style*="color:#fff"],
html[data-theme="light"] h5[style*="color:#fff"],
html[data-theme="light"] h6[style*="color:#fff"],
html[data-theme="light"] p[style*="color:#fff"],
html[data-theme="light"] span[style*="color:#fff"],
html[data-theme="light"] div[style*="color:#fff"],
html[data-theme="light"] strong[style*="color:#fff"]{color:#0F172A !important}

/* Colores rosa hardcoded inline (#FF60EE / rgba 255,96,238) en light → azul.
   Coincide con el override de --pink arriba, pero el var no aplica en inline. */
html[data-theme="light"] [style*="color:#FF60EE"],
html[data-theme="light"] [style*="color: #FF60EE"]{color:#0279FF !important}
html[data-theme="light"] [style*="color:rgba(255,96,238"]{color:rgba(2,121,255,.85) !important}
html[data-theme="light"] [style*="background:rgba(255,96,238"]{background:rgba(2,121,255,.07) !important}
html[data-theme="light"] [style*="border:1px solid rgba(255,96,238"],
html[data-theme="light"] [style*="border-color:rgba(255,96,238"]{border-color:rgba(2,121,255,.25) !important}
/* Gradientes con #FF60EE → versión con azul. Pattern matching limitado. */
html[data-theme="light"] [style*="linear-gradient(135deg,#FF60EE"]{background:linear-gradient(135deg,#0279FF,#0064d8) !important}
html[data-theme="light"] [style*="linear-gradient(135deg, #FF60EE"]{background:linear-gradient(135deg,#0279FF,#0064d8) !important}

/* ── Botones primarios en light: gradiente azul (no rosa→magenta) ── */
html[data-theme="light"] .btn-cta-main{background:linear-gradient(135deg,#0279FF,#0064d8) !important}
html[data-theme="light"] .btn-cta-main:hover{box-shadow:0 8px 30px rgba(2,121,255,.4) !important}
html[data-theme="light"] .btn-demo-primary:hover{background:#0064d8 !important}
html[data-theme="light"] .btn-nav-demo:hover{background:#0064d8 !important}
html[data-theme="light"] .btn-nav-login{border-color:rgba(15,23,42,.18);color:#0F172A}
html[data-theme="light"] .btn-nav-login:hover{background:rgba(2,121,255,.06);border-color:rgba(2,121,255,.35);color:#0279FF}

/* ── Box-shadow rosa hardcoded en CSS classes (call-btn glow, etc.) ── */
html[data-theme="light"] .call-btn.pink{background:rgba(2,121,255,.12);color:#0279FF;border-color:rgba(2,121,255,.3)}
html[data-theme="light"] .call-btn.pink:hover{background:rgba(2,121,255,.22);box-shadow:0 0 20px rgba(2,121,255,.35)}
html[data-theme="light"] .call-btn.try-me::after{border-color:rgba(2,121,255,.55)}
html[data-theme="light"] .call-btn.try-me.is-playing{background:rgba(2,121,255,.32);box-shadow:0 0 24px rgba(2,121,255,.55)}
html[data-theme="light"] .call-btn.try-me.is-playing::after{border-color:rgba(2,121,255,.85)}
html[data-theme="light"] .agent-av.pink{background:rgba(2,121,255,.18);color:#0279FF}
html[data-theme="light"] .value-icon.pink{background:rgba(2,121,255,.12);color:#0279FF}
html[data-theme="light"] .voice-badge{color:#0279FF;background:rgba(2,121,255,.1);border-color:rgba(2,121,255,.2)}
html[data-theme="light"] .agent-card:hover{border-color:rgba(2,121,255,.3);background:rgba(2,121,255,.04)}
html[data-theme="light"] .pillar-card.p-pink::before{background:#0279FF}
html[data-theme="light"] .mod-item.active{color:#0F172A;background:rgba(2,121,255,.08);border-left-color:#0279FF}
html[data-theme="light"] .mod-item.active .mod-icon,
html[data-theme="light"] .mod-item.active::after,
html[data-theme="light"] .mod-item:hover::after{color:#0279FF !important}
html[data-theme="light"] .mod-cat-label[data-cat="mgmt"]{color:#0279FF}
html[data-theme="light"] .check-omb{color:#0279FF}
html[data-theme="light"] .compare-table thead th.omb-col::after{background:linear-gradient(90deg,#0279FF,#86C6FF)}
html[data-theme="light"] .value-card:hover::before{background:linear-gradient(90deg,#0279FF,#86C6FF)}
html[data-theme="light"] .ct-eyebrow,
html[data-theme="light"] .section-eyebrow{color:#0279FF}
html[data-theme="light"] .aes-badge{color:#0279FF;background:rgba(2,121,255,.08);border-color:rgba(2,121,255,.35)}
html[data-theme="light"] .hero h1 .accent{color:#0279FF}
html[data-theme="light"] .flow-agent-node{background:rgba(2,121,255,.12);border-color:rgba(2,121,255,.4);box-shadow:0 0 10px rgba(2,121,255,.25),0 0 20px rgba(2,121,255,.12)}
html[data-theme="light"] .flow-node[data-phase="convert"]{background:rgba(2,121,255,.08);border-color:rgba(2,121,255,.3);color:#0279FF}
html[data-theme="light"] .flow-node[data-phase="convert"]:hover{background:rgba(2,121,255,.14);border-color:#0279FF;color:#0064d8}

/* Glow del hero (rosa → azul tenue) */
html[data-theme="light"] .hero-glow-2{background:radial-gradient(circle,rgba(2,121,255,.08) 0%,transparent 65%)}
html[data-theme="light"] .sec-pillars::before{background:radial-gradient(circle,rgba(2,121,255,.05) 0%,transparent 70%)}
html[data-theme="light"] .sec-cta::before{background:radial-gradient(ellipse 80% 60% at 50% 100%,rgba(2,121,255,.06) 0%,transparent 60%)}
html[data-theme="light"] .navbar-omb{border-bottom-color:rgba(2,121,255,.12)}

/* Background radial pink inline (time-cta corner glow, etc.) */
html[data-theme="light"] [style*="radial-gradient(circle,rgba(255,96,238"]{background:radial-gradient(circle,rgba(2,121,255,.08) 0%,transparent 70%) !important}

/* Gradiente del divisor brand (90deg, transparent → pink → cyan → blue → transparent).
   En light dejamos un degradado azul más suave. */
html[data-theme="light"] [style*="linear-gradient(90deg,transparent 0%,#FF60EE"]{background:linear-gradient(90deg,transparent 0%,#0279FF 25%,#86C6FF 50%,#0279FF 75%,transparent 100%) !important}

/* ── Time-CTA card y banner inferior — fondo azul tenue en light ── */
html[data-theme="light"] [style*="background:rgba(255,96,238,.04"]{background:rgba(2,121,255,.04) !important}
html[data-theme="light"] [style*="background:rgba(255,96,238,.05"]{background:rgba(2,121,255,.05) !important}
html[data-theme="light"] [style*="background:rgba(255,96,238,.08"]{background:rgba(2,121,255,.06) !important}
html[data-theme="light"] [style*="background:rgba(255,96,238,.12"]{background:rgba(2,121,255,.10) !important}
html[data-theme="light"] [style*="background:rgba(255,96,238,.15"]{background:rgba(2,121,255,.12) !important}

/* ════════════════════════════════════════════════════════════════════════
   Mini-app demos (.dm-*) en light — el explorer renderea cards estilo dashboard
   con MUCHOS rgba(255,255,255,X) hardcoded en CSS classes (no inline). Este
   bloque les da contraste apropiado sobre fondo claro. Color semánticos
   (rojo/verde/ámbar/cian) se mantienen — son señales, no decoración.
   ════════════════════════════════════════════════════════════════════════ */

/* CRM stat cards (.dm-stat) y dashboard secciones */
html[data-theme="light"] .dm-stat,
html[data-theme="light"] .dm-bp-grid > div,
html[data-theme="light"] .dm-job,
html[data-theme="light"] .dm-topbar,
html[data-theme="light"] .dm-agent-card,
html[data-theme="light"] .dm-mail-list,
html[data-theme="light"] .dm-doc-table,
html[data-theme="light"] .dm-kan-col,
html[data-theme="light"] .dm-drive-tile{background:#FFFFFF !important;border:1px solid rgba(15,23,42,.10) !important}
html[data-theme="light"] .dm-stat-l,
html[data-theme="light"] .dm-stat-d,
html[data-theme="light"] .dm-stat-t,
html[data-theme="light"] .dm-dash-section,
html[data-theme="light"] .dm-bp-grid span,
html[data-theme="light"] .dm-job-foot,
html[data-theme="light"] .dm-topbar-label,
html[data-theme="light"] .dm-tab,
html[data-theme="light"] .dm-agent-role,
html[data-theme="light"] .dm-agents-legend,
html[data-theme="light"] .dm-kan-head,
html[data-theme="light"] .dm-kan-hint,
html[data-theme="light"] .dm-mail-row .when,
html[data-theme="light"] .dm-mail-row .snip,
html[data-theme="light"] .dm-doc-row.head,
html[data-theme="light"] .dm-drive-tile .meta{color:#64748B !important}
html[data-theme="light"] .dm-stat-v,
html[data-theme="light"] .dm-bp-grid strong,
html[data-theme="light"] .dm-job-head,
html[data-theme="light"] .dm-agent-name,
html[data-theme="light"] .dm-mail-row .from,
html[data-theme="light"] .dm-mail-row.unread,
html[data-theme="light"] .dm-doc-row strong,
html[data-theme="light"] .dm-doc-row .amt,
html[data-theme="light"] .dm-drive-tile,
html[data-theme="light"] .dm-kan-card,
html[data-theme="light"] .dm-tab.active{color:#0F172A !important}

/* Variantes coloreadas de .dm-stat-v (mantienen sus colores semánticos) */
html[data-theme="light"] .dm-stat-v.bl{color:#0279FF !important}
html[data-theme="light"] .dm-stat-v.dim{color:#64748B !important}
/* .te (verde), .am (ámbar), .pu (morado), .rd (rojo) ya contrastan en light */

/* Topbar y tabs */
html[data-theme="light"] .dm-topbar-pill{color:#475569}
html[data-theme="light"] .dm-tabs{border-bottom-color:rgba(15,23,42,.10)}
html[data-theme="light"] .dm-tab.active{border-bottom-color:#0279FF}

/* Mail */
html[data-theme="light"] .dm-mail-row{color:#475569;border-bottom-color:rgba(15,23,42,.06)}
html[data-theme="light"] .dm-mail-row.unread{background:rgba(2,121,255,.04)}
html[data-theme="light"] .dm-mail-row .snip strong{color:#0F172A}

/* Doc table (invoices/quotes) */
html[data-theme="light"] .dm-doc-row{border-bottom-color:rgba(15,23,42,.06)}
html[data-theme="light"] .dm-doc-row.head{background:rgba(15,23,42,.03)}
html[data-theme="light"] .dm-doc-row .num{color:#0279FF}

/* Kan-board cards */
html[data-theme="light"] .dm-kan-card{background:#FFFFFF;border:1px solid rgba(15,23,42,.1)}
html[data-theme="light"] .dm-kan-card .meta{color:#64748B}
html[data-theme="light"] .dm-kan-card .val{color:#0279FF}
html[data-theme="light"] .dm-kan-count{background:rgba(15,23,42,.08);color:#0F172A}

/* Drive avatars y agent stats */
html[data-theme="light"] .dm-agent-stats{color:#475569}
html[data-theme="light"] .dm-agent-stats strong{color:#0279FF}
html[data-theme="light"] .dm-agent-av{border-color:rgba(15,23,42,.10)}

/* Stages CRM */
html[data-theme="light"] .dm-stage{background:rgba(2,121,255,.04);border-color:rgba(2,121,255,.18)}
html[data-theme="light"] .dm-stage-h,
html[data-theme="light"] .dm-stage-c{color:#0279FF}
html[data-theme="light"] .dm-stage-c{background:rgba(2,121,255,.12)}

/* Status chips: en light suben opacidad pero conservan el matiz semántico */
html[data-theme="light"] .dm-status.paid,
html[data-theme="light"] .dm-status.approved{background:rgba(16,185,129,.15);color:#047857}
html[data-theme="light"] .dm-status.stamped,
html[data-theme="light"] .dm-status.sent{background:rgba(2,121,255,.15);color:#0064d8}
html[data-theme="light"] .dm-status.pending{background:rgba(245,158,11,.18);color:#92400e}
html[data-theme="light"] .dm-status.overdue{background:rgba(239,68,68,.15);color:#b91c1c}
html[data-theme="light"] .dm-status.draft,
html[data-theme="light"] .dm-status.expired{background:rgba(15,23,42,.08);color:#475569}
html[data-theme="light"] .dm-status.converted{background:rgba(2,121,255,.15);color:#0064d8}

/* ════════════════════════════════════════════════════════════════════════
   PARALLAX sections — el bg es una imagen oscura con overlay rgba(8,12,20,.94)
   que NO cambia con el tema. Por tanto el texto SIEMPRE debe ser blanco
   (incluso en light). Re-aseveramos color blanco aquí con mayor especificidad
   que los overrides genéricos de inline-style.
   ════════════════════════════════════════════════════════════════════════ */
html[data-theme="light"] .parallax-content h1,
html[data-theme="light"] .parallax-content h2,
html[data-theme="light"] .parallax-content h3,
html[data-theme="light"] .parallax-content h4,
html[data-theme="light"] .parallax-content h5,
html[data-theme="light"] .parallax-content h6,
html[data-theme="light"] .parallax-content [style*="color:#fff"]{color:#fff !important}
html[data-theme="light"] .parallax-content p,
html[data-theme="light"] .parallax-content span,
html[data-theme="light"] .parallax-content div,
html[data-theme="light"] .parallax-content [style*="color:rgba(255,255,255"]{color:rgba(255,255,255,.85) !important}
/* Eyebrow rosa dentro de parallax → mantenerlo rosa porque va sobre fondo oscuro,
   no sobre fondo claro. */
html[data-theme="light"] .parallax-content [style*="color:rgba(255,96,238"]{color:rgba(255,96,238,.7) !important}

/* ════════════════════════════════════════════════════════════════════════
   MODAL waitlist (.wl-modal y #wl-overlay) — en light: card blanca, texto
   oscuro, inputs claros. En dark queda intacto.
   ════════════════════════════════════════════════════════════════════════ */
html[data-theme="light"] .wl-modal{background:#FFFFFF !important;border:1px solid rgba(15,23,42,.10) !important;box-shadow:0 25px 60px rgba(15,23,42,.18)}
html[data-theme="light"] .wl-modal h3{color:#0F172A !important}
html[data-theme="light"] .wl-modal p,
html[data-theme="light"] .wl-modal [style*="color:rgba(255,255,255,.5"],
html[data-theme="light"] .wl-modal [style*="color:rgba(255,255,255,.55"],
html[data-theme="light"] .wl-modal [style*="color:rgba(255,255,255,.6"]{color:#475569 !important}
html[data-theme="light"] .wl-modal [style*="color:rgba(255,255,255,.3"],
html[data-theme="light"] .wl-modal [style*="color:rgba(255,255,255,.35"]{color:#94A3B8 !important}
html[data-theme="light"] .wl-modal input{background:#F4F6FA !important;border:1px solid rgba(15,23,42,.10) !important;color:#0F172A !important}
html[data-theme="light"] .wl-modal input::placeholder{color:#94A3B8}
html[data-theme="light"] .wl-modal [style*="background:rgba(255,255,255,.06"]{background:rgba(15,23,42,.04) !important;border:1px solid rgba(15,23,42,.08) !important}
/* Close button (✕) en light */
html[data-theme="light"] .wl-modal button[onclick*="closeContact"][style*="background:none"],
html[data-theme="light"] .wl-modal button[onclick*="closeWaitlist"][style*="background:none"]{color:#94A3B8 !important}

/* Modal _soon.php (PT/FR) — usa .wl-card en lugar de .wl-modal */
html[data-theme="light"] #wl-overlay .wl-card{background:#FFFFFF !important;border-color:rgba(15,23,42,.10) !important;box-shadow:0 25px 60px rgba(15,23,42,.18)}
html[data-theme="light"] #wl-overlay .wl-card h3{color:#0F172A !important}
html[data-theme="light"] #wl-overlay .wl-lead{color:#475569 !important}
html[data-theme="light"] #wl-overlay input{background:#F4F6FA !important;border-color:rgba(15,23,42,.10) !important;color:#0F172A !important}
html[data-theme="light"] #wl-overlay button.wl-close{background:rgba(15,23,42,.04) !important;border-color:rgba(15,23,42,.08) !important;color:#475569 !important}
html[data-theme="light"] #wl-overlay .wl-x{color:#94A3B8 !important}

/* ════════════════════════════════════════════════════════════════════════
   Dashboard demo charts (.dm-dash-*) en light — el bloque que muestra
   "Charts / Top 5 clients / Invoice status / Period compare / Recent docs"
   tiene su propio set de clases con rgba(255,255,255,X) hardcoded.
   ════════════════════════════════════════════════════════════════════════ */
html[data-theme="light"] .dm-dash-chart{background:#FFFFFF;border:1px solid rgba(15,23,42,.10)}
html[data-theme="light"] .dm-dash-chart-title{color:#0F172A}
html[data-theme="light"] .dm-dash-chart-sub{color:#64748B}

/* Top 5 clients — barras horizontales */
html[data-theme="light"] .dm-dash-bar{color:#0F172A}
html[data-theme="light"] .dm-dash-bar .name{color:#475569}
html[data-theme="light"] .dm-dash-bar .track{background:rgba(15,23,42,.07)}
/* .dm-dash-bar .fill ya tiene gradiente azul→rosa que en light se convierte
   azul→azul gracias al override de --pink. */
html[data-theme="light"] .dm-dash-bar .v{color:#0279FF}

/* Donut legend ("Paid · 89%" etc.) */
html[data-theme="light"] .dm-dash-donut-legend{color:#475569}

/* Recent documents table */
html[data-theme="light"] .dm-dash-doc-table{background:#FFFFFF;border:1px solid rgba(15,23,42,.10)}
html[data-theme="light"] .dm-dash-doc-row{border-bottom-color:rgba(15,23,42,.06)}
html[data-theme="light"] .dm-dash-doc-row.head{background:rgba(15,23,42,.03);color:#64748B}
html[data-theme="light"] .dm-dash-doc-row strong,
html[data-theme="light"] .dm-dash-doc-row .amt{color:#0F172A}
html[data-theme="light"] .dm-dash-doc-row .num{color:#0279FF}

/* Línea SVG de comparación (inline stroke:rgba(255,255,255,.35)) */
html[data-theme="light"] .dm-dash-line path[style*="stroke:rgba(255,255,255"]{stroke:rgba(15,23,42,.35) !important}

/* ════════════════════════════════════════════════════════════════════════
   Chat bubbles (overlay 40% bottom-right de cada demo) — bg blanco con
   borde tenue y texto oscuro en light. La burbuja "user" sigue azul.
   ════════════════════════════════════════════════════════════════════════ */
html[data-theme="light"] .chat-bubble{background:rgba(15,23,42,.04);color:#0F172A;border:1px solid rgba(15,23,42,.06)}
html[data-theme="light"] .chat-bubble.user{background:rgba(2,121,255,.12);color:#0F172A;border-color:rgba(2,121,255,.2)}

/* Chat header (Anna Bennett, Executive Assistant) */
html[data-theme="light"] .mod-demo-chat{background:rgba(255,255,255,.96);border-top-color:rgba(2,121,255,.18);border-left-color:rgba(2,121,255,.18);box-shadow:-12px -12px 40px rgba(15,23,42,.08)}
html[data-theme="light"] .mod-demo-chat-head{border-bottom-color:rgba(15,23,42,.06)}
html[data-theme="light"] .mod-demo-chat-name{color:#0F172A}
html[data-theme="light"] .mod-demo-chat-role{color:#64748B}

/* Botón "Call Anna" (call-btn pink/blue) — en light el rosa pasa a azul.
   Variante green permanece verde porque es semántica de estado activo. */
html[data-theme="light"] .call-btn.blue{background:rgba(2,121,255,.12);color:#0064d8;border-color:rgba(2,121,255,.3)}
html[data-theme="light"] .call-btn.blue:hover{background:rgba(2,121,255,.22);box-shadow:0 0 20px rgba(2,121,255,.25)}

/* ════════════════════════════════════════════════════════════════════════
   Fallback panel (Companies/Contacts/Clients/Catalog) — para módulos sin
   demoHtml. Renderea "Chat with VS" + "Voice preview" en cards con bg
   hardcoded en hex (#0A1020 / #12182B). En light deben quedar claros.
   ════════════════════════════════════════════════════════════════════════ */

/* Chat container inline background:#0A1020 → blanco con borde tenue */
html[data-theme="light"] [style*="background:#0A1020"]{background:#FFFFFF !important;border:1px solid rgba(15,23,42,.10) !important}

/* .call-screen (voice preview card) en light */
html[data-theme="light"] .call-screen{background:#F4F6FA;border:1px solid rgba(15,23,42,.10)}

/* Waveform — barras grises tenues sobre fondo claro */
html[data-theme="light"] .waveform span{background:rgba(15,23,42,.30)}

/* "Partial solutions" badges (.comp-badge) — chip light */
html[data-theme="light"] .comp-badge{background:#FFFFFF;border:1px solid rgba(15,23,42,.12);color:#475569}

/* Borde de divisores dentro del fallback chat (rgba 255,255,255,.06/.07) */
html[data-theme="light"] [style*="border:1px solid rgba(255,255,255,.07"],
html[data-theme="light"] [style*="border-bottom:1px solid rgba(255,255,255,.06"],
html[data-theme="light"] [style*="border-top:1px solid rgba(255,255,255,.06"]{border-color:rgba(15,23,42,.08) !important}

/* Input "Write a message..." (background:rgba(255,255,255,.05)) ya cubierto por
   override genérico de background:rgba(255,255,255,.0X). Color del placeholder
   también ya cubierto por override genérico. */

/* ════════════════════════════════════════════════════════════════════════
   Calendar demo (.cal-*) en light — el demo del Calendar usa colores
   pastel sobre fondo oscuro. En light hay que oscurecer el texto y el bg.
   ════════════════════════════════════════════════════════════════════════ */

/* Top tabs / nav / sync chips */
html[data-theme="light"] .cal-views{border-bottom-color:rgba(15,23,42,.10)}
html[data-theme="light"] .cal-view-tab{color:#475569}
html[data-theme="light"] .cal-view-tab.active{color:#0F172A}
html[data-theme="light"] .cal-nav{color:#0F172A}
html[data-theme="light"] .cal-arrow{background:#FFFFFF;border-color:rgba(15,23,42,.10);color:#475569}
html[data-theme="light"] .cal-today{background:rgba(167,139,250,.18);color:#6D28D9;border-color:rgba(167,139,250,.4)}
html[data-theme="light"] .cal-sync{background:rgba(16,185,129,.10);color:#047857;border-color:rgba(16,185,129,.25)}

/* Grid container y celdas */
html[data-theme="light"] .cal-grid{background:#FFFFFF;border:1px solid rgba(15,23,42,.10)}
html[data-theme="light"] .cal-grid-head{background:rgba(15,23,42,.03);border-bottom-color:rgba(15,23,42,.08)}
html[data-theme="light"] .cal-h-day{border-left-color:rgba(15,23,42,.06)}
html[data-theme="light"] .cal-h-day span{color:#64748B}
html[data-theme="light"] .cal-h-day strong{color:#0F172A}
html[data-theme="light"] .cal-h-day.today strong,
html[data-theme="light"] .cal-h-day.today span{color:#6D28D9}
html[data-theme="light"] .cal-times{border-right-color:rgba(15,23,42,.06)}
html[data-theme="light"] .cal-times span{color:#64748B}

/* Event blocks — bg más sólido + texto oscuro para legibilidad en light */
html[data-theme="light"] .cal-evt{color:#0F172A}
html[data-theme="light"] .cal-evt strong{color:#0F172A}
html[data-theme="light"] .cal-evt.blue{background:rgba(2,121,255,.14);border-color:rgba(2,121,255,.5);color:#0064d8}
html[data-theme="light"] .cal-evt.blue strong{color:#0064d8}
html[data-theme="light"] .cal-evt.purple{background:rgba(167,139,250,.18);border-color:rgba(167,139,250,.5);color:#5B21B6}
html[data-theme="light"] .cal-evt.purple strong{color:#5B21B6}
html[data-theme="light"] .cal-evt.amber{background:rgba(252,211,77,.22);border-color:rgba(245,158,11,.55);color:#92400E}
html[data-theme="light"] .cal-evt.amber strong{color:#92400E}
html[data-theme="light"] .cal-evt.pink{background:rgba(255,96,238,.14);border-color:rgba(255,96,238,.45);color:#A21CAF}
html[data-theme="light"] .cal-evt.pink strong{color:#A21CAF}
html[data-theme="light"] .cal-evt span,
html[data-theme="light"] .cal-evt i{color:inherit;opacity:.85}

/* Borders inline `border:...rgba(255,255,255,X)` también se rompen
   (queda invisible o gris ultra-claro). Override genérico por sección. */
html[data-theme="light"] [style*="border:1px solid rgba(255,255,255"],
html[data-theme="light"] [style*="border-top:1px solid rgba(255,255,255"],
html[data-theme="light"] [style*="border-bottom:1px solid rgba(255,255,255"],
html[data-theme="light"] [style*="border-left:1px solid rgba(255,255,255"],
html[data-theme="light"] [style*="border-right:1px solid rgba(255,255,255"]{
  border-color:rgba(15,23,42,.10) !important;
}

/* Backgrounds inline en `rgba(255,255,255,X)` muy bajos (cards/chips) — hacerlos
   sutiles en light. Sólo afecta backgrounds de baja opacidad blancos. */
html[data-theme="light"] [style*="background:rgba(255,255,255,.0"],
html[data-theme="light"] [style*="background:rgba(255,255,255,.04"],
html[data-theme="light"] [style*="background:rgba(255,255,255,.05"],
html[data-theme="light"] [style*="background:rgba(255,255,255,.06"],
html[data-theme="light"] [style*="background:rgba(255,255,255,.08"]{
  background:#F8FAFC !important;
}

/* Backgrounds de divisores `background:rgba(255,255,255,X)` (líneas verticales)
   — flipearlas a borders oscuros tenues. */
html[data-theme="light"] [style*="background:rgba(255,255,255,.1"],
html[data-theme="light"] [style*="background:rgba(255,255,255,.15"],
html[data-theme="light"] [style*="background:rgba(255,255,255,.2"]{
  background:rgba(15,23,42,.12) !important;
}
