:root{
  --blue-50:#E6F1FB;--blue-100:#B5D4F4;--blue-200:#85B7EB;--blue-600:#185FA5;--blue-800:#0C447C;--blue-900:#042C53;
  --green-50:#EAF3DE;--green-100:#C0DD97;--green-600:#3B6D11;--green-800:#27500A;
  --amber-50:#FAEEDA;--amber-100:#FAC775;--amber-400:#EF9F27;--amber-600:#854F0B;--amber-800:#633806;
  --red-50:#FCEBEB;--red-100:#F7C1C1;--red-600:#A32D2D;--red-800:#791F1F;
  --purple-50:#EEEDFE;--purple-100:#CECBF6;--purple-600:#534AB7;--purple-800:#3C3489;
  --teal-50:#E1F5EE;--teal-600:#0F6E56;--teal-800:#085041;
  --gray-50:#F5F4F0;--gray-100:#E0DED8;--gray-200:#C4C2BA;--gray-400:#888780;--gray-600:#5F5E5A;--gray-900:#1E1E1C;

  --bg:#F2F1ED;
  --surface:#FFFFFF;
  --surface2:#F8F7F4;
  --border:rgba(0,0,0,0.09);
  --border-md:rgba(0,0,0,0.16);
  --text:#18180F;
  --muted:#6B6A64;
  --r-sm:6px;--r-md:10px;--r-lg:14px;--r-xl:18px;
  --shadow-xs:0 1px 2px rgba(0,0,0,0.06);
  --shadow-sm:0 1px 4px rgba(0,0,0,0.09);
  --shadow-md:0 4px 16px rgba(0,0,0,0.10);
  --font:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  --mono:'SF Mono','Fira Code',Consolas,monospace;
  --sb:220px;
  --tb:54px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{font-size:14px;-webkit-text-size-adjust:100%;}
body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.55;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;}
::-webkit-scrollbar{width:5px;height:5px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--gray-200);border-radius:4px;}

/* ── Layout ── */
.layout{display:flex;min-height:100vh;}
.main{margin-left:var(--sb);display:flex;flex-direction:column;min-height:100vh;width:calc(100% - var(--sb));}
.content{padding:1.5rem;flex:1;}

/* ── Sidebar ── */
.sidebar{
  width:var(--sb);background:var(--surface);
  border-right:0.5px solid var(--border);
  position:fixed;top:0;left:0;bottom:0;
  display:flex;flex-direction:column;
  z-index:200;overflow-y:auto;overflow-x:hidden;
}
.sb-logo{
  height:var(--tb);padding:0 1.1rem;
  display:flex;align-items:center;gap:9px;
  font-size:14px;font-weight:700;color:var(--blue-600);
  border-bottom:0.5px solid var(--border);flex-shrink:0;
  line-height:1.25;
}
.sb-logo svg{flex-shrink:0;}
.sb-logo-text{overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;}

.sb-section{
  display:flex;align-items:center;gap:6px;
  padding:1.15rem 1rem 0.4rem;
  font-size:10px;font-weight:700;
  text-transform:uppercase;letter-spacing:0.7px;
  color:var(--gray-400);
}
.sb-section:first-child{padding-top:0.85rem;}
.sb-section svg{width:11px;height:11px;opacity:.7;}

.sb-nav{padding:0.4rem 0.65rem 1rem;flex:1;}
.nav-item{
  display:flex;align-items:center;gap:10px;
  padding:8px 11px;border-radius:var(--r-md);
  color:var(--gray-700,var(--text));font-size:13.5px;font-weight:450;
  transition:all .12s;cursor:pointer;margin-bottom:1px;
  position:relative;white-space:nowrap;
}
.nav-item svg{flex-shrink:0;opacity:.6;width:17px;height:17px;}
.nav-item:hover{background:var(--gray-50);color:var(--text);}
.nav-item:hover svg{opacity:.85;}
.nav-item.active{background:var(--blue-50);color:var(--blue-700,var(--blue-600));font-weight:600;}
.nav-item.active svg{opacity:1;color:var(--blue-600);}
.nav-item.active::before{
  content:'';position:absolute;left:-0.65rem;top:50%;transform:translateY(-50%);
  width:3px;height:18px;border-radius:0 4px 4px 0;background:var(--blue-600);
}
.nav-item-label{flex:1;overflow:hidden;text-overflow:ellipsis;}
.nav-badge{margin-left:auto;background:var(--red-600);color:#fff;font-size:10px;font-weight:700;padding:1px 6px;border-radius:10px;min-width:18px;text-align:center;flex-shrink:0;}

.sb-divider{height:0.5px;background:var(--border);margin:0.5rem 0.8rem;}

/* ── Usuario / footer del sidebar ── */
.sb-user{
  padding:.7rem .8rem;border-top:0.5px solid var(--border);
  display:flex;align-items:center;gap:9px;flex-shrink:0;
  background:var(--surface2);
}
.sb-user .av{flex-shrink:0;}
.sb-user .u-info{overflow:hidden;flex:1;}
.sb-user .u-name{font-size:13px;font-weight:600;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sb-user .u-role-badge{
  display:inline-block;margin-top:2px;font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;
  padding:1px 7px;border-radius:8px;
}
.u-role-badge.role-admin{background:var(--purple-50);color:var(--purple-800);}
.u-role-badge.role-rrhh{background:var(--blue-50);color:var(--blue-800);}
.u-role-badge.role-empleado{background:var(--gray-100);color:var(--gray-600);}
.u-role-badge.role-superadmin{background:var(--amber-50);color:var(--amber-800);}

/* ── Toggle de colapso (desktop) ── */
.sb-collapse-btn{
  width:26px;height:26px;border-radius:7px;border:0.5px solid var(--border-md);
  background:var(--surface);display:flex;align-items:center;justify-content:center;
  color:var(--muted);cursor:pointer;flex-shrink:0;transition:all .12s;
}
.sb-collapse-btn:hover{background:var(--gray-50);color:var(--text);}

/* ── Sidebar colapsado (solo iconos) ── */
.sidebar.collapsed{width:64px;}
.sidebar.collapsed .sb-logo-text,
.sidebar.collapsed .sb-section,
.sidebar.collapsed .nav-item-label,
.sidebar.collapsed .nav-badge,
.sidebar.collapsed .u-info{display:none;}
.sidebar.collapsed .sb-logo{justify-content:center;padding:0;}
.sidebar.collapsed .nav-item{justify-content:center;padding:9px;}
.sidebar.collapsed .nav-item.active::before{left:0;border-radius:0 4px 4px 0;}
.sidebar.collapsed .sb-user{justify-content:center;padding:.7rem 0;}
.sidebar.collapsed ~ .main{margin-left:64px;width:calc(100% - 64px);}

/* ── Topbar ── */
.topbar{
  height:var(--tb);background:var(--surface);
  border-bottom:0.5px solid var(--border);
  display:flex;align-items:center;padding:0 1.5rem;gap:1rem;
  position:sticky;top:0;z-index:100;
}
.topbar-title{font-size:15px;font-weight:600;flex:1;color:var(--text);}
.topbar-date{font-size:12px;color:var(--muted);}
#sb-toggle{display:none;}

/* ── Cards ── */
.card{background:var(--surface);border:0.5px solid var(--border);border-radius:var(--r-lg);padding:1.25rem;}
.card+.card{margin-top:1rem;}
.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.1rem;}
.card-title{font-size:14px;font-weight:600;display:flex;align-items:center;gap:7px;color:var(--text);}
.card-title svg{color:var(--blue-600);flex-shrink:0;}

/* ── Metric cards ── */
.metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(155px,1fr));gap:12px;margin-bottom:1.5rem;}
.metric{background:var(--surface);border:0.5px solid var(--border);border-radius:var(--r-lg);padding:1rem 1.1rem;}
.metric-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:6px;}
.metric-value{font-size:26px;font-weight:700;line-height:1.1;color:var(--text);}
.metric-sub{font-size:11px;color:var(--muted);margin-top:3px;}

/* ── Grids ── */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem;}
.g-main{display:grid;grid-template-columns:1fr 310px;gap:1rem;}
.g-main-wide{display:grid;grid-template-columns:1fr 340px;gap:1rem;}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--r-md);border:0.5px solid var(--border-md);background:transparent;color:var(--text);font-size:13px;font-weight:500;cursor:pointer;transition:all .12s;white-space:nowrap;font-family:var(--font);}
.btn:hover{background:var(--gray-50);}
.btn:active{transform:scale(.98);}
.btn svg{flex-shrink:0;}
.btn-primary{background:var(--blue-600);color:#fff;border-color:var(--blue-600);}
.btn-primary:hover{background:var(--blue-800);}
.btn-success{background:var(--green-600);color:#fff;border-color:var(--green-600);}
.btn-success:hover{background:var(--green-800);}
.btn-danger{background:var(--red-600);color:#fff;border-color:var(--red-600);}
.btn-danger:hover{background:var(--red-800);}
.btn-sm{padding:5px 11px;font-size:12px;}
.btn-xs{padding:3px 9px;font-size:11px;}
.btn-icon{padding:6px;}
.btn-block{width:100%;justify-content:center;}
.btn-lg{padding:13px 30px;font-size:15px;border-radius:var(--r-lg);}

/* Fichar */
.btn-fichar{display:inline-flex;align-items:center;justify-content:center;gap:12px;padding:16px 40px;border-radius:var(--r-xl);border:none;font-size:16px;font-weight:700;cursor:pointer;transition:all .15s;letter-spacing:.2px;}
.btn-fichar:active{transform:scale(.97);}
.bf-entrada{background:var(--blue-600);color:#fff;}
.bf-entrada:hover{background:var(--blue-800);}
.bf-salida{background:var(--red-600);color:#fff;}
.bf-salida:hover{background:var(--red-800);}
.bf-pausa{background:var(--amber-600);color:#fff;}
.bf-pausa:hover{background:var(--amber-800);}
.bf-reanudar{background:var(--green-600);color:#fff;}
.bf-reanudar:hover{background:var(--green-800);}

/* ── Forms ── */
.fg{margin-bottom:.9rem;}
.fg label{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:4px;}
.form-control{width:100%;padding:8px 11px;border:0.5px solid var(--border-md);border-radius:var(--r-md);background:var(--surface);color:var(--text);font-size:13.5px;font-family:var(--font);outline:none;transition:border-color .12s;}
.form-control:focus{border-color:var(--blue-600);box-shadow:0 0 0 3px rgba(24,95,165,.1);}
select.form-control{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24'%3E%3Cpath fill='%236B6A64' d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px;}
textarea.form-control{resize:vertical;min-height:70px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.form-row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem;}

/* ── Tables ── */
.tbl-wrap{overflow-x:auto;}
table{width:100%;border-collapse:collapse;}
th{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);padding:9px 14px;border-bottom:0.5px solid var(--border);text-align:left;white-space:nowrap;background:var(--surface2);}
td{padding:10px 14px;border-bottom:0.5px solid var(--border);font-size:13.5px;vertical-align:middle;}
tr:last-child td{border-bottom:none;}
tbody tr:hover td{background:var(--blue-50);}

/* ── Badges ── */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap;}
.badge-success{background:var(--green-50);color:var(--green-800);}
.badge-warning{background:var(--amber-50);color:var(--amber-800);}
.badge-danger{background:var(--red-50);color:var(--red-800);}
.badge-info{background:var(--blue-50);color:var(--blue-800);}
.badge-purple{background:var(--purple-50);color:var(--purple-800);}
.badge-secondary{background:var(--gray-50);color:var(--gray-600);border:0.5px solid var(--border);}
.badge-teal{background:var(--teal-50);color:var(--teal-800);}
.dot{width:6px;height:6px;border-radius:50%;display:inline-block;flex-shrink:0;}
.dot-green{background:#5BA312;}.dot-amber{background:#D4920A;}.dot-red{background:#C43030;}.dot-gray{background:#888780;}.dot-blue{background:#1E75CE;}.dot-purple{background:#6F66D6;}

/* ── Avatar ── */
.av{width:34px;height:34px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0;}
.av-sm{width:28px;height:28px;font-size:10px;}
.av-lg{width:44px;height:44px;font-size:15px;}
.av-blue{background:var(--blue-50);color:var(--blue-800);}
.av-green{background:var(--green-50);color:var(--green-800);}
.av-amber{background:var(--amber-50);color:var(--amber-800);}
.av-purple{background:var(--purple-50);color:var(--purple-800);}
.av-red{background:var(--red-50);color:var(--red-800);}
.av-teal{background:var(--teal-50);color:var(--teal-800);}

/* ── Clock panel ── */
.clock-panel{background:var(--blue-900);border-radius:var(--r-xl);padding:2.25rem 1.5rem;text-align:center;color:#fff;margin-bottom:1rem;}
.clock-time{font-size:60px;font-weight:200;font-variant-numeric:tabular-nums;letter-spacing:5px;line-height:1;color:#fff;}
.clock-date{font-size:13px;color:rgba(255,255,255,.6);margin:7px 0 1.5rem;}
.clock-status{margin-top:1rem;font-size:13px;color:rgba(255,255,255,.7);}
.fichar-btns{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;}

/* ── Geo ── */
.geo-panel{border-radius:var(--r-md);padding:10px 14px;font-size:13px;display:flex;align-items:center;gap:9px;margin-bottom:1rem;background:var(--amber-50);border:0.5px solid var(--amber-100);color:var(--amber-800);}
.geo-ok{background:var(--green-50);border-color:var(--green-100);color:var(--green-800);}
.geo-error{background:var(--red-50);border-color:var(--red-100);color:var(--red-800);}
.geo-pulse{animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:.6;}}

/* ── Timeline ── */
.tl{display:flex;flex-direction:column;}
.tl-item{display:flex;align-items:center;gap:11px;padding:9px 0;border-bottom:0.5px solid var(--border);}
.tl-item:last-child{border-bottom:none;}
.tl-time{font-size:13px;font-variant-numeric:tabular-nums;min-width:44px;color:var(--muted);font-weight:500;}
.tl-ico{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:13px;}
.tl-desc{font-size:13.5px;flex:1;}
.tl-geo{font-size:11px;color:var(--muted);}

/* ── Progress ── */
.progress{background:var(--gray-100);border-radius:8px;height:6px;overflow:hidden;}
.prog-bar{height:100%;border-radius:8px;background:var(--blue-600);transition:width .3s;}
.prog-green{background:var(--green-600);}
.prog-amber{background:var(--amber-400);}
.prog-red{background:var(--red-600);}

/* ── Sol item (vacaciones) ── */
.sol-item{display:flex;align-items:center;gap:11px;padding:11px 14px;border:0.5px solid var(--border);border-radius:var(--r-md);margin-bottom:8px;background:var(--surface);}
.sol-item:last-child{margin-bottom:0;}
.sol-info{flex:1;}
.sol-tipo{font-size:13px;font-weight:600;}
.sol-dates{font-size:12px;color:var(--muted);margin-top:2px;}

/* ── Alerts ── */
.alert{padding:10px 15px;border-radius:var(--r-md);font-size:13px;display:flex;align-items:flex-start;gap:9px;margin-bottom:1rem;}
.alert-info{background:var(--blue-50);color:var(--blue-800);border:0.5px solid var(--blue-100);}
.alert-success{background:var(--green-50);color:var(--green-800);border:0.5px solid var(--green-100);}
.alert-warning{background:var(--amber-50);color:var(--amber-800);border:0.5px solid var(--amber-100);}
.alert-danger{background:var(--red-50);color:var(--red-800);border:0.5px solid var(--red-100);}

/* ── Modal ── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.38);z-index:300;display:flex;align-items:center;justify-content:center;padding:1rem;}
.modal-box{background:var(--surface);border-radius:var(--r-xl);padding:1.75rem;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.18);}
.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;}
.modal-title{font-size:16px;font-weight:700;}

/* ── Map ── */
#mapa{height:340px;border-radius:var(--r-lg);border:0.5px solid var(--border);overflow:hidden;}

/* ── Calendar ── */
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;}
.cal-head{text-align:center;font-size:10px;font-weight:700;color:var(--muted);padding:4px 2px;text-transform:uppercase;letter-spacing:.4px;}
.cal-day{text-align:center;padding:6px 2px;font-size:12px;border-radius:6px;}
.cal-empty{opacity:0;}
.cal-today{background:var(--blue-600);color:#fff;font-weight:700;}
.cal-vac{background:var(--purple-50);color:var(--purple-800);}
.cal-fest{background:var(--amber-50);color:var(--amber-800);}
.cal-weekend{color:var(--muted);}
.cal-legend{display:flex;gap:12px;flex-wrap:wrap;margin-top:10px;}
.leg-item{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--muted);}
.leg-dot{width:10px;height:10px;border-radius:3px;}

/* ── Divider ── */
hr.div{border:none;border-top:0.5px solid var(--border);margin:1rem 0;}

/* ── Utilities ── */
.d-flex{display:flex;align-items:center;}
.gap-6{gap:6px;}.gap-8{gap:8px;}.gap-12{gap:12px;}
.fw5{font-weight:500;}.fw6{font-weight:600;}.fw7{font-weight:700;}
.fs11{font-size:11px;}.fs12{font-size:12px;}.fs13{font-size:13px;}.fs20{font-size:20px;}
.text-muted{color:var(--muted);}
.text-blue{color:var(--blue-600);}
.text-green{color:var(--green-600);}
.text-red{color:var(--red-600);}
.text-amber{color:var(--amber-600);}
.text-center{text-align:center;}
.ml-auto{margin-left:auto;}
.mt-1{margin-top:.5rem;}.mt-2{margin-top:1rem;}.mt-3{margin-top:1.5rem;}
.mb-1{margin-bottom:.5rem;}.mb-2{margin-bottom:1rem;}
.w100{width:100%;}
.mono{font-family:var(--mono);}

/* ── Page header ── */
.page-header{margin-bottom:1.5rem;}
.page-header h1{font-size:20px;font-weight:700;line-height:1.2;}
.page-header p{font-size:13px;color:var(--muted);margin-top:3px;}

/* ── Login ── */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);}
.login-card{background:var(--surface);border:0.5px solid var(--border);border-radius:var(--r-xl);padding:2.5rem;width:100%;max-width:390px;box-shadow:var(--shadow-md);}
.login-logo{text-align:center;margin-bottom:2rem;}
.login-logo svg{color:var(--blue-600);}
.login-logo h1{font-size:22px;font-weight:800;color:var(--blue-900);margin-top:10px;}
.login-logo p{font-size:12px;color:var(--muted);}

/* ── Toast ── */
#toasts{position:fixed;bottom:1.5rem;right:1.5rem;z-index:999;display:flex;flex-direction:column;gap:8px;}
.toast{background:var(--gray-900);color:#fff;padding:11px 16px;border-radius:var(--r-lg);font-size:13px;box-shadow:var(--shadow-md);display:flex;align-items:center;gap:9px;max-width:340px;animation:tin .2s ease;}
.toast-success{background:var(--green-600);}
.toast-error{background:var(--red-600);}
.toast-warning{background:var(--amber-600);}
@keyframes tin{from{transform:translateX(20px);opacity:0;}to{transform:translateX(0);opacity:1;}}

/* ── Compliance ── */
.comp-list{display:flex;flex-direction:column;gap:10px;}
.comp-item{display:flex;gap:10px;align-items:flex-start;}
.comp-item .ci-ok{color:var(--green-600);flex-shrink:0;margin-top:1px;}
.comp-title{font-size:13px;font-weight:600;}
.comp-desc{font-size:12px;color:var(--muted);}

/* ── Responsive ── */
@media(max-width:900px){
  .g-main,.g-main-wide,.g2,.g3{grid-template-columns:1fr;}
  .metrics{grid-template-columns:1fr 1fr;}
  .form-row,.form-row3{grid-template-columns:1fr;}
}
@media(max-width:768px){
  .sidebar{transform:translateX(-100%);transition:transform .22s;}
  .sidebar.open{transform:none;box-shadow:var(--shadow-md);}
  .main{margin-left:0;width:100%;}
  #sb-toggle{display:flex;}
  .clock-time{font-size:42px;}
  .metrics{grid-template-columns:1fr 1fr;}
  .content{padding:1rem;}
}
@media(max-width:480px){
  .metrics{grid-template-columns:1fr;}
  .login-card{padding:1.5rem;}
}
