:root {
  --navy:#0d3a63; --blue:#185b8f; --teal:#27aeb6; --green:#15803d;
  --red:#b91c1c; --amber:#b45309; --gray:#64748b; --light:#f3f7fa;
  --border:#d7e2ea; --white:#fff; --shadow:0 10px 30px rgba(13,58,99,.12);
}
*{box-sizing:border-box} body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,"Segoe UI",sans-serif;background:#eef3f7;color:#15283a}
.brandbar{height:96px;background:#fff;display:flex;align-items:center;justify-content:space-between;padding:10px max(18px,calc((100vw - 860px)/2));border-bottom:1px solid var(--border);position:sticky;top:0;z-index:20}
.logo{object-fit:contain;max-height:76px}.logo-drs{width:150px}.logo-conexion{width:300px;max-height:76px}
.app-shell{width:min(860px,100%);margin:auto;background:#fff;min-height:calc(100vh - 126px);box-shadow:var(--shadow)}
.hero{padding:28px 20px 20px;background:linear-gradient(145deg,#f9fcfe,#edf7fa);text-align:center}.hero h1{margin:2px 0 6px;color:var(--navy);font-size:clamp(28px,7vw,44px)}.hero p{margin:6px 0;color:#4b6477}.eyebrow{font-weight:800;letter-spacing:.16em;color:var(--teal)!important;font-size:12px}
.base-status{display:inline-flex;margin-top:12px;padding:7px 12px;border-radius:999px;font-size:13px;font-weight:800}.base-status.ok{background:#dcfce7;color:#166534}.base-status.warning{background:#fef3c7;color:#92400e}
.tabs{display:grid;grid-template-columns:repeat(4,1fr);border-bottom:1px solid var(--border);background:#fff;position:sticky;top:96px;z-index:15}.tab{border:0;background:#fff;padding:14px 4px;font-weight:800;color:#64748b;border-bottom:3px solid transparent}.tab.active{color:var(--navy);border-color:var(--teal)}
.panel{display:none;padding:22px 18px 34px}.panel.active{display:block}.panel h2{color:var(--navy);margin-top:0}.panel p{color:#526b7e}
button,input{font:inherit}button{cursor:pointer}.primary,.secondary{border-radius:12px;padding:13px 17px;font-weight:800;border:0}.primary{background:var(--navy);color:#fff}.primary:disabled{opacity:.45}.secondary{background:#e8f1f6;color:var(--navy);border:1px solid #c7d8e3}.action-large{width:100%;min-height:66px;font-size:18px;display:flex;gap:10px;align-items:center;justify-content:center}.icon{font-size:24px}
.scanner-wrap{margin-top:16px;padding:12px;background:#081e31;border-radius:16px}.scanner-wrap #reader{background:#fff;border-radius:10px;overflow:hidden}.scanner-wrap button{margin-top:10px;width:100%}.hidden{display:none!important}
.divider{display:flex;align-items:center;gap:12px;margin:24px 0;color:#7890a2;font-size:13px}.divider:before,.divider:after{content:"";height:1px;background:var(--border);flex:1}
.rut-form label{display:block;font-weight:800;margin-bottom:8px;color:var(--navy)}.input-row{display:flex;gap:8px}.input-row input,.stack input{width:100%;border:1px solid #b9cbd8;border-radius:12px;padding:13px;background:#fff;font-size:16px}.input-row input:focus,.stack input:focus{outline:3px solid rgba(39,174,182,.18);border-color:var(--teal)}
.result-card{margin-top:22px;border-radius:18px;padding:20px;border:3px solid;box-shadow:var(--shadow)}.result-card.habilitado{background:#f0fdf4;border-color:#22c55e}.result-card.inhabilitado{background:#fef2f2;border-color:#ef4444}.result-card.no-encontrado{background:#fffbeb;border-color:#f59e0b}.result-status{font-size:29px;font-weight:950;text-align:center;margin-bottom:14px}.habilitado .result-status{color:var(--green)}.inhabilitado .result-status{color:var(--red)}.no-encontrado .result-status{color:var(--amber)}
.details{display:grid;grid-template-columns:1fr;gap:0;background:#fff;border-radius:12px;overflow:hidden}.detail{padding:10px 13px;border-bottom:1px solid #e6edf2}.detail:last-child{border-bottom:0}.detail span{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#718697;font-weight:800}.detail strong{display:block;margin-top:3px;color:#18334a;word-break:break-word}
.stack{display:grid;gap:10px}.compact{max-width:420px}.help{font-size:13px}.file-drop{display:flex;flex-direction:column;align-items:center;justify-content:center;border:2px dashed #9eb8c9;border-radius:16px;min-height:120px;background:#f7fbfd;color:var(--navy);font-weight:900;margin:14px 0}.file-drop small{font-weight:500;color:#738b9d;margin-top:4px}.message{margin-top:14px;padding:12px;border-radius:10px}.message.ok{background:#dcfce7;color:#166534}.message.error{background:#fee2e2;color:#991b1b}hr{border:0;border-top:1px solid var(--border);margin:28px 0}
.panel-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.log-list{display:grid;gap:10px;margin-top:14px}.log-item{border:1px solid var(--border);border-radius:12px;padding:12px;background:#fafcfd}.log-item .top{display:flex;justify-content:space-between;gap:8px;font-weight:850;color:var(--navy)}.badge{font-size:11px;padding:4px 7px;border-radius:999px}.badge.habilitado{background:#dcfce7;color:#166534}.badge.inhabilitado{background:#fee2e2;color:#991b1b}.badge.no-encontrado{background:#fef3c7;color:#92400e}.log-item p{margin:6px 0 0;font-size:13px}.empty{text-align:center;color:#7890a2;padding:30px}
footer{text-align:center;padding:14px;color:#6a8192;font-size:12px}
@media(max-width:560px){.brandbar{height:80px;padding:8px 12px}.logo-drs{width:105px}.logo-conexion{width:180px;max-height:58px}.logo{max-height:62px}.tabs{top:80px}.tab{font-size:12px}.panel-heading{display:block}.panel-heading button{margin-top:8px}.input-row{display:grid;grid-template-columns:1fr auto}.hero{padding-top:22px}}

/* Versión 3: personal + vehículos */
.base-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:14px}.base-grid .base-status{margin-top:0}
.mode-switch{display:grid;grid-template-columns:1fr 1fr;gap:8px;background:#edf4f7;padding:5px;border-radius:14px;margin-bottom:18px}.mode-btn{border:0;background:transparent;color:#557083;font-weight:900;border-radius:10px;padding:12px 8px;cursor:pointer}.mode-btn.active{background:#fff;color:var(--navy);box-shadow:0 3px 12px rgba(13,58,99,.12)}
.section-help{margin-top:-6px;margin-bottom:18px}.upload-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:16px}.upload-card{border:1px solid var(--border);border-radius:16px;padding:16px;background:#fbfdfe}.upload-card h3{margin-top:0;color:var(--navy)}
.result-card.vencido{background:#fff7ed;border-color:#f97316}.vencido .result-status{color:#c2410c}.badge.vencido{background:#ffedd5;color:#9a3412}.reason-list{margin:7px 0 0;padding-left:20px;color:#18334a}.reason-list li{margin:4px 0;font-weight:700}
@media(max-width:720px){.base-grid,.upload-grid{grid-template-columns:1fr}.mode-btn{font-size:13px}.hero h1{font-size:30px}}
\n\n/* Módulo de alertas y recordatorios */\n.alert-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:18px 0}.summary-card{border-radius:14px;padding:14px;text-align:center;border:1px solid var(--border)}.summary-card strong{display:block;font-size:28px}.summary-card span{font-size:12px;font-weight:800;text-transform:uppercase}.summary-card.overdue{background:#fef2f2;color:#991b1b}.summary-card.upcoming{background:#fff7ed;color:#9a3412}.summary-card.done{background:#f1f5f9;color:#475569}.alert-toolbar{display:flex;justify-content:space-between;gap:10px;align-items:center;margin-bottom:16px}.alert-toolbar select,.form-grid select,.form-grid input,.form-grid textarea{width:100%;border:1px solid #b9cbd8;border-radius:10px;padding:11px;background:#fff}.alert-toolbar select{max-width:210px}.alert-form{border:1px solid var(--border);border-radius:16px;padding:16px;margin-bottom:18px;background:#f8fbfd}.alert-form h3{margin-top:0;color:var(--navy)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-grid label span{display:block;font-weight:800;color:var(--navy);font-size:13px;margin-bottom:5px}.form-grid .full{grid-column:1/-1}.form-grid textarea{resize:vertical}.form-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:14px}.alerts-list{display:grid;gap:12px}.alert-item{border:1px solid var(--border);border-left:6px solid #f59e0b;border-radius:14px;padding:14px;background:#fff}.alert-item.overdue{border-left-color:#ef4444;background:#fffafa}.alert-item.closed{border-left-color:#94a3b8;background:#f8fafc;opacity:.82}.alert-item.priority-critica{box-shadow:inset 0 0 0 1px #ef4444}.alert-item .alert-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.alert-item h3{margin:0;color:var(--navy);font-size:17px}.alert-date{font-weight:900;white-space:nowrap;color:#334155}.alert-meta{display:flex;flex-wrap:wrap;gap:6px;margin:9px 0}.alert-chip{font-size:11px;font-weight:800;border-radius:999px;padding:5px 8px;background:#e8f1f6;color:#24465f}.alert-chip.high{background:#fee2e2;color:#991b1b}.alert-item p{margin:7px 0}.alert-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}.alert-actions button{padding:8px 11px;border-radius:9px;font-size:12px}.danger{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.modal{position:fixed;inset:0;background:rgba(7,25,40,.65);z-index:100;display:flex;align-items:center;justify-content:center;padding:18px}.modal-card{position:relative;width:min(620px,100%);max-height:82vh;overflow:auto;background:#fff;border-radius:18px;padding:24px;box-shadow:0 24px 70px rgba(0,0,0,.28)}.modal-close{position:absolute;right:12px;top:8px;border:0;background:transparent;font-size:28px;color:#64748b}.modal-alert{padding:11px 0;border-bottom:1px solid var(--border)}.modal-alert:last-child{border-bottom:0}.modal-alert strong{display:block;color:var(--navy)}.modal-card>#goToAlertsBtn{width:100%;margin-top:16px}\n@media(max-width:620px){.form-grid{grid-template-columns:1fr}.form-grid .full{grid-column:auto}.alert-summary{grid-template-columns:repeat(3,1fr)}.summary-card{padding:10px 4px}.summary-card strong{font-size:23px}.summary-card span{font-size:9px}.alert-toolbar{align-items:stretch;flex-direction:column}.alert-toolbar select{max-width:none}.alert-item .alert-head{display:block}.alert-date{display:block;margin-top:6px}.tabs{overflow-x:auto;grid-template-columns:repeat(4,minmax(86px,1fr))}}\n
/* V5 · Panel corporativo e inspecciones */
body{background:#eaf0f5}.layout{display:grid;grid-template-columns:250px minmax(0,1fr);max-width:1500px;margin:0 auto;min-height:calc(100vh - 96px)}
.sidebar{background:#0b2f50;color:#fff;padding:20px 14px;position:sticky;top:96px;height:calc(100vh - 96px);display:flex;flex-direction:column;gap:7px;z-index:18}.side-title{font-weight:900;font-size:18px;padding:5px 10px 18px;border-bottom:1px solid rgba(255,255,255,.16);margin-bottom:8px}.sidebar .tab{background:transparent;color:#cfe0ec;border:0;border-radius:10px;text-align:left;padding:12px 14px;font-size:14px}.sidebar .tab.active,.sidebar .tab:hover{background:#fff;color:#0b2f50;border:0}.app-shell{width:100%;max-width:none;margin:0;box-shadow:none;min-height:calc(100vh - 96px)}
.hero{display:none}.panel{padding:28px 30px 48px}.panel.active{display:block}.kpi-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin:22px 0}.kpi{background:#fff;border:1px solid var(--border);border-radius:16px;padding:18px;box-shadow:0 5px 18px rgba(13,58,99,.06)}.kpi span{display:block;color:#60798b;font-size:12px;font-weight:850;text-transform:uppercase;letter-spacing:.05em}.kpi strong{display:block;color:var(--navy);font-size:31px;margin-top:7px}.chart-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.chart-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:18px;min-height:340px}.chart-card h3{margin:0 0 12px;color:var(--navy)}.chart-card canvas{max-height:280px}
.inspection-toolbar{display:flex;gap:9px;flex-wrap:wrap;margin:18px 0}.inspection-form{background:#f8fbfd;border:1px solid var(--border);border-radius:18px;padding:18px;margin:18px 0}.checklist{margin:20px 0;border:1px solid var(--border);border-radius:14px;overflow:hidden;background:#fff}.check-row{display:grid;grid-template-columns:minmax(220px,1fr) 330px minmax(180px,1fr);gap:12px;align-items:center;padding:13px;border-bottom:1px solid var(--border)}.check-row:last-child{border-bottom:0}.check-name{font-weight:850;color:var(--navy)}.status-group{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.status-group label{display:flex;align-items:center;justify-content:center;gap:5px;border:1px solid var(--border);border-radius:9px;padding:8px;font-size:12px;font-weight:800;cursor:pointer}.status-group label:has(input:checked){background:#dff4f4;border-color:var(--teal);color:#0b5f66}.check-observation{width:100%;border:1px solid #b9cbd8;border-radius:9px;padding:9px}.general-observation span{display:block;font-weight:800;color:var(--navy);margin-bottom:6px}.general-observation textarea{width:100%;border:1px solid #b9cbd8;border-radius:10px;padding:11px}.live-result{display:flex;justify-content:space-between;align-items:center;background:#e8f1f6;border-radius:12px;padding:13px 15px;margin-top:14px}.live-result span{font-weight:800;color:#60798b}.live-result strong{color:var(--navy);font-size:18px}.filters{display:grid;grid-template-columns:2fr 1fr 1fr auto;gap:8px;margin:18px 0}.filters input{border:1px solid #b9cbd8;border-radius:10px;padding:11px}.mini-summary{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0 15px}.mini-summary span{background:#e8f1f6;color:var(--navy);font-weight:850;border-radius:999px;padding:7px 11px;font-size:12px}.inspection-list{display:grid;gap:11px}.inspection-item{background:#fff;border:1px solid var(--border);border-left:6px solid #22c55e;border-radius:14px;padding:14px}.inspection-item.warning{border-left-color:#f59e0b}.inspection-item.danger{border-left-color:#ef4444}.inspection-top{display:flex;justify-content:space-between;gap:12px}.inspection-top h3{margin:0;color:var(--navy)}.inspection-percentage{font-size:25px;font-weight:950;color:var(--navy)}.inspection-meta{color:#61798b;font-size:13px;margin:6px 0}.inspection-result{font-weight:900}.inspection-actions{display:flex;gap:7px;flex-wrap:wrap;margin-top:10px}.inspection-actions button{padding:8px 10px;border-radius:8px;font-size:12px}.brandbar{padding-left:max(18px,calc((100vw - 1500px)/2 + 18px));padding-right:max(18px,calc((100vw - 1500px)/2 + 18px))}
@media(max-width:960px){.layout{grid-template-columns:1fr}.sidebar{position:sticky;top:80px;height:auto;display:flex;flex-direction:row;overflow-x:auto;padding:8px;gap:5px}.side-title{display:none}.sidebar .tab{white-space:nowrap;padding:10px 12px}.panel{padding:20px 16px 40px}.kpi-grid{grid-template-columns:repeat(2,1fr)}.chart-grid{grid-template-columns:1fr}.check-row{grid-template-columns:1fr}.filters{grid-template-columns:1fr 1fr}.filters input:first-child{grid-column:1/-1}}
@media(max-width:560px){.kpi-grid{grid-template-columns:1fr 1fr}.kpi strong{font-size:24px}.filters{grid-template-columns:1fr}.filters input:first-child{grid-column:auto}.status-group{grid-template-columns:1fr}.inspection-top{display:block}.brandbar{position:relative;top:auto}.sidebar{top:0}}
.attendance-toolbar{display:flex;gap:12px;align-items:end;flex-wrap:wrap;margin:18px 0}.attendance-toolbar label{display:grid;gap:6px;min-width:190px}.attendance-toolbar span{font-size:.82rem;font-weight:700;color:#536575}.table-wrap{overflow:auto;background:#fff;border:1px solid #d9e3eb;border-radius:16px;margin-top:18px}.data-table{width:100%;border-collapse:collapse;min-width:980px}.data-table th,.data-table td{padding:11px 12px;border-bottom:1px solid #e8eef3;text-align:left;font-size:.86rem}.data-table th{background:#0d3a63;color:#fff;position:sticky;top:0}.data-table tr:hover td{background:#f5fafc}.subheading{margin-top:26px}.attendance-kpis{margin-top:18px}

.contractor-accreditation-toolbar{grid-template-columns:repeat(auto-fit,minmax(170px,1fr));}
.status-pill{display:inline-block;padding:4px 8px;border-radius:999px;font-size:.78rem;font-weight:700;background:#e8edf2;color:#334155;white-space:nowrap}.status-pill.acreditado{background:#dcfce7;color:#166534}.status-pill.pendiente{background:#fef3c7;color:#92400e}.status-pill.observadoincompleto{background:#ffedd5;color:#9a3412}.status-pill.inactivo{background:#fee2e2;color:#991b1b}.base-status{font-size:1rem;font-weight:700;padding:16px;border-radius:12px;background:#f1f5f9;margin-top:12px}

.login-overlay{position:fixed;inset:0;z-index:9999;background:linear-gradient(135deg,#082d4c,#0d3a63);display:grid;place-items:center;padding:20px}.login-overlay.hidden{display:none}.login-card{width:min(420px,100%);background:#fff;border-radius:18px;padding:28px;box-shadow:0 24px 70px rgba(0,0,0,.35);text-align:center}.login-logo{max-width:180px;max-height:70px;object-fit:contain;margin-bottom:10px}.login-card select,.login-card input{width:100%;padding:13px;border:1px solid #b8c5d1;border-radius:10px}.auth-pending .app-shell,.auth-pending footer{filter:blur(3px);pointer-events:none}.session-box{margin-left:auto;display:flex;align-items:center;gap:10px;font-weight:700}.session-box .secondary{padding:7px 10px}.role-hidden{display:none!important}@media(max-width:700px){.session-box{width:100%;justify-content:center;margin-top:8px}.brandbar{flex-wrap:wrap}}

/* V9 · Verificación de Estándares SST */
.sst-checklist-info{display:flex;flex-direction:column;gap:4px;background:#e8f1f6;border-left:5px solid var(--teal);padding:12px 14px;border-radius:10px;margin:18px 0 10px}.sst-checklist-info strong{color:var(--navy);font-size:17px}.sst-checklist-info span{color:#536b7c;font-size:13px}.sst-checklist{display:grid;gap:0;border:1px solid var(--border);border-radius:14px;overflow:hidden;background:#fff;margin-bottom:18px}.sst-section-title{padding:10px 14px;background:#edf4f7;color:var(--navy);font-weight:900;border-bottom:1px solid var(--border)}.sst-item{display:grid;grid-template-columns:minmax(260px,1fr) 320px minmax(180px,.8fr);gap:12px;align-items:start;padding:13px 14px;border-bottom:1px solid var(--border)}.sst-item:last-child{border-bottom:0}.sst-question{font-weight:800;color:#18334a;line-height:1.35}.sst-question small{display:block;margin-top:5px;color:#718697;font-weight:600}.sst-observation{width:100%;min-height:42px;border:1px solid #b9cbd8;border-radius:9px;padding:9px;resize:vertical}.sst-photo-preview{margin:12px 0}.sst-photo-preview img{max-width:320px;max-height:220px;border-radius:12px;border:1px solid var(--border);object-fit:cover}.sst-filters{grid-template-columns:2fr 1fr 1fr 1fr auto}.sst-filters select{border:1px solid #b9cbd8;border-radius:10px;padding:11px;background:#fff}.sst-details{margin-top:12px;padding-top:10px;border-top:1px solid var(--border)}.sst-details summary{cursor:pointer;font-weight:850;color:var(--navy)}.sst-details table{width:100%;border-collapse:collapse;margin-top:10px}.sst-details th,.sst-details td{padding:8px;border-bottom:1px solid #e7edf2;text-align:left;font-size:12px}.sst-result-critico{border-left-color:#991b1b!important}.sst-result-deficiente{border-left-color:#ef4444!important}.sst-result-observaciones{border-left-color:#f59e0b!important}.sst-result-conforme{border-left-color:#22c55e!important}@media(max-width:1000px){.sst-item{grid-template-columns:1fr}.sst-filters{grid-template-columns:1fr 1fr}.sst-filters input:first-child{grid-column:1/-1}}@media(max-width:560px){.sst-filters{grid-template-columns:1fr}.sst-filters input:first-child{grid-column:auto}}
.history-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.history-filters{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:10px;align-items:end;margin:16px 0}.history-filters label{display:flex;flex-direction:column;gap:5px;font-size:.82rem;font-weight:700}.history-filters input,.history-filters select{width:100%}.summary-chips{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0 16px}.summary-chips span{background:#eaf2f8;border:1px solid #c8d9e8;border-radius:999px;padding:6px 10px;font-weight:700;font-size:.82rem}.log-title{display:flex;align-items:center;gap:9px}.log-item .small{margin-top:8px;padding:6px 10px;font-size:.78rem}.log-item small{color:#526270}.admin-only.hidden{display:none!important}@media(max-width:760px){.history-actions{justify-content:stretch}.history-actions button{flex:1 1 46%}.history-filters{grid-template-columns:1fr}}

.portal-overlay{position:fixed;inset:0;z-index:2000;background:#f4f7fb;overflow:auto;padding:24px}.portal-shell{max-width:1100px;margin:auto}.portal-head{display:flex;justify-content:space-between;gap:20px;align-items:flex-start;margin-bottom:18px}.portal-head h2{margin:.15rem 0}.portal-form{display:block!important;background:#fff;border-radius:18px;padding:24px;box-shadow:0 12px 36px rgba(13,58,99,.12)}.document-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:12px;margin:12px 0 18px}.document-upload{border:1px dashed #9eb4c7;border-radius:12px;padding:14px;background:#f8fbfd}.document-upload span,.document-upload small{display:block}.document-upload input{margin:10px 0}.check-row{display:flex!important;gap:10px;align-items:flex-start;margin:14px 0}.check-row input{width:auto}.precheck-box{display:flex;flex-direction:column;gap:4px;border-radius:12px;padding:14px;margin:12px 0;background:#fff5d8;border:1px solid #e9c66a}.precheck-box.ok{background:#e9f8ef;border-color:#79c995}.precheck-box.warning{background:#fff5d8}.status-pill{background:#eaf1f7;border-radius:999px;padding:7px 10px;font-size:.8rem}.inspection-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}@media(max-width:720px){.portal-overlay{padding:10px}.portal-head{flex-direction:column}.portal-form{padding:14px}}

/* Estado offline / sincronización V16 */
.offline-status{position:sticky;top:0;z-index:99999;display:flex;align-items:center;justify-content:center;gap:12px;padding:8px 16px;font-size:14px;border-bottom:1px solid rgba(0,0,0,.12);background:#e8f4ec;color:#164d2b}
.offline-status.offline{background:#fff3cd;color:#664d03}.offline-status.pending{background:#dbeafe;color:#1e3a8a}.offline-status.syncing{background:#e0f2fe;color:#075985}
.offline-status button{border:1px solid currentColor;background:rgba(255,255,255,.65);color:inherit;border-radius:8px;padding:5px 10px;font-weight:700;cursor:pointer}
@media(max-width:700px){.offline-status{font-size:12px;flex-wrap:wrap;padding:7px 10px}}

.visit-documents{display:grid;gap:10px;margin:10px 0 16px}.visit-document-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px;border:1px solid #d8e5ee;border-radius:12px;background:#f8fbfd}.visit-document-row span{font-size:.9rem;color:#597084}.visit-document-actions{display:flex;gap:8px;flex-wrap:wrap}.visit-document-actions button{padding:8px 12px}.muted{color:#7b8c99;font-size:.9rem}@media(max-width:720px){.visit-document-row{align-items:flex-start;flex-direction:column}.visit-document-actions{width:100%}.visit-document-actions button{flex:1}}

/* V19 - Revisión F30/F30-1 */
.f30-upload-grid{margin:18px 0}.f30-checklist{display:grid;gap:8px;margin-bottom:18px}.f30-check-row{display:grid;grid-template-columns:minmax(260px,1fr) 160px 160px;gap:10px;align-items:center;border:1px solid #d8e3ec;border-radius:12px;padding:10px 12px;background:#fff}.f30-check-row strong{font-size:.94rem}.f30-check-row small{color:#64748b}.f30-status-ok{color:#08783f}.f30-status-warn{color:#a45a00}.f30-status-bad{color:#b42318}.f30-cross-ok{background:#effcf4}.f30-cross-warn{background:#fff8e8}.f30-cross-bad{background:#fff0f0}.f30-history-badge{display:inline-block;border-radius:999px;padding:5px 9px;font-weight:800;font-size:.78rem;background:#e7f0f7}.table-wrap{overflow:auto}.data-table{width:100%;border-collapse:collapse;background:#fff}.data-table th,.data-table td{border-bottom:1px solid #dce6ee;padding:9px;text-align:left;font-size:.86rem}.data-table th{background:#edf4f8;color:#0d3a63;position:sticky;top:0}.f30-kpis .kpi strong{font-size:1.4rem}@media(max-width:800px){.f30-check-row{grid-template-columns:1fr}.data-table{min-width:1100px}}


/* V29: historial previsualizable, Excel vertical e informe consolidado F30/F30-1 */
.f30-consolidated-check{border:1px solid #cbdbe6;border-radius:12px;padding:11px 13px;background:#fff}.f30-inline-check{display:flex!important;align-items:flex-start;gap:9px;font-weight:700!important;color:#334e62!important}.f30-inline-check input{width:auto!important;margin-top:2px}.f30-history-filters,.f30-consolidated-filters{grid-template-columns:repeat(3,minmax(145px,1fr)) auto}.f30-consolidated-panel{margin-top:28px;padding-top:24px;border-top:2px solid #d9e6ee}.f30-consolidated-table{min-width:1250px}.f30-consolidated-table td,.f30-consolidated-table th{text-align:center}.f30-consolidated-table td:first-child,.f30-consolidated-table td:nth-child(3){text-align:left}.f30-matrix-ok{background:#eaf9ef;color:#08783f;font-weight:900}.f30-matrix-bad{background:#fff0f0;color:#b42318;font-weight:900}.f30-matrix-na{background:#f1f5f9;color:#64748b;font-weight:900}.f30-vigente-badge{display:inline-block;margin-left:6px;border-radius:999px;padding:5px 9px;font-size:.76rem;font-weight:900;background:#dcfce7;color:#166534}.f30-preview-card{width:min(1420px,100%);max-height:92vh}.f30-preview-section{margin:20px 0}.f30-preview-section h3{margin:0 0 10px;color:var(--navy);border-bottom:2px solid #dce8ef;padding-bottom:7px}.f30-preview-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(185px,1fr));gap:9px}.f30-preview-summary>div{background:#f4f8fb;border:1px solid #dce8ef;border-radius:10px;padding:10px}.f30-preview-summary small{display:block;color:#64748b}.f30-preview-summary strong{display:block;color:#0d3a63;margin-top:4px}.f30-preview-docs{display:grid;gap:6px}.f30-preview-doc{padding:8px 10px;border:1px solid #dce8ef;border-radius:9px;background:#fff}.f30-preview-result{padding:14px;border-radius:12px;background:#e8f1f6;font-size:1.05rem}.f30-preview-observation{white-space:pre-wrap;background:#fff;border:1px solid #dce8ef;border-radius:10px;padding:12px}.f30-active-button{background:#dcfce7!important;color:#166534!important;border-color:#86efac!important}
@media(max-width:900px){.f30-history-filters,.f30-consolidated-filters{grid-template-columns:1fr 1fr}.f30-preview-card{padding:16px}.f30-consolidated-kpis{grid-template-columns:repeat(2,1fr)}}
@media(max-width:580px){.f30-history-filters,.f30-consolidated-filters{grid-template-columns:1fr}}

/* M1.2 MENU SIDEBAR FIX START */
@media (min-width: 961px) {
  .sidebar {
    height: calc(100vh - 96px) !important;
    min-height: 0 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    overscroll-behavior: contain;
    scrollbar-gutter: stable;
    padding-bottom: calc(20px + env(safe-area-inset-bottom)) !important;
  }
  .sidebar .tab {
    flex: 0 0 auto !important;
    width: 100% !important;
  }
}
@media (max-width: 960px) {
  .sidebar {
    height: auto !important;
    min-height: auto !important;
    overflow-y: hidden !important;
    overflow-x: auto !important;
    scrollbar-gutter: auto !important;
  }
}
/* M1.2 MENU SIDEBAR FIX END */
