/* Actualización Internet horizontal + Gastos de Tienda avanzado */
.panel-subtitle{margin:4px 0 0;color:var(--muted);font-size:14px}.compact-strip{grid-template-columns:repeat(5,minmax(150px,1fr));margin-bottom:16px}.compact-strip>div{min-height:86px}.net-panel-horizontal{overflow:hidden}.net-head{align-items:flex-start}.net-head .tools{align-items:center}.net-head .search{min-width:300px}.net-legend{display:flex;gap:10px;flex-wrap:wrap;padding:12px 18px;border-bottom:1px solid var(--border)}.net-legend span{display:flex;align-items:center;gap:8px;border:1px solid var(--border);background:rgba(255,255,255,.04);border-radius:999px;padding:8px 12px;font-weight:900;font-size:13px}.dot{width:10px;height:10px;border-radius:50%;display:inline-block}.dot.casa{background:#10b981}.dot.punto-alto{background:#3b82f6}.dot.sectorial{background:#8b5cf6}.dot.cliente{background:#06b6d4}.net-projects{padding:18px;display:grid;gap:18px;background:radial-gradient(circle at top left,rgba(16,185,129,.12),transparent 30%),radial-gradient(circle at bottom right,rgba(59,130,246,.10),transparent 28%)}.net-project-card{border:1px solid var(--border);border-radius:20px;background:rgba(255,255,255,.025);padding:14px;min-width:980px;overflow:auto}.net-project-title{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:14px}.net-project-title h3{font-size:20px;margin:0}.net-project-title small{color:var(--muted);font-weight:800}.concept-row{display:flex;align-items:flex-start;gap:14px}.concept-col{display:flex;align-items:flex-start;gap:14px}.points-col{display:flex;gap:14px;flex-wrap:wrap}.point-flow{display:flex;align-items:flex-start;gap:14px}.sectorial-group{display:flex;gap:14px;flex-wrap:wrap;align-items:flex-start}.sectorial-block{display:flex;flex-direction:column;gap:10px;align-items:center}.flow-arrow{font-size:26px;font-weight:900;color:#10b981;padding-top:62px;text-shadow:0 0 18px rgba(16,185,129,.55)}.flow-arrow.small{font-size:22px;padding-top:60px;color:#3b82f6}.concept-node{width:220px;border-radius:16px;border:1px solid var(--border);border-top:4px solid #10b981;background:var(--panel2);padding:10px;box-shadow:var(--shadow)}.concept-node.punto-alto{border-top-color:#3b82f6}.concept-node.sectorial{border-top-color:#8b5cf6}.concept-node.router,.concept-node.switch,.concept-node.enlace,.concept-node.equipo-extra{border-top-color:#f59e0b}.concept-top{display:flex;gap:8px;align-items:center}.concept-icon{width:34px;height:34px;border-radius:11px;display:grid;place-items:center;background:rgba(16,185,129,.12);border:1px solid rgba(16,185,129,.25);font-size:19px;flex:0 0 auto}.concept-top div{flex:1;min-width:0}.concept-top b{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.concept-top small{display:block;color:var(--muted);font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.icon-action{width:34px;height:34px;border:0;border-radius:11px;background:#3156db;color:#fff;cursor:pointer;font-weight:900}.concept-mini{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:10px}.concept-mini span{display:block;border-radius:10px;background:rgba(255,255,255,.05);padding:7px 8px;color:var(--muted);font-weight:800;font-size:11px}.concept-mini b{display:block;color:var(--text);font-size:13px;margin-top:2px}.concept-note{border-radius:10px;background:rgba(255,255,255,.05);padding:8px;margin:8px 0 0;color:var(--muted);font-size:12px;line-height:1.25}.client-branch{display:grid;grid-template-columns:repeat(2,minmax(118px,1fr));gap:8px;max-width:330px}.client-node{border:1px solid rgba(6,182,212,.35);background:rgba(6,182,212,.09);border-radius:13px;padding:8px;min-width:118px}.client-node b{display:block;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.client-node span{display:block;color:#38bdf8;font-weight:900;font-size:12px}.client-node small{display:block;color:var(--muted);font-weight:900}.concept-empty,.no-client{border:1px dashed var(--border);border-radius:14px;color:var(--muted);padding:18px;display:block;min-width:140px;text-align:center}.tiny-actions{display:flex;gap:4px;align-items:center;white-space:nowrap}.tiny-actions button{width:28px;height:28px;border:0;border-radius:7px;background:rgba(255,255,255,.07);cursor:pointer;font-size:15px}.tiny-actions button:hover{transform:translateY(-1px);filter:brightness(1.2)}.compact-table table th,.compact-table table td{white-space:nowrap}.net-alert{display:inline-flex;align-items:center;justify-content:center;min-width:62px;padding:7px 10px;border-radius:12px;font-weight:900}.net-alert.ok{background:#c8fff0;color:#047857}.net-alert.warn{background:#fff3bf;color:#9a6700}.net-alert.today{background:#ffd7a8;color:#9a3412}.net-alert.danger{background:#ffd1d1;color:#b91c1c}.net-alert.muted{background:rgba(148,163,184,.18);color:var(--muted)}.detail-card{background:var(--panel2);border:1px solid var(--border);border-radius:18px;padding:18px}.detail-card h3{font-size:22px;margin-bottom:12px}.detail-card p{margin:8px 0;color:var(--muted)}.expense-cards{grid-template-columns:repeat(3,minmax(190px,1fr))}.expense-help{display:grid;gap:10px;padding:16px}.expense-help div{border:1px solid var(--border);background:var(--panel2);border-radius:14px;padding:12px}.expense-help b{display:block;margin-bottom:4px}.expense-help span{color:var(--muted)}.expense-mini-summary{display:grid;grid-template-columns:repeat(3,minmax(140px,1fr));gap:12px;padding:14px 20px;border-bottom:1px solid var(--border)}.expense-mini-summary div{background:var(--panel2);border:1px solid var(--border);border-radius:14px;padding:12px}.expense-mini-summary small{display:block;color:var(--muted);font-weight:900;margin-bottom:5px}.expense-mini-summary b{font-size:20px}.expense-chip{display:inline-flex;border-radius:999px;padding:6px 10px;background:rgba(16,185,129,.12);color:#10b981;font-weight:900}.expense-table small{color:var(--muted)}
body.light .net-legend span,body.light .concept-mini span,body.light .concept-note{background:rgba(15,23,42,.04)}body.light .net-project-card{background:#fff}body.light .net-projects{background:linear-gradient(180deg,#f7fbff,#edf5ff)}
@media(max-width:1100px){.compact-strip,.expense-cards{grid-template-columns:repeat(2,1fr)}.net-head{display:block}.net-head .tools{margin-top:12px}.net-project-card{min-width:850px}.concept-node{width:200px}.client-branch{grid-template-columns:1fr}}@media(max-width:700px){.compact-strip,.expense-cards,.expense-mini-summary{grid-template-columns:1fr}.net-project-card{min-width:760px}.net-head .search{min-width:100%}}

/* ===============================
   INTERNET V4 - compacto y cliente primero
================================ */
.compact-tabs{margin-bottom:14px}
.compact-tools{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.compact-tools .search{min-width:270px}
.mini-kpis{grid-template-columns:repeat(5,minmax(130px,1fr));gap:12px}
.mini-kpis>div{padding:12px 14px;border-radius:16px;background:var(--card);border:1px solid var(--border)}
.mini-kpis small{display:block;color:var(--muted);font-weight:900;margin-bottom:5px}
.mini-kpis b{font-size:18px;line-height:1.1}
.compact-map-panel{overflow:hidden}
.internet-map-head{align-items:flex-start}
.internet-top-switches{display:flex;gap:12px;align-items:center;flex-wrap:wrap;padding:10px 18px;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:rgba(255,255,255,.02)}
.tech-switch{display:inline-flex;align-items:center;gap:8px;font-weight:900;color:var(--text);cursor:pointer}
.tech-switch input{display:none}
.tech-switch span{width:46px;height:24px;border-radius:999px;background:rgba(148,163,184,.28);position:relative;border:1px solid var(--border);transition:.25s}
.tech-switch span::after{content:'';position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#fff;transition:.25s}
.tech-switch input:checked + span{background:rgba(16,185,129,.3);border-color:rgba(16,185,129,.55)}
.tech-switch input:checked + span::after{left:24px;background:#10b981}
.compact-legend{padding:10px 18px;gap:8px}
.compact-legend span{padding:7px 10px;font-size:12px}
.internet-map-body{padding:16px;display:grid;gap:14px;background:radial-gradient(circle at top left,rgba(16,185,129,.08),transparent 28%),radial-gradient(circle at bottom right,rgba(59,130,246,.08),transparent 24%)}
.empty-focus-card{border:1px dashed var(--border);border-radius:18px;background:rgba(255,255,255,.03);padding:22px;text-align:center;color:var(--muted)}
.empty-focus-card h3{margin:0 0 8px;color:var(--text)}
.project-lane-card{border:1px solid var(--border);border-radius:18px;background:rgba(255,255,255,.025);padding:14px;overflow:auto}
.project-lane-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:12px}
.project-lane-head h3{margin:0;font-size:19px}
.project-lane-head small{color:var(--muted);font-weight:800}
.project-lanes{display:grid;gap:12px}
.route-lane{border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:10px;background:rgba(255,255,255,.025);overflow-x:auto}
.route-track{display:flex;align-items:center;gap:10px;min-width:max-content}
.route-node{width:170px;flex:0 0 170px;border-radius:15px;border:1px solid var(--border);border-top:3px solid #10b981;background:var(--panel2);padding:8px;box-shadow:var(--shadow)}
.route-node.punto-alto{border-top-color:#3b82f6}
.route-node.sectorial{border-top-color:#8b5cf6}
.route-node.router,.route-node.switch,.route-node.enlace,.route-node.equipo-extra{border-top-color:#f59e0b}
.route-node-top{display:flex;align-items:center;gap:7px;margin-bottom:6px}
.route-node-icon{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;background:rgba(255,255,255,.06);font-size:17px;flex:0 0 auto}
.route-node-name{min-width:0;flex:1}
.route-node-name b{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:13px;line-height:1.1}
.route-node-name small{display:block;color:var(--muted);font-size:11px;font-weight:900;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mini-edit{width:28px;height:28px;border:0;border-radius:9px;background:#3156db;color:#fff;cursor:pointer;font-weight:900;font-size:13px;flex:0 0 auto}
.route-node-grid{display:grid;grid-template-columns:1fr 1fr;gap:5px}
.route-node-grid span{display:block;border-radius:10px;background:rgba(255,255,255,.05);padding:5px 6px}
.route-node-grid small{display:block;color:var(--muted);font-size:10px;font-weight:900}
.route-node-grid b{display:block;font-size:12px;margin-top:1px;line-height:1.15}
.route-node-note{margin-top:6px;padding:7px;border-radius:10px;background:rgba(255,255,255,.05);font-size:12px;color:var(--muted);line-height:1.2;min-height:34px}
.route-arrow-box{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;min-width:58px;flex:0 0 58px}
.route-arrow-line{display:block;width:44px;height:2px;background:linear-gradient(90deg,#10b981,#3b82f6);position:relative;border-radius:999px}
.route-arrow-line::after{content:'➜';position:absolute;right:-10px;top:-12px;color:#38bdf8;font-size:18px;font-weight:900}
.route-arrow-box small{font-size:10px;font-weight:900;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}
.route-clients-box{display:flex;align-items:center;flex-wrap:wrap;gap:8px;max-width:440px;min-height:42px}
.route-no-client{display:inline-flex;border:1px dashed var(--border);border-radius:12px;padding:9px 12px;color:var(--muted);font-weight:800}
.client-chip-map{border:1px solid rgba(6,182,212,.35);background:rgba(6,182,212,.1);border-radius:12px;padding:7px 10px;cursor:pointer;text-align:left;min-width:96px;transition:.2s}
.client-chip-map:hover{transform:translateY(-1px);filter:brightness(1.08)}
.client-chip-map.active{border-color:#10b981;background:rgba(16,185,129,.14);box-shadow:0 0 0 1px rgba(16,185,129,.25)}
.client-chip-map b{display:block;font-size:12px;line-height:1.1}
.client-chip-map span{display:block;font-size:11px;color:#38bdf8;font-weight:900;margin-top:3px}
.table-icon-actions{display:flex;align-items:center;gap:5px;white-space:nowrap}
.mini-icon{width:28px;height:28px;border-radius:7px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.03);color:#fff;cursor:pointer;font-weight:900;display:grid;place-items:center;font-size:13px}
.mini-icon.view{color:#15d4cc;border-color:rgba(21,212,204,.35)}
.mini-icon.edit{color:#f59e0b;border-color:rgba(245,158,11,.35)}
.mini-icon.pay{color:#22c55e;border-color:rgba(34,197,94,.35)}
.mini-icon.pay.done{background:rgba(34,197,94,.12)}
.mini-icon.delete{color:#ef4444;border-color:rgba(239,68,68,.35)}
.mini-icon:hover{transform:translateY(-1px);filter:brightness(1.08)}
.client-link-btn{padding:0;border:0;background:none;color:var(--text);font:inherit;font-weight:900;cursor:pointer;text-align:left}
.client-link-btn:hover{text-decoration:underline;color:#38bdf8}
.focused-project{box-shadow:0 0 0 1px rgba(16,185,129,.22)}
.compact-guide p{margin:8px 0}

body.light .project-lane-card,
body.light .route-lane{background:#fff}
body.light .internet-top-switches,
body.light .route-node-grid span,
body.light .route-node-note,
body.light .route-node-icon{background:rgba(15,23,42,.04)}

@media(max-width:1100px){
  .mini-kpis{grid-template-columns:repeat(2,1fr)}
  .internet-map-head{display:block}
  .compact-tools{margin-top:12px}
}
@media(max-width:760px){
  .mini-kpis{grid-template-columns:1fr}
  .compact-tools .search{min-width:100%;width:100%}
  .internet-top-switches{padding:10px 12px}
  .internet-map-body,.project-lane-card{padding:12px}
  .route-node{width:148px;flex-basis:148px;padding:7px}
  .route-node-grid b{font-size:11px}
  .route-clients-box{max-width:320px}
  .net-alert{min-width:56px;padding:6px 8px;font-size:12px}
  .table-icon-actions{gap:4px}
}

/* ===============================
   INTERNET PRO V5 - red compacta, móvil y cables animados
================================ */
.compact-tabs{margin-bottom:12px}.internet-tabs .tab{min-height:42px;padding:0 18px}.internet-resume-cards{grid-template-columns:repeat(3,minmax(180px,1fr))}.one-line-kpis{display:flex;gap:8px;overflow-x:auto;padding:2px 0 12px;scrollbar-width:thin}.one-line-kpis>div{min-width:118px;background:var(--card);border:1px solid var(--border);border-radius:14px;padding:9px 12px}.one-line-kpis small{display:block;color:var(--muted);font-weight:900;font-size:11px}.one-line-kpis b{display:block;font-size:17px;margin-top:2px}.client-first-panel{overflow:hidden}.client-head-mobile{align-items:flex-start}.client-tools-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.compact-btn{min-height:38px;padding:0 12px;border-radius:12px;font-size:13px}.client-search-row{padding:0 18px 12px}.client-search-row .search{width:100%;max-width:520px}.client-chip-grid{display:flex;gap:8px;overflow-x:auto;padding:0 18px 14px;border-bottom:1px solid var(--border);scrollbar-width:thin}.client-live-card{min-width:120px;max-width:140px;border:1px solid rgba(6,182,212,.28);background:linear-gradient(135deg,rgba(6,182,212,.13),rgba(49,86,219,.08));border-radius:14px;padding:10px;text-align:left;color:var(--text);cursor:pointer;position:relative;box-shadow:0 10px 24px rgba(0,0,0,.13)}.client-live-card b{display:block;font-size:13px;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-left:14px}.client-live-card small{display:block;color:#38bdf8;font-size:11px;font-weight:900;margin-left:14px;margin-top:3px}.pulse-dot{position:absolute;left:10px;top:13px;width:8px;height:8px;border-radius:50%;background:#64748b}.pulse-dot.on{background:#10b981;box-shadow:0 0 0 rgba(16,185,129,.55);animation:pulseNet 1.6s infinite}.pulse-dot.off{background:#ef4444}.small-empty{padding:12px;min-width:180px}.mobile-table-one table{font-size:13px}.mobile-table-one th,.mobile-table-one td{padding:8px 7px!important;white-space:nowrap}.table-icon-actions{display:flex;gap:4px;align-items:center;white-space:nowrap}.mini-icon{width:24px;height:24px;border-radius:6px;border:1px solid rgba(255,255,255,.13);background:rgba(255,255,255,.04);display:inline-grid;place-items:center;color:#fff;cursor:pointer;font-size:12px;font-weight:900;padding:0}.mini-icon.view{color:#22d3ee;border-color:rgba(34,211,238,.35)}.mini-icon.edit{color:#f59e0b;border-color:rgba(245,158,11,.35)}.mini-icon.pay{color:#22c55e;border-color:rgba(34,197,94,.35)}.mini-icon.pay.done{background:rgba(34,197,94,.14)}.mini-icon.delete{color:#ef4444;border-color:rgba(239,68,68,.35)}.mini-icon:hover{transform:translateY(-1px);filter:brightness(1.15)}.client-link-btn{padding:0;border:0;background:transparent;color:var(--text);font:inherit;font-weight:900;cursor:pointer}.client-link-btn:hover{color:#38bdf8;text-decoration:underline}.pro-map-panel{overflow:hidden}.pro-map-head{align-items:flex-start}.pro-map-tools{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.pro-map-tools .search{min-width:280px}.pro-switches{padding:9px 16px;background:rgba(255,255,255,.025);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.tech-switch{display:inline-flex;align-items:center;gap:8px;font-weight:900;cursor:pointer;color:var(--text);font-size:13px}.tech-switch input{display:none}.tech-switch span{width:38px;height:22px;border-radius:999px;background:rgba(148,163,184,.3);border:1px solid var(--border);position:relative;transition:.2s}.tech-switch span:after{content:'';position:absolute;left:2px;top:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:.2s}.tech-switch input:checked+span{background:rgba(16,185,129,.32);border-color:rgba(16,185,129,.55)}.tech-switch input:checked+span:after{left:18px;background:#10b981}.circuit-map-body{padding:14px;display:grid;gap:14px;background:radial-gradient(circle at 0 0,rgba(16,185,129,.11),transparent 30%),radial-gradient(circle at 100% 100%,rgba(59,130,246,.13),transparent 25%)}.network-board{border:1px solid rgba(80,116,178,.35);border-radius:18px;background:linear-gradient(135deg,rgba(12,20,40,.75),rgba(15,28,54,.75));padding:12px;overflow:hidden;box-shadow:0 18px 40px rgba(0,0,0,.18)}.focused-network{box-shadow:0 0 0 1px rgba(16,185,129,.22),0 0 36px rgba(16,185,129,.08)}.network-title{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:10px}.network-title h3{font-size:17px;margin:0}.network-title small{color:var(--muted);font-weight:800}.circuit-routes{display:grid;gap:9px}.circuit-route{border:1px solid rgba(255,255,255,.06);border-radius:15px;background:rgba(3,8,23,.25);padding:9px;overflow-x:auto}.circuit-track{display:flex;align-items:center;gap:8px;min-width:max-content}.node-micro{width:84px;height:72px;flex:0 0 84px;border-radius:14px;border:1px solid rgba(59,130,246,.28);background:rgba(15,23,42,.8);color:var(--text);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;position:relative;overflow:hidden;box-shadow:0 8px 20px rgba(0,0,0,.18)}.node-micro:before{content:'';position:absolute;inset:0;border-top:2px solid #10b981;opacity:.9}.node-micro.punto-alto:before{border-top-color:#3b82f6}.node-micro.sectorial:before{border-top-color:#8b5cf6}.node-micro.router:before,.node-micro.switch:before,.node-micro.enlace:before,.node-micro.gen2-emisor:before,.node-micro.gen2-receptor:before,.node-micro.starlink:before{border-top-color:#f59e0b}.node-micro:hover{transform:translateY(-2px);filter:brightness(1.12)}.node-photo{width:30px;height:30px;border-radius:10px;display:grid;place-items:center;background:rgba(255,255,255,.07);overflow:hidden}.node-photo img{width:100%;height:100%;object-fit:cover}.node-photo span{display:grid;place-items:center;font-size:18px}.node-micro b{font-size:11px;line-height:1.05;max-width:74px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wire{width:62px;min-width:62px;height:38px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px}.wire span{width:55px;height:3px;border-radius:999px;background:linear-gradient(90deg,rgba(16,185,129,.2),#10b981,rgba(56,189,248,.2));position:relative;overflow:hidden;box-shadow:0 0 14px rgba(56,189,248,.2)}.wire span:before{content:'';position:absolute;top:0;bottom:0;width:22px;background:linear-gradient(90deg,transparent,#fff,transparent);animation:wireFlow 1.25s linear infinite}.wire span:after{content:'➜';position:absolute;right:-3px;top:-13px;font-size:18px;color:#38bdf8;text-shadow:0 0 10px rgba(56,189,248,.7)}.wire small{font-size:9px;color:var(--muted);font-weight:900;text-transform:uppercase}.wire.radio span{background:linear-gradient(90deg,rgba(139,92,246,.2),#8b5cf6,rgba(56,189,248,.2));height:2px;border-style:dashed}.wire.radio small{color:#c4b5fd}.wire.wifi span{background:linear-gradient(90deg,rgba(6,182,212,.15),#06b6d4,rgba(16,185,129,.18))}.clients-terminal{display:flex;align-items:center;gap:6px;flex-wrap:wrap;max-width:390px}.client-terminal{min-width:84px;border:1px solid rgba(6,182,212,.35);background:rgba(6,182,212,.1);border-radius:12px;color:var(--text);padding:7px 9px;text-align:left;cursor:pointer;position:relative;overflow:hidden}.client-terminal:before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:#06b6d4;box-shadow:0 0 14px #06b6d4}.client-terminal.active{border-color:#10b981;background:rgba(16,185,129,.13)}.client-terminal.active:before{background:#10b981}.client-terminal b{display:block;font-size:11px;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.client-terminal span{display:block;color:#38bdf8;font-size:10px;font-weight:900;margin-top:2px}.route-no-client{display:inline-flex;border:1px dashed var(--border);border-radius:12px;padding:8px 10px;color:var(--muted);font-size:12px}.neon-empty{background:linear-gradient(135deg,rgba(15,23,42,.65),rgba(30,41,59,.5));border:1px dashed rgba(56,189,248,.25);border-radius:18px;padding:22px;text-align:center;color:var(--muted)}.neon-empty h3{margin:0 0 8px;color:var(--text)}.node-detail-pro .node-detail-head{display:flex;gap:12px;align-items:center;margin-bottom:10px}.node-detail-icon{width:54px;height:54px;border-radius:16px;display:grid;place-items:center;background:rgba(56,189,248,.1);border:1px solid rgba(56,189,248,.25);overflow:hidden}.node-detail-icon img{width:100%;height:100%;object-fit:cover}.node-detail-icon span{font-size:28px}.btn.danger{background:#ef4444;color:#fff}.btn.danger:hover{filter:brightness(1.08)}
@keyframes wireFlow{0%{left:-25px}100%{left:60px}}@keyframes pulseNet{0%{box-shadow:0 0 0 0 rgba(16,185,129,.55)}70%{box-shadow:0 0 0 8px rgba(16,185,129,0)}100%{box-shadow:0 0 0 0 rgba(16,185,129,0)}}
body.light .network-board{background:#fff}body.light .circuit-route{background:rgba(15,23,42,.03)}body.light .node-micro{background:#f8fafc}body.light .client-live-card{background:#fff}.form-actions .btn.danger{border-color:#ef4444}
@media(max-width:900px){.internet-resume-cards{grid-template-columns:repeat(2,1fr)}.pro-map-head,.client-head-mobile{display:block}.pro-map-tools,.client-tools-row{margin-top:10px}.pro-map-tools .search{min-width:100%;width:100%}.client-search-row{padding:0 12px 10px}.client-chip-grid{padding:0 12px 12px}.circuit-map-body{padding:10px}.network-board{padding:10px}.wire{width:46px;min-width:46px}.wire span{width:40px}.node-micro{width:72px;height:64px;flex-basis:72px}.node-photo{width:26px;height:26px}.node-micro b{max-width:64px}.client-terminal{min-width:74px;padding:6px 8px}.clients-terminal{max-width:280px}.mobile-table-one{overflow-x:auto}.mobile-table-one table{font-size:12px}.mobile-table-one th,.mobile-table-one td{padding:6px 5px!important}.mini-icon{width:22px;height:22px;font-size:11px}.net-alert{min-width:48px;padding:5px 7px;font-size:11px}.compact-btn{min-height:34px;font-size:12px;padding:0 10px}}
@media(max-width:520px){.internet-tabs{display:flex;gap:8px;overflow-x:auto}.internet-tabs .tab{flex:0 0 auto;min-height:38px;padding:0 14px}.one-line-kpis{padding-bottom:9px}.one-line-kpis>div{min-width:96px;padding:8px 10px}.one-line-kpis b{font-size:15px}.client-live-card{min-width:106px;padding:8px}.pro-switches{padding:8px 10px;gap:8px}.tech-switch{font-size:12px}.tech-switch span{width:34px;height:20px}.tech-switch span:after{width:14px;height:14px}.tech-switch input:checked+span:after{left:17px}.network-title{display:block}.network-title .btn{margin-top:8px}.circuit-route{padding:7px}.circuit-track{gap:6px}.node-micro{width:66px;height:58px;flex-basis:66px;border-radius:12px}.node-photo{width:23px;height:23px}.node-photo span{font-size:15px}.node-micro b{font-size:10px;max-width:58px}.wire{width:36px;min-width:36px}.wire span{width:31px}.wire small{font-size:8px}.wire span:after{font-size:14px;top:-10px}.client-terminal{min-width:66px;border-radius:10px;padding:5px 7px}.client-terminal b{font-size:10px}.client-terminal span{font-size:9px}.mobile-table-one th:nth-child(1),.mobile-table-one td:nth-child(1),.mobile-table-one th:nth-child(5),.mobile-table-one td:nth-child(5),.mobile-table-one th:nth-child(6),.mobile-table-one td:nth-child(6){display:none}.internet-resume-cards{grid-template-columns:1fr}}

/* =========================================================
   INTERNET PRO V6 - formularios y móvil realmente compactos
   ========================================================= */
.internet-resume-cards{display:flex!important;overflow-x:auto;gap:8px;margin-bottom:12px;padding-bottom:4px;scroll-snap-type:x mandatory}.internet-resume-cards .card{min-width:142px;max-width:150px;min-height:76px;padding:9px 10px;border-radius:13px;scroll-snap-align:start}.internet-resume-cards .card small{font-size:10px;margin-bottom:4px;line-height:1.15}.internet-resume-cards .card strong{font-size:17px;line-height:1.1}.internet-resume-cards .delta{font-size:11px;margin-top:4px;line-height:1.1}
.one-line-kpis{display:flex!important;overflow-x:auto;gap:8px;margin:0 0 8px;padding:0 0 6px}.one-line-kpis>div{min-width:86px;padding:7px 9px;border-radius:11px}.one-line-kpis small{font-size:10px;line-height:1;margin-bottom:3px}.one-line-kpis b{font-size:14px}.client-first-panel .panel-head{padding:12px 14px}.client-first-panel h2{font-size:20px}.client-first-panel .panel-subtitle{font-size:12px}.client-tools-row{display:flex!important;flex-direction:row!important;gap:8px;align-items:center}.client-tools-row .btn{min-height:32px;padding:7px 10px;font-size:12px;flex:1}.client-search-row{padding:0 12px 8px}.client-search-row .search{min-height:38px;padding:8px 11px;border-radius:10px}.client-chip-grid{display:flex!important;overflow-x:auto;gap:7px;padding:0 12px 10px}.client-live-card{min-width:94px!important;padding:7px 8px!important;border-radius:11px!important}.client-live-card b{font-size:11px!important}.client-live-card small{font-size:10px!important}.pulse-dot{left:7px!important;top:10px!important;width:7px!important;height:7px!important}.mobile-table-one table{font-size:12px!important}.mobile-table-one th,.mobile-table-one td{padding:5px 5px!important}.mini-icon{width:21px!important;height:21px!important;font-size:10px!important}.table-icon-actions{gap:3px!important}.net-alert{min-width:43px!important;padding:4px 6px!important;font-size:10px!important;border-radius:9px!important}.badge{padding:5px 7px!important;font-size:11px!important}.client-link-btn{font-size:12px!important}.compact-table table th,.compact-table table td{height:30px!important}
.pro-map-panel .panel-head{padding:12px 14px}.pro-map-panel h2{font-size:20px}.pro-map-tools{display:grid!important;grid-template-columns:1fr 1fr;gap:7px}.pro-map-tools .search{grid-column:1/-1;min-width:0!important;width:100%;min-height:38px;padding:8px 11px}.pro-map-tools .btn{min-height:32px;padding:7px 10px;font-size:12px}.pro-switches{padding:7px 10px!important;gap:10px!important;flex-wrap:nowrap!important;overflow-x:auto}.tech-switch{font-size:11px!important;white-space:nowrap}.tech-switch span{width:30px!important;height:17px!important;flex:0 0 auto}.tech-switch span:after{width:12px!important;height:12px!important;top:1.5px!important;left:2px!important}.tech-switch input:checked+span:after{left:15px!important}.circuit-map-body{padding:8px!important;gap:8px!important}.network-board{padding:8px!important;border-radius:14px!important}.network-title{display:flex!important;align-items:center!important;margin-bottom:7px!important}.network-title h3{font-size:15px!important}.network-title small{display:none}.network-title .btn{padding:6px 9px!important;min-height:30px;font-size:11px!important;margin:0!important}.circuit-route{padding:6px!important;border-radius:12px!important}.circuit-track{gap:4px!important}.node-micro{width:58px!important;height:52px!important;flex-basis:58px!important;border-radius:10px!important}.node-photo{width:21px!important;height:21px!important;border-radius:7px!important}.node-photo span{font-size:14px!important}.node-micro b{font-size:9px!important;max-width:50px!important}.wire{width:30px!important;min-width:30px!important;height:28px!important}.wire span{width:25px!important;height:2px!important}.wire small{font-size:7px!important}.wire span:after{font-size:12px!important;top:-8px!important}.clients-terminal{max-width:240px!important;gap:5px!important}.client-terminal{min-width:58px!important;padding:4px 6px!important;border-radius:9px!important}.client-terminal b{font-size:9px!important}.client-terminal span{font-size:8px!important}.route-no-client{padding:6px 8px!important;font-size:10px!important;border-radius:9px!important}

/* Modales compactos */
.mobile-compact-form{display:grid!important;grid-template-columns:1fr!important;gap:8px!important;padding:12px!important}.mobile-compact-form label{display:flex;flex-direction:column;gap:4px;color:var(--muted);font-weight:900;font-size:12px;line-height:1.1}.mobile-compact-form input,.mobile-compact-form select,.mobile-compact-form textarea{min-height:38px;padding:8px 10px;border-radius:10px;font-size:13px}.mobile-compact-form textarea{min-height:58px}.compact-form-core{display:grid;gap:8px}.two-field-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}.compact-section{border:1px solid var(--line);border-radius:12px;background:rgba(255,255,255,.025);overflow:hidden}.compact-section summary{list-style:none;cursor:pointer;padding:10px 11px;font-weight:900;color:var(--text);font-size:13px;display:flex;align-items:center;justify-content:space-between}.compact-section summary:after{content:'+';color:var(--primary2);font-size:17px}.compact-section[open] summary:after{content:'−'}.compact-section>label,.compact-section>.two-field-row{padding:0 10px 10px}.sticky-actions{position:static;bottom:auto;background:transparent;padding:0!important;margin-top:12px!important;z-index:2;display:flex!important;gap:8px!important;justify-content:flex-end!important;border-top:0!important}.sticky-actions .btn{min-height:36px;padding:8px 11px;font-size:12px;flex:1}.sticky-actions .btn.danger{flex:.9}.form-grid.mobile-compact-form .full{grid-column:auto}.mobile-compact-form .form-actions{grid-column:1/-1}.media-preview span{color:var(--muted);font-weight:800;text-align:center}

@media(max-width:520px){
  #content{padding:12px!important}.tabs.internet-tabs{display:flex!important;flex-wrap:nowrap!important;overflow-x:auto!important;gap:6px!important;margin-bottom:10px!important}.tabs.internet-tabs .tab{min-height:34px!important;padding:7px 12px!important;border-radius:12px!important;font-size:12px!important;flex:0 0 auto!important}.panel{border-radius:14px!important}.panel-subtitle{font-size:11px!important}.modal{padding:0!important;place-items:stretch!important;background:rgba(2,6,23,.86)!important}.modal-card{width:100vw!important;max-height:100vh!important;height:100vh!important;border-radius:0!important;border-left:0!important;border-right:0!important;overflow:hidden!important}.modal-head{padding:10px 14px!important;min-height:48px!important;position:sticky;top:0;background:var(--panel);z-index:5}.modal-head h2{font-size:20px!important;line-height:1.05!important}.modal-head .icon-btn{font-size:24px!important}.mobile-compact-form{padding:10px 12px 16px!important;gap:7px!important;overflow:auto!important;height:100%!important}.mobile-compact-form input,.mobile-compact-form select{min-height:35px!important;padding:7px 9px!important}.mobile-compact-form textarea{min-height:50px!important;padding:7px 9px!important}.mobile-compact-form .two-field-row{grid-template-columns:1fr!important;gap:7px!important}.compact-section summary{padding:9px 10px!important}.mobile-compact-form .sticky-actions{position:static!important;left:auto!important;right:auto!important;bottom:auto!important;padding:0 0 calc(8px + env(safe-area-inset-bottom,0px))!important;background:transparent!important;box-shadow:none!important;margin-top:12px!important}.sticky-actions .btn{min-height:36px!important}.mobile-table-one th:nth-child(1),.mobile-table-one td:nth-child(1),.mobile-table-one th:nth-child(5),.mobile-table-one td:nth-child(5),.mobile-table-one th:nth-child(6),.mobile-table-one td:nth-child(6),.mobile-table-one th:nth-child(7),.mobile-table-one td:nth-child(7),.mobile-table-one th:nth-child(8),.mobile-table-one td:nth-child(8),.mobile-table-one th:nth-child(9),.mobile-table-one td:nth-child(9){display:none!important}.mobile-table-one th,.mobile-table-one td{padding:5px 5px!important}.mobile-table-one table{min-width:360px!important}.table-wrap{overflow-x:auto!important}.client-first-panel .panel-head{padding:10px 12px!important}.client-first-panel h2{font-size:19px!important}.client-tools-row .btn{flex:1 1 0}.internet-resume-cards .card{min-width:128px;max-width:128px;padding:8px 9px;min-height:66px}.internet-resume-cards .card strong{font-size:15px}.internet-resume-cards .card small{font-size:9px}.internet-resume-cards .delta{font-size:10px}.pro-map-tools{grid-template-columns:1fr 1fr!important}.empty-focus-card,.neon-empty{padding:14px!important}.empty-focus-card h3,.neon-empty h3{font-size:15px!important}.empty-focus-card p,.neon-empty p{font-size:11px!important;margin:5px 0!important}.network-title h3{max-width:190px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.node-detail-pro .node-detail-head{gap:8px}.node-detail-icon{width:42px;height:42px}.detail-card{padding:12px!important;border-radius:14px!important}.detail-card h3{font-size:17px!important}.detail-card p{font-size:12px!important;line-height:1.35!important}
}

/* BOT WHATSAPP */
.bot-pro-page{display:grid;gap:16px}
.bot-hero-panel{padding:18px}
.bot-quick-test{display:flex;gap:10px;align-items:center;margin-top:12px}
.bot-result{margin-top:12px;background:var(--input);border:1px solid var(--line);border-radius:14px;padding:12px;white-space:pre-wrap}
.bot-dashboard-grid{display:grid;grid-template-columns:1.35fr .95fr;gap:16px}
.bot-status-head{align-items:flex-start}
.bot-action-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.bot-kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;padding:0 20px 18px}
.bot-kpis>div{background:var(--panel2);border:1px solid var(--line);border-radius:14px;padding:10px 12px}
.bot-kpis small{display:block;color:var(--muted);font-weight:800}
.bot-kpis b{display:block;font-size:17px;margin-top:4px}
.bot-switch-list{display:grid;gap:10px;padding:0 20px 18px}
.bot-switch-row{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:12px 14px;border:1px solid var(--line);border-radius:16px;background:var(--panel2)}
.bot-switch-row b{display:block}
.bot-switch-row span{display:block;color:var(--muted);font-weight:700;font-size:13px;margin-top:4px}
.bot-command-list{display:grid;gap:12px;padding:18px}
.bot-command-row{display:grid;grid-template-columns:1fr auto;gap:16px;align-items:start;padding:14px 16px;border:1px solid var(--line);border-radius:18px;background:linear-gradient(180deg,rgba(255,255,255,.02),rgba(255,255,255,.01))}
body.light .bot-command-row{background:linear-gradient(180deg,#fff,#f7f9fe)}
.bot-command-row.off{opacity:.72}
.bot-command-main b{display:block;font-size:17px;margin:8px 0 4px}
.bot-command-main span{display:block;color:var(--muted);line-height:1.45;font-weight:700}
.bot-command-main small{display:block;margin-top:8px;color:var(--muted);font-weight:800}
.bot-command-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.bot-command-tag{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;background:rgba(20,199,151,.12);color:var(--primary2);font-weight:900;font-size:12px;border:1px solid rgba(20,199,151,.24)}
.bot-command-state{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;font-weight:900;font-size:12px;border:1px solid var(--line);background:var(--panel2);color:var(--text)}
.bot-command-state.ok{background:rgba(16,185,129,.15);color:#10b981;border-color:rgba(16,185,129,.35)}
.bot-command-state.danger{background:rgba(239,68,68,.15);color:#fb7185;border-color:rgba(239,68,68,.35)}
.bot-command-toggle{justify-self:end;align-self:center;margin-top:6px}
.bot-info,.bot-warning,.bot-state-pill{display:inline-flex;align-items:center;gap:8px;border-radius:999px;padding:8px 12px;font-weight:900}
.bot-state-pill.ok,.bot-info.ok{background:rgba(16,185,129,.15);color:#10b981;border:1px solid rgba(16,185,129,.3)}
.bot-state-pill.warn,.bot-info.warn{background:rgba(245,158,11,.15);color:#fbbf24;border:1px solid rgba(245,158,11,.28)}
.bot-state-pill.danger,.bot-info.danger,.bot-warning{background:rgba(239,68,68,.15);color:#fb7185;border:1px solid rgba(239,68,68,.3)}
.bot-dot{width:10px;height:10px;border-radius:50%;background:#64748b;display:inline-block}
.bot-dot.on{background:#10b981;box-shadow:0 0 0 4px rgba(16,185,129,.14)}

@media(max-width:1100px){
  .bot-dashboard-grid{grid-template-columns:1fr}
}
@media(max-width:760px){
  .bot-quick-test{flex-direction:column;align-items:stretch}
  .bot-action-grid{grid-template-columns:1fr 1fr}
  .bot-kpis{grid-template-columns:1fr 1fr}
  .bot-command-row{grid-template-columns:1fr;gap:10px}
  .bot-command-toggle{justify-self:start;margin-top:0}
}

/* V9 conexiones manuales de Internet */
.manual-network-body{padding:14px;display:grid;gap:14px;background:radial-gradient(circle at top left,rgba(16,185,129,.08),transparent 28%),radial-gradient(circle at bottom right,rgba(59,130,246,.08),transparent 26%)}
.manual-board{overflow:hidden;padding:12px;border-radius:18px;border:1px solid var(--border);background:linear-gradient(180deg,rgba(20,36,60,.78),rgba(13,24,45,.74))}
.network-scroll-zone{overflow-x:auto;overflow-y:hidden;padding:2px 0 4px;scrollbar-width:thin}
.board-head{position:relative;z-index:2}
.manual-node-tree{display:flex;align-items:flex-start;gap:10px;min-width:max-content}
.manual-node-main{display:flex;flex-direction:column;align-items:flex-start;gap:8px;min-width:max-content}
.manual-node-row{display:flex;align-items:center;gap:8px;min-width:max-content}
.manual-children{display:flex;flex-direction:column;gap:8px;margin-left:4px;padding-left:8px;border-left:1px dashed rgba(56,189,248,.24)}
.manual-branch{display:flex;align-items:flex-start;gap:8px;position:relative;min-width:max-content}
.connection-mini-delete{width:22px;height:22px;border-radius:6px;border:1px solid rgba(239,68,68,.4);background:rgba(239,68,68,.1);color:#ff8a8a;font-weight:900;cursor:pointer;margin-top:24px}
.inline-clients{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(102px,112px);grid-template-rows:repeat(var(--client-rows,3),minmax(38px,auto));gap:8px 8px;align-content:start;justify-content:start;max-width:none;padding-top:2px}
.inline-clients.rows-1{--client-rows:1}.inline-clients.rows-2{--client-rows:2}.inline-clients.rows-3{--client-rows:3}.inline-clients.rows-4{--client-rows:4}.inline-clients.rows-5{--client-rows:5}
.focus-route-line{display:flex;align-items:center;gap:8px;overflow:auto;min-height:92px;border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:10px;background:linear-gradient(180deg,rgba(255,255,255,.035),rgba(255,255,255,.015))}
.wire.cable-lan span,.wire.cable span{background:linear-gradient(90deg,#38bdf8,#22c55e)}.wire.radio span{background:repeating-linear-gradient(90deg,#cbd5e1 0 6px,transparent 6px 12px)}.wire.fibra span{background:linear-gradient(90deg,#22c55e,#84cc16)}.wire.poe span{background:linear-gradient(90deg,#f59e0b,#ef4444)}.wire.wifi span{background:linear-gradient(90deg,#06b6d4,#60a5fa)}
.wire{position:relative;overflow:visible}.wire span{box-shadow:0 0 16px rgba(56,189,248,.18)}.wire span:before{animation:wireFlow 1.05s linear infinite}.wire span:after{content:'';position:absolute;right:-2px;top:50%;width:7px;height:7px;border-radius:50%;transform:translateY(-50%);background:#7dd3fc;box-shadow:0 0 12px rgba(125,211,252,.95);animation:wirePulse 1.4s ease-in-out infinite}.wire i{position:absolute;left:-8px;top:7px;width:8px;height:8px;border-radius:999px;background:#e0f2fe;box-shadow:0 0 12px rgba(224,242,254,.95);animation:wirePacket 1.8s linear infinite}.wire.radio i{background:#ddd6fe;box-shadow:0 0 12px rgba(221,214,254,.95);animation-duration:1.35s}.wire.fibra i{background:#bbf7d0;box-shadow:0 0 12px rgba(187,247,208,.95)}.wire.poe i{background:#fed7aa;box-shadow:0 0 12px rgba(254,215,170,.95)}.wire.wifi i{background:#67e8f9;box-shadow:0 0 12px rgba(103,232,249,.95);animation-duration:1.2s}
.node-micro-ip{font-size:10px;color:#38bdf8;font-weight:900;display:block;line-height:1.1;margin-top:2px}.node-micro{min-height:64px}.clients-terminal{align-items:flex-start;gap:6px;flex-wrap:nowrap}.inline-clients.clients-terminal{display:grid}.client-terminal{min-height:40px;min-width:102px;max-width:112px}.client-terminal span{display:block;color:#38bdf8;font-size:10px;font-weight:900;margin-top:2px}.network-title{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:10px}.network-title h3{margin:0;font-size:18px}.network-title small{color:var(--muted);font-weight:800}
.client-picker-board{padding:14px}.client-picker-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(136px,1fr));gap:10px}.client-picker-item{border:1px solid rgba(6,182,212,.28);background:linear-gradient(135deg,rgba(6,182,212,.13),rgba(49,86,219,.08));border-radius:14px;padding:10px;text-align:left;color:var(--text);cursor:pointer;min-height:72px}.client-picker-item b{display:block;font-size:13px;line-height:1.15}.client-picker-item span{display:block;color:#38bdf8;font-size:11px;font-weight:900;margin-top:4px}.client-picker-item small{display:block;color:var(--muted);font-size:11px;font-weight:800;margin-top:4px}
.internet-mini-info{position:fixed;inset:0;background:rgba(2,6,23,.42);display:grid;place-items:center;z-index:95;padding:18px}.internet-mini-card{width:min(320px,92vw);background:linear-gradient(180deg,#182644,#101b30);border:1px solid rgba(80,116,178,.45);border-radius:16px;padding:14px 16px;box-shadow:0 20px 60px rgba(0,0,0,.35);position:relative}.internet-mini-card b{display:block;font-size:18px;margin-bottom:8px}.internet-mini-card small{display:block;color:#7dd3fc;font-weight:900;margin-bottom:10px}.internet-mini-card p{margin:0;color:var(--muted);line-height:1.35;white-space:pre-wrap}.internet-mini-close{position:absolute;right:10px;top:10px;width:28px;height:28px;border-radius:999px;border:1px solid var(--border);background:rgba(255,255,255,.05);color:var(--text);cursor:pointer}
@keyframes wirePacket{0%{transform:translate(0,0) scale(.7);opacity:0}12%{opacity:1}85%{opacity:1}100%{transform:translate(58px,0) scale(1);opacity:0}}@keyframes wirePulse{0%,100%{transform:translateY(-50%) scale(.9);opacity:.75}50%{transform:translateY(-50%) scale(1.15);opacity:1}}
@media(max-width:760px){.manual-network-body{padding:10px}.manual-board{padding:10px}.manual-node-tree{gap:7px}.manual-node-main{gap:6px}.manual-children{gap:6px;padding-left:6px}.node-micro{min-width:64px;max-width:72px;min-height:58px}.node-micro b{font-size:10px}.node-micro-ip{font-size:9px}.wire{min-width:42px}.wire small{font-size:8px}.wire i{top:6px}.inline-clients{grid-auto-columns:minmax(82px,94px);gap:6px}.client-terminal{min-width:82px;max-width:94px}.client-picker-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.connection-mini-delete{width:20px;height:20px;font-size:12px}}
