:root{
  --bg:#07090f;
  --surface:#0c1220;
  --card:rgba(255,255,255,.04);
  --text:#f0f3fa;
  --muted:#9aa7c7;
  --line:rgba(255,255,255,.10);
  --gold:rgba(201,168,106,.35);
  --brand:#6b8cff;
  --brand-2:#8b6bff;
  --danger:#ff4d6d;
  --good:#00d7a2;
  --shadow:0 22px 55px rgba(0,0,0,.42);
  --radius:16px;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:"DM Sans",ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background:
    radial-gradient(900px 400px at 12% -10%, rgba(107,140,255,.22), transparent 58%),
    radial-gradient(700px 350px at 92% 0%, rgba(201,168,106,.08), transparent 62%),
    var(--bg);
  color:var(--text);
}
a{color:inherit;text-decoration:none}

.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:.65rem .9rem;border-radius:999px;
  border:1px solid transparent;font-weight:700;
  transition:transform .15s ease, background .15s ease, border-color .15s ease, opacity .15s ease;
}
.btn:hover{transform:translateY(-1px)}
.btn-outline{background:transparent;border-color:var(--line)}
.btn-primary{background:linear-gradient(135deg,var(--brand),var(--brand-2))}
.btn-danger{background:rgba(255,77,109,.12);border:1px solid rgba(255,77,109,.35);color:#ffd1da}
.btn-danger:hover{border-color:rgba(255,77,109,.55)}

.admin-shell{display:grid;grid-template-columns: 270px 1fr;min-height:100vh}
.sidebar{
  padding:18px 14px;
  border-right:1px solid rgba(201,168,106,.12);
  background:rgba(7,9,15,.72);
  backdrop-filter: blur(12px) saturate(1.15);
  position:sticky;top:0;height:100vh;
}
.side-brand{display:flex;gap:12px;align-items:center;margin:6px 6px 14px;min-width:0}
.side-logo{
  width:40px;height:40px;object-fit:contain;border-radius:12px;
  flex-shrink:0;
  filter:drop-shadow(0 2px 10px rgba(0,0,0,.35));
}
.side-mark{
  width:40px;height:40px;border-radius:14px;display:grid;place-items:center;
  background:linear-gradient(145deg, rgba(201,168,106,.35), var(--brand) 45%, var(--brand-2));
  font-weight:900;
  flex-shrink:0;
  box-shadow:0 8px 22px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.1);
}
.side-name-stack{display:flex;flex-direction:column;gap:2px;line-height:1.15;min-width:0}
.side-name{font-weight:800;letter-spacing:.02em;font-size:1.02rem}
.side-tag{
  font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(201,168,106,.88);
}
.side-nav{display:grid;gap:6px;padding:6px}
.side-nav a{
  padding:.7rem .8rem;border-radius:14px;
  border:1px solid transparent;
  background:transparent;
  color:var(--muted);
  font-weight:700;
  transition:background .15s ease, border-color .15s ease, color .15s ease;
}
.side-nav a:hover{
  color:var(--text);
  background:rgba(255,255,255,.05);
  border-color:rgba(255,255,255,.10);
}
.side-nav a.active{
  color:var(--text);
  background:rgba(255,255,255,.07);
  border-color:rgba(255,255,255,.14);
}
.side-muted{opacity:.85}

.admin-main{min-width:0}
.topbar{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:14px 18px;
  border-bottom:1px solid rgba(255,255,255,.08);
  background:rgba(11,18,32,.72);
  backdrop-filter: blur(10px);
  position:sticky;top:0;z-index:40;
}
.topbar-title{font-weight:900;letter-spacing:.2px}
.topbar-right{display:flex;align-items:center;gap:10px}
.chip{
  padding:.35rem .55rem;border-radius:999px;
  background:rgba(255,255,255,.06);border:1px solid var(--line);
  color:var(--muted);font-weight:800;font-size:.9rem;
}
.icon-btn{
  width:44px;height:44px;border-radius:14px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.04);
  display:none;cursor:pointer;
}
.icon-btn span{display:block;height:2px;background:var(--text);margin:6px 10px;border-radius:99px;opacity:.9}

.admin-content{padding:18px;max-width:1100px}
.card{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.10);
  border-radius:var(--radius);
  padding:16px;
  box-shadow:var(--shadow);
}
.grid{display:grid;gap:14px}
.grid-2{grid-template-columns: 1fr 1fr}
.muted{color:var(--muted)}

.inline-upload-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:10px}
.inline-upload-btn{margin:0;cursor:pointer;font-size:.92rem}
/* Hidden but associated with <label for="…"> so the picker opens reliably (no JS .click() on clipped inputs). */
.inline-file-input-hidden{display:none!important}
.field{display:grid;gap:7px;margin-bottom:12px}
label{font-weight:800}
input[type="text"], input[type="url"], input[type="password"], select, textarea{
  width:100%;
  padding:.75rem .85rem;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.18);
  color:var(--text);
  outline:none;
}
textarea{min-height:180px;resize:vertical}
input:focus, select:focus, textarea:focus{border-color:rgba(91,140,255,.55);box-shadow:0 0 0 4px rgba(91,140,255,.12)}

.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.check{
  display:flex;align-items:center;gap:8px;
  padding:.55rem .7rem;border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.03);
}
.check input{width:18px;height:18px}

.table-wrap{overflow:auto;border-radius:var(--radius);border:1px solid rgba(255,255,255,.10)}
table{width:100%;border-collapse:collapse;min-width:860px;background:rgba(255,255,255,.02)}
th,td{padding:12px 12px;border-bottom:1px solid rgba(255,255,255,.08);text-align:left}
th{font-size:.92rem;color:var(--muted);font-weight:900}
tr:hover td{background:rgba(255,255,255,.03)}
.actions{display:flex;gap:8px;flex-wrap:wrap}
.badge{
  padding:.22rem .5rem;border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.05);
  color:var(--muted);
  font-weight:900;font-size:.82rem;
}
.badge.good{border-color:rgba(0,215,162,.35);background:rgba(0,215,162,.14);color:#b9ffef}

.alert{
  padding:12px 14px;border-radius:16px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.04);
  margin-bottom:12px;
}
.alert.error{border-color:rgba(255,77,109,.35);background:rgba(255,77,109,.10)}
.alert.success{border-color:rgba(0,215,162,.35);background:rgba(0,215,162,.10)}

.login-shell{
  min-height:100vh;
  display:grid;
  place-items:center;
  padding:18px;
}
.login-card{
  width:min(480px, 100%);
  padding:18px;
  border-radius:22px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.10);
  box-shadow:var(--shadow);
}
.login-brand{display:flex;align-items:center;gap:14px;margin-bottom:14px;flex-wrap:wrap}
.login-logo{height:40px;width:auto;max-width:200px;object-fit:contain}
.login-brand-text{display:flex;flex-direction:column;gap:4px}
.login-site{
  font-weight:800;font-size:1.15rem;letter-spacing:.02em;
  font-family:Georgia,"Times New Roman",serif;
}
.login-kicker{
  font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(201,168,106,.85);
}
.login-title{font-weight:800;font-size:1.35rem;margin:2px 0 4px}
.login-sub{margin:0 0 14px;color:var(--muted)}

.preview{
  margin-top:10px;
  border-radius:16px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.18);
}
.preview img{width:100%;max-height:260px;object-fit:cover}

@media (max-width: 860px){
  .admin-shell{grid-template-columns: 1fr}
  .sidebar{
    position:fixed;inset:0 auto 0 0;
    width:270px;transform:translateX(-105%);
    transition:transform .2s ease;
    z-index:60;
  }
  .sidebar.is-open{transform:translateX(0)}
  .icon-btn{display:inline-grid;place-items:center}
  .grid-2{grid-template-columns:1fr}
}

