:root{
  --bg:#0b1020; --text:rgba(255,255,255,.92); --muted:rgba(255,255,255,.62);
  --panel:rgba(255,255,255,.06); --border:rgba(255,255,255,.10);
  --primary:#7c5cff; --danger:#ff4d6d; --ok:#4ade80;
  --radius:18px; --shadow:0 10px 24px rgba(0,0,0,.30); --max:1100px;
}
*{box-sizing:border-box}
body{
  margin:0; min-height:100vh;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial;
  color:var(--text);
  background:
    radial-gradient(900px 500px at 10% 10%, rgba(124,92,255,.25), transparent 60%),
    radial-gradient(900px 500px at 90% 0%, rgba(94,234,212,.18), transparent 60%),
    var(--bg);
}
.container{max-width:var(--max); margin:0 auto; padding:18px}
.topbar{
  position:sticky; top:0; z-index:20;
  backdrop-filter: blur(14px);
  background:linear-gradient(to bottom, rgba(11,16,32,.75), rgba(11,16,32,.35));
  border-bottom:1px solid rgba(255,255,255,.08);
}
.inner{display:flex; align-items:center; justify-content:space-between; gap:12px}
.brand{display:flex; align-items:center; gap:10px; font-weight:800}
.logo{
  width:38px; height:38px; border-radius:14px;
  background:linear-gradient(135deg, rgba(124,92,255,.9), rgba(94,234,212,.7));
  display:grid; place-items:center; color:#0b1020; font-weight:900;
  box-shadow:var(--shadow);
}
.pill{
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 10px; border-radius:999px; font-size:13px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.06); color:var(--muted);
}
.layout{display:grid; gap:16px; grid-template-columns:1fr}
@media(min-width:980px){.layout{grid-template-columns:280px 1fr}}
.sidebar{
  position:sticky; top:84px; align-self:start;
  border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.04));
  border-radius:var(--radius); box-shadow:var(--shadow); overflow:hidden;
}
.nav{display:grid; padding:10px}
.nav a, .nav button{
  width:100%; border:0; background:transparent; color:var(--text);
  padding:10px 12px; border-radius:14px; cursor:pointer;
  display:flex; align-items:center; justify-content:space-between;
}
.nav a:hover, .nav button:hover{background:rgba(255,255,255,.07)}
.main{min-width:0}
.h1{display:flex; align-items:flex-end; justify-content:space-between; gap:12px; margin:6px 0 14px}
.h1 h1{margin:0; font-size:28px}
.h1 p{margin:0; color:var(--muted)}
.grid{display:grid; gap:14px; grid-template-columns:1fr}
@media(min-width:980px){.grid{grid-template-columns:1fr 1fr}}
.card{
  border:1px solid rgba(255,255,255,.10);
  background:linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.04));
  border-radius:var(--radius); padding:16px; box-shadow:var(--shadow);
}
.card h2{margin:0 0 10px; font-size:16px}
.card h3{margin:16px 0 8px; font-size:14px}
.stack{display:grid; gap:10px}
label{display:grid; gap:6px; font-size:13px; color:rgba(255,255,255,.82)}
input{
  width:100%; padding:12px; border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.18); color:var(--text); outline:none;
}
input::placeholder{color:rgba(255,255,255,.35)}
.actions{display:flex; gap:10px; flex-wrap:wrap; align-items:center}
.btn{
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.06); color:var(--text);
  padding:10px 12px; border-radius:14px; cursor:pointer; font-weight:700;
}
.btn:hover{background:rgba(255,255,255,.10)}
.btn.primary{background:linear-gradient(135deg, rgba(124,92,255,.95), rgba(94,234,212,.65)); color:#0b1020}
.btn.danger{background:linear-gradient(135deg, rgba(255,77,109,.92), rgba(124,92,255,.45)); color:#0b1020}
.btn.ghost{background:transparent}
.badge{
  padding:6px 10px; border-radius:999px; font-size:12px; font-weight:800;
  border:1px solid rgba(255,255,255,.12); background:rgba(255,255,255,.06);
}
.badge.pending{background:rgba(251,191,36,.10)}
.badge.approved{background:rgba(74,222,128,.10)}
.badge.rejected{background:rgba(255,77,109,.10)}
.alert{
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.06);
  padding:10px 12px; border-radius:14px; color:var(--muted);
}
.alert.ok{border-color:rgba(74,222,128,.30)}
.alert.err{border-color:rgba(255,77,109,.30)}
.table{display:grid; gap:8px}
.thead,.trow{display:grid; grid-template-columns:1.1fr 1.1fr .55fr 1.2fr; gap:10px; align-items:center}
.thead{color:rgba(255,255,255,.72); font-size:12px; text-transform:uppercase; letter-spacing:.7px; padding:6px 10px}
.trow{
  padding:10px 10px; border-radius:14px;
  border:1px solid rgba(255,255,255,.08); background:rgba(255,255,255,.04);
}
.small{font-size:13px}
.muted{color:var(--muted)}
.right{justify-self:end}
select{
  width:100%;
  padding:12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.18);
  color:var(--text);
  outline:none;
}
.bar{
  position:relative;
  height:14px;
  border-radius:999px;
  background: rgba(255,255,255,.08);
  overflow:hidden;
}

.barFill{
  height:100%;
  border-radius:999px;
  background: rgba(255,255,255,.28);
}

.barTarget{
  position:absolute;
  top:0;
  bottom:0;
  width:2px;
  background: rgba(255,255,255,.55);
  transform: translateX(-1px);
}
.brand{
  display:flex;
  align-items:center;
  gap:12px;
  text-decoration:none;
}

.brandLogo{
  height:36px;
  width:auto;
  border-radius:10px;
  background: rgba(255,255,255,.06);
  padding:6px 8px;
}

.brandText{
  font-weight:700;
  letter-spacing:.2px;
}
.topbar{
  backdrop-filter: blur(8px);
  background: rgba(0,0,0,.35);
  border-bottom: 1px solid rgba(255,255,255,.06);
  padding: 14px 0;
}

.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
}

.brand{
  display:flex;
  align-items:center;
  gap:12px;
  text-decoration:none;
  color:var(--text);
}

.brandLogo{
  height:38px;
  width:auto;
  border-radius:12px;
  padding:6px 10px;
  background: rgba(255,255,255,.06);
}

.brandText{
  font-weight:700;
  font-size:18px;
  letter-spacing:.3px;
}

.navRight{
  display:flex;
  align-items:center;
  gap:14px;
}

.userName{
  font-weight:600;
  opacity:.85;
}
/* ================= TOPBAR ================= */

.ttTopbar{
    width:100%;
    padding:16px 20px;
    border-bottom:1px solid rgba(255,255,255,.06);
    background: linear-gradient(90deg, #0f172a, #0b1220);
}

.ttContainer{
    max-width:1100px;
    margin:0 auto;
    display:flex;
    align-items:center;
    justify-content:space-between;
}

.ttBrand{
    display:flex;
    align-items:center;
    gap:14px;
    text-decoration:none;
}

.ttLogo{
    height:36px;
    width:auto;
    border-radius:12px;
    padding:6px 10px;
    background:rgba(255,255,255,.06);
    transition:0.2s ease;
}

.ttLogo:hover{
    transform:scale(1.04);
}

.ttTitle{
    font-size:18px;
    font-weight:800;
    color:rgba(255,255,255,.95);
    letter-spacing:.3px;
}

.ttNav{
    display:flex;
    align-items:center;
    gap:18px;
}

.ttLink{
    text-decoration:none;
    font-weight:600;
    color:rgba(255,255,255,.8);
}

.ttLink:hover{
    color:white;
}

.ttUser{
    font-weight:600;
    color:rgba(255,255,255,.85);
}

.ttLogout{
    background:rgba(255,255,255,.08);
    border:1px solid rgba(255,255,255,.1);
    padding:8px 14px;
    border-radius:10px;
    color:white;
    cursor:pointer;
    transition:0.2s ease;
}

.ttLogout:hover{
    background:rgba(255,255,255,.15);
}

/* Content spacing */
.ttMain{
    max-width:1100px;
    margin:30px auto;
    padding:0 20px;
}
