:root{--bg:#f4f6fb;--card:#fff;--text:#152033;--muted:#65748b;--line:#dbe3ef;--primary:#1f4f8f;--primary2:#12396c;--ok:#12805c;--bad:#b42318;--warn:#b7791f;--soft:#eef4ff;--soft2:#f8fafc;--shadow:0 14px 34px rgba(15,23,42,.08)}*{box-sizing:border-box}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:radial-gradient(circle at top left,#eaf1ff,transparent 38%),var(--bg);color:var(--text)}.wrap{max-width:1280px;margin:auto}.app-header{background:linear-gradient(135deg,var(--primary),var(--primary2));color:#fff;box-shadow:0 8px 28px rgba(15,23,42,.18);position:sticky;top:0;z-index:20}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px}.brand{display:flex;align-items:center;gap:11px;color:white;text-decoration:none}.brand-icon{width:38px;height:38px;border-radius:14px;background:rgba(255,255,255,.14);display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.25)}.brand b{display:block;font-size:19px;line-height:1.15}.brand small{display:block;color:#dce9ff;margin-top:2px}.nav{display:flex;gap:8px;flex-wrap:wrap}.nav a{color:white;text-decoration:none;font-weight:850;border:1px solid rgba(255,255,255,.28);background:rgba(255,255,255,.11);border-radius:999px;padding:9px 13px}.nav a:hover,.nav a.active{background:white;color:var(--primary)}.page{padding:22px 14px 45px}.hero{background:linear-gradient(135deg,#fff,#f7fbff);border:1px solid var(--line);border-radius:26px;padding:22px;box-shadow:var(--shadow)}.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}.span12{grid-column:span 12}.span8{grid-column:span 8}.span7{grid-column:span 7}.span6{grid-column:span 6}.span5{grid-column:span 5}.span4{grid-column:span 4}.span3{grid-column:span 3}.span2{grid-column:span 2}@media(max-width:950px){.span8,.span7,.span6,.span5,.span4,.span3,.span2{grid-column:span 12}.topbar{align-items:flex-start}.nav{width:100%}}.card{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:16px;box-shadow:var(--shadow)}h1,h2,h3{margin:0 0 10px}h1{font-size:30px}h2{font-size:20px}h3{font-size:16px}.muted{color:var(--muted);font-size:13px}.small{font-size:12px;color:var(--muted)}.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.between{display:flex;justify-content:space-between;gap:12px;align-items:center;flex-wrap:wrap}.tools{display:flex;gap:8px;flex-wrap:wrap}.btn,button{border:0;border-radius:13px;padding:10px 13px;font-weight:900;cursor:pointer;background:var(--primary);color:white;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:40px}.btn:hover,button:hover{filter:brightness(.96)}.secondary{background:#e9eef7!important;color:#193454!important}.danger{background:#fee2e2!important;color:#991b1b!important}.ok{background:#dcfce7!important;color:#166534!important}.warnbtn{background:#fef3c7!important;color:#92400e!important}.field{display:flex;flex-direction:column;gap:4px;min-width:150px}.grow{flex:1}label{font-size:12px;color:var(--muted);font-weight:900}input,select,textarea{width:100%;border:1px solid var(--line);border-radius:13px;padding:10px 11px;background:#fff;min-height:40px;color:var(--text)}textarea{min-height:92px;resize:vertical}.searchbar{background:#fff;border:1px solid var(--line);border-radius:20px;padding:12px;box-shadow:var(--shadow)}table{width:100%;border-collapse:separate;border-spacing:0;border:1px solid var(--line);border-radius:16px;overflow:hidden;background:#fff}th,td{padding:10px;border-bottom:1px solid var(--line);text-align:left;font-size:13px;vertical-align:middle}th{background:#f1f5fb;color:#334155;font-size:12px;text-transform:uppercase;letter-spacing:.04em}tr:last-child td{border-bottom:0}.table-wrap{overflow:auto}.pill{display:inline-flex;align-items:center;border-radius:999px;padding:4px 9px;font-size:12px;font-weight:900;background:#eef2ff;color:#3730a3}.pill.ok{background:#dcfce7;color:#166534}.pill.bad{background:#fee2e2;color:#991b1b}.pill.warn{background:#fef3c7;color:#92400e}.pill.empty{background:#f1f5f9;color:#475569}.kpi{display:flex;flex-direction:column;gap:5px;background:linear-gradient(135deg,#fff,#f8fbff);border:1px solid var(--line);border-radius:18px;padding:15px}.kpi span:first-child{font-size:12px;color:var(--muted);font-weight:900;text-transform:uppercase;letter-spacing:.04em}.kpi b{font-size:30px}.flash{border-radius:15px;padding:12px 14px;margin-bottom:14px;border:1px solid #bbf7d0;background:#f0fdf4;color:#166534;font-weight:800}.flash.bad{border-color:#fecaca;background:#fef2f2;color:#991b1b}.flash.warn{border-color:#fde68a;background:#fffbeb;color:#92400e}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(135deg,var(--primary),#102b55)}.login-card{width:100%;max-width:440px;border-radius:28px;padding:26px;background:#fff;box-shadow:0 25px 70px rgba(0,0,0,.25)}.login-card h1{font-size:28px}.step-tabs{display:flex;gap:8px;flex-wrap:wrap}.step-tabs a{border-radius:999px;background:#eef4ff;color:#1e3a8a;text-decoration:none;padding:8px 11px;font-weight:900}.step-tabs a.active{background:var(--primary);color:white}.relay-card{break-inside:avoid}.relay-title{display:flex;justify-content:space-between;align-items:center;gap:10px;background:#172033;color:white;border-radius:16px 16px 0 0;padding:13px 15px}.relay-body{border:1px solid var(--line);border-top:0;border-radius:0 0 16px 16px;background:white;padding:12px}.cell-person{display:flex;flex-direction:column;gap:5px}.cell-person b{font-size:13px}.cell-actions{margin-top:6px}.mini-select{min-height:34px;font-size:12px;padding:7px}.notice{border:1px solid #bfdbfe;background:#eff6ff;color:#1e3a8a;border-radius:16px;padding:12px}.manual{background:#f5f3ff!important;color:#5b21b6!important}.print-actions{display:none}.whatsapp-box{white-space:pre-wrap;background:#f8fafc;border:1px solid var(--line);border-radius:14px;padding:12px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:12px;max-height:320px;overflow:auto}@media print{header,.nav,.tools,.no-print,.flash,.searchbar,.step-tabs,.cell-actions,.btn,button{display:none!important}body{background:white}.page{max-width:none;padding:0}.card,.hero{box-shadow:none;border:0}.relay-card{page-break-after:always}.relay-card:last-child{page-break-after:auto}.relay-title{background:#172033!important;color:white!important}.print-actions{display:block}}

/* V4 SaaS */
.config-preview{border-radius:22px;padding:22px;background:linear-gradient(135deg,var(--primary),var(--primary2));color:#fff;box-shadow:0 16px 40px rgba(15,23,42,.16)}
.config-preview b{font-size:28px;display:block}.config-preview small{opacity:.85}.sidebar-note{border:1px solid var(--line);background:#f8fafc;border-radius:16px;padding:14px;color:#475569}.role-superadmin{background:#ede9fe;color:#5b21b6}.role-admin{background:#dbeafe;color:#1e40af}.role-gestor{background:#dcfce7;color:#166534}.role-consulta{background:#fef3c7;color:#92400e}.danger-zone{border-color:#fecaca;background:#fff7f7}.mobile-panel{display:grid;gap:12px}.mobile-tramo{border:1px solid var(--line);border-radius:18px;background:#fff;padding:14px}.mobile-tramo h3{margin:0 0 8px}.audit-line{display:flex;gap:10px;align-items:flex-start;border-bottom:1px solid var(--line);padding:10px 0}.audit-line:last-child{border-bottom:0}.audit-dot{width:10px;height:10px;border-radius:999px;background:var(--primary);margin-top:5px;flex:0 0 10px}.soft-card{background:#f8fafc;border:1px solid var(--line);border-radius:18px;padding:14px}.copybox{width:100%;min-height:220px;border:1px solid var(--line);border-radius:14px;padding:12px;font-family:ui-monospace,Menlo,Consolas,monospace;background:#f8fafc}.year-badge{display:inline-flex;padding:6px 10px;border-radius:999px;background:#eef2ff;color:#3730a3;font-weight:800;margin:3px}.logo-box{width:56px;height:56px;border-radius:18px;background:#fff;border:1px solid var(--line);display:inline-flex;align-items:center;justify-content:center;font-size:28px}.nav{max-width:100%;overflow-x:auto}.print-title{display:none}@media print{.print-title{display:block}.app-header,.tools,.no-print,.nav,.flash{display:none!important}.card,.hero{box-shadow:none!important}.page{max-width:none!important;margin:0!important}.btn{display:none!important}}


/* Corrección visual V4.1 */
.page > .grid { align-items: start; }
.config-page-grid { align-items: start; }
.config-aside { display: flex; flex-direction: column; gap: 12px; }
.config-form-card { min-width: 0; }
.form-grid { display:grid; grid-template-columns: repeat(12, minmax(0, 1fr)); gap: 14px; align-items:end; }
.form-grid .field { min-width: 0; }
.form-grid input, .form-grid select { min-width: 0; }
.checkbox-card { display:flex; align-items:center; gap:10px; min-height:44px; padding:10px 12px; border:1px solid var(--line); border-radius:14px; background:#f8fafc; color:var(--text); font-size:13px; font-weight:900; }
.checkbox-card input { width:auto; min-height:auto; transform:scale(1.15); }
.config-preview { min-height: 210px; display:flex; flex-direction:column; justify-content:flex-end; }
.config-preview .logo-box { margin-bottom: 14px; color: var(--primary); }
.config-preview b { line-height: 1.05; max-width: 260px; }
.sidebar-note { line-height:1.35; }
@media(max-width:720px){
  .topbar{padding:14px 12px}.brand b{font-size:16px}.brand small{font-size:12px}.page{padding:16px 10px 35px}.hero{padding:16px;border-radius:20px}h1{font-size:24px}.card{padding:14px;border-radius:18px}.form-grid .span6,.form-grid .span3,.form-grid .span12{grid-column:span 12}.config-preview{min-height:auto}.config-preview b{font-size:24px}.nav a{font-size:12px;padding:8px 10px}
}

/* V4.2 - Ancho ampliado y layout más cómodo */
:root{--app-max-width:1560px;}
.wrap{max-width:var(--app-max-width)!important;width:100%;}
.page{padding:28px 24px 55px;}
.hero{padding:26px 28px;}
.card{padding:20px;}
.topbar{padding:18px 24px;}
.grid{gap:18px;}
.form-grid{gap:16px 18px;}
.searchbar{padding:16px;}
.table-wrap table{min-width:980px;}
.config-page-grid{grid-template-columns:repeat(12,minmax(0,1fr));}
.config-aside{grid-column:span 3;}
.config-form-card{grid-column:span 9;}
.config-preview{min-height:245px;}
.config-preview b{font-size:32px;max-width:320px;}
.nav a{white-space:nowrap;}
@media(max-width:1200px){
  :root{--app-max-width:1180px;}
  .config-aside,.config-form-card{grid-column:span 12;}
}
@media(max-width:720px){
  .page{padding:16px 10px 35px;}
  .topbar{padding:14px 12px;}
  .card{padding:14px;}
}

/* V5 - SaaS completo: menú lateral, ancho grande, móvil, PDF */
:root{--sidebar-width:290px;--app-max-width:1680px;--radius:22px;}
body.app-shell{padding-left:var(--sidebar-width);}
.wrap-fluid{max-width:var(--app-max-width);margin:0 auto;width:100%;}
.sidebar{position:fixed;inset:0 auto 0 0;width:var(--sidebar-width);background:linear-gradient(180deg,var(--primary),var(--primary2));color:#fff;padding:20px 16px;z-index:40;display:flex;flex-direction:column;gap:18px;box-shadow:14px 0 35px rgba(15,23,42,.16)}
.side-brand{color:#fff;text-decoration:none;display:flex;flex-direction:column;gap:6px;padding:8px 8px 16px;border-bottom:1px solid rgba(255,255,255,.18)}.side-brand span,.side-brand img{width:58px;height:58px;border-radius:18px;background:rgba(255,255,255,.15);display:inline-flex;align-items:center;justify-content:center;font-size:28px;border:1px solid rgba(255,255,255,.25);object-fit:cover}.side-brand strong{font-size:24px;line-height:1.05}.side-brand small{color:#dbeafe}.side-nav{display:flex;flex-direction:column;gap:8px;overflow:auto;padding-right:4px}.side-nav a{color:#eef6ff;text-decoration:none;font-weight:900;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.08);border-radius:15px;padding:12px 13px}.side-nav a:hover,.side-nav a.active{background:#fff;color:var(--primary);box-shadow:0 8px 20px rgba(15,23,42,.12)}.side-user{margin-top:auto;border-top:1px solid rgba(255,255,255,.18);padding-top:14px;display:grid;gap:6px}.side-user small{color:#dbeafe}.side-user a{color:#fff;font-weight:900;text-decoration:none;font-size:13px}.mobile-header{display:none}.page{padding:28px 28px 60px}.hero{border-radius:28px}.card{border-radius:22px}.dashboard-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:12px}.action-card{background:#fff;border:1px solid var(--line);border-radius:20px;padding:16px;text-decoration:none;color:var(--text);box-shadow:var(--shadow)}.action-card b{display:block;margin-bottom:5px}.action-card:hover{transform:translateY(-1px);border-color:#bfdbfe}.status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.mobile-current{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px}.mobile-worker{border:1px solid var(--line);border-radius:16px;background:#fff;padding:13px}.mobile-worker b{display:block;font-size:16px}.season-card{border:1px solid var(--line);border-radius:18px;padding:15px;background:#fff}.pdf-cover{display:none}.logo-preview{width:86px;height:86px;border-radius:22px;border:1px solid var(--line);background:#fff;object-fit:cover}.phone-link{font-weight:900;color:var(--primary);text-decoration:none}.form-grid .span4{grid-column:span 4}.form-grid .span2{grid-column:span 2}.form-grid .span1{grid-column:span 1}.empty-state{text-align:center;padding:35px;background:#f8fafc;border:1px dashed #cbd5e1;border-radius:20px;color:#475569}.super-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}.tenant-card{border:1px solid var(--line);border-radius:20px;background:#fff;padding:16px;box-shadow:var(--shadow)}
@media(max-width:1050px){body.app-shell{padding-left:0}.sidebar{transform:translateX(-105%);transition:.2s}.nav-open .sidebar{transform:translateX(0)}.mobile-header{display:flex;position:sticky;top:0;z-index:35;background:linear-gradient(135deg,var(--primary),var(--primary2));color:#fff;align-items:center;justify-content:space-between;padding:12px 14px;box-shadow:var(--shadow)}.mobile-header button{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.25)}.page{padding:16px 12px 45px}.form-grid .span6,.form-grid .span4,.form-grid .span3,.form-grid .span2,.form-grid .span1,.form-grid .span12{grid-column:span 12}.sidebar{width:300px}}
@media print{body.app-shell{padding-left:0}.sidebar,.mobile-header,.no-print,.side-nav,.side-user,.cell-actions,form{display:none!important}.page{padding:0}.wrap-fluid{max-width:none}.pdf-cover{display:block;text-align:center;padding:30mm 10mm 18mm;page-break-after:always}.pdf-cover h1{font-size:34px}.relay-title{background:#172033!important;color:#fff!important}.relay-card{page-break-after:always}.relay-card:last-child{page-break-after:auto}.table-wrap table{min-width:0!important}.whatsapp-box{display:none!important}}

/* V5.1 WhatsApp y mejoras rápidas */
.whatsapp-btn{background:#16a34a!important;color:#fff!important;border-color:#16a34a!important}
.whatsapp-btn:hover{filter:brightness(.95)}
.whatsapp-box{white-space:pre-wrap;background:#f8fafc;border:1px solid #dbe5f1;border-radius:16px;padding:14px;margin:10px 0;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:13px;line-height:1.5;max-height:320px;overflow:auto}
.relay-title .tools{align-items:center}
@media(max-width:780px){.relay-title{align-items:flex-start;gap:10px}.relay-title .tools{width:100%;display:grid;grid-template-columns:1fr;gap:8px}.relay-title .tools .btn,.relay-title .tools button{width:100%;text-align:center}.table-wrap{overflow:auto}.cell-actions form{display:grid;gap:6px}}

.field-help{display:block;margin-top:4px;color:var(--muted);font-size:11px;line-height:1.35}.relay-card th:not(:first-child){text-align:center;white-space:nowrap}.relay-card td:not(:first-child){min-width:150px}.mobile-worker .pill{white-space:normal}.notice b{font-weight:950}
.puesto-chip{display:inline-flex;align-items:center;justify-content:center;width:max-content;max-width:100%;padding:3px 8px;margin-bottom:6px;border-radius:999px;background:#f1f5f9;color:#475569;font-size:11px;font-weight:900;line-height:1.1}
.cell-person{display:flex;flex-direction:column;gap:5px;align-items:flex-start}

/* V5.4 - Limpieza visual solicitada */
.dashboard-actions-clean{grid-template-columns:repeat(2,minmax(260px,1fr));max-width:780px}
.dashboard-actions-clean .action-main{min-height:92px;padding:22px;border-radius:24px;border-color:#c7d7ee;background:linear-gradient(135deg,#fff,#f7fbff)}
.dashboard-actions-clean .action-main b{font-size:18px}.dashboard-actions-clean .action-main span{font-size:13px}
.trab-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:10px}.trab-summary-item{border:1px solid var(--line);background:#f8fafc;border-radius:16px;padding:13px}.trab-summary-item b{display:block;font-size:15px}.trab-summary-item span{display:block;color:var(--muted);font-size:13px;margin-top:3px}.trab-summary-item em{display:inline-flex;margin-top:8px;background:#dcfce7;color:#166534;border-radius:999px;padding:4px 8px;font-size:12px;font-style:normal;font-weight:900}
.ensayo-list{display:grid;gap:10px}.ensayo-list-item{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid var(--line);background:#f8fafc;border-radius:16px;padding:12px;text-decoration:none;color:var(--text)}.ensayo-list-item:hover{border-color:#bfdbfe;background:#fff}.ensayo-list-item b{display:block}.ensayo-list-item small{display:block;color:var(--muted);margin-top:3px}.audit-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:8px}.empty-state.compact{padding:16px}
.person-form-card{padding:0;overflow:hidden}.form-title-row{padding:22px 24px;border-bottom:1px solid var(--line);background:linear-gradient(135deg,#fff,#f8fbff)}.person-form{padding:20px 24px 24px;display:grid;gap:18px}.form-section{border:1px solid var(--line);border-radius:18px;background:#fff;padding:18px}.form-section h3{margin:0 0 14px;font-size:17px}.person-switches{display:flex;gap:12px;flex-wrap:wrap}.switch-card{display:flex;align-items:center;gap:10px;border:1px solid var(--line);background:#f8fafc;border-radius:16px;padding:12px 14px;min-width:210px;color:var(--text)}.switch-card input{width:22px;height:22px;min-height:22px;accent-color:var(--primary)}.switch-card span{font-weight:950}.switch-card small{display:block;color:var(--muted);font-size:11px}.form-actions{display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap;padding-top:2px}
.mobile-current{grid-template-columns:repeat(5,minmax(0,1fr));align-items:stretch}.mobile-worker{min-height:92px}.mobile-worker .pill{font-size:11px}.mobile-worker b{line-height:1.15}.page .notice:empty{display:none}.table-wrap table{min-width:unset}.card .table-wrap{border-radius:16px}
@media(max-width:1350px){.mobile-current{grid-template-columns:repeat(4,minmax(0,1fr))}}
@media(max-width:1050px){.mobile-current{grid-template-columns:repeat(3,minmax(0,1fr))}.dashboard-actions-clean{grid-template-columns:1fr;max-width:none}}
@media(max-width:720px){.mobile-current{grid-template-columns:repeat(2,minmax(0,1fr))}.person-form{padding:14px}.form-title-row{padding:16px}.form-section{padding:14px}.person-switches{display:grid}.form-actions{justify-content:stretch}.form-actions .btn,.form-actions button{width:100%}}
@media(max-width:460px){.mobile-current{grid-template-columns:1fr}}


/* V5.6 - Calles por tramo e informe de participación */
.route-form{display:grid;grid-template-columns:1fr 1fr auto;gap:12px;align-items:end;background:#f8fafc;border:1px solid var(--line);border-radius:18px;padding:14px;margin-bottom:14px}.relay-route-print{display:block;margin-top:6px;font-size:13px;font-weight:800;color:#dbeafe}.participation-report table th:nth-child(4),.participation-report table th:nth-child(5),.participation-report table th:nth-child(6),.participation-report table td:nth-child(4),.participation-report table td:nth-child(5),.participation-report table td:nth-child(6){text-align:center}.participation-report .pill{min-width:38px;justify-content:center}.relay-title>div:first-child{display:flex;flex-direction:column;gap:2px}
@media(max-width:780px){.route-form{grid-template-columns:1fr}.route-form button{width:100%}}
@media print{.route-form{display:none!important}.relay-route-print{display:block!important;color:#fff!important}.participation-report{page-break-before:always}.participation-report .table-wrap table{font-size:11px}.participation-report .card{box-shadow:none!important}}

/* V5.11 - Informe de participación visual */
.participation-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin:18px 0 20px}.participation-kpi{border:1px solid var(--line);border-radius:20px;background:linear-gradient(135deg,#fff,#f8fafc);padding:16px;display:grid;gap:7px;box-shadow:0 8px 18px rgba(15,23,42,.05)}.participation-kpi div{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}.participation-kpi b{font-size:17px}.participation-kpi div span{color:var(--muted);font-size:12px;text-align:right}.participation-kpi strong{font-size:34px;line-height:1;color:var(--primary)}.participation-kpi small{color:var(--muted);font-weight:800}.participation-kpi em{font-style:normal;font-size:12px;font-weight:900;border-radius:999px;padding:5px 9px;width:max-content}.participation-kpi.good em{background:#dcfce7;color:#166534}.participation-kpi.warn em{background:#fef3c7;color:#92400e}.participation-kpi.bad em{background:#fee2e2;color:#991b1b}.participation-groups{display:grid;gap:18px}.participation-group{border:1px solid var(--line);border-radius:22px;background:#fff;overflow:hidden}.participation-group-title{display:flex;justify-content:space-between;gap:10px;align-items:center;background:#f8fafc;border-bottom:1px solid var(--line);padding:14px 16px}.participation-group-title h3{margin:0;font-size:18px}.participation-group-title span{font-size:13px;color:var(--muted);font-weight:900}.participation-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px;padding:14px}.person-part-card{border:1px solid #e2e8f0;border-radius:18px;background:#fff;padding:14px;display:grid;gap:11px;box-shadow:0 6px 14px rgba(15,23,42,.04);position:relative;overflow:hidden}.person-part-card:before{content:"";position:absolute;inset:0 auto 0 0;width:5px;background:#cbd5e1}.person-part-card.state-ok:before{background:#22c55e}.person-part-card.state-bajo:before{background:#f59e0b}.person-part-card.state-alto:before{background:#ef4444}.person-part-card.state-no-viene{opacity:.72;background:#f8fafc}.person-part-head{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}.person-part-head b{display:block;font-size:15px;line-height:1.15}.person-part-head span{display:block;color:var(--muted);font-size:12px;margin-top:3px}.person-part-head strong{font-size:34px;line-height:1;color:var(--primary)}.part-bar{height:10px;background:#edf2f7;border-radius:999px;overflow:hidden}.part-bar span{display:block;height:100%;background:linear-gradient(90deg,var(--primary),#60a5fa);border-radius:999px}.part-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.part-metrics span{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:8px;text-align:center;color:var(--muted);font-size:12px}.part-metrics b{display:block;color:var(--text);font-size:16px}.part-status{display:flex;justify-content:flex-end}.participation-detail{margin-top:18px}.participation-detail summary{cursor:pointer;font-weight:950;background:#f8fafc;border:1px solid var(--line);border-radius:14px;padding:12px 14px;color:var(--primary)}.participation-detail .table-wrap{margin-top:12px}
@media(max-width:700px){.participation-group-title{align-items:flex-start;flex-direction:column}.participation-cards{grid-template-columns:1fr}.part-metrics{grid-template-columns:1fr 1fr 1fr}.participation-kpi div{display:block}.participation-kpi div span{text-align:left;display:block;margin-top:3px}}
@media print{.participation-summary,.participation-groups{display:block}.participation-kpi,.participation-group,.person-part-card{break-inside:avoid;box-shadow:none!important}.participation-kpi{margin-bottom:8px}.participation-group{margin-bottom:12px}.participation-cards{grid-template-columns:repeat(3,1fr)!important}.participation-detail{display:none!important}}


/* V5.12 - mejoras relevos / calles */
.route-planner{border:1px solid #dbe7ff;background:linear-gradient(180deg,#ffffff,#f7fbff)}
.inline-generate{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.routes-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px;margin-top:14px}
.route-mini-card{border:1px solid #dde7f3;background:#fff;border-radius:16px;padding:12px;display:flex;flex-direction:column;gap:8px;box-shadow:0 8px 18px rgba(15,23,42,.04)}
.route-mini-card b{font-size:13px;color:#172033}
.route-mini-card input{width:100%;min-height:38px;border-radius:11px}
.routes-actions{grid-column:1/-1;display:flex;justify-content:flex-end;margin-top:2px}
.relay-route-print{display:block;margin-top:6px;font-size:13px;color:#dbeafe;font-weight:700}
.route-form{background:#f8fbff;border:1px dashed #c7d7ee;border-radius:14px;padding:10px;margin-bottom:12px}
.participation-report{margin-top:8px}
@media(max-width:700px){.inline-generate,.routes-actions{justify-content:stretch}.inline-generate>*{width:100%}.routes-actions button{width:100%}}
@media print{.route-planner{display:none!important}.relay-route-print{color:#111827!important;background:#eef4ff!important;border:1px solid #c7d7ee!important;border-radius:999px!important;padding:4px 10px!important;display:inline-block!important}}

/* V5.13 · Capataz de cola y PDF limpio */
.pill.capataz{background:#fef3c7;color:#92400e;border:1px solid #fde68a}
.capataz-switch{border-color:#fde68a!important;background:#fffbeb!important}
.capataz-name{display:inline-flex!important;align-items:center;gap:6px;flex-wrap:wrap;color:#92400e!important}
.capataz-mark{display:inline-flex;align-items:center;border-radius:999px;padding:2px 7px;background:#fef3c7;color:#92400e;border:1px solid #fde68a;font-size:10px;font-weight:950;text-transform:uppercase;letter-spacing:.03em}
.relay-card .capataz-name:before{content:'⭐';font-size:13px;line-height:1}
@media print{
  .no-print-info,.puesto-chip,.manual,.pill.manual,.cell-person .small{display:none!important}
  .cell-person{align-items:center;text-align:center;gap:2px!important}
  .cell-person b{font-size:14px!important;line-height:1.15!important;color:#111827!important}
  .cell-person .capataz-name{color:#92400e!important;font-weight:950!important}
  .capataz-mark{font-size:9px!important;padding:1px 5px!important;background:#fef3c7!important;color:#92400e!important;border:1px solid #fde68a!important}
  .participation-report .muted,
  .participation-kpi small,
  .participation-kpi em,
  .participation-group-title span,
  .part-status,
  .part-metrics span:nth-child(2),
  .part-metrics span:nth-child(3){display:none!important}
  .person-part-card{padding:8px!important;gap:5px!important}
  .person-part-head span,.part-bars{display:none!important}
  .part-metrics{display:block!important}
  .part-metrics span{border:0!important;background:transparent!important;padding:0!important}
  .part-metrics span:first-child{display:block!important;font-size:11px!important;color:#111827!important}
}


/* V5.14 - PDF solo relevos y mejoras de pantalla */
.relay-overview{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px;margin-top:-6px}
.relay-overview div{background:#fff;border:1px solid var(--line);border-radius:18px;padding:14px 16px;box-shadow:0 8px 18px rgba(15,23,42,.05)}
.relay-overview b{display:block;font-size:26px;line-height:1;color:var(--primary)}
.relay-overview span{display:block;margin-top:3px;color:var(--muted);font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.04em}
.relay-overview div.ok b{color:#166534}.relay-overview div.warn b{color:#b45309}
.relay-card{border:1px solid #dce7f3;box-shadow:0 10px 24px rgba(15,23,42,.06)}
.relay-card .table-wrap table th{text-align:center}.relay-card .table-wrap table td{text-align:center;vertical-align:top}
.cell-person{min-height:94px;justify-content:center}.cell-actions{margin-top:8px}.whatsapp-btn{background:#16a34a!important}.participation-report{border-style:dashed}
@media(max-width:1100px){.relay-overview{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(max-width:650px){.relay-overview{grid-template-columns:1fr 1fr}.relay-overview div:last-child{grid-column:1/-1}}
@media print{
  .participation-report{display:none!important}
  .relay-overview{display:none!important}
  .pdf-cover{display:block!important}
  .relay-card{break-after:page;page-break-after:always;border:none!important;box-shadow:none!important}
  .relay-card:last-of-type{break-after:auto;page-break-after:auto}
}

/* V5.17 - Asistencia mejorada */
.asistencia-page .hero{position:relative;overflow:hidden}
.asistencia-page .hero:after{content:"";position:absolute;right:-80px;top:-80px;width:220px;height:220px;border-radius:999px;background:rgba(31,79,143,.08)}
.asistencia-kpi-card.si .kpi{border-color:#bbf7d0;background:linear-gradient(135deg,#fff,#f0fdf4)}
.asistencia-kpi-card.tarde .kpi{border-color:#fde68a;background:linear-gradient(135deg,#fff,#fffbeb)}
.asistencia-kpi-card.no .kpi{border-color:#fecaca;background:linear-gradient(135deg,#fff,#fef2f2)}
.asistencia-toolbar{position:sticky;top:82px;z-index:12}
.asistencia-filters{display:grid;grid-template-columns:1fr 220px 190px;gap:12px;margin-top:14px;align-items:end}
.asistencia-groups{display:grid;gap:18px}
.asistencia-group{border:1px solid var(--line);border-radius:24px;background:#fff;box-shadow:var(--shadow);overflow:hidden}
.asistencia-group-head{display:flex;justify-content:space-between;gap:14px;align-items:center;padding:16px 18px;background:linear-gradient(135deg,#f8fafc,#eef4ff);border-bottom:1px solid var(--line)}
.asistencia-group-head h3{margin:0;font-size:19px}.asistencia-group-head span{color:var(--muted);font-size:13px;font-weight:800}.asistencia-group-stats{display:flex;gap:7px;flex-wrap:wrap;justify-content:flex-end}
.asistencia-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:12px;padding:14px}
.att-card{border:1px solid #e2e8f0;border-radius:20px;background:#fff;padding:14px;display:grid;gap:12px;position:relative;overflow:hidden;box-shadow:0 8px 18px rgba(15,23,42,.045)}
.att-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:#cbd5e1}.att-card.state-si:before{background:#22c55e}.att-card.state-tarde:before{background:#f59e0b}.att-card.state-no:before{background:#ef4444}
.att-card.state-si{background:linear-gradient(135deg,#fff,#f9fffb)}.att-card.state-tarde{background:linear-gradient(135deg,#fff,#fffdf4)}.att-card.state-no{background:linear-gradient(135deg,#fff,#fff8f8)}
.att-card-top{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}.att-card-top b{display:block;font-size:15px;line-height:1.15}.att-card-top span{display:block;margin-top:4px;color:var(--muted);font-size:12px;font-weight:800}.att-card-top em{font-style:normal;border-radius:999px;padding:5px 9px;font-size:11px;font-weight:950;white-space:nowrap;background:#eef2ff;color:#3730a3}.state-si .att-card-top em{background:#dcfce7;color:#166534}.state-tarde .att-card-top em{background:#fef3c7;color:#92400e}.state-no .att-card-top em{background:#fee2e2;color:#991b1b}
.att-actions{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}.att-actions button{min-height:36px;padding:8px 10px;border-radius:12px;font-size:12px}.att-late{display:none;border:1px dashed #fbbf24;background:#fffbeb;border-radius:14px;padding:10px}.att-late.open{display:block}.att-late label,.att-comment label{display:block;margin-bottom:5px}.att-comment input{min-height:38px;border-radius:12px}.attendance-sticky-save{position:sticky;bottom:16px;margin-top:18px;background:#172033;color:#fff;border:1px solid rgba(255,255,255,.12);box-shadow:0 18px 45px rgba(15,23,42,.22);border-radius:20px;padding:13px 14px;display:flex;justify-content:space-between;gap:12px;align-items:center;z-index:18}.attendance-sticky-save b{display:block}.attendance-sticky-save span{display:block;color:#dbeafe;font-size:12px;margin-top:2px}.attendance-sticky-save button{background:#fff;color:var(--primary)}
@media(max-width:900px){.asistencia-toolbar{position:static}.asistencia-filters{grid-template-columns:1fr}.asistencia-group-head{align-items:flex-start;flex-direction:column}.asistencia-group-stats{justify-content:flex-start}.attendance-sticky-save{align-items:stretch;flex-direction:column}.attendance-sticky-save button{width:100%}}
@media(max-width:520px){.asistencia-cards{grid-template-columns:1fr;padding:10px}.att-actions{grid-template-columns:1fr}.att-card-top{flex-direction:column}.asistencia-group-head{padding:14px}.attendance-sticky-save{bottom:8px}}
@media print{.asistencia-toolbar,.att-actions,.att-late,.attendance-sticky-save{display:none!important}.asistencia-cards{grid-template-columns:repeat(3,1fr)!important}.att-card{box-shadow:none!important;break-inside:avoid}.asistencia-group{box-shadow:none!important;break-inside:avoid;margin-bottom:12px}.att-comment input{border:0!important;padding:0!important;min-height:auto!important}.att-comment label{display:none!important}}
/* V5.19 ajustes asistencia y WhatsApp */
.sticky-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.sticky-actions button:first-child{background:#e9eef7!important;color:#193454!important}
.sticky-actions button:last-child{background:var(--primary)!important;color:#fff!important}
@media(max-width:760px){.sticky-actions{display:grid;grid-template-columns:1fr}.sticky-actions button{width:100%}}
.whatsapp-box{line-height:1.45}

/* V5.21 - Panel principal mejorado */
.dashboard-v2{gap:18px}.dashboard-hero{padding:26px}.dashboard-hero-main{display:flex;justify-content:space-between;gap:18px;align-items:center;flex-wrap:wrap}.eyebrow{display:inline-flex;border-radius:999px;background:#eef4ff;color:var(--primary);font-weight:950;font-size:12px;padding:6px 10px;margin-bottom:8px;text-transform:uppercase;letter-spacing:.04em}.hero-actions{display:flex;gap:10px;flex-wrap:wrap}.dash-card{background:#fff;border:1px solid var(--line);border-radius:22px;padding:18px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:4px;min-height:132px}.dash-card.primary{background:linear-gradient(135deg,var(--primary),var(--primary2));color:#fff}.dash-card.primary small,.dash-card.primary span{color:#dbeafe}.dash-card span{font-size:12px;font-weight:950;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.dash-card b{font-size:36px;line-height:1}.dash-card small{color:var(--muted);font-size:12px;line-height:1.35}.dashboard-section{padding:20px}.trab-visual-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;margin-top:14px}.trab-visual-card{display:block;text-decoration:none;color:inherit;border:1px solid #dbe4f0;border-radius:18px;background:linear-gradient(180deg,#fff,#f8fbff);padding:13px;transition:.16s ease}.trab-visual-card:hover{transform:translateY(-2px);box-shadow:0 12px 24px rgba(15,23,42,.09)}.trab-visual-top{display:flex;justify-content:space-between;gap:10px;align-items:center}.trab-visual-top b{font-size:15px}.trab-visual-top span{width:34px;height:34px;border-radius:12px;background:#eef4ff;color:var(--primary);display:inline-flex;align-items:center;justify-content:center;font-weight:950}.progress{height:8px;background:#e6edf7;border-radius:999px;overflow:hidden;margin:10px 0}.progress i{display:block;height:100%;background:linear-gradient(90deg,var(--primary),#7c5cf0);border-radius:999px}.quick-stack{display:grid;gap:10px;margin-top:12px}.quick-stack a{display:block;text-decoration:none;color:inherit;border:1px solid #dbe4f0;border-radius:17px;padding:14px;background:#f8fbff}.quick-stack a:hover{background:#eef4ff}.quick-stack b{display:block}.quick-stack span{display:block;color:var(--muted);font-size:12px;margin-top:3px}.ensayo-timeline{display:grid;gap:10px;margin-top:12px}.timeline-item{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center;text-decoration:none;color:inherit;border:1px solid #dbe4f0;border-radius:17px;padding:13px;background:#fff}.timeline-item:hover{background:#f8fbff}.timeline-dot{width:12px;height:12px;border-radius:999px;background:#f59e0b}.timeline-dot.generado{background:#22c55e}.timeline-dot.cerrado{background:#64748b}.timeline-item small{display:block;color:var(--muted);margin-top:3px}.timeline-item em{font-style:normal;font-weight:900;color:var(--primary);font-size:12px}.prep-box{display:flex;gap:16px;align-items:center;margin-top:12px}.prep-ring{--size:110px;width:var(--size);height:var(--size);border-radius:999px;background:conic-gradient(var(--primary) calc(var(--p)*1%),#e6edf7 0);display:grid;place-items:center;flex:0 0 auto;position:relative}.prep-ring:after{content:"";position:absolute;inset:10px;background:#fff;border-radius:999px}.prep-ring b,.prep-ring span{position:relative;z-index:1;display:block;text-align:center}.prep-ring b{font-size:23px}.prep-ring span{font-size:10px;color:var(--muted);font-weight:900;text-transform:uppercase}.prep-box p{margin:0;color:var(--muted);line-height:1.45}.mini-activity{border-top:1px solid var(--line);margin-top:15px;padding-top:12px;display:grid;gap:5px}.mini-activity b{font-size:13px}.mini-activity span{font-size:12px;color:var(--muted)}.big-notice{display:flex;justify-content:space-between;gap:12px;align-items:center;flex-wrap:wrap}
@media(max-width:900px){.dashboard-hero-main{align-items:flex-start}.hero-actions,.hero-actions a{width:100%}.prep-box{align-items:flex-start;flex-direction:column}.dash-card{min-height:auto}.dash-card b{font-size:30px}}

/* V5.21 - Vista móvil mejorada */
.mobile-page{gap:16px}.mobile-hero{padding:20px}.mobile-stage-card{background:linear-gradient(135deg,var(--primary),var(--primary2));color:#fff;border-radius:26px;padding:18px;box-shadow:0 16px 35px rgba(15,23,42,.18)}.mobile-stage-main{display:flex;justify-content:space-between;gap:18px;align-items:center}.mobile-stage-label{display:inline-flex;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.25);padding:5px 9px;border-radius:999px;font-size:11px;font-weight:950;text-transform:uppercase;letter-spacing:.04em}.mobile-stage-card h2{margin:8px 0 4px}.mobile-stage-card p{margin:0;color:#dbeafe}.mobile-stage-number{width:112px;min-height:112px;background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.24);border-radius:24px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;text-align:center}.mobile-stage-number span{font-size:11px;font-weight:950;text-transform:uppercase;color:#dbeafe}.mobile-stage-number b{font-size:42px;line-height:1}.mobile-stage-number em{font-style:normal;font-size:12px;color:#fff;font-weight:900}.mobile-route-current{margin-top:14px;border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.1);border-radius:18px;padding:13px}.mobile-route-current span{display:block;font-size:11px;font-weight:950;text-transform:uppercase;color:#dbeafe}.mobile-route-current b{display:block;margin-top:4px;font-size:18px}.mobile-stage-actions{display:grid;grid-template-columns:1fr auto 1fr;gap:10px;margin-top:14px}.mobile-stage-actions .btn{text-align:center}.disabled-link{opacity:.42;pointer-events:none}.mobile-tramo-nav{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:9px}.mobile-tramo-pill{display:flex;gap:10px;align-items:center;text-decoration:none;color:inherit;border:1px solid #dbe4f0;border-radius:16px;background:#fff;padding:10px;min-height:66px;box-shadow:0 6px 16px rgba(15,23,42,.04)}.mobile-tramo-pill b{width:38px;height:38px;border-radius:13px;background:#eef4ff;color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:18px}.mobile-tramo-pill span{font-size:11px;line-height:1.2;color:var(--muted);font-weight:800}.mobile-tramo-pill.active{border-color:var(--primary);background:#f6f9ff}.mobile-tramo-pill.active b{background:var(--primary);color:#fff}.mobile-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.mobile-kpis div{background:#fff;border:1px solid var(--line);border-radius:17px;padding:12px;box-shadow:0 8px 18px rgba(15,23,42,.04)}.mobile-kpis b{display:block;font-size:25px;line-height:1}.mobile-kpis span{display:block;color:var(--muted);font-size:11px;font-weight:950;text-transform:uppercase;margin-top:4px}.mobile-kpis .ok b{color:#166534}.mobile-kpis .warn b{color:#b45309}.mobile-current.mobile-current-dynamic{display:grid;grid-template-columns:1fr;gap:14px}.mobile-trab-block{background:#fff;border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow);overflow:hidden}.mobile-trab-head{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:13px 15px;background:linear-gradient(135deg,#f8fafc,#eef4ff);border-bottom:1px solid var(--line)}.mobile-trab-head h3{margin:0}.mobile-trab-head span{font-size:12px;color:var(--muted);font-weight:900}.mobile-slots-grid{display:grid;grid-template-columns:repeat(var(--mobile-cols),minmax(0,1fr));gap:10px;padding:12px}.mobile-worker{border:1px solid #dbe4f0;border-radius:17px;padding:12px;background:#fff;display:grid;gap:6px;min-height:118px}.mobile-worker.pending{background:#fff7ed;border-color:#fed7aa}.mobile-worker.cola{background:#fffbeb;border-color:#fde68a}.mobile-worker b{font-size:15px;line-height:1.15}.mobile-worker b small{font-size:11px;color:#92400e}.phone-link{font-size:12px;font-weight:900;color:var(--primary);text-decoration:none}.whatsapp-btn{background:#16a34a!important;color:#fff!important}
@media(max-width:1100px){.mobile-slots-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.mobile-stage-actions{grid-template-columns:1fr}.mobile-kpis{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.mobile-stage-main{align-items:flex-start;flex-direction:column}.mobile-stage-number{width:100%;min-height:auto;padding:14px}.mobile-tramo-nav{grid-template-columns:1fr 1fr}.mobile-slots-grid{grid-template-columns:1fr}.mobile-kpis{grid-template-columns:1fr 1fr}.mobile-route-current b{font-size:15px}}

/* V5.22 - PDF de relevos optimizado: una página por tramo */
.pdf-cover{display:none}
@media print{
  @page{size:A4 landscape;margin:7mm}
  html,body{width:auto!important;height:auto!important;background:#fff!important;color:#111827!important;font-family:Arial,Helvetica,sans-serif!important}
  body.app-shell{padding-left:0!important}
  .sidebar,.mobile-header,.app-header,.hero,.route-planner,.relay-overview,.participation-report,.no-print,.tools,.flash,.searchbar,.step-tabs,.cell-actions,form,.whatsapp-box,.pdf-cover{display:none!important}
  .page{padding:0!important;margin:0!important;background:#fff!important}
  .wrap-fluid,.wrap{max-width:none!important;width:100%!important;margin:0!important;padding:0!important}
  .grid{display:block!important;width:100%!important;margin:0!important;padding:0!important;gap:0!important}
  .span12{display:block!important;width:100%!important;margin:0!important;padding:0!important}

  .relay-card{
    display:block!important;
    width:100%!important;
    height:194mm!important;
    max-height:194mm!important;
    overflow:hidden!important;
    margin:0!important;
    padding:0!important;
    border:0!important;
    box-shadow:none!important;
    background:#fff!important;
    break-after:page!important;
    page-break-after:always!important;
    break-inside:avoid!important;
    page-break-inside:avoid!important;
  }
  .relay-card:last-of-type{break-after:auto!important;page-break-after:auto!important}

  .relay-title{
    display:flex!important;
    align-items:center!important;
    justify-content:space-between!important;
    gap:8mm!important;
    background:#172033!important;
    color:#fff!important;
    border-radius:8px!important;
    padding:4mm 6mm!important;
    margin:0 0 4mm!important;
    min-height:17mm!important;
  }
  .relay-title b{font-size:17pt!important;line-height:1.1!important;letter-spacing:.01em!important}
  .relay-route-print{
    display:inline-block!important;
    margin-top:2mm!important;
    padding:1.5mm 4mm!important;
    border-radius:999px!important;
    background:#eef4ff!important;
    border:1px solid #c7d7ee!important;
    color:#111827!important;
    font-size:10.5pt!important;
    font-weight:800!important;
    line-height:1.15!important;
    max-width:240mm!important;
    white-space:normal!important;
  }

  .relay-body{padding:0!important;border:0!important;background:#fff!important}
  .table-wrap{overflow:visible!important;width:100%!important;border:0!important}
  .table-wrap table{
    width:100%!important;
    min-width:0!important;
    table-layout:fixed!important;
    border-collapse:separate!important;
    border-spacing:0!important;
    border:1px solid #cfd8e6!important;
    border-radius:10px!important;
    overflow:hidden!important;
    background:#fff!important;
  }
  .relay-card table th,
  .relay-card table td{
    border-bottom:1px solid #dbe3ef!important;
    border-right:1px solid #e3eaf3!important;
    text-align:center!important;
    vertical-align:middle!important;
    padding:0!important;
    color:#111827!important;
  }
  .relay-card table th:last-child,
  .relay-card table td:last-child{border-right:0!important}
  .relay-card table tr:last-child td{border-bottom:0!important}
  .relay-card table th{
    height:10mm!important;
    background:#eef4ff!important;
    font-size:8.8pt!important;
    font-weight:950!important;
    text-transform:uppercase!important;
    letter-spacing:.04em!important;
    color:#334155!important;
    padding:1.5mm!important;
  }
  .relay-card table th:first-child{width:32mm!important;background:#172033!important;color:#fff!important}
  .relay-card table td:first-child{
    width:32mm!important;
    background:#f8fafc!important;
    color:#111827!important;
    font-size:10.5pt!important;
    font-weight:950!important;
    padding:2mm!important;
  }
  .relay-card table td{
    height:25mm!important;
    max-height:25mm!important;
    font-size:10.7pt!important;
    font-weight:900!important;
  }
  .cell-person{
    min-height:0!important;
    height:25mm!important;
    display:flex!important;
    align-items:center!important;
    justify-content:center!important;
    text-align:center!important;
    gap:1mm!important;
    padding:1.5mm!important;
  }
  .cell-person b{
    display:block!important;
    max-width:100%!important;
    font-size:10.8pt!important;
    line-height:1.12!important;
    font-weight:950!important;
    color:#111827!important;
    word-break:normal!important;
    overflow-wrap:anywhere!important;
  }
  .puesto-chip,.no-print-info,.manual,.pill.manual,.cell-person .small{display:none!important}
  .relay-card .capataz-name:before{content:''!important}
  .cell-person .capataz-name{color:#8a4b08!important;font-weight:950!important}
  .capataz-mark{
    display:inline-flex!important;
    margin-left:1.5mm!important;
    padding:.5mm 2mm!important;
    border-radius:999px!important;
    background:#fff7ed!important;
    border:1px solid #f3c473!important;
    color:#8a4b08!important;
    font-size:7.2pt!important;
    font-weight:950!important;
    line-height:1!important;
    vertical-align:middle!important;
    white-space:nowrap!important;
  }
}


/* V5.23 - PDF limpio: imprimir solo tramos */
@media print{
  .pdf-cover, .participation-report, .hero, .route-planner, .relay-overview, .print-title{display:none!important;}
  .grid{display:block!important;}
  .relay-card{display:block!important;break-after:page!important;page-break-after:always!important;break-inside:avoid!important;page-break-inside:avoid!important;margin:0!important;padding:0!important;}
  .relay-card:last-of-type{break-after:auto!important;page-break-after:auto!important;}
}

/* V5.24 */
.slot-map-card{border:1px solid #bfdbfe;background:#eff6ff;border-radius:18px;padding:14px;margin-top:4px}
.slot-map-card h3{margin:0 0 6px;color:#1e3a8a}
.slot-map-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:12px}
.slot-map-grid>div{background:white;border:1px solid #dbeafe;border-radius:16px;padding:12px;display:flex;flex-direction:column;gap:7px}
.slot-map-grid b{color:#172033;margin-bottom:4px}
.slot-map-grid span{display:flex;align-items:center;gap:8px;border-radius:12px;background:#f8fafc;border:1px solid #e2e8f0;padding:7px 9px;font-weight:800;color:#334155}
.security-note{margin-top:12px;border:1px solid #dbeafe;background:#eff6ff;color:#1e3a8a;border-radius:14px;padding:10px;font-size:12px;line-height:1.35}
@media(max-width:800px){.slot-map-grid{grid-template-columns:1fr}}


/* V5.25 - mapa de puestos editable */
.slot-map-grid.editable label{display:grid;grid-template-columns:42px 1fr;gap:8px;align-items:center;margin:0}
.slot-map-grid.editable label span{justify-content:center;margin:0;padding:9px 6px;font-weight:950;color:#1e3a8a;background:#eff6ff;border-color:#bfdbfe}
.slot-map-grid.editable input{width:100%;min-height:38px;border:1px solid #d7e2f0;border-radius:12px;padding:9px 10px;font-weight:800;color:#172033;background:#fff}
.slot-map-grid.editable input:focus{outline:2px solid #bfdbfe;border-color:#93c5fd}

/* V5.26 - Configuración más usable */
.config-v2{align-items:start}
.config-hero{background:linear-gradient(135deg,#ffffff,#f7fbff)}
.config-panel-preview{display:grid;gap:16px;align-content:start;position:sticky;top:24px}
.config-preview-card,.config-help-card{background:#fff;border:1px solid var(--line);border-radius:26px;padding:22px;box-shadow:0 14px 30px rgba(15,23,42,.07)}
.preview-logo-wrap{display:flex;align-items:center;margin-bottom:14px}
.logo-preview.big,.logo-box.big{width:92px;height:92px;border-radius:26px;font-size:42px;display:inline-flex;align-items:center;justify-content:center;object-fit:cover;background:linear-gradient(135deg,var(--primary),#7c3aed);color:#fff;border:1px solid rgba(255,255,255,.3);box-shadow:0 12px 25px rgba(15,23,42,.14)}
.config-preview-card .eyebrow{display:inline-flex;width:max-content;border-radius:999px;background:#eef4ff;color:var(--primary);font-size:11px;font-weight:950;letter-spacing:.06em;text-transform:uppercase;padding:5px 9px;margin-bottom:8px}
.config-preview-card h2{font-size:30px;line-height:1.05;margin:0 0 8px}
.config-preview-card p{margin:0;color:var(--muted);font-weight:800}
.config-mini-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:18px}
.config-mini-grid div{border:1px solid #dbe7f5;background:#f8fbff;border-radius:17px;padding:13px}
.config-mini-grid b{display:block;font-size:24px;color:var(--primary);line-height:1}
.config-mini-grid span{display:block;margin-top:6px;color:#64748b;font-size:11px;font-weight:950;text-transform:uppercase;letter-spacing:.04em}
.config-help-card h3{margin:0 0 10px;font-size:18px}
.config-help-card p{margin:10px 0 0;color:#475569;font-size:14px;line-height:1.45}
.config-form-v2{display:grid;gap:16px}
.settings-section{background:#fff;border:1px solid var(--line);border-radius:26px;padding:22px;box-shadow:0 14px 30px rgba(15,23,42,.06)}
.settings-section-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;border-bottom:1px solid #e6edf6;padding-bottom:15px;margin-bottom:18px}
.settings-section-head>div{display:flex;align-items:center;gap:10px}.settings-section-head h2{margin:0;font-size:20px}.settings-section-head p{max-width:460px;margin:0;color:var(--muted);font-size:13px;line-height:1.4;text-align:right;font-weight:700}
.section-num{width:34px;height:34px;border-radius:12px;background:linear-gradient(135deg,var(--primary),#7c3aed);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:950;box-shadow:0 8px 16px rgba(15,23,42,.12)}
.form-grid.compact{gap:14px}.form-grid.compact input,.form-grid.compact select{width:100%}
.slots-editor-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.slots-editor-card{border:1px solid #dbe7f5;background:linear-gradient(180deg,#fff,#fbfdff);border-radius:22px;padding:18px}.slots-editor-card h3{margin:0 0 5px;font-size:17px}.slots-editor-card .muted{margin:0 0 14px}.slot-edit-row{display:grid;grid-template-columns:105px 1fr;gap:10px;align-items:center;margin-bottom:10px}.slot-edit-row span{font-size:12px;font-weight:950;color:#475569;text-transform:uppercase;letter-spacing:.04em}.slot-edit-row input{min-height:42px}.wide-check{display:flex;align-items:center;gap:12px;max-width:520px}.wide-check span{display:grid;gap:2px}.wide-check b{font-size:15px}.wide-check small{color:var(--muted);font-weight:700}.config-sticky-actions{position:sticky;bottom:0;z-index:5;display:flex;justify-content:flex-end;gap:10px;background:linear-gradient(180deg,rgba(245,247,251,0),#f5f7fb 45%);padding:18px 0 0}
@media(max-width:1200px){.config-panel-preview{position:static;grid-column:span 12}.config-v2>.span8{grid-column:span 12}.config-preview-card{display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:center}.preview-logo-wrap{margin:0}.config-mini-grid{grid-column:1/-1}}
@media(max-width:760px){.settings-section{padding:16px;border-radius:20px}.settings-section-head{display:block}.settings-section-head>div{margin-bottom:8px}.settings-section-head p{text-align:left}.slots-editor-grid{grid-template-columns:1fr}.slot-edit-row{grid-template-columns:1fr}.config-preview-card{display:block}.preview-logo-wrap{margin-bottom:12px}.config-sticky-actions{display:grid}.config-sticky-actions .btn,.config-sticky-actions button{width:100%}}
/* V5.30 estabilidad y usabilidad */
.relay-issues-panel h2,.relay-history-panel h2{margin-bottom:4px}
.issue-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:10px;margin-top:14px}
.issue-card{border:1px solid var(--line);border-radius:14px;padding:12px 14px;font-weight:800;background:#fff}
.issue-ok{background:#ecfdf5;border-color:#bbf7d0;color:#166534}
.issue-info{background:#eff6ff;border-color:#bfdbfe;color:#1e40af}
.issue-warn{background:#fffbeb;border-color:#fde68a;color:#92400e}
.issue-bad{background:#fef2f2;border-color:#fecaca;color:#991b1b}
.history-list{display:flex;flex-direction:column;gap:10px;margin-top:14px}
.history-item{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid var(--line);background:#fff;border-radius:14px;padding:12px}
.history-item span{display:block;color:var(--muted);font-size:12px;margin-top:3px}
.participation-filters{display:flex;gap:8px;flex-wrap:wrap;margin:14px 0 10px}
.participation-filters button{border:1px solid var(--line);background:#fff;color:#172033;border-radius:999px;padding:8px 12px;font-weight:900;cursor:pointer}
.participation-filters button.active,.participation-filters button:hover{background:var(--primary);color:white;border-color:var(--primary)}
.mini-capataz{display:inline-flex;font-size:10px;border-radius:999px;padding:2px 6px;background:#fef3c7;color:#92400e;margin-left:5px;vertical-align:middle}
.quick-edit-card .quick-table td{vertical-align:middle}
.quick-edit-card .mini-select{min-width:120px;max-width:190px}
.inline-check{display:inline-flex;align-items:center;gap:6px;font-weight:900;color:#334155;background:#f8fafc;border:1px solid var(--line);border-radius:999px;padding:7px 10px;white-space:nowrap}
.inline-check input{transform:scale(1.05)}
.capataz-inline{background:#fffbeb;color:#92400e;border-color:#fde68a}
@media(max-width:900px){.history-item{align-items:flex-start;flex-direction:column}.quick-edit-card .table-wrap{overflow:auto}.quick-edit-card table{min-width:980px}}
@media print{.relay-issues-panel,.relay-history-panel,.participation-filters,.quick-edit-card{display:none!important}}


/* V6 PWA / experiencia app móvil */
.install-pwa-btn{position:fixed;right:18px;bottom:18px;z-index:80;border:0;border-radius:999px;background:var(--primary);color:#fff;padding:12px 16px;font-weight:900;box-shadow:0 16px 40px rgba(15,23,42,.25)}
.mobile-bottom-nav{display:none}
@media(max-width:900px){
  .app-shell .page{padding-bottom:86px!important}
  .mobile-bottom-nav{position:fixed;left:0;right:0;bottom:0;z-index:70;display:grid;grid-template-columns:repeat(5,1fr);gap:0;background:rgba(255,255,255,.96);border-top:1px solid #dde2ea;box-shadow:0 -12px 30px rgba(15,23,42,.10);backdrop-filter:blur(12px);padding:7px 6px calc(7px + env(safe-area-inset-bottom))}
  .mobile-bottom-nav a{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;text-decoration:none;color:#64748b;border-radius:14px;padding:7px 3px;font-size:11px;font-weight:900;min-width:0}
  .mobile-bottom-nav a span{font-size:18px;line-height:1;color:#334155}.mobile-bottom-nav a b{font-size:10.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
  .mobile-bottom-nav a.active{background:color-mix(in srgb,var(--primary) 12%,#fff);color:var(--primary)}.mobile-bottom-nav a.active span{color:var(--primary)}
  .install-pwa-btn{bottom:84px;right:12px;padding:10px 13px;font-size:13px}
  .mobile-header{position:sticky;top:0;z-index:60;backdrop-filter:blur(10px)}
}
@media(display-mode:standalone){.install-pwa-btn{display:none!important}.mobile-header{padding-top:env(safe-area-inset-top)}}

/* V6.1 · Login personalizado + dashboard pro */
.login-custom{min-height:100vh;background:
  radial-gradient(circle at 12% 12%, color-mix(in srgb,var(--primary) 22%,transparent), transparent 32%),
  linear-gradient(135deg,#0f172a 0%,#172033 45%, color-mix(in srgb,var(--primary) 70%,#0f172a) 100%);
  display:flex;align-items:center;justify-content:center;padding:28px;color:#172033}
.login-shell{width:min(1180px,100%);display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:stretch}
.login-brand-panel,.login-form-panel{border:1px solid rgba(255,255,255,.22);border-radius:34px;box-shadow:0 30px 70px rgba(2,6,23,.34);overflow:hidden}
.login-brand-panel{background:linear-gradient(145deg,rgba(255,255,255,.18),rgba(255,255,255,.07));backdrop-filter:blur(16px);color:white;padding:34px;display:flex;flex-direction:column;justify-content:space-between;min-height:620px}
.login-brand-top{display:flex;align-items:center;gap:18px}.login-logo{width:86px;height:86px;border-radius:26px;object-fit:cover;background:white;border:1px solid rgba(255,255,255,.35);box-shadow:0 16px 36px rgba(0,0,0,.22)}.login-logo.fallback{display:inline-flex;align-items:center;justify-content:center;font-size:42px;background:rgba(255,255,255,.14);color:white}.login-brand-top h1{font-size:34px;margin:4px 0 4px;line-height:1.05}.login-brand-top p{margin:0;color:#dbeafe;font-weight:800}.login-brand-panel .eyebrow{background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.28);color:white;border-radius:999px;padding:5px 9px;font-weight:950;font-size:12px;letter-spacing:.05em;text-transform:uppercase}
.login-hero-copy{max-width:600px;margin-top:auto}.login-hero-copy h2{font-size:46px;line-height:1;margin:0 0 16px}.login-hero-copy p{font-size:17px;line-height:1.55;color:#e5eefc;margin:0}
.login-feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:28px}.login-feature-grid div{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.20);border-radius:18px;padding:14px}.login-feature-grid b{display:block;font-size:15px}.login-feature-grid span{display:block;font-size:12px;color:#dbeafe;margin-top:4px;line-height:1.35}
.login-form-panel{background:rgba(255,255,255,.92);backdrop-filter:blur(12px);padding:24px;display:flex;align-items:center}.login-form-card{width:100%;background:white;border:1px solid #e2e8f0;border-radius:28px;padding:30px;box-shadow:0 18px 40px rgba(15,23,42,.12)}.login-form-head span{display:inline-flex;border-radius:999px;background:#eef4ff;color:var(--primary);font-size:12px;font-weight:950;text-transform:uppercase;letter-spacing:.05em;padding:6px 10px}.login-form-head h2{font-size:30px;margin:16px 0 6px}.login-form-head p{margin:0 0 20px;color:var(--muted)}.login-form{display:grid;gap:15px}.login-form .field{min-width:0}.login-form input{width:100%;min-height:52px;border-radius:16px;font-size:16px}.login-submit{width:100%;min-height:52px;border-radius:16px;font-size:16px;margin-top:4px}.login-links{margin-top:16px;text-align:center}.login-links a{color:var(--primary);font-weight:900;text-decoration:none}.login-form-card .security-note{margin-top:18px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;padding:12px;color:#64748b;font-size:12px;text-align:center}
.dashboard-pro{align-items:stretch}.dash-welcome{grid-column:span 12;border-radius:30px;padding:26px 28px;color:white;background:linear-gradient(135deg,var(--primary),#111827);box-shadow:0 18px 45px rgba(15,23,42,.20);display:flex;justify-content:space-between;gap:18px;align-items:center}.dash-welcome-brand{display:flex;align-items:center;gap:16px}.dash-welcome-brand img,.dash-welcome-brand>span{width:74px;height:74px;border-radius:22px;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.26);object-fit:cover;display:inline-flex;align-items:center;justify-content:center;font-size:36px}.dash-welcome h1{margin:4px 0;font-size:34px}.dash-welcome p{margin:0;color:#dbeafe}.dash-welcome .eyebrow{color:#dbeafe}.dash-welcome-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.dash-welcome-actions .btn.secondary{background:rgba(255,255,255,.14);color:white;border:1px solid rgba(255,255,255,.25)}
.stat-tile{border:1px solid var(--line);background:#fff;border-radius:24px;padding:20px;box-shadow:var(--shadow);display:grid;gap:6px;min-height:132px}.stat-tile span{color:var(--muted);font-weight:950;text-transform:uppercase;font-size:12px;letter-spacing:.05em}.stat-tile b{font-size:40px;line-height:1;color:var(--text)}.stat-tile small{color:var(--muted);font-weight:800}.stat-tile.blue{background:linear-gradient(135deg,#fff,#eff6ff);border-color:#bfdbfe}.stat-tile.blue b{color:var(--primary)}.stat-tile.amber{background:linear-gradient(135deg,#fff,#fffbeb);border-color:#fde68a}.stat-tile.amber b{color:#92400e}
.current-ensayo-panel{background:linear-gradient(180deg,#fff,#f8fbff)}.current-ensayo-card{border:1px solid #dbe7ff;border-radius:24px;background:#fff;padding:18px;margin-top:12px;display:grid;gap:16px}.current-ensayo-title{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.current-ensayo-title span{color:var(--muted);font-weight:900}.current-ensayo-title h3{margin:4px 0 0;font-size:28px}.current-ensayo-title strong{background:#eef4ff;color:var(--primary);border-radius:999px;padding:8px 12px;font-size:13px;white-space:nowrap}.current-ensayo-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.current-ensayo-meta span{border:1px solid #e2e8f0;background:#f8fafc;border-radius:16px;padding:12px;color:#64748b;font-size:12px}.current-ensayo-meta b{display:block;color:var(--text);font-size:16px;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.current-ensayo-actions{display:flex;gap:10px;flex-wrap:wrap}
.prep-panel-pro .prep-box.pro{display:flex;gap:16px;align-items:center;border:1px solid #e2e8f0;border-radius:22px;background:#f8fafc;padding:16px}.prep-box.pro p{margin:0 0 6px;color:#475569;font-weight:800}.prep-box.pro small{color:var(--muted);font-weight:900}.health-list{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:14px}.health-list span{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:10px;text-align:center;color:#64748b;font-size:12px}.health-list b{display:block;font-size:20px;color:var(--text)}
.trab-dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:12px;margin-top:14px}.trab-dash-card{border:1px solid var(--line);border-radius:20px;padding:14px;background:#fff;text-decoration:none;color:var(--text);display:grid;gap:10px;box-shadow:0 8px 18px rgba(15,23,42,.04)}.trab-dash-card:hover{border-color:#bfdbfe;transform:translateY(-1px)}.trab-dash-card div:first-child{display:flex;justify-content:space-between;align-items:center;gap:10px}.trab-dash-card strong{color:var(--primary);font-size:18px}.trab-dash-card small{color:var(--muted);font-weight:800}.quick-stack.pro a{border-radius:18px;padding:15px 16px}.ensayo-timeline.pro .timeline-item{border-radius:18px}.activity-list-pro{display:grid;gap:10px}.activity-list-pro div{border:1px solid #e2e8f0;background:#f8fafc;border-radius:16px;padding:12px}.activity-list-pro b{display:block}.activity-list-pro span{display:block;color:var(--muted);font-size:12px;margin-top:3px}.dashboard-empty-seed{align-items:center}
@media(max-width:980px){.login-shell{grid-template-columns:1fr}.login-brand-panel{min-height:auto}.login-hero-copy h2{font-size:34px}.login-feature-grid{grid-template-columns:1fr}.dash-welcome{display:grid}.dash-welcome-actions{justify-content:flex-start}.current-ensayo-meta{grid-template-columns:1fr}.health-list{grid-template-columns:1fr 1fr 1fr}}
@media(max-width:640px){.login-custom{padding:12px}.login-brand-panel{padding:22px;border-radius:24px}.login-form-panel{padding:10px;border-radius:24px}.login-form-card{padding:20px;border-radius:22px}.login-brand-top{align-items:flex-start}.login-logo{width:64px;height:64px;border-radius:18px}.login-brand-top h1{font-size:24px}.login-hero-copy h2{font-size:28px}.dash-welcome{padding:20px;border-radius:24px}.dash-welcome h1{font-size:26px}.dash-welcome-brand{align-items:flex-start}.dash-welcome-brand img,.dash-welcome-brand>span{width:58px;height:58px;border-radius:18px}.dash-welcome-actions .btn{width:100%;justify-content:center}.current-ensayo-title{display:grid}.current-ensayo-actions .btn{width:100%;justify-content:center}.stat-tile{min-height:auto}.health-list{grid-template-columns:1fr}}
