:root{
  --ink:#15140f;
  --panel:#1e1c16;
  --panel-2:#26241c;
  --line:#3a3526;
  --amber:#f5a623;
  --amber-soft:#ffcf6b;
  --green:#8fd14f;
  --red:#e2574c;
  --paper:#ece4d2;
  --muted:#8c856f;
  --txt:#ece4d2;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:'Archivo',system-ui,sans-serif;
  background:
    radial-gradient(1200px 600px at 80% -10%, #2a2619 0%, transparent 60%),
    radial-gradient(900px 500px at -10% 110%, #221f15 0%, transparent 55%),
    var(--ink);
  color:var(--txt);
  min-height:100vh;
}
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;
  background-image:repeating-linear-gradient(0deg,rgba(255,255,255,.012) 0 1px,transparent 1px 3px);
}
#app{position:relative;z-index:1}
.mono{font-family:'Space Mono',monospace}
.display{font-family:'Archivo Black',sans-serif;letter-spacing:-.01em}
button{font-family:inherit;cursor:pointer;border:none}
input,select,textarea{font-family:inherit}
a{color:var(--amber)}

/* ---------- Login ---------- */
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px}
.login-card{
  width:min(420px,100%);background:var(--panel);
  border:1px solid var(--line);border-radius:14px;overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,.5);
}
.login-top{
  background:linear-gradient(180deg,#2c2818,#211e14);
  padding:34px 32px 26px;border-bottom:2px dashed var(--line);position:relative;
}
.login-top::after{content:"";position:absolute;left:0;right:0;bottom:-8px;height:16px;
  background:radial-gradient(circle at 10px center,var(--ink) 6px,transparent 7px) repeat-x;
  background-size:20px 16px;background-position:0 -4px;}
.brand{display:flex;align-items:center;gap:12px}
.brand-mark{width:42px;height:42px;border-radius:9px;background:var(--amber);
  display:grid;place-items:center;color:#1a1810;font-size:22px;box-shadow:0 0 24px rgba(245,166,35,.35)}
.brand h1{font-size:24px}.brand h1 span{color:var(--amber)}
.login-sub{color:var(--muted);margin-top:14px;font-size:14px}
.login-body{padding:28px 32px 32px}
.field{margin-bottom:16px}
.field label{display:block;font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:6px}
.field input,.field select,.field textarea{
  width:100%;background:var(--ink);color:var(--txt);
  border:1px solid var(--line);border-radius:8px;padding:12px 14px;font-size:15px;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--amber);box-shadow:0 0 0 3px rgba(245,166,35,.15)}
.btn{background:var(--amber);color:#1a1810;font-weight:700;padding:13px 18px;border-radius:8px;font-size:15px;width:100%;transition:.15s}
.btn:hover{background:var(--amber-soft)}
.btn:active{transform:translateY(1px)}
.btn.secondary{background:var(--panel-2);color:var(--txt);border:1px solid var(--line)}
.btn.secondary:hover{border-color:var(--amber)}
.btn.danger{background:transparent;color:var(--red);border:1px solid #5a342f}
.btn.danger:hover{background:#2a1a18}
.btn.small{width:auto;padding:8px 14px;font-size:13px}
.err{color:var(--red);font-size:13px;margin-top:8px;min-height:18px}

/* ---------- App shell ---------- */
.shell{display:grid;grid-template-columns:230px 1fr;min-height:100vh}
.side{background:var(--panel);border-right:1px solid var(--line);padding:22px 16px;display:flex;flex-direction:column}
.side .brand{margin-bottom:28px;padding:0 6px}
.side .brand h1{font-size:20px}
.nav{display:flex;flex-direction:column;gap:4px;flex:1}
.nav button{display:flex;align-items:center;gap:11px;text-align:left;background:transparent;color:var(--muted);
  padding:11px 12px;border-radius:9px;font-size:14px;font-weight:600;transition:.12s}
.nav button:hover{background:var(--panel-2);color:var(--txt)}
.nav button.active{background:var(--panel-2);color:var(--amber);box-shadow:inset 3px 0 0 var(--amber)}
.nav .icon{width:18px;text-align:center}
.who{border-top:1px solid var(--line);padding-top:16px;margin-top:10px}
.who .name{font-weight:700;font-size:14px}
.who .role{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.main{padding:32px 38px;overflow:auto}
.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:26px;flex-wrap:wrap;gap:14px}
.page-head h2{font-size:26px}
.page-head .sub{color:var(--muted);font-size:14px;margin-top:4px}

/* ---------- Clock card ---------- */
.clock-card{background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid var(--line);
  border-radius:16px;padding:40px;text-align:center;max-width:560px;margin:0 auto 28px;position:relative;overflow:hidden}
.clock-card::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(400px 200px at 50% 0%,rgba(245,166,35,.08),transparent)}
.clock-card>*{position:relative;z-index:1}
.now-time{font-size:64px;font-weight:700;letter-spacing:.02em}
.now-date{color:var(--muted);font-size:15px;text-transform:uppercase;letter-spacing:.12em;margin-top:4px}
.status-pill{display:inline-flex;align-items:center;gap:8px;margin:24px 0 6px;padding:8px 16px;border-radius:999px;font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.08em}
.status-pill.in{background:rgba(143,209,79,.13);color:var(--green);border:1px solid rgba(143,209,79,.3)}
.status-pill.out{background:rgba(140,133,111,.13);color:var(--muted);border:1px solid var(--line)}
.dot{width:9px;height:9px;border-radius:50%;background:currentColor;box-shadow:0 0 10px currentColor}
.elapsed{color:var(--amber);font-size:15px;margin-bottom:24px;min-height:20px}
.clock-actions{display:flex;gap:12px;justify-content:center}
.clock-actions .btn{width:auto;min-width:160px;padding:16px 22px;font-size:16px}
.btn.clockin{background:var(--green);color:#142410}
.btn.clockin:hover{background:#a4e063}
.btn.clockout{background:var(--red);color:#fff}
.btn.clockout:hover{background:#ea6d63}
.geo-note{font-size:12px;color:var(--muted);margin-top:14px}

/* ---------- Tables / cards ---------- */
.card{background:var(--panel);border:1px solid var(--line);border-radius:13px;overflow:hidden}
.card h3{padding:16px 20px;border-bottom:1px solid var(--line);font-size:15px;text-transform:uppercase;letter-spacing:.06em;color:var(--amber-soft)}
table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:12px 16px;font-size:14px;border-bottom:1px solid var(--line)}
th{font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);font-weight:700}
tr:last-child td{border-bottom:none}
tbody tr:hover{background:var(--panel-2)}
.badge{display:inline-block;padding:3px 9px;border-radius:6px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.badge.pending{background:rgba(245,166,35,.14);color:var(--amber)}
.badge.approved{background:rgba(143,209,79,.14);color:var(--green)}
.badge.rejected{background:rgba(226,87,76,.14);color:var(--red)}
.badge.admin{background:rgba(245,166,35,.14);color:var(--amber)}
.badge.employee{background:rgba(140,133,111,.15);color:var(--muted)}
.row-actions{display:flex;gap:6px}
.icon-btn{background:var(--panel-2);border:1px solid var(--line);color:var(--txt);width:30px;height:30px;border-radius:7px;font-size:14px;display:grid;place-items:center}
.icon-btn:hover{border-color:var(--amber)}
.icon-btn.ok:hover{border-color:var(--green);color:var(--green)}
.icon-btn.no:hover{border-color:var(--red);color:var(--red)}
.toolbar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px;align-items:end}
.toolbar .field{margin:0}
.toolbar .field input,.toolbar .field select{width:auto}
.empty{padding:40px;text-align:center;color:var(--muted)}

/* ---------- Calendar ---------- */
.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.cal-head .mlabel{font-size:20px;font-weight:700}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cal-dow{text-align:center;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);padding:6px 0}
.cal-cell{background:var(--panel);border:1px solid var(--line);border-radius:9px;min-height:104px;padding:7px;cursor:pointer;transition:.1s}
.cal-cell:hover{border-color:var(--amber)}
.cal-cell.dim{opacity:.35}
.cal-cell.today{border-color:var(--amber);box-shadow:inset 0 0 0 1px var(--amber)}
.cal-daynum{font-size:13px;font-weight:700;color:var(--muted);margin-bottom:5px}
.cal-cell.today .cal-daynum{color:var(--amber)}
.cal-ev{background:var(--panel-2);border-left:3px solid var(--amber);border-radius:5px;padding:4px 6px;font-size:11px;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cal-ev b{color:var(--amber-soft)}

/* ---------- Modal ---------- */
.modal-bg{position:fixed;inset:0;background:rgba(8,7,4,.7);backdrop-filter:blur(3px);display:grid;place-items:center;z-index:50;padding:20px}
.modal{width:min(480px,100%);background:var(--panel);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.modal-head{padding:18px 22px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.modal-head h3{font-size:17px}
.modal-body{padding:22px}
.modal-foot{padding:16px 22px;border-top:1px solid var(--line);display:flex;gap:10px;justify-content:flex-end}
.modal-foot .btn{width:auto}
.x{background:transparent;color:var(--muted);font-size:22px;line-height:1}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.toast{position:fixed;bottom:24px;right:24px;background:var(--panel);border:1px solid var(--line);border-left:4px solid var(--green);padding:14px 18px;border-radius:9px;font-size:14px;z-index:60;box-shadow:0 12px 40px rgba(0,0,0,.4)}
.toast.err{border-left-color:var(--red)}

.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:24px}
.kpi{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:18px}
.kpi .v{font-size:30px;font-weight:700;font-family:'Space Mono',monospace}
.kpi .l{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.06em;margin-top:2px}

@media(max-width:760px){
  .shell{grid-template-columns:1fr}
  .side{flex-direction:row;flex-wrap:wrap;align-items:center;padding:12px}
  .side .brand{margin:0 auto 0 0}
  .nav{flex-direction:row;flex-wrap:wrap;flex:0}
  .who{border:none;padding:0;margin:0}
  .main{padding:20px}
  .grid2{grid-template-columns:1fr}
  .now-time{font-size:48px}
}
