:root {
  --p: #171717; --accent: #A16207; --bg: #f7f6f4; --card:#fff;
  --border:#e7e5e4; --fg:#1c1917; --soft:#57534e; --faint:#a8a29e;
  --ok:#15803d; --err:#b91c1c;
  --font: 'Archivo', system-ui, sans-serif; --head:'Space Grotesk', system-ui, sans-serif;
}
*,*::before,*::after{box-sizing:border-box}
[hidden]{display:none !important}
body{margin:0;font-family:var(--font);background:var(--bg);color:var(--fg);font-size:15px;line-height:1.55;overflow-x:hidden}
h1,h2,h3{font-family:var(--head);font-weight:500;letter-spacing:-.01em;margin:0}
a{color:inherit}
button{font-family:var(--head)}

/* ---- Login ---- */
.login{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:1.5rem;width:100%}
.login__card{background:var(--card);border:1px solid var(--border);padding:2.5rem;width:100%;max-width:400px}
.login__card h1{font-size:1.5rem;margin-bottom:.4rem}
.login__card p{color:var(--soft);margin:0 0 1.6rem}

/* ---- Shell ---- */
.shell{display:grid;grid-template-columns:230px 1fr;min-height:100dvh}
.scrim{display:none}
.side{background:var(--p);color:#fff;padding:1.5rem 1rem;display:flex;flex-direction:column}
.side__brand{font-family:var(--head);font-weight:600;font-size:1.05rem;padding:.4rem .6rem 1.4rem}
.side__brand small{display:block;color:var(--accent);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;font-weight:500;margin-top:.2rem}
.nav-item{display:block;width:100%;text-align:left;background:none;border:0;color:rgba(255,255,255,.72);
  padding:.7rem .65rem;border-radius:6px;cursor:pointer;font-size:.92rem;transition:all .15s}
.nav-item:hover{background:rgba(255,255,255,.08);color:#fff}
.nav-item.is-active{background:#fff;color:var(--p);font-weight:500}
.side__foot{margin-top:auto;display:flex;flex-direction:column;gap:.5rem;padding-top:1rem}
.side__foot a,.side__foot button{color:rgba(255,255,255,.6);font-size:.82rem;background:none;border:0;text-align:left;cursor:pointer;padding:.3rem .65rem}
.side__foot a:hover,.side__foot button:hover{color:#fff}

.main{padding:clamp(1.25rem,3vw,2.5rem);overflow-x:hidden}
.page__head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.6rem;flex-wrap:wrap}
.page__head h2{font-size:1.6rem}
.muted{color:var(--soft)}

/* ---- Mobile shell ---- */
.topbar{display:none}
@media (max-width:820px){
  .shell{grid-template-columns:1fr}
  .side{position:fixed;inset:0 30% 0 0;z-index:50;transform:translateX(-100%);transition:transform .3s}
  .side.is-open{transform:none}
  .scrim{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:40}
  .scrim.is-open{display:block}
  .topbar{display:flex;align-items:center;gap:.8rem;background:var(--p);color:#fff;padding:.8rem 1rem;position:sticky;top:0;z-index:30}
  .topbar button{background:none;border:0;color:#fff;cursor:pointer;padding:4px}
  .topbar svg{width:24px;height:24px}
}

/* ---- Cards / forms ---- */
.card{background:var(--card);border:1px solid var(--border);padding:1.5rem;margin-bottom:1.25rem}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media (max-width:640px){.grid2{grid-template-columns:1fr}}
label{display:block;font-family:var(--head);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--soft);margin:0 0 .35rem}
.field{margin-bottom:1rem}
input,textarea,select{width:100%;font-family:var(--font);font-size:.95rem;padding:.6rem .75rem;border:1px solid var(--border);background:#fff;border-radius:4px;color:var(--fg)}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--p)}
textarea{resize:vertical;min-height:90px}
input[type=color]{padding:.2rem;height:42px;cursor:pointer}
.row-color{display:flex;align-items:center;gap:.6rem}
.row-color input[type=text]{max-width:120px}

.btn{display:inline-flex;align-items:center;gap:.4rem;font-weight:500;font-size:.88rem;padding:.6rem 1.1rem;
  border:1px solid var(--p);background:var(--p);color:#fff;cursor:pointer;border-radius:4px;transition:.2s}
.btn:hover{opacity:.88}
.btn--ghost{background:transparent;color:var(--p)}
.btn--ghost:hover{background:var(--p);color:#fff;opacity:1}
.btn--sm{padding:.4rem .75rem;font-size:.8rem}
.btn--danger{border-color:var(--err);background:var(--err)}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* ---- List rows ---- */
.item{display:flex;align-items:center;gap:1rem;padding:.85rem 1rem;border:1px solid var(--border);background:var(--card);margin-bottom:.6rem;border-radius:6px}
.item__thumb{width:64px;height:48px;object-fit:cover;border-radius:4px;background:var(--bg);flex:none}
.item__body{flex:1;min-width:0}
.item__title{font-family:var(--head);font-weight:500}
.item__sub{color:var(--soft);font-size:.85rem}
.item__actions{display:flex;gap:.4rem;flex:none}
.tag{display:inline-block;font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;background:var(--bg);color:var(--soft);padding:.15rem .5rem;border-radius:3px;margin-left:.5rem}
.tag--accent{background:var(--accent);color:#fff}

/* ---- Image picker ---- */
.imgpick{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.imgpick img{width:120px;height:90px;object-fit:cover;border:1px solid var(--border);border-radius:4px;background:var(--bg)}
.thumbs{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:.6rem}
.thumbs figure{position:relative;margin:0}
.thumbs img{width:90px;height:68px;object-fit:cover;border:1px solid var(--border);border-radius:4px}
.thumbs button{position:absolute;top:-8px;right:-8px;width:22px;height:22px;border-radius:50%;background:var(--err);color:#fff;border:0;cursor:pointer;font-size:13px;line-height:1}

/* ---- Modal ---- */
.modal{position:fixed;inset:0;z-index:100;display:flex;padding:1.5rem}
.modal__scrim{position:absolute;inset:0;background:rgba(0,0,0,.5)}
.modal__panel{position:relative;margin:auto;background:var(--card);width:min(680px,100%);max-height:90vh;overflow-y:auto;border-radius:8px;padding:1.75rem}
.modal__panel h3{font-size:1.3rem;margin-bottom:1.2rem}

/* ---- Toast ---- */
.toast{position:fixed;bottom:1.25rem;left:50%;transform:translateX(-50%) translateY(120%);
  background:var(--p);color:#fff;padding:.8rem 1.4rem;border-radius:8px;font-size:.9rem;z-index:200;transition:transform .3s;box-shadow:0 8px 30px rgba(0,0,0,.25)}
.toast.show{transform:translateX(-50%) translateY(0)}
.toast.err{background:var(--err)}
.toast.ok{background:var(--ok)}

.empty{color:var(--faint);padding:2rem;text-align:center;border:1px dashed var(--border);border-radius:6px}
.help{font-size:.82rem;color:var(--soft);margin:.3rem 0 0}
