:root{
  --paper:#f4f1e4;--ink:#16243a;--ink2:#0f1a2b;--muted:#7a7a6c;--line:#e2ddc9;
  --red:#c0432a;--gold:#d8a23a;--teal:#2f7d57;--card:#fff;
  --serif:"Fraunces",Georgia,serif;--sans:"Hanken Grotesk",system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--sans);background:var(--paper);color:var(--ink);-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
code{background:#e9e4cf;padding:1px 6px;border-radius:5px;font-size:.9em}
.muted{color:var(--muted)}

/* ---------- login ---------- */
.login-page{min-height:100vh;display:grid;place-items:center;
  background:radial-gradient(circle at 30% 20%,#1d2f49,#0f1a2b);padding:24px}
.login-card{background:var(--paper);border-radius:22px;padding:40px;width:100%;max-width:400px;
  box-shadow:0 30px 70px -30px rgba(0,0,0,.6)}
.login-brand{color:var(--red);font-weight:800;letter-spacing:-1px}
.login-brand span{color:var(--ink);letter-spacing:.18em;font-size:13px;margin-left:6px}
.login-card h1{font-family:var(--serif);font-size:26px;margin-top:14px;line-height:1}
.login-card .sub{color:var(--muted);margin-bottom:22px;font-size:14px}
.login-card label{display:block;font-size:13px;font-weight:600;margin-bottom:14px}
.login-card input{width:100%;margin-top:6px;padding:11px 14px;border:1.5px solid var(--line);
  border-radius:11px;font:inherit;background:#fff;outline:none}
.login-card input:focus{border-color:var(--ink)}
.hint{font-size:12.5px;color:var(--muted);margin-top:14px}
.back{display:inline-block;margin-top:16px;font-size:13px;color:var(--red);font-weight:600}

/* ---------- alerts ---------- */
.alert{padding:12px 16px;border-radius:11px;font-size:14px;font-weight:600;margin-bottom:18px}
.alert.err{background:#fbe3dd;color:#8c2c19}
.alert.ok{background:#dff0e4;color:#1f6b41}

/* ---------- layout ---------- */
.admin{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.sidebar{background:var(--ink2);color:#fff;padding:26px 20px;display:flex;flex-direction:column}
.side-brand{font-weight:800;color:var(--gold);letter-spacing:-1px}
.side-brand span{color:#fff;letter-spacing:.16em;font-size:12px;margin-left:6px}
.side-sub{font-family:var(--serif);font-style:italic;color:rgba(255,255,255,.6);font-size:14px;margin:4px 0 28px}
.sidebar nav{display:flex;flex-direction:column;gap:4px}
.sidebar nav a{padding:11px 14px;border-radius:11px;font-weight:600;font-size:14.5px;color:rgba(255,255,255,.78);transition:.2s}
.sidebar nav a:hover{background:rgba(255,255,255,.08);color:#fff}
.sidebar nav a.on{background:var(--red);color:#fff}
.side-logout{margin-top:auto;padding:11px 14px;color:rgba(255,255,255,.6);font-weight:600;font-size:14px}
.side-logout:hover{color:#fff}

.admin-main{display:flex;flex-direction:column}
.admin-top{display:flex;align-items:center;justify-content:space-between;
  padding:22px 34px;background:#fff;border-bottom:1px solid var(--line)}
.admin-top h1{font-family:var(--serif);font-size:26px;font-weight:800}
.admin-user{font-size:14px;color:var(--muted)}
.admin-content{padding:30px 34px}

/* ---------- stats ---------- */
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:26px}
.stat{background:#fff;border:1px solid var(--line);border-radius:16px;padding:22px}
.stat .num{font-family:var(--serif);font-size:34px;font-weight:800;display:block;line-height:1}
.stat .lbl{color:var(--muted);font-size:13px;font-weight:600}
.stat:nth-child(1){border-top:3px solid var(--red)}
.stat:nth-child(2){border-top:3px solid var(--teal)}
.stat:nth-child(3){border-top:3px solid var(--gold)}
.stat:nth-child(4){border-top:3px solid var(--ink)}

/* ---------- panel & table ---------- */
.panel{background:#fff;border:1px solid var(--line);border-radius:18px;padding:24px}
.panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.panel-head h2{font-family:var(--serif);font-size:22px}
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:14px}
td:nth-child(1){min-width:300px}
td:nth-child(3),td:nth-child(4),td:nth-child(5){white-space:nowrap}
th{text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);
  padding:10px 12px;border-bottom:2px solid var(--line)}
td{padding:12px;border-bottom:1px solid var(--line);vertical-align:middle}
.td-title{display:flex;align-items:center;gap:12px;min-width:0}
.td-title img{width:56px;height:42px;object-fit:cover;border-radius:8px;flex:none}
.td-title>div{min-width:0}
.td-title strong{display:block;font-size:14.5px;line-height:1.3;max-width:100%;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.td-title small{display:block}
.dot-tag{font-size:12px;font-weight:700;padding-left:16px;position:relative;display:inline-block}
.dot-tag::before{content:"";position:absolute;left:0;top:5px;width:9px;height:9px;border-radius:50%;background:var(--c)}
.badge{display:inline-block;font-size:11px;font-weight:800;padding:3px 9px;border-radius:20px;text-transform:uppercase;letter-spacing:.03em}
.badge.published{background:#dff0e4;color:#1f6b41}
.badge.draft{background:#eee6cf;color:#8a6a1a}
.badge.feat{background:#fbe3dd;color:#8c2c19}
.actions{display:flex;align-items:center;gap:6px;white-space:nowrap}
.actions form{display:inline}
.mini{font-size:12.5px;font-weight:700;padding:6px 11px;border-radius:8px;border:1.5px solid var(--line);background:#fff;cursor:pointer;transition:.2s}
.mini:hover{border-color:var(--ink)}
.mini.edit{color:var(--teal);border-color:#bfe0cd}
.mini.edit:hover{background:var(--teal);color:#fff}
.mini.del{color:var(--red);border-color:#f0cabf}
.mini.del:hover{background:var(--red);color:#fff}

/* ---------- buttons ---------- */
.btn-primary{background:var(--red);color:#fff;border:0;padding:11px 20px;border-radius:11px;font:inherit;font-weight:700;cursor:pointer;transition:.2s}
.btn-primary:hover{background:var(--ink)}
.btn-ghost{padding:11px 20px;border:1.5px solid var(--line);border-radius:11px;font-weight:700}
.btn-ghost:hover{border-color:var(--ink)}

/* ---------- form ---------- */
.form-grid{display:grid;grid-template-columns:1fr 340px;gap:26px}
.fld{display:block;font-size:13px;font-weight:600;margin-bottom:18px}
.fld input,.fld textarea,.fld select{width:100%;margin-top:7px;padding:11px 13px;border:1.5px solid var(--line);
  border-radius:11px;font:inherit;background:#fff;outline:none}
.fld textarea{resize:vertical;line-height:1.6}
.fld input:focus,.fld textarea:focus,.fld select:focus{border-color:var(--ink)}
.side-box{background:#faf8ef;border:1px solid var(--line);border-radius:14px;padding:18px;margin-bottom:18px}
.side-box h4{font-family:var(--serif);font-size:17px;margin-bottom:14px}
.check{display:flex;align-items:center;gap:9px;font-size:14px;font-weight:600}
.check input{width:auto}
.preview{width:100%;aspect-ratio:16/10;object-fit:cover;border-radius:10px;margin-bottom:12px;border:1px solid var(--line)}
.preview.hidden{display:none}
.form-actions{display:flex;gap:10px;align-items:center}

@media(max-width:900px){
  .admin{grid-template-columns:1fr}
  .sidebar{flex-direction:row;flex-wrap:wrap;align-items:center;gap:12px}
  .sidebar nav{flex-direction:row;flex-wrap:wrap}
  .side-sub{display:none}.side-logout{margin:0}
  .form-grid{grid-template-columns:1fr}
  .stat-row{grid-template-columns:1fr 1fr}
}

/* foto tambahan / galeri */
.small{font-size:12px}
.gallery-admin{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}
.gallery-admin .g-item{position:relative;display:block;margin:0}
.gallery-admin img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:8px;display:block}
.gallery-admin .g-rm{position:absolute;left:5px;top:5px;background:rgba(15,20,16,.72);color:#fff;font-size:11px;font-weight:600;padding:3px 7px;border-radius:6px;display:inline-flex;align-items:center;gap:4px;cursor:pointer}
.gallery-admin .g-rm input{margin:0}
.gallery-preview{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.gallery-preview img{width:58px;height:58px;object-fit:cover;border-radius:6px}