:root{
  --bg:#07111f;
  --bg-2:#0b1730;
  --card:rgba(255,255,255,.075);
  --card-2:rgba(255,255,255,.105);
  --line:rgba(255,255,255,.13);
  --text:#eef5ff;
  --muted:#9fb2cd;
  --blue:#4aa3ff;
  --blue-2:#1d6fff;
  --green:#44d39d;
  --yellow:#f8c24e;
  --red:#ff6575;
  --shadow:0 24px 70px rgba(0,0,0,.35);
  --radius:22px;
}
*{box-sizing:border-box}
body{
  margin:0;
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at top left, rgba(56,132,255,.28), transparent 34%),
    radial-gradient(circle at 70% 20%, rgba(0,255,218,.10), transparent 28%),
    linear-gradient(135deg,#07111f,#0a1227 54%,#06101d);
  min-height:100vh;
}
button,input,select{font:inherit}
button{cursor:pointer}
.app-shell{display:flex;min-height:100vh}
.sidebar{
  width:282px;
  padding:26px 18px;
  position:sticky;
  top:0;
  height:100vh;
  border-right:1px solid var(--line);
  background:rgba(4,12,24,.72);
  backdrop-filter:blur(18px);
}
.brand{display:flex;gap:13px;align-items:center;margin-bottom:30px;padding:10px}
.brand-mark{
  width:52px;height:52px;border-radius:18px;
  display:grid;place-items:center;font-weight:900;
  background:linear-gradient(135deg,var(--blue),#00dcc5);
  color:#04101e;box-shadow:0 14px 36px rgba(74,163,255,.34);
}
.brand strong{display:block;font-size:18px;letter-spacing:.2px}
.brand span{display:block;color:var(--muted);font-size:12px;margin-top:2px}
.nav{display:grid;gap:8px}
.nav-item{
  width:100%;border:1px solid transparent;background:transparent;color:var(--muted);
  text-align:left;padding:13px 14px;border-radius:16px;transition:.18s ease;
}
.nav-item:hover,.nav-item.active{background:rgba(74,163,255,.13);border-color:rgba(74,163,255,.28);color:var(--text);transform:translateX(3px)}
.sidebar-card{margin-top:26px;padding:16px;border-radius:18px;background:rgba(255,255,255,.06);border:1px solid var(--line)}
.sidebar-card p{margin:8px 0 0;color:var(--muted);font-size:13px;line-height:1.4}.mini-label,.eyebrow{color:#75c4ff;text-transform:uppercase;letter-spacing:.14em;font-size:11px;font-weight:800}
.main{flex:1;padding:28px;min-width:0}.topbar{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;margin-bottom:22px}.topbar h1{margin:3px 0;font-size:34px;line-height:1.1}.subtitle{margin:0;color:var(--muted);max-width:760px}.top-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);backdrop-filter:blur(16px)}
.btn{border:0;border-radius:14px;padding:11px 16px;color:#03101e;font-weight:800;background:linear-gradient(135deg,var(--blue),#00dcc5);box-shadow:0 14px 28px rgba(74,163,255,.23)}.btn.compact{padding:9px 12px;border-radius:12px;font-size:13px}.btn.secondary{background:rgba(255,255,255,.13);border:1px solid var(--line);color:var(--text);box-shadow:none}.btn.ghost{background:rgba(255,255,255,.06);border:1px solid var(--line);color:var(--text);box-shadow:none}.btn.danger{background:rgba(255,101,117,.14);border:1px solid rgba(255,101,117,.35);color:#ffd7dc;box-shadow:none}.filters{display:flex;gap:12px;align-items:end;padding:15px;margin-bottom:22px;flex-wrap:wrap}.field{display:grid;gap:7px}.field.grow{flex:1;min-width:240px}.field.inline{min-width:260px}.field label{font-size:12px;color:var(--muted);font-weight:800}input,select{border:1px solid var(--line);background:rgba(2,8,18,.44);color:var(--text);border-radius:13px;padding:11px 12px;outline:none;min-height:42px}input:focus,select:focus{border-color:rgba(74,163,255,.72);box-shadow:0 0 0 4px rgba(74,163,255,.12)}option{background:#0b1730}.view{display:none}.view.active{display:block}.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:18px}.kpi{padding:18px}.kpi span{display:block;color:var(--muted);font-size:13px}.kpi strong{display:block;font-size:28px;margin:7px 0}.kpi small{color:var(--muted)}.grid-2{display:grid;grid-template-columns:1.18fr .82fr;gap:18px;margin-bottom:18px}.panel{padding:18px;min-width:0}.panel-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:16px}.panel-head h2{margin:0;font-size:20px}.panel-head p{margin:4px 0 0;color:var(--muted);font-size:13px}.pill{display:inline-flex;align-items:center;gap:6px;border:1px solid rgba(74,163,255,.25);background:rgba(74,163,255,.12);color:#b9dcff;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:800;white-space:nowrap}.pill.warning{border-color:rgba(248,194,78,.35);background:rgba(248,194,78,.12);color:#ffe4a3}.pill.danger{border-color:rgba(255,101,117,.35);background:rgba(255,101,117,.12);color:#ffd7dc}.table-wrap{overflow:auto;border-radius:16px;border:1px solid rgba(255,255,255,.08)}table{width:100%;border-collapse:collapse;min-width:680px}th,td{padding:12px 13px;border-bottom:1px solid rgba(255,255,255,.08);text-align:left;font-size:13px;vertical-align:middle}th{color:#c9dbf2;background:rgba(255,255,255,.06);font-size:12px;text-transform:uppercase;letter-spacing:.05em}tbody tr:hover{background:rgba(255,255,255,.04)}.money{font-weight:900}.muted{color:var(--muted)}.badge{border-radius:999px;padding:5px 8px;font-weight:900;font-size:11px;display:inline-flex}.badge.green{background:rgba(68,211,157,.13);color:#92ffd5}.badge.yellow{background:rgba(248,194,78,.14);color:#ffe09a}.badge.red{background:rgba(255,101,117,.16);color:#ffc1c8}.badge.blue{background:rgba(74,163,255,.15);color:#bcddff}.bars{display:grid;gap:12px}.bar-row{display:grid;gap:6px}.bar-meta{display:flex;justify-content:space-between;gap:10px;color:#dcecff;font-size:13px}.bar-track{height:12px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden}.bar-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--blue),#00dcc5)}.chart-bars{display:flex;align-items:end;gap:8px;height:250px;padding:12px;border:1px solid rgba(255,255,255,.08);border-radius:16px;overflow-x:auto}.chart-day{min-width:34px;display:flex;flex-direction:column;align-items:center;gap:7px;height:100%;justify-content:flex-end}.chart-col{width:100%;min-height:3px;border-radius:9px 9px 3px 3px;background:linear-gradient(180deg,#68bbff,#00dcc5)}.chart-day small{color:var(--muted);font-size:10px;writing-mode:vertical-rl;transform:rotate(180deg)}.upload-card{display:grid;grid-template-columns:1fr 1fr;gap:20px;padding:22px;margin-bottom:18px}.upload-copy h2{font-size:26px;margin:8px 0}.upload-copy p{color:var(--muted);line-height:1.5}.hint-list{display:flex;gap:8px;flex-wrap:wrap}.hint-list span{font-size:12px;border:1px solid rgba(68,211,157,.24);background:rgba(68,211,157,.09);color:#adf8dd;border-radius:999px;padding:7px 10px}.dropzone{min-height:230px;border:1.5px dashed rgba(117,196,255,.52);border-radius:24px;background:rgba(74,163,255,.08);display:grid;place-items:center;text-align:center;padding:22px;transition:.2s ease}.dropzone:hover,.dropzone.dragover{background:rgba(74,163,255,.16);transform:translateY(-2px)}.dropzone input{display:none}.dropzone strong{display:block;font-size:22px}.dropzone span{display:block;color:var(--muted);margin-top:8px}.progress-wrap{display:grid;gap:10px}.progress-meta{display:flex;justify-content:space-between;gap:12px}.progress-meta span{color:var(--muted)}.progress{height:16px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden}.progress div{height:100%;width:0;background:linear-gradient(90deg,var(--blue-2),#00dcc5);transition:width .15s ease}.load-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-top:15px}.load-summary div{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:14px}.load-summary span{display:block;color:var(--muted);font-size:12px}.load-summary strong{display:block;margin-top:5px;font-size:22px}.load-summary small{display:block;margin-top:5px;color:var(--muted);font-size:11px;line-height:1.3}.empty-state{min-height:220px;display:grid;place-items:center;color:var(--muted);border:1px dashed rgba(255,255,255,.16);border-radius:18px;background:rgba(255,255,255,.035);text-align:center;padding:24px}.ficha-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:13px;margin-bottom:16px}.mini-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.09);border-radius:18px;padding:14px}.mini-card span{display:block;color:var(--muted);font-size:12px}.mini-card strong{display:block;font-size:22px;margin-top:5px}.compare-selects{display:flex;gap:10px;flex-wrap:wrap}.compare-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.compare-card{border-radius:18px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.055);padding:16px}.compare-card h3{margin:0 0 12px}.delta{font-weight:900}.delta.good{color:#8fffd2}.delta.bad{color:#ffabb4}.quality-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.quality-item{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:17px;padding:15px}.quality-item span{display:block;color:var(--muted);font-size:12px}.quality-item strong{display:block;font-size:24px;margin-top:6px}.catalog-list{display:grid;gap:12px}.rule{display:grid;grid-template-columns:1fr 1fr 1fr 1.5fr auto;gap:10px;align-items:end;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.09);border-radius:18px;padding:12px}.toast{position:fixed;right:22px;bottom:22px;max-width:430px;padding:14px 16px;border-radius:18px;background:#eaf5ff;color:#07111f;font-weight:800;box-shadow:0 18px 45px rgba(0,0,0,.35);transform:translateY(120px);opacity:0;transition:.25s ease;z-index:20}.toast.show{transform:translateY(0);opacity:1}

.client-focus-panel{margin-bottom:18px}
.client-showcase{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.client-hero-card{padding:18px;border-radius:22px;border:1px solid rgba(255,255,255,.12);background:linear-gradient(135deg,rgba(255,255,255,.06),rgba(255,255,255,.03));min-height:152px;display:grid;gap:18px}
.client-tone-1{box-shadow:inset 0 0 0 1px rgba(91,141,255,.1)}
.client-tone-2{box-shadow:inset 0 0 0 1px rgba(68,211,157,.1)}
.client-tone-3{box-shadow:inset 0 0 0 1px rgba(141,132,255,.1)}
.client-tone-4{box-shadow:inset 0 0 0 1px rgba(255,101,117,.08)}
.client-hero-top{display:flex;justify-content:space-between;gap:16px;align-items:flex-start}
.client-hero-mini{display:block;color:#d7dce7;font-size:12px;opacity:.78;margin-bottom:3px}
.client-hero-top h3{margin:0;font-size:30px;line-height:1.05}
.client-hero-top p{margin:8px 0 0;color:var(--muted);font-size:13px;max-width:500px}
.client-share-badge{display:inline-flex;align-items:center;justify-content:center;min-width:74px;padding:7px 12px;border-radius:999px;font-weight:900;font-size:15px;background:rgba(230,236,215,.95);color:#3b4a2d}
.client-share-badge.yellow{background:rgba(255,237,194,.96);color:#7a5a00}
.client-share-badge.red{background:rgba(255,223,226,.96);color:#8a2a34}
.client-share-badge.blue{background:rgba(216,234,255,.96);color:#264c79}
.client-hero-metrics{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.client-hero-metrics div{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:14px}
.client-hero-metrics span{display:block;color:#d5dceb;font-size:13px}
.client-hero-metrics strong{display:block;font-size:32px;margin-top:4px}
.client-chart-grid{align-items:stretch}
.client-chart-block{border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:18px 14px 10px;background:rgba(255,255,255,.03);min-height:330px;overflow-x:auto}
.client-bars{display:flex;align-items:flex-end;gap:18px;min-height:286px;padding:8px 4px 2px}
.client-bar-item{min-width:110px;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:10px;height:100%}
.client-bar-column{width:100%;max-width:82px;border-radius:18px 18px 4px 4px;box-shadow:0 12px 30px rgba(0,0,0,.22)}
.client-bar-column.tone-1{background:#5b8dff}
.client-bar-column.tone-2{background:#53a47e}
.client-bar-column.tone-3{background:#8178d8}
.client-bar-column.tone-4{background:#d28f67}
.client-bar-label{font-size:13px;text-align:center;color:#dce7f7;line-height:1.2;max-width:100px;word-break:break-word}
.client-bar-value{font-size:12px;color:var(--muted);text-align:center}
.good-text{color:#56d6a5!important}.bad-text{color:#ff7180!important}
.client-share-badge.good{background:rgba(226,241,213,.96);color:#38612d}
.client-share-badge.bad{background:rgba(255,225,227,.98);color:#8d2f39}
.client-bar-column.negative{background:#d96a75}
.profit-bars{align-items:flex-end}

.cruce-hero{margin-bottom:18px;background:linear-gradient(135deg,rgba(74,163,255,.13),rgba(255,255,255,.06))}
.cruce-flow{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-top:16px}
.cruce-flow div{border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.055);border-radius:18px;padding:15px;display:flex;gap:12px;align-items:center}
.cruce-flow strong{width:34px;height:34px;border-radius:12px;display:grid;place-items:center;background:linear-gradient(135deg,var(--blue),#00dcc5);color:#06101d}
.cruce-flow span{font-weight:800;color:#dfefff;font-size:13px}.cruce-upload-grid{align-items:stretch}.mini-dropzone{min-height:160px}.mini-dropzone strong{font-size:20px}.btn:disabled{opacity:.48;cursor:not-allowed}.cruce-summary strong{font-size:24px}.cruce-summary div:nth-child(3){border-color:rgba(68,211,157,.22);background:rgba(68,211,157,.075)}.cruce-summary div:nth-child(4){border-color:rgba(255,101,117,.22);background:rgba(255,101,117,.075)}

.hidden-select{display:none!important}
.ficha-head{margin-bottom:10px}
.client-search-card{display:flex;gap:12px;align-items:end;margin-bottom:14px;padding:14px;border:1px solid rgba(255,255,255,.09);border-radius:18px;background:rgba(255,255,255,.045)}
.client-search-results{margin-bottom:16px}
.client-search-title{color:var(--muted);font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.08em;margin:0 0 8px 2px}
.client-result-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
.client-result-card{border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.055);color:var(--text);text-align:left;border-radius:16px;padding:12px;min-height:92px;transition:.16s ease}
.client-result-card:hover,.client-result-card.active{border-color:rgba(74,163,255,.72);background:rgba(74,163,255,.14);transform:translateY(-1px)}
.client-result-card span{display:block;color:#75c4ff;font-size:11px;font-weight:900;letter-spacing:.05em}
.client-result-card strong{display:block;margin-top:4px;font-size:15px;line-height:1.2}
.client-result-card small{display:block;margin-top:7px;color:var(--muted);line-height:1.35}
.compact-empty{min-height:76px;padding:14px}

.region-submeta{color:var(--muted);font-size:12px;margin-top:-2px}
.region-row{gap:5px}
.compact-table table{min-width:560px}

.provider-region-bars{gap:16px}
.provider-region-group{border:1px solid rgba(255,255,255,.09);background:rgba(255,255,255,.035);border-radius:16px;padding:12px;display:grid;gap:10px}
.provider-region-head{display:flex;justify-content:space-between;gap:10px;align-items:center;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.08)}
.provider-region-head strong{font-size:15px}
.provider-region-head span{color:var(--muted);font-size:12px;font-weight:800;text-align:right}
.provider-region-list{display:grid;gap:10px}
.provider-table-head td{background:rgba(74,163,255,.12)!important;color:#cfe8ff;text-transform:none;letter-spacing:0}
.provider-table-head strong{font-size:14px}

.highlight-download{border-color:rgba(0,220,197,.52)!important;background:linear-gradient(135deg,rgba(74,163,255,.22),rgba(0,220,197,.22))!important;color:#eaffff!important}

.btn.is-busy{opacity:.82;cursor:not-allowed;pointer-events:none}
.btn.is-busy::after{content:'';display:inline-block;width:12px;height:12px;margin-left:8px;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;vertical-align:-2px;animation:spin .75s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
@media(max-width:1180px){.kpi-grid,.load-summary,.ficha-grid,.client-showcase,.cruce-flow{grid-template-columns:repeat(2,1fr)}.grid-2,.upload-card{grid-template-columns:1fr}.topbar{display:grid}.top-actions{justify-content:flex-start}.sidebar{width:240px}}
@media(max-width:820px){.app-shell{display:block}.sidebar{position:relative;width:auto;height:auto}.main{padding:18px}.nav{grid-template-columns:repeat(2,1fr)}.topbar h1{font-size:28px}.kpi-grid,.load-summary,.ficha-grid,.compare-grid,.quality-grid,.client-showcase,.client-hero-metrics,.cruce-flow{grid-template-columns:1fr}.rule{grid-template-columns:1fr}.filters{display:grid}.field.grow{min-width:0}.client-hero-top{display:grid}.client-hero-top h3{font-size:24px}.client-bar-item{min-width:92px}}


/* v22: detalle clickeable de clientes y proveedores del Excel limpio */
.clickable-row{cursor:pointer;transition:.16s ease}.clickable-row:hover{background:rgba(74,163,255,.12)!important}.clickable-row.selected{background:rgba(74,163,255,.18)!important;box-shadow:inset 3px 0 0 #75c4ff}.row-hint{display:inline-block;margin-top:5px;color:#75c4ff;font-size:11px;font-weight:900;letter-spacing:.04em;text-transform:uppercase}.clean-client-detail,.clean-provider-detail{margin:18px 0}.clean-client-content.is-hidden,.clean-provider-content.is-hidden{display:none}.clean-client-summary,.clean-provider-summary{margin-bottom:18px}.clean-client-tables,.clean-provider-tables{grid-template-columns:0.75fr 1.25fr}.mini-panel{background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:14px;min-width:0}.mini-panel-head{margin-bottom:12px}.mini-panel-head h3{margin:0;font-size:17px}.mini-panel-head p{margin:4px 0 0;color:var(--muted);font-size:12px}.clean-client-ops-panel,.clean-provider-clients-panel,.clean-provider-ops-panel{margin-top:18px}.total-row{background:rgba(117,196,255,.10);font-weight:900}.total-row td{border-top:1px solid rgba(117,196,255,.22)}#tablaCleanSalesClientPivot,#tablaCleanSalesProviderPivot{min-width:920px}#tablaCleanSalesClientPivot td,#tablaCleanSalesClientPivot th,#tablaCleanSalesProviderPivot td,#tablaCleanSalesProviderPivot th{white-space:nowrap}.top-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
@media(max-width:1180px){.clean-client-tables,.clean-provider-tables{grid-template-columns:1fr}.top-actions{justify-content:flex-start}}

.upload-box{display:grid;gap:12px}.load-options{display:grid;gap:8px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.045);border-radius:18px;padding:12px}.load-options label{display:flex;align-items:center;gap:9px;color:#dcecff;font-size:13px;font-weight:800}.load-options input{min-height:auto;width:18px;height:18px;padding:0;accent-color:#00dcc5}.load-options small{color:var(--muted);font-size:12px;line-height:1.4}
