/* ============ KIAP Admin Panel Styles ============ */
:root{
  --green:#1f7a3d;--green-d:#14532d;--green-dd:#0f3d22;--gold:#d4a017;--gold-l:#e8bd45;
  --ink:#1c2b1f;--muted:#6b7b6e;--line:#e4e9dd;--bg:#f1f4ec;--white:#fff;
  --radius:12px;--shadow:0 4px 16px rgba(15,61,34,.08);
}
*{box-sizing:border-box;margin:0;padding:0;}
body{font-family:'Poppins','Segoe UI',sans-serif;background:var(--bg);color:var(--ink);line-height:1.6;}
a{text-decoration:none;color:inherit;}
img{max-width:100%;display:block;}

/* ---- Login ---- */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;
  background:linear-gradient(120deg,var(--green-d),var(--green-dd));}
.login-card{background:#fff;border-radius:18px;box-shadow:0 20px 50px rgba(0,0,0,.3);width:100%;max-width:400px;padding:40px 34px;}
.login-card .logo{text-align:center;margin-bottom:18px;}
.login-card .logo img{width:74px;height:74px;border-radius:50%;margin:0 auto 10px;border:3px solid var(--gold-l);}
.login-card h1{font-size:21px;text-align:center;color:var(--green-d);margin-bottom:4px;}
.login-card .sub{text-align:center;color:var(--muted);font-size:14px;margin-bottom:24px;}

/* ---- Layout ---- */
.admin{display:flex;min-height:100vh;}
.sidebar{width:248px;background:var(--green-dd);color:#cfe0d2;position:fixed;top:0;bottom:0;left:0;display:flex;flex-direction:column;transition:.3s;z-index:100;}
.sidebar .brand{display:flex;align-items:center;gap:11px;padding:20px 18px;border-bottom:1px solid rgba(255,255,255,.08);}
.sidebar .brand img{width:42px;height:42px;border-radius:50%;border:2px solid var(--gold-l);}
.sidebar .brand strong{color:#fff;font-size:15px;line-height:1.2;}
.sidebar .brand small{color:var(--gold-l);font-size:11px;letter-spacing:1px;}
.sidebar nav{padding:14px 12px;flex:1;overflow-y:auto;}
.sidebar nav a{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:9px;color:#bcd0c0;font-size:14.5px;font-weight:500;margin-bottom:4px;transition:.2s;}
.sidebar nav a i{width:20px;text-align:center;color:var(--gold-l);}
.sidebar nav a:hover{background:rgba(255,255,255,.06);color:#fff;}
.sidebar nav a.active{background:var(--green);color:#fff;}
.sidebar nav a.active i{color:#fff;}
.sidebar .logout-link{margin:12px;padding:11px;background:rgba(255,255,255,.06);border-radius:9px;text-align:center;color:#fff;font-weight:600;font-size:14px;}
.sidebar .logout-link:hover{background:#9b2c2c;}

.main{flex:1;margin-left:248px;display:flex;flex-direction:column;min-width:0;}
.topbar{background:#fff;height:64px;display:flex;align-items:center;justify-content:space-between;padding:0 24px;box-shadow:var(--shadow);position:sticky;top:0;z-index:50;}
.topbar h2{font-size:18px;color:var(--green-d);}
.topbar .right{display:flex;align-items:center;gap:14px;font-size:14px;}
.topbar .right .view-site{color:var(--green);font-weight:600;}
.menu-btn{display:none;background:none;border:none;font-size:22px;color:var(--green-d);cursor:pointer;}
.content{padding:26px 24px;flex:1;}

/* ---- Stat cards ---- */
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:26px;}
.s-card{background:#fff;border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);display:flex;align-items:center;gap:16px;}
.s-card .ic{width:52px;height:52px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;color:#fff;}
.s-card .num{font-size:26px;font-weight:800;color:var(--green-d);line-height:1;}
.s-card .lbl{color:var(--muted);font-size:13.5px;}

/* ---- Panel / table ---- */
.panel{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:24px;overflow:hidden;}
.panel-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--line);flex-wrap:wrap;gap:10px;}
.panel-head h3{font-size:16px;color:var(--green-d);}
.panel-body{padding:20px;}
.tbl{width:100%;border-collapse:collapse;}
.tbl th,.tbl td{text-align:left;padding:12px 14px;border-bottom:1px solid var(--line);font-size:14px;vertical-align:middle;}
.tbl th{background:#f7faf3;color:var(--green-d);font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.5px;}
.tbl tr:hover td{background:#fafdf7;}
.tbl img.thumb{width:60px;height:44px;object-fit:cover;border-radius:6px;}
.tbl .muted{color:var(--muted);font-size:13px;}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;gap:7px;padding:10px 18px;border-radius:8px;font-weight:600;font-size:14px;border:none;cursor:pointer;transition:.2s;font-family:inherit;}
.btn-green{background:var(--green);color:#fff;}.btn-green:hover{background:var(--green-d);}
.btn-gold{background:var(--gold);color:var(--green-dd);}.btn-gold:hover{background:var(--gold-l);}
.btn-sm{padding:7px 12px;font-size:13px;}
.btn-edit{background:#e8f0fb;color:#2c5282;}.btn-edit:hover{background:#d0e0f5;}
.btn-del{background:#fde8e8;color:#9b2c2c;}.btn-del:hover{background:#f5c2c2;}
.btn-light{background:#eef2e6;color:var(--green-d);}.btn-light:hover{background:#e0e8d4;}

.badge{display:inline-block;padding:3px 11px;border-radius:50px;font-size:12px;font-weight:600;}
.badge-on{background:#e3f5e8;color:#1b6b39;}
.badge-off{background:#f1f1f1;color:#888;}
.badge-new{background:var(--gold);color:var(--green-dd);}

/* ---- Forms ---- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.fg{margin-bottom:16px;}
.fg.full{grid-column:1/-1;}
.fg label{display:block;font-weight:600;font-size:13.5px;margin-bottom:6px;color:var(--green-d);}
.fg input,.fg textarea,.fg select{width:100%;padding:11px 13px;border:1.5px solid var(--line);border-radius:8px;font-family:inherit;font-size:14.5px;background:#fafdf7;transition:.2s;}
.fg input:focus,.fg textarea:focus,.fg select:focus{outline:none;border-color:var(--green);background:#fff;box-shadow:0 0 0 3px rgba(31,122,61,.1);}
.fg .hint{font-size:12.5px;color:var(--muted);margin-top:5px;}
.fg .current-img{margin-top:8px;}
.fg .current-img img{width:120px;border-radius:8px;border:1px solid var(--line);}
.form-actions{display:flex;gap:10px;margin-top:8px;}

.alert{padding:13px 16px;border-radius:9px;margin-bottom:18px;font-weight:500;font-size:14px;}
.alert-success{background:#e3f5e8;color:#1b6b39;}
.alert-error{background:#fde8e8;color:#9b2c2c;}

.empty-row td{text-align:center;color:var(--muted);padding:34px;}
.gallery-admin{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px;}
.gallery-admin .ga-item{position:relative;border-radius:10px;overflow:hidden;box-shadow:var(--shadow);}
.gallery-admin .ga-item img{width:100%;height:130px;object-fit:cover;}
.gallery-admin .ga-item .ga-actions{position:absolute;top:6px;right:6px;display:flex;gap:5px;}
.gallery-admin .ga-item .cap{padding:8px 10px;font-size:12.5px;}
.gallery-admin .ga-item .cap strong{display:block;color:var(--green-d);font-size:13px;}
.gallery-admin .ga-item .cap span{color:var(--muted);}

@media(max-width:900px){
  .stat-row{grid-template-columns:1fr 1fr;}
  .form-grid{grid-template-columns:1fr;}
}
@media(max-width:768px){
  .sidebar{left:-260px;}
  .sidebar.open{left:0;}
  .main{margin-left:0;}
  .menu-btn{display:block;}
  .tbl{display:block;overflow-x:auto;white-space:nowrap;}
}

/* ---- additions: gallery meta, message rows, key/value table ---- */
.gallery-admin .ga-item .ga-meta{padding:8px 10px;font-size:12.5px;display:flex;align-items:center;justify-content:space-between;gap:6px;flex-wrap:wrap;}
.gallery-admin .ga-item .ga-cat{color:var(--green-d);font-weight:600;}
.gallery-admin .ga-item .ga-del{position:absolute;top:6px;right:6px;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:8px;background:rgba(190,40,40,.92);color:#fff;text-decoration:none;font-size:13px;opacity:0;transition:.18s;}
.gallery-admin .ga-item:hover .ga-del{opacity:1;}
tr.row-unread{background:#fffdf3;}
tr.row-unread td strong{color:var(--green-dd);}
table.kv{width:100%;border-collapse:collapse;}
table.kv th{text-align:left;width:150px;vertical-align:top;padding:10px 12px;color:var(--muted);font-weight:600;border-bottom:1px solid #eee;}
table.kv td{padding:10px 12px;border-bottom:1px solid #eee;}
.block-label{display:block;margin-bottom:6px;}
