*{margin:0;padding:0;box-sizing:border-box}

/* ── CSS Variables (Dark theme = default) ── */
:root{
  --bg:#051620;
  --bg-surface:rgba(7,28,45,0.7);
  --bg-surface2:rgba(7,28,45,0.6);
  --bg-hover:rgba(7,28,45,0.8);
  --accent:#19ffcc;
  --accent-bg:rgba(25,255,204,0.1);
  --accent-border:rgba(25,255,204,0.3);
  --accent-border-soft:rgba(25,255,204,0.08);
  --accent-border-med:rgba(25,255,204,0.12);
  --text:#e2e8f0;
  --text-heading:#f8fafc;
  --text-muted:#7b95a8;
  --text-cell:#cbd5e1;
  --border:rgba(255,255,255,0.04);
  --sidebar-bg:rgba(3,15,25,0.95);
  --sidebar-border:rgba(25,255,204,0.06);
  --search-bg:rgba(5,22,32,0.7);
  --logo-color:#fff;
  --shadow:0 1px 3px rgba(0,0,0,0.3);
}

/* ── Light theme ── */
.light{
  --bg:#f1f5f9;
  --bg-surface:#ffffff;
  --bg-surface2:#f8fafc;
  --bg-hover:#e2e8f0;
  --accent:#0f766e;
  --accent-bg:rgba(15,118,110,0.06);
  --accent-border:rgba(15,118,110,0.25);
  --accent-border-soft:rgba(15,118,110,0.1);
  --accent-border-med:rgba(15,118,110,0.15);
  --text:#1e293b;
  --text-heading:#0f172a;
  --text-muted:#475569;
  --text-cell:#334155;
  --border:rgba(0,0,0,0.07);
  --sidebar-bg:#ffffff;
  --sidebar-border:#e2e8f0;
  --search-bg:#f1f5f9;
  --logo-color:#0f172a;
  --shadow:0 1px 3px rgba(0,0,0,0.08);
}

body{
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  background:var(--bg);
  color:var(--text);
  min-height:100vh;
  display:flex;
  font-size:16px;
}

/* ── Sidebar ── */
#sidebar{
  width:230px;
  height:100vh;
  background:var(--sidebar-bg);
  border-right:1px solid var(--sidebar-border);
  display:flex;
  flex-direction:column;
  position:fixed;
  top:0;
  left:0;
  z-index:100;
  overflow:hidden;
  box-shadow:var(--shadow);
  transition:width 0.2s ease, transform 0.2s ease;
}
#sidebar.collapsed{
  width:52px;
}
#sidebar.collapsed .sidebar-title,
#sidebar.collapsed .nav-group-label,
#sidebar.collapsed .tab,
#sidebar.collapsed .user-info,
#sidebar.collapsed #logoutBtn{
  display:none;
}
#sidebar.collapsed #tabs{padding:20px 4px 0}
#sidebar.collapsed .sidebar-header{justify-content:center;padding:16px 4px}
#sidebar.collapsed .sidebar-footer-actions{justify-content:center}
#sidebar-toggle{
  position:fixed;
  top:14px;
  left:216px;
  width:28px;
  height:28px;
  border:1px solid var(--sidebar-border);
  background:var(--sidebar-bg);
  color:var(--text-muted);
  border-radius:6px;
  cursor:pointer;
  font-size:16px;
  line-height:1;
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:500;
  transition:left 0.2s;
  box-shadow:0 2px 8px rgba(0,0,0,0.15);
}
#sidebar-toggle:hover{color:var(--accent);border-color:var(--accent)}
body.sidebar-collapsed #sidebar-toggle{
  left:38px;
}
body.sidebar-collapsed #content{margin-left:52px;}
.sidebar-header{
  display:flex;
  align-items:center;
  gap:10px;
  padding:32px 16px 16px;
}
.sidebar-header .logo-sm{width:44px;height:auto;color:var(--logo-color)}
.sidebar-header .logo-light{display:none}
.light .sidebar-header .logo-dark{display:none}
.light .sidebar-header .logo-light{display:block}
.sidebar-title{font-size:0.95rem;font-weight:600;color:var(--text-heading);letter-spacing:-0.01em}

/* Sidebar nav */
#tabs{
  display:flex;
  flex-direction:column;
  gap:6px;
  padding:20px 8px 0;
  flex:1;
  overflow-y:auto;
}
.nav-group-label{
  display:block;
  font-size:0.78rem;
  font-weight:600;
  color:var(--text);
  text-transform:uppercase;
  letter-spacing:0.05em;
  padding:16px 12px 6px;
  opacity:1;
}
.nav-group-label:first-child{
  padding-top:4px;
}
#tabs > .tab + details.nav-collapse,
#tabs > details.nav-collapse + .tab,
#tabs > details.nav-collapse + details.nav-collapse{
  margin-top:6px;
}
.tab{
  display:block;
  width:100%;
  padding:9px 12px;
  border:none;
  border-radius:6px;
  background:transparent;
  color:var(--text-muted);
  font-size:0.95rem;
  font-family:'Inter',system-ui,sans-serif;
  cursor:pointer;
  transition:all 0.15s;
  text-align:left;
}
#tabs > .tab{font-size:1.1rem;font-weight:600;padding:11px 12px;margin-bottom:10px}
.tab:hover{color:var(--text);background:var(--accent-bg)}
.tab.active{
  background:var(--accent-bg);
  color:var(--accent);
  font-weight:500;
}

/* Collapsible nav groups */
.nav-collapse{
  display:block;
  margin:0;
}
.nav-collapse[open] .nav-collapse-summary{
  opacity:1;
}
.nav-collapse-summary{
  cursor:pointer;
  list-style:none;
  -webkit-user-select:none;
  user-select:none;
  position:relative;
}
.nav-collapse-summary::-webkit-details-marker{display:none;}
.nav-collapse-summary::after{
  content:'▸';
  position:absolute;
  right:12px;
  font-size:0.7rem;
  transition:transform 0.15s;
}
.nav-collapse[open] > .nav-collapse-summary::after{
  transform:rotate(90deg);
}

/* Sidebar footer */
.sidebar-footer{
  padding:12px 12px 16px;
  border-top:1px solid var(--sidebar-border);
  display:flex;
  flex-direction:column;
  gap:8px;
  margin-top:auto;
}
/* User info block */
.user-info{
  display:flex;
  flex-direction:column;
  gap:6px;
  padding:0 4px;
}
.user-info-name{
  font-size:0.88rem;
  font-weight:600;
  color:var(--text-heading);
}
.user-info-detail{
  font-size:0.75rem;
  color:var(--text-muted);
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.user-info-role{
  font-size:0.7rem;
  color:var(--accent);
  text-transform:uppercase;
  letter-spacing:0.04em;
  font-weight:500;
}
.sidebar-footer-actions{
  display:flex;
  align-items:center;
  gap:8px;
}
#themeToggle{
  padding:6px;
  border:1px solid var(--accent-border);
  border-radius:6px;
  background:transparent;
  color:var(--text);
  cursor:pointer;
  transition:all 0.2s;
  align-self:flex-start;
  width:32px;
  height:32px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
#themeToggle svg{
  display:block;
  stroke:currentColor;
  fill:none;
  width:18px;
  height:18px;
}
#themeToggle:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-bg)}
#themeToggle:focus{outline:none;border-color:var(--accent)}
#themeToggle:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.light #themeToggle{color:#0f172a;border-color:#94a3b8;background:#f1f5f9}
.light #themeToggle:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-bg)}
.light #themeToggle svg{stroke:#0f172a}
.light #themeToggle:hover svg{stroke:var(--accent)}
#iconMoon{display:none}
.light #iconSun{display:none}
.light #iconMoon{display:inline}
#logoutBtn{
  padding:6px 14px;
  border:1px solid var(--accent-border-soft);
  border-radius:6px;
  background:transparent;
  color:var(--accent);
  font-size:0.78rem;
  font-family:'Inter',system-ui,sans-serif;
  cursor:pointer;
  transition:all 0.2s;
}
#logoutBtn:hover{background:var(--accent-bg)}

/* ── Content ── */
#content{
  margin-left:230px;
  flex:1;
  padding:28px;
  min-height:100vh;
}
.tab-panel{display:none}
.tab-panel.active{display:block}
.loading{
  text-align:center;
  padding:60px 20px;
  color:var(--text-muted);
  font-size:1rem;
}

/* ── Date Bar ── */
#date-bar{
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 16px;
  background:var(--bg-surface);
  border:1px solid var(--accent-border-soft);
  border-radius:10px;
  margin-bottom:20px;
  box-shadow:var(--shadow);
  flex-wrap:wrap;
}
.date-label{
  font-size:0.78rem;
  color:var(--text-muted);
  text-transform:uppercase;
  letter-spacing:0.03em;
  font-weight:500;
}
.date-input{
  padding:7px 10px;
  border:1px solid var(--accent-border-med);
  border-radius:6px;
  background:var(--search-bg);
  color:var(--text);
  font-size:0.85rem;
  font-family:'Inter',system-ui,sans-serif;
  cursor:pointer;
}
.date-input:focus{
  outline:none;
  border-color:var(--accent-border);
  box-shadow:0 0 0 2px var(--accent-bg);
}
.date-input::-webkit-calendar-picker-indicator{
  filter:invert(0.7);
  cursor:pointer;
}
.light .date-input::-webkit-calendar-picker-indicator{
  filter:none;
}
.date-range-display{
  min-width:170px;
  text-align:center;
  letter-spacing:0.02em;
  font-weight:500;
}
.date-range-display:hover{
  border-color:var(--accent-border);
}
.date-nav{
  width:28px;
  height:32px;
  padding:0;
  border:1px solid var(--accent-border-med);
  border-radius:6px;
  background:var(--search-bg);
  color:var(--text);
  font-size:1.2rem;
  font-weight:600;
  line-height:1;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.date-nav:hover{
  background:var(--accent-bg, rgba(25,255,204,0.1));
  border-color:var(--accent-border);
  color:var(--accent, #19ffcc);
}
.fp-presets{
  display:flex;
  flex-wrap:wrap;
  gap:4px;
  padding:8px;
  border-bottom:1px solid rgba(255,255,255,0.08);
  background:rgba(255,255,255,0.02);
}
.fp-preset-btn{
  flex:1 1 auto;
  min-width:78px;
  padding:5px 8px;
  border:1px solid rgba(255,255,255,0.1);
  border-radius:4px;
  background:transparent;
  color:#cbd5e1;
  font-size:0.72rem;
  font-family:inherit;
  cursor:pointer;
  white-space:nowrap;
  transition:all 0.15s;
}
.fp-preset-btn:hover{
  background:rgba(25,255,204,0.12);
  border-color:#19ffcc;
  color:#19ffcc;
}
.fp-yearbar{
  display:flex;
  align-items:center;
  gap:8px;
  padding:8px 10px;
  border-bottom:1px solid rgba(255,255,255,0.08);
  background:rgba(255,255,255,0.02);
}
.fp-yearbar-label{
  font-size:0.72rem;
  color:#7b95a8;
  text-transform:uppercase;
  letter-spacing:0.04em;
}
.fp-year-select{
  flex:1;
  padding:5px 8px;
  border:1px solid rgba(255,255,255,0.12);
  border-radius:4px;
  background:rgba(15,26,45,0.8);
  color:#e5edf5;
  font-size:0.82rem;
  font-family:inherit;
  cursor:pointer;
}
.fp-year-select:hover{
  border-color:#19ffcc;
}
.fp-footer{
  padding:8px;
  border-top:1px solid rgba(255,255,255,0.08);
  background:rgba(255,255,255,0.02);
  display:flex;
  justify-content:flex-end;
}
.fp-apply-btn{
  padding:6px 14px;
  border:1px solid #19ffcc;
  border-radius:4px;
  background:rgba(25,255,204,0.15);
  color:#19ffcc;
  font-size:0.78rem;
  font-weight:600;
  font-family:inherit;
  cursor:pointer;
}
.fp-apply-btn:hover{
  background:rgba(25,255,204,0.25);
}
/* Flatpickr dark theme overrides to match dashboard palette */
.flatpickr-calendar{
  background:var(--panel-bg, #0f1a2d) !important;
  border:1px solid var(--accent-border-med) !important;
  box-shadow:0 8px 24px rgba(0,0,0,0.35) !important;
  font-family:'Inter',system-ui,sans-serif !important;
}
.flatpickr-monthSelect-month.selected,
.flatpickr-monthSelect-month.startRange,
.flatpickr-monthSelect-month.endRange{
  background:var(--accent-bg, #19ffcc33) !important;
  color:var(--text) !important;
  border-color:var(--accent-border) !important;
}
.flatpickr-monthSelect-month.inRange{
  background:rgba(25,255,204,0.15) !important;
  color:var(--text) !important;
}
.flatpickr-monthSelect-month:hover{
  background:rgba(25,255,204,0.2) !important;
}
.btn-date{
  padding:7px 18px;
  font-size:0.82rem;
}
.filter-sep{
  width:1px;
  height:24px;
  background:var(--border);
  margin:0 4px;
}
.btn-clear{
  padding:4px 10px;
  border:1px solid var(--border);
  border-radius:5px;
  background:transparent;
  color:var(--text-muted);
  font-size:0.75rem;
  cursor:pointer;
  font-family:'Inter',system-ui,sans-serif;
}
.btn-clear:hover{border-color:var(--accent-border);color:var(--accent)}
.ms-wrap{position:relative;display:inline-block}
.ms-btn{
  padding:5px 12px;border:1px solid var(--border);border-radius:6px;
  background:var(--bg-surface);color:var(--text);font-size:0.78rem;
  cursor:pointer;font-family:'Inter',system-ui,sans-serif;white-space:nowrap;
}
.ms-btn:hover{border-color:var(--accent-border)}
.ms-btn.active{border-color:var(--accent);color:var(--accent)}
.ms-arrow{font-size:0.6rem;margin-left:3px;opacity:0.6}
.ms-panel{
  display:none;position:absolute;top:100%;left:0;z-index:100;
  margin-top:4px;padding:6px 0;min-width:200px;max-height:280px;overflow-y:auto;
  background:var(--sidebar-bg);border:1px solid var(--border);border-radius:8px;
  box-shadow:0 8px 24px rgba(0,0,0,0.3);
}
.ms-panel.open{display:block}
.ms-panel label{
  display:flex;align-items:center;gap:8px;padding:4px 12px;font-size:0.78rem;
  color:var(--text);cursor:pointer;
}
.ms-panel label:hover{background:var(--bg-hover)}
.ms-panel input[type=checkbox]{accent-color:var(--accent);width:14px;height:14px}
.ms-search{
  width:calc(100% - 16px);margin:4px 8px 6px;padding:4px 8px;
  border:1px solid var(--border);border-radius:4px;background:var(--search-bg);
  color:var(--text);font-size:0.75rem;font-family:'Inter',system-ui,sans-serif;
}
.ms-search:focus{outline:none;border-color:var(--accent-border)}
.sync-info{font-size:0.72rem;color:var(--text-muted);white-space:nowrap}
.btn-sync{font-size:0.78rem;padding:4px 10px;border:1px solid var(--accent-border);color:var(--accent);background:transparent;cursor:pointer;border-radius:5px;font-family:'Inter',system-ui,sans-serif}
.btn-sync:hover{background:var(--accent-bg)}
.btn-sync.syncing{opacity:0.5;pointer-events:none}

/* ── Tables ── */
.data-table{
  width:100%;
  border-collapse:collapse;
  font-size:0.88rem;
  margin-top:12px;
  border-radius:8px;
  overflow:hidden;
}
.data-table th{
  background:var(--accent-bg);
  color:var(--accent);
  padding:10px 14px;
  text-align:left;
  font-weight:600;
  font-size:0.75rem;
  text-transform:uppercase;
  letter-spacing:0.05em;
  border-bottom:2px solid var(--accent-border-soft);
  position:sticky;
  top:0;
  white-space:nowrap;
}
.data-table td{
  padding:9px 14px;
  border-bottom:1px solid var(--border);
  color:var(--text-cell);
  transition:background 0.1s;
}
.data-table tbody tr:nth-child(even) td{background:var(--bg-surface2, rgba(255,255,255,0.02))}
.data-table tbody tr:hover td{background:var(--accent-bg)}
.data-table .num{text-align:right;font-variant-numeric:tabular-nums}

/* ── KPI Cards ── */
.kpi-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(180px, 1fr));
  gap:14px;
  margin-bottom:20px;
}
.kpi-card{
  background:var(--bg-surface);
  border:1px solid var(--accent-border-soft);
  border-radius:10px;
  padding:16px 18px;
  box-shadow:var(--shadow);
  transition:border-color 0.2s, transform 0.15s;
}
.kpi-card:hover{border-color:var(--accent-border);transform:translateY(-1px)}
.kpi-card .label{font-size:0.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.05em;font-weight:500}
.kpi-card .value{font-size:1.6rem;font-weight:700;color:var(--text-heading);margin-top:4px;line-height:1.2}
.kpi-card .value .unit{font-size:0.85rem;color:var(--text-muted);font-weight:400}

/* ── Collapsible sections ── */
.section-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:10px 14px;
  background:var(--bg-surface);
  border:1px solid var(--accent-border-soft);
  border-radius:8px;
  cursor:pointer;
  margin-top:8px;
  transition:background 0.2s;
  box-shadow:var(--shadow);
}
.section-header:hover{background:var(--bg-hover)}
.section-header .name{font-weight:500;font-size:1rem}
.section-header .hours{color:var(--text);font-size:0.95rem;font-weight:500;font-variant-numeric:tabular-nums;display:flex;align-items:center;gap:8px}

/* ── Stat chips en headers ── */
.stat-chips{display:inline-flex;align-items:center;gap:6px;flex-wrap:wrap;justify-content:flex-end}
.stat-chip{
  display:inline-flex;align-items:center;gap:5px;
  padding:3px 9px;border-radius:999px;
  background:var(--bg-hover, rgba(255,255,255,0.04));
  border:1px solid var(--border, rgba(255,255,255,0.08));
  font-size:0.78rem;line-height:1.2;
  font-variant-numeric:tabular-nums;
}
.stat-chip__label{color:var(--text-muted);font-weight:400;text-transform:uppercase;letter-spacing:0.03em;font-size:0.7rem}
.stat-chip__value{color:var(--text);font-weight:600}
.stat-chip--pos{border-color:rgba(45,212,168,0.35);background:rgba(45,212,168,0.08)}
.stat-chip--pos .stat-chip__value{color:#2dd4a8}
.stat-chip--neg{border-color:rgba(248,113,113,0.35);background:rgba(248,113,113,0.08)}
.stat-chip--neg .stat-chip__value{color:#f87171}
.stat-chip--warn{border-color:rgba(245,158,11,0.35);background:rgba(245,158,11,0.08)}
.stat-chip--warn .stat-chip__value{color:#f59e0b}
.stat-chip--info{border-color:rgba(59,130,246,0.35);background:rgba(59,130,246,0.08)}
.stat-chip--info .stat-chip__value{color:#3b82f6}
.stat-chip--muted .stat-chip__value{color:var(--text-muted)}
.section-body{display:none;padding:8px 0 8px 16px}
.section-body.open{display:block}

/* ── Search ── */
.search-bar{
  width:100%;
  max-width:400px;
  padding:10px 14px;
  border:1px solid var(--accent-border-med);
  border-radius:10px;
  background:var(--search-bg);
  color:var(--text-heading);
  font-size:0.95rem;
  font-family:'Inter',system-ui,sans-serif;
  margin-bottom:16px;
}
.search-bar:focus{
  outline:none;
  border-color:var(--accent-border);
  box-shadow:0 0 0 3px var(--accent-bg);
}
.search-bar::placeholder{color:var(--text-muted)}

/* ── Bar chart ── */
.bar-row{display:flex;align-items:center;gap:8px;margin:4px 0}
.bar-label{width:220px;text-align:left;font-size:0.82rem;color:var(--text-muted);flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bar-track{flex:1;height:22px;background:var(--border);border-radius:4px;overflow:hidden}
.bar-fill{height:100%;background:linear-gradient(90deg,#0d9b7a,var(--accent));border-radius:4px;transition:width 0.5s}
.bar-value{min-width:100px;font-size:0.82rem;color:var(--text-cell);font-variant-numeric:tabular-nums;white-space:nowrap;text-align:right}

/* ── Pagination ── */
.pager{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  margin-top:16px;
  padding:12px 0;
}
.pager-info{
  font-size:0.82rem;
  color:var(--text-muted);
  font-variant-numeric:tabular-nums;
}
.pager .btn-sm{
  min-width:80px;
  text-align:center;
}
.pager .btn-sm.disabled{
  opacity:0.35;
  cursor:not-allowed;
  pointer-events:none;
}

/* ── Forms & Buttons ── */
.form-label{display:block;font-size:0.72rem;color:var(--text-muted);margin-bottom:4px;text-transform:uppercase;letter-spacing:0.03em}
.form-input{
  padding:8px 10px;
  border:1px solid var(--accent-border-med);
  border-radius:6px;
  background:var(--search-bg);
  color:var(--text);
  font-size:0.85rem;
  font-family:'Inter',system-ui,sans-serif;
}
.form-input:focus{outline:none;border-color:var(--accent-border);box-shadow:0 0 0 2px var(--accent-bg)}
.form-input-sm{padding:5px 8px;font-size:0.78rem}
.user-form{
  background:var(--bg-surface);
  border:1px solid var(--accent-border-soft);
  border-radius:10px;
  padding:16px 20px;
  box-shadow:var(--shadow);
}
.btn-primary{
  padding:8px 16px;
  border:none;
  border-radius:6px;
  background:var(--accent);
  color:#051620;
  font-size:0.82rem;
  font-weight:600;
  font-family:'Inter',system-ui,sans-serif;
  cursor:pointer;
  transition:opacity 0.2s;
}
.btn-primary:hover{opacity:0.85}
.light .btn-primary{color:#ffffff}
.btn-sm{
  padding:4px 10px;
  border:1px solid var(--accent-border-soft);
  border-radius:5px;
  background:transparent;
  font-size:0.75rem;
  font-family:'Inter',system-ui,sans-serif;
  cursor:pointer;
  transition:all 0.15s;
  color:var(--text-muted);
}
.btn-sm:hover{color:var(--text);background:var(--accent-bg)}
.btn-active{color:var(--accent);border-color:var(--accent-border)}
.btn-inactive{color:var(--text-muted);border-color:var(--border)}
.btn-danger{color:#ef4444;border-color:rgba(239,68,68,0.3)}
.btn-danger:hover{background:rgba(239,68,68,0.1)}

/* ── Responsive ── */
@media(max-width:768px){
  #sidebar{
    width:100%;
    min-height:auto;
    position:relative;
    flex-direction:row;
    flex-wrap:wrap;
    border-right:none;
    border-bottom:1px solid var(--sidebar-border);
    box-shadow:none;
  }
  .sidebar-header{padding:12px 16px}
  #tabs{flex-direction:row;flex-wrap:wrap;gap:3px;padding:4px 8px 8px}
  .tab{width:auto;padding:6px 10px;font-size:0.78rem}
  .sidebar-footer{
    flex-direction:row;
    align-items:center;
    padding:8px 12px;
    border-top:none;
    margin-top:0;
  }
  #content{margin-left:0;padding:14px}
  #date-bar{gap:6px;padding:10px 12px}
  .date-input{font-size:0.8rem;padding:6px 8px}
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
  body{flex-direction:column}
}

/* ── AYF: tarjeta empleado con barra proporcional y chips ── */
.ayf-emp-card{
  background:rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:8px;
  margin-bottom:8px;
  overflow:hidden;
  transition:border-color 0.15s;
}
.ayf-emp-card:hover{
  border-color:rgba(25,255,204,0.3);
}
.ayf-emp-header{
  padding:10px 14px;
  cursor:pointer;
  -webkit-user-select:none;
  user-select:none;
}
.ayf-emp-row1{
  display:grid;
  grid-template-columns:180px 1fr 90px;
  align-items:center;
  gap:12px;
}
.ayf-emp-name{
  color:#e5edf5;
  font-weight:500;
  font-size:0.9rem;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.ayf-emp-track{
  position:relative;
  height:18px;
  background:rgba(255,255,255,0.05);
  border-radius:4px;
  overflow:hidden;
}
.ayf-emp-bar{
  position:absolute;
  left:0;top:0;bottom:0;
  background:linear-gradient(90deg,rgba(25,255,204,0.6),#19ffcc);
  border-radius:4px;
  transition:width 0.3s;
}
.ayf-emp-total{
  text-align:right;
  color:#19ffcc;
  font-weight:600;
  font-size:0.95rem;
  font-variant-numeric:tabular-nums;
}
.ayf-emp-chips{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin-top:8px;
  padding-left:192px;
}
.ayf-emp-chip{
  display:inline-flex;
  align-items:center;
  gap:5px;
  padding:3px 8px;
  border:1px solid;
  border-radius:10px;
  font-size:0.72rem;
  font-weight:500;
  background:rgba(255,255,255,0.02);
}
.ayf-emp-chip-dot{
  width:6px;height:6px;border-radius:50%;
  display:inline-block;
}
.ayf-emp-chip-val{
  margin-left:3px;
  opacity:0.85;
  font-variant-numeric:tabular-nums;
}
.ayf-emp-body{
  max-height:0;
  overflow:hidden;
  transition:max-height 0.25s ease;
  padding:0 14px;
}
.ayf-emp-body.open{
  max-height:3000px;
  padding:10px 14px 14px;
  border-top:1px solid rgba(255,255,255,0.06);
}
@media (max-width:720px){
  .ayf-emp-row1{grid-template-columns:1fr 80px}
  .ayf-emp-track{grid-column:1/3;order:3;margin-top:6px}
  .ayf-emp-chips{padding-left:0}
}

/* ── Boton flotante de ayuda por tab ── */
.help-fab{
  position:fixed;
  right:24px;
  bottom:24px;
  width:44px;
  height:44px;
  border-radius:50%;
  background:var(--accent);
  color:#0a0a0a;
  border:none;
  cursor:pointer;
  font-size:20px;
  font-weight:700;
  font-family:serif;
  box-shadow:0 4px 16px rgba(0,0,0,0.4);
  z-index:900;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:transform 0.15s, box-shadow 0.15s;
}
.help-fab:hover{
  transform:translateY(-2px);
  box-shadow:0 6px 20px rgba(25,255,204,0.4);
}
.help-overlay{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0.6);
  z-index:950;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
}
.help-modal{
  background:#0f1519;
  border:1px solid rgba(25,255,204,0.2);
  border-radius:12px;
  max-width:680px;
  width:100%;
  max-height:85vh;
  overflow-y:auto;
  padding:24px 28px;
  box-shadow:0 8px 32px rgba(0,0,0,0.6);
}
.help-modal h2{
  margin:0 0 4px;
  color:var(--accent);
  font-size:1.1rem;
}
.help-modal h3{
  margin:18px 0 6px;
  color:var(--text-heading);
  font-size:0.85rem;
  text-transform:uppercase;
  letter-spacing:0.04em;
}
.help-modal p, .help-modal li{
  color:var(--text-muted);
  font-size:0.85rem;
  line-height:1.55;
  margin:6px 0;
}
.help-modal code{
  background:rgba(25,255,204,0.08);
  color:var(--accent);
  padding:1px 5px;
  border-radius:3px;
  font-size:0.78rem;
}
.help-modal ul{
  margin:6px 0;
  padding-left:18px;
}
.help-close{
  position:absolute;
  top:12px;
  right:16px;
  background:none;
  border:none;
  color:var(--text-muted);
  font-size:22px;
  cursor:pointer;
  line-height:1;
}
.help-close:hover{color:var(--accent)}
