:root{--bg: #0b1020;--panel: #131a30;--panel-2: #1a2240;--text: #e6ecff;--muted: #9aa6c7;--accent: #5b8cff;--good: #3ddc97;--bad: #ff5d73;--warn: #ffb454;--border: #2a335a}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;min-height:100vh}.app{max-width:1400px;margin:0 auto;padding:24px}.app-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.app-header h1{font-size:22px;margin:0;letter-spacing:.5px}.app-header .meta{color:var(--muted);font-size:13px}.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:16px}.card{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:18px}.card h3{margin:0 0 12px;font-size:14px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.6px}.kpi-row{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--border)}.kpi-row:last-child{border-bottom:none}.kpi-row .label{color:var(--muted);font-size:13px}.kpi-row .value{font-weight:600}.badge{display:inline-block;padding:2px 8px;border-radius:8px;font-size:11px;font-weight:600}.badge.good{background:#3ddc9726;color:var(--good)}.badge.bad{background:#ff5d7326;color:var(--bad)}.badge.warn{background:#ffb45426;color:var(--warn)}.toolbar{display:flex;gap:12px;margin-bottom:16px;flex-wrap:wrap}.toolbar select,.toolbar input{background:var(--panel);border:1px solid var(--border);color:var(--text);padding:8px 10px;border-radius:8px;font-size:13px}.error{background:#ff5d7326;color:var(--bad);padding:10px;border-radius:8px;margin-bottom:16px}.loading{color:var(--muted);padding:20px}table.aging{width:100%;border-collapse:collapse;margin-top:8px}table.aging th,table.aging td{padding:6px 8px;text-align:right;border-bottom:1px solid var(--border);font-size:13px}table.aging th:first-child,table.aging td:first-child{text-align:left}table.aging th{color:var(--muted);font-weight:500}.director-view{display:flex;flex-direction:column;gap:16px}.director-toolbar{display:flex;gap:20px;align-items:flex-end;flex-wrap:wrap;background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:14px 18px}.director-toolbar__group{display:flex;flex-direction:column;gap:6px}.director-toolbar__group label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.6px}.director-toolbar__group select{background:var(--panel-2);border:1px solid var(--border);color:var(--text);padding:8px 12px;border-radius:8px;font-size:13px;min-width:160px}.director-toolbar__meta{margin-left:auto;color:var(--muted);font-size:12px;display:flex;flex-direction:column;align-items:flex-end;gap:2px;text-align:right}.director-toolbar__updated{font-size:11px;color:var(--muted);opacity:.85}.director-toolbar__group--pills{flex:1 1 auto;min-width:0}.period-pills{display:flex;flex-wrap:wrap;align-items:center;gap:6px;padding:4px;background:var(--panel-2);border:1px solid var(--border);border-radius:10px}.period-pill{background:transparent;border:1px solid transparent;color:var(--text);padding:6px 12px;border-radius:7px;font-size:12px;font-weight:500;cursor:pointer;transition:background .12s ease,color .12s ease,border-color .12s ease;letter-spacing:.2px;font-family:inherit}.period-pill:hover:not(.period-pill--active){background:#5b8cff1f;color:var(--text)}.period-pill--active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 2px 6px #5b8cff40}.period-pills__sep{width:1px;height:18px;background:var(--border);margin:0 2px;flex-shrink:0}.period-pills--mode{flex-wrap:nowrap}.period-pills--mode .period-pill{min-width:64px;text-align:center}.empresa-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.empresa-card{text-align:left;background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:18px;color:var(--text);cursor:pointer;transition:transform .12s ease,border-color .12s ease,box-shadow .12s ease;display:flex;flex-direction:column;gap:10px;font:inherit}.empresa-card:hover:not(:disabled){transform:translateY(-2px);border-color:var(--accent);box-shadow:0 8px 24px #5b8cff1f}.empresa-card--disabled,.empresa-card:disabled{cursor:not-allowed;opacity:.55;filter:grayscale(.85)}.empresa-card__logo{height:56px;background:#ffffffeb;border-radius:10px;padding:6px 12px;display:flex;align-items:center;justify-content:center;overflow:hidden}.empresa-card__logo img{max-height:100%;max-width:100%;object-fit:contain;display:block}.empresa-card__logo-fallback{font-weight:800;letter-spacing:1px;color:#2b2b2b;font-size:22px}.empresa-card__nombre{font-size:16px;font-weight:600}.empresa-card__meta{font-size:12px;color:var(--muted)}.empresa-card__estado{display:flex;flex-direction:column;gap:6px;padding-top:8px}.empresa-card__kpis{display:grid;grid-template-columns:1fr 1fr;gap:10px 14px;margin-top:6px}.kpi-block{display:flex;flex-direction:column;gap:2px;padding:8px 0;border-top:1px solid var(--border)}.kpi-block:first-child,.kpi-block:nth-child(2){border-top:none}.kpi-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;display:inline-flex;align-items:center;gap:4px}.kpi-value{font-size:18px;font-weight:600}.kpi-value--good{color:var(--good)}.kpi-value--warn{color:var(--warn)}.kpi-value--bad{color:var(--bad)}.kpi-value--muted{color:var(--muted)}.kpi-sub{font-size:11px;color:var(--muted);font-weight:400;margin-left:6px}.info-tip{position:relative;display:inline-flex;align-items:center;color:var(--muted);cursor:help;outline:none}.info-tip:hover,.info-tip:focus-visible{color:var(--accent)}.info-tip-bubble{position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);width:max-content;max-width:260px;background:#0e1530;color:var(--text);border:1px solid var(--border);padding:8px 10px;border-radius:8px;font-size:12px;line-height:1.4;text-transform:none;letter-spacing:0;font-weight:400;z-index:50;box-shadow:0 8px 24px #00000059;white-space:normal}.breadcrumb{display:flex;align-items:center;gap:8px;margin-bottom:14px;font-size:13px;color:var(--muted)}.breadcrumb__link{background:transparent;border:1px solid var(--border);color:var(--text);padding:4px 10px;border-radius:8px;cursor:pointer;font-size:13px}.breadcrumb__link:hover{border-color:var(--accent)}.breadcrumb__sep{color:var(--muted)}.breadcrumb__current{color:var(--text);font-weight:500}.detail-toolbar{display:flex;gap:18px;align-items:flex-end;flex-wrap:wrap;margin-bottom:16px;background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:12px 16px}.detail-toolbar__group{display:flex;flex-direction:column;gap:6px}.detail-toolbar__group label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.6px}.detail-toolbar__group select{background:var(--panel-2);border:1px solid var(--border);color:var(--text);padding:8px 12px;border-radius:8px;font-size:13px;min-width:160px}.detail-toolbar__tabs{display:flex;gap:8px;margin-left:auto}.tab{background:var(--panel-2);border:1px solid var(--border);color:var(--text);padding:8px 16px;border-radius:8px;cursor:pointer;font-size:13px}.tab--active{background:var(--accent);color:#fff;border-color:var(--accent)}.empresa-card__header{display:flex;flex-direction:column;gap:2px;padding-bottom:4px;border-bottom:1px solid var(--border)}.empresa-card__badge{margin-top:8px;align-self:flex-start}.empresa-card__body{display:flex;flex-direction:column;gap:12px;margin-top:4px}.empresa-card__footer{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding-top:10px;border-top:1px solid var(--border)}.empresa-card__footer .kpi-block{border-top:none;padding:0}.categoria-block{background:var(--panel-2);border:1px solid var(--border);border-radius:10px;padding:10px 12px;display:flex;flex-direction:column;gap:8px}.categoria-block__header{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.categoria-block__titulo{font-size:13px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;color:var(--text)}.categoria-block__sub{font-size:11px;color:var(--muted)}.categoria-block__kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:6px 10px}.categoria-block__kpis--b{grid-template-columns:1.3fr 1fr}.kpi-mini{display:flex;flex-direction:column;gap:2px;min-width:0}.kpi-mini__label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;display:inline-flex;align-items:center;gap:3px;white-space:nowrap}.kpi-mini__value{font-size:15px;font-weight:600;line-height:1.15}.kpi-mini__sub{font-size:11px;font-weight:400;color:var(--muted);margin-left:2px}.kpi-mini__value .kpi-mini__sub{color:var(--muted)}.kpi-mini__value.kpi-value--good{color:var(--good)}.kpi-mini__value.kpi-value--warn{color:var(--warn)}.kpi-mini__value.kpi-value--bad{color:var(--bad)}.kpi-mini__value.kpi-value--muted{color:var(--muted)}@media (max-width: 1100px){.categoria-block__kpis{grid-template-columns:repeat(2,1fr)}}.stock-view{display:flex;flex-direction:column;gap:24px}.stock-section{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:16px 18px;display:flex;flex-direction:column;gap:12px}.stock-section__header{display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:8px;padding-bottom:8px;border-bottom:1px solid var(--border)}.stock-section__titulo{margin:0;font-size:16px;font-weight:600;letter-spacing:.3px}.stock-section__resumen{font-size:13px;color:var(--muted);display:flex;gap:6px;align-items:baseline}.stock-section__resumen strong{color:var(--text)}.stock-section__sep{opacity:.5}.stock-buckets{display:flex;flex-direction:column;gap:8px}.bucket-card{background:var(--panel-2);border:1px solid var(--border);border-radius:10px;overflow:hidden;transition:border-color .12s ease}.bucket-card--open{border-color:var(--accent)}.bucket-card__head{width:100%;background:transparent;border:none;color:var(--text);padding:12px 14px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:12px;font-family:inherit;font-size:13px;text-align:left}.bucket-card__head:hover{background:#5b8cff0f}.bucket-card__head-left{display:flex;align-items:center;gap:10px;min-width:0;flex:1}.bucket-card__caret{color:var(--muted);font-size:12px;width:12px;display:inline-block;text-align:center}.bucket-card__label{font-weight:600;font-size:14px}.bucket-card__desc{color:var(--muted);font-size:11px}.bucket-card__head-right{display:flex;align-items:center;gap:14px;flex-shrink:0}.bucket-card__cant{font-weight:700;font-size:16px}.bucket-card__cant-sub{font-size:11px;font-weight:400;color:var(--muted);margin-left:2px}.bucket-card__pct{color:var(--muted);font-size:12px;min-width:36px;text-align:right}.bucket-card__valor{color:var(--text);font-size:12px;min-width:80px;text-align:right;opacity:.8}.bucket-card__body{border-top:1px solid var(--border);padding:12px 14px;display:flex;flex-direction:column;gap:10px;background:#00000026}.bucket-card__search{display:flex;align-items:center;gap:10px}.bucket-card__search input{flex:1;background:var(--panel);border:1px solid var(--border);color:var(--text);padding:8px 12px;border-radius:8px;font-size:13px;font-family:inherit}.bucket-card__search input:focus{outline:none;border-color:var(--accent)}.bucket-card__count{font-size:12px;color:var(--muted);font-variant-numeric:tabular-nums}.bucket-table-wrap{overflow-x:auto;max-height:360px;overflow-y:auto;border:1px solid var(--border);border-radius:8px}.bucket-table{width:100%;border-collapse:collapse;font-size:12px}.bucket-table th,.bucket-table td{padding:8px 10px;border-bottom:1px solid var(--border);text-align:left;white-space:nowrap}.bucket-table th{position:sticky;top:0;background:var(--panel);color:var(--muted);font-weight:500;text-transform:uppercase;letter-spacing:.5px;font-size:11px;z-index:1}.bucket-table td.num,.bucket-table th.num{text-align:right;font-variant-numeric:tabular-nums}.bucket-table td.mono{font-family:ui-monospace,Menlo,Consolas,monospace;font-size:11px;color:var(--muted)}.bucket-table tbody tr:hover{background:#5b8cff0f}.bucket-table tbody tr:last-child td{border-bottom:none}.kpi-mini--clickable{cursor:pointer;border-radius:8px;transition:background-color .15s ease,transform .05s ease;padding:4px 6px;margin:-4px -6px}.kpi-mini--clickable:hover{background:#5b8cff14}.kpi-mini--clickable:active{transform:scale(.98)}.kpi-mini--clickable:focus-visible{outline:2px solid var(--accent, #5b8cff);outline-offset:1px}.kpi-block--clickable{cursor:pointer;border-radius:8px;transition:background-color .15s ease,transform .05s ease}.kpi-block--clickable:hover{background:#5b8cff14}.kpi-block--clickable:active{transform:scale(.99)}.kpi-block--clickable:focus-visible{outline:2px solid var(--accent, #5b8cff);outline-offset:1px}.ventas-detalle-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:100;display:flex;align-items:center;justify-content:center;padding:24px;animation:vd-fade-in .15s ease}@keyframes vd-fade-in{0%{opacity:0}to{opacity:1}}.ventas-detalle-modal{background:var(--panel, #fff);color:var(--text, #1a1a1a);border-radius:14px;box-shadow:0 20px 50px #00000059;width:min(960px,100%);max-height:88vh;overflow:hidden;display:flex;flex-direction:column}.ventas-detalle-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--border, rgba(0,0,0,.08));background:linear-gradient(180deg,rgba(91,140,255,.08),transparent)}.ventas-detalle-title{font-size:18px;font-weight:600}.ventas-detalle-sub{font-size:13px;color:var(--muted, #6b7280);margin-top:2px}.ventas-detalle-close{background:transparent;border:none;font-size:26px;line-height:1;cursor:pointer;color:var(--muted, #6b7280);padding:4px 10px;border-radius:6px}.ventas-detalle-close:hover{background:#0000000f;color:var(--text, #1a1a1a)}.ventas-detalle-body{overflow-y:auto;padding:18px 24px 24px;display:flex;flex-direction:column;gap:22px}.ventas-detalle-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.summary-pill{background:#5b8cff0f;border:1px solid rgba(91,140,255,.15);border-radius:10px;padding:10px 14px;display:flex;flex-direction:column;gap:2px}.summary-pill__label{font-size:11px;color:var(--muted, #6b7280);text-transform:uppercase;letter-spacing:.04em}.summary-pill__value{font-size:18px;font-weight:600}.summary-pill__sub{font-size:12px;font-weight:400;color:var(--muted, #6b7280)}.ventas-detalle-section{display:flex;flex-direction:column;gap:8px}.ventas-detalle-section__head{display:flex;align-items:center;justify-content:space-between;gap:12px}.ventas-detalle-section h3{font-size:14px;font-weight:600;margin:0;text-transform:uppercase;letter-spacing:.04em;color:var(--muted, #6b7280)}.ventas-detalle-section__hint{font-size:12px;color:var(--muted, #6b7280);background:#ffc10714;border-left:3px solid rgba(255,193,7,.55);padding:6px 10px;border-radius:4px}.ventas-detalle-section__empty{color:var(--muted, #6b7280);font-size:13px;padding:8px 0}.ventas-detalle-table{width:100%;border-collapse:collapse;font-size:13px}.ventas-detalle-table thead th{text-align:left;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted, #6b7280);padding:8px 10px;border-bottom:1px solid var(--border, rgba(0,0,0,.08));background:#00000005;position:sticky;top:0}.ventas-detalle-table th.num,.ventas-detalle-table td.num{text-align:right;font-variant-numeric:tabular-nums}.ventas-detalle-table tbody td{padding:8px 10px;border-bottom:1px solid var(--border, rgba(0,0,0,.05))}.ventas-detalle-table tbody tr:hover{background:#5b8cff0a}.ventas-detalle-table .rank{display:inline-block;font-size:11px;font-weight:600;color:var(--accent, #5b8cff);background:#5b8cff1a;padding:1px 6px;border-radius:4px;margin-right:6px;min-width:26px;text-align:center}.top-n-controls{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--muted, #6b7280)}.top-n-controls .period-pill{padding:3px 9px;font-size:11px}@media (max-width: 640px){.ventas-detalle-modal{max-height:95vh}.ventas-detalle-summary{grid-template-columns:1fr}.ventas-detalle-body{padding:14px 16px 18px}.ventas-detalle-header{padding:14px 16px}}
