/* ===================================================
   TASM MONITOR - Director Stylesheet
   iTekno.id © 2026
   =================================================== */
:root{
  --brand:#06b6d4;
  --brand-dark:#0891b2;
  --bg:#0f172a;
  --bg-2:#1e293b;
  --bg-3:#334155;
  --card:#1e293b;
  --text:#e2e8f0;
  --text-2:#cbd5e1;
  --text-3:#94a3b8;
  --border:#334155;
  --success:#10b981;
  --warning:#f59e0b;
  --danger:#ef4444;
  --purple:#a855f7;
  --radius:12px;
  --shadow:0 10px 30px rgba(0,0,0,.35);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Inter",sans-serif;
  background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;
  -webkit-font-smoothing:antialiased;
  background-image:
    radial-gradient(circle at 20% 0%, rgba(6,182,212,.15), transparent 50%),
    radial-gradient(circle at 80% 100%, rgba(168,85,247,.1), transparent 50%);
  background-attachment:fixed;
}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
input,select,textarea{font-family:inherit;font-size:14px;color:inherit}
a{color:inherit;text-decoration:none}

/* Login */
.login-wrap{
  min-height:100vh;display:flex;align-items:center;justify-content:center;padding:16px;
}
.login-card{
  background:rgba(30,41,59,.7);backdrop-filter:blur(14px);
  border:1px solid var(--border);border-radius:16px;
  width:100%;max-width:380px;padding:32px 28px;
  box-shadow:var(--shadow);
}
.login-card h1{font-size:22px;text-align:center;margin-bottom:4px;background:linear-gradient(90deg,#22d3ee,#a855f7);-webkit-background-clip:text;background-clip:text;color:transparent}
.login-card p{text-align:center;color:var(--text-3);margin-bottom:24px;font-size:13px}
.field{margin-bottom:16px}
.field label{display:block;font-size:12px;font-weight:600;color:var(--text-3);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}
.field input,.field select{
  width:100%;padding:12px 14px;background:#0f172a;
  border:1px solid var(--border);border-radius:10px;color:var(--text);
  transition:border-color .15s;font-size:14px;font-family:inherit;
}
.field input:focus,.field select:focus{outline:0;border-color:var(--brand)}
.field input[type="date"]{color-scheme:dark}
.inv{font-family:Menlo,Consolas,monospace;color:var(--brand);font-size:12px}

/* Layout */
.app{display:flex;min-height:100vh}
.sidebar{
  width:240px;background:rgba(15,23,42,.95);backdrop-filter:blur(10px);
  border-right:1px solid var(--border);padding:20px 0;
  position:fixed;top:0;bottom:0;left:0;z-index:50;transition:transform .2s ease;
}
.sidebar .logo{padding:0 20px 16px;border-bottom:1px solid var(--border);margin-bottom:12px}
.sidebar .logo h1{font-size:16px;background:linear-gradient(90deg,#22d3ee,#a855f7);-webkit-background-clip:text;background-clip:text;color:transparent}
.sidebar .logo p{font-size:11px;color:var(--text-3)}
.sidebar nav a{
  display:flex;align-items:center;gap:10px;padding:12px 20px;
  color:var(--text-2);font-size:13px;font-weight:500;
  border-left:3px solid transparent;
}
.sidebar nav a:hover{background:rgba(30,41,59,.6);color:#fff}
.sidebar nav a.active{background:rgba(30,41,59,.6);color:#fff;border-left-color:var(--brand)}
.sidebar .user-info{position:absolute;bottom:0;left:0;right:0;padding:14px 20px;border-top:1px solid var(--border)}
.sidebar .user-info strong{color:#fff;display:block;font-size:13px}
.sidebar .user-info small{color:var(--text-3);font-size:11px}
.sidebar .logout-btn{display:block;margin-top:8px;color:#fca5a5;font-weight:600;font-size:12px}

.main{flex:1;margin-left:240px;min-width:0}
.topbar{
  padding:16px 24px;display:flex;align-items:center;justify-content:space-between;gap:12px;
  position:sticky;top:0;z-index:40;
  background:rgba(15,23,42,.8);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--border);
}
.topbar h2{font-size:18px}
.topbar .time{font-size:13px;color:var(--text-3)}
.burger{display:none;font-size:22px;padding:6px 10px;border-radius:6px}
.realtime-dot{
  display:inline-block;width:8px;height:8px;border-radius:50%;
  background:var(--success);margin-right:6px;
  animation:pulse 1.4s infinite;
  box-shadow:0 0 0 0 rgba(16,185,129,.6);
}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(16,185,129,.6)}
  70%{box-shadow:0 0 0 8px rgba(16,185,129,0)}
  100%{box-shadow:0 0 0 0 rgba(16,185,129,0)}
}

.content{padding:24px}

/* Stat */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:24px}
.stat-card{
  background:linear-gradient(145deg,rgba(30,41,59,.8),rgba(15,23,42,.6));
  border:1px solid var(--border);border-radius:var(--radius);
  padding:18px 20px;position:relative;overflow:hidden;
}
.stat-card::before{
  content:'';position:absolute;right:-20px;top:-20px;width:100px;height:100px;
  border-radius:50%;opacity:.12;filter:blur(24px);
}
.stat-card.primary::before{background:#06b6d4}
.stat-card.success::before{background:#10b981}
.stat-card.warning::before{background:#f59e0b}
.stat-card.purple::before{background:#a855f7}
.stat-card .label{color:var(--text-3);font-size:11px;text-transform:uppercase;letter-spacing:.5px;font-weight:600}
.stat-card .value{font-size:24px;font-weight:700;margin-top:6px;color:#fff}
.stat-card .meta{font-size:11px;color:var(--text-3);margin-top:4px}
.stat-card .icon{position:absolute;top:16px;right:16px;font-size:22px;opacity:.6}

/* Cards */
.card{
  background:rgba(30,41,59,.7);backdrop-filter:blur(6px);
  border:1px solid var(--border);border-radius:var(--radius);
  overflow:hidden;margin-bottom:16px;
}
.card-head{
  padding:14px 18px;border-bottom:1px solid var(--border);
  font-weight:600;display:flex;align-items:center;justify-content:space-between;
}
.card-body{padding:16px 18px}

/* Trx live */
.live-trx{max-height:520px;overflow-y:auto}
.live-trx::-webkit-scrollbar{width:6px}
.live-trx::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}
.trx-row{
  padding:12px 18px;border-bottom:1px solid var(--border);
  display:grid;grid-template-columns:60px 1fr 1fr auto auto;
  gap:10px;align-items:center;font-size:13px;
  animation:fadeInUp .3s ease;
}
@keyframes fadeInUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.trx-row.new{background:rgba(16,185,129,.08)}
.trx-row .time{color:var(--text-3);font-size:12px}
.trx-row .inv{font-family:Menlo,Consolas,monospace;color:var(--brand);font-size:12px}
.trx-row .petugas strong{display:block;font-size:13px;color:#fff}
.trx-row .petugas small{color:var(--text-3);font-size:11px}
.trx-row .amount{text-align:right;font-weight:700;color:#fff}
.trx-row .items{color:var(--text-3);font-size:11px;grid-column:2/span 2;margin-top:2px}

.badge{padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600}
.badge-qr{background:rgba(59,130,246,.2);color:#60a5fa}
.badge-transfer{background:rgba(245,158,11,.2);color:#fbbf24}
.badge-tunai{background:rgba(16,185,129,.2);color:#34d399}
.badge-success{background:rgba(16,185,129,.2);color:#34d399}
.badge-warning{background:rgba(245,158,11,.2);color:#fbbf24}
.badge-danger{background:rgba(239,68,68,.2);color:#f87171}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:6px;justify-content:center;
  padding:10px 16px;border-radius:10px;font-weight:600;font-size:13px;
  transition:all .15s;cursor:pointer;border:none;
}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn-sm{padding:6px 10px;font-size:12px;border-radius:8px}
.btn-primary{background:linear-gradient(90deg,#06b6d4,#0891b2);color:#fff}
.btn-primary:hover{filter:brightness(1.1);box-shadow:0 6px 20px rgba(6,182,212,.4)}
.btn-ghost{background:rgba(255,255,255,.06);color:var(--text)}
.btn-ghost:hover{background:rgba(255,255,255,.12)}
.btn-success{background:linear-gradient(90deg,#10b981,#059669);color:#fff}
.btn-success:hover{filter:brightness(1.1);box-shadow:0 6px 20px rgba(16,185,129,.4)}
.btn-danger{background:linear-gradient(90deg,#ef4444,#dc2626);color:#fff}
.btn-danger:hover{filter:brightness(1.1);box-shadow:0 6px 20px rgba(239,68,68,.4)}
.btn-success{background:linear-gradient(90deg,#10b981,#059669);color:#fff}
.btn-success:hover{filter:brightness(1.1)}
.btn-block{width:100%}

/* Table */
.table-wrap{overflow-x:auto}
table.tbl{width:100%;border-collapse:collapse;font-size:13px}
table.tbl th,table.tbl td{padding:10px 14px;text-align:left;border-bottom:1px solid var(--border)}
table.tbl th{background:rgba(15,23,42,.5);color:var(--text-3);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.3px}
table.tbl tr:hover td{background:rgba(51,65,85,.3)}
.text-right{text-align:right}

/* Modal */
.modal-backdrop{
  position:fixed;inset:0;background:rgba(0,0,0,.7);
  display:none;align-items:center;justify-content:center;z-index:100;padding:16px;
}
.modal-backdrop.open{display:flex}
.modal{
  background:#1e293b;border:1px solid var(--border);
  border-radius:14px;width:100%;max-width:420px;padding:24px;
  box-shadow:var(--shadow);
}
.modal h2{font-size:18px;margin-bottom:14px}

/* Toast */
.toast-wrap{position:fixed;top:16px;right:16px;z-index:200;display:flex;flex-direction:column;gap:8px}
.toast{
  background:#1e293b;border:1px solid var(--border);color:#fff;
  padding:12px 16px;border-radius:10px;box-shadow:var(--shadow);
  font-size:13px;min-width:220px;max-width:340px;
  animation:slideIn .25s ease;
}
.toast.success{background:linear-gradient(90deg,#10b981,#059669);border-color:transparent}
.toast.error{background:linear-gradient(90deg,#ef4444,#dc2626);border-color:transparent}
.toast.info{background:linear-gradient(90deg,#06b6d4,#0891b2);border-color:transparent}
@keyframes slideIn{from{transform:translateX(110%);opacity:0}to{transform:translateX(0);opacity:1}}

/* Grid sections */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid-3{display:grid;grid-template-columns:2fr 1fr;gap:16px}

.petugas-list{display:flex;flex-direction:column;gap:10px}
.petugas-item{
  display:flex;gap:12px;align-items:center;padding:10px;
  background:rgba(15,23,42,.5);border-radius:10px;
}
.petugas-item .avt{
  width:40px;height:40px;border-radius:50%;
  background:linear-gradient(135deg,#06b6d4,#a855f7);
  display:flex;align-items:center;justify-content:center;
  font-weight:700;color:#fff;
}
.petugas-item .info{flex:1;min-width:0}
.petugas-item .info strong{display:block;font-size:13px}
.petugas-item .info small{color:var(--text-3);font-size:11px}
.petugas-item .amt{font-weight:700;color:var(--success);font-size:14px}

/* Utilities */
.muted{color:var(--text-3)}
.small{font-size:12px}
.hidden{display:none!important}
.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.mt-16{margin-top:16px}
.flex{display:flex}.flex-1{flex:1}.gap-8{gap:8px}.gap-12{gap:12px}
.items-center{align-items:center}.justify-between{justify-content:space-between}

/* Responsive */
@media (max-width:1024px){
  .grid-2,.grid-3{grid-template-columns:1fr}
  .trx-row{grid-template-columns:1fr 1fr;gap:8px}
  .trx-row .time{grid-column:1}
  .trx-row .amount{grid-column:2;text-align:right}
  .trx-row .petugas{grid-column:1/span 2}
  .trx-row .items{grid-column:1/span 2;margin-top:2px}
}
@media (max-width:768px){
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0)}
  .main{margin-left:0}
  .burger{display:block}
  .content{padding:16px}
  .stat-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:480px){
  .stat-grid{grid-template-columns:1fr}
}
