/* ==========================================================
   SIGO - Diseño profesional ligero sobre AdminLTE
   Sin imágenes pesadas. Solo CSS + variables.
   ========================================================== */
:root{
  --sigo-bg:#f4f7fb;
  --sigo-surface:#ffffff;
  --sigo-surface-2:#f8fafc;
  --sigo-sidebar:#0f172a;
  --sigo-sidebar-2:#111827;
  --sigo-primary:#2563eb;
  --sigo-primary-2:#38bdf8;
  --sigo-success:#10b981;
  --sigo-warning:#f59e0b;
  --sigo-danger:#ef4444;
  --sigo-purple:#7c3aed;
  --sigo-text:#0f172a;
  --sigo-muted:#64748b;
  --sigo-border:#e2e8f0;
  --sigo-shadow:0 14px 35px rgba(15,23,42,.08);
  --sigo-shadow-sm:0 8px 20px rgba(15,23,42,.06);
  --sigo-radius:16px;
  --sigo-radius-sm:10px;
}
*{box-sizing:border-box}
body{font-family:'Inter',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:var(--sigo-bg);color:var(--sigo-text);font-size:14px}
a{color:var(--sigo-primary)}
.hidden{display:none!important}.text-cyan{color:var(--sigo-primary-2)!important}.text-emerald{color:var(--sigo-success)!important}.text-purple{color:var(--sigo-purple)!important}.text-orange{color:var(--sigo-warning)!important}.text-red{color:var(--sigo-danger)!important}
::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#e5e7eb}::-webkit-scrollbar-thumb{background:#94a3b8;border-radius:999px}::-webkit-scrollbar-thumb:hover{background:#64748b}

/* Login */
.login-page{min-height:100vh;background:radial-gradient(circle at 15% 20%, rgba(37,99,235,.28), transparent 26%),radial-gradient(circle at 85% 80%, rgba(56,189,248,.22), transparent 28%),linear-gradient(135deg,#020617 0%,#0f172a 45%,#111827 100%);display:flex;align-items:center;justify-content:center;padding:24px;position:relative;overflow:hidden}
.login-page:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:42px 42px;mask-image:radial-gradient(circle at center,black,transparent 78%)}
.login-box{width:420px;max-width:100%;position:relative;z-index:2}.login-logo a{color:#fff!important;font-weight:800;letter-spacing:.5px;font-size:34px;text-decoration:none}.login-logo a b{background:linear-gradient(135deg,#60a5fa,#22d3ee);-webkit-background-clip:text;background-clip:text;color:transparent}.login-logo:after{content:"Smart Intelligent Global Operations";display:block;color:#cbd5e1;font-size:13px;margin-top:6px;letter-spacing:.4px}.login-box .card{border:1px solid rgba(255,255,255,.14)!important;border-radius:22px!important;box-shadow:0 28px 80px rgba(0,0,0,.35)!important;background:rgba(255,255,255,.94);backdrop-filter:blur(18px);overflow:hidden}.login-box .card-header{border-bottom:1px solid #e5e7eb;background:linear-gradient(180deg,#fff,#f8fafc);padding:28px 24px 18px}.login-box .card-header i{background:linear-gradient(135deg,var(--sigo-primary),var(--sigo-primary-2));-webkit-background-clip:text;background-clip:text;color:transparent!important}.login-box .card-header h5{font-weight:800;color:#0f172a;line-height:1.25}.login-card-body{padding:28px!important}.login-box-msg{color:var(--sigo-muted);font-weight:500}.input-group .form-control,.form-group input,.form-group select,.form-group textarea,.select-box,.search-box{border:1px solid var(--sigo-border);border-radius:12px!important;background:#fff;color:var(--sigo-text);min-height:42px;box-shadow:none!important;transition:.18s ease}.input-group .form-control:focus,.form-group input:focus,.form-group select:focus,.form-group textarea:focus,.select-box:focus,.search-box:focus{border-color:#93c5fd;box-shadow:0 0 0 4px rgba(37,99,235,.12)!important}.input-group-text{border:1px solid var(--sigo-border);border-left:0;border-radius:0 12px 12px 0!important;background:#f8fafc;color:var(--sigo-muted)}

/* AdminLTE base */
.wrapper{background:var(--sigo-bg)}.main-header{height:62px;border-bottom:1px solid var(--sigo-border)!important;background:rgba(255,255,255,.88)!important;backdrop-filter:blur(14px);box-shadow:0 4px 20px rgba(15,23,42,.04)}.main-header .nav-link{color:#334155!important}.main-header .nav-link:hover{color:var(--sigo-primary)!important}#current-tab-title{font-weight:800;color:#0f172a;letter-spacing:.1px}.content-wrapper{background:linear-gradient(180deg,#f8fafc 0%,#eef2f7 100%);padding-bottom:20px}.main-footer{border-top:1px solid var(--sigo-border);background:#fff;color:var(--sigo-muted)}
.main-sidebar{background:linear-gradient(180deg,var(--sigo-sidebar) 0%,var(--sigo-sidebar-2) 100%)!important;box-shadow:8px 0 30px rgba(15,23,42,.2)}.brand-link{height:62px;border-bottom:1px solid rgba(255,255,255,.08)!important;display:flex;align-items:center;padding-left:18px}.brand-link .brand-image{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;border-radius:12px;background:linear-gradient(135deg,var(--sigo-primary),var(--sigo-primary-2));color:#fff!important;margin-right:10px;box-shadow:0 8px 18px rgba(37,99,235,.28);font-size:17px}.brand-link .brand-text{font-weight:900!important;color:#fff;letter-spacing:.8px}.sidebar{padding:12px}.user-panel{border-bottom:1px solid rgba(255,255,255,.08)!important}.user-adminlte-icon{width:38px;height:38px;display:flex!important;align-items:center;justify-content:center;background:rgba(56,189,248,.14);color:#67e8f9!important}.user-panel .info a{color:#f8fafc!important;font-weight:700}.user-panel .badge{font-size:10px;letter-spacing:.5px;background:rgba(56,189,248,.18)!important;color:#a5f3fc!important;border:1px solid rgba(56,189,248,.25)}.nav-sidebar .nav-item{margin-bottom:4px}.nav-sidebar .nav-link{border-radius:12px!important;color:#cbd5e1!important;transition:.18s ease}.nav-sidebar .nav-link p{font-weight:600}.nav-sidebar .nav-link:hover{background:rgba(255,255,255,.08)!important;color:#fff!important;transform:translateX(2px)}.nav-sidebar .nav-link.active{background:linear-gradient(135deg,var(--sigo-primary),#0ea5e9)!important;color:#fff!important;box-shadow:0 10px 20px rgba(37,99,235,.22)}.nav-sidebar .nav-icon{font-size:15px;width:26px!important}.sidebar .btn{border-radius:12px!important;font-weight:700;padding:.55rem .75rem}.indicator-dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:6px;background:#94a3b8}.indicator-dot.offline,.status-offline{background:var(--sigo-danger)}.indicator-dot.online{background:var(--sigo-success)}

/* Componentes generales */
.glass,.table-container,.chart-container,.attendance-card,.dist-control,.dist-manual,.forms-sidebar,.form-view-panel,.form-builder-editor,.form-builder-preview,.reports-control-card,.reports-info,.action-bar,.modal-card,.live-status-box,.form-empty-state{background:var(--sigo-surface);border:1px solid var(--sigo-border);border-radius:var(--sigo-radius);box-shadow:var(--sigo-shadow-sm)}.tab-panel{display:none;animation:fadeUp .22s ease}.tab-panel.active{display:block}.tab-panels{padding-bottom:24px}.content .container-fluid{max-width:1500px}.action-bar,.table-header,.section-title-row,.attendance-header,.modal-header{display:flex;align-items:center;justify-content:space-between;gap:14px}.action-bar{padding:18px 20px;margin-bottom:18px}.action-bar h3,.table-header h3,.chart-container h3,.dist-control h3,.dist-manual h3,.forms-sidebar h3,.form-builder-editor h3,.form-builder-preview h3,.reports-control-card h3{font-size:16px;font-weight:850;color:#0f172a;margin:0}.section-desc,.reports-info p,.empty-preview-msg{color:var(--sigo-muted);margin-bottom:16px}.divider{border:0;border-top:1px solid var(--sigo-border);margin:18px 0}

/* Botones */
.btn{border-radius:12px!important;font-weight:750;border:0;transition:.18s ease;box-shadow:none!important}.btn:hover{transform:translateY(-1px)}.btn-primary{background:linear-gradient(135deg,var(--sigo-primary),#0ea5e9)!important;color:#fff!important}.btn-success{background:linear-gradient(135deg,#059669,var(--sigo-success))!important;color:#fff!important}.btn-danger{background:linear-gradient(135deg,#dc2626,var(--sigo-danger))!important;color:#fff!important}.btn-warning{background:linear-gradient(135deg,#d97706,var(--sigo-warning))!important;color:#fff!important}.btn-info{background:linear-gradient(135deg,#0891b2,var(--sigo-primary-2))!important;color:#fff!important}.btn-outline,.btn-outline-cyan{background:#fff!important;border:1px solid var(--sigo-border)!important;color:#2563eb!important}.btn-outline:hover,.btn-outline-cyan:hover{background:#eff6ff!important;border-color:#bfdbfe!important}.btn-block{width:100%}.btn-sm{padding:.45rem .75rem;font-size:12px}.btn-xs{padding:.2rem .45rem;font-size:11px}.btn-punch{min-height:92px;border-radius:18px!important;font-size:15px;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}.btn-punch i{font-size:24px}

/* KPI y dashboard */
.dashboard-kpi-grid,.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;margin-bottom:18px}.kpi-card,.stat-box{position:relative;overflow:hidden;padding:22px;display:flex;align-items:center;gap:16px}.kpi-card:after,.stat-box:after{content:"";position:absolute;right:-32px;top:-32px;width:110px;height:110px;border-radius:50%;background:rgba(37,99,235,.08)}.kpi-icon{width:54px;height:54px;border-radius:16px;background:#eff6ff;display:flex;align-items:center;justify-content:center;font-size:24px}.kpi-data h3,.stat-label{font-size:12px;text-transform:uppercase;letter-spacing:.6px;color:var(--sigo-muted);font-weight:800;margin:0 0 6px}.kpi-value,.stat-box strong{font-size:30px;font-weight:900;color:#0f172a;line-height:1}.border-cyan{border-left:5px solid var(--sigo-primary-2)}.border-orange{border-left:5px solid var(--sigo-warning)}.border-emerald{border-left:5px solid var(--sigo-success)}.border-purple{border-left:5px solid var(--sigo-purple)}.dashboard-charts-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}.chart-container{padding:20px}.chart-wrapper{min-height:190px;margin-top:12px}.chart-legend{display:flex;flex-wrap:wrap;gap:8px;color:var(--sigo-muted);font-size:12px}.dashboard-recent-row{display:block}.recent-sots{margin-top:0}

/* Tablas */
.table-container{overflow:hidden}.table-header{padding:18px 20px;border-bottom:1px solid var(--sigo-border);background:linear-gradient(180deg,#fff,#f8fafc)}.table-responsive{width:100%;overflow:auto}.data-table{width:100%;border-collapse:separate;border-spacing:0;background:#fff}.data-table thead th{position:sticky;top:0;background:#f8fafc;color:#475569;font-size:12px;text-transform:uppercase;letter-spacing:.55px;font-weight:850;border-bottom:1px solid var(--sigo-border);padding:13px 14px;white-space:nowrap}.data-table tbody td{padding:13px 14px;border-bottom:1px solid #eef2f7;color:#1e293b;vertical-align:middle}.data-table tbody tr:hover{background:#f8fbff}.data-table tbody tr:last-child td{border-bottom:0}.badge{border-radius:999px;padding:.42rem .6rem;font-weight:800;font-size:11px;letter-spacing:.2px}.scroll-y{max-height:640px;overflow:auto}.search-filter-group{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.search-box{min-width:260px;padding:0 14px}.select-box{padding:0 14px}

/* Asistencia */
.attendance-layout{display:grid;grid-template-columns:minmax(280px,420px) 1fr;gap:18px}.attendance-card{padding:24px}.clock-label{font-size:42px;font-weight:900;letter-spacing:-1px;color:#0f172a}.attendance-status-badge{display:inline-flex;align-items:center;gap:6px;background:#eff6ff;color:#1d4ed8;border:1px solid #bfdbfe;border-radius:999px;padding:8px 12px;font-weight:800}.attendance-buttons{display:flex;gap:12px;margin:18px 0}.attendance-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px}.info-metrics-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:16px}.info-metric-box{padding:14px;background:#f8fafc;border:1px solid var(--sigo-border);border-radius:14px}.remark-group textarea{min-height:100px}

/* Distribución / formularios */
.distribution-grid{display:grid;grid-template-columns:minmax(300px,420px) 1fr;gap:18px}.dist-control,.dist-manual,.forms-sidebar,.form-builder-editor,.form-builder-preview,.reports-control-card,.reports-info{padding:20px}.dist-manual-container{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:12px}.pending-sots-list,.operators-dropzone,.builder-fields-container,.preview-fields-box,.comments-list,.timeline{min-height:160px;background:#f8fafc;border:1px dashed #cbd5e1;border-radius:14px;padding:14px}.live-status-box{margin-top:16px;padding:14px;background:#f8fafc}.forms-management-grid{display:grid;grid-template-columns:300px 1fr;gap:18px}.form-list{list-style:none;padding:0;margin:12px 0 0}.form-list li,.form-list a{display:block;padding:12px 14px;border-radius:12px;color:#334155;font-weight:700}.form-list li:hover,.form-list a:hover{background:#eff6ff;color:#1d4ed8;text-decoration:none}.form-empty-state{text-align:center;padding:54px 24px;color:var(--sigo-muted)}.form-empty-state i{font-size:52px;color:#bfdbfe;margin-bottom:12px}.form-empty-state h3{font-weight:850;color:#0f172a}.form-tabs{display:flex;gap:8px;margin-bottom:12px}.form-tab-btn{border:1px solid var(--sigo-border);background:#fff;color:#475569;border-radius:12px;padding:10px 14px;font-weight:800}.form-tab-btn.active{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe}.form-view-panel{display:none;padding:20px}.form-view-panel.active{display:block}.dynamic-captured-fields{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.form-builder-layout{display:grid;grid-template-columns:1.15fr .85fr;gap:18px}.preview-container{background:#f8fafc;border:1px solid var(--sigo-border);border-radius:16px;padding:16px}.preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.preview-badge{background:#e0f2fe;color:#0369a1;border-radius:999px;padding:5px 10px;font-weight:850;font-size:11px}.reports-layout{display:grid;grid-template-columns:380px 1fr;gap:18px}

/* Formularios y modales */
.form-group{margin-bottom:14px}.form-group label{font-size:12px;text-transform:uppercase;letter-spacing:.45px;color:#64748b;font-weight:850;margin-bottom:7px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-left:0;margin-right:0}.input-readonly{background:#f1f5f9!important;color:#64748b!important}.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,.55);display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px;backdrop-filter:blur(6px)}.modal-card{width:100%;max-width:520px;max-height:92vh;overflow:auto}.modal-lg{max-width:920px}.modal-header{padding:18px 20px;border-bottom:1px solid var(--sigo-border)}.modal-header h3{margin:0;font-size:17px;font-weight:900}.modal-card form,.modal-card .modal-body{padding:20px}.modal-footer{padding:16px 20px;border-top:1px solid var(--sigo-border);display:flex;justify-content:flex-end;gap:10px}.btn-close-modal{background:#f1f5f9!important;color:#64748b!important;width:34px;height:34px;border-radius:10px!important;padding:0!important}.sot-editor-layout{display:grid;grid-template-columns:1fr 300px;gap:18px}.sot-editor-fields,.sot-editor-timeline{padding:20px}.toast-container{position:fixed;right:18px;bottom:18px;z-index:3000}.concurrency-banner{background:#fff7ed;border:1px solid #fed7aa;color:#9a3412;border-radius:12px;padding:12px 14px;margin-bottom:14px;font-weight:700}

/* Estados genéricos */
.status-text{font-weight:650}.status-offline{color:#fff;border-radius:999px;padding:4px 8px}.small{font-size:12px}.float-right{float:right}

@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@media(max-width:1100px){.dashboard-kpi-grid,.stats-grid{grid-template-columns:repeat(2,1fr)}.dashboard-charts-row,.distribution-grid,.forms-management-grid,.form-builder-layout,.reports-layout,.attendance-layout,.sot-editor-layout{grid-template-columns:1fr}.reports-control-card{order:1}.reports-info{order:2}}
@media(max-width:720px){.content{padding:10px!important}.dashboard-kpi-grid,.stats-grid,.dynamic-captured-fields,.form-row,.info-metrics-row,.attendance-stats,.dist-manual-container{grid-template-columns:1fr}.action-bar,.table-header,.attendance-header,.modal-header{align-items:flex-start;flex-direction:column}.clock-label{font-size:34px}.search-box{min-width:100%;width:100%}.login-box{width:100%}.data-table{min-width:720px}.main-header .navbar-nav.ml-auto .nav-item:first-child{display:none}}


/* Módulos ocultos por perfil */
.module-denied{
    display:none !important;
}

#dynamic-module-menu{
    display:block;
}


/* ================================================================
   Ajustes modulares por páginas independientes
   ================================================================ */
.module-page .tab-panel{display:block !important; opacity:1 !important; visibility:visible !important;}
.table-container,.table-responsive{width:100%; overflow-x:auto;}
.data-table{min-width:900px; width:100%; border-collapse:collapse;}
.content-wrapper{min-height:calc(100vh - 57px);}
.hidden{display:none !important;}
@media (max-width: 768px){
  .dashboard-kpi-grid,.dashboard-charts-row,.dashboard-recent-row,.attendance-layout,.distribution-grid,.forms-management-grid,.form-builder-layout,.reports-layout{grid-template-columns:1fr !important;}
  .action-bar{flex-direction:column; align-items:stretch; gap:12px;}
  .search-filter-group{flex-direction:column; width:100%;}
}


/* ================================================================
   FIX 2026-06 - Módulos independientes y tablas rápidas/estables
   ================================================================ */
.module-page{width:100%;}
.module-page .tab-panel{display:block !important;}
.table-container{width:100%; overflow-x:auto; overflow-y:hidden;}
.table-container .data-table{min-width:980px; table-layout:auto;}
.data-table th,.data-table td{line-height:1.35; vertical-align:middle;}
.data-table td{word-break:normal; overflow-wrap:anywhere;}
.data-table td .btn{white-space:nowrap;}
.action-bar{align-items:center; flex-wrap:wrap;}
.search-filter-group{flex:1 1 480px; min-width:260px;}
.search-box input,.select-box select{width:100%; border:0; outline:0; min-height:40px; background:transparent;}
.search-box,.select-box{display:flex; align-items:center; gap:8px;}
.forms-management-grid,.distribution-grid,.form-builder-layout,.reports-layout,.attendance-layout{align-items:start;}
.glass{min-width:0;}
.kpi-card,.stat-box,.card,.glass{overflow-wrap:break-word;}
.content-wrapper .container-fluid{padding-left:18px; padding-right:18px;}
.badge{display:inline-flex; align-items:center; justify-content:center; min-height:24px;}
.btn-xs{white-space:nowrap;}
@media(max-width: 900px){
  .content-wrapper .container-fluid{padding-left:10px; padding-right:10px;}
  .table-container .data-table{min-width:820px;}
  .action-bar{align-items:stretch;}
  .search-filter-group{width:100%;}
}

/* ==========================================================
   SOT - Modal edición tipo chat + evidencias local/S3 ready
   ========================================================== */
.modal-xl{max-width:1180px}.sot-modal-card{overflow:hidden}.sot-modal-header{align-items:flex-start}.sot-modal-subtitle{margin:5px 0 0;color:#64748b;font-size:12px;font-weight:650}.sot-editor-layout-v2{grid-template-columns:380px minmax(0,1fr);gap:16px;padding:0 20px 20px}.sot-editor-layout-v2 .sot-editor-fields,.sot-editor-layout-v2 .sot-editor-timeline{padding:16px;border-radius:16px}.sot-editor-layout-v2 .sot-editor-timeline{display:flex;flex-direction:column;min-height:560px;max-height:68vh}.sot-chat-header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:10px}.sot-chat-header h4{margin:0;font-size:15px;font-weight:900;color:#0f172a}.sot-chat-header span{font-size:11px;color:#64748b;font-weight:800;background:#f1f5f9;border-radius:999px;padding:5px 9px}.sot-chat-list{height:100%;min-height:440px;max-height:58vh;overflow-y:auto;background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;padding:14px;display:flex;flex-direction:column;gap:10px}.sot-chat-loading{font-size:12px;color:#64748b}.comment-bubble.sot-chat-bubble{width:fit-content;max-width:82%;padding:11px 12px;border-radius:16px;border:1px solid #e2e8f0;background:#fff;box-shadow:0 8px 22px rgba(15,23,42,.05)}.comment-bubble.sot-chat-bubble.mine{align-self:flex-end;background:#eff6ff;border-color:#bfdbfe}.comment-bubble.sot-chat-bubble.other{align-self:flex-start;background:#fff}.comment-bubble-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:6px;font-size:11px;color:#64748b}.comment-bubble-meta strong{color:#1d4ed8}.comment-bubble.sot-chat-bubble p{margin:0;font-size:13px;line-height:1.35;color:#1e293b;white-space:normal;word-break:break-word}.sot-action-row{display:flex;justify-content:flex-start;margin-top:-4px;margin-bottom:10px}.sot-modal-footer{padding-left:0!important;padding-right:0!important}.sot-evidence-card{margin-top:9px;border:1px solid #cbd5e1;background:#fff;border-radius:12px;padding:9px;display:flex;align-items:center;gap:9px;max-width:260px;color:#334155;text-align:left;cursor:pointer;text-decoration:none}.sot-evidence-card:hover{background:#f8fafc;text-decoration:none}.sot-evidence-image{display:block;padding:7px}.sot-evidence-image img{display:block;width:210px;max-width:100%;height:120px;object-fit:cover;border-radius:10px;margin-bottom:7px}.sot-evidence-image span{display:block;font-size:12px;font-weight:800;color:#2563eb}.sot-evidence-pdf-card i{font-size:26px;color:#dc2626}.sot-evidence-pdf-card span{font-size:12px;font-weight:850;max-width:165px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sot-evidence-pdf-card small{display:block;font-size:10px;color:#64748b}.sot-evidence-viewer-card{height:90vh;overflow:hidden}.sot-evidence-viewer-body{height:calc(90vh - 72px);padding:14px;background:#0f172a;display:flex;align-items:center;justify-content:center}.sot-evidence-full-img{max-width:100%;max-height:100%;border-radius:12px;box-shadow:0 20px 45px rgba(0,0,0,.35)}.sot-evidence-pdf{width:100%;height:100%;border:0;border-radius:12px;background:#fff}.sot-evidence-download{background:#fff;border-radius:14px;padding:22px;display:flex;align-items:center;gap:12px}.sot-evidence-download i{font-size:26px;color:#2563eb}@media(max-width:1100px){.sot-editor-layout-v2{grid-template-columns:1fr}.sot-editor-layout-v2 .sot-editor-timeline{min-height:420px}.sot-chat-list{min-height:330px;max-height:45vh}.comment-bubble.sot-chat-bubble{max-width:94%}}

/* ==========================================================
   SOT EDITOR V3 - modal amplio, historial tipo chat y viewer
   ========================================================== */
#modal-edit-sot.modal-overlay{align-items:center;justify-content:center;padding:18px;overflow:hidden;z-index:2100}
.sot-modal-card-v3{width:min(1380px,96vw)!important;max-width:1380px!important;height:min(820px,92vh);max-height:92vh!important;overflow:hidden!important;display:flex;flex-direction:column;border-radius:18px;background:#fff;box-shadow:0 24px 80px rgba(15,23,42,.28)}
.sot-modal-header-v3{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 20px;background:#fff;border-bottom:1px solid #e2e8f0}
.sot-modal-header-v3 h3{display:flex;align-items:center;gap:10px;color:#0f172a;font-size:19px}.sot-modal-header-v3 h3 i{color:#2563eb}.sot-modal-header-actions{display:flex;align-items:center;gap:10px}.sot-lock-pill{margin:0!important;padding:8px 12px!important;border-radius:999px!important;font-size:12px!important;white-space:nowrap;background:#fff7ed!important}
.sot-editor-layout-v3{flex:1 1 auto;display:grid!important;grid-template-columns:420px minmax(0,1fr)!important;gap:0!important;min-height:0;padding:0!important;background:#f8fafc;overflow:hidden}
.sot-editor-layout-v3 .sot-editor-fields{border-radius:0!important;border:0!important;border-right:1px solid #e2e8f0;background:#fff!important;padding:18px!important;overflow-y:auto;min-width:0}
.sot-section-title{display:flex;align-items:center;gap:8px;margin-bottom:14px;font-weight:900;color:#0f172a;font-size:14px}.sot-section-title i{color:#2563eb}.sot-help-box{display:flex;gap:10px;align-items:flex-start;background:#eff6ff;border:1px solid #bfdbfe;color:#1e3a8a;border-radius:14px;padding:12px;margin:12px 0 18px;font-size:12px;line-height:1.35}.sot-help-box i{margin-top:2px;color:#2563eb}.sot-modal-footer-v3{position:sticky;bottom:0;background:#fff;padding:14px 0 0!important;margin-top:14px!important;display:grid!important;grid-template-columns:1fr 1fr;gap:12px;border-top:1px solid #e2e8f0!important}
.sot-chat-panel-v3{display:flex!important;flex-direction:column;min-width:0;min-height:0;height:100%;max-height:none!important;border-radius:0!important;border:0!important;background:#f8fafc!important;padding:0!important;overflow:hidden!important}
.sot-chat-header-v3{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 18px;background:#fff;border-bottom:1px solid #e2e8f0;margin:0!important}.sot-chat-header-v3 h4{font-size:16px!important;margin:0 0 4px!important}.sot-chat-header-v3 span{font-size:12px!important;color:#64748b;background:none!important;padding:0!important}
.sot-chat-list-v3{flex:1 1 auto;height:auto!important;min-height:0!important;max-height:none!important;overflow-y:auto!important;padding:18px 20px!important;background:linear-gradient(180deg,#f8fafc 0%,#eef6ff 100%)!important;border:0!important;border-radius:0!important;gap:14px!important;scrollbar-width:thin}
.sot-chat-message{display:flex;align-items:flex-start;gap:10px;max-width:88%}.sot-chat-message.mine{margin-left:auto;flex-direction:row-reverse}.sot-chat-avatar{flex:0 0 36px;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#2563eb;color:#fff;font-weight:900;font-size:13px;box-shadow:0 8px 18px rgba(37,99,235,.25)}.sot-chat-message.mine .sot-chat-avatar{background:#16a34a}
.sot-chat-message .sot-chat-bubble{width:auto!important;max-width:100%!important;margin:0!important;padding:12px 13px!important;border-radius:16px!important;background:#fff!important;border:1px solid #e2e8f0!important;box-shadow:0 8px 24px rgba(15,23,42,.06)!important}.sot-chat-message.mine .sot-chat-bubble{background:#eaf8f0!important;border-color:#bbf7d0!important}.sot-chat-message.other .sot-chat-bubble{background:#fff!important}.comment-bubble-meta{font-size:12px!important;gap:12px!important}.comment-bubble-meta strong{color:#0f172a!important}.comment-bubble-meta span{color:#64748b;white-space:nowrap}.sot-chat-bubble p{font-size:13px!important;line-height:1.45!important;color:#1e293b!important;margin:0!important;word-break:break-word}
.sot-attachment{margin-top:10px;width:100%;max-width:460px;display:flex;align-items:center;gap:10px;padding:8px;border:1px solid #dbeafe;background:#f8fbff;border-radius:12px;text-decoration:none;color:#0f172a;cursor:pointer;text-align:left;transition:.15s ease}.sot-attachment:hover{transform:translateY(-1px);background:#eff6ff}.sot-attachment-thumb{flex:0 0 62px;width:62px;height:44px;border-radius:9px;overflow:hidden;background:#e2e8f0;border:1px solid #cbd5e1}.sot-attachment-thumb img{width:100%;height:100%;object-fit:cover;display:block}.sot-attachment-icon{flex:0 0 44px;width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:#fee2e2;color:#dc2626;font-size:22px}.sot-attachment-info{min-width:0;flex:1;display:flex;flex-direction:column;gap:2px}.sot-attachment-info strong{font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sot-attachment-info small{font-size:11px;color:#64748b}.sot-attachment>i{color:#2563eb;margin-left:auto}.sot-chat-composer{flex:0 0 auto;padding:14px 18px;background:#fff;border-top:1px solid #e2e8f0}.sot-chat-composer textarea{width:100%;resize:none;border:1px solid #cbd5e1;border-radius:12px;padding:10px 12px;font-size:13px;min-height:48px;max-height:120px}.sot-chat-composer-actions{display:flex;align-items:center;gap:10px;margin-top:10px}.sot-file-picker{display:inline-flex;align-items:center;gap:8px;border:1px dashed #93c5fd;background:#eff6ff;color:#1d4ed8;border-radius:10px;padding:10px 12px;font-weight:800;font-size:12px;cursor:pointer}.sot-file-picker:hover{background:#dbeafe}.sot-chat-composer input[type=file]{display:none}.sot-chat-composer .btn{margin-left:auto}.sot-chat-composer small{display:block;margin-top:6px;font-size:11px}
#modal-sot-evidence-viewer.modal-overlay{z-index:2500;background:rgba(15,23,42,.72);padding:22px}.sot-evidence-viewer-card-v3{width:min(1160px,94vw)!important;height:min(780px,90vh)!important;max-width:1160px!important;overflow:hidden!important;border-radius:18px;background:#fff}.sot-evidence-viewer-header{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#fff}.sot-viewer-actions{display:flex;align-items:center;gap:8px}.sot-evidence-viewer-body{height:calc(100% - 72px)!important;background:#0f172a!important;padding:16px!important}.sot-evidence-full-img{max-width:100%!important;max-height:100%!important;object-fit:contain!important}.sot-evidence-pdf{width:100%!important;height:100%!important;border:0;border-radius:12px;background:#fff}
@media(max-width:1100px){.sot-modal-card-v3{height:94vh}.sot-editor-layout-v3{grid-template-columns:1fr!important;overflow-y:auto}.sot-editor-layout-v3 .sot-editor-fields{border-right:0;border-bottom:1px solid #e2e8f0;overflow:visible}.sot-chat-panel-v3{min-height:560px}.sot-chat-message{max-width:96%}.sot-modal-footer-v3{grid-template-columns:1fr}.sot-chat-header-v3{align-items:flex-start}.sot-chat-composer-actions{flex-wrap:wrap}.sot-chat-composer .btn{margin-left:0;width:100%}}


/* SOT MODAL V4 FIX - layout amplio y evidencias compactas */
#modal-edit-sot .sot-modal-card-v4{width:min(1280px,calc(100vw - 48px))!important;max-width:min(1280px,calc(100vw - 48px))!important;min-width:980px!important;height:min(820px,calc(100vh - 48px))!important;overflow:hidden!important;display:flex!important;flex-direction:column!important}
#modal-edit-sot .sot-editor-layout-v3{grid-template-columns:360px minmax(0,1fr)!important;overflow:hidden!important;min-height:0!important}
#modal-edit-sot .sot-attachment-thumb,#modal-edit-sot .sot-attachment-thumb img,#modal-edit-sot .sot-attachment-img img{width:72px!important;height:48px!important;max-width:72px!important;max-height:48px!important;object-fit:cover!important}
#modal-edit-sot .sot-attachment{max-width:430px!important;max-height:72px!important;overflow:hidden!important}
@media(max-width:1040px){#modal-edit-sot .sot-modal-card-v4{min-width:0!important;width:calc(100vw - 24px)!important;max-width:calc(100vw - 24px)!important;height:calc(100vh - 24px)!important}#modal-edit-sot .sot-editor-layout-v3{grid-template-columns:1fr!important}}
