/* ============================================================
   HADIR — Facial Recognition Attendance System
   Shared design system
   Font: Plus Jakarta Sans (UI) + Space Grotesk (display numerals)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=Space+Grotesk:wght@400;500;600;700&display=swap');

:root {
  --font-ui: 'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;
  --font-display: 'Space Grotesk', 'Plus Jakarta Sans', sans-serif;

  /* Brand accent — biometric mint/teal */
  --accent: #20E3B2;
  --accent-deep: #0FB890;
  --accent-ink: #053b30;

  /* Semantics */
  --present: #22C55E;
  --present-dim: #34D399;
  --late: #F5A524;
  --absent: #F4516C;
  --info: #5B8DEF;

  --radius-xl: 28px;
  --radius-lg: 20px;
  --radius-md: 14px;
  --radius-sm: 10px;

  --ease: cubic-bezier(0.22, 1, 0.36, 1);
}

/* ---------- DARK THEME (kiosk + super admin) ---------- */
[data-theme="dark"] {
  --bg: #080B12;
  --bg-grad-1: #0C1322;
  --bg-grad-2: #080B12;
  --surface: #111827;
  --surface-2: #161F30;
  --surface-3: #1D283C;
  --border: rgba(255, 255, 255, 0.07);
  --border-strong: rgba(255, 255, 255, 0.13);
  --text: #ECF1F8;
  --text-dim: #94A1B8;
  --text-faint: #5C677D;
  --shadow: 0 24px 60px -20px rgba(0, 0, 0, 0.6);
  --glass: rgba(255, 255, 255, 0.04);
}

/* ---------- LIGHT THEME (admin) ---------- */
[data-theme="light"] {
  --bg: #EEF2F7;
  --bg-grad-1: #F3F6FA;
  --bg-grad-2: #E7ECF3;
  --surface: #FFFFFF;
  --surface-2: #F6F8FC;
  --surface-3: #EEF2F8;
  --border: #E4E9F1;
  --border-strong: #D5DCE7;
  --text: #0E1726;
  --text-dim: #5E6B82;
  --text-faint: #95A0B5;
  --shadow: 0 18px 48px -24px rgba(28, 44, 84, 0.22);
  --glass: rgba(255, 255, 255, 0.7);
  --accent: #0DAE88;
  --accent-deep: #0A8E70;
  --present: #16A34A;
}

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

html, body {
  height: 100%;
  font-family: var(--font-ui);
  background: var(--bg);
  color: var(--text);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

body { font-size: 16px; line-height: 1.5; }

::selection { background: var(--accent); color: #06241c; }

a { color: inherit; text-decoration: none; }

.mono { font-family: var(--font-display); font-variant-numeric: tabular-nums; }
.muted { color: var(--text-dim); }
.faint { color: var(--text-faint); }

/* ---------- Buttons ---------- */
.btn {
  font-family: var(--font-ui);
  font-weight: 600;
  font-size: 15px;
  border: none;
  border-radius: var(--radius-md);
  padding: 13px 22px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  transition: transform .18s var(--ease), box-shadow .25s var(--ease), background .2s var(--ease);
  white-space: nowrap;
}
.btn:active { transform: translateY(1px) scale(.99); }

.btn-primary {
  background: linear-gradient(135deg, var(--accent), var(--accent-deep));
  color: #04241b;
  box-shadow: 0 10px 26px -10px var(--accent-deep);
}
.btn-primary:hover { box-shadow: 0 14px 34px -10px var(--accent-deep); transform: translateY(-1px); }

.btn-ghost {
  background: var(--glass);
  color: var(--text);
  border: 1px solid var(--border-strong);
}
.btn-ghost:hover { background: var(--surface-2); }

.btn-lg { padding: 18px 30px; font-size: 17px; border-radius: var(--radius-lg); }

/* ---------- Cards ---------- */
.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow);
}

/* ---------- Badges / pills ---------- */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-size: 12.5px;
  font-weight: 600;
  padding: 5px 11px;
  border-radius: 999px;
  letter-spacing: .1px;
}
.badge .dot { width: 7px; height: 7px; border-radius: 50%; background: currentColor; }
.badge-present { color: var(--present); background: color-mix(in srgb, var(--present) 14%, transparent); }
.badge-late { color: var(--late); background: color-mix(in srgb, var(--late) 16%, transparent); }
.badge-absent { color: var(--absent); background: color-mix(in srgb, var(--absent) 14%, transparent); }
.badge-info { color: var(--info); background: color-mix(in srgb, var(--info) 16%, transparent); }
.badge-neutral { color: var(--text-dim); background: var(--surface-3); }

/* ---------- Avatars ---------- */
.avatar {
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-weight: 700;
  color: #fff;
  flex: none;
  overflow: hidden;
  font-family: var(--font-ui);
  letter-spacing: .3px;
}
.avatar img { width: 100%; height: 100%; object-fit: cover; }

/* ---------- Scrollbar ---------- */
*::-webkit-scrollbar { width: 10px; height: 10px; }
*::-webkit-scrollbar-thumb { background: var(--border-strong); border-radius: 999px; border: 3px solid transparent; background-clip: padding-box; }
*::-webkit-scrollbar-track { background: transparent; }

/* ---------- Helpers ---------- */
.row { display: flex; align-items: center; }
.col { display: flex; flex-direction: column; }
.gap-2 { gap: 8px; } .gap-3 { gap: 12px; } .gap-4 { gap: 16px; } .gap-6 { gap: 24px; }
.grow { flex: 1; }
.center { display: grid; place-items: center; }

/* subtle entrance — opacity stays at base so a frozen/throttled preview
   never traps content hidden; only a small translate is animated. */
@keyframes riseIn { from { transform: translateY(14px); } to { transform: none; } }
@media (prefers-reduced-motion: no-preference) {
  .rise { animation: riseIn .6s var(--ease); }
}
