:root{
  /* Bright-but-soft website palette */
  --bg:#ffffff;
  --bg-soft:#fbfbff;
  --card:#ffffff;
  --border:#e6e8f3;
  --muted:#66708a;
  --text:#121826;
  --white:#ffffff;
  --accent:#2563eb;   /* vivid blue */
  --accent2:#ec4899;  /* vivid pink */
  --accent-soft:rgba(37,99,235,.10);
  --accent-soft2:rgba(236,72,153,.10);
  --link:#1d4ed8;
  /* "Simpan Data" style (purple -> blue 3D) for logo + dashboard button */
  --brandbtn-a:#c55cff;
  --brandbtn-b:#7c3aed;
  --brandbtn-c:#2563eb;
  --brandbtn-border:rgba(255,255,255,.30);
  --brandbtn-shadow:rgba(37,99,235,.22);
  --danger:#dc2626;
  --danger2:#b91c1c;
  --ok:#e7f6ee;
  --okb:#bde5cc;
  --warn:#fff3cd;
  --warnb:#ffe69c;
  --exp:#ffd6d6;
  --expb:#ff9b9b;
  --shadow:0 10px 22px rgba(17, 24, 39, .08);
  --radius:14px;
  --topbar-h:74px;
  --page-gutter:16px;
  --page-max:1700px;

  --row-even:#fbfcff;
  --hover:rgba(37,99,235,.07);
}
*{box-sizing:border-box}
body{
  margin:0;
  font-family:"Segoe UI",Tahoma,Arial,sans-serif;
  color:var(--text);
  background:var(--bg);
  padding:0 0 22px 0;
}
a{color:var(--link);text-decoration:none}
a:hover{text-decoration:underline}

/* Auth (Login/Setup) pages */
.auth-page{
  background:
    radial-gradient(1000px 520px at 10% 0%, rgba(236,72,153,.10), transparent 62%),
    radial-gradient(1100px 600px at 90% 0%, rgba(37,99,235,.10), transparent 62%),
    var(--bg);
}
.auth-topbar .topbar-row{justify-content:space-between}
.auth-page .topbar.auth-topbar{
  width:min(1100px, calc(100% - (var(--page-gutter) * 2)));
  margin:16px auto;
}
.auth-topbar-right{display:flex;align-items:center;gap:10px}
.auth-pill{
  display:inline-flex;
  align-items:center;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(37,99,235,.18);
  background:linear-gradient(180deg, rgba(236,72,153,.10), rgba(37,99,235,.08));
  color:var(--text);
  font-weight:900;
  font-size:12px;
}
.auth-main{
  width:min(1100px, calc(100% - (var(--page-gutter) * 2)));
  margin:0 auto;
  padding-bottom:6px;
}
.auth-main .panel{
  width:100%;
  margin:0 0 14px;
}
.auth-shell{padding:18px}
.auth-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:14px;
  align-items:stretch;
}
.auth-card{
  border:1px solid rgba(37,99,235,.14);
  background:linear-gradient(160deg, rgba(236,72,153,.08), rgba(37,99,235,.06));
  border-radius:var(--radius);
  padding:16px;
}
.auth-title{
  margin:0 0 6px;
  font-size:22px;
  letter-spacing:-.2px;
}
.auth-sub{margin:0 0 14px}
.auth-alert{
  padding:10px 12px;
  border-radius:12px;
  font-weight:800;
  font-size:13px;
  margin:0 0 12px;
}
.auth-alert-danger{
  border:1px solid rgba(220,38,38,.22);
  background:rgba(220,38,38,.10);
  color:#7f1d1d;
}
.auth-side-title{margin:0 0 10px;font-size:16px}
.auth-side-list{display:flex;flex-direction:column;gap:10px}
.auth-side-item strong{display:block;font-size:13px}
.auth-side-item span{display:block;font-size:12px;color:var(--muted);font-weight:700;margin-top:3px}
.auth-side-art{
  margin-top:14px;
  height:90px;
  border-radius:14px;
  border:1px dashed rgba(37,99,235,.22);
  background:
    radial-gradient(18px 18px at 16% 35%, rgba(236,72,153,.18), transparent 60%),
    radial-gradient(22px 22px at 48% 62%, rgba(37,99,235,.16), transparent 62%),
    radial-gradient(20px 20px at 78% 28%, rgba(236,72,153,.14), transparent 62%),
    rgba(255,255,255,.55);
}
.auth-disclaimer-title{margin:0 0 8px;font-size:16px}
.auth-disclaimer-text{margin:0;font-size:12px;line-height:1.6;color:var(--muted);font-weight:700}
.auth-footer{
  margin-top:12px;
  display:flex;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  font-size:11px;
  color:rgba(18,24,38,.60);
  font-weight:800;
}
@media (max-width: 980px){
  .auth-grid{grid-template-columns:1fr}
  .auth-shell{padding:14px}
}

.topbar{
  position:sticky;
  top:16px;
  z-index:999;
  background:#ffffff;
  border:1px solid rgba(37,99,235,.14);
  border-radius:18px;
  box-shadow:var(--shadow);
  padding:12px;
  overflow:hidden;
  width:auto;
  margin:16px var(--page-gutter);
}
.topbar-row{
  display:flex;
  align-items:center;
  gap:12px;
}
.topnav{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  flex:1;
  min-width:240px;
}
.brandbar{
  display:flex;
  align-items:center;
  gap:12px;
  padding:10px 12px;
  background:linear-gradient(140deg, rgba(236,72,153,.16), rgba(37,99,235,.12));
  color:var(--text);
  border-radius:16px;
  position:relative;
}
.brandbar::after{
  content:"";
  position:absolute;
  right:10px;
  top:8px;
  width:26px;
  height:26px;
  border-radius:50%;
  background:rgba(37,99,235,.16);
  box-shadow:0 0 0 10px rgba(37,99,235,.06);
}
.brandlogo{
  width:48px;
  height:48px;
  border-radius:12px;
  background:linear-gradient(180deg, var(--brandbtn-a) 0%, var(--brandbtn-b) 45%, var(--brandbtn-c) 100%);
  color:#ffffff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  letter-spacing:.6px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.48),
    inset 0 -2px 0 rgba(0,0,0,.12),
    0 4px 0 rgba(37,99,235,.18),
    0 12px 18px rgba(17,24,39,.12);
  border:1px solid rgba(255,255,255,.22);
}
.yt-play{
  width:0;
  height:0;
  border-top:8px solid transparent;
  border-bottom:8px solid transparent;
  border-left:14px solid rgba(255,255,255,.96);
  margin-left:3px;
}
.brandtext{line-height:1.2}
.brandtext .title{font-size:15px;font-weight:900}
.brandtext .sub{font-size:12px;opacity:.95}
.brandtext .title,.brandtext .sub{color:var(--text)}

.user-info{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(37,99,235,.12);
  background:#ffffff;
  font-size:13px;
  color:var(--text);
}
.user-stack{display:flex;flex-direction:column;line-height:1.1;min-width:0}
.user-line{font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-clock{font-size:11px;color:var(--muted);font-weight:700;margin-top:4px;white-space:nowrap}
.logout-btn{
  padding:7px 10px;
  font-size:12px;
  background:rgba(236,72,153,.10);
  color:var(--accent2);
  border:1px solid rgba(236,72,153,.22);
  border-radius:8px;
  cursor:pointer;
  font-weight:700;
}
.logout-btn:hover{background:rgba(236,72,153,.14)}

.navbtn{
  display:flex;
  align-items:center;
  gap:9px;
  min-height:44px;
  padding:8px 12px;
  border-radius:12px;
  border:1px solid rgba(18,24,38,.10);
  background:linear-gradient(180deg, #ffffff, #fbfaff);
  font-weight:800;
  font-size:13px;
  color:var(--text);
  box-shadow:none;
}
.navbtn:hover{
  background:linear-gradient(180deg, #ffffff, rgba(37,99,235,.05));
  text-decoration:none;
}
.navbtn.active{
  background:linear-gradient(180deg, rgba(37,99,235,.10), rgba(236,72,153,.08));
  color:var(--text);
  border-color:rgba(37,99,235,.18);
  box-shadow:none;
}
.navicon{
  min-width:20px;
  width:26px;
  height:26px;
  border-radius:8px;
  color:var(--text);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(180deg, rgba(37,99,235,.10), rgba(236,72,153,.07));
  border:1px solid rgba(37,99,235,.14);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.55);
}
.navicon svg{
  width:17px;
  height:17px;
  filter:drop-shadow(0 2px 0 rgba(0,0,0,.35));
}
.navbtn.active .navicon{
  color:var(--text);
  background:linear-gradient(180deg, rgba(37,99,235,.12), rgba(236,72,153,.10));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.55);
}

/* Top menu buttons: 3D gradient style like the reference button. */
.topnav .navbtn{
  border-color:rgba(37,99,235,.22);
  background:linear-gradient(180deg, var(--brandbtn-a) 0%, var(--brandbtn-b) 45%, var(--brandbtn-c) 100%);
  color:#ffffff;
  text-shadow:0 1px 0 rgba(0,0,0,.18);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.42),
    inset 0 -2px 0 rgba(0,0,0,.12),
    0 4px 0 rgba(37,99,235,.18),
    0 14px 20px rgba(17,24,39,.14);
  transform:translateY(0);
  transition:transform .12s ease, box-shadow .12s ease, filter .12s ease;
}
.topnav .navbtn:hover{filter:brightness(1.03) saturate(1.05)}
.topnav .navbtn:active{
  transform:translateY(1px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.40),
    inset 0 -2px 0 rgba(0,0,0,.12),
    0 2px 0 rgba(37,99,235,.18),
    0 10px 16px rgba(17,24,39,.14);
}
.topnav .navbtn .navicon{
  background:rgba(255,255,255,.18);
  border-color:rgba(255,255,255,.26);
}
.topnav .navbtn .navicon svg{
  /* Inline SVGs contain hard-coded colors; invert makes them readable on the gradient button. */
  filter:brightness(0) invert(1);
}

/* Keep active/selected menu item text white. */
.topnav .navbtn.active{
  color:#ffffff !important;
}
.navbtn.active{color:var(--text)}

.widget-title{
  font-size:12px;
  font-weight:900;
  color:var(--muted);
  margin-bottom:6px;
  text-transform:uppercase;
}
.clock-main{
  font-size:20px;
  line-height:1;
  font-weight:900;
  color:var(--text);
  margin-bottom:6px;
}
.clock-sub{font-size:12px;color:var(--muted);margin-bottom:2px}
.mini-calendar{
  width:100%;
  border-collapse:separate;
  border-spacing:3px;
  table-layout:fixed;
}
.mini-calendar th{
  font-size:10px;
  color:var(--muted);
  font-weight:900;
  text-align:center;
}
.mini-calendar td{
  font-size:11px;
  text-align:center;
  padding:5px 0;
  border-radius:7px;
  background:#ffffff;
  color:var(--text);
  border:1px solid var(--border);
}
.mini-calendar td.off{background:transparent}
.mini-calendar td.today{
  background:linear-gradient(180deg, rgba(37,99,235,.10), rgba(236,72,153,.08));
  color:var(--text);
  font-weight:900;
}

.panel{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:16px;
  width:auto;
  margin:0 var(--page-gutter) 14px;
  box-shadow:0 10px 22px rgba(17,24,39,.06);
  overflow-x:auto;
  position:relative;
}
.panel::before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:0;
  height:3px;
  background:linear-gradient(90deg, rgba(236,72,153,.70), rgba(37,99,235,.70));
  opacity:.55;
}
.dashboard-hero{
  background:
    radial-gradient(900px 420px at 10% 0%, rgba(236,72,153,.10), transparent 60%),
    radial-gradient(900px 420px at 90% 0%, rgba(37,99,235,.10), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.96), rgba(255,255,255,.90));
  border:1px solid rgba(37,99,235,.14);
  color:var(--text);
}
.dashboard-hero h2,
.dashboard-hero .hint,
.dashboard-hero label{
  color:var(--text);
}
.dashboard-hero .data-table th,
.dashboard-hero .data-table td{
  color:var(--text);
}
.dashboard-hero .data-table th{
  background:rgba(37,99,235,.05);
}
.dashboard-hero input,
.dashboard-hero select,
.dashboard-hero textarea{
  color:var(--text);
}
.dashboard-hero input::placeholder,
.dashboard-hero textarea::placeholder{
  color:#6a84a1;
}
.dashboard-hero .cardmini{
  background:linear-gradient(160deg, rgba(236,72,153,.10), rgba(37,99,235,.08));
  border:1px solid rgba(37,99,235,.14);
  color:var(--text);
}
.dashboard-hero .cardmini .k,
.dashboard-hero .cardmini .s{
  color:var(--muted);
}
h2{font-size:17px;margin:0 0 12px;font-weight:900;color:#2a2342}

.grid{display:grid;grid-template-columns:repeat(4, minmax(0, 1fr));gap:12px}
@media (max-width: 1300px){ .grid{grid-template-columns:repeat(2,minmax(0,1fr));} }
@media (max-width: 880px){ .grid{grid-template-columns:1fr;} }
.filter-controls{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  align-items:flex-end;
  margin:10px 0 12px;
}
.row-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:12px;
}

.field{display:flex;flex-direction:column}
label{font-size:12px;margin-bottom:6px;font-weight:800;color:#40577d}
input,select,textarea{
  padding:9px 10px;
  font-size:13px;
  border:1px solid var(--border);
  border-radius:10px;
  background:var(--bg-soft);
  color:var(--text);
}
textarea{min-height:70px;resize:vertical}
input:focus,select:focus,textarea:focus{
  outline:none;
  border-color:rgba(37,99,235,.30);
  box-shadow:0 0 0 3px rgba(37,99,235,.10);
}
input[readonly]{background:#f1f6ff}

.btn{
  padding:10px 14px;
  font-size:13px;
  font-weight:800;
  border:none;
  border-radius:10px;
  cursor:pointer;
  background:linear-gradient(135deg, #ec4899 0%, #2563eb 100%);
  color:#ffffff;
  border:1px solid rgba(37,99,235,.28);
  text-shadow:0 1px 0 rgba(0,0,0,.10);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.40),
    inset 0 -2px 0 rgba(0,0,0,.08),
    0 2px 0 rgba(37,99,235,.12),
    0 8px 14px rgba(17,24,39,.12);
  transform:translateY(0);
  transition:transform .12s ease, box-shadow .12s ease, filter .12s ease;
}
.btn:hover{
  filter:brightness(1.02) saturate(1.02);
}
.btn:active{
  transform:translateY(2px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.35),
    inset 0 -2px 0 rgba(0,0,0,.08),
    0 1px 0 rgba(37,99,235,.12),
    0 7px 12px rgba(17,24,39,.12);
}
.btn.secondary{
  background:linear-gradient(180deg, #ffffff, #f2f5f8);
  color:var(--text);
  border:1px solid var(--border);
  text-shadow:none;
  box-shadow:none;
}
.btn.secondary:hover{background:linear-gradient(180deg, #ffffff, #edf2f6)}
.btn.secondary:active{
  transform:none;
  box-shadow:none;
}
.btn.danger{
  background:linear-gradient(180deg, rgba(220,38,38,.14), rgba(220,38,38,.08));
  color:var(--danger2);
  border:1px solid rgba(220,38,38,.22);
  text-shadow:none;
  box-shadow:none;
}
.btn.danger:hover{background:linear-gradient(180deg, rgba(220,38,38,.18), rgba(220,38,38,.10))}
.btn.danger:active{
  transform:none;
  box-shadow:none;
}
.btn.outline{
  background:transparent;
  color:var(--accent);
  border:1px solid rgba(37,99,235,.26);
  text-shadow:none;
  box-shadow:none;
}
.btn.outline:hover{background:rgba(37,99,235,.06)}
.btn.outline:active{
  transform:none;
  box-shadow:none;
}

.btn-small{
  padding:6px 10px;
  font-size:11px;
  border-radius:10px;
  font-weight:900;
  border:none;
  cursor:pointer;
}
.btn-small.btn-outline{
  background:linear-gradient(180deg, #ffffff, rgba(37,99,235,.06));
  color:var(--text);
  border:1px solid var(--border);
}
.btn-small.btn-outline:hover{background:linear-gradient(180deg, #ffffff, rgba(236,72,153,.06))}
.btn-del{
  background:linear-gradient(170deg,#fff1f1,#ffe5e5);
  color:#a66666;
  border:1px solid #f3d3d3;
}
.btn-del:hover{background:linear-gradient(170deg,#ffe9e9,#ffdddd)}
.btn-edit{
  background:linear-gradient(170deg,#edf9f2,#e0f2e8);
  color:#4f7e66;
  border:1px solid #cae6d6;
}
.btn-edit:hover{background:linear-gradient(170deg,#e7f6ee,#d8eedf)}
.btn-backup{
  background:linear-gradient(170deg,#eef6ff,#e3efff);
  color:#0f4c8a;
  border:1px solid #cfe2ff;
}
.btn-backup:hover{background:linear-gradient(170deg,#e7f2ff,#d8e9ff)}
.btn-restore{
  background:linear-gradient(170deg,#fff7eb,#ffefd9);
  color:#9e7a4d;
  border:1px solid #f2e0bc;
}
.btn-restore:hover{background:linear-gradient(170deg,#fff2e2,#ffe9cf)}

.hint{font-size:12px;color:var(--muted);margin-top:8px}
.meta{display:flex;gap:12px;flex-wrap:wrap;margin:10px 0 12px}
.cardmini{
  background:linear-gradient(160deg, rgba(236,72,153,.08), rgba(37,99,235,.06));
  border:1px solid rgba(37,99,235,.12);
  border-radius:16px;
  padding:11px 13px;
  min-width:220px;
  flex:1;
}
.cardmini .k{font-size:11px;color:#4f6c94;font-weight:900;text-transform:uppercase}
.cardmini .k{color:var(--muted)}
.cardmini .v{font-size:21px;font-weight:1000;margin-top:4px}
.cardmini .s{font-size:12px;color:var(--muted);margin-top:4px}

.data-table{width:100%;border-collapse:collapse;font-size:12px;background:#fff}
.data-table th,.data-table td{border:1px solid var(--border);padding:8px 10px;text-align:left;white-space:nowrap;vertical-align:top}
.data-table th{
  background:linear-gradient(180deg, rgba(236,72,153,.10), rgba(37,99,235,.07));
  font-weight:900;
  position:sticky;
  top:0;
  z-index:12;
}
.data-table tbody tr:nth-child(even) td{background:var(--row-even)}
.data-table tbody tr:hover td{background:var(--hover);cursor:pointer}
.table-toolbar{position:sticky;top:0;z-index:12;display:flex;gap:8px;padding:6px 0;background:var(--card)}
.table-toolbar.sticky-float{
  position:fixed;
  right:20px;
  bottom:16px;
  top:auto;
  z-index:999;
  padding:8px;
  border:1px solid var(--border);
  border-radius:12px;
  background:rgba(255,255,255,.95);
  box-shadow:0 10px 22px rgba(17,24,39,.10);
  backdrop-filter:blur(6px);
}
.table-scroll{overflow-x:auto;position:relative}
.data-table th:nth-child(1), .data-table td:nth-child(1){position:sticky;left:0;z-index:11;background:#fff;min-width:70px}
.data-table th:nth-child(2), .data-table td:nth-child(2){position:sticky;left:70px;z-index:11;background:#fff;min-width:230px}
.data-table th:nth-child(3), .data-table td:nth-child(3){position:sticky;left:300px;z-index:11;background:#fff;min-width:260px}
.data-table th:nth-child(4), .data-table td:nth-child(4){position:sticky;left:560px;z-index:11;background:#fff;min-width:220px}
.data-table tbody tr:nth-child(even) td:nth-child(1){background:var(--row-even)}
.data-table tbody tr:nth-child(even) td:nth-child(2){background:var(--row-even)}
.data-table tbody tr:nth-child(even) td:nth-child(3){background:var(--row-even)}
.data-table tbody tr:nth-child(even) td:nth-child(4){background:var(--row-even)}
.data-table tbody tr:hover td:nth-child(1){background:var(--hover)}
.data-table tbody tr:hover td:nth-child(2){background:var(--hover)}
.data-table tbody tr:hover td:nth-child(3){background:var(--hover)}
.data-table tbody tr:hover td:nth-child(4){background:var(--hover)}
.data-table thead th:nth-child(1),
.data-table thead th:nth-child(2),
.data-table thead th:nth-child(3),
.data-table thead th:nth-child(4){z-index:13}

.badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:1000;margin-left:6px}
.badge.warn{background:var(--warn);color:#7a5a00;border:1px solid var(--warnb)}
.badge.expired{background:var(--exp);color:#8a0f0f;border:1px solid var(--expb)}
.badge.ok{background:var(--ok);color:#1b6b3a;border:1px solid var(--okb)}
.badge.libur{background:#eef2ff;color:#1e40af;border:1px solid #c7d2fe}
.badge.running{background:#d1fae5;color:#065f46;border:1px solid #6ee7b7}
.badge.schedule{background:#dbeafe;color:#1e40af;border:1px solid #93c5fd}
.expired-row{background:#fff1f1}
.warning-row{background:#fff9e9}
.libur-row{background:#f3f7ff}

#toast{
  position:fixed;
  right:18px;
  bottom:18px;
  background:#173562;
  color:#fff;
  padding:10px 14px;
  border-radius:12px;
  box-shadow:0 10px 26px rgba(0,0,0,.18);
  font-size:13px;
  font-weight:900;
  opacity:0;
  transform:translateY(8px);
  transition:opacity .15s ease, transform .15s ease;
  z-index:9999;
  pointer-events:none;
  max-width:70vw;
}
#toast.show{opacity:1;transform:translateY(0)}

.notification-box {
  background: rgba(245,158,11,.14);
  border: 1px solid rgba(245,158,11,.28);
  border-radius: 10px;
  padding: 10px;
  margin-bottom: 10px;
  font-weight: 600;
  color: #7a4a00;
}
.notification-box.danger {
  background: rgba(220,38,38,.12);
  border: 1px solid rgba(220,38,38,.22);
  color: #8a0f0f;
}

.backup-restore-container {
  display:flex;
  justify-content:space-between;
  gap:12px;
  margin-bottom:20px;
  background:var(--bg-soft);
  padding:10px;
  border-radius:10px;
  border:1px solid var(--border);
}

.backup-item {
  margin-bottom:15px;
  padding:15px;
  border-radius:10px;
  background:var(--bg-soft);
  border:1px solid var(--border);
}

.backup-item h3 {margin-top:0;color:var(--text)}
.backup-item p {margin-bottom:15px;color:var(--muted)}

.pagination {display:flex;justify-content:center;margin-top:20px}
.pagination button {
  margin:0 5px;
  padding:8px 12px;
  background:linear-gradient(180deg, #ffffff, var(--bg-soft));
  color:var(--text);
  border:1px solid var(--border);
  border-radius:5px;
  cursor:pointer;
}
.pagination button:hover {background:linear-gradient(180deg, #ffffff, rgba(37,99,235,.06))}
.pagination button:disabled {background:#f3f6f9;color:#97a6b6;cursor:not-allowed}
.pagination .current {background:linear-gradient(180deg, rgba(236,72,153,.14), rgba(37,99,235,.10));color:var(--text);border-color:rgba(37,99,235,.18)}

.loading-indicator {
  display:none;
  position:fixed;
  top:50%;
  left:50%;
  transform:translate(-50%, -50%);
  background:rgba(0, 0, 0, 0.8);
  color:#fff;
  padding:20px;
  border-radius:10px;
  z-index:10000;
}

.deadline-modal{
  position:fixed;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  z-index:10020;
  background:rgba(15,23,42,.45);
  backdrop-filter:blur(2px);
}
.deadline-modal.show{display:flex}
.deadline-modal-card{
  width:min(860px, 92vw);
  max-height:82vh;
  overflow:auto;
  background:#fff;
  border:1px solid #dbe6f3;
  border-radius:14px;
  box-shadow:0 18px 36px rgba(15,23,42,.22);
  padding:14px;
}
.deadline-modal-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom:10px;
}
.deadline-modal-head h3{
  margin:0;
  color:#17344f;
  font-size:18px;
}
.deadline-modal-list{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.deadline-item{
  border:1px solid #dbe6f3;
  border-radius:10px;
  background:#f8fbff;
  padding:10px;
}
.deadline-item strong{color:#0f2f55}
.deadline-item small{display:block;color:#5d7490;font-weight:700;margin-top:3px}
.deadline-item.expired{
  background:#fff5f5;
  border-color:#f2c3c3;
}

@media (max-width: 980px){
  body{padding:12px}
  .topbar{
    position:static;
    left:auto;
    right:auto;
    top:auto;
    width:auto;
    margin:12px;
  }
  .panel{width:auto}
  .table-toolbar.sticky-float{
    right:12px;
    bottom:12px;
  }
}
