/* ============================================
   SiAbsen — Design System (Modern Green)
   Inspired by clean SaaS dashboards.
   ============================================ */

:root {
  /* Primary brand — modern emerald */
  --primary:        #10b981;
  --primary-glow:   #34d399;
  --primary-dark:   #047857;
  --primary-soft:   #ecfdf5;
  --primary-fg:     #ffffff;

  /* Surface */
  --bg:             #f6f7f9;
  --surface:        #ffffff;
  --surface-2:      #f9fafb;
  --surface-3:      #f1f5f4;
  --border:         #eceff3;
  --border-strong:  #dde2e8;

  /* Text */
  --text:           #0b1220;
  --text-muted:     #5b6573;
  --text-soft:      #98a1ad;

  /* Status */
  --success:        #10b981;
  --warning:        #f59e0b;
  --danger:         #ef4444;
  --info:           #0ea5e9;

  /* Effects */
  --gradient-primary: linear-gradient(135deg, #10b981 0%, #059669 100%);
  --gradient-soft:    linear-gradient(135deg, #ecfdf5 0%, #d1fae5 100%);
  --gradient-success: linear-gradient(135deg, #10b981 0%, #34d399 100%);

  --radius-sm:  8px;
  --radius:     12px;
  --radius-lg:  16px;
  --radius-xl:  22px;
  --radius-full:9999px;

  --shadow-sm:      0 1px 2px rgba(16,24,40,.04);
  --shadow:         0 2px 8px rgba(16,24,40,.05);
  --shadow-lg:      0 12px 28px rgba(16,24,40,.08);
  --shadow-elegant: 0 10px 30px -12px rgba(16,185,129,.35);
  --shadow-glow:    0 0 0 4px rgba(16,185,129,.14);

  --sidebar-w:      256px;
  --header-h:       64px;
  --mobile-nav-h:   72px;

  --transition:     all .2s ease;
}

/* ============================================ Base */
* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  background: var(--bg);
  color: var(--text);
  font-size: 14.5px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}

a { color: var(--primary-dark); text-decoration: none; }
a:hover { color: var(--primary); }

h1,h2,h3,h4,h5 { color: var(--text); margin: 0 0 .5rem; font-weight: 600; letter-spacing: -.015em; }
h1 { font-size: 1.65rem; }
h2 { font-size: 1.35rem; }
h3 { font-size: 1.1rem; }

/* ============================================ Layout: Desktop */
.app-shell { display: flex; min-height: 100vh; }

.sidebar {
  width: var(--sidebar-w);
  background: var(--surface);
  border-right: 1px solid var(--border);
  position: fixed;
  inset: 0 auto 0 0;
  display: flex;
  flex-direction: column;
  z-index: 30;
  transition: var(--transition);
}
.sidebar-brand {
  padding: 1.1rem 1.25rem;
  display: flex; align-items: center; gap: .65rem;
  border-bottom: 1px solid var(--border);
}
.sidebar-brand .logo {
  width: 36px; height: 36px;
  background: var(--gradient-primary);
  border-radius: 10px;
  display: grid; place-items: center;
  color: #fff; font-weight: 700; font-size: 1rem;
  box-shadow: var(--shadow-elegant);
}
.sidebar-brand .name { font-weight: 700; font-size: 1rem; color: var(--text); letter-spacing: -.01em; }
.sidebar-brand .tag  { font-size: .68rem; color: var(--text-muted); letter-spacing: .04em; text-transform: uppercase; }

.sidebar-nav { padding: .85rem .65rem; flex: 1; overflow-y: auto; }
.sidebar-nav .group-label {
  font-size: .66rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--text-soft);
  padding: 1rem .8rem .45rem;
  font-weight: 600;
}
.sidebar-nav a {
  display: flex; align-items: center; gap: .75rem;
  padding: .6rem .85rem;
  margin-bottom: 2px;
  border-radius: 10px;
  color: var(--text-muted);
  font-weight: 500;
  font-size: .9rem;
  transition: var(--transition);
}
.sidebar-nav a:hover {
  background: var(--surface-2);
  color: var(--text);
}
.sidebar-nav a.active {
  background: var(--primary-soft);
  color: var(--primary-dark);
  font-weight: 600;
}
.sidebar-nav a i { font-size: 1.05rem; width: 20px; text-align: center; }

.sidebar-footer { padding: .85rem; border-top: 1px solid var(--border); }
.sidebar-user {
  display: flex; align-items: center; gap: .65rem;
  padding: .6rem;
  border-radius: 12px;
  background: var(--surface-2);
}
.sidebar-user .avatar { width: 38px; height: 38px; border-radius: 50%; background: var(--gradient-primary); color:#fff; display:grid; place-items:center; font-weight:600; }
.sidebar-user .info { flex: 1; min-width: 0; }
.sidebar-user .info .nm { font-size: .87rem; font-weight: 600; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sidebar-user .info .rl { font-size: .72rem; color: var(--text-muted); }

.app-main {
  flex: 1;
  margin-left: var(--sidebar-w);
  display: flex;
  flex-direction: column;
}

.topbar {
  height: var(--header-h);
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center;
  padding: 0 1.5rem;
  gap: 1rem;
  position: sticky; top: 0; z-index: 20;
}
.topbar .toggle { display: none; background: none; border: 0; font-size: 1.25rem; color: var(--text-muted); }
.topbar .pagetitle { font-weight: 600; font-size: 1.05rem; flex: 1; letter-spacing: -.01em; }
.topbar .announce-pill {
  display: inline-flex; align-items: center; gap: .5rem;
  background: var(--primary-soft);
  color: var(--primary-dark);
  padding: .4rem .85rem;
  border-radius: var(--radius-full);
  font-size: .82rem; font-weight: 500;
  max-width: 320px; overflow: hidden; white-space: nowrap; text-overflow: ellipsis;
}

.app-content { padding: 1.5rem; flex: 1; }

/* ============================================ Cards */
.card-soft {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: 1.25rem;
}
.card-stat {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 1.1rem 1.25rem;
  transition: var(--transition);
  box-shadow: var(--shadow-sm);
}
.card-stat:hover { box-shadow: var(--shadow); transform: translateY(-1px); }
.card-stat .head { display:flex; align-items:center; justify-content:space-between; margin-bottom:.65rem; }
.card-stat .icon {
  width: 40px; height: 40px;
  border-radius: 10px;
  display: grid; place-items: center;
  font-size: 1.05rem; color: var(--primary-dark);
  background: var(--primary-soft);
}
.card-stat .icon.success { background: #d1fae5; color:#047857; }
.card-stat .icon.warning { background:#fef3c7; color:#b45309; }
.card-stat .icon.danger  { background:#fee2e2; color:#b91c1c; }
.card-stat .icon.info    { background:#e0f2fe; color:#0369a1; }
.card-stat .label { color: var(--text-muted); font-size: .82rem; font-weight:500; }
.card-stat .value { font-size: 1.7rem; font-weight: 700; color: var(--text); line-height: 1.1; letter-spacing:-.02em; }
.card-stat .delta { font-size:.75rem; font-weight:600; padding:.15rem .5rem; border-radius:999px; }
.card-stat .delta.up   { background:#d1fae5; color:#047857; }
.card-stat .delta.down { background:#fee2e2; color:#b91c1c; }

.card-hero {
  background: var(--gradient-primary);
  color: #fff;
  border-radius: var(--radius-xl);
  padding: 1.65rem;
  box-shadow: var(--shadow-elegant);
  position: relative;
  overflow: hidden;
}
.card-hero::after {
  content:''; position:absolute; right:-40px; top:-40px; width:200px; height:200px;
  background: radial-gradient(circle, rgba(255,255,255,.18), transparent 70%);
  pointer-events:none;
}
.card-hero h2 { color: #fff; font-size: 1.45rem; }
.card-hero p  { color: rgba(255,255,255,.88); margin: .25rem 0 0; }

/* ============================================ Buttons */
.btn-primary-grad {
  background: var(--gradient-primary);
  color: #fff;
  border: 0;
  padding: .6rem 1.1rem;
  border-radius: 10px;
  font-weight: 600;
  font-size: .9rem;
  box-shadow: var(--shadow-elegant);
  transition: var(--transition);
  cursor: pointer;
  display: inline-flex; align-items: center; gap: .5rem;
}
.btn-primary-grad:hover { transform: translateY(-1px); box-shadow: 0 18px 36px -12px rgba(16,185,129,.45); color:#fff; }
.btn-primary-grad:active { transform: translateY(0); }

.btn-outline-soft {
  background: var(--surface);
  color: var(--text);
  border: 1px solid var(--border-strong);
  padding: .55rem 1rem;
  border-radius: 10px;
  font-weight: 500;
  cursor: pointer;
  transition: var(--transition);
  display: inline-flex; align-items: center; gap: .5rem;
}
.btn-outline-soft:hover { background: var(--surface-2); border-color: var(--primary); color: var(--primary-dark); }

/* ============================================ Form */
.form-field { margin-bottom: 1rem; }
.form-field label { display:block; font-size:.84rem; font-weight:500; color:var(--text); margin-bottom:.4rem; }
.form-control-clean {
  width: 100%;
  padding: .65rem .9rem;
  background: var(--surface);
  border: 1px solid var(--border-strong);
  border-radius: 10px;
  font-size: .92rem;
  color: var(--text);
  transition: var(--transition);
  font-family: inherit;
}
.form-control-clean:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: var(--shadow-glow);
}

/* ============================================ Tables */
.table-clean {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  background: var(--surface);
  border-radius: var(--radius-lg);
  overflow: hidden;
  font-size: .9rem;
}
.table-clean th {
  text-align: left;
  padding: .85rem 1rem;
  font-size: .75rem;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--text-muted);
  background: var(--surface-2);
  border-bottom: 1px solid var(--border);
  font-weight: 600;
}
.table-clean td { padding: .9rem 1rem; border-bottom: 1px solid var(--border); }
.table-clean tr:last-child td { border-bottom: 0; }
.table-clean tbody tr:hover { background: var(--surface-2); }

/* ============================================ Mobile Layout (pegawai) */
.mobile-shell {
  min-height: 100vh;
  padding-bottom: calc(var(--mobile-nav-h) + 16px);
  background: var(--bg);
}

/* Cleaner mobile header — light surface, not heavy gradient */
.mobile-header {
  background: var(--surface);
  color: var(--text);
  padding: 1.1rem 1.25rem .9rem;
  border-bottom: 1px solid var(--border);
  position: sticky; top: 0; z-index: 25;
}
.mobile-header .greet  { font-size: .78rem; color: var(--text-muted); }
.mobile-header .name   { font-size: 1.1rem; font-weight: 700; margin-top: 1px; letter-spacing:-.01em; color: var(--text); }
.mobile-header .role   { font-size: .72rem; color: var(--text-soft); margin-top: 1px; }
.mobile-header .avatar {
  width: 42px; height: 42px; border-radius: 50%;
  background: var(--gradient-primary); color:#fff;
  display:grid; place-items:center; font-weight:600;
  box-shadow: var(--shadow-elegant);
  text-decoration:none;
}

.mobile-content { padding: 1rem 1.1rem 0; }

.mobile-clock-card {
  background: var(--gradient-primary);
  color:#fff;
  border-radius: var(--radius-lg);
  padding: 1.25rem;
  box-shadow: var(--shadow-elegant);
  text-align: center;
  margin-bottom: 1rem;
  position:relative;
  overflow:hidden;
}
.mobile-clock-card::after{
  content:''; position:absolute; right:-30px; top:-30px; width:160px; height:160px;
  background: radial-gradient(circle, rgba(255,255,255,.18), transparent 70%);
  pointer-events:none;
}
.mobile-clock-card .time { font-size: 2.1rem; font-weight: 700; color: #fff; letter-spacing: -.03em; font-feature-settings:'tnum'; line-height:1; }
.mobile-clock-card .date { color: rgba(255,255,255,.88); font-size: .82rem; margin-top:.4rem; }

.mobile-stats-row { display:grid; grid-template-columns: repeat(3,1fr); gap:10px; margin-bottom:1rem; }
.mobile-stat {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: .75rem .65rem;
  text-align:center;
}
.mobile-stat .lbl { font-size:.66rem; color: var(--text-muted); text-transform:uppercase; letter-spacing:.04em; font-weight:600; }
.mobile-stat .val { font-size:1.25rem; font-weight:700; color: var(--text); margin-top:2px; letter-spacing:-.02em; }
.mobile-stat .val small { font-size:.6rem; color:var(--text-muted); font-weight:500; margin-left:2px; }
.mobile-stat .val.green { color: var(--primary-dark); }
.mobile-stat .val.amber { color: #b45309; }

.mobile-section-title {
  font-size:.78rem; text-transform:uppercase; letter-spacing:.06em;
  color:var(--text-soft); font-weight:700;
  margin: .25rem 2px .55rem;
}

.mobile-action-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 1.25rem;
}
.mobile-action-btn {
  background: var(--surface);
  border-radius: 14px;
  padding: 1rem .9rem;
  text-align: left;
  border: 1px solid var(--border);
  cursor: pointer;
  transition: var(--transition);
  text-decoration: none;
  color: var(--text);
  display: block;
}
.mobile-action-btn:active { transform: scale(.98); }
.mobile-action-btn .ico {
  width: 40px; height: 40px;
  border-radius: 10px;
  margin-bottom: .6rem;
  display: grid; place-items: center;
  background: var(--primary-soft);
  color: var(--primary-dark);
  font-size: 1.15rem;
}
.mobile-action-btn.primary { background: var(--gradient-primary); color: #fff; border-color: transparent; box-shadow: var(--shadow-elegant); }
.mobile-action-btn.primary .ico { background: rgba(255,255,255,.22); color: #fff; }
.mobile-action-btn .label { font-weight: 600; font-size: .92rem; letter-spacing:-.005em; }
.mobile-action-btn .sub   { font-size: .72rem; color: var(--text-muted); margin-top: 2px; }
.mobile-action-btn.primary .sub { color: rgba(255,255,255,.85); }

.mobile-bottom-nav {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  height: var(--mobile-nav-h);
  background: var(--surface);
  border-top: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-around;
  padding: 0 8px;
  z-index: 50;
  box-shadow: 0 -4px 20px rgba(15,23,42,.04);
  padding-bottom: env(safe-area-inset-bottom);
}
.mobile-bottom-nav a {
  flex: 1;
  display: flex; flex-direction: column; align-items: center; gap: 2px;
  padding: .5rem;
  color: var(--text-muted);
  font-size: .68rem;
  text-decoration: none;
  border-radius: 10px;
  transition: var(--transition);
}
.mobile-bottom-nav a i { font-size: 1.2rem; }
.mobile-bottom-nav a.active { color: var(--primary-dark); font-weight: 600; }
.mobile-bottom-nav .center {
  margin-top: -28px;
  background: var(--gradient-primary);
  color: #fff !important;
  width: 56px; height: 56px;
  border-radius: 50%;
  flex: 0 0 auto;
  display: grid; place-items: center;
  box-shadow: var(--shadow-elegant);
  font-size: .65rem;
}
.mobile-bottom-nav .center i { font-size: 1.4rem; }

/* ============================================ Status row (today) */
.today-status {
  display:grid; grid-template-columns: 1fr 1fr auto; gap:.75rem; align-items:center;
}
.today-status .col-time .lbl { font-size:.7rem; color:var(--text-muted); text-transform:uppercase; letter-spacing:.05em; font-weight:600; }
.today-status .col-time .val { font-weight:700; font-size:1.05rem; color:var(--text); margin-top:2px; font-feature-settings:'tnum'; }

/* ============================================ Announcement banner */
.announce-banner {
  background: var(--primary-soft);
  border-left: 3px solid var(--primary);
  padding: .75rem .9rem;
  border-radius: 10px;
  margin-bottom: .65rem;
  display: flex; align-items: flex-start; gap: .7rem;
}
.announce-banner i { color: var(--primary-dark); font-size: 1rem; margin-top: 2px; }
.announce-banner .judul { font-weight: 600; font-size: .9rem; color: var(--text); }
.announce-banner .isi   { font-size: .8rem; color: var(--text-muted); margin-top: 2px; }

/* ============================================ Misc */
.text-muted-soft { color: var(--text-muted); }
.empty-state { text-align: center; padding: 2.5rem 1rem; color: var(--text-muted); }
.empty-state i { font-size: 2.5rem; opacity: .5; margin-bottom: .75rem; }

/* ============================================ Responsive */
@media (max-width: 992px) {
  .sidebar { transform: translateX(-100%); }
  .sidebar.open { transform: translateX(0); box-shadow: var(--shadow-lg); }
  .app-main { margin-left: 0; }
  .topbar .toggle { display: inline-flex; }
}

@media (max-width: 576px) {
  .app-content { padding: 1rem; }
  h1 { font-size: 1.35rem; }
}

/* ===== Stage 2: Master Data ===== */
.avatar-sm { width:40px; height:40px; border-radius:50%; object-fit:cover; }
.avatar-fallback { display:inline-flex; align-items:center; justify-content:center;
  background: var(--gradient-primary);
  color:#fff; font-weight:600; font-size:.8rem; }
.avatar-xl { width:140px; height:140px; border-radius:50%;
  background: var(--gradient-primary);
  color:#fff; font-weight:700; font-size:2.5rem;
  display:inline-flex; align-items:center; justify-content:center; }

.face-preview-wrap { position:relative; width:100%; aspect-ratio: 1/1;
  border:2px dashed var(--border-strong); border-radius: 14px;
  background:var(--surface-2); display:flex; align-items:center; justify-content:center;
  overflow:hidden; }
.face-preview-wrap img { max-width:100%; max-height:100%; object-fit:contain; display:block; }
.face-preview-wrap canvas { position:absolute; inset:0; pointer-events:none; }
.face-preview-wrap img:not([src]), .face-preview-wrap img[src=""] { display:none; }
.face-preview-wrap:empty::before, .face-preview-wrap:has(img:not([src])):after {
  content:'Preview foto'; color:var(--text-soft); font-size:.85rem; }

.shift-time { display:flex; flex-direction:column; gap:.25rem;
  background:var(--surface-2); padding:.7rem .9rem; border-radius:10px; font-size:.92rem; }

table.dataTable thead th { font-weight:600; font-size:.78rem; text-transform:uppercase;
  letter-spacing:.04em; color:var(--text-muted); }
.dataTables_wrapper .dt-buttons { margin-bottom:.5rem; }
.dt-search input, .dt-length select { border-radius:10px !important; border:1px solid var(--border-strong) !important; }

/* ============================================ Stage 3: Absensi */
.absen-wrap { padding-bottom: 24px; }
.absen-head {
  display:flex; align-items:center; gap:12px;
  margin: 0 0 1rem;
}
.absen-head .back-btn {
  width:40px; height:40px; border-radius:50%;
  display:grid; place-items:center;
  background: var(--surface); border:1px solid var(--border);
  color: var(--text); transition: var(--transition);
  text-decoration:none;
  flex-shrink:0;
}
.absen-head .back-btn:hover { background: var(--primary-soft); color: var(--primary-dark); border-color: var(--primary-soft); }
.absen-head .title { font-size:1.1rem; font-weight:700; color:var(--text); letter-spacing:-.01em; }
.absen-head .sub   { font-size:.78rem; color:var(--text-muted); margin-top:1px; }

.absen-camera-card {
  background: var(--surface);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  padding: 14px;
  box-shadow: var(--shadow-sm);
}
.cam-stage {
  position:relative;
  border-radius: var(--radius);
  overflow:hidden;
  background:#0b1220;
  aspect-ratio: 4/3;
}
.cam-stage video {
  width:100%; height:100%; object-fit:cover;
  transform: scaleX(-1);
}
.cam-stage canvas {
  position:absolute; inset:0; width:100%; height:100%;
  transform: scaleX(-1);
  pointer-events:none;
}
.cam-hud {
  position:absolute; left:8px; right:8px; bottom:8px;
  display:flex; gap:6px; flex-wrap:wrap;
}
.hud-pill {
  background: rgba(11,18,32,.72);
  color:#fff;
  font-size:.72rem;
  padding:.35rem .6rem;
  border-radius: var(--radius-full);
  display:inline-flex; align-items:center; gap:.35rem;
  backdrop-filter: blur(6px);
}
.hud-pill.ok  { background: rgba(16,185,129,.92); }
.hud-pill.bad { background: rgba(239,68,68,.92); }
.hud-pill.wait{ background: rgba(245,158,11,.92); }

.cam-meta { padding: 14px 4px 4px; font-size:.85rem; }
.cam-meta .meta-row {
  display:flex; justify-content:space-between; gap:10px;
  padding:.45rem 0;
  border-bottom: 1px dashed var(--border);
}
.cam-meta .meta-row:last-child { border-bottom: 0; }
.cam-meta .lbl { color: var(--text-muted); }
.cam-meta .val { font-weight:600; color: var(--text); text-align:right; }

.btn-absen {
  width:100%; margin-top:14px;
  background: var(--gradient-primary);
  color:#fff; border:0;
  padding: 14px 18px;
  border-radius: 12px;
  font-weight:700; font-size:1rem;
  display:flex; align-items:center; justify-content:center; gap:.5rem;
  box-shadow: var(--shadow-elegant);
  transition: var(--transition);
}
.btn-absen:disabled { opacity:.5; cursor:not-allowed; box-shadow:none; }
.btn-absen:not(:disabled):hover { transform: translateY(-1px); }
.btn-absen:not(:disabled):active { transform: translateY(0); }

/* ============================================ Stage 3: Riwayat */
.riwayat-row {
  display:grid;
  grid-template-columns: 56px 1fr auto auto;
  gap: 14px;
  align-items:center;
  padding: 14px 16px;
  border-bottom: 1px solid var(--border);
}
.riwayat-row:last-child { border-bottom: 0; }
.riwayat-row .r-date {
  text-align:center;
  background: var(--primary-soft);
  border-radius: 10px;
  padding: 6px 4px;
}
.riwayat-row .r-date .day { font-size:1.25rem; font-weight:800; color:var(--primary-dark); line-height:1; }
.riwayat-row .r-date .mon { font-size:.66rem; font-weight:700; color:var(--primary); letter-spacing:.06em; }

.riwayat-row .r-times .r-row {
  display:flex; gap:10px; justify-content:space-between;
  font-size:.85rem;
}
.riwayat-row .r-times .r-row span { color: var(--text-muted); }

.riwayat-row .r-thumbs { display:flex; gap:6px; }
.riwayat-row .r-thumbs img {
  width:44px; height:44px; object-fit:cover;
  border-radius: 8px;
  border:1px solid var(--border);
}
.riwayat-row .r-meta { text-align:right; font-size:.78rem; }
.riwayat-row .r-meta a { color: var(--primary-dark); }

@media (max-width: 575.98px) {
  .riwayat-row {
    grid-template-columns: 48px 1fr;
    grid-template-areas: "date times" "thumbs meta";
    row-gap: 8px;
  }
  .riwayat-row .r-date   { grid-area: date; }
  .riwayat-row .r-times  { grid-area: times; }
  .riwayat-row .r-thumbs { grid-area: thumbs; }
  .riwayat-row .r-meta   { grid-area: meta; text-align:right; }
}

/* ============================================ Stage 4: Cuti */
.cuti-row { display:flex; gap:14px; padding:14px 16px; border-bottom:1px solid var(--border); align-items:flex-start; }
.cuti-row:last-child{ border-bottom:0; }
.cuti-row .c-icon { width:44px; height:44px; border-radius:12px; display:grid; place-items:center; font-size:1.1rem; flex-shrink:0; }
.cuti-row .c-body { flex:1; min-width:0; }
.alert-soft { background: var(--primary-soft); border-radius:10px; padding:.55rem .8rem; font-size:.82rem; color:var(--text); }

/* Bootstrap subtle palette overrides */
.bg-primary-subtle{background:var(--primary-soft)!important}
.text-primary{color:var(--primary-dark)!important}
.bg-info-subtle{background:#e0f2fe!important}
.bg-warning-subtle{background:#fef3c7!important}
.bg-danger-subtle{background:#fee2e2!important}
.bg-success-subtle{background:#d1fae5!important}
.bg-secondary-subtle{background:#eef0f3!important}
.text-success{color:var(--primary-dark)!important}
.text-warning{color:#b45309!important}
.text-danger{color:#b91c1c!important}
.text-info{color:#0369a1!important}
.text-secondary{color:var(--text-muted)!important}

/* Bootstrap button primary recolor */
.btn-primary{ background:var(--primary)!important; border-color:var(--primary)!important; }
.btn-primary:hover{ background:var(--primary-dark)!important; border-color:var(--primary-dark)!important; }
.btn-outline-primary{ color:var(--primary-dark)!important; border-color:var(--primary)!important; }
.btn-outline-primary:hover{ background:var(--primary)!important; color:#fff!important; }

/* Badges/chips */
.badge.bg-primary{ background: var(--primary)!important; }

/* ============================================ Stage 4+: Notifikasi */
.mh-actions .mh-bell {
  position: relative;
  width: 40px; height: 40px;
  border-radius: 50%;
  display: grid; place-items: center;
  background: var(--primary-soft);
  color: var(--primary-dark);
  font-size: 1.05rem;
  text-decoration: none;
  transition: var(--transition);
}
.mh-actions .mh-bell:hover { background: var(--primary); color:#fff; }
.mh-actions .mh-bell .badge {
  position: absolute; top: -2px; right: -2px;
  background: #ef4444; color:#fff;
  font-size: .62rem; font-weight: 700;
  padding: 2px 5px; border-radius: 999px;
  border: 2px solid #fff;
  min-width: 18px; line-height:1;
}

.mobile-bottom-nav .nav-with-dot { position: relative; }
.mobile-bottom-nav .dot-badge {
  position: absolute; top: 4px; right: 22%;
  background: #ef4444; color:#fff;
  font-size:.6rem; font-weight:700;
  padding: 1px 5px; border-radius:999px;
  min-width: 16px; line-height:1.1;
  border: 2px solid #fff;
}

.notif-list { display:flex; flex-direction:column; gap: 10px; }
.notif-item {
  display: grid; grid-template-columns: 44px 1fr; gap: 12px;
  padding: 14px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 14px;
  text-decoration: none;
  color: inherit;
  transition: var(--transition);
}
.notif-item:hover { transform: translateY(-1px); box-shadow: var(--shadow-elegant); }
.notif-item.is-unread { background: var(--primary-soft); border-color: color-mix(in oklab, var(--primary) 30%, transparent); }
.notif-item .ico {
  width:44px; height:44px; border-radius:12px;
  display:grid; place-items:center;
  font-size:1.15rem;
  background: var(--surface-2); color: var(--text-muted);
}
.notif-item.tone-primary .ico { background: var(--primary-soft); color: var(--primary-dark); }
.notif-item.tone-success .ico { background: #d1fae5; color: #047857; }
.notif-item.tone-danger  .ico { background: #fee2e2; color: #b91c1c; }
.notif-item .body { min-width:0; }
.notif-item .title { font-weight: 700; font-size: .95rem; color: var(--text); }
.notif-item .msg   { font-size: .85rem; color: var(--text-muted); margin-top: 2px;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.notif-item .meta  { font-size: .72rem; color: var(--text-muted); margin-top: 6px; }
.notif-item .dot {
  width: 9px; height: 9px; border-radius: 50%;
  background: var(--primary); flex-shrink:0;
  box-shadow: 0 0 0 3px var(--primary-soft);
}
.notif-item.is-read { opacity: .8; }
.notif-item.is-read .title { font-weight: 600; }
