body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:20px;text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{margin-bottom:30px}.App-header h1{color:#fff;font-size:2.5rem;margin:0;text-shadow:2px 2px 4px #0000004d}.nav-buttons{display:flex;flex-wrap:wrap;gap:15px;justify-content:center;margin-top:20px}.nav-button{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:2px solid #ffffff4d;border-radius:25px;color:#fff;cursor:pointer;font-size:1rem;font-weight:700;min-width:120px;padding:12px 24px;text-align:center;transition:all .3s ease}.nav-button:hover{background:#ffffff4d;border-color:#ffffff80;transform:translateY(-2px)}.nav-button.activo{background:#ffffffe6;border-color:#fff;box-shadow:0 4px 15px #ffffff4d;color:#667eea}.nav-button.activo:hover{background:#fff;box-shadow:0 6px 20px #fff6;transform:translateY(-2px)}main{margin:0 auto;max-width:1200px}.horas-container{background:#fff;border-radius:15px;box-shadow:0 10px 30px #0003;padding:30px}.header-section{margin-bottom:30px}.header-section h2{color:#333;font-size:2rem;margin:0 0 20px}.filtro-section{align-items:center;display:flex;flex-wrap:wrap;gap:15px}.filtro-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:25px;box-shadow:0 4px 15px #667eea4d;color:#fff;cursor:pointer;font-size:1rem;font-weight:700;padding:12px 20px;transition:all .3s ease}.filtro-button:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.filtro-button.activo{background:linear-gradient(135deg,#e74c3c,#c0392b);box-shadow:0 4px 15px #e74c3c4d}.filtro-button.activo:hover{box-shadow:0 6px 20px #e74c3c66}.filtro-indicator{background:#e8f5e8;border:2px solid #4caf50;border-radius:20px;color:#2e7d32;font-size:.9rem;font-weight:500;padding:8px 15px}.exclusion-info{align-items:center;background:#fff3cd;border:2px solid #ffc107;border-radius:10px;color:#856404;display:flex;font-size:.9rem;gap:10px;margin-top:15px;padding:12px 15px}.exclusion-info.motivos{background:#f8d7da;border:2px solid #dc3545;color:#721c24;margin-top:10px}.exclusion-info.excepcion{background:#d1ecf1;border:2px solid #17a2b8;color:#0c5460;margin-top:10px}.exclusion-info.conceptos{background:#e2e3e5;border-left:4px solid #6c757d;color:#383d41;margin-top:10px}.exclusion-icon{font-size:1.1rem}.exclusion-text{font-weight:500}.loading{color:#fff;font-size:1.2rem}.error{background:#fff;border-radius:10px;color:#ff6b6b;margin:20px 0;padding:20px}.clientes-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));margin-top:20px}.cliente-card{background:#f8f9fa;border-left:5px solid #667eea;border-radius:10px;overflow:hidden;padding:0;transition:transform .2s}.cliente-card:hover{transform:translateY(-2px)}.cliente-card.con-contratos-excedidos{background:ivory;border-left:5px solid #f39c12;box-shadow:0 4px 15px #f39c1233}.cliente-card.con-contratos-excedidos .cliente-header{background:linear-gradient(135deg,#f39c12,#e67e22)}.cliente-card.con-contratos-excedidos .cliente-header:hover{background:linear-gradient(135deg,#e67e22,#d35400)}.cliente-card.con-contratos-excedidos .cliente-nombre{color:#fff;text-shadow:1px 1px 2px #0000004d}.cliente-card.con-contratos-excedidos .resumen-valor-consumidas,.cliente-card.con-contratos-excedidos .resumen-valor-utilizacion{color:#e74c3c;font-weight:700}.cliente-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;cursor:pointer;display:flex;justify-content:space-between;padding:20px;transition:background .3s}.cliente-header:hover{background:linear-gradient(135deg,#5a6fd8,#6a4190)}.cliente-info{flex:1 1}.cliente-nombre{font-size:1.4rem;font-weight:700;margin-bottom:10px;text-align:left}.cliente-resumen{display:flex;flex-direction:column;gap:5px;text-align:left}.resumen-item{align-items:center;font-size:.9rem;justify-content:space-between}.resumen-label{opacity:.9}.resumen-valor-consumidas{color:#ff6b6b;font-weight:700}.resumen-valor-contratadas{color:#446943;font-weight:700}.resumen-valor-utilizacion{color:#339af0;font-weight:700}.expand-button{align-items:center;background:#fff3;border-radius:50%;display:flex;font-size:1.5rem;font-weight:700;height:30px;justify-content:center;margin-left:15px;width:30px}.contratos-section{background:#fff;padding:20px}.contratos-section h4{color:#333;font-size:1.1rem;margin:0 0 15px;text-align:left}.contratos-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.contrato-card{background:#f8f9fa;border-left:3px solid #339af0;border-radius:8px;padding:15px;position:relative;transition:all .3s ease}.contrato-card.excedido{background:#fff5f5;border-left:3px solid #e74c3c;box-shadow:0 2px 8px #e74c3c33}.contrato-card.excedido .contrato-nombre{color:#c0392b}.contrato-card.excedido .detalle-valor-aplicadas,.contrato-card.excedido .detalle-valor-utilizacion{color:#e74c3c;font-size:1.1rem;font-weight:700}.contrato-nombre{word-wrap:break-word;border-bottom:2px solid #e9ecef;color:#2c3e50;font-size:1.1rem;font-weight:700;line-height:1.3;margin-bottom:12px;min-height:50px;padding:8px 0;text-align:left}.contrato-label{background:#e9ecef;border-radius:6px;color:#333;display:inline-block;font-size:1rem;font-weight:500;margin-right:8px;padding:2px 6px;vertical-align:middle}.contrato-detalles{margin-bottom:10px}.contrato-actions{align-items:flex-end;display:flex;flex-direction:column;gap:10px}.ver-detalle-button{background:#bdbdbd;border:none;border-radius:8px;color:#fff;cursor:pointer;display:block;font-size:.7em;font-weight:500;margin:10px auto 0;min-height:16px;min-width:40px;padding:1px 6px;transition:background .2s,box-shadow .2s}.ver-detalle-button:hover{background:#bdbdbd;box-shadow:0 2px 8px #bdbdbd1a;color:#fff}.detalle-row{align-items:center;display:flex;font-size:.85rem;justify-content:space-between;margin-bottom:5px}.detalle-label{color:#666}.detalle-valor-aplicadas{color:#e74c3c;font-weight:700}.detalle-valor-contratadas{color:#2ecc71;font-weight:700}.detalle-valor-utilizacion{color:#3498db;font-weight:700}.estado-badge{border-radius:4px;color:#fff;font-size:.5rem;font-weight:700;height:12px;padding:2px 4px;position:absolute;right:1px;top:1px;z-index:0}.total-section{background:#667eea;border-radius:10px;color:#fff;margin-top:20px;padding:20px}.total-section h3{font-size:1.5rem;margin:0 0 20px}.total-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.total-item{text-align:center}.total-label{font-size:.9rem;margin-bottom:5px;opacity:.9}.total-valor{font-size:1.8rem;font-weight:700}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.categorias-grid{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));margin-top:20px}.categoria-card{background:#f8f9fa;border-left:6px solid #667eea;border-radius:12px;box-shadow:0 4px 12px #0000001a;overflow:hidden;padding:0;transition:transform .2s}.categoria-card:hover{box-shadow:0 6px 20px #00000026;transform:translateY(-3px)}.categoria-card.con-contratos-excedidos{background:#fff3e0;border-left:5px solid #ffb74d;box-shadow:0 4px 15px #ffb74d4d}.categoria-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;cursor:pointer;display:flex;justify-content:space-between;padding:25px;transition:background .3s}.categoria-header:hover{background:linear-gradient(135deg,#5a6fd8,#6a4190)}.categoria-card.con-contratos-excedidos .categoria-header{background:linear-gradient(135deg,#ffb74d,#ffa726)}.categoria-card.con-contratos-excedidos .categoria-header:hover{background:linear-gradient(135deg,#ffa726,#ff9800)}.categoria-info{flex:1 1}.categoria-nombre{font-size:1.6rem;font-weight:700;margin-bottom:12px;text-align:left;text-shadow:1px 1px 2px #0000004d}.categoria-resumen{display:flex;flex-direction:column;gap:6px;text-align:left}.categoria-card.con-contratos-excedidos .resumen-valor-consumidas,.categoria-card.con-contratos-excedidos .resumen-valor-utilizacion{color:#e74c3c;font-weight:700}.clientes-section{background:#fff;padding:25px}.clientes-section h4{border-bottom:2px solid #e9ecef;color:#333;font-size:1.3rem;margin:0 0 20px;padding-bottom:10px;text-align:left}.clientes-section .clientes-grid{gap:15px;grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.clientes-section .cliente-card{border-left:4px solid #339af0}.clientes-section .cliente-card.con-contratos-excedidos{border-left:4px solid #e74c3c}.clientes-section .cliente-header{background:linear-gradient(135deg,#339af0,#1971c2);padding:18px}.clientes-section .cliente-header:hover{background:linear-gradient(135deg,#228be6,#1864ab)}.clientes-section .cliente-card.con-contratos-excedidos .cliente-header{background:linear-gradient(135deg,#e74c3c,#c0392b)}.clientes-section .cliente-card.con-contratos-excedidos .cliente-header:hover{background:linear-gradient(135deg,#d63031,#a93226)}.clientes-section .cliente-nombre{font-size:1.2rem;margin-bottom:8px}.clientes-section .cliente-resumen{gap:4px}.clientes-section .resumen-item{font-size:.85rem}@media (max-width:768px){.nav-buttons{align-items:center;flex-direction:column;gap:10px;padding:0 20px}.nav-button{font-size:.95rem;max-width:300px;min-width:auto;padding:15px 20px;width:100%}.App-header h1{font-size:2rem;padding:0 10px}.App{padding:10px}.horas-container{margin:10px;padding:20px}.header-section h2{font-size:1.5rem}.categorias-grid{gap:20px;grid-template-columns:1fr}.categoria-header{padding:20px}.categoria-nombre{font-size:1.4rem}.clientes-section{padding:20px}.clientes-section .clientes-grid{grid-template-columns:1fr}}.productos-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));margin-top:20px}.producto-card{background:#f8f9fa;border-left:5px solid #667eea;border-radius:10px;box-shadow:0 4px 15px #0000001a;overflow:hidden;padding:0;transition:transform .2s}.producto-card:hover{box-shadow:0 6px 25px #00000026;transform:translateY(-3px)}.producto-card.con-contratos-excedidos{background:#fff3e0;border-left:5px solid #ffb74d;box-shadow:0 4px 15px #ffb74d4d}.producto-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;cursor:pointer;display:flex;justify-content:space-between;padding:20px;transition:background .3s}.producto-header:hover{background:linear-gradient(135deg,#5a6fd8,#6a4190)}.producto-card.con-contratos-excedidos .producto-header{background:linear-gradient(135deg,#ffb74d,#ffa726)}.producto-card.con-contratos-excedidos .producto-header:hover{background:linear-gradient(135deg,#ffa726,#ff9800)}.producto-info{flex:1 1}.producto-nombre{font-size:1.4rem;font-weight:700;margin-bottom:10px;text-align:left;text-shadow:1px 1px 2px #0000004d}.producto-resumen{display:flex;flex-direction:column;gap:8px;text-align:left}.producto-card.con-contratos-excedidos .resumen-valor-consumidas,.producto-card.con-contratos-excedidos .resumen-valor-utilizacion{color:#e74c3c;font-weight:700}.categorias-section{background:#fff;padding:30px}.categorias-section h4{border-bottom:3px solid #e9ecef;color:#333;font-size:1.5rem;margin:0 0 25px;padding-bottom:15px;text-align:left}.categorias-section .categorias-grid{gap:20px;grid-template-columns:repeat(auto-fit,minmax(400px,1fr))}.categorias-section .categoria-card{border-left:5px solid #339af0}.categorias-section .categoria-card.con-contratos-excedidos{border-left:5px solid #e74c3c}.categorias-section .categoria-header{background:linear-gradient(135deg,#339af0,#1971c2);padding:20px}.categorias-section .categoria-header:hover{background:linear-gradient(135deg,#228be6,#1864ab)}.categorias-section .categoria-card.con-contratos-excedidos .categoria-header{background:linear-gradient(135deg,#e74c3c,#c0392b)}.categorias-section .categoria-card.con-contratos-excedidos .categoria-header:hover{background:linear-gradient(135deg,#d63031,#a93226)}.categorias-section .categoria-nombre{font-size:1.3rem;margin-bottom:10px}.categorias-section .categoria-resumen{gap:5px}.categorias-section .resumen-item{font-size:.9rem}@media (max-width:768px){.productos-grid{gap:25px;grid-template-columns:1fr}.producto-header{padding:25px}.producto-nombre{font-size:1.6rem}.categorias-section{padding:25px}.categorias-section .categorias-grid{grid-template-columns:1fr}}.modal-overlay{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:15px;box-shadow:0 10px 30px #0000004d;max-height:95vh;max-width:95vw;overflow:hidden}.modal-content.detalle-horas{max-width:1400px;width:90vw}.modal-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:15px 15px 0 0;color:#fff;display:flex;justify-content:space-between;padding:20px 30px}.modal-header h2{font-size:1.5rem;margin:0}.close-button{align-items:center;background:none;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:2rem;height:40px;justify-content:center;padding:0;transition:background .2s;width:40px}.close-button:hover{background:#fff3}.modal-body{max-height:calc(95vh - 100px);overflow-y:auto;padding:30px}.contrato-info{background:#f8f9fa;border-left:5px solid #667eea;border-radius:10px;margin-bottom:25px;padding:20px}.contrato-info h3{color:#333;font-size:1.3rem;margin:0 0 10px}.contrato-info p{color:#666;margin:5px 0}.total-horas{background:#e3f2fd;border-radius:5px;color:#1976d2;font-size:1.1rem;margin-top:15px;padding:10px;text-align:center}.horas-info{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:15px}.horas-item{align-items:center;background-color:#fff;border:1px solid #e9ecef;border-radius:6px;display:flex;justify-content:space-between;padding:8px 12px}.horas-label{color:#495057;font-weight:600}.horas-valor{border-radius:4px;font-size:.9em;font-weight:700;padding:2px 8px}.horas-valor.aplicadas{background-color:#d4edda;color:#155724}.horas-valor.contratadas{background-color:#198754;color:#fff}.horas-valor.utilizacion{background-color:#fff3cd;color:#856404}.actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end;margin-bottom:25px}.export-button{background:linear-gradient(135deg,#28a745,#20c997);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:12px 24px;transition:transform .2s,box-shadow .2s}.export-button:hover{box-shadow:0 4px 15px #28a7454d;transform:translateY(-2px)}.pdf-button{background:linear-gradient(135deg,#e74c3c,#c0392b)}.pdf-button:hover{box-shadow:0 4px 15px #e74c3c66}.detalle-table-container{border-radius:10px;box-shadow:0 4px 15px #0000001a;overflow-x:auto}.detalle-table{background:#fff;border-collapse:collapse;font-size:.9rem;width:100%}.detalle-table th{background:linear-gradient(135deg,#495057,#6c757d);color:#fff;font-weight:600;padding:15px 12px;position:-webkit-sticky;position:sticky;text-align:left;top:0;z-index:10}.detalle-table td{border-bottom:1px solid #e9ecef;padding:12px;vertical-align:top}.detalle-table tbody tr:hover,.detalle-table tbody tr:nth-child(2n){background:#f8f9fa}.detalle-table tbody tr:nth-child(2n):hover{background:#e9ecef}.ticket-number{color:#495057;font-family:Courier New,monospace;font-weight:700;min-width:100px}.ticket-title{word-wrap:break-word;color:#333;max-width:300px}.hours{color:#28a745;font-weight:700;min-width:80px;text-align:right}.motivo{word-wrap:break-word;color:#666;max-width:200px}.categoria{color:#495057;font-weight:500}.fecha{color:#6c757d;font-size:.85rem;min-width:90px}.estado-badge{border-radius:12px;font-size:.8rem;font-weight:500;letter-spacing:.5px;padding:4px 8px;text-transform:uppercase}.estado-badge.resuelto{background:#d4edda;color:#155724}.estado-badge.en-progreso{background:#fff3cd;color:#856404}.estado-badge.pendiente{background:#f8d7da;color:#721c24}.estado-badge.cerrado{background:#d1ecf1;color:#0c5460}.estado-badge.cancelado{background:#f5c6cb;color:#721c24}.estado-badge.sin-consumo{background:#495057;color:#fff}.estado-badge.excedido{background:#ff6b6b;color:#fff}.estado-badge.default{background:#e2e3e5;color:#383d41}.total-row{background:#e3f2fd!important;color:#1976d2;font-weight:700}.total-row td{border-top:2px solid #1976d2;padding:15px 12px}.no-data{color:#6c757d;font-style:italic;padding:40px;text-align:center}@media (max-width:768px){.modal-content.detalle-horas{margin:10px;width:95vw}.modal-header{padding:15px 20px}.modal-header h2{font-size:1.2rem}.modal-body{padding:20px}.detalle-table{font-size:.8rem}.detalle-table td,.detalle-table th{padding:8px 6px}.ticket-title{max-width:150px}.motivo{max-width:120px}.actions{flex-direction:column}.export-button{justify-content:center;width:100%}}.filtros-fecha{background:#fff;border-radius:12px;box-shadow:0 4px 15px #0000001a;margin-bottom:30px;padding:20px}.filtros-rapidos{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(3,1fr);grid-template-rows:auto auto auto;margin-bottom:20px}.filtros-rapidos .filtro-btn:first-child,.filtros-rapidos .filtro-btn:nth-child(2),.filtros-rapidos .filtro-btn:nth-child(3){grid-row:1}.filtros-rapidos .filtro-btn:nth-child(4),.filtros-rapidos .filtro-btn:nth-child(5),.filtros-rapidos .filtro-btn:nth-child(6){grid-row:2}.filtros-rapidos .filtro-btn:nth-child(7){grid-column:2;grid-row:3;justify-self:center}.filtro-btn{background:#fff;border:2px solid #e9ecef;border-radius:8px;color:#495057;font-weight:500;gap:8px;min-width:140px;padding:10px 16px}.filtro-btn:hover{background:#f8f9ff;border-color:#667eea;box-shadow:0 2px 8px #667eea33;transform:translateY(-1px)}.filtro-btn.activo{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;box-shadow:0 4px 15px #667eea4d}.filtro-btn.activo:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.filtro-icon{font-size:1.1rem}.filtro-label{font-weight:500}.filtros-avanzados{border-top:2px solid #e9ecef;margin-top:20px;padding-top:20px}.rango-fechas{align-items:center;display:flex;flex-wrap:wrap;gap:15px;margin-bottom:15px}.fecha-input{display:flex;flex-direction:column;gap:5px}.fecha-input label{color:#495057;font-size:.85rem;font-weight:500}.fecha-input input{border:2px solid #e9ecef;border-radius:6px;font-size:.9rem;padding:8px 12px;transition:border-color .3s ease}.fecha-input input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.aplicar-rango-btn{align-items:center;background:linear-gradient(135deg,#28a745,#20c997);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:8px;padding:10px 20px;transition:all .3s ease}.aplicar-rango-btn:hover:not(:disabled){box-shadow:0 4px 15px #28a7454d;transform:translateY(-2px)}.aplicar-rango-btn:disabled{background:#6c757d;cursor:not-allowed;opacity:.6}.sugerencias-fecha{display:flex;flex-wrap:wrap;gap:10px}.sugerencia-btn{background:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;color:#495057;cursor:pointer;font-size:.8rem;padding:6px 12px;transition:all .2s ease}.sugerencia-btn:hover{background:#e9ecef;border-color:#adb5bd}@media (max-width:768px){.filtros-rapidos{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(2,1fr);grid-template-rows:auto auto auto;padding:0 10px}.filtros-rapidos .filtro-btn:first-child,.filtros-rapidos .filtro-btn:nth-child(2){grid-row:1}.filtros-rapidos .filtro-btn:nth-child(3),.filtros-rapidos .filtro-btn:nth-child(4){grid-row:2}.filtros-rapidos .filtro-btn:nth-child(5),.filtros-rapidos .filtro-btn:nth-child(6){grid-row:3}.filtros-rapidos .filtro-btn:nth-child(7){grid-column:1/-1;grid-row:4;margin-top:5px}.filtro-btn{border-radius:15px;flex-direction:column;font-size:.8rem;justify-content:center;min-height:80px;padding:12px 8px;text-align:center}.filtro-icon{font-size:1.3rem;margin-bottom:4px}.filtro-label{font-size:.75rem;font-weight:600;line-height:1.2;margin-bottom:3px}.filtro-fechas-indicator{background:#ffffff26;border-radius:6px;font-size:.6rem;line-height:1;margin-top:4px;padding:3px 4px}.rango-fechas{align-items:stretch;flex-direction:column;gap:15px;margin-top:20px}.fecha-input{width:100%}.fecha-input input{padding:15px}.aplicar-rango-btn,.fecha-input input{border-radius:10px;font-size:1rem;width:100%}.aplicar-rango-btn{justify-content:center;padding:18px}.sugerencias-fecha{gap:12px;justify-content:center;margin-top:15px}.sugerencia-btn{border-radius:8px;font-size:.9rem;padding:12px 18px}}.filtros-row{align-items:center;display:flex;gap:30px;margin-bottom:10px}.contratante-section{align-items:center;display:flex;gap:8px}.contratante-section label{color:#333;font-weight:500}.contratante-section select{background:#f8f9fa;border:1px solid #ccc;border-radius:6px;color:#333;font-size:1rem;padding:6px 12px}.contratantes-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));margin-top:20px}.contratante-card{background:#fff;border-left:5px solid #667eea;border-radius:10px;box-shadow:0 4px 15px #667eea1a;overflow:hidden;padding:0;transition:transform .2s}.contratante-card:hover{transform:translateY(-2px)}.contratante-card.con-contratos-excedidos{background:#fff3e0;border-left:5px solid #ffb74d;box-shadow:0 4px 15px #ffb74d4d}.contratante-card.con-contratos-excedidos .producto-header{background:linear-gradient(135deg,#ffb74d,#ffa726)}.contratante-card.con-contratos-excedidos .producto-header:hover{background:linear-gradient(135deg,#ffa726,#ff9800)}.contratante-card.con-contratos-excedidos .resumen-valor-consumidas,.contratante-card.con-contratos-excedidos .resumen-valor-utilizacion{color:#e74c3c;font-weight:700}.contratante-header{align-items:center;cursor:pointer;display:flex;justify-content:space-between;padding:24px 24px 0}.contratante-info{flex:1 1}.contratante-nombre{font-size:1.2rem;font-weight:700;margin-bottom:8px}.contratante-resumen{display:flex;flex-wrap:wrap;gap:16px}.resumen-item{align-items:flex-start;display:flex;flex-direction:column}.expand-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:20px;color:#fff;cursor:pointer;font-size:2rem;font-size:.9rem;margin-left:12px;margin-top:10px;padding:8px 16px;transition:all .3s ease;-webkit-user-select:none;user-select:none}.filtro-fechas-indicator{background:#ffffff1a;border-radius:4px;color:#fff;font-size:.7rem;font-weight:400;line-height:1;margin-left:4px;margin-right:4px;margin-top:4px;opacity:.9;padding:2px 4px;text-align:center}.filtro-btn:hover .filtro-fechas-indicator{background:#fff3;opacity:1}.filtro-btn.activo .filtro-fechas-indicator{background:#ffffff4d;color:#fff;font-weight:500}.filtro-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;box-shadow:0 4px 15px #667eea4d;color:#fff;cursor:pointer;display:flex;flex-direction:column;font-size:.9rem;font-weight:700;justify-content:center;min-height:80px;padding:12px 8px;position:relative;transition:all .3s ease}.filtro-btn:hover{background:linear-gradient(135deg,#5a6fd8,#6a4190);box-shadow:0 6px 20px #667eea66;color:#fff;transform:translateY(-2px)}.filtro-btn.activo{background:linear-gradient(135deg,#e74c3c,#c0392b);box-shadow:0 4px 15px #e74c3c4d;color:#fff}.filtro-btn.activo:hover{background:linear-gradient(135deg,#d63c2c,#b0291b);box-shadow:0 6px 20px #e74c3c66;color:#fff}.filtro-icon{font-size:1.5rem;margin-bottom:4px}.filtro-label{color:#fff;font-size:.85rem;margin-bottom:2px}
/*# sourceMappingURL=main.38d339ee.css.map*/