*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:#333;background-color:#f0f2f5;min-height:100vh;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}#root{width:100%;min-height:100vh}.table-wrapper{background:#fff;border-left:1px solid #dde3ea;border-right:1px solid #dde3ea;overflow:hidden}.table-scroll{-webkit-overflow-scrolling:touch;overflow-x:auto}.matriz-table{border-collapse:collapse;width:100%;min-width:900px;font-size:.83rem}.matriz-table thead tr{color:#fff;background:#2d5016}.matriz-table thead th{text-align:center;letter-spacing:.4px;text-transform:uppercase;vertical-align:middle;border-right:1px solid #ffffff26;padding:12px 10px;font-size:.74rem;font-weight:700;line-height:1.3}.matriz-table thead th:last-child{border-right:none}.col-item{width:52px}.col-id{width:70px}.col-bien{width:120px}.col-fecha{width:100px}.col-responsable{width:140px}.col-descripcion{width:auto}.col-cumple{width:90px}.col-observacion{width:220px}.matriz-table tbody tr{border-bottom:1px solid #e8ecf0;transition:background-color .15s}.row-even{background-color:#fff}.row-odd{background-color:#f4f7f4}.matriz-table tbody tr:hover{background-color:#e8f4ee!important}.matriz-table tbody td{vertical-align:top;color:#333;border-right:1px solid #e8ecf0;padding:10px;line-height:1.5}.matriz-table tbody td:last-child{border-right:none}.cell-center{text-align:center;vertical-align:middle!important}.cell-item{color:#1a3a5c;font-size:.9rem;font-weight:700}.cell-id{color:#555;font-weight:600}.col-descripcion-cell{min-width:200px}.col-observacion-cell{color:#555;font-style:italic}.text-muted{color:#bbb;font-style:normal}.badge{text-align:center;white-space:nowrap;border-radius:20px;padding:4px 9px;font-size:.72rem;font-weight:700;line-height:1.3;display:inline-block}.badge-vehiculo{color:#3949ab;background:#e8eaf6;border:1px solid #c5cae9}.badge-terreno{color:#2e7d32;background:#e8f5e9;border:1px solid #a5d6a7}.badge-cumple-si{color:#1a7a4a;background:#e6f9f0;border:1px solid #a3d9be}.badge-cumple-regular{color:#d68910;background:#fff8e1;border:1px solid #f5d99f}.badge-cumple-no{color:#c0392b;background:#fde8e8;border:1px solid #f5c6c6}.badge-default{color:#666;background:#f0f0f0;border:1px solid #ddd}.empty-state{text-align:center;color:#999;padding:60px 20px}.empty-state span{margin-bottom:12px;font-size:3rem;display:block}.empty-state p{font-size:1rem}.app-container{width:100%;padding:20px}.app-header{color:#fff;background:linear-gradient(135deg,#1a3a5c 0%,#2d6a4f 100%);border-radius:12px 12px 0 0;justify-content:space-between;align-items:center;gap:16px;padding:20px 28px;display:flex;box-shadow:0 4px 12px #0003}.header-title h1{letter-spacing:.5px;text-transform:uppercase;text-shadow:0 1px 3px #0000004d;font-size:1.25rem;font-weight:700}.header-meta{opacity:.9;white-space:nowrap;flex-direction:column;align-items:flex-end;gap:4px;font-size:.8rem;display:flex}.toolbar{background:#fff;border-left:1px solid #dde3ea;border-right:1px solid #dde3ea;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:14px 20px;display:flex;box-shadow:0 2px 6px #0000000f}.filters{flex-wrap:wrap;align-items:center;gap:20px;display:flex}.filters label{color:#444;align-items:center;gap:8px;font-size:.85rem;font-weight:600;display:flex}.filters select{color:#333;cursor:pointer;background:#f8fafc;border:1px solid #c5cdd8;border-radius:6px;padding:6px 10px;font-size:.85rem;transition:border-color .2s}.filters select:focus{border-color:#2d6a4f;outline:none;box-shadow:0 0 0 3px #2d6a4f26}.btn-add{color:#fff;cursor:pointer;background:linear-gradient(135deg,#2d6a4f,#40916c);border:none;border-radius:8px;padding:9px 20px;font-size:.9rem;font-weight:600;transition:transform .15s,box-shadow .15s;box-shadow:0 3px 8px #2d6a4f59}.btn-add:hover{transform:translateY(-1px);box-shadow:0 5px 14px #2d6a4f73}.btn-add:active{transform:translateY(0)}.app-footer{color:#666;text-align:right;background:#f8fafc;border:1px solid #dde3ea;border-top:none;border-radius:0 0 12px 12px;padding:10px 20px;font-size:.82rem}.state-box{border-left:1px solid #dde3ea;border-right:1px solid #dde3ea;align-items:center;gap:16px;padding:20px 24px;font-size:.9rem;display:flex}.state-loading{color:#1a6fa8;background:#f0f7ff;border-top:3px solid #1a6fa8}.state-error{color:#c0392b;background:#fff8f8;border-top:3px solid #e74c3c;flex-wrap:wrap}.state-error strong{margin-bottom:4px;display:block}.state-error p{opacity:.85;margin:0;font-size:.82rem}.state-icon{flex-shrink:0;font-size:1.8rem}.spinner{border:3px solid #b3d4f0;border-top-color:#1a6fa8;border-radius:50%;flex-shrink:0;width:22px;height:22px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.btn-retry{color:#fff;cursor:pointer;background:#e74c3c;border:none;border-radius:8px;margin-left:auto;padding:8px 18px;font-size:.85rem;font-weight:600;transition:background-color .15s}.btn-retry:hover{background:#c0392b}.btn-refresh{color:#fff;cursor:pointer;background:linear-gradient(135deg,#1a3a5c,#2d6a8f);border:none;border-radius:8px;padding:9px 20px;font-size:.9rem;font-weight:600;transition:transform .15s,box-shadow .15s;box-shadow:0 3px 8px #1a3a5c59}.btn-refresh:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 5px 14px #1a3a5c73}.btn-refresh:disabled{opacity:.65;cursor:not-allowed}
