body { min-height: 100vh; }
.login-screen { min-height: 100vh; display:grid; place-items:center; padding: 24px; background: radial-gradient(circle at 20% 10%, rgba(244,197,66,.25), transparent 30%), var(--color-bg); }
.login-card { width: min(430px, 100%); }
.admin-layout { min-height: 100vh; display:grid; grid-template-columns: 280px 1fr; }
.admin-sidebar { background: var(--color-surface); border-right: 1px solid var(--color-border); padding: 20px; position: sticky; top: 0; height: 100vh; overflow:auto; }
.admin-brand { display:flex; align-items:center; gap:12px; margin-bottom: 22px; }
.admin-brand .brand-mark { width: 42px; height:42px; }
.admin-nav { display:grid; gap: 6px; }
.admin-nav button { border:0; background: transparent; color: var(--color-muted); padding: 11px 12px; border-radius: 12px; text-align:left; font-weight:800; }
.admin-nav button.active, .admin-nav button:hover { background: rgba(0,89,168,.09); color: var(--color-primary); }
.admin-main { padding: 24px; overflow: hidden; }
.admin-topbar { display:flex; justify-content: space-between; align-items:center; gap:12px; margin-bottom: 22px; }
.admin-actions { display:flex; gap:8px; flex-wrap: wrap; }
.panel-grid { display:grid; grid-template-columns: 340px 1fr; gap: 18px; align-items:start; }
.entity-list { display:grid; gap:8px; max-height: calc(100vh - 260px); overflow:auto; padding-right: 4px; }
.entity-item { border:1px solid var(--color-border); border-radius: 14px; background: var(--color-surface); padding: 12px; display:grid; gap:4px; cursor:pointer; }
.entity-item.active { border-color: var(--color-primary); box-shadow: 0 0 0 3px rgba(0,89,168,.12); }
.entity-item strong { display:block; }
.entity-item small { color: var(--color-muted); }
.editor-box { background: white; color:#111827; border:1px solid var(--color-border); border-radius: 12px; overflow:hidden; }
.editor-box .ql-toolbar { border: 0; border-bottom:1px solid #ddd; }
.editor-box .ql-container { border:0; min-height: 210px; }
.form-row { display:grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap:14px; }
.media-grid { display:grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 12px; }
.media-card { border:1px solid var(--color-border); border-radius: 14px; background: var(--color-surface); overflow:hidden; }
.media-card img { width:100%; aspect-ratio:1/1; object-fit:cover; background: var(--color-surface-2); }
.media-card div { padding:10px; display:grid; gap:6px; }
.kpi-grid { display:grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap:14px; margin-bottom: 18px; }
.kpi { padding:18px; border-radius: var(--radius-md); border:1px solid var(--color-border); background: var(--color-surface); }
.kpi strong { display:block; font-size:2rem; color: var(--color-primary); }
.status-pill { font-size:.78rem; font-weight:800; padding: 4px 8px; border-radius: 999px; border:1px solid var(--color-border); display:inline-flex; width:max-content; }
.status-published { color: var(--color-success); background: rgba(18,140,126,.08); }
.status-draft { color: var(--color-warning); background: rgba(183,121,31,.1); }
.code-box { white-space:pre-wrap; overflow:auto; max-height:400px; padding:12px; background: #0f172a; color:#e2e8f0; border-radius:12px; }
.filepond--credits { display:none; }
@media (max-width: 980px) {
  .admin-layout { grid-template-columns: 1fr; }
  .admin-sidebar { position: relative; height:auto; }
  .admin-nav { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .panel-grid { grid-template-columns: 1fr; }
  .kpi-grid, .form-row { grid-template-columns: 1fr; }
}

/* v5 admin: branding, SEO, users */
.brand-logo-admin {
  width: 42px;
  height: 42px;
  object-fit: cover;
  border-radius: 14px;
  border: 1px solid var(--color-border);
  background: var(--color-surface-2);
  box-shadow: var(--shadow-sm);
}
.seo-score {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  margin-bottom: 14px;
  background: var(--color-surface-2);
}
.seo-score strong { font-size: 2rem; color: var(--color-primary); }
.seo-score small { color: var(--color-muted); margin-left: auto; }
.seo-checks { display: grid; gap: 10px; }
.seo-check {
  border: 1px solid var(--color-border);
  border-radius: 14px;
  padding: 12px;
  background: var(--color-surface);
}
.seo-check p { margin-top: 4px; color: var(--color-muted); }
.seo-check.ok { border-color: rgba(18,140,126,.35); background: rgba(18,140,126,.07); }
.seo-check.warn { border-color: rgba(183,121,31,.35); background: rgba(183,121,31,.08); }
.seo-check.error { border-color: rgba(220,38,38,.35); background: rgba(220,38,38,.08); }
