/* css/style.css */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --navy:#1a2744;--navy2:#111c33;--gold:#e8b84b;
  --blue:#1a5276;--blue2:#2e86c1;--green:#1e7e4e;
  --red:#c0392b;--yellow:#d4a017;
  --bg:#f4f6f9;--white:#fff;--border:#dee2e6;
  --text:#2c3e50;--muted:#6c757d;
  --shadow:0 2px 12px rgba(0,0,0,.08);
  --r:10px;--r2:6px;
}
html{scroll-behavior:smooth}
body{font-family:'Segoe UI',Tahoma,Geneva,Verdana,sans-serif;background:var(--bg);color:var(--text);font-size:15px;line-height:1.6}

/* NAVBAR */
.navbar{background:var(--navy);padding:0 2rem;height:60px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:1000;box-shadow:0 2px 10px rgba(0,0,0,.2)}
.brand{color:var(--gold);font-size:17px;font-weight:700;text-decoration:none;display:flex;align-items:center;gap:8px}
.brand span{color:#fff;font-weight:400}
.nav-menu{display:flex;list-style:none;gap:2px;align-items:center}
.nav-menu a,.nav-menu button{color:rgba(255,255,255,.75);text-decoration:none;padding:8px 14px;border-radius:var(--r2);font-size:14px;font-weight:500;cursor:pointer;border:none;background:transparent;font-family:inherit;transition:all .2s}
.nav-menu a:hover,.nav-menu button:hover{background:rgba(255,255,255,.1);color:#fff}
.nav-menu a.active{background:rgba(232,184,75,.2);color:var(--gold)}
.badge-admin{background:var(--gold);color:var(--navy);font-size:11px;padding:2px 8px;border-radius:20px;font-weight:700;margin-left:4px}
.btn-logout{color:#ff7675!important}
.btn-logout:hover{background:rgba(255,118,117,.15)!important}

/* LAYOUT */
.container{max-width:1080px;margin:0 auto;padding:0 1.5rem}
.page{display:none;padding:2rem 0;animation:fadeIn .25s ease}
.page.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* HERO */
.hero{background:linear-gradient(135deg,var(--navy) 0%,#2c3e7a 100%);color:#fff;padding:3.5rem 2rem 3rem;text-align:center;border-radius:var(--r);margin-bottom:1.5rem}
.hero h1{font-size:1.9rem;font-weight:700;margin-bottom:.75rem}
.hero h1 span{color:var(--gold)}
.hero p{font-size:15px;color:rgba(255,255,255,.8);max-width:500px;margin:0 auto 1.75rem}
.hero-btn{display:inline-block;background:var(--gold);color:var(--navy);padding:11px 28px;border-radius:50px;font-weight:700;text-decoration:none;font-size:15px;border:none;cursor:pointer;font-family:inherit;transition:transform .2s,box-shadow .2s}
.hero-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(232,184,75,.4)}

/* STAT CARDS */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:1.5rem}
.stat-card{background:var(--white);border-radius:var(--r);padding:1.25rem;text-align:center;box-shadow:var(--shadow);border-top:3px solid var(--gold)}
.stat-card .ico{font-size:26px;margin-bottom:6px}
.stat-card .num{font-size:26px;font-weight:700;color:var(--navy)}
.stat-card .lbl{font-size:12px;color:var(--muted);margin-top:3px}

/* CARD */
.card{background:var(--white);border-radius:var(--r);padding:1.5rem;box-shadow:var(--shadow);margin-bottom:1.5rem}
.card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}
.card-title{font-size:17px;font-weight:600;color:var(--navy)}

/* SEARCH */
.search-wrap{display:flex;gap:10px;margin-bottom:1rem}
.search-wrap input{flex:1;padding:10px 14px;border:1px solid var(--border);border-radius:var(--r2);font-size:14px;font-family:inherit;outline:none;transition:border-color .2s}
.search-wrap input:focus{border-color:var(--blue2);box-shadow:0 0 0 3px rgba(46,134,193,.12)}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:5px;padding:9px 18px;border:none;border-radius:var(--r2);font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .2s;text-decoration:none}
.btn:hover{filter:brightness(.9);transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn-primary{background:var(--blue);color:#fff}
.btn-success{background:var(--green);color:#fff}
.btn-warning{background:var(--yellow);color:#fff}
.btn-danger{background:var(--red);color:#fff}
.btn-gray{background:#eee;color:var(--text)}
.btn-sm{padding:6px 12px;font-size:12px}

/* TABLE */
.tbl-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:14px}
thead tr{background:var(--navy);color:#fff}
thead th{padding:11px 14px;text-align:left;font-weight:600}
tbody td{padding:11px 14px;border-bottom:1px solid var(--border);vertical-align:middle}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover td{background:#f8f9ff}
.badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600}
.badge-blue{background:#d6eaf8;color:#1a5276}
.badge-green{background:#d5f5e3;color:#1e7e4e}
.badge-yellow{background:#fef9e7;color:#9a7d0a}

/* PAGINATION */
.pagination{display:flex;justify-content:center;gap:5px;margin-top:1rem;flex-wrap:wrap}
.page-btn{min-width:34px;height:34px;padding:0 8px;border:1px solid var(--border);border-radius:var(--r2);background:var(--white);cursor:pointer;font-size:13px;font-family:inherit;transition:all .2s}
.page-btn:hover{background:var(--bg)}
.page-btn.active{background:var(--navy);color:#fff;border-color:var(--navy)}
.page-btn:disabled{opacity:.4;cursor:not-allowed}

/* MODAL */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:2000;align-items:center;justify-content:center;padding:1rem}
.modal-overlay.open{display:flex}
.modal{background:var(--white);border-radius:var(--r);padding:2rem;width:100%;max-width:420px;box-shadow:0 20px 60px rgba(0,0,0,.2);animation:mIn .25s ease}
@keyframes mIn{from{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}
.modal h2{font-size:17px;font-weight:700;color:var(--navy);margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:2px solid var(--gold)}
.modal-foot{display:flex;gap:10px;justify-content:flex-end;margin-top:1.25rem}

/* FORM */
.form-group{margin-bottom:1rem}
.form-group label{display:block;font-size:13px;font-weight:600;margin-bottom:5px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 13px;border:1px solid var(--border);border-radius:var(--r2);font-size:14px;font-family:inherit;outline:none;transition:border-color .2s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--blue2);box-shadow:0 0 0 3px rgba(46,134,193,.12)}
.form-group textarea{resize:vertical;min-height:95px}

/* ALERT */
.alert{padding:10px 14px;border-radius:var(--r2);font-size:13px;margin-bottom:1rem;display:none}
.alert-danger{background:#fadbd8;color:#922b21;border-left:3px solid var(--red)}
.alert-success{background:#d5f5e3;color:#145a32;border-left:3px solid var(--green)}

/* TOAST */
.toast-box{position:fixed;bottom:1.5rem;right:1.5rem;z-index:9999;display:flex;flex-direction:column;gap:8px}
.toast{background:var(--navy);color:#fff;padding:11px 18px;border-radius:var(--r2);font-size:13px;font-weight:500;box-shadow:0 4px 16px rgba(0,0,0,.2);border-left:4px solid var(--gold);animation:tIn .3s ease;min-width:220px}
.toast.ok{border-left-color:#2ecc71}
.toast.err{border-left-color:var(--red)}
@keyframes tIn{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}

/* KONTAK */
.kontak-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}
.kontak-item{background:var(--bg);border-radius:var(--r);padding:1.1rem;display:flex;gap:10px;align-items:flex-start}
.kontak-item .ki-ico{font-size:20px;flex-shrink:0;margin-top:2px}
.kontak-item .ki-lbl{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:2px}
.kontak-item .ki-val{font-size:14px;font-weight:600}

/* LOGIN */
.login-wrap{max-width:380px;margin:2rem auto}
.login-card{background:var(--white);border-radius:var(--r);padding:2.5rem 2rem;box-shadow:var(--shadow);border-top:4px solid var(--gold)}
.login-card h2{text-align:center;font-size:21px;font-weight:700;color:var(--navy);margin-bottom:.4rem}
.login-card .sub{text-align:center;font-size:13px;color:var(--muted);margin-bottom:1.5rem}

/* RESPONSIVE */
@media(max-width:768px){
  .navbar{padding:0 1rem}
  .brand span{display:none}
  .nav-menu a,.nav-menu button{padding:7px 9px;font-size:13px}
  .hero h1{font-size:1.4rem}
  .hero{padding:2.5rem 1rem 2rem}
  .container{padding:0 1rem}
}

/* ===== PESAN ===== */
.tab-bar{display:flex;gap:6px;margin-bottom:1rem;flex-wrap:wrap}
.tab-btn{padding:8px 16px;border:1px solid var(--border);border-radius:var(--r2);background:var(--white);cursor:pointer;font-size:13px;font-weight:600;font-family:inherit;transition:all .2s}
.tab-btn:hover{background:var(--bg)}
.tab-btn.active{background:var(--navy);color:#fff;border-color:var(--navy)}

.pesan-item{border:1px solid var(--border);border-radius:var(--r);padding:1rem 1.25rem;margin-bottom:.75rem;background:var(--white);transition:box-shadow .2s}
.pesan-item.unread{border-left:4px solid var(--gold);background:#fffdf5}
.pesan-item:hover{box-shadow:var(--shadow)}
.pesan-head{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.5rem;flex-wrap:wrap}
.pesan-email{font-size:13px;color:var(--muted);margin-left:6px}
.pesan-tgl{font-size:12px;color:var(--muted);white-space:nowrap}
.pesan-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.pesan-body{font-size:14px;color:var(--text);line-height:1.6;background:var(--bg);padding:.75rem 1rem;border-radius:var(--r2);margin-top:.5rem;white-space:pre-wrap}
.badge-baru{background:var(--gold);color:var(--navy);font-size:11px;padding:2px 8px;border-radius:20px;font-weight:700;margin-left:6px}

/* ===== NAV BADGE ===== */
.nav-badge{background:var(--red);color:#fff;font-size:10px;padding:1px 6px;border-radius:20px;font-weight:700;margin-left:4px;display:none}
