:root {
  --bg:#f7f3fb; --surface:#ffffff; --surface-soft:#fcf8ff; --line:#eadff7; --text:#231942; --muted:#6b7280;
  --primary:#6d28d9; --accent:#f59e0b; --success:#15803d; --success-bg:#ecfdf3; --warning:#b45309; --warning-bg:#fff7ed;
  --danger:#b91c1c; --danger-bg:#fef2f2; --sidebar:#3b0764; --sidebar-2:#581c87; --shadow:0 10px 30px rgba(35,25,66,.08); --radius:18px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:Arial,Helvetica,sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden}
button,input,select,textarea{font:inherit}
.hidden{display:none!important}

.login-shell{min-height:100vh;display:grid;place-items:center;padding:24px;background:
  radial-gradient(circle at top right,rgba(245,158,11,.18),transparent 30%),
  radial-gradient(circle at top left,rgba(109,40,217,.18),transparent 28%),var(--bg)}
.login-card{width:100%;max-width:1080px;display:grid;grid-template-columns:1.1fr .9fr;gap:20px;background:var(--surface);border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow);overflow:hidden}
.login-left{padding:40px;background:linear-gradient(180deg,var(--sidebar),var(--sidebar-2));color:#fff}
.login-left small{color:#d8b4fe;text-transform:uppercase;letter-spacing:.2em;font-size:11px;display:block;margin-bottom:10px}
.login-left h1{margin:0 0 12px;font-size:36px;line-height:1.1}
.login-left p{color:#f3e8ff;line-height:1.7}
.login-right{padding:40px}
.login-right h2{margin:0 0 8px;font-size:30px}
.login-right p{margin:0 0 22px;color:var(--muted)}

.app{display:grid;grid-template-columns:290px 1fr;min-height:100vh}
.sidebar-overlay{display:none}
.sidebar{background:linear-gradient(180deg,var(--sidebar),var(--sidebar-2));color:#fff;padding:24px 18px}
.brand small{display:block;color:#d8b4fe;text-transform:uppercase;letter-spacing:.18em;font-size:11px;margin-bottom:8px}
.brand h1{margin:0;font-size:24px;line-height:1.2}
.brand p{margin:8px 0 0;color:#f3e8ff;font-size:13px;line-height:1.5}
.candidate-box{margin-top:18px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:16px;text-align:center}
.candidate-photo{width:100%;max-width:230px;aspect-ratio:1/1;object-fit:cover;border-radius:20px;display:block;margin:0 auto 12px}
.candidate-caption{font-size:13px;color:#f3e8ff}
.user-box{margin-top:18px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:14px;font-size:13px;line-height:1.6}
.menu{margin-top:22px;display:flex;flex-direction:column;gap:8px}
.menu button{width:100%;text-align:left;border:0;background:transparent;color:#f3e8ff;padding:14px;border-radius:12px;cursor:pointer;font-size:14px}
.menu button:hover{background:rgba(255,255,255,.08)}
.menu button.active{background:var(--accent);color:#fff;font-weight:700}

.main{padding:28px;min-width:0}
.mobile-topbar{display:none;align-items:center;justify-content:space-between;margin-bottom:16px}
.mobile-title{font-size:20px;font-weight:700}
.mobile-menu-btn{display:none;width:48px;height:48px;background:var(--primary);color:#fff;border:0;border-radius:12px;font-size:22px;line-height:1;align-items:center;justify-content:center;box-shadow:var(--shadow)}

.topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:22px}
.topbar h2{margin:0;font-size:32px}
.topbar p{margin:8px 0 0;color:var(--muted);font-size:14px}
.actions{display:flex;gap:10px;flex-wrap:wrap}
.btn{border:1px solid var(--line);background:#fff;color:var(--text);padding:10px 16px;border-radius:12px;cursor:pointer;font-weight:700;text-decoration:none;display:inline-flex;align-items:center;justify-content:center}
.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}
.btn.secondary{background:var(--primary);border-color:var(--primary);color:#fff}
.btn.ghost{background:transparent}

.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;min-width:0}
.view{display:none}
.view.active{display:block}
.stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:22px}
.stat-title{color:var(--muted);font-size:13px;margin-bottom:12px}
.stat-value{font-size:32px;font-weight:700;margin-bottom:6px}
.stat-sub{color:var(--muted);font-size:13px}
.grid-2{display:grid;grid-template-columns:1.35fr 1fr;gap:16px;margin-bottom:22px}
.mini-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.mini-card{background:var(--surface-soft);border:1px solid #f1e8ff;border-radius:14px;padding:16px;min-width:0}
.mini-top{display:flex;justify-content:space-between;gap:8px;color:var(--muted);font-size:13px;margin-bottom:8px}
.mini-value{font-size:26px;font-weight:700;margin-bottom:12px}
.bar{height:10px;background:#eadcfb;border-radius:999px;overflow:hidden}
.bar > span{display:block;height:100%;background:var(--accent);border-radius:999px}
.tiny{margin-top:6px;color:var(--muted);font-size:12px}
.section-title{margin:0 0 4px;font-size:22px}
.section-sub{margin:0 0 18px;color:var(--muted);font-size:14px}
.info-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 18px;border-radius:14px;background:linear-gradient(90deg,rgba(109,40,217,.08),rgba(245,158,11,.10));border:1px solid var(--line);margin-bottom:22px}

table{width:100%;border-collapse:collapse;font-size:14px;table-layout:fixed}
th,td{padding:14px 10px;text-align:left;border-bottom:1px solid #f1e8ff;vertical-align:top;word-break:break-word}
th{color:var(--muted);font-size:13px}
.pill{display:inline-block;padding:6px 12px;border-radius:999px;font-size:12px;font-weight:700}
.pill.success{background:var(--success-bg);color:var(--success)}
.pill.warning{background:var(--warning-bg);color:var(--warning)}
.pill.danger{background:var(--danger-bg);color:var(--danger)}
.pill.primary{background:#f3e8ff;color:var(--primary)}

.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.field{display:flex;flex-direction:column;gap:8px;margin-bottom:16px;min-width:0}
.field.full{grid-column:1 / -1}
.field label{font-size:13px;font-weight:700;color:var(--text)}
.field input,.field select,.field textarea{width:100%;border:1px solid #d8cdee;background:#fff;color:var(--text);padding:12px 14px;border-radius:12px;outline:none;min-width:0}
.field textarea{min-height:110px;resize:vertical}
.toolbar{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:18px;flex-wrap:wrap}
.search{min-width:250px;max-width:320px;width:100%}

@media (max-width:1200px){
  .stats{grid-template-columns:repeat(2,minmax(0,1fr))}
  .grid-2,.mini-grid,.form-grid{grid-template-columns:1fr}
}
@media (max-width:960px){.login-card{grid-template-columns:1fr}}
@media (max-width:880px){
  .app{display:block}
  .sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.32);z-index:999}
  .app.sidebar-open .sidebar-overlay{display:block}
  .sidebar{display:none;position:fixed;top:0;left:0;width:min(86vw,320px);height:100dvh;z-index:1000;overflow-y:auto;overflow-x:hidden;padding-bottom:24px;-ms-overflow-style:none;scrollbar-width:none}
  .sidebar::-webkit-scrollbar{display:none}
  .app.sidebar-open .sidebar{display:block}
  .mobile-topbar{display:flex}
  .mobile-menu-btn{display:inline-flex}
  .main{padding:18px}
  .topbar{flex-direction:column}
  .stats,.form-grid{grid-template-columns:1fr}
  table,thead,tbody,tr,td,th{display:block;width:100%}
  thead{display:none}
  tbody tr{border:1px solid #f1e8ff;border-radius:14px;padding:10px 12px;margin-bottom:12px;background:#fff;overflow:hidden}
  td{border:0;padding:8px 0;white-space:normal;overflow-wrap:anywhere}
  td::before{content:attr(data-label);display:block;font-size:12px;font-weight:700;color:var(--muted);margin-bottom:4px}
}
