:root{
  --blue:#017BC4;--mid:#1B5FA4;--gold:#F5C842;--gold2:#C9A94E;--gold3:#FBE7A6;
  --navy:#002B4A;--black:#0B0B0C;--ink:#16191E;--gray:#5C6670;--white:#fff;
  --off:#EEF4FA;--off2:#F6F9FC;--line:#D7E3EE;--bluegray:#96BAD0;
  --green:#1E9E63;--green-bg:#E4F5EC;--amber:#E6A700;--amber-bg:#FCF3DC;--red:#D64545;--red-bg:#FBE6E6;
  --fh:'Barlow Condensed',sans-serif;--fb:'Nunito',sans-serif;
  --sidebar-w:264px;--radius:14px;--radius-sm:10px;
  --shadow:0 1px 3px rgba(16,25,30,.06),0 8px 24px rgba(16,25,30,.06);
  --shadow-sm:0 1px 2px rgba(16,25,30,.06),0 2px 8px rgba(16,25,30,.05);
  --shadow-lg:0 4px 12px rgba(16,25,30,.08),0 18px 50px rgba(16,25,30,.12);
  --deep:#0A5688;
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}
body{font-family:var(--fb);color:var(--ink);background:var(--off2);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,.fh{font-family:var(--fh)}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,select,textarea{font-family:inherit;font-size:14px}
a{color:var(--blue);text-decoration:none}
::selection{background:var(--gold3)}
.app{display:flex;min-height:100vh}

/* ===== SIDEBAR ===== */
.sidebar{width:var(--sidebar-w);background:linear-gradient(165deg,#0A5688 0%,var(--blue) 46%,var(--mid) 100%);color:#fff;position:fixed;top:0;left:0;bottom:0;display:flex;flex-direction:column;z-index:40;box-shadow:2px 0 24px rgba(10,86,136,.2)}
.sb-brand{padding:22px 22px 16px;display:flex;align-items:center;gap:0;border-bottom:1px solid rgba(255,255,255,.12)}
.sb-brand img{height:30px;width:auto;display:block}
.sb-lab{font-family:var(--fh);font-style:italic;font-weight:800;font-size:23px;color:var(--gold);margin-left:9px;padding-left:11px;border-left:2px solid rgba(255,255,255,.32);line-height:1}
.sb-sub{padding:14px 22px 8px;font-family:var(--fh);font-weight:700;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--bluegray)}
.sb-nav{flex:1;overflow-y:auto;padding:4px 12px 12px}
.sb-nav::-webkit-scrollbar{width:6px}.sb-nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.18);border-radius:3px}
.nav-item{display:flex;align-items:center;gap:12px;width:100%;padding:11px 14px;border-radius:11px;color:rgba(255,255,255,.82);font-weight:700;font-size:14px;text-align:left;transition:.16s;margin-bottom:3px;position:relative}
.nav-item:hover{background:rgba(255,255,255,.1);color:#fff}
.nav-item.active{background:rgba(255,255,255,.16);color:#fff}
.nav-item.active::before{content:"";position:absolute;left:-12px;top:50%;transform:translateY(-50%);width:4px;height:22px;background:var(--gold);border-radius:0 4px 4px 0}
.nav-item .ic{width:20px;height:20px;flex:none;opacity:.95}
.nav-item .badge{margin-left:auto;background:var(--gold);color:var(--navy);font-family:var(--fb);font-weight:800;font-size:11px;min-width:20px;height:20px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 6px}
.nav-phase{font-family:var(--fh);font-weight:700;font-size:11px;letter-spacing:.12em;color:var(--bluegray);padding:14px 14px 5px;text-transform:uppercase}
.sb-foot{padding:14px 22px 18px;border-top:1px solid rgba(255,255,255,.12);font-size:11.5px;color:var(--bluegray);line-height:1.6}
.sb-foot b{color:#fff;font-weight:800}

/* ===== MAIN ===== */
.main{flex:1;margin-left:var(--sidebar-w);display:flex;flex-direction:column;min-width:0}
.topbar{height:64px;background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:18px;padding:0 28px;position:sticky;top:0;z-index:30}
.tb-title{font-family:var(--fh);font-weight:800;font-size:22px;color:var(--navy);letter-spacing:.01em}
.tb-ctx{margin-left:auto;display:flex;align-items:center;gap:14px}
.ctx-pill{display:flex;align-items:center;gap:9px;background:var(--off);border:1px solid var(--line);border-radius:11px;padding:7px 14px;font-size:13px;font-weight:700}
.ctx-pill .lbl{color:var(--gray);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.05em}
.ctx-pill select{border:none;background:none;font-weight:800;color:var(--navy);max-width:200px;outline:none}
.content{padding:28px;flex:1}

/* ===== COMPONENTS ===== */
.btn{display:inline-flex;align-items:center;gap:8px;background:var(--blue);color:#fff;font-weight:800;font-size:14px;padding:10px 18px;border-radius:11px;transition:.16s;box-shadow:0 2px 8px rgba(1,123,196,.25)}
.btn:hover{background:var(--mid);transform:translateY(-1px);box-shadow:0 5px 16px rgba(1,123,196,.32)}
.btn:active{transform:translateY(0)}
.btn.gold{background:var(--gold);color:var(--navy);box-shadow:0 2px 8px rgba(245,200,66,.3)}
.btn.gold:hover{background:#ecbf36}
.btn.ghost{background:#fff;color:var(--blue);border:1.5px solid var(--line);box-shadow:none}
.btn.ghost:hover{border-color:var(--blue);background:var(--off)}
.btn.sm{padding:7px 13px;font-size:13px;border-radius:9px}
.btn .ic{width:17px;height:17px}
.btn.mail{background:#fff;color:var(--mid);border:1.5px solid var(--bluegray);box-shadow:none}
.btn.mail:hover{background:var(--off);border-color:var(--blue)}

.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);transition:box-shadow .2s,transform .2s}
.card:hover{box-shadow:var(--shadow-lg)}
.card-pad{padding:22px}
.card-h{display:flex;align-items:center;gap:12px;padding:18px 22px;border-bottom:1px solid var(--line)}
.card-h h3{font-size:18px;font-weight:800;color:var(--navy)}
.card-h .ic{width:22px;height:22px;color:var(--blue)}
.card-h .sub{margin-left:auto;font-size:13px;color:var(--gray);font-weight:600}

.grid{display:grid;gap:18px}
.fade-up{opacity:0;transform:translateY(14px);animation:fadeUp .55s cubic-bezier(.2,.7,.2,1) forwards}
@keyframes fadeUp{to{opacity:1;transform:none}}
@keyframes floatA{0%,100%{transform:translate(0,0)}50%{transform:translate(-26px,30px)}}
@keyframes floatB{0%,100%{transform:translate(0,0)}50%{transform:translate(24px,-26px)}}
@keyframes spin{to{transform:rotate(360deg)}}
.fade-up.d1{animation-delay:.05s}.fade-up.d2{animation-delay:.1s}.fade-up.d3{animation-delay:.15s}.fade-up.d4{animation-delay:.2s}.fade-up.d5{animation-delay:.25s}.fade-up.d6{animation-delay:.3s}

/* KPI cards */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.kpi{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px 22px;position:relative;overflow:hidden;box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s}
.kpi:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.kpi:before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--blue),var(--mid));opacity:0;transition:.2s}
.kpi:hover:before{opacity:1}
.kpi .ic-wrap{position:absolute;top:18px;right:18px;width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:var(--off);transition:.2s}
.kpi:hover .ic-wrap{background:linear-gradient(135deg,#EAF4FB,#D5E8F5)}
.kpi .ic-wrap .ic{width:22px;height:22px;color:var(--blue)}
.kpi .lbl{font-size:12.5px;color:var(--gray);font-weight:700;text-transform:uppercase;letter-spacing:.02em;padding-right:46px;line-height:1.3}
.kpi .val{font-family:var(--fh);font-weight:800;font-size:40px;color:var(--navy);line-height:1.05;margin-top:8px}
.kpi .foot{font-size:12.5px;color:var(--gray);margin-top:6px;font-weight:600}
.kpi.accent{background:linear-gradient(145deg,#017BC4,#1B5FA4);border:none;color:#fff}
.kpi.accent .lbl,.kpi.accent .foot{color:rgba(255,255,255,.85)}
.kpi.accent .val{color:#fff}
.kpi.accent .ic-wrap{background:rgba(255,255,255,.16)}.kpi.accent .ic-wrap .ic{color:#fff}
.kpi.accent .orb{position:absolute;border-radius:50%;background:radial-gradient(circle,rgba(245,200,66,.4),transparent 70%);width:160px;height:160px;right:-50px;bottom:-60px;pointer-events:none}

/* badges */
.badge-st{display:inline-flex;align-items:center;gap:6px;font-weight:800;font-size:12px;padding:4px 11px;border-radius:20px}
.badge-st .dot{width:7px;height:7px;border-radius:50%}
.b-green{background:var(--green-bg);color:var(--green)}.b-green .dot{background:var(--green)}
.b-amber{background:var(--amber-bg);color:var(--amber)}.b-amber .dot{background:var(--amber)}
.b-red{background:var(--red-bg);color:var(--red)}.b-red .dot{background:var(--red)}
.b-blue{background:#E2F0FA;color:var(--blue)}.b-blue .dot{background:var(--blue)}
.b-gray{background:var(--off);color:var(--gray)}.b-gray .dot{background:var(--gray)}

/* tables */
.tbl{width:100%;border-collapse:collapse;font-size:14px}
.tbl th{text-align:left;font-family:var(--fh);font-weight:700;font-size:12px;letter-spacing:.05em;text-transform:uppercase;color:var(--gray);padding:11px 14px;border-bottom:2px solid var(--line);white-space:nowrap}
.tbl td{padding:12px 14px;border-bottom:1px solid var(--line);vertical-align:middle}
.tbl tbody tr:hover{background:var(--off2)}
.tbl tbody tr:last-child td{border-bottom:none}
.tbl .nm{font-weight:800;color:var(--navy)}
.tbl .mut{color:var(--gray);font-size:13px}

/* phase tracker */
.phase-track{display:flex;gap:0;align-items:stretch;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.ph-step{flex:1;padding:16px 18px;position:relative;border-right:1px solid var(--line)}
.ph-step:last-child{border-right:none}
.ph-step .n{font-family:var(--fh);font-weight:800;font-size:12px;color:var(--bluegray);letter-spacing:.08em}
.ph-step .t{font-weight:800;font-size:14px;color:var(--navy);margin-top:4px}
.ph-step .c{font-size:12px;color:var(--gray);margin-top:3px;font-weight:600}
.ph-step.done{background:var(--green-bg)}.ph-step.done .n{color:var(--green)}
.ph-step.active{background:#E2F0FA}.ph-step.active .n{color:var(--blue)}
.ph-step .chk{position:absolute;top:14px;right:16px;width:18px;height:18px}

/* empty / section title */
.sec-title{font-family:var(--fh);font-weight:800;font-size:15px;color:var(--gray);letter-spacing:.08em;text-transform:uppercase;margin:4px 0 14px;display:flex;align-items:center;gap:10px}
.sec-title .ln{flex:1;height:1px;background:var(--line)}
.empty{text-align:center;padding:48px 20px;color:var(--gray)}
.empty .ic{width:46px;height:46px;opacity:.4;margin-bottom:12px}

.mini{display:flex;gap:18px;flex-wrap:wrap}
.mini-card{flex:1;min-width:200px;background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);padding:16px 18px;box-shadow:var(--shadow)}
.mini-card .l{font-size:12px;color:var(--gray);font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.mini-card .v{font-family:var(--fh);font-weight:800;font-size:26px;color:var(--navy);margin-top:5px}

.chart-wrap{position:relative;height:240px}
.two-col{display:grid;grid-template-columns:1.4fr 1fr;gap:18px}
@media(max-width:1100px){.kpis{grid-template-columns:repeat(2,1fr)}.two-col{grid-template-columns:1fr}}
@media(max-width:680px){.sidebar{transform:translateX(-100%);transition:.2s}.sidebar.open{transform:none}.main{margin-left:0}.kpis{grid-template-columns:1fr}.phase-track{flex-direction:column}}

/* alerts list */
.alert-row{display:flex;align-items:center;gap:12px;padding:13px 16px;border-radius:var(--radius-sm);border:1px solid var(--line);margin-bottom:10px;background:#fff}
.alert-row .ic{width:20px;height:20px;flex:none}
.alert-row.r{border-left:4px solid var(--red)}.alert-row.r .ic{color:var(--red)}
.alert-row.red{border-left:4px solid var(--red)}.alert-row.red .ic{color:var(--red)}
.alert-row.a{border-left:4px solid var(--amber)}.alert-row.a .ic{color:var(--amber)}
.alert-row.amber{border-left:4px solid var(--amber)}.alert-row.amber .ic{color:var(--amber)}
.alert-row .txt{flex:1}.alert-row .txt b{color:var(--navy)}
.alert-row .meta{font-size:12.5px;color:var(--gray);font-weight:600}
.alert-row.act{width:100%;text-align:left;cursor:pointer;font:inherit;transition:transform .1s,box-shadow .1s,border-color .1s}
.alert-row.act:hover{transform:translateX(3px);box-shadow:0 4px 14px rgba(1,123,196,.16);border-color:var(--blue)}
.alert-row.act .meta{white-space:nowrap}

.toast{position:fixed;bottom:24px;right:24px;background:var(--navy);color:#fff;padding:14px 20px;border-radius:12px;font-weight:700;font-size:14px;box-shadow:var(--shadow-lg);z-index:200;display:flex;align-items:center;gap:10px;opacity:0;transform:translateY(12px);transition:.25s}
.toast.show{opacity:1;transform:none}
.toast .ic{width:18px;height:18px;color:var(--gold)}
/* ===== IT2 styles ===== */
.al-block{border:1px solid var(--line);border-radius:var(--radius-sm);padding:16px 18px;margin-bottom:14px;background:var(--off2)}
.al-head{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:12px}
.al-id{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.al-id .aux{font-family:var(--fh);font-weight:800;font-size:13px;background:var(--blue);color:#fff;padding:3px 10px;border-radius:8px}
.al-id .nm{font-weight:800;color:var(--navy);font-size:15px}
.al-meta{margin-left:auto;display:flex;align-items:center;gap:12px}
.prog{width:120px;height:7px;background:var(--line);border-radius:5px;overflow:hidden}
.prog-bar{height:100%;background:linear-gradient(90deg,var(--blue),var(--mid));border-radius:5px;transition:width .4s}
.al-docs{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:9px}
.doc-chip{display:flex;align-items:center;gap:9px;padding:10px 13px;border:1.5px solid var(--line);border-radius:10px;background:#fff;text-align:left;transition:.15s;font-weight:700;font-size:13px;color:var(--gray)}
.doc-chip:hover{border-color:var(--blue)}
.doc-chip.on{border-color:var(--green);background:var(--green-bg);color:var(--green)}
.doc-chip .dc-ic{width:20px;height:20px;flex:none;display:flex}.doc-chip .dc-ic .ic{width:18px;height:18px}
.doc-chip.on .dc-ic{color:var(--green)}
.doc-chip .dc-lbl{line-height:1.25}
.al-valid{margin-top:11px;display:flex;flex-direction:column;gap:6px}
.vmsg{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;padding:7px 11px;border-radius:8px}
.vmsg .ic{width:16px;height:16px;flex:none}
.vmsg.a{background:var(--amber-bg);color:var(--amber)}.vmsg.r{background:var(--red-bg);color:var(--red)}

.cfg-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px}
.fld{display:flex;flex-direction:column;gap:5px}
.fld>span{font-size:12px;font-weight:700;color:var(--gray);text-transform:uppercase;letter-spacing:.03em}
.fld input,.fld select{padding:9px 12px;border:1.5px solid var(--line);border-radius:9px;outline:none;transition:.15s;background:#fff}
.fld input:focus,.fld select:focus{border-color:var(--blue)}
.fld.chk{flex-direction:row;align-items:center;gap:9px}
.fld.chk input{width:18px;height:18px;accent-color:var(--blue)}
.fld.chk span{text-transform:none;font-size:13.5px;color:var(--ink);font-weight:700}

.cal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(64px,1fr));gap:7px}
.cal-cell{border:1px solid var(--line);border-radius:9px;padding:7px 5px;text-align:center;background:#fff;min-height:64px;display:flex;flex-direction:column;align-items:center;justify-content:center}
.cal-cell .cd{font-family:var(--fh);font-weight:800;font-size:17px;color:var(--navy);line-height:1}
.cal-cell .cm{font-size:9.5px;color:var(--gray);text-transform:uppercase;font-weight:700}
.cal-cell .ch{font-size:10px;font-weight:800;margin-top:3px}
.cal-cell .ch-row{display:flex;flex-direction:column;gap:1px;margin-top:3px;align-items:center}
.cal-cell .ch.f{color:var(--green)}
.cal-cell .ch.t{color:var(--blue)}
.cal-cell .ch.z{color:var(--bluegray)}
.cal-cell{cursor:pointer;transition:transform .1s,box-shadow .1s}
.cal-cell:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(1,123,196,.18);border-color:var(--blue)}
.cal-cell .cmf{font-size:8.5px;font-weight:800;color:var(--blue);margin-top:2px;letter-spacing:.02em}
.cal-cell.lectivo{border-color:#BFE0C9;background:#F2FBF5}.cal-cell.lectivo .ch{color:var(--green)}
.cal-cell.finde{background:var(--off);opacity:.7}
.cal-cell.fest{background:var(--amber-bg);border-color:#F2DFA8}

/* modal */
.modal-ov{position:fixed;inset:0;background:rgba(11,11,12,.5);backdrop-filter:blur(3px);z-index:100;display:flex;align-items:center;justify-content:center;padding:24px;animation:fadeIn .18s}
@keyframes fadeIn{from{opacity:0}}
.modal{background:#fff;border-radius:18px;width:min(640px,100%);max-height:88vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);animation:modalUp .22s cubic-bezier(.2,.7,.2,1)}
@keyframes modalUp{from{transform:translateY(18px);opacity:0}}
.modal-h{display:flex;align-items:center;padding:20px 24px;border-bottom:1px solid var(--line)}
.modal-h h3{font-size:19px;font-weight:800;color:var(--navy)}
.modal-x{margin-left:auto;width:32px;height:32px;border-radius:9px;color:var(--gray);font-size:16px;font-weight:800}
.modal-x:hover{background:var(--off)}
.modal-b{padding:22px 24px;overflow-y:auto}
.modal-f{padding:16px 24px;border-top:1px solid var(--line);display:flex;gap:10px;justify-content:flex-end}

/* ===== IT3 styles ===== */
.kv-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.kv{display:flex;flex-direction:column;gap:3px;padding:11px 14px;background:var(--off2);border:1px solid var(--line);border-radius:10px}
.kv .k{font-size:11px;font-weight:700;color:var(--gray);text-transform:uppercase;letter-spacing:.03em}
.kv .v{font-weight:800;color:var(--navy);font-size:14.5px}
.gen-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);display:flex;flex-direction:column;transition:.18s}
.gen-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.gc-ic{width:48px;height:48px;border-radius:13px;background:linear-gradient(145deg,var(--blue),var(--mid));display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.gc-ic .ic{width:24px;height:24px;color:#fff}
.gc-t{font-family:var(--fh);font-weight:800;font-size:19px;color:var(--navy)}
.gc-d{font-size:13px;color:var(--gray);font-weight:600;margin:6px 0 14px;flex:1;line-height:1.45}
.gc-act{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.gc-sel{flex:1;min-width:140px;padding:8px 11px;border:1.5px solid var(--line);border-radius:9px;font-weight:700;color:var(--navy);outline:none}
.gc-sel:focus{border-color:var(--blue)}
.doc-asign{border:1px solid var(--line);border-radius:10px;padding:13px 15px;background:var(--off2)}
.da-mf{display:flex;align-items:baseline;gap:9px}.da-mf b{color:var(--navy);font-size:15px}

/* ===== IT4-5 styles ===== */
.dash-bar{display:flex;align-items:center;gap:14px;flex-wrap:wrap;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:14px 18px;box-shadow:var(--shadow)}
.db-filters{display:flex;gap:10px;flex-wrap:wrap;align-items:center;flex:1}
.db-sel{padding:9px 12px;border:1.5px solid var(--line);border-radius:9px;font-weight:700;color:var(--navy);outline:none;background:#fff}
.db-sel:focus{border-color:var(--blue)}
.db-q{flex:1;min-width:200px;padding:9px 13px;border:1.5px solid var(--line);border-radius:9px;outline:none}
.db-q:focus{border-color:var(--blue)}
.row-del{width:26px;height:26px;border-radius:7px;color:var(--gray);font-weight:800}
.row-del:hover{background:var(--red-bg);color:var(--red)}

.cfg-tabs{display:flex;gap:8px;flex-wrap:wrap;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:8px;box-shadow:var(--shadow)}
.cfg-tab{display:flex;align-items:center;gap:8px;padding:10px 16px;border-radius:10px;font-weight:700;color:var(--gray);transition:.15s}
.cfg-tab .ic{width:18px;height:18px}
.cfg-tab:hover{background:var(--off)}
.cfg-tab.active{background:var(--blue);color:#fff}
.esp-row{border:1px solid var(--line);border-radius:10px;padding:14px 16px;margin-bottom:10px;background:var(--off2)}
.esp-head{display:flex;align-items:center;gap:8px;font-weight:700;color:var(--ink)}
.esp-head .nm{color:var(--navy);font-size:15px}
.esp-mods{display:flex;gap:7px;flex-wrap:wrap;margin-top:9px}
.esp-mf{font-size:12px;font-weight:700;background:#E2F0FA;color:var(--blue);padding:4px 10px;border-radius:7px}

/* visor */
.visor-ov{position:fixed;inset:0;background:rgba(11,11,12,.62);backdrop-filter:blur(4px);z-index:120;display:flex;align-items:center;justify-content:center;padding:24px;animation:fadeIn .18s}
.visor{background:#fff;border-radius:16px;width:min(960px,100%);height:min(90vh,1000px);display:flex;flex-direction:column;box-shadow:var(--shadow-lg);overflow:hidden;animation:modalUp .22s cubic-bezier(.2,.7,.2,1)}
.visor-h{display:flex;align-items:center;gap:12px;padding:14px 18px;border-bottom:1px solid var(--line);background:var(--off2)}
.visor-t{display:flex;align-items:center;gap:9px;font-family:var(--fh);font-weight:800;font-size:16px;color:var(--navy)}
.visor-t .ic{width:20px;height:20px;color:var(--blue)}
.visor-act{margin-left:auto;display:flex;gap:8px;align-items:center}
.visor-x{width:32px;height:32px;border-radius:9px;color:var(--gray);font-size:16px;font-weight:800}
.visor-x:hover{background:var(--off)}
.visor-b{flex:1;background:#e9eef3;overflow:auto;padding:18px}
.visor-b iframe{width:100%;height:100%;min-height:600px;border:none;background:#fff;border-radius:8px;box-shadow:var(--shadow)}
.visor-t-nm{font-family:var(--fh);font-weight:800;font-size:16px;color:var(--navy);line-height:1.1}
.visor-t-meta{font-family:var(--fb);font-weight:600;font-size:11.5px;color:var(--gray);display:flex;gap:6px;align-items:center;margin-top:2px}
.visor-orient{display:inline-flex;align-items:center;gap:4px;background:#EAF4FB;color:var(--blue);border-radius:6px;padding:1px 7px;font-weight:700}
.visor-orient .ic{width:12px;height:12px}
.visor-fmts{display:inline-flex;gap:6px;background:var(--off);border:1px solid var(--line);border-radius:10px;padding:4px}
.visor-fmt{display:inline-flex;align-items:center;gap:5px;font-family:var(--fb);font-weight:700;font-size:12.5px;color:var(--ink);padding:6px 11px;border-radius:7px;transition:.15s}
.visor-fmt .ic{width:14px;height:14px}
.visor-fmt:hover{background:#fff;box-shadow:var(--shadow-sm);color:var(--blue)}
.visor-fmt.prim{background:linear-gradient(135deg,var(--blue),var(--mid));color:#fff}
.visor-fmt.prim:hover{filter:brightness(1.06);color:#fff}
/* ===== Expediente · hero premium ===== */
.exp-hero{position:relative;border-radius:18px;overflow:hidden;background:linear-gradient(145deg,#017BC4,#1B5FA4);color:#fff;box-shadow:var(--shadow-lg)}
.exp-hero-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.exp-hero-bg .orb-a,.exp-hero-bg .orb-b{position:absolute;border-radius:50%;filter:blur(46px);opacity:.5}
.exp-hero-bg .orb-a{width:300px;height:300px;background:#36B6E8;top:-120px;right:-60px;animation:floatA 9s ease-in-out infinite}
.exp-hero-bg .orb-b{width:240px;height:240px;background:#F5C842;bottom:-130px;left:-50px;opacity:.32;animation:floatB 11s ease-in-out infinite}
.exp-hero-in{position:relative;padding:24px 26px}
.exp-hero-top{display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap}
.exp-hero-eyebrow{font-family:var(--fh);font-weight:700;font-size:12.5px;letter-spacing:.12em;color:#FBE7A6}
.exp-hero-t{font-family:var(--fh);font-weight:800;font-size:30px;line-height:1.04;margin:3px 0 4px}
.exp-hero-sub{font-family:var(--fb);font-weight:600;font-size:13.5px;color:#DCEBF7}
.exp-hero-ring{position:relative;width:108px;height:108px;flex:none}
.exp-hero-ring svg{width:108px;height:108px;transform:rotate(-90deg)}
.exp-hero-ring .r-bg{fill:none;stroke:rgba(255,255,255,.22);stroke-width:9}
.exp-hero-ring .r-fg{fill:none;stroke:#F5C842;stroke-width:9;stroke-linecap:round;stroke-dasharray:327;stroke-dashoffset:327;transition:stroke-dashoffset 1.1s cubic-bezier(.2,.7,.2,1)}
.exp-hero-ring-v{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-weight:800}
.exp-hero-ring-v b{font-size:30px}.exp-hero-ring-v span{font-size:15px;margin-top:6px;opacity:.85}
.exp-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:20px}
.exp-kpi{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);border-radius:12px;padding:13px 15px;backdrop-filter:blur(3px)}
.exp-kpi-v{font-family:var(--fh);font-weight:800;font-size:26px;line-height:1}
.exp-kpi-l{font-family:var(--fb);font-weight:600;font-size:11.5px;color:#DCEBF7;margin-top:3px}
.exp-actions{display:flex;gap:10px;margin-top:20px;flex-wrap:wrap}
.exp-actions .btn{background:rgba(255,255,255,.95)}
.exp-actions .btn.mail{background:rgba(255,255,255,.95)}
/* ===== doc-cards ===== */
.doc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:13px}
.doc-card{position:relative;display:flex;align-items:flex-start;gap:12px;background:#fff;border:1.5px solid var(--line);border-radius:13px;padding:14px 15px;transition:.18s}
.doc-card:hover{border-color:var(--bluegray);box-shadow:var(--shadow);transform:translateY(-2px)}
.doc-card.done{border-color:#BFE0C9;background:linear-gradient(180deg,#F4FBF6,#fff)}
.doc-card.gen{}
.doc-card-chk{position:absolute;top:12px;right:12px;cursor:pointer}
.doc-card-chk input{position:absolute;opacity:0;width:0;height:0}
.doc-card-chk span{display:block;width:22px;height:22px;border-radius:7px;border:2px solid var(--line);background:#fff;transition:.15s;position:relative}
.doc-card-chk input:checked+span{background:var(--green);border-color:var(--green)}
.doc-card-chk input:checked+span:after{content:'✓';position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:13px;font-weight:800}
.doc-card-ic{width:42px;height:42px;border-radius:11px;flex:none;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#EAF4FB,#D5E8F5);color:var(--blue)}
.doc-card-ic .ic{width:21px;height:21px}
.doc-card.alum .doc-card-ic{background:linear-gradient(135deg,#FBF3DF,#F7E7BD);color:#B07C00}
.doc-card.ext .doc-card-ic{background:linear-gradient(135deg,#EDEFF2,#E1E5EA);color:var(--gray)}
.doc-card.done .doc-card-ic{background:linear-gradient(135deg,#E2F5E9,#CCEBD6);color:var(--green)}
.doc-card-body{flex:1;min-width:0;padding-right:26px}
.doc-card-t{font-family:var(--fh);font-weight:700;font-size:15.5px;color:var(--navy);line-height:1.12}
.doc-card-d{font-family:var(--fb);font-weight:500;font-size:12px;color:var(--gray);margin-top:3px;line-height:1.3}
.doc-card-meta{display:flex;flex-wrap:wrap;gap:5px;margin-top:9px}
.doc-tag{font-family:var(--fb);font-weight:700;font-size:10.5px;padding:2px 8px;border-radius:20px;letter-spacing:.01em}
.doc-tag.g{background:#EAF4FB;color:var(--blue)}
.doc-tag.a{background:#FBF3DF;color:#9A6B00}
.doc-tag.e{background:#EDEFF2;color:var(--gray)}
.doc-tag.ok{background:#E2F5E9;color:#0A8F5B}
.doc-tag.up{background:#EFE9FB;color:#6B46C1}
.doc-card-act{margin-top:auto;align-self:flex-end;flex:none}
.doc-card-act .btn{white-space:nowrap}
@media(max-width:720px){.exp-kpis{grid-template-columns:repeat(2,1fr)}.doc-grid{grid-template-columns:1fr}}
/* ===== selector de persona ===== */
.doc-pick{display:flex;flex-direction:column;gap:9px}
.doc-pick-btn{display:flex;align-items:center;gap:11px;width:100%;text-align:left;background:var(--off2);border:1.5px solid var(--line);border-radius:11px;padding:11px 14px;transition:.15s;cursor:pointer}
.doc-pick-btn:hover{border-color:var(--blue);background:#fff;box-shadow:var(--shadow)}
.doc-pick-btn .ic{width:20px;height:20px;color:var(--blue);flex:none}
.doc-pick-btn span{display:flex;flex-direction:column;line-height:1.2}
.doc-pick-btn b{font-family:var(--fb);font-weight:800;font-size:14px;color:var(--ink)}
.doc-pick-btn small{font-family:var(--fb);color:var(--gray);font-size:12px}

/* barra trabajo/formación */
.pct-bar{display:flex;height:38px;border-radius:10px;overflow:hidden;border:1px solid var(--line);font-weight:800;font-size:13px;color:#fff}
.pct-trab{background:linear-gradient(135deg,#017BC4,#1B5FA4);display:flex;align-items:center;justify-content:center;transition:width .4s}
.pct-form{background:linear-gradient(135deg,#F5C842,#E0A92E);color:#0B0B0C;display:flex;align-items:center;justify-content:center;transition:width .4s}
.pct-rule{display:flex;gap:18px;flex-wrap:wrap;margin-top:10px;font-size:12.5px;font-weight:700}
.pct-rule .ok{color:var(--green)}.pct-rule .ko{color:var(--red)}
.crono-jornada{display:flex;align-items:center;gap:10px;margin-top:14px;flex-wrap:wrap}
.crono-jornada .cj-box{flex:1;min-width:110px;background:var(--off);border:1px solid var(--line);border-radius:10px;padding:10px 12px;display:flex;flex-direction:column;gap:2px;text-align:center}
.crono-jornada .cj-box.cj-form{border-color:#BFE0C9;background:#F2FBF5}
.crono-jornada .cj-box.cj-trab{border-color:#BBD7EE;background:#F0F7FC}
.crono-jornada .cj-l{font-size:11px;color:var(--gray);font-weight:700;text-transform:uppercase;letter-spacing:.02em}
.crono-jornada .cj-v{font-family:var(--fh);font-weight:800;font-size:22px;color:var(--navy);line-height:1}
.crono-jornada .cj-box.cj-form .cj-v{color:var(--green)}
.crono-jornada .cj-box.cj-trab .cj-v{color:var(--blue)}
.crono-jornada .cj-pct{font-size:11px;color:var(--gray);font-weight:700}
.crono-jornada .cj-arrow,.crono-jornada .cj-plus{font-size:20px;font-weight:800;color:var(--bluegray);flex:none}

/* tabla evaluación Fase 3 */
.eval-tbl th{white-space:nowrap}
.eval-cell{text-align:center}
.apto-tg{min-width:58px;padding:5px 10px;border-radius:8px;font-weight:800;font-size:12px;background:var(--off);color:var(--gray);border:1.5px solid var(--line);transition:.15s}
.apto-tg.on{background:var(--green-bg,#E6F6EC);color:var(--green);border-color:var(--green)}
.apto-tg:hover{border-color:var(--blue)}

/* barra de progreso expediente */
.prog-track{height:12px;background:var(--off2);border-radius:8px;overflow:hidden;border:1px solid var(--line)}
.prog-fill{height:100%;background:linear-gradient(90deg,var(--blue),var(--mid));border-radius:8px;transition:width .5s}
.lab-chk{width:18px;height:18px;accent-color:var(--blue);cursor:pointer}

/* CEO hero */
.ceo-hero{position:relative;overflow:hidden;background:linear-gradient(145deg,#017BC4,#1B5FA4);color:#fff;border:none}
.ceo-hero-bg{position:absolute;inset:0;overflow:hidden}
.ceo-hero-bg .orb{position:absolute;border-radius:50%;filter:blur(50px);opacity:.4}
.ceo-hero-bg .o1{width:280px;height:280px;background:#36B6E8;top:-90px;right:-50px}
.ceo-hero-bg .o2{width:220px;height:220px;background:#F5C842;bottom:-90px;left:20%}
.ceo-hero-c{position:relative;padding:30px 34px}
.ceo-tag{font-weight:800;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:#F5C842;margin-bottom:8px}
.ceo-hero-c h2{font-family:var(--fh);font-weight:800;font-size:30px;margin:0;line-height:1.05}
.ceo-hero-c p{margin:8px 0 0;opacity:.92;font-weight:600}
.logo-prev{background:var(--off2);border:1px dashed var(--line);border-radius:10px;padding:18px;display:flex;align-items:center;justify-content:center;min-height:70px}

/* ===== IT9 ===== */
/* kanban */
.kanban{display:grid;grid-template-columns:repeat(7,minmax(150px,1fr));gap:10px;overflow-x:auto;padding-bottom:8px}
.kb-col{background:var(--off2);border-radius:12px;min-height:200px;display:flex;flex-direction:column}
.kb-head{display:flex;align-items:center;gap:7px;padding:11px 12px;font-weight:800;color:var(--navy);font-size:13px;background:#fff;border-radius:12px 12px 0 0}
.kb-head .ic{width:16px;height:16px}.kb-count{margin-left:auto;background:var(--off);border-radius:20px;padding:1px 9px;font-size:12px}
.kb-body{padding:8px;display:flex;flex-direction:column;gap:8px;flex:1;transition:.15s}
.kb-body.drop-on{background:#E2F0FA;outline:2px dashed var(--blue)}
.kb-card{background:#fff;border:1px solid var(--line);border-radius:10px;padding:10px 12px;cursor:grab;box-shadow:var(--shadow);transition:.15s}
.kb-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-1px)}
.kb-card.dragging{opacity:.5}
.kb-card-t{font-weight:800;color:var(--navy);display:flex;align-items:center;gap:6px}
.kb-sem{width:9px;height:9px;border-radius:50%;margin-left:auto}.kb-sem.green{background:var(--green)}.kb-sem.amber{background:var(--amber)}.kb-sem.red{background:var(--red)}
.kb-card-cp{font-size:12px;font-weight:700;color:var(--blue);margin:2px 0}
.kb-card-m{display:flex;justify-content:space-between;font-size:11.5px;color:var(--gray);font-weight:600}
.kb-card-f{font-size:11px;color:var(--gray);margin-top:5px}
.kb-empty{text-align:center;color:var(--bluegray);padding:14px;font-size:13px}
/* gantt */
.gantt{min-width:680px}
.gantt-scale{display:flex;border-bottom:1px solid var(--line);margin-bottom:6px;position:relative;height:22px}
.gantt-lbl-sp,.gantt-lbl{width:150px;flex:none;font-size:12px}
.gantt-lbl b{color:var(--navy)}.gantt-lbl .mut{margin-left:6px}
.gantt-track{position:relative;flex:1;height:22px}
.gantt-m{position:absolute;font-size:10.5px;color:var(--gray);font-weight:700;transform:translateX(-2px)}
.gantt-row{display:flex;align-items:center;height:30px}
.gantt-bar{position:absolute;top:5px;height:20px;border-radius:5px;display:flex;align-items:center;padding:0 7px;color:#fff;font-size:10.5px;font-weight:700;box-shadow:var(--shadow);overflow:hidden}
.gantt-bar.pr{background:repeating-linear-gradient(45deg,#F5C842,#F5C842 6px,#E0A92E 6px,#E0A92E 12px)!important;top:7px;height:16px}
.gb-txt{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gantt-hoy{position:absolute;top:0;bottom:0;width:2px;background:var(--red);z-index:2}
/* calendario periodos */
.cd-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.cd-mode{display:flex;gap:6px}
.cd-mbtn{padding:7px 13px;border-radius:8px;font-weight:700;font-size:13px;background:var(--off);color:var(--gray);display:flex;align-items:center;gap:6px}
.cd-mbtn .ic{width:15px;height:15px}.cd-mbtn.active{background:var(--blue);color:#fff}
.cd-legend{display:flex;gap:14px;margin-bottom:10px;font-size:12px;font-weight:700}
.cd-legend .lg{display:flex;align-items:center;gap:5px}.cd-legend .lg::before{content:'';width:13px;height:13px;border-radius:4px;display:inline-block}
.cd-legend .fest::before{background:var(--red)}.cd-legend .vac::before{background:var(--gold)}.cd-legend .wknd::before{background:var(--bluegray)}
.cd-wrap{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:14px;max-height:420px;overflow-y:auto}
.cd-month{border:1px solid var(--line);border-radius:10px;padding:10px}
.cd-mh{font-weight:800;color:var(--navy);text-align:center;margin-bottom:6px;font-size:13px}
.cd-dow{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;font-size:10px;color:var(--gray);font-weight:700}
.cd-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-top:3px}
.cd-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:11.5px;border-radius:5px;cursor:pointer;font-weight:600}
.cd-day:hover{outline:1.5px solid var(--blue)}
.cd-day.fest{background:var(--red);color:#fff}.cd-day.vac{background:var(--gold);color:#0B0B0C}
.cd-day.wknd{background:var(--off);color:var(--bluegray);cursor:default}
.cd-day.out{opacity:.25;cursor:default}.cd-empty{aspect-ratio:1}
/* semáforo */
.sem-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}
.sem-card{border:1px solid var(--line);border-left:4px solid var(--green);border-radius:10px;padding:12px 14px;cursor:pointer;transition:.15s;background:#fff}
.sem-card:hover{box-shadow:var(--shadow);transform:translateY(-1px)}
.sem-card.amber{border-left-color:var(--amber)}.sem-card.red{border-left-color:var(--red)}
.sem-top{display:flex;align-items:center;gap:7px;font-weight:800;color:var(--navy)}
.sem-top .mut{margin-left:auto;font-size:12px}
.sem-dot{width:11px;height:11px;border-radius:50%}.sem-dot.green{background:var(--green)}.sem-dot.amber{background:var(--amber)}.sem-dot.red{background:var(--red)}
.sem-cp{font-size:12px;color:var(--blue);font-weight:700;margin:3px 0 6px}
.sem-iss{list-style:none;padding:0;margin:0;font-size:12px}
.sem-iss li{padding:3px 0 3px 16px;position:relative;color:var(--ink)}
.sem-iss li::before{content:'●';position:absolute;left:0;font-size:9px;top:5px}
.sem-iss li.red::before{color:var(--red)}.sem-iss li.amber::before{color:var(--amber)}
.sem-ok{color:var(--green);font-weight:700;font-size:12.5px}
/* adjuntos */
.adj-row{display:flex;align-items:center;gap:10px;padding:9px 12px;border:1px solid var(--line);border-radius:9px;margin-bottom:8px;background:var(--off2)}
.adj-ic{width:20px;height:20px;color:var(--blue)}.adj-ic .ic{width:20px;height:20px}
.adj-info{flex:1}.adj-info b{color:var(--navy)}
.imp-paste{width:100%;min-height:120px;border:1.5px solid var(--line);border-radius:9px;padding:10px;font-family:monospace;font-size:12px;outline:none}
.imp-paste:focus{border-color:var(--blue)}
.bonif-trab{margin-top:16px;border-top:1px dashed var(--line);padding-top:14px}
.bonif-trab h4{display:flex;align-items:center;gap:7px;font-family:var(--fh);color:var(--navy);margin:0 0 10px}
.bonif-trab h4 .ic{width:17px;height:17px}

/* ===== ENS / seguridad ===== */
.ens-gate{position:fixed;inset:0;z-index:200;background:linear-gradient(145deg,#017BC4,#1B5FA4 62%,#0A4F8C);display:flex;align-items:center;justify-content:center;padding:20px;overflow:hidden}
.gate-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.gate-orb{position:absolute;border-radius:50%;filter:blur(60px)}
.gate-orb.a{width:520px;height:520px;background:#36B6E8;opacity:.42;top:-200px;right:-120px;animation:floatA 11s ease-in-out infinite}
.gate-orb.b{width:420px;height:420px;background:#F5C842;opacity:.20;bottom:-180px;left:-100px;animation:floatB 13s ease-in-out infinite}
.gate-orb.c{width:340px;height:340px;background:#0A4F8C;opacity:.5;bottom:-120px;right:18%;animation:floatA 15s ease-in-out infinite}
.gate-ring{position:absolute;border-radius:50%;border:1.5px solid rgba(255,255,255,.12)}
.gate-ring.r1{width:460px;height:460px;top:-140px;left:-120px;animation:spin 34s linear infinite}
.gate-ring.r2{width:300px;height:300px;bottom:-90px;right:6%;border-style:dashed;border-color:rgba(245,200,66,.18);animation:spin 26s linear infinite reverse}
.gate-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;gap:46px;align-items:center;width:min(940px,100%)}
.gate-brand{color:#fff;animation:fadeUp .6s cubic-bezier(.2,.7,.2,1)}
.gate-lock{display:flex;align-items:center;gap:0;margin-bottom:26px}
.gate-wm{font-family:var(--fh);font-weight:800;font-size:30px;color:#fff;letter-spacing:.01em;line-height:1}
.gate-wm i{font-weight:600;font-style:normal;opacity:.92}
.gate-sep{width:2px;height:26px;background:rgba(255,255,255,.5);margin:0 13px}
.gate-lab{font-family:var(--fh);font-weight:800;font-style:italic;font-size:30px;color:var(--gold);letter-spacing:.02em;line-height:1}
.gate-h1{font-family:var(--fh);font-weight:800;font-size:42px;line-height:1.04;margin:0 0 16px;letter-spacing:-.01em}
.gate-tag{font-family:var(--fb);font-weight:500;font-size:15px;line-height:1.55;color:#E2EFF9;max-width:430px;margin:0 0 22px}
.gate-pills{display:flex;gap:9px;flex-wrap:wrap;margin-bottom:30px}
.gate-pill{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.2);border-radius:30px;padding:7px 14px;font-family:var(--fb);font-weight:700;font-size:12.5px;color:#fff;backdrop-filter:blur(4px)}
.gate-pill .ic{width:15px;height:15px;color:var(--gold)}
.gate-brandfoot{font-family:var(--fb);font-weight:600;font-size:12px;color:#BFDCF0;letter-spacing:.01em}
.ens-card{background:#fff;border-radius:20px;padding:34px 30px;width:min(380px,100%);text-align:center;box-shadow:0 30px 80px rgba(4,30,55,.45);animation:modalUp .42s cubic-bezier(.2,.7,.2,1)}
.acc-card-h{display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.acc-wm{font-family:var(--fh);font-weight:800;font-size:21px;color:var(--blue);line-height:1}
.acc-wm i{font-weight:600;font-style:normal;color:var(--ink);opacity:.85}
.acc-sep{width:2px;height:18px;background:var(--line);margin:0 10px}
.acc-lab{font-family:var(--fh);font-weight:800;font-style:italic;font-size:21px;color:var(--gold2);line-height:1}
.ens-logo{width:60px;height:60px;border-radius:16px;background:linear-gradient(145deg,var(--blue),var(--mid));display:flex;align-items:center;justify-content:center;margin:0 auto 14px}
.ens-logo .ic{width:30px;height:30px;color:#fff}
.ens-card h2{font-family:var(--fh);font-weight:800;font-size:25px;color:var(--navy);margin:0}
.ens-sub{color:var(--gray);font-weight:600;margin:5px 0 18px;font-size:13.5px}
.ens-pin{width:100%;padding:14px;border:1.5px solid var(--line);border-radius:12px;font-size:22px;text-align:center;letter-spacing:.3em;outline:none;margin-bottom:10px;transition:.15s}
.ens-pin:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(1,123,196,.12)}
.ens-msg{color:var(--red);font-weight:700;font-size:13px;min-height:18px;margin-bottom:8px}
.ens-skip{display:block;width:100%;margin-top:12px;color:var(--gray);font-size:12.5px;font-weight:600;text-decoration:underline}
.ens-note{font-size:11.5px;color:var(--gray);margin-top:12px;line-height:1.4}
.ens-foot{margin-top:18px;padding-top:14px;border-top:1px solid var(--line);font-size:11px;color:var(--gray);font-weight:600;display:flex;align-items:center;justify-content:center;gap:6px}
.ens-foot .ic{width:14px;height:14px;color:var(--green)}
@media(max-width:820px){.gate-grid{grid-template-columns:1fr;gap:26px;max-width:420px}.gate-brand{text-align:center}.gate-h1{font-size:32px}.gate-lock,.gate-pills{justify-content:center}.gate-tag{margin-inline:auto}}
.ens-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}
.ens-item{border:1px solid var(--line);border-radius:11px;padding:14px;background:var(--off2)}
.ens-item b{display:flex;align-items:center;gap:7px;color:var(--navy);font-size:14px}
.ens-item b .ic{width:16px;height:16px;color:var(--blue)}
.ens-item p{font-size:12.5px;color:var(--gray);margin:7px 0 10px;line-height:1.45}
.ens-log{max-height:280px;overflow-y:auto;border:1px solid var(--line);border-radius:9px;background:var(--off2)}
.ens-log-row{display:grid;grid-template-columns:160px 130px 1fr;gap:10px;padding:7px 12px;border-bottom:1px solid var(--line);font-size:12px}
.ens-log-row:last-child{border-bottom:none}
.ens-log-row .t{color:var(--gray);font-family:monospace;font-size:11px}
.ens-log-row .a{font-weight:700;color:var(--blue)}
.ens-log-row .d{color:var(--ink)}
/* ===== IT6 · ROLES & MULTIUSUARIO ===== */
.tb-user{margin-left:8px}
.tb-user-btn{display:flex;align-items:center;gap:9px;padding:5px 10px 5px 5px;border-radius:30px;background:var(--off2);border:1px solid var(--line);cursor:pointer;transition:.18s}
.tb-user-btn:hover{border-color:var(--blue);box-shadow:0 3px 12px rgba(1,123,196,.14)}
.tb-av{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-family:var(--fh);font-size:15px;flex:0 0 auto}
.tb-uinfo{display:flex;flex-direction:column;line-height:1.1;text-align:left}
.tb-un{font-weight:800;font-size:12.5px;color:var(--navy)}
.tb-ur{font-weight:700;font-size:10.5px;text-transform:uppercase;letter-spacing:.04em}
.nav-ro{margin-left:auto;font-size:11px;opacity:.6}
.acc-card{width:min(420px,100%)}
.acc-list{display:flex;flex-direction:column;gap:9px;margin-bottom:6px}
.acc-user{display:flex;align-items:center;gap:12px;padding:11px 13px;border:1.5px solid var(--line);border-radius:13px;background:#fff;cursor:pointer;transition:.18s;text-align:left;width:100%}
.acc-user:hover{border-color:var(--blue);background:var(--off2);transform:translateY(-1px)}
.acc-av{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-family:var(--fh);font-size:20px;flex:0 0 auto}
.acc-info{display:flex;flex-direction:column;line-height:1.2;flex:1}
.acc-info b{color:var(--navy);font-size:15px}
.acc-rol{font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.03em}
.acc-pin{text-align:left}
.acc-back{background:none;border:none;color:var(--blue);font-weight:700;font-size:13px;cursor:pointer;padding:0 0 10px}
.acc-sel{display:flex;align-items:center;gap:12px;padding:10px;background:var(--off2);border-radius:12px;margin-bottom:12px}
.usr-modal{text-align:center;padding:6px 4px}
.usr-modal-av{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-family:var(--fh);font-size:30px;margin:0 auto 12px}
.usr-modal-nm{font-family:var(--fh);font-weight:800;font-size:22px;color:var(--navy)}
.usr-modal-rol{font-weight:800;font-size:13px;text-transform:uppercase;letter-spacing:.04em;margin-top:2px}
.usr-modal-email{color:var(--gray);font-size:13px;margin-top:4px}
.usr-modal-desc{color:var(--ink);font-size:13px;line-height:1.5;margin:14px auto 0;max-width:340px}
.usr-modal-cif{margin-top:10px;font-weight:700;color:var(--navy);font-size:13px}
.usr-av{width:26px;height:26px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:13px;margin-right:8px;vertical-align:middle}
.usr-rolchip{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-weight:700;font-size:12px}
.usr-rolchip .ic{width:13px;height:13px}
.usr-state{font-weight:700;font-size:12px;padding:2px 9px;border-radius:14px}
.usr-state.on{background:rgba(10,143,91,.12);color:#0A8F5B}
.usr-state.off{background:rgba(120,120,120,.14);color:var(--gray)}
.usr-tmp{font-size:10px;font-weight:800;color:#E0A92E;background:rgba(245,200,66,.18);padding:2px 7px;border-radius:10px;margin-left:6px;text-transform:uppercase;letter-spacing:.03em}
.roles-legend{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:10px}
.rl-item{display:flex;flex-direction:column;gap:3px;padding:11px 13px;border:1px solid var(--line);border-radius:11px;background:var(--off2);position:relative;padding-left:22px}
.rl-dot{position:absolute;left:11px;top:15px;width:9px;height:9px;border-radius:50%}
.rl-item b{color:var(--navy);font-size:13.5px}
.rl-item span{font-size:11.5px;color:var(--gray);line-height:1.4}

/* ===== IT4 · FINALIZACIÓN / TRANSFORMACIÓN INDEFINIDO ===== */
.fin-box{margin-top:18px;border:1.5px solid rgba(10,143,91,.3);border-radius:14px;padding:16px;background:linear-gradient(180deg,rgba(10,143,91,.05),rgba(10,143,91,.01))}
.fin-check{display:flex;align-items:center;gap:9px;font-weight:700;color:var(--navy);cursor:pointer;font-size:13.5px}
.fin-check input{width:17px;height:17px;accent-color:#0A8F5B}
.fin-status{font-weight:700;font-size:12.5px;padding:7px 12px;border-radius:9px}
.fin-status.ok{background:rgba(10,143,91,.12);color:#0A8F5B}
.fin-status.neutral{background:var(--off2);color:var(--gray)}
.ind-badge{display:inline-flex;align-items:center;gap:5px;background:rgba(10,143,91,.12);color:#0A8F5B;font-weight:800;font-size:11.5px;padding:3px 9px;border-radius:20px}
.ind-badge .ic{width:13px;height:13px}

/* ===== IT5 · FICHAS DE RECLUTAMIENTO PREMIUM ===== */
.fcard{display:flex;gap:18px;padding:18px;border:1px solid var(--line);border-radius:16px;background:#fff;margin-bottom:14px;
  box-shadow:0 2px 10px rgba(0,43,74,.04);transition:.22s cubic-bezier(.2,.7,.2,1);position:relative;overflow:hidden;
  opacity:0;transform:translateY(10px);animation:fcardIn .5s forwards}
@keyframes fcardIn{to{opacity:1;transform:none}}
.fcard::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--bluegray);transition:.22s}
.fcard.is-ok::before{background:#0A8F5B}
.fcard:hover{box-shadow:0 12px 34px rgba(1,123,196,.14);transform:translateY(-2px);border-color:var(--blue)}
.fcard-side{display:flex;flex-direction:column;align-items:center;gap:8px;flex:0 0 auto;width:78px}
.fcard-avatar{position:relative;width:64px;height:64px}
.fcard-ring{position:absolute;inset:0;transform:rotate(-90deg)}
.fcard-ring .rg-bg{fill:none;stroke:var(--off);stroke-width:5}
.fcard-ring .rg-fg{fill:none;stroke:var(--rc);stroke-width:5;stroke-linecap:round;transition:stroke-dashoffset .8s cubic-bezier(.2,.7,.2,1)}
.fcard-ini{position:absolute;inset:7px;border-radius:50%;background:linear-gradient(145deg,var(--blue),var(--mid));color:#fff;
  display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-weight:800;font-size:20px}
.fcard-pct{position:absolute;bottom:-7px;left:50%;transform:translateX(-50%);background:#fff;border-radius:10px;padding:0 5px;
  font-size:10.5px;font-weight:800;box-shadow:0 1px 4px rgba(0,0,0,.12)}
.fcard-aux{font-size:11px;font-weight:800;color:var(--gray);letter-spacing:.03em}
.fcard-main{flex:1;min-width:0}
.fcard-top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap}
.fcard-name h4{margin:0;font-family:var(--fh);font-weight:800;font-size:18px;color:var(--navy);line-height:1.1}
.fcard-sub{font-size:12px;color:var(--gray);margin-top:3px}
.fcard-tags{display:flex;gap:6px;flex-wrap:wrap}
.fcard-state{font-size:11px;font-weight:800;padding:3px 10px;border-radius:20px;text-transform:uppercase;letter-spacing:.03em}
.fcard-state.ok{background:rgba(10,143,91,.12);color:#0A8F5B}
.fcard-state.pend{background:rgba(245,200,66,.18);color:#B07C00}
.fcard-state.baja{background:rgba(224,86,59,.12);color:#E0563B}
.fcard-state.pr{background:rgba(1,123,196,.12);color:var(--blue)}
.fcard-state.noel{background:rgba(224,86,59,.12);color:#E0563B}
.fcard-ind{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:800;padding:3px 10px;border-radius:20px;background:rgba(10,143,91,.12);color:#0A8F5B}
.fcard-ind .ic{width:12px;height:12px}
.fcard-docs{display:flex;gap:8px;flex-wrap:wrap;margin-top:13px}
.fdoc{display:flex;align-items:center;gap:7px;padding:7px 12px;border-radius:10px;border:1.5px solid var(--line);
  background:var(--off2);cursor:pointer;font-size:12.5px;font-weight:700;color:var(--gray);transition:.16s}
.fdoc:hover{border-color:var(--blue);color:var(--navy)}
.fdoc .fdoc-ic .ic{width:15px;height:15px}
.fdoc.on{background:rgba(10,143,91,.1);border-color:rgba(10,143,91,.5);color:#0A8F5B}
.fcard-valid{display:flex;flex-direction:column;gap:5px;margin-top:11px}
.fcard-valid .vmsg{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:5px 9px;border-radius:8px}
.fcard-valid .vmsg .ic{width:14px;height:14px;flex:0 0 auto}
.fcard-valid .vmsg.a{background:rgba(245,200,66,.14);color:#B07C00}
.fcard-valid .vmsg.r{background:rgba(224,86,59,.12);color:#E0563B}
.fcard-actions{display:flex;align-items:center;gap:8px;margin-top:13px}
.fcard-actions .btn b{color:var(--blue)}
.fcard-prog{flex:1;height:6px;border-radius:6px;background:var(--off);overflow:hidden;min-width:60px}
.fcard-prog-bar{display:block;height:100%;border-radius:6px;transition:width .8s cubic-bezier(.2,.7,.2,1)}
@media(max-width:560px){.fcard{flex-direction:column}.fcard-side{flex-direction:row;width:auto;gap:14px}}

/* ===== IT2 · ENVÍO FICHA BONIFICACIÓN ===== */
.send-opts{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}
.send-opt{display:flex;align-items:center;gap:11px;padding:14px;border:1.5px solid var(--line);border-radius:13px;background:var(--off2);cursor:pointer;transition:.18s;text-align:left}
.send-opt:hover{border-color:var(--blue);background:#fff;box-shadow:0 4px 14px rgba(1,123,196,.12)}
.send-opt .ic{width:24px;height:24px;color:var(--blue);flex:0 0 auto}
.send-opt b{display:block;color:var(--navy);font-size:13.5px}
.send-opt span{font-size:11.5px;color:var(--gray)}
@media(max-width:520px){.send-opts{grid-template-columns:1fr}}

/* ===== IT3 · P&L / PIPELINE ECONÓMICO ===== */
.pyl-pipe{display:flex;flex-direction:column;gap:10px}
.pyl-pipe-row{display:grid;grid-template-columns:200px 1fr 220px;gap:14px;align-items:center}
.pyl-pipe-lbl{font-weight:700;color:var(--navy);font-size:13px;display:flex;align-items:center;gap:7px}
.pyl-dot{width:10px;height:10px;border-radius:50%;flex:0 0 auto}
.pyl-pipe-bar{height:22px;background:var(--off);border-radius:7px;overflow:hidden}
.pyl-pipe-fill{height:100%;border-radius:7px;min-width:2px;transition:width .8s cubic-bezier(.2,.7,.2,1)}
.pyl-pipe-val{font-weight:800;color:var(--navy);font-size:13px;text-align:right}
.pyl-pipe-val .mut{font-weight:600;font-size:11.5px;margin-left:4px}
.pyl-pl td{padding:7px 12px;font-size:13px}
.pyl-pl .r{text-align:right;font-variant-numeric:tabular-nums}
.pyl-pl .pyl-sec td{background:var(--off2);font-weight:800;color:var(--blue);font-size:11px;text-transform:uppercase;letter-spacing:.04em;padding-top:10px}
.pyl-pl .pyl-tot td{border-top:1.5px solid var(--line);font-weight:800;color:var(--navy)}
.pyl-pl .pyl-margen td{background:rgba(10,143,91,.08);font-weight:800;font-size:15px;color:#0A8F5B;border-top:2px solid #0A8F5B;border-bottom:2px solid #0A8F5B}
.pyl-pl .pyl-margen.neg td{background:rgba(224,86,59,.08);color:#E0563B;border-color:#E0563B}
.pyl-pct{font-size:12px;opacity:.8;margin-left:8px}
@media(max-width:640px){.pyl-pipe-row{grid-template-columns:1fr;gap:5px}.pyl-pipe-val{text-align:left}}

/* ===== IT-R3 · DETALLE EXPEDIENTE HISTÓRICO ===== */
.exd-wrap{max-height:62vh;overflow-y:auto;padding-right:6px;display:flex;flex-direction:column;gap:14px}
.exd-sec{border:1px solid var(--line);border-radius:12px;padding:12px 14px;background:var(--off2)}
.exd-h{font-family:var(--fh);font-weight:800;font-size:15px;color:var(--blue);display:flex;align-items:center;gap:8px;margin-bottom:10px}
.exd-h .ic{width:16px;height:16px}
.exd-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px 18px}
.exd-grid>div{display:flex;flex-direction:column;font-size:13px}
.exd-grid span{color:var(--gray);font-size:11px;text-transform:uppercase;letter-spacing:.04em}
.exd-grid b{color:var(--navy)}
.exd-chips{display:flex;flex-wrap:wrap;gap:6px}
.exd-chip{font-size:12px;padding:5px 10px;border-radius:7px;font-weight:600}
.exd-chip.ok{background:rgba(10,143,91,.12);color:#0A8F5B}
.exd-chip.no{background:#fff;color:var(--gray);border:1px dashed var(--line)}
.exd-tbl{width:100%;border-collapse:collapse;font-size:12.5px}
.exd-tbl th{text-align:left;color:var(--gray);font-weight:700;padding:5px 8px;border-bottom:1px solid var(--line)}
.exd-tbl td{padding:5px 8px;border-bottom:1px solid var(--line);color:var(--navy)}
.exd-docs{display:flex;flex-direction:column;gap:8px}
.exd-doc{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--line);border-radius:10px;padding:9px 12px}
.exd-doc-ic{width:34px;height:34px;border-radius:8px;background:rgba(1,123,196,.1);color:var(--blue);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.exd-doc-ic .ic{width:17px;height:17px}
.exd-doc-m{display:flex;flex-direction:column;flex:1;min-width:0;font-size:13px}
.exd-doc-m b{color:var(--navy);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.exd-doc-act{display:flex;gap:6px;flex:0 0 auto}
@media(max-width:560px){.exd-grid{grid-template-columns:1fr}}

/* ===== IT-R4 · FICHA RECLUTAMIENTO ENRIQUECIDA ===== */
.fcard-meta{display:flex;flex-wrap:wrap;gap:6px 14px;margin:8px 0 4px}
.fmeta{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--gray)}
.fmeta .ic{width:13px;height:13px;opacity:.8}
.fmeta.warn{color:#E0A92E;font-weight:700}
.fmeta.mut{color:var(--bluegray)}
.fcard-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:10px 0}
.fstat{display:flex;align-items:center;gap:8px;background:var(--off2);border-radius:10px;padding:8px 10px}
.fstat-ic{display:flex;flex:0 0 auto}.fstat-ic .ic{width:18px;height:18px}
.fstat-tx{display:flex;flex-direction:column;line-height:1.15}
.fstat-tx b{font-family:var(--fh);font-weight:800;font-size:16px;color:var(--navy)}
.fstat-tx span{font-size:10.5px;color:var(--gray);text-transform:uppercase;letter-spacing:.03em}
.fcard-eval{display:flex;align-items:center;gap:10px;margin:8px 0}
.fcard-eval-l{font-size:11px;font-weight:700;color:var(--gray);text-transform:uppercase;letter-spacing:.04em;flex:0 0 auto}
.fcard-eval-bar{flex:1;height:8px;background:var(--off);border-radius:5px;overflow:hidden}
.fcard-eval-bar span{display:block;height:100%;border-radius:5px;transition:width .6s}
.fcard-eval-v{font-size:12px;font-weight:800;color:var(--navy);flex:0 0 auto}
@media(max-width:560px){.fcard-stats{grid-template-columns:repeat(2,1fr)}}

/* ===== IT-R5 · BUSCADOR GLOBAL ===== */
.tb-search-btn{display:flex;align-items:center;gap:7px;padding:7px 12px;border-radius:30px;background:var(--off2);border:1px solid var(--line);cursor:pointer;color:var(--gray);font-weight:600;font-size:13px;transition:.18s;margin-left:auto}
.tb-search-btn:hover{border-color:var(--blue);color:var(--navy);box-shadow:0 3px 12px rgba(1,123,196,.14)}
.tb-search-btn .ic{width:15px;height:15px}
.tb-search-btn kbd{font-family:var(--fh);font-size:11px;background:#fff;border:1px solid var(--line);border-radius:5px;padding:1px 6px;color:var(--gray)}
.gs-overlay{position:fixed;inset:0;z-index:9000;background:rgba(8,28,44,.5);backdrop-filter:blur(4px);display:flex;align-items:flex-start;justify-content:center;padding-top:11vh;animation:gsfade .18s ease}
@keyframes gsfade{from{opacity:0}to{opacity:1}}
.gs-box{width:min(680px,92vw);background:#fff;border-radius:18px;box-shadow:0 24px 70px rgba(8,28,44,.4);overflow:hidden;animation:gspop .22s cubic-bezier(.2,.9,.3,1.2)}
@keyframes gspop{from{opacity:0;transform:translateY(-14px) scale(.98)}to{opacity:1;transform:none}}
.gs-input-wrap{display:flex;align-items:center;gap:12px;padding:16px 18px;border-bottom:1px solid var(--line)}
.gs-input-wrap .ic{width:20px;height:20px;color:var(--blue);flex:0 0 auto}
.gs-input{flex:1;border:none;outline:none;font-size:17px;font-family:var(--fb);color:var(--navy);background:transparent}
.gs-input::placeholder{color:var(--bluegray)}
.gs-input-wrap kbd{font-family:var(--fh);font-size:11px;background:var(--off2);border:1px solid var(--line);border-radius:5px;padding:2px 7px;color:var(--gray)}
.gs-body{max-height:56vh;overflow-y:auto;padding:8px}
.gs-hint{padding:30px 18px;text-align:center;color:var(--gray);font-size:14px}
.gs-group{margin-bottom:6px}
.gs-gh{display:flex;align-items:center;gap:7px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--gray);padding:10px 12px 6px}
.gs-gh .ic{width:14px;height:14px;color:var(--blue)}
.gs-item{display:flex;align-items:center;gap:12px;width:100%;text-align:left;background:transparent;border:none;border-radius:11px;padding:10px 12px;cursor:pointer;transition:.12s}
.gs-item:hover{background:var(--off2)}
.gs-ico{width:34px;height:34px;border-radius:9px;background:rgba(1,123,196,.1);color:var(--blue);display:flex;align-items:center;justify-content:center;flex:0 0 auto;font-family:var(--fh);font-weight:800}
.gs-ico .ic{width:17px;height:17px}
.gs-ico.p{background:var(--blue);color:#fff}
.gs-tx{display:flex;flex-direction:column;flex:1;min-width:0}
.gs-tx b{color:var(--navy);font-size:14.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gs-tx span{color:var(--gray);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gs-fase{font-size:11px;font-weight:700;color:var(--gray);background:var(--off2);border-radius:20px;padding:4px 10px;flex:0 0 auto}
@media(max-width:680px){.tb-search-btn span,.tb-search-btn kbd{display:none}}

/* ===== IT-R6 · FILTROS BONIFICACIONES ===== */
.eco-hl{background:rgba(245,200,66,.16)!important}
.eco-hl td:first-child{box-shadow:inset 3px 0 0 var(--gold)}

/* ===== IT-S1 · FIRMAS ===== */
.firma-cap{display:flex;flex-direction:column;gap:12px}
.firma-tabs{display:flex;gap:8px}
.firma-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:7px;padding:9px;border-radius:10px;border:1.5px solid var(--line);background:var(--off2);cursor:pointer;font-weight:700;font-size:13px;color:var(--gray)}
.firma-tab.active{background:var(--blue);color:#fff;border-color:var(--blue)}
.firma-pane{margin-top:4px}
.firma-tab .ic{width:15px;height:15px}
.firma-canvas{width:100%;height:200px;border:2px dashed var(--bluegray);border-radius:12px;background:#fff;touch-action:none;cursor:crosshair}
.firma-hint{font-size:12px;color:var(--gray);margin:6px 0}
.firma-drop{display:flex;flex-direction:column;align-items:center;gap:8px;padding:28px;border:2px dashed var(--bluegray);border-radius:12px;color:var(--gray);cursor:pointer;text-align:center}
.firma-drop.over{border-color:var(--blue);background:rgba(1,123,196,.06)}
.firma-drop .ic{width:30px;height:30px;color:var(--blue)}
.firma-preview{max-width:100%;max-height:160px;margin-top:12px;border:1px solid var(--line);border-radius:10px;background:#fff;padding:8px}
.firma-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.firma-slot{border:1.5px solid var(--line);border-radius:14px;padding:14px;background:var(--off2);display:flex;flex-direction:column;gap:8px;transition:.15s}
.firma-slot.has{border-color:var(--blue);background:rgba(1,123,196,.04)}
.firma-slot-h{display:flex;align-items:center;gap:7px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;color:var(--gray)}
.firma-slot-h .ic{width:14px;height:14px;color:var(--blue)}
.firma-slot-prev{height:64px;display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid var(--line);border-radius:9px}
.firma-slot-prev img{max-height:56px;max-width:100%}
.firma-slot-nm{font-size:13px;font-weight:700;color:var(--navy);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ===== IT-S2 · P&L MATRIZ MENSUAL ===== */
.pyl-matriz{font-size:12.5px;min-width:760px}
.pyl-matriz th,.pyl-matriz td{padding:7px 10px;white-space:nowrap}
.pyl-matriz thead th{background:var(--navy);color:#fff;font-family:var(--fh);font-weight:700;text-align:right;position:sticky;top:0}
.pyl-matriz thead th.pyl-concepto-h{text-align:left;border-top-left-radius:8px}
.pyl-matriz .pyl-yr{display:block;font-size:9px;opacity:.6;font-weight:400}
.pyl-matriz td.r,.pyl-matriz th.r{text-align:right}
.pyl-concepto{font-weight:600;color:var(--navy);text-align:left!important;position:sticky;left:0;background:#fff}
.pyl-tcol{background:rgba(1,123,196,.06);font-weight:700}
.pyl-secrow td{background:var(--navy);color:var(--gold);font-family:var(--fh);font-weight:700;font-size:11px;letter-spacing:.06em;text-transform:uppercase}
.pyl-secrow td:first-child{position:sticky;left:0;background:var(--navy)}
.pyl-subtot td{background:var(--soft);font-weight:800;color:var(--navy);border-top:1.5px solid var(--bluegray)}
.pyl-subtot td:first-child{position:sticky;left:0;background:var(--soft)}
.pyl-margenrow td{background:rgba(10,143,91,.08);font-weight:800;font-family:var(--fh);border-top:2px solid var(--navy)}
.pyl-margenrow td:first-child{position:sticky;left:0;background:rgba(10,143,91,.08);color:var(--navy)}
.pyl-pctrow td{font-size:11px}
.pyl-pctrow td:first-child{position:sticky;left:0;background:#fff}
.pyl-matriz th.pyl-man{box-shadow:inset 0 -3px 0 var(--gold)}
.pyl-matriz-foot{font-size:11px;color:var(--gray);margin-top:8px}
.pyl-man-badge{color:var(--gold)}

/* IT-T1 · filas informativas P&L (bonif tutor empresa, no ingreso) */
.pyl-info td,.pyl-inforow td{color:var(--gray);font-style:italic;background:rgba(245,200,66,.06)}
.pyl-inforow td:first-child{position:sticky;left:0;background:rgba(245,200,66,.06)}

/* ===== IT-R1 · P&L DIMENSIONAL ===== */
.pyl-dims{display:flex;gap:5px;flex-wrap:wrap}
.pyl-dim{display:flex;align-items:center;gap:5px;padding:6px 12px;border-radius:9px;border:1.5px solid var(--line);background:var(--off2);cursor:pointer;font-weight:700;font-size:12.5px;color:var(--gray);transition:.15s}
.pyl-dim:hover{border-color:var(--blue);color:var(--navy)}
.pyl-dim.active{background:var(--blue);color:#fff;border-color:var(--blue)}
.pyl-dim .ic{width:14px;height:14px}
.pyl-dimtbl th.r,.pyl-dimtbl td.r{text-align:right;font-variant-numeric:tabular-nums}
.pyl-dimtbl th{font-size:11px}
.chart-na{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:8px;color:var(--bluegray);font-weight:600;font-size:13px}
.chart-na .ic{width:26px;height:26px}
