:root{
  --bg:#f5f1ea;
  --card:#ffffff;
  --primary:#1a3a5c;
  --primary-dark:#0f2a44;
  --accent:#8b6914;
  --accent-dark:#6b5010;
  --border:#d4cfc4;
  --text:#1a1a1a;
  --muted:#6b6b6b;
  --danger:#b03030;
  --success:#2d7a3e;
  --warning:#a86a00;
  --serif:'Cormorant Garamond', Georgia, serif;
  --sans:'Inter', system-ui, -apple-system, sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--sans);background:var(--bg);color:var(--text);font-size:14px;line-height:1.5}
.hidden{display:none !important}

/* ==================== LOGIN ==================== */
.login-wrap{
  min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;
  background:linear-gradient(135deg,#1a3a5c 0%,#0f2a44 100%);
}
.login-card{
  background:var(--card);border-radius:12px;padding:48px 40px;width:100%;max-width:440px;
  box-shadow:0 20px 60px rgba(0,0,0,.3);text-align:center;
}
.login-emblem{font-size:48px;margin-bottom:8px}
.login-title{font-family:var(--serif);font-size:32px;font-weight:600;color:var(--primary);margin-bottom:4px;letter-spacing:-.01em}
.login-sub{color:var(--muted);font-size:13px;margin-bottom:32px}
.login-error{color:var(--danger);font-size:13px;min-height:18px;margin:12px 0 8px;text-align:left}
.login-foot{
  margin-top:24px;padding-top:20px;border-top:1px solid var(--border);
  font-size:12px;color:var(--muted);line-height:1.6;text-align:left;
}

/* ==================== GOOGLE BUTTON ==================== */
.btn-google{
  display:flex;align-items:center;justify-content:center;gap:12px;
  width:100%;padding:14px 20px;font-size:15px;font-weight:600;
  background:#fff;color:#3c4043;
  border:1px solid #dadce0;border-radius:8px;cursor:pointer;font-family:var(--sans);
  transition:all .15s;box-shadow:0 1px 2px rgba(60,64,67,.1);
}
.btn-google:hover{background:#f8f9fa;box-shadow:0 1px 3px rgba(60,64,67,.2);border-color:#c0c4c9}
.btn-google:active{background:#f1f3f4}

/* ==================== HEADER ==================== */
.app-header{background:var(--primary);color:#fff;border-bottom:3px solid var(--accent);position:sticky;top:0;z-index:100}
.header-inner{max-width:1280px;margin:0 auto;padding:18px 32px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}
.header-title{font-family:var(--serif);font-size:24px;font-weight:600;letter-spacing:-.01em}
.header-sub{font-size:12px;opacity:.8;margin-top:2px}
.nav{display:flex;gap:6px;flex-wrap:wrap}
.nav-btn{
  position:relative;padding:8px 14px;border:1px solid rgba(255,255,255,.25);background:transparent;color:#fff;
  border-radius:4px;font-size:13px;font-weight:500;cursor:pointer;font-family:var(--sans);transition:all .15s;
}
.nav-btn:hover{background:rgba(255,255,255,.1)}
.nav-btn.active{background:var(--accent);border-color:var(--accent)}
.nav-logout{border-color:rgba(255,255,255,.15);font-size:12px}
.nav-badge{
  display:inline-block;margin-left:6px;padding:1px 7px;border-radius:10px;
  background:#e23636;color:#fff;font-size:11px;font-weight:700;
}

/* ==================== MAIN ==================== */
.main-wrap{max-width:1280px;margin:0 auto;padding:32px}

.view-head{margin-bottom:24px}
.view-head-row{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:24px;gap:16px;flex-wrap:wrap}
.view-head h2,.view-head-row h2{font-family:var(--serif);font-size:24px;font-weight:600;color:var(--primary);margin-bottom:4px;letter-spacing:-.01em}
.view-head p,.view-head-row p{color:var(--muted);font-size:13px}

/* ==================== CARDS ==================== */
.card{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:24px;margin-bottom:16px}
.card h3{font-family:var(--serif);font-size:18px;font-weight:600;color:var(--primary);margin-bottom:16px;display:flex;align-items:center;gap:8px}
.card-highlight{background:#faf8f4;border-left:4px solid var(--accent)}

.badge{
  display:inline-block;font-size:11px;font-weight:600;padding:2px 8px;border-radius:10px;
  background:var(--accent);color:#fff;letter-spacing:.5px;text-transform:uppercase;
  font-family:var(--sans);
}
.badge-admin{background:var(--primary)}
.badge-user{background:var(--muted)}
.badge-pending{background:var(--warning)}
.badge-rejected{background:var(--danger)}
.badge-active{background:var(--success)}

.info-block{background:#faf8f4;border-left:3px solid var(--accent);padding:10px 14px;font-size:13px;color:var(--muted);margin-bottom:16px;border-radius:4px}

/* ==================== FORM ==================== */
.field{margin-bottom:12px}
.field label{display:block;font-size:11px;font-weight:600;color:var(--muted);margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}
input,select,textarea{
  width:100%;padding:8px 12px;font-family:var(--sans);font-size:14px;
  border:1px solid var(--border);border-radius:4px;background:#fff;color:var(--text);
  transition:all .15s;
}
input:focus,select:focus,textarea:focus{
  outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(26,58,92,.1);
}
textarea{resize:vertical;font-family:var(--sans)}

.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
@media(max-width:700px){.grid-2,.grid-3{grid-template-columns:1fr}}

.calc-line{display:flex;align-items:flex-end;padding:8px 0;font-size:14px;color:var(--muted)}
.calc-line strong{color:var(--primary);margin-left:6px}

.total-line{display:flex;justify-content:space-between;align-items:center;border-top:2px solid var(--accent);margin-top:20px;padding-top:16px}
.total-label{font-family:var(--serif);font-size:18px;font-weight:600}
.total-val{font-family:var(--serif);font-size:26px;font-weight:700;color:var(--primary)}
.terbilang{font-size:13px;color:var(--muted);font-style:italic;text-align:right;margin-top:4px}

/* ==================== BUTTONS ==================== */
.btn{padding:10px 18px;border:none;border-radius:4px;font-weight:600;font-size:13px;cursor:pointer;font-family:var(--sans);display:inline-flex;align-items:center;gap:6px;transition:all .15s}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-dark)}
.btn-secondary{background:#fff;color:var(--primary);border:1px solid var(--border)}
.btn-secondary:hover{background:#faf8f4;border-color:var(--primary)}
.btn-accent{background:var(--accent);color:#fff}
.btn-accent:hover{background:var(--accent-dark)}
.btn-danger{background:transparent;color:var(--danger);border:1px solid #e5d0d0}
.btn-danger:hover{background:#fdf2f2}
.btn-success{background:var(--success);color:#fff}
.btn-success:hover{background:#225f30}
.btn-warning{background:var(--warning);color:#fff}
.btn-warning:hover{background:#854f00}
.btn-full{width:100%;justify-content:center;padding:12px}
.btn-group{display:flex;gap:8px;flex-wrap:wrap}
.btn-sm{padding:6px 10px;font-size:12px}

.action-bar{display:flex;justify-content:flex-end;gap:12px;margin-top:24px}

/* ==================== LIST CARDS ==================== */
.list-grid{display:grid;gap:12px}
.list-card{
  background:var(--card);border:1px solid var(--border);border-radius:8px;padding:18px 20px;
  display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;
}
.list-card-name{font-family:var(--serif);font-size:17px;font-weight:600;color:var(--primary);display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.list-card-meta{font-size:13px;color:var(--muted);margin-top:4px}
.list-card-actions{display:flex;gap:6px;flex-wrap:wrap}

.empty-state{text-align:center;padding:32px;color:var(--muted);background:#faf8f4;border:1px dashed var(--border);border-radius:8px;font-size:13px}

/* User cards: gambar avatar */
.user-avatar{
  width:40px;height:40px;border-radius:50%;background:var(--accent);
  display:inline-flex;align-items:center;justify-content:center;color:#fff;font-weight:600;
  margin-right:12px;flex-shrink:0;font-size:16px;
}
.user-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}
.user-row{display:flex;align-items:center;flex:1;min-width:0}
.user-info-block{min-width:0}

/* ==================== TABLE ==================== */
.table-wrap{overflow-x:auto}
.data-table{width:100%;border-collapse:collapse;font-size:13px}
.data-table th{background:#faf8f4;text-align:left;padding:10px 12px;border:1px solid var(--border);font-weight:600;color:var(--muted);text-transform:uppercase;font-size:11px;letter-spacing:.5px}
.data-table td{padding:6px 12px;border:1px solid var(--border)}
.data-table input{padding:4px 8px;font-size:13px;border:1px solid transparent;background:transparent}
.data-table input:hover{border-color:var(--border)}
.data-table input:focus{border-color:var(--primary);background:#fff}
.data-table td.cell-name{font-weight:600;color:var(--primary)}

/* ==================== FOOTER ==================== */
.app-footer{text-align:center;padding:24px;color:var(--muted);font-size:12px}

/* ==================== PRINT (DOC PAGES) ==================== */
.doc-page{
  background:#fff;padding:40px 50px;margin:0 auto 24px;max-width:820px;
  font-family:'Times New Roman',serif;font-size:11pt;color:#000;
  box-shadow:0 4px 20px rgba(0,0,0,.08);
}
.doc-page h2,.doc-page h3{text-align:center;text-decoration:underline;margin:14px 0;font-size:13pt;font-family:'Times New Roman',serif;color:#000}
.doc-page table{border-collapse:collapse;width:100%}
.doc-page table.bordered td,.doc-page table.bordered th{border:1px solid #000;padding:5px 8px;vertical-align:top}
.doc-page .bold{font-weight:700}
.doc-page .underline{text-decoration:underline}
.doc-page .center{text-align:center}
.doc-page .right{text-align:right}

.print-only{display:none}

@media print{
  body *{visibility:hidden}
  #print-area,#print-area *{visibility:visible}
  #print-area{position:absolute;left:0;top:0;width:100%;background:#fff;display:block !important}
  .no-print{display:none !important}
  .page-break{page-break-before:always}
  .doc-page{box-shadow:none;margin:0;padding:1.5cm;max-width:100%}
  @page{size:A4;margin:0}
}
