:root{--bg:#fff;--bg-alt:#f5f5f7;--text:#1d1d1f;--text-soft:#6e6e73;--border:#e8e8ed;--border-strong:#d2d2d7;--bg-dark:#00205b;--bg-dark-hover:#003087;--accent:#00205b;--success:#007a3d;--warning:#c8102e;--warn-soft:#fff4f4;--ok-soft:#f1f9f4;--font-sans:"Inter",-apple-system,sans-serif;--font-mono:"IBM Plex Mono",monospace;--radius:8px;--radius-lg:12px}*{box-sizing:border-box}html,body{margin:0;padding:0;font-family:var(--font-sans);color:var(--text);background:var(--bg-alt)}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums}.hero{padding:48px 0 16px}.hero-title{font-size:36px;font-weight:600;letter-spacing:-.02em;line-height:1.1;margin:0 0 12px}.hero-subtitle{font-size:16px;color:var(--text-soft);max-width:720px;margin:0}.eyebrow{font-size:13px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-soft);font-weight:500}.section-title{font-size:26px;font-weight:600;letter-spacing:-.01em;margin:8px 0 12px}.result-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px 22px}.result-card-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-soft)}.result-card-number{font-family:var(--font-mono);font-size:34px;font-weight:500;margin:6px 0}.result-card-note{font-size:12px;font-family:var(--font-mono);color:var(--text-soft)}.result-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.dark-card{background:var(--bg-dark);color:#fff;border-radius:var(--radius-lg);padding:32px}.dark-card-badge{display:inline-block;background:#fff;color:var(--bg-dark);padding:4px 10px;border-radius:100px;font-size:11px;text-transform:uppercase;letter-spacing:.06em;font-weight:600}.dark-card-title{font-size:15px;opacity:.8;margin:14px 0 6px}.dark-card-huge{font-family:var(--font-mono);font-size:48px;font-weight:500;line-height:1;margin:6px 0}.dark-card-meta{font-size:14px;opacity:.75}.topbar{position:sticky;top:0;background:#fff;border-bottom:1px solid var(--border-strong);padding:14px 40px;z-index:30;display:flex;align-items:center;justify-content:space-between;gap:16px}.topbar-brand{font-size:15px;font-weight:600;display:flex;align-items:center;gap:16px}.topbar-brand-logo{font-size:17px;font-weight:700;color:var(--accent);-webkit-user-select:none;user-select:none}.topbar-brand-logo:hover{text-decoration:none}.topbar-nav{display:flex;gap:4px;margin-left:8px}.topbar-nav a{padding:6px 12px;font-size:14px;color:var(--text-soft);border-radius:6px;font-weight:500;cursor:pointer}.topbar-nav a:hover{background:var(--bg-alt);color:var(--text);text-decoration:none}.topbar-nav a.is-active{color:var(--accent);font-weight:600;background:var(--bg-alt)}.topbar-user{font-size:13px;color:var(--text-soft);display:flex;align-items:center;gap:10px}.topbar-username{display:inline-flex;align-items:center;gap:6px}.topbar-username:before{content:"";width:8px;height:8px;border-radius:50%;background:var(--success)}.role-pill{display:inline-block;padding:3px 9px;border-radius:100px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;background:var(--bg-alt);color:var(--accent)}.topbar-burger{display:none;width:42px;height:42px;border:1px solid var(--border-strong);background:var(--bg);border-radius:var(--radius);align-items:center;justify-content:center;cursor:pointer;padding:0}.topbar-burger svg{width:20px;height:20px}.drawer{position:fixed;top:0;left:0;width:280px;max-width:85vw;height:100vh;background:var(--bg);z-index:1000;display:flex;flex-direction:column;box-shadow:2px 0 12px #0000000f;overflow-y:auto;transform:translate(-100%);transition:transform .25s}.drawer.is-open{transform:translate(0)}.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border)}.drawer-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-soft)}.drawer-close{width:36px;height:36px;border:1px solid var(--border-strong);background:var(--bg);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0}.drawer-close svg{width:16px;height:16px}.drawer-user{padding:14px 16px;border-bottom:1px solid var(--border)}.drawer-user-name{display:block;font-size:14px;font-weight:600}.drawer-user-sub{display:block;font-size:11px;color:var(--text-soft);margin-top:3px;text-transform:uppercase;letter-spacing:.04em}.drawer-nav{display:flex;flex-direction:column;padding:8px;gap:2px}.drawer-nav a{display:flex;align-items:center;padding:12px;min-height:48px;font-size:14px;font-weight:500;border-radius:var(--radius);cursor:pointer}.drawer-nav a:hover{background:var(--bg-alt);text-decoration:none}.drawer-nav a.is-active{color:var(--accent);font-weight:600;background:var(--bg-alt)}.drawer-footer{margin-top:auto;padding:8px;border-top:1px solid var(--border)}.drawer-footer button{display:flex;width:100%;align-items:center;padding:12px;min-height:48px;font-size:14px;font-weight:500;border-radius:var(--radius);cursor:pointer;background:none;border:none;color:var(--text);font-family:inherit}.drawer-footer button:hover{background:var(--bg-alt)}.drawer-overlay{position:fixed;inset:0;background:#00000073;z-index:999;opacity:0;pointer-events:none;transition:opacity .2s}.drawer-overlay.is-visible{opacity:1;pointer-events:auto}@media(min-width:769px){.drawer,.drawer-overlay{display:none!important}}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.field-label{font-size:13px;font-weight:500}.field-label .required{color:var(--warning);margin-left:2px}.input{padding:11px 14px;border-radius:var(--radius);border:1px solid var(--border-strong);font-size:15px;font-weight:500;font-family:var(--font-sans);background:var(--bg);color:var(--text);outline:none;width:100%}.input:focus{border-color:var(--accent)}.field-hint{font-size:12px;color:var(--text-soft);margin-top:4px}.input.mono{font-family:var(--font-mono)}@media(max-width:768px){.input{font-size:16px}}select.input{cursor:pointer}.btn-primary,.btn-secondary,.btn-danger{font-family:var(--font-sans);font-weight:500;font-size:14px;padding:9px 16px;border-radius:var(--radius);cursor:pointer;text-decoration:none;display:inline-block;text-align:center;border:1px solid transparent;white-space:nowrap}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{background:var(--bg-dark-hover);text-decoration:none}.btn-secondary{background:#fff;border-color:var(--border-strong);color:var(--text)}.btn-secondary:hover{background:var(--bg-alt);text-decoration:none}.btn-danger{background:#fff;border-color:#d8aaaa;color:#b00020}.btn-danger:hover{background:#fbeaea;border-color:#b00020;text-decoration:none}.btn-sm{padding:6px 12px;font-size:13px}.btn-icon{padding:7px;border-radius:var(--radius);background:none;border:1px solid transparent;color:var(--text-soft);cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.btn-icon:hover{background:var(--bg-alt);color:var(--text)}.btn-icon.danger:hover{background:#fbeaea;color:#b00020}.btn-icon svg{width:17px;height:17px}@media(max-width:768px){.btn-primary,.btn-secondary,.btn-danger{min-height:44px;padding:12px 18px}}table.datatable{width:100%;border-collapse:separate;border-spacing:0;background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}table.datatable thead th{background:#fafafc;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-soft);text-align:left;padding:12px 16px;border-bottom:1px solid var(--border)}table.datatable tbody td{border-bottom:1px solid var(--border);padding:14px 16px;font-size:14px}table.datatable tbody tr:last-child td{border-bottom:none}table.datatable tbody tr:hover{background:#fafafc}table.datatable td.num{text-align:right;font-family:var(--font-mono)}.row-actions{display:flex;gap:4px;align-items:center;justify-content:flex-end;flex-wrap:nowrap}@media(max-width:640px){table.datatable{border:none;background:transparent;border-radius:0}table.datatable thead{display:none}table.datatable,table.datatable tbody,table.datatable tr,table.datatable td{display:block;width:100%}table.datatable tbody tr{background:#fff;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:12px;padding:10px 14px}table.datatable tbody td{border:none;border-bottom:1px solid #f0f0f3;padding:10px 0;text-align:right;display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}table.datatable tbody td:last-child{border-bottom:none;padding-top:12px}table.datatable tbody td[data-label]:not([data-label=""]):before{content:attr(data-label);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-soft);text-align:left}}.pill{display:inline-block;padding:3px 10px;border-radius:100px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.pill-ok{background:var(--ok-soft);color:var(--success)}.pill-fail{background:var(--warn-soft);color:var(--warning)}.pill-info{background:#e8edf7;color:var(--accent)}.pill-warning{background:#fff7e6;color:#b35900}.pill-neutral{background:var(--bg-alt);color:var(--text-soft)}.alert{border:1px solid var(--border);background:#fff;padding:12px 16px;border-radius:var(--radius);margin-bottom:16px}.alert-title{font-size:13px;font-weight:600}.alert-body{font-size:14px;color:var(--text-soft)}.alert-error{border-color:#eccacd;background:var(--warn-soft)}.alert-error .alert-body{color:#9a1b2e}.alert-ok{border-color:#cbe7d6;background:var(--ok-soft)}.alert-ok .alert-body{color:#0a6b3a}.acceso-card{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 18px;margin-bottom:20px}.acceso-info{font-size:14px}.acceso-info strong{font-weight:600}.filter-bar{display:flex;gap:14px;align-items:flex-end;flex-wrap:wrap;padding:14px 16px;background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:18px}.filter-bar label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-soft);font-weight:600;display:block;margin-bottom:4px}.filter-bar .input{padding:9px 12px;font-size:14px}table.datatable tbody tr.row-link{cursor:pointer}.section{padding:32px 40px;max-width:1100px;margin:0 auto}@media(max-width:768px){.section{padding:24px 16px}.topbar{padding:12px 16px}.topbar-nav,.topbar-user .topbar-username,.topbar-user .role-pill,.topbar-user .btn-secondary{display:none}.topbar-burger{display:inline-flex}.hero-title{font-size:28px}}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px 16px;background:var(--bg-dark);background-image:radial-gradient(circle at 20% 20%,rgba(0,48,135,.55),transparent 50%),radial-gradient(circle at 80% 80%,rgba(0,48,135,.45),transparent 50%)}.login-card{width:100%;max-width:420px;background:var(--bg);border-radius:14px;padding:40px 36px;box-shadow:0 6px 24px #0000002e}.login-title{font-size:24px;font-weight:700;margin:0 0 6px}.login-subtitle{font-size:13px;color:var(--text-soft);margin:0 0 28px}.login-card .input{background:#eef2f9;border:1px solid transparent;font-size:15px;padding:12px 14px}.login-card .input:focus{border-color:var(--accent);background:#fff}.login-card .btn-primary{width:100%;padding:14px 18px;font-size:15px;font-weight:600;margin-top:8px;background:var(--bg-dark);border-color:var(--bg-dark)}.login-error{background:var(--warn-soft);color:var(--warning);border-radius:8px;padding:10px 14px;font-size:13px;margin-bottom:16px}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px 20px}.form-actions{display:flex;gap:12px;align-items:center;justify-content:space-between;margin-top:18px;flex-wrap:wrap}.modal-overlay{position:fixed;inset:0;background:#0f172a8c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:none;align-items:flex-start;justify-content:center;z-index:200;padding:40px 16px;overflow-y:auto}.modal-overlay.active{display:flex}.modal-content{background:#fff;border-radius:var(--radius-lg);max-width:460px;width:100%;padding:28px;box-shadow:0 12px 48px #0003}.modal-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px}.modal-title{font-size:18px;font-weight:600;margin:0}.modal-close{background:none;border:none;font-size:22px;color:var(--text-soft);cursor:pointer;padding:4px 8px;border-radius:6px;line-height:1}.hidden{display:none!important}.charts-grid{display:grid;grid-template-columns:1fr;gap:16px}.chart-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.chart-card-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-soft);margin:0 0 12px;display:flex;align-items:center;justify-content:space-between}.chart-wrap{position:relative;height:380px}.live-dot{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--text-soft);text-transform:none;letter-spacing:0;font-weight:400}.live-dot:before{content:"";width:7px;height:7px;border-radius:50%;background:var(--success)}.flex-row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.flex-between{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}.mt-24{margin-top:24px}.text-soft{color:var(--text-soft)}.dropzone{border:2px dashed var(--border-strong);border-radius:var(--radius-lg);padding:36px 16px;text-align:center;cursor:pointer;background:#fff;transition:border-color .15s,background .15s}.dropzone:hover,.dropzone.drag{border-color:var(--accent);background:#f3f6fb}.dropzone svg{width:40px;height:40px;color:var(--text-soft)}.dropzone-title{font-weight:600;margin:8px 0 2px}.dropzone-hint{font-size:13px;color:var(--text-soft)}.upload-list{display:flex;flex-direction:column;gap:8px;margin-top:16px}.upload-row{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px}.upload-row .name{flex:1;min-width:0;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upload-row .bar{height:4px;background:var(--bg-alt);border-radius:100px;overflow:hidden;margin-top:5px}.upload-row .bar>span{display:block;height:100%;background:var(--accent);width:0;transition:width .2s}.counter-bar{display:flex;align-items:center;justify-content:space-between;background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 18px;margin-top:20px}.counter-bar .label{font-size:13px;color:var(--text-soft)}.counter-bar .value{font-family:var(--font-mono);font-size:22px;font-weight:500}.list-rows{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.list-row{display:flex;align-items:center;gap:12px;padding:13px 16px;border-bottom:1px solid var(--border);cursor:pointer;color:inherit}.list-row:last-child{border-bottom:none}.list-row:hover{background:#fafafc;text-decoration:none}.list-row .name{flex:1;min-width:0;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.list-empty{padding:32px;text-align:center;color:var(--text-soft);font-size:14px}.icon-muted{color:var(--text-soft);flex-shrink:0}
