/* Geekworks Time Clock — Desert Editorial, restrained for a utility tool */
:root{
  --navy:#1f2d4d; --navy-700:#16213a;
  --terra:#c8643c; --terra-600:#b1542f;
  --sand:#f4eee2; --paper:#fbf8f1; --card:#ffffff;
  --ink:#2a2722; --muted:#6f6a60; --line:#e3dccd;
  --sage:#6f8a6b; --gold:#c9a24b; --danger:#b23b3b;
  --r:14px; --shadow:0 1px 2px rgba(31,45,77,.06),0 8px 24px rgba(31,45,77,.06);
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:"Hanken Grotesk",system-ui,sans-serif;
  color:var(--ink);background:var(--sand);line-height:1.5;
}
a{color:var(--navy)}
.serif{font-family:"Fraunces",Georgia,serif}

/* ---------- clock (staff) page ---------- */
.clock-wrap{min-height:100dvh;display:flex;flex-direction:column;align-items:center;
  justify-content:center;padding:24px;text-align:center}
.brand{font-family:"Fraunces",serif;font-weight:600;letter-spacing:.01em;
  color:var(--navy);font-size:1.05rem;margin-bottom:4px}
.brand small{display:block;font-family:"Hanken Grotesk",sans-serif;font-weight:500;
  text-transform:uppercase;letter-spacing:.18em;font-size:.62rem;color:var(--muted)}
.bigclock{font-family:"Fraunces",serif;font-weight:600;font-size:clamp(2.6rem,9vw,4.2rem);
  color:var(--navy);line-height:1;margin:18px 0 2px;font-variant-numeric:tabular-nums}
.bigdate{color:var(--muted);font-size:.95rem;margin-bottom:26px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);
  box-shadow:var(--shadow);padding:26px;width:100%;max-width:420px;text-align:left}
.card h1{font-family:"Fraunces",serif;font-size:1.35rem;margin:0 0 18px;color:var(--navy)}
label{display:block;font-weight:600;font-size:.82rem;margin:0 0 6px;color:var(--ink)}
select,input[type=text],input[type=password],input[type=number],input[type=email],
input[type=datetime-local],input[type=date]{
  width:100%;padding:12px 13px;font:inherit;color:var(--ink);background:var(--paper);
  border:1px solid var(--line);border-radius:10px;margin-bottom:16px}
select:focus,input:focus{outline:2px solid var(--navy);outline-offset:1px;border-color:var(--navy)}
.pin{letter-spacing:.5em;text-align:center;font-size:1.3rem}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  border:none;border-radius:11px;font:inherit;font-weight:700;cursor:pointer;
  padding:13px 18px;text-decoration:none}
.btn-block{width:100%;font-size:1.05rem;padding:16px}
.btn-in{background:var(--terra);color:#fff}.btn-in:hover{background:var(--terra-600)}
.btn-out{background:var(--navy);color:#fff}.btn-out:hover{background:var(--navy-700)}
.btn-ghost{background:transparent;color:var(--navy);border:1px solid var(--line)}
.btn-ghost:hover{background:var(--paper)}
.btn-sm{padding:8px 12px;font-size:.85rem;font-weight:600}
.btn-danger{background:var(--danger);color:#fff}
.status{margin:18px 0 0;padding:14px;border-radius:11px;font-size:.95rem}
.status.in{background:#eef3ee;color:#3d5a3a;border:1px solid #d4e2d2}
.status.out{background:#f6efe7;color:#7a5230;border:1px solid #ecdcca}
.flash{padding:13px 15px;border-radius:11px;margin-bottom:16px;font-weight:600}
.flash.ok{background:#eef3ee;color:#3d5a3a;border:1px solid #d4e2d2}
.flash.err{background:#f7e9e9;color:#9a2f2f;border:1px solid #eccaca}
.muted{color:var(--muted)}.small{font-size:.85rem}
.center{text-align:center}.mt{margin-top:18px}

/* ---------- admin layout ---------- */
.topbar{background:var(--navy);color:#fff;padding:14px 22px;display:flex;
  align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}
.topbar .logo{font-family:"Fraunces",serif;font-weight:600}
.topbar .logo small{display:block;font-family:"Hanken Grotesk",sans-serif;font-weight:500;
  font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;opacity:.7}
.nav{display:flex;gap:4px;flex-wrap:wrap}
.nav a{color:#dfe4ee;text-decoration:none;padding:8px 13px;border-radius:9px;font-weight:600;font-size:.9rem}
.nav a:hover{background:rgba(255,255,255,.1)}
.nav a.active{background:#fff;color:var(--navy)}
.wrap{max-width:1040px;margin:0 auto;padding:26px 22px 60px}
.page-title{font-family:"Fraunces",serif;color:var(--navy);font-size:1.7rem;margin:0 0 4px}
.page-sub{color:var(--muted);margin:0 0 22px}
.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--r);
  box-shadow:var(--shadow);padding:22px;margin-bottom:22px}
.panel h2{font-family:"Fraunces",serif;color:var(--navy);font-size:1.15rem;margin:0 0 14px}
table{width:100%;border-collapse:collapse;font-size:.92rem}
th,td{text-align:left;padding:11px 12px;border-bottom:1px solid var(--line);vertical-align:middle}
th{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-weight:700}
td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}
tr:last-child td{border-bottom:none}
.tag{display:inline-block;padding:3px 9px;border-radius:999px;font-size:.72rem;font-weight:700}
.tag.in{background:#eef3ee;color:#3d5a3a}.tag.out{background:#f1ece3;color:#7a6a4e}
.grid{display:grid;gap:16px}
.grid.two{grid-template-columns:1fr 1fr}
.kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:22px}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:16px 18px;box-shadow:var(--shadow)}
.kpi .n{font-family:"Fraunces",serif;font-size:1.9rem;color:var(--navy);line-height:1}
.kpi .l{color:var(--muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;margin-top:6px}
.row-actions{display:flex;gap:6px}
.toolbar{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap;margin-bottom:18px}
.toolbar > div{flex:0 0 auto}
.toolbar label{margin-bottom:6px}
.toolbar select,.toolbar input{margin-bottom:0;width:auto;min-width:150px}
.login-wrap{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px}
hr.sep{border:none;border-top:1px solid var(--line);margin:20px 0}
@media(max-width:640px){
  .grid.two,.kpis{grid-template-columns:1fr}
  .wrap{padding:18px 14px 50px}
  table{font-size:.86rem}
  th,td{padding:9px 8px}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}
