:root{
  --bg:#EFF3F8;
  --bg-alt:#E4EAF3;
  --surface:#FFFFFF;
  --surface-2:#F7FAFD;
  --ink:#1B2733;
  --ink-soft:#54626F;
  --ink-faint:#8794A1;
  --line:#DCE3EB;
  --line-soft:#E9EEF3;

  --accent:#1E4B8C;
  --accent-dark:#153761;
  --accent-soft:#DCE7F6;
  --accent-soft-ink:#153761;

  --warm:#AD6F26;
  --warm-soft:#F3E2C6;
  --warm-soft-ink:#7A4E17;

  --privacy:#55599E;
  --privacy-soft:#E5E6F4;
  --privacy-soft-ink:#38396B;

  --urgent:#A8452F;
  --urgent-soft:#F4DCD3;
  --urgent-soft-ink:#7A2E1B;

  --font-display:'Fraunces', Georgia, serif;
  --font-body:'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-mono:'IBM Plex Mono', 'SFMono-Regular', Consolas, monospace;

  --radius:16px;
  --radius-sm:10px;
  --radius-pill:999px;
  --shadow-sm:0 1px 2px rgba(27,39,51,.06), 0 1px 1px rgba(27,39,51,.04);
  --shadow-md:0 12px 28px -10px rgba(27,39,51,.22);
}

*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:15px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
#app{min-height:100vh;display:flex;flex-direction:column;}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;margin:0;color:var(--ink);}
p{margin:0;}
button{font-family:inherit;cursor:pointer;}
input,select,textarea{font-family:inherit;font-size:14px;color:var(--ink);}
a{color:var(--accent-dark);}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;}

/* ---------- Topbar ---------- */
.topbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 32px;background:var(--surface);
  border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:20;
  gap:16px;flex-wrap:wrap;
}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;}
.brand-mark{width:34px;height:34px;flex-shrink:0;}
.brand-text h1{font-size:19px;letter-spacing:.2px;}
.brand-text span{display:block;font-size:11.5px;color:var(--ink-soft);margin-top:1px;}

.topbar-right{display:flex;align-items:center;gap:14px;}
.user-chip{
  display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--ink-soft);
}
.user-chip .avatar{
  width:26px;height:26px;border-radius:50%;background:var(--accent-soft);color:var(--accent-soft-ink);
  display:flex;align-items:center;justify-content:center;font-size:11.5px;font-weight:700;
}

main{flex:1;display:flex;flex-direction:column;}
.wrap{max-width:1080px;margin:0 auto;padding:0 32px;}

/* ---------- Buttons ---------- */
.btn{
  border-radius:var(--radius-sm);padding:13px 22px;font-size:14.5px;font-weight:600;
  border:1px solid transparent;transition:.15s;display:inline-flex;align-items:center;gap:8px;
}
.btn-primary{background:var(--accent);color:#fff;box-shadow:var(--shadow-sm);}
.btn-primary:hover{background:var(--accent-dark);}
.btn-ghost{background:var(--surface);color:var(--ink);border-color:var(--line);}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent-dark);}
.btn-sm{padding:8px 14px;font-size:13px;border-radius:8px;}
.btn-block{width:100%;justify-content:center;}
.btn[disabled]{opacity:.5;cursor:not-allowed;}

/* ---------- Employee: home ---------- */
.hero{padding:64px 0 40px;}
.hero-eyebrow{
  font-family:var(--font-mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--accent-dark);margin-bottom:14px;display:flex;align-items:center;gap:8px;
}
.hero-eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);}
.hero h2{font-size:40px;line-height:1.15;max-width:620px;letter-spacing:-.01em;}
.hero p.lead{margin-top:16px;font-size:16px;color:var(--ink-soft);max-width:480px;}

.cta-row{display:flex;gap:14px;margin-top:32px;flex-wrap:wrap;}

.reassure-row{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:48px;}
.reassure-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:20px;}
.reassure-card .ic{width:22px;height:22px;margin-bottom:12px;color:var(--accent-dark);}
.reassure-card h4{font-size:14.5px;font-weight:600;font-family:var(--font-body);}
.reassure-card p{font-size:13px;color:var(--ink-soft);margin-top:6px;}

/* ---------- Card / form ---------- */
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);}
.form-shell{max-width:640px;margin:40px auto 80px;}
.form-head{padding:28px 32px 0;}
.form-head .back{font-size:13px;color:var(--ink-soft);background:none;border:none;padding:0;display:flex;align-items:center;gap:6px;margin-bottom:18px;font-weight:600;}
.form-head .back:hover{color:var(--accent-dark);}
.form-head h2{font-size:24px;}
.form-head p{color:var(--ink-soft);font-size:13.5px;margin-top:8px;}

.f-section{padding:26px 32px;border-top:1px solid var(--line-soft);}
.f-section:first-of-type{border-top:none;margin-top:22px;}
.f-step{display:flex;align-items:center;gap:10px;margin-bottom:18px;}
.f-step .num{font-family:var(--font-mono);font-size:11.5px;width:22px;height:22px;border-radius:50%;background:var(--accent-soft);color:var(--accent-soft-ink);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-weight:600;}
.f-step h3{font-size:14.5px;font-weight:700;font-family:var(--font-body);letter-spacing:.01em;}

.field{margin-bottom:16px;}
.field:last-child{margin-bottom:0;}
.field label{display:block;font-size:13px;font-weight:600;color:var(--ink);margin-bottom:7px;}
.field .hint{font-size:12px;color:var(--ink-faint);margin-top:6px;}
.field input[type=text], .field input[type=email], .field input[type=password], .field select, .field textarea{
  width:100%;border:1px solid var(--line);border-radius:9px;padding:11px 13px;background:var(--surface-2);transition:.15s;
}
.field input:focus, .field select:focus, .field textarea:focus{border-color:var(--accent);background:#fff;}
.field textarea{resize:vertical;min-height:100px;line-height:1.5;}

.seg{display:flex;border:1px solid var(--line);border-radius:var(--radius-pill);padding:3px;background:var(--surface-2);gap:2px;}
.seg button{flex:1;border:none;background:transparent;padding:9px 10px;border-radius:var(--radius-pill);font-size:13px;font-weight:600;color:var(--ink-soft);}
.seg button.active{background:var(--ink);color:#fff;}
.seg.seg-2 button.active{background:var(--accent);}

.pill-group{display:flex;gap:8px;flex-wrap:wrap;}
.pill-opt{border:1px solid var(--line);background:var(--surface-2);border-radius:var(--radius-pill);padding:8px 15px;font-size:13px;font-weight:600;color:var(--ink-soft);}
.pill-opt.active[data-u="Rendah"]{background:var(--accent-soft);border-color:var(--accent-soft);color:var(--accent-soft-ink);}
.pill-opt.active[data-u="Sedang"]{background:var(--warm-soft);border-color:var(--warm-soft);color:var(--warm-soft-ink);}
.pill-opt.active[data-u="Tinggi"], .pill-opt.active[data-u="Darurat"]{background:var(--urgent-soft);border-color:var(--urgent-soft);color:var(--urgent-soft-ink);}

.anon-badge{margin-top:10px;display:inline-flex;align-items:center;gap:8px;background:var(--privacy-soft);color:var(--privacy-soft-ink);padding:8px 13px;border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:12.5px;font-weight:600;}
.anon-badge .ic{width:14px;height:14px;flex-shrink:0;}

.note-box{border-radius:10px;padding:13px 15px;font-size:12.8px;line-height:1.55;margin-top:12px;display:flex;gap:10px;}
.note-box.warm{background:var(--warm-soft);color:var(--warm-soft-ink);}
.note-box.urgent{background:var(--urgent-soft);color:var(--urgent-soft-ink);}
.note-box .ic{width:16px;height:16px;flex-shrink:0;margin-top:1px;}

.form-foot{padding:24px 32px 32px;}
.privacy-line{display:flex;align-items:flex-start;gap:8px;font-size:12px;color:var(--ink-faint);margin-top:14px;line-height:1.5;}
.privacy-line .ic{width:14px;height:14px;flex-shrink:0;margin-top:2px;}

/* ---------- Ticket stub ---------- */
.stub-wrap{max-width:520px;margin:56px auto 80px;text-align:center;}
.stub-wrap > p.eyebrow{font-family:var(--font-mono);font-size:12px;color:var(--accent-dark);text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px;}
.stub-wrap h2{font-size:24px;margin-bottom:6px;}
.stub-wrap > p.sub{color:var(--ink-soft);font-size:14px;margin-bottom:28px;}
.stub{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-md);padding:30px 28px;text-align:left;overflow:visible;}
.stub::before, .stub::after{content:"";position:absolute;width:24px;height:24px;background:var(--bg);border-radius:50%;top:50%;transform:translateY(-50%);}
.stub::before{left:-12px;}
.stub::after{right:-12px;}
.stub-perf{border-top:1.5px dashed var(--line);margin:20px 0;}
.stub-label{font-size:11px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.09em;margin-bottom:4px;}
.stub-code{font-family:var(--font-mono);font-size:28px;font-weight:600;letter-spacing:.02em;color:var(--accent-dark);}
.stub-meta{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;}
.stub-meta div{flex:1;min-width:120px;}
.stub-meta .k{font-size:10.5px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.07em;margin-bottom:3px;}
.stub-meta .v{font-size:13.5px;font-weight:600;}
.stub-actions{margin-top:26px;display:flex;gap:10px;flex-wrap:wrap;justify-content:center;}

/* ---------- Badges ---------- */
.badge{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;padding:4px 10px;border-radius:var(--radius-pill);white-space:nowrap;}
.badge.b-accent{background:var(--accent-soft);color:var(--accent-soft-ink);}
.badge.b-warm{background:var(--warm-soft);color:var(--warm-soft-ink);}
.badge.b-privacy{background:var(--privacy-soft);color:var(--privacy-soft-ink);}
.badge.b-urgent{background:var(--urgent-soft);color:var(--urgent-soft-ink);}
.badge.b-neutral{background:var(--bg-alt);color:var(--ink-soft);}

/* ---------- Status stepper ---------- */
.stepper{display:flex;align-items:center;margin:22px 0 6px;}
.step{display:flex;flex-direction:column;align-items:center;flex:1;position:relative;}
.step .dot{width:13px;height:13px;border-radius:50%;background:var(--line);border:2px solid var(--line);z-index:1;}
.step.done .dot{background:var(--accent);border-color:var(--accent);}
.step.current .dot{background:#fff;border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft);}
.step .lbl{font-size:11px;color:var(--ink-faint);margin-top:8px;text-align:center;max-width:82px;font-weight:600;}
.step.done .lbl, .step.current .lbl{color:var(--ink);}
.step::before{content:"";position:absolute;top:6px;left:-50%;width:100%;height:2px;background:var(--line);z-index:0;}
.step:first-child::before{display:none;}
.step.done::before{background:var(--accent);}

.status-shell{max-width:520px;margin:56px auto 80px;}
.status-search{display:flex;gap:10px;margin-top:22px;}
.status-search input{flex:1;text-transform:uppercase;font-family:var(--font-mono);}
.status-result{margin-top:26px;padding:24px;}
.status-error{margin-top:18px;background:var(--urgent-soft);color:var(--urgent-soft-ink);padding:12px 15px;border-radius:10px;font-size:13px;}

footer{border-top:1px solid var(--line);padding:20px 32px;text-align:center;font-size:12px;color:var(--ink-faint);}
footer a{color:var(--ink-faint);}

.hidden{display:none !important;}

/* ============================================================
   LOGIN
   ============================================================ */
.auth-shell{
  flex:1;display:flex;align-items:center;justify-content:center;padding:40px 20px;
}
.auth-card{max-width:400px;width:100%;padding:36px 32px;}
.auth-card .brand{justify-content:center;margin-bottom:22px;}
.auth-card h2{font-size:22px;text-align:center;}
.auth-card p.sub{text-align:center;color:var(--ink-soft);font-size:13.5px;margin-top:8px;margin-bottom:26px;}
.auth-error{background:var(--urgent-soft);color:var(--urgent-soft-ink);padding:11px 14px;border-radius:9px;font-size:13px;margin-bottom:16px;}
.auth-foot{text-align:center;margin-top:20px;font-size:12.5px;color:var(--ink-faint);}

/* ============================================================
   HR DASHBOARD
   ============================================================ */
.hr-shell{padding:36px 0 80px;}
.hr-head{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;flex-wrap:wrap;margin-bottom:26px;}
.hr-head h2{font-size:26px;}
.hr-head p{color:var(--ink-soft);font-size:13.5px;margin-top:6px;}

.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px;}
.stat-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:20px;}
.stat-card .v{font-family:var(--font-display);font-size:30px;font-weight:600;}
.stat-card .l{font-size:12.5px;color:var(--ink-soft);margin-top:4px;font-weight:600;}

.hr-grid{display:grid;grid-template-columns:1.1fr 1.6fr;gap:16px;margin-bottom:20px;align-items:start;}
.chart-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px;}
.chart-card h3{font-size:14px;font-family:var(--font-body);font-weight:700;margin-bottom:16px;}
.bar-row{margin-bottom:12px;}
.bar-row .bl{display:flex;justify-content:space-between;font-size:12.5px;margin-bottom:5px;color:var(--ink-soft);font-weight:600;}
.bar-track{height:9px;background:var(--bg-alt);border-radius:5px;overflow:hidden;}
.bar-fill{height:100%;background:var(--accent);border-radius:5px;}

.counsel-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px;}
.counsel-card h3{font-size:14px;font-family:var(--font-body);font-weight:700;margin-bottom:14px;}
.counsel-list{display:flex;flex-direction:column;gap:10px;}
.counsel-item{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:11px 13px;background:var(--surface-2);border-radius:10px;border:1px solid var(--line-soft);cursor:pointer;}
.counsel-item .code{font-family:var(--font-mono);font-size:12.5px;font-weight:600;}
.counsel-empty{color:var(--ink-faint);font-size:13px;padding:8px 0;}

.filter-bar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;align-items:center;}
.filter-bar input[type=text]{border:1px solid var(--line);border-radius:8px;padding:9px 12px;background:var(--surface-2);font-size:13px;min-width:200px;flex:1;}
.filter-bar select{border:1px solid var(--line);border-radius:8px;padding:9px 10px;background:var(--surface-2);font-size:13px;}
.filter-chk{display:flex;align-items:center;gap:7px;font-size:12.8px;font-weight:600;color:var(--ink-soft);white-space:nowrap;}

.table-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;}
table{width:100%;border-collapse:collapse;}
thead th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-faint);padding:12px 16px;border-bottom:1px solid var(--line);background:var(--surface-2);font-weight:700;}
tbody td{padding:13px 16px;border-bottom:1px solid var(--line-soft);font-size:13px;vertical-align:middle;}
tbody tr{cursor:pointer;transition:.12s;}
tbody tr:hover{background:var(--surface-2);}
tbody tr:last-child td{border-bottom:none;}
.code-cell{font-family:var(--font-mono);font-weight:600;font-size:12.5px;}
.empty-row td{text-align:center;color:var(--ink-faint);padding:34px;font-size:13.5px;}

/* ---------- Modal ---------- */
.modal-overlay{position:fixed;inset:0;background:rgba(27,39,51,.45);display:flex;align-items:flex-start;justify-content:center;padding:48px 20px;z-index:50;overflow-y:auto;}
.modal{background:var(--surface);border-radius:18px;max-width:620px;width:100%;box-shadow:var(--shadow-md);margin-bottom:40px;}
.modal-head{display:flex;justify-content:space-between;align-items:flex-start;padding:24px 26px 0;}
.modal-head .x{background:var(--bg-alt);border:none;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--ink-soft);flex-shrink:0;}
.modal-head .x:hover{background:var(--line);}
.modal-body{padding:18px 26px 26px;}
.modal-badges{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0 18px;}
.modal-code{font-family:var(--font-mono);font-size:20px;font-weight:600;color:var(--accent-dark);}
.modal-meta-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:18px;}
.modal-meta-grid .k{font-size:10.5px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.06em;margin-bottom:3px;}
.modal-meta-grid .v{font-size:13.5px;font-weight:600;}
.desc-box{background:var(--surface-2);border:1px solid var(--line-soft);border-radius:10px;padding:15px;font-size:13.5px;line-height:1.6;color:var(--ink);margin-bottom:20px;white-space:pre-wrap;}
.modal-section-title{font-size:12.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft);margin-bottom:10px;}
.update-block{border-top:1px solid var(--line-soft);padding-top:18px;margin-top:6px;}
.update-row{display:flex;gap:10px;margin-bottom:10px;}
.update-row select{flex:1;border:1px solid var(--line);border-radius:8px;padding:9px 10px;background:var(--surface-2);}
.timeline{margin-top:14px;display:flex;flex-direction:column;gap:8px;}
.timeline-item{font-size:12px;color:var(--ink-soft);display:flex;gap:8px;}
.timeline-item .t-date{font-family:var(--font-mono);color:var(--ink-faint);flex-shrink:0;}
.counsel-block{margin-top:18px;background:var(--warm-soft);border-radius:12px;padding:16px 18px;}
.counsel-block .modal-section-title{color:var(--warm-soft-ink);}
.counsel-block textarea{width:100%;border:1px solid var(--line);border-radius:8px;padding:10px;min-height:70px;margin-top:10px;}

@media (max-width: 860px){
  .wrap{padding:0 18px;}
  .topbar{padding:14px 18px;}
  .hero h2{font-size:30px;}
  .reassure-row{grid-template-columns:1fr;}
  .stat-grid{grid-template-columns:1fr 1fr;}
  .hr-grid{grid-template-columns:1fr;}
  .modal-meta-grid{grid-template-columns:1fr;}
  table thead{display:none;}
  tbody tr{display:block;border-bottom:8px solid var(--bg);padding:10px 0;}
  tbody td{display:flex;justify-content:space-between;gap:10px;border-bottom:none;padding:6px 16px;}
  tbody td::before{content:attr(data-label);font-size:11px;color:var(--ink-faint);font-weight:700;}
}

/* ============================================================
   APP SHELL (sidebar + konten) — dipakai di dashboard.html & users.html
   ============================================================ */
.app-shell{display:block;min-height:100vh;}

.sidebar{
  width:236px;background:var(--surface);border-right:1px solid var(--line);
  display:flex;flex-direction:column;padding:22px 16px;gap:26px;
  position:fixed;top:0;left:0;bottom:0;z-index:30;overflow-y:auto;
}
.sidebar-brand{display:flex;align-items:center;gap:10px;padding:0 6px;}
.sidebar-brand .brand-mark{width:32px;height:32px;flex-shrink:0;}
.sidebar-brand h1{font-size:17px;}
.sidebar-brand span{display:block;font-size:11px;color:var(--ink-soft);margin-top:1px;}

.sidebar-nav{display:flex;flex-direction:column;gap:3px;flex:1;}
.nav-item{
  display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:10px;
  font-size:13.5px;font-weight:600;color:var(--ink-soft);text-decoration:none;transition:.14s;
  border:none;background:transparent;text-align:left;width:100%;cursor:pointer;
}
.nav-item .nav-ic{width:18px;height:18px;flex-shrink:0;opacity:.85;}
.nav-item:hover{background:var(--surface-2);color:var(--ink);}
.nav-item.active{background:var(--accent);color:#fff;}
.nav-item.active .nav-ic{opacity:1;}

.sidebar-logout{
  display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:10px;font-size:13.5px;font-weight:600;
  color:var(--urgent);background:transparent;border:none;cursor:pointer;flex-shrink:0;
}
.sidebar-logout:hover{background:var(--urgent-soft);}

.content{margin-left:236px;min-height:100vh;padding:26px 32px 60px;}
.content-topbar{
  display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap;margin-bottom:24px;
}
.content-topbar h2{font-size:24px;}
.content-topbar p{color:var(--ink-soft);font-size:13.5px;margin-top:6px;}

.role-tag{
  font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:2px 7px;border-radius:5px;
  margin-left:6px;vertical-align:middle;
}
.role-tag.superadmin{background:var(--accent-soft);color:var(--accent-soft-ink);}
.role-tag.admin{background:var(--bg-alt);color:var(--ink-soft);}

/* ---------- Pengguna: banner ---------- */
.gov-banner{
  background:linear-gradient(120deg, var(--accent), var(--accent-dark));
  color:#fff;border-radius:var(--radius);padding:28px 30px;margin-bottom:22px;
  display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;
}
.gov-banner .eyebrow{font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em;opacity:.85;margin-bottom:8px;}
.gov-banner h3{color:#fff;font-size:22px;margin-bottom:8px;}
.gov-banner p{color:rgba(255,255,255,.85);font-size:13px;max-width:480px;}
.gov-banner .count-pill{background:rgba(255,255,255,.16);color:#fff;padding:9px 18px;border-radius:var(--radius-pill);font-weight:700;font-size:13px;white-space:nowrap;}

/* ---------- Pengguna: form tambah ---------- */
.user-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:16px;align-items:start;margin-bottom:20px;}
.add-user-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px;}
.add-user-card h3{font-size:15px;margin-bottom:4px;}
.add-user-card p.sub{font-size:12.5px;color:var(--ink-soft);margin-bottom:16px;}

.dir-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px;}
.dir-card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;}
.dir-card-head h3{font-size:15px;}

.status-pill{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;padding:4px 10px;border-radius:var(--radius-pill);}
.status-pill.active{background:var(--accent-soft);color:var(--accent-soft-ink);}
.status-pill.inactive{background:var(--urgent-soft);color:var(--urgent-soft-ink);}

.row-actions{display:flex;gap:6px;flex-wrap:wrap;}
.icon-btn{
  width:30px;height:30px;border-radius:8px;border:1px solid var(--line);background:var(--surface-2);
  display:flex;align-items:center;justify-content:center;color:var(--ink-soft);
}
.icon-btn:hover{border-color:var(--accent);color:var(--accent-dark);}
.icon-btn.danger:hover{border-color:var(--urgent);color:var(--urgent);background:var(--urgent-soft);}

.you-tag{font-size:10.5px;color:var(--ink-faint);font-weight:600;margin-left:6px;}

@media (max-width: 980px){
  .sidebar{
    position:relative;width:100%;height:auto;top:auto;left:auto;bottom:auto;
    flex-direction:row;align-items:center;padding:14px 16px;border-right:none;
    border-bottom:1px solid var(--line);gap:14px;overflow-y:visible;
  }
  .sidebar-brand span{display:none;}
  .sidebar-nav{flex-direction:row;flex:1;overflow-x:auto;}
  .nav-item{white-space:nowrap;}
  .sidebar-logout{white-space:nowrap;}
  .content{margin-left:0;padding:20px 18px 50px;}
  .user-grid{grid-template-columns:1fr;}
  .gov-banner{flex-direction:column;align-items:flex-start;}
}
