:root{--brand: #0F2C59;--brand-r: 15;--brand-g: 44;--brand-b: 89;--bg: #ffffff;--panel: #f9f9f9;--panel-2: #f3f3f3;--text: #111111;--muted: #555555;--line: #cfcfcf;--line-soft: #e6e6e6;--ok: #25c08a;--warn: #e5a100;--bad: #e5484d;--radius: 12px;--shadow: 0 8px 24px rgba(0,0,0,.08);--hover-neon: 0 0 10px rgba(var(--brand-r), var(--brand-g), var(--brand-b), .2);--focus-neon: 0 0 0 2px rgba(var(--brand-r), var(--brand-g), var(--brand-b), .65), 0 0 14px rgba(var(--brand-r), var(--brand-g), var(--brand-b), .35)}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.page{max-width:1200px;margin:0 auto;padding:20px 16px 96px;display:flex;flex-direction:column;gap:12px}.last-update{text-align:center;color:var(--muted);font-size:13px}.search-bar{display:flex;flex-direction:column;gap:14px;align-items:center;margin:12px 0 10px}.search-row{width:100%;display:flex;justify-content:center}.search-row input[type=text]{width:min(560px,90%);height:46px;padding:0 14px;border-radius:12px;border:2px solid var(--brand);background:#fff;color:#111;outline:none;text-align:center;box-shadow:var(--hover-neon);transition:box-shadow .15s ease,border-color .15s ease,background .15s ease}.search-row input[type=text]::placeholder{color:#777;opacity:.9;text-align:center}.search-row input[type=text]:hover{box-shadow:var(--hover-neon)}.search-row input[type=text]:focus{box-shadow:var(--focus-neon)}.controls-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.controls-row select,.controls-row .sort-button{height:44px;padding:0 14px;border-radius:12px;border:2px solid var(--brand);background:#fff;color:#111;text-align:center;text-align-last:center;cursor:pointer;box-shadow:var(--hover-neon);transition:box-shadow .15s ease,border-color .15s ease,background .15s ease}.controls-row .sort-button:hover,.controls-row select:hover{background:#faf7f8}.controls-row .sort-button:focus,.controls-row select:focus{outline:none;box-shadow:var(--focus-neon)}.controls-row .category-select,.controls-row .category-dropdown{display:contents;text-align:center}.view-section{display:flex;align-items:center;gap:8px;margin-left:12px;padding-left:12px;border-left:2px solid var(--line)}.view-label{font-size:14px;font-weight:600;color:var(--muted)}.view-toggle{display:flex;gap:0;height:44px;border:2px solid var(--brand);border-radius:12px;overflow:hidden;box-shadow:var(--hover-neon)}.view-button{height:100%;padding:0 16px;border:none;background:#fff;color:#111;font-size:14px;font-weight:500;cursor:pointer;transition:background .15s ease,color .15s ease;display:flex;align-items:center;justify-content:center;white-space:nowrap}.view-button:first-child{border-right:1px solid var(--line)}.view-button:hover{background:#faf7f8}.view-button.active{background:var(--brand);color:#fff}.app-header{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;margin-bottom:10px}.app-header .logo{object-fit:contain}.app-header .logo.left{height:90px}.app-header .logo.right{height:40px}.card-grid,.grid,.cards{display:contents}.table-wrap{margin-top:6px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}.data-table{width:100%;border-collapse:separate;border-spacing:0;table-layout:fixed;font-size:14px}.data-table thead th{position:sticky;top:0;z-index:10;background:#f4f4f4;color:var(--muted);text-align:center;font-weight:600;letter-spacing:.2px;padding:12px 14px;border-bottom:1px solid var(--line)}.data-table thead th:first-child{width:42px}.data-table thead th:nth-child(2){width:40%}.data-table thead th:nth-child(3){width:16%}.data-table thead th:nth-child(4){width:16%}.data-table thead th:nth-child(5){width:12%}.data-table thead th:nth-child(6){width:12%}.data-table thead th:nth-child(7){width:120px}.data-table tbody tr{background:var(--panel);border-bottom:1px solid var(--line-soft);transition:background .12s ease}.data-table tbody tr:nth-child(2n){background:var(--panel-2)}.data-table tbody tr:hover{background:#efefef}.data-table td{padding:12px 14px;vertical-align:middle;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center}.col-estado{width:42px}.dot{display:inline-block;width:10px;height:10px;border-radius:50%;box-shadow:0 0 0 3px #0000000d}.dot.positivo{background:var(--ok)}.dot.cercano{background:var(--warn)}.dot.negativo{background:var(--bad)}.col-titulo{width:40%}.col-titulo .title{font-weight:700;line-height:1.25;overflow:hidden;text-overflow:ellipsis}.col-titulo .subtitle{margin-top:2px;color:var(--muted);font-size:12px;overflow:hidden;text-overflow:ellipsis}a{color:#0a58ca;text-decoration:none}a:hover{text-decoration:underline}.col-dias{text-align:center}.pill{display:inline-flex;align-items:center;justify-content:center;min-width:74px;height:28px;padding:0 10px;border-radius:999px;font-weight:800;font-variant-numeric:tabular-nums;border:1px solid #000;background:#fff}.pill.positivo{border-color:var(--ok);color:var(--ok)}.pill.cercano{border-color:var(--warn);color:var(--warn)}.pill.negativo{border-color:var(--bad);color:var(--bad)}.dias-label{font-size:11px;color:var(--muted);display:block;margin-top:4px;text-align:center}.col-categoria,.col-tipo,.col-fecha{color:#333}.data-table tbody tr:focus-within{outline:3px solid rgba(var(--brand-r),var(--brand-g),var(--brand-b),.35);outline-offset:-2px}.col-estado{position:relative}.row-toggle{position:absolute;left:6px;top:50%;transform:translateY(-50%);width:16px;height:16px;border:1px solid var(--line);border-radius:50%;background:#fff;color:var(--brand);font-size:12px;line-height:14px;padding:0;display:grid;place-items:center;cursor:pointer}.row-toggle:hover{background:var(--panel-2)}.col-estado .dot{margin-left:16px}.expanded-row td{background:#fafafa;border-top:1px solid var(--line)}.expanded-content{padding:12px 16px;font-size:14px;line-height:1.45}.expanded-content h4{margin:0 0 6px}.tooltip{position:absolute;padding:12px 16px;background-color:#fff;border:2px solid var(--brand);border-radius:10px;box-shadow:var(--hover-neon);max-width:280px;z-index:1000}.border-positivo{border-color:var(--ok)}.border-cercano{border-color:var(--warn)}.border-negativo{border-color:var(--bad)}.border-default{border-color:var(--brand)}.tooltip-label{font-weight:800;margin-bottom:4px;font-size:14px;color:#000}.tooltip-content{font-size:13px;color:var(--text)}.loading-overlay{position:fixed;inset:0;display:flex;justify-content:center;align-items:center;background:#fff;z-index:9999}.loading-content{display:flex;flex-direction:column;align-items:center;gap:60px}.loading-logo{width:500px;margin-bottom:2px}.spinner{width:42px;height:42px;border-radius:50%;border:3px solid rgba(0,0,0,.15);border-top-color:#0f2c59;animation:spin 1s linear infinite}.loading-text{font-weight:600;font-size:20px;color:#111;opacity:.85}@keyframes spin{to{transform:rotate(360deg)}}.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:20px;margin-top:20px;grid-auto-rows:1fr}.directiva-card{background:var(--panel);border-left:6px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);transition:transform .2s ease,box-shadow .2s ease;position:relative;display:flex;flex-direction:column}.directiva-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px #0000001f}.directiva-card.positivo{border-left-color:var(--ok)}.directiva-card.cercano{border-left-color:var(--warn)}.directiva-card.negativo{border-left-color:var(--bad)}.card-main-content{display:flex;flex-direction:column;gap:14px;flex:1;min-height:0}.card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:4px}.card-category-img{display:flex;align-items:center;justify-content:center;width:40px;height:40px;flex-shrink:0}.card-category-img img{width:40px;height:40px;object-fit:contain}.card-badge{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}.badge-pill{display:inline-flex;align-items:center;justify-content:center;min-width:70px;height:32px;padding:0 12px;border-radius:999px;font-weight:800;font-size:18px;font-variant-numeric:tabular-nums;border:2px solid;background:#fff}.badge-pill.positivo{border-color:var(--ok);color:var(--ok)}.badge-pill.cercano{border-color:var(--warn);color:var(--warn)}.badge-pill.negativo{border-color:var(--bad);color:var(--bad)}.badge-label{font-size:11px;color:var(--muted);text-align:right;white-space:nowrap}.card-title{font-size:17px;font-weight:700;line-height:1.3;margin:0;color:var(--text);cursor:pointer;overflow:hidden;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}.card-directiva,.card-fecha{font-size:14px;line-height:1.4;color:var(--text)}.card-directiva strong,.card-fecha strong{font-weight:600;color:var(--muted);display:block;margin-bottom:3px}.card-expand-btn-circle{width:32px;height:32px;border-radius:50%;border:2px solid;background:#fff;color:inherit;font-size:20px;font-weight:700;cursor:pointer;transition:background .2s ease,transform .2s ease;display:flex;align-items:center;justify-content:center;align-self:flex-end;margin-top:auto;flex-shrink:0}.card-expand-btn-circle.positivo{border-color:var(--ok);color:var(--ok)}.card-expand-btn-circle.cercano{border-color:var(--warn);color:var(--warn)}.card-expand-btn-circle.negativo{border-color:var(--bad);color:var(--bad)}.card-expand-btn-circle:hover{transform:scale(1.1)}.card-details{margin-top:12px;padding-top:12px;border-top:1px solid var(--line-soft);font-size:13px;line-height:1.5}.card-details p{margin:8px 0}.card-details strong{font-weight:600;color:var(--muted)}.cards-empty{grid-column:1 / -1;text-align:center;padding:40px;color:var(--muted);font-size:16px}@media (max-width: 920px){.col-tipo{display:none}.data-table thead th:nth-child(2){width:42%}}@media (max-width: 720px){.col-categoria{display:none}.data-table thead th:nth-child(2){width:48%}.cards-grid{grid-template-columns:1fr}}@media (max-width: 560px){.data-table thead{display:none}.data-table,.data-table tbody,.data-table tr,.data-table td{display:block;width:100%}.data-table tr{margin:10px 0;border:1px solid var(--line);border-radius:10px;overflow:hidden}.data-table td{white-space:normal}.col-estado{border-bottom:1px solid var(--line-soft)}.col-dias{border-top:1px solid var(--line-soft)}}
