
:root{
  --bg:#f4f7fb;
  --panel:#ffffff;
  --line:#e6edf5;
  --text:#1d2a3b;
  --muted:#6f7d90;
  --blue:#61a9ff;
  --blue-deep:#2f80ed;
  --green:#3ecf8e;
  --green-soft:#dff8ec;
  --shadow:0 10px 30px rgba(25,42,70,.08);
  --radius:18px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:Segoe UI,Inter,Arial,sans-serif;background:var(--bg);color:var(--text)}
a{text-decoration:none;color:inherit}
body.fade-ready{animation:fadeIn .5s ease}
@keyframes fadeIn{from{opacity:.0;transform:translateY(8px)}to{opacity:1;transform:none}}
.layout{display:flex;min-height:100vh}
.sidebar{
  width:260px;background:linear-gradient(180deg,#fff,#f7fbff);
  border-right:1px solid var(--line);padding:18px;position:fixed;left:0;top:0;bottom:0;overflow:auto
}
.sidebar h1{font-size:18px;margin:6px 0 18px 0;font-weight:700;letter-spacing:.2px}
.sidebar .muted{font-size:12px;color:var(--muted);margin-bottom:20px}
.nav a{
  display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:14px;color:#37506e;
  margin-bottom:8px;border:1px solid transparent;transition:.2s ease;font-size:14px;font-weight:600
}
.nav a:hover,.nav a.active{background:#eef6ff;border-color:#dcecff;color:#1f5fbf;transform:translateX(2px)}
.icon{width:10px;height:10px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--green))}
.main{margin-left:260px;flex:1;padding:24px}
.topbar{
  display:flex;justify-content:space-between;align-items:center;background:var(--panel);
  border:1px solid var(--line);border-radius:20px;padding:16px 20px;box-shadow:var(--shadow);margin-bottom:20px
}
.topbar h2{margin:0;font-size:22px}
.userbox{display:flex;align-items:center;gap:10px}
.badge{padding:8px 12px;border-radius:999px;background:#eef6ff;color:#2765c2;font-size:12px;font-weight:700}
.btn,.btn-secondary,.btn-danger,.btn-success{
  border:none;border-radius:12px;padding:11px 15px;cursor:pointer;font-weight:700;transition:.2s ease;font-size:14px
}
.btn{background:linear-gradient(135deg,var(--blue-deep),var(--blue));color:#fff}
.btn:hover,.btn-secondary:hover,.btn-danger:hover,.btn-success:hover{transform:translateY(-1px);box-shadow:0 10px 18px rgba(20,40,80,.08)}
.btn-secondary{background:#eef4fb;color:#2a4b6f}
.btn-danger{background:#ffe8e8;color:#b23a3a}
.btn-success{background:#e5fbef;color:#1a8a55}
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:18px}
.card{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px
}
.stat-card{grid-column:span 3}
.stat-title{font-size:13px;color:var(--muted);margin-bottom:8px}
.stat-value{font-size:30px;font-weight:800}
.stat-sub{font-size:12px;color:var(--muted);margin-top:6px}
.chart-card{grid-column:span 8;min-height:330px}
.feed-card{grid-column:span 4}
.table-card{grid-column:span 12}
table{width:100%;border-collapse:collapse}
th,td{padding:12px 10px;border-bottom:1px solid var(--line);font-size:14px;vertical-align:top}
th{text-align:left;color:#5f6f82;font-size:12px;text-transform:uppercase;letter-spacing:.3px}
tbody tr{transition:.2s ease}
tbody tr:hover{background:#f8fbff}
.toolbar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px}
input,select,textarea{
  width:100%;padding:12px 14px;border:1px solid #d9e3ef;border-radius:12px;background:#fff;
  font-size:14px;outline:none;transition:.2s ease
}
input:focus,select:focus,textarea:focus{border-color:#8dbdff;box-shadow:0 0 0 4px rgba(97,169,255,.13)}
label{display:block;font-size:13px;font-weight:700;margin:0 0 8px 0}
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.form-group.full{grid-column:1/-1}
textarea{min-height:110px;resize:vertical}
.page-actions{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:16px}
.status{padding:7px 10px;border-radius:999px;font-size:12px;font-weight:700;display:inline-block}
.status.selesai{background:#e7faef;color:#14814d}
.status.pending{background:#fff3da;color:#af7d00}
.status.ditinjau{background:#eaf1ff;color:#2a66c3}
.mini-list{display:flex;flex-direction:column;gap:12px}
.feed-item{padding:14px;border:1px solid var(--line);border-radius:14px;background:#fbfdff}
.feed-item h4{margin:0 0 6px 0;font-size:14px}
.feed-item p{margin:0;color:var(--muted);font-size:13px;line-height:1.5}
.filters{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.preview-wrap{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.preview-item{width:110px;height:88px;border-radius:12px;overflow:hidden;border:1px solid var(--line);background:#f8fbff;position:relative}
.preview-item img{width:100%;height:100%;object-fit:cover}
.modal{
  position:fixed;inset:0;background:rgba(15,23,42,.35);display:none;align-items:center;justify-content:center;z-index:999
}
.modal.show{display:flex;animation:fadeIn .2s ease}
.modal-content{
  width:min(920px,92vw);max-height:88vh;overflow:auto;background:#fff;border-radius:22px;border:1px solid var(--line);
  box-shadow:0 30px 60px rgba(15,23,42,.25);padding:20px
}
.empty{padding:30px;border:1px dashed #d8e4f2;border-radius:16px;text-align:center;color:var(--muted)}
.auth-wrap{min-height:100vh;display:flex;justify-content:center;align-items:center;padding:30px;background:linear-gradient(180deg,#f4f8fe,#eef5f3)}
.auth-card{width:min(470px,96vw);background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);border-radius:28px;padding:28px}
.auth-card h1{margin:0 0 8px 0}
.auth-card p{margin:0 0 24px 0;color:var(--muted);line-height:1.6}
.login-actions{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.notice{padding:12px 14px;border-radius:14px;background:#f6fbff;border:1px solid #ddefff;color:#3566a7;font-size:13px;margin-top:16px}
.thumb-stack{display:flex;gap:6px;flex-wrap:wrap}
.thumb-stack img{width:52px;height:40px;object-fit:cover;border-radius:8px;border:1px solid var(--line)}
.report-paper{background:#fff;padding:28px;border-radius:18px;border:1px solid var(--line)}
.report-head{text-align:center;margin-bottom:18px}
.report-head h1{margin:0;font-size:24px}
.report-head p{margin:6px 0;color:var(--muted)}
.signature-box{margin-top:26px;display:flex;justify-content:flex-end}
.signature-inner{text-align:center;width:220px}
.signature-inner img{max-width:160px;max-height:80px;display:block;margin:0 auto 6px auto}
.chart-bars{display:flex;align-items:flex-end;height:220px;gap:12px;padding:18px 6px 0 6px}
.bar{flex:1;background:linear-gradient(180deg,#9fd0ff,#6be0af);border-radius:14px 14px 6px 6px;position:relative;min-height:10px}
.bar span{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);font-size:12px;color:#53657a;font-weight:700}
.bar label{position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%);font-size:12px;color:#6f7d90;font-weight:600;white-space:nowrap}
.flex{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.right{text-align:right}
.hidden{display:none!important}
.small{font-size:12px;color:var(--muted)}
.footer-note{margin-top:18px;color:var(--muted);font-size:12px}
@media (max-width:1200px){
  .stat-card{grid-column:span 6}
  .chart-card,.feed-card{grid-column:span 12}
  .filters{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:900px){
  .sidebar{position:relative;width:100%;border-right:none;border-bottom:1px solid var(--line)}
  .main{margin-left:0}
  .layout{display:block}
  .form-grid{grid-template-columns:1fr}
  .filters{grid-template-columns:1fr}
  .stat-card{grid-column:span 12}
}
.print-only{display:none}
@media print{
  body{background:#fff}
  .sidebar,.topbar,.page-actions,.no-print,.toolbar,button,input,select,textarea,.footer-note{display:none!important}
  .main{margin:0;padding:0}
  .card,.report-paper{box-shadow:none;border:none}
  .print-only{display:block}
}
