:root{
  --primary:#0f4dab;
  --primary-2:#2563eb;
  --accent:#10b981;
  --dark:#071326;
  --soft:#f4f7fb;
  --line:#e2e8f0;
  --text:#0f172a;
  --muted:#64748b;
  --white:#ffffff;
  --danger:#dc2626;
  --shadow:0 18px 50px rgba(15,23,42,.08);
  --radius:20px;
}
*{box-sizing:border-box}
body{margin:0;font-family:Inter,system-ui,Segoe UI,Arial,sans-serif;background:linear-gradient(180deg,#f7fbff,#eef4fb);color:var(--text);line-height:1.55}
a{color:inherit;text-decoration:none}

.admin-shell{display:grid;grid-template-columns:292px 1fr;min-height:100vh}
.side{position:sticky;top:0;height:100vh;background:linear-gradient(180deg,#071326,#0b1d36);color:#fff;padding:24px;display:flex;flex-direction:column;box-shadow:12px 0 34px rgba(7,19,38,.12)}
.side-brand,.brand-login{display:flex;align-items:center;gap:14px}
.brand-mark{width:52px;height:52px;border-radius:16px;background:linear-gradient(135deg,var(--primary-2),var(--accent));display:grid;place-items:center;font-weight:900;color:#fff;box-shadow:0 12px 28px rgba(37,99,235,.25);overflow:visible;flex-shrink:0}.brand-mark img{width:100%;height:100%;object-fit:cover;display:block}.brand-logo{background:transparent;border:none;box-shadow:none}
.side h2{font-size:20px;line-height:1.1;margin:0}.side p{margin:4px 0 0;color:#b9c7dc;font-size:13px}.side-nav{margin-top:30px;display:grid;gap:7px}.side-nav a{display:flex;align-items:center;gap:12px;color:#d8e4f3;padding:12px 14px;border-radius:14px;font-weight:700;transition:.22s}.side-nav a span{width:26px;text-align:center}.side-nav a:hover,.side-nav a.active{background:rgba(37,99,235,.20);color:#fff;transform:translateX(3px)}.side-nav a.active{box-shadow:inset 3px 0 0 #38bdf8;background:linear-gradient(90deg,rgba(37,99,235,.35),rgba(16,185,129,.10))}.side-footer{margin-top:auto;display:grid;gap:10px}.side-footer a{display:block;padding:12px 14px;border-radius:14px;font-weight:800}.visit{background:rgba(255,255,255,.08);color:#fff}.logout{background:rgba(220,38,38,.14);color:#fecaca}

.main{padding:28px;min-width:0}.admin-topbar{height:76px;background:rgba(255,255,255,.82);backdrop-filter:blur(14px);border:1px solid rgba(226,232,240,.9);border-radius:22px;padding:16px 20px;margin-bottom:22px;display:flex;align-items:center;justify-content:space-between;gap:16px;box-shadow:0 12px 30px rgba(15,23,42,.04)}.top-label{display:block;color:var(--primary);font-size:12px;font-weight:900;letter-spacing:.05em;text-transform:uppercase}.admin-topbar strong{font-size:18px}.admin-user{display:flex;align-items:center;gap:10px;color:#334155;font-weight:800}.avatar{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,#e0f2fe,#dbeafe);color:var(--primary);border:1px solid #bfdbfe}
.top{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:18px}.top h1{margin:0;font-size:34px;letter-spacing:-.8px}.top p{color:var(--muted);margin:4px 0 0}

.card{background:rgba(255,255,255,.95);border:1px solid rgba(226,232,240,.92);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);margin-bottom:18px;overflow-x:auto}.card h2{margin:0 0 14px;font-size:22px}.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.stats-grid{margin-bottom:18px}.stat-card{display:flex;align-items:center;gap:16px;margin-bottom:0;transition:.22s}.stat-card:hover{transform:translateY(-4px)}.stat-card strong{display:block;font-size:34px;line-height:1;color:var(--primary)}.stat-card span{color:var(--muted);font-weight:800}.stat-icon{width:54px;height:54px;border-radius:18px;display:grid;place-items:center;background:#eef6ff;font-size:24px;color:var(--primary)}
.welcome-card{position:relative;overflow:hidden;background:linear-gradient(135deg,#0f4dab,#0b6bdc);color:#fff;border-radius:28px;padding:28px;margin-bottom:18px;display:flex;justify-content:space-between;gap:24px;box-shadow:0 22px 50px rgba(15,77,171,.20)}.welcome-card::after{content:"";position:absolute;right:-80px;top:-90px;width:260px;height:260px;border-radius:50%;background:rgba(255,255,255,.12)}.welcome-card h1{font-size:36px;line-height:1.12;margin:8px 0 10px;letter-spacing:-1px}.welcome-card p{margin:0;color:#e0ecff;max-width:760px}.welcome-action{display:flex;align-items:center;gap:12px;flex-wrap:wrap;position:relative;z-index:1}.btn{border:0;border-radius:12px;padding:11px 16px;background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;font-weight:900;cursor:pointer;transition:.2s;box-shadow:0 10px 24px rgba(37,99,235,.18)}.btn:hover{transform:translateY(-2px)}.btn.red{background:var(--danger);box-shadow:0 10px 24px rgba(220,38,38,.16)}.btn.gray,.btn.ghost{background:#475569}.welcome-card .btn{background:#fff;color:var(--primary)}.welcome-card .btn.ghost{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.26);color:#fff}.btn-wide{width:100%;padding:14px 18px}
.dashboard-grid{display:grid;grid-template-columns:1.4fr .8fr;gap:18px}.feature-list{display:grid;gap:12px}.feature-list div{display:grid;gap:2px;padding:14px 16px;border-radius:16px;background:#f8fbff;border:1px solid #e7eef8}.feature-list span{color:var(--muted);font-size:14px}.quick-card{display:grid;gap:10px;align-content:start}.quick-card a{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border:1px solid #e7eef8;border-radius:16px;background:#f8fbff;font-weight:900;color:#0f3f85;transition:.2s}.quick-card a:hover{background:#eef6ff;transform:translateX(2px)}.quick-card small{color:var(--muted)}

table{width:100%;border-collapse:collapse;background:#fff;border-radius:16px;overflow:hidden;min-width:760px}th,td{border-bottom:1px solid #e5e7eb;padding:13px;text-align:left;vertical-align:top}th{background:#eef5ff;color:#0f3f85;font-size:13px;text-transform:uppercase;letter-spacing:.03em}tr:hover td{background:#fbfdff}.form{display:grid;gap:14px}label{font-weight:800;color:#334155}input,textarea,select{width:100%;padding:13px 14px;border:1px solid #cbd5e1;border-radius:12px;font-family:inherit;background:#fff;margin-top:6px;transition:border-color .2s, box-shadow .2s}input:focus,textarea:focus,select:focus{outline:none;border-color:#93c5fd;box-shadow:0 0 0 4px rgba(59,130,246,.12)}textarea{min-height:150px}.actions{display:flex;gap:8px;flex-wrap:wrap}.alert{padding:13px 15px;border-radius:14px;background:#ecfdf5;color:#065f46;margin-bottom:14px;border:1px solid #bbf7d0;font-weight:700}.bad{background:#fef2f2;color:#991b1b;border-color:#fecaca}

.login-page{min-height:100vh;background:radial-gradient(circle at 20% 20%,rgba(37,99,235,.18),transparent 28%),linear-gradient(135deg,#071326,#0b3f8d);display:grid;place-items:center;padding:28px}.login-shell{width:min(1040px,96vw);display:grid;grid-template-columns:1.1fr .9fr;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:30px;overflow:hidden;box-shadow:0 28px 80px rgba(0,0,0,.28);backdrop-filter:blur(14px)}.login-visual{color:#fff;padding:54px;display:flex;flex-direction:column;justify-content:center;min-height:560px;background:linear-gradient(135deg,rgba(15,77,171,.44),rgba(16,185,129,.18))}.login-badge{display:inline-flex;width:max-content;padding:9px 14px;border-radius:999px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.20);font-size:12px;font-weight:900;letter-spacing:.04em;text-transform:uppercase}.login-visual h1{font-size:48px;line-height:1.05;margin:18px 0 14px;letter-spacing:-1.2px}.login-visual p{color:#dbeafe;font-size:17px;max-width:560px}.login-points{display:flex;gap:10px;flex-wrap:wrap;margin-top:24px}.login-points span{padding:10px 12px;border-radius:999px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.16);font-weight:800;font-size:13px}.login-card{background:#fff;padding:46px;display:flex;flex-direction:column;justify-content:center}.brand-login{margin-bottom:26px}.brand-login h2{font-size:30px;margin:0}.brand-login p{color:var(--muted);margin:4px 0 0}.login-form{gap:16px}.back-link{text-align:center;margin:18px 0 0}.back-link a{color:var(--primary);font-weight:800}

@media(max-width:1000px){.admin-shell{grid-template-columns:1fr}.side{position:static;height:auto}.side-nav{grid-template-columns:repeat(2,1fr)}.side-footer{grid-template-columns:1fr 1fr}.grid,.dashboard-grid{grid-template-columns:1fr 1fr}.welcome-card{flex-direction:column}.login-shell{grid-template-columns:1fr}.login-visual{min-height:auto;padding:34px}.login-visual h1{font-size:38px}}
@media(max-width:640px){.main{padding:16px}.admin-topbar{height:auto;align-items:flex-start;flex-direction:column}.side{padding:18px}.side-nav{grid-template-columns:1fr}.grid,.dashboard-grid{grid-template-columns:1fr}.top{align-items:flex-start;flex-direction:column}.top h1{font-size:28px}.welcome-card{padding:22px}.welcome-card h1{font-size:30px}.login-card{padding:28px}.login-visual h1{font-size:32px}}


/* Admin Data Penduduk */
.form-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.form-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.admin-filter{display:grid;grid-template-columns:1fr 260px auto;gap:12px;margin:12px 0 18px}.compact{margin-bottom:12px}.muted{color:#64748b;font-size:14px}.permanent-note{padding:13px 15px;border-radius:14px;background:#eff6ff;border:1px solid #bfdbfe;color:#0f3f85;font-weight:800;margin-bottom:14px}.admin-stats-6{grid-template-columns:repeat(6,1fr)}.admin-stats-3{grid-template-columns:repeat(3,1fr)}code{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:8px;padding:4px 6px;color:#0f172a}@media(max-width:1200px){.admin-stats-6{grid-template-columns:repeat(3,1fr)}}@media(max-width:760px){.form-grid-2,.form-grid-3,.admin-filter,.admin-stats-6,.admin-stats-3{grid-template-columns:1fr}}

.privacy-admin-note{margin-bottom:18px;padding:14px 16px;border-radius:14px;background:#eff6ff;border:1px solid #bfdbfe;color:#1e3a8a}.private-label{display:inline-flex;margin-left:8px;padding:3px 8px;border-radius:999px;background:#dbeafe;color:#1d4ed8;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.04em}
.inline-form{display:inline-flex;margin:0}
.inline-form .btn{margin:0}
.logout-form{margin:0}.logout-form .logout{width:100%;border:0;background:transparent;text-align:left;cursor:pointer;font:inherit}
.table-scroll{overflow:auto}
.password-card{max-width:680px}
.status-form{display:flex;gap:8px;align-items:center;min-width:220px}.status-form select{min-width:110px}
