:root{--bg: #000000;--fg: #ffffff;--bd: rgba(255, 255, 255, .07);--bd-strong: rgba(255, 255, 255, .15);--muted: rgba(255, 255, 255, .55);--accent-green: #00d97e;--accent-red: #ff4757;--font-display: "Chakra Petch", system-ui, sans-serif;--font-body: "Outfit", system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, monospace}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{background:var(--bg);color:var(--fg);font-family:var(--font-body);min-height:100vh;-webkit-font-smoothing:antialiased}.mono{font-family:var(--font-mono)}.display{font-family:var(--font-display)}.auth-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.auth-card{width:100%;max-width:420px;padding:32px;border:1px solid var(--bd);background:#050505}.auth-title{font-size:22px;letter-spacing:1px;margin-bottom:4px}.auth-sub{font-size:13px;margin-bottom:28px}.auth-form{display:flex;flex-direction:column;gap:0}.auth-switch{display:block;width:100%;margin-top:20px;padding:8px;background:transparent;border:none;color:var(--muted);font-family:var(--font-body);font-size:13px;cursor:pointer;text-align:center;transition:color .15s ease}.auth-switch:hover{color:var(--fg)}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.field-label{font-family:var(--font-mono);font-size:11px;letter-spacing:.5px;text-transform:uppercase;color:var(--muted)}.field-input{font-family:var(--font-mono);font-size:14px;padding:12px 14px;min-height:44px;background:transparent;border:1px solid var(--bd);color:var(--fg);outline:none;transition:border-color .15s ease;width:100%;box-sizing:border-box}.field-input:focus{border-color:var(--bd-strong)}.btn{display:inline-block;padding:12px 24px;min-height:44px;font-family:var(--font-display);font-size:12px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;background:transparent;border:1px solid var(--bd-strong);color:var(--fg);cursor:pointer;transition:border-color .15s ease,background .15s ease,color .15s ease;text-align:center}.btn:hover:not(:disabled){border-color:var(--fg)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--fg);color:var(--bg);border-color:var(--fg);width:100%;margin-top:8px}.btn-primary:hover:not(:disabled){background:transparent;color:var(--fg)}.btn-secondary{background:transparent;color:var(--fg)}.btn-danger{background:transparent;border-color:var(--accent-red);color:var(--accent-red)}.btn-danger:hover:not(:disabled){background:#ff475714;border-color:var(--accent-red);color:var(--accent-red)}.app-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--bd);flex-wrap:wrap;gap:12px}.app-title{font-size:18px;letter-spacing:1px}.app-header-right{display:flex;align-items:center;gap:16px}.app-user-email{font-size:12px}@media(max-width:480px){.app-user-email{display:none}}.container{max-width:960px;margin:0 auto;padding:32px 24px;display:flex;flex-direction:column;gap:24px}.panel{border:1px solid var(--bd);padding:24px;background:#050505}.panel-title{font-size:14px;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:16px;color:var(--muted)}.panel-desc{font-size:14px;line-height:1.6;margin-bottom:16px}.kv{display:grid;grid-template-columns:120px 1fr;gap:8px 16px;font-size:13px}.kv dt{color:var(--muted);text-transform:uppercase;font-size:11px;letter-spacing:.5px;padding-top:2px}.kv dd{color:var(--fg);word-break:break-all}@media(max-width:480px){.kv{grid-template-columns:1fr;gap:4px}.kv dt{margin-top:8px}}.error-box{margin-top:16px;padding:12px;border:1px solid var(--accent-red);color:var(--accent-red);font-family:var(--font-mono);font-size:12px;background:#ff47570d}.result-box{margin-top:16px;padding:16px;border:1px solid var(--accent-green);background:#00d97e0a;color:var(--accent-green);font-size:12px;white-space:pre-wrap;word-break:break-all;overflow-x:auto}.loading-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;color:var(--muted);font-family:var(--font-mono)}.back-link{display:inline-block;color:var(--muted);font-size:12px;text-decoration:none;padding:4px 0;transition:color .15s ease;margin-bottom:-8px}.back-link:hover{color:var(--fg)}.cuenta-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.cuenta-card{text-align:left;background:transparent;border:1px solid var(--bd);padding:20px;color:var(--fg);cursor:pointer;font-family:var(--font-body);transition:border-color .15s ease,background .15s ease;display:flex;flex-direction:column;gap:6px;min-height:100px}.cuenta-card:hover{border-color:var(--bd-strong);background:#ffffff04}.cuenta-card-code{font-size:18px;font-weight:600;letter-spacing:.5px}.cuenta-card-name{font-size:14px;color:var(--fg)}.cuenta-card-meta{font-size:11px;margin-top:auto;letter-spacing:.3px}.medidor-list{display:flex;flex-direction:column;gap:8px}.medidor-row{display:flex;align-items:center;gap:16px;padding:12px 16px;border:1px solid var(--bd)}.medidor-num{font-size:14px;font-weight:600;color:var(--muted);min-width:32px}.medidor-info{display:flex;flex-direction:column;gap:2px;flex:1}.medidor-nombre{font-size:14px}.medidor-meta{font-size:11px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}.form-row-3{grid-template-columns:1fr 1fr 1fr}@media(max-width:600px){.form-row,.form-row-3{grid-template-columns:1fr}}.lectura-row{display:grid;grid-template-columns:60px 1fr 1fr;gap:12px;align-items:center;margin-bottom:10px}.lectura-band{font-size:13px;font-weight:600;letter-spacing:1px;color:var(--muted);padding-left:4px}@media(max-width:480px){.lectura-row{grid-template-columns:1fr;gap:6px;padding:10px 12px;border:1px solid var(--bd);margin-bottom:8px}.lectura-band{padding-left:0}}.kv-tarifa,.kv-resultado{margin-top:8px;font-size:13px}.kv-resultado .total-label{color:var(--accent-green);font-size:13px;font-weight:700;letter-spacing:1px}.kv-resultado .total-value{color:var(--accent-green);font-size:18px;font-weight:700}.panel-resultado{border-color:var(--bd-strong)}.warn-box{margin-top:12px;padding:12px;border:1px solid #fbbf24;background:#fbbf240d;color:#fbbf24;font-size:12px}.small{font-size:11px}.panel-head-row{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;flex-wrap:wrap}.panel-head-row .panel-title{margin-bottom:0}.btn-inline{width:auto;margin-top:0;text-decoration:none;font-size:11px;padding:10px 16px}.factura-list{display:flex;flex-direction:column;gap:6px}.factura-row{display:grid;grid-template-columns:1fr 2fr auto;gap:16px;align-items:center;padding:12px 16px;border:1px solid var(--bd)}.factura-period{font-size:14px;font-weight:600}.factura-meta{font-size:11px}.factura-total{font-size:14px;font-weight:600;color:var(--accent-green);text-align:right}@media(max-width:600px){.factura-row{grid-template-columns:1fr auto;grid-template-rows:auto auto}.factura-meta{grid-column:1 / -1;grid-row:2}}.subpanel-title{font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin-top:20px;margin-bottom:8px}.factura-row-link{text-decoration:none;color:inherit;display:grid;transition:border-color .15s ease,background .15s ease}.factura-row-link:hover{border-color:var(--bd-strong);background:#ffffff04}.dist-list{display:flex;flex-direction:column;gap:6px;margin-top:12px}.dist-preview{margin-bottom:12px}.dist-row{display:grid;grid-template-columns:1fr 2fr auto;gap:16px;align-items:center;padding:12px 16px;border:1px solid var(--bd)}.dist-name{font-size:14px}.dist-meta{font-size:11px}.dist-monto{font-size:14px;font-weight:600;color:var(--accent-green);text-align:right}@media(max-width:600px){.dist-row{grid-template-columns:1fr auto}.dist-meta{grid-column:1 / -1}}.insight-list{display:flex;flex-direction:column;gap:10px}.insight-card{border:1px solid var(--bd);padding:16px;border-left-width:3px}.insight-card.insight-media{border-left-color:#fbbf24}.insight-card.insight-alta{border-left-color:var(--accent-red)}.insight-card.insight-info{border-left-color:var(--accent-green)}.insight-title{font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin-bottom:8px}.insight-body{font-size:13px;line-height:1.6}.admin-actions-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.dist-row-admin{grid-template-columns:1fr 1.5fr auto auto}.row-icon-actions{display:flex;gap:6px;justify-content:flex-end}.icon-action{width:36px;height:36px;border:1px solid var(--bd);background:transparent;color:var(--fg);cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.icon-action:hover:not(:disabled){border-color:var(--bd-strong);background:#ffffff08}.icon-action:disabled{opacity:.35;cursor:not-allowed}.icon-action-danger{color:var(--accent-red)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bd;display:flex;align-items:center;justify-content:center;padding:18px;z-index:80}.modal-panel{width:min(100%,480px);border:1px solid var(--bd-strong);background:#050505;padding:24px;box-shadow:0 18px 60px #0000008c}.modal-title{font-size:16px;letter-spacing:.08em;margin-bottom:14px}.modal-copy{color:#ffffffad;line-height:1.55;font-size:14px;margin-bottom:20px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:18px;flex-wrap:wrap}.modal-actions .btn,.modal-actions .btn-primary{width:auto;margin-top:0}.admin-toast{position:sticky;top:12px;z-index:30;margin-left:auto;width:min(100%,420px);padding:12px 14px;border:1px solid var(--bd-strong);background:#050505;font-family:var(--font-mono);font-size:12px;line-height:1.5}.admin-toast-success{border-color:var(--accent-green);color:var(--accent-green)}.admin-toast-error{border-color:var(--accent-red);color:var(--accent-red)}@media(max-width:600px){.dist-row-admin{grid-template-columns:1fr auto}.row-icon-actions{grid-column:1 / -1;justify-content:flex-start}.modal-actions{flex-direction:column-reverse}.modal-actions .btn,.modal-actions .btn-primary,.modal-actions .btn-danger{width:100%}}.cliente-page{min-height:100vh;background:var(--bg);color:var(--fg)}.cliente-container{width:100%;max-width:760px;margin:0 auto;padding:28px 18px 48px;display:flex;flex-direction:column;gap:18px}.cliente-hero{padding:6px 0 4px}.cliente-title{font-size:24px;font-weight:600;letter-spacing:.04em;margin-bottom:8px}.cliente-subtitle{font-size:14px;line-height:1.5;color:var(--muted)}.cliente-message{display:flex;flex-direction:column;gap:8px;color:#ffffffad;font-size:15px;line-height:1.5}.cliente-section-title{font-size:14px;letter-spacing:.12em;color:var(--muted);margin-bottom:18px}.cliente-form-panel .btn-primary{min-height:58px;margin-top:18px;background:var(--accent-green);border-color:var(--accent-green);color:#000;font-size:16px;letter-spacing:.08em}.cliente-form-panel .btn-primary:hover:not(:disabled){background:transparent;color:var(--accent-green)}.cliente-lecturas-list{display:flex;flex-direction:column;gap:14px}.cliente-lectura-card{border:1px solid var(--bd);padding:16px;background:#ffffff03}.cliente-medidor-title{font-size:15px;letter-spacing:.05em;margin-bottom:14px}.cliente-lectura-previa,.cliente-lectura-field{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center;font-size:14px;color:#ffffffad;margin-bottom:10px}.cliente-lectura-field{grid-template-columns:1fr minmax(140px,220px);margin-bottom:0}.cliente-lectura-previa strong{color:var(--fg);font-size:16px}.cliente-lectura-input{min-height:56px;padding:12px 14px;border:1px solid var(--bd-strong);background:#000;color:var(--fg);font-size:20px;text-align:right;outline:none;width:100%}.cliente-lectura-input:focus{border-color:var(--fg)}.cliente-input-error{border-color:var(--accent-red);color:var(--accent-red)}.cliente-error-text,.cliente-warning-text{margin-top:10px;font-family:var(--font-mono);font-size:11px;line-height:1.4}.cliente-error-text{color:var(--accent-red)}.cliente-warning-text{color:#fbbf24}.cliente-reparto-card{border:1px solid var(--bd-strong);background:#050505;padding:24px}.cliente-periodo{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px}.cliente-total-label{color:var(--muted);font-family:var(--font-display);font-size:12px;letter-spacing:.14em;text-transform:uppercase}.cliente-total-monto{color:var(--accent-green);font-size:clamp(28px,9vw,54px);font-weight:700;line-height:1.1;margin:6px 0 24px}.cliente-reparto-title{font-size:13px;letter-spacing:.12em;color:var(--muted);margin-bottom:12px}.cliente-reparto-list{display:flex;flex-direction:column;gap:8px}.cliente-reparto-item{border-bottom:1px solid var(--bd);padding:12px 0}.cliente-reparto-row,.cliente-total-cargado{display:grid;grid-template-columns:1fr auto;gap:14px;align-items:baseline;padding:0}.cliente-reparto-row span,.cliente-total-cargado span{color:#ffffffc2}.cliente-reparto-row strong{color:var(--accent-green);font-size:1.55rem;text-align:right}.cliente-total-cargado{border-bottom:none;margin-top:8px}.cliente-secundario-lecturas{margin-top:12px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));border:1px solid var(--bd)}.cliente-secundario-lecturas div{min-height:44px;padding:10px 12px;border-right:1px solid var(--bd);display:flex;flex-direction:column;gap:4px}.cliente-secundario-lecturas div:last-child{border-right:none}.cliente-secundario-lecturas span{color:var(--muted);font-size:11px;line-height:1.25}.cliente-secundario-lecturas strong{color:var(--fg);font-size:13px;font-weight:600}.cliente-total-cargado strong{color:var(--fg);font-size:1rem}.cliente-nota{margin-top:18px;color:var(--muted);font-size:13px;line-height:1.5}.cliente-historial{padding:0}.cliente-historial-toggle{width:100%;min-height:54px;padding:0 18px;border:none;background:transparent;color:var(--muted);display:flex;align-items:center;justify-content:space-between;font-size:13px;letter-spacing:.12em;cursor:pointer}.cliente-historial-toggle:hover{color:var(--fg)}.cliente-historial-body{border-top:1px solid var(--bd);padding:12px}.cliente-historial-item{border:1px solid var(--bd);margin-bottom:8px}.cliente-historial-item:last-child{margin-bottom:0}.cliente-historial-row{display:grid;grid-template-columns:1fr auto auto;gap:12px;align-items:center;padding:12px;font-size:13px}.cliente-detalle-btn{border:1px solid var(--bd);background:transparent;color:var(--muted);min-height:36px;padding:0 10px;cursor:pointer;font-size:11px}.cliente-detalle-btn:hover{color:var(--fg);border-color:var(--bd-strong)}.cliente-historial-item .cliente-reparto-card{border:none;border-top:1px solid var(--bd);padding:18px 12px}.cliente-historial-item .cliente-total-monto{font-size:28px}.cliente-historial-empty{padding:0 12px 12px;font-size:13px}.cliente-detalle-panel{border:1px solid var(--bd);background:#050505}.cliente-detalle-toggle{width:100%;min-height:54px;padding:0 18px;border:none;background:transparent;color:var(--muted);display:flex;align-items:center;justify-content:space-between;font-size:13px;letter-spacing:.12em;cursor:pointer;text-align:left}.cliente-detalle-toggle:hover{color:var(--fg)}.cliente-detalle-body{border-top:1px solid var(--bd);padding:16px;display:flex;flex-direction:column;gap:18px}.cliente-detalle-block{border:1px solid var(--bd)}.cliente-detalle-title{min-height:44px;display:flex;align-items:center;padding:0 14px;border-bottom:1px solid var(--bd);color:var(--muted);font-size:11px;letter-spacing:.08em;text-transform:uppercase}.cliente-metric-grid,.cliente-cargos-list{display:flex;flex-direction:column}.cliente-metric-row,.cliente-cargo-row,.cliente-readings-row,.cliente-readings-head{min-height:44px;display:grid;align-items:center;gap:12px;padding:10px 14px;border-bottom:1px solid var(--bd);font-size:13px}.cliente-metric-row,.cliente-cargo-row{grid-template-columns:1fr auto}.cliente-metric-row:last-child,.cliente-cargo-row:last-child,.cliente-readings-row:last-child{border-bottom:none}.cliente-metric-row span,.cliente-cargo-row span{color:#ffffffb3}.cliente-metric-row strong,.cliente-cargo-row strong,.cliente-readings-row strong{text-align:right;font-weight:600}.cliente-readings-table{display:flex;flex-direction:column}.cliente-readings-head,.cliente-readings-row{grid-template-columns:.8fr 1fr 1fr}.cliente-readings-head{color:var(--muted);font-size:10px;letter-spacing:.08em;text-transform:uppercase}.cliente-detalle-note{padding:12px 14px;border-top:1px solid var(--bd);color:var(--muted);font-size:11px}.cliente-info-icon{width:28px;height:28px;margin-left:8px;border:1px solid var(--bd);background:transparent;color:var(--muted);cursor:help;font-family:var(--font-mono)}.cliente-cargo-total{border-top:1px solid var(--bd-strong)}.cliente-cargo-total span,.cliente-cargo-total strong{color:var(--accent-green);font-size:1rem}.cliente-cargo-total strong{font-size:1.25rem}.cliente-reparto-row-editable{grid-template-columns:1fr auto 44px}.cliente-edit-btn{width:44px;height:44px;border:1px solid var(--bd);background:transparent;color:var(--muted);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;justify-self:end}.cliente-edit-btn:hover{color:var(--fg);border-color:var(--bd-strong)}.cliente-historial-title{min-height:54px;display:flex;align-items:center;padding:0 18px;color:var(--muted);font-size:13px;letter-spacing:.12em;border-bottom:1px solid var(--bd)}.cliente-historial-card{width:100%;min-height:54px;display:grid;grid-template-columns:1fr auto auto;gap:12px;align-items:center;padding:12px;border:none;background:transparent;color:var(--fg);cursor:pointer;text-align:left}.cliente-historial-card:hover{background:#ffffff04}.cliente-historial-card strong{color:var(--accent-green)}.cliente-historial-detail{border-top:1px solid var(--bd);padding:12px;display:flex;flex-direction:column;gap:12px}.cliente-historial-detail .cliente-reparto-card{border:1px solid var(--bd)}.cliente-proximo-panel{border-color:var(--bd-strong)}.cliente-modal-note{color:var(--muted);font-size:13px;line-height:1.5}@media(max-width:480px){.cliente-container{padding:22px 14px 40px}.cliente-title{font-size:22px}.cliente-lectura-card{padding:14px}.cliente-lectura-previa,.cliente-lectura-field,.cliente-reparto-row,.cliente-total-cargado{grid-template-columns:1fr}.cliente-lectura-input,.cliente-reparto-row strong{text-align:left}.cliente-reparto-card{padding:20px 16px}.cliente-historial-row,.cliente-historial-card,.cliente-reparto-row-editable,.cliente-metric-row,.cliente-cargo-row{grid-template-columns:1fr}.cliente-readings-head,.cliente-readings-row{grid-template-columns:.6fr 1fr 1fr}.cliente-secundario-lecturas{grid-template-columns:1fr}.cliente-secundario-lecturas div{border-right:none;border-bottom:1px solid var(--bd)}.cliente-secundario-lecturas div:last-child{border-bottom:none}.cliente-metric-row strong,.cliente-cargo-row strong,.cliente-readings-row strong{text-align:left}.cliente-detalle-btn{width:100%}}
