/* ============================================================
   LA PANTHÈRE MAGIQUE — admin.css
   ============================================================ */

:root {
  --bg:          #0c1210;
  --bg2:         #111916;
  --surface:     #161e1a;
  --surface2:    #1c2622;
  --border:      rgba(255,255,255,0.07);
  --text:        #edf3ee;
  --soft:        rgba(237,243,238,0.58);
  --muted:       rgba(237,243,238,0.34);
  --green:       #74a87a;
  --green-dk:    #5a8e60;
  --green-gl:    rgba(116,168,122,0.16);
  --accent:      #e8c547;
  --danger:      #d96b6b;
  --danger-bg:   rgba(217,107,107,0.13);
  --sidebar-w:   232px;
  --r:           16px;
  --r-sm:        10px;
  --shadow:      0 20px 60px rgba(0,0,0,0.38);
  --shadow-sm:   0 4px 16px rgba(0,0,0,0.22);
  --ease:        cubic-bezier(0.16,1,0.3,1);
}

*,*::before,*::after { box-sizing:border-box; }
html,body { margin:0; height:100%; }
body {
  font-family:"Manrope",system-ui,sans-serif;
  font-size:14px;
  background:var(--bg);
  color:var(--text);
  min-height:100svh;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
button,input,textarea,select { font:inherit; }
button { cursor:pointer; border:none; background:none; padding:0; }
img { display:block; max-width:100%; }
h1,h2,h3,h4 { margin:0; }
p { margin:0; }
a { text-decoration:none; color:inherit; }

/* ── LOGIN ── */
.login-shell {
  min-height:100svh; display:grid; place-items:center;
  padding:1.5rem; position:relative; overflow:hidden;
}
.login-bg {
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse at 18% 50%, rgba(116,168,122,.07) 0%, transparent 52%),
    radial-gradient(ellipse at 82% 20%, rgba(232,197,71,.04) 0%, transparent 42%);
  pointer-events:none;
}
.login-card {
  position:relative; width:min(420px,100%);
  background:var(--surface); border:1px solid var(--border);
  border-radius:26px; padding:2.5rem 2.25rem;
  box-shadow:var(--shadow); animation:card-in .5s var(--ease) both;
}
@keyframes card-in {
  from { opacity:0; transform:translateY(24px) scale(.97); }
  to   { opacity:1; transform:none; }
}
.login-mark {
  display:inline-grid; place-items:center;
  width:46px; height:46px; border-radius:13px;
  background:var(--green-gl); border:1px solid rgba(116,168,122,.2);
  color:var(--accent); font-size:1.3rem; margin-bottom:1.1rem;
}
.kicker {
  margin:0 0 .3rem; font-size:.72rem; font-weight:800;
  letter-spacing:.2em; text-transform:uppercase; color:var(--green);
}
.login-card h1 { font-family:"Fraunces",serif; font-size:1.9rem; margin-bottom:.35rem; }
.login-sub { color:var(--soft); font-size:.88rem; line-height:1.6; margin-bottom:1.5rem; }

.login-card form { display:grid; gap:.9rem; }
.field { display:grid; gap:.38rem; }
.field label { font-size:.75rem; font-weight:800; text-transform:uppercase; letter-spacing:.1em; color:var(--soft); }
.req { color:var(--green); margin-left:.15rem; }
.input-wrap { position:relative; display:flex; align-items:center; }
.input-ico { position:absolute; left:.85rem; color:var(--muted); pointer-events:none; width:16px; height:16px; flex-shrink:0; }

.field input,
.field textarea,
.field select {
  width:100%; background:var(--bg2); border:1.5px solid var(--border);
  border-radius:var(--r-sm); padding:.78rem 1rem .78rem 2.55rem;
  color:var(--text); outline:none; transition:border-color .18s,box-shadow .18s;
}
.field input:not(.input-wrap input),
.field textarea,
.field select { padding-left:1rem; }
.field input::placeholder, .field textarea::placeholder { color:var(--muted); }
.field input:focus, .field textarea:focus, .field select:focus {
  border-color:var(--green); box-shadow:0 0 0 3px var(--green-gl);
}
.field textarea { resize:vertical; min-height:90px; }
.field-full { grid-column:1/-1; }
.field-checks { display:flex; flex-direction:column; gap:.6rem; justify-content:center; }

.pass-toggle { position:absolute; right:.8rem; color:var(--muted); display:flex; transition:color .15s; }
.pass-toggle:hover { color:var(--text); }

.login-error {
  display:flex; align-items:center; gap:.5rem; padding:.7rem .9rem;
  border-radius:var(--r-sm); background:var(--danger-bg);
  border:1px solid rgba(217,107,107,.24); color:#f0a0a0;
  font-weight:600; font-size:.84rem; animation:shake .38s ease;
}
@keyframes shake {
  0%,100% { transform:translateX(0); }
  25%      { transform:translateX(-5px); }
  75%      { transform:translateX(5px); }
}

/* Buttons */
.btn-primary {
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  min-height:44px; padding:.7rem 1.2rem; border-radius:999px;
  background:var(--green); color:#fff; font-weight:800; font-size:.88rem;
  border:none; cursor:pointer;
  transition:background .18s,transform .18s,box-shadow .18s,opacity .18s;
}
.btn-primary:hover:not(:disabled) { background:var(--green-dk); transform:translateY(-1px); box-shadow:0 6px 20px rgba(116,168,122,.3); }
.btn-primary:disabled { opacity:.42; cursor:not-allowed; }
.btn-primary:active:not(:disabled) { transform:scale(.97); }
.w-full { width:100%; margin-top:.4rem; min-height:48px; font-size:.92rem; }

.btn-outline {
  display:inline-flex; align-items:center; justify-content:center; gap:.4rem;
  min-height:38px; padding:.55rem 1rem; border-radius:999px;
  border:1.5px solid var(--border); background:transparent; color:var(--soft);
  font-weight:700; font-size:.84rem; cursor:pointer;
  transition:background .18s,border-color .18s,color .18s;
}
.btn-outline:hover { background:rgba(255,255,255,.04); border-color:rgba(255,255,255,.14); color:var(--text); }
.btn-sm { min-height:34px; padding:.45rem .85rem; font-size:.8rem; }

.btn-danger {
  display:inline-flex; align-items:center; gap:.35rem;
  min-height:34px; padding:.45rem .85rem; border-radius:999px;
  background:var(--danger-bg); border:1px solid rgba(217,107,107,.2);
  color:var(--danger); font-weight:700; font-size:.8rem; cursor:pointer;
  transition:background .18s;
}
.btn-danger:hover { background:rgba(217,107,107,.22); }

.btn-text {
  background:none; border:none; color:var(--muted); font-size:.8rem;
  font-weight:600; cursor:pointer; padding:.25rem .45rem; border-radius:6px;
  transition:color .15s,background .15s;
}
.btn-text:hover { color:var(--text); background:var(--surface2); }

.icon-btn {
  display:grid; place-items:center; width:30px; height:30px; border-radius:50%;
  background:var(--surface2); color:var(--soft); transition:background .15s,color .15s;
}
.icon-btn:hover { background:var(--danger-bg); color:var(--danger); }

.login-back { display:block; text-align:center; margin-top:1.4rem; font-size:.84rem; font-weight:600; color:var(--muted); transition:color .15s; }
.login-back:hover { color:var(--green); }

/* ── ADMIN SHELL ── */
.admin-shell { display:flex; min-height:100svh; }

/* ── SIDEBAR ── */
.sidebar {
  width:var(--sidebar-w); flex-shrink:0; background:var(--surface);
  border-right:1px solid var(--border); display:flex; flex-direction:column;
  position:fixed; top:0; left:0; height:100svh; z-index:100; overflow-y:auto;
  transition:transform .3s var(--ease);
}
.sidebar-brand {
  display:flex; align-items:center; gap:.7rem; padding:1.3rem 1.1rem 1.1rem;
  border-bottom:1px solid var(--border); flex-shrink:0;
}
.brand-gem { display:grid; place-items:center; width:34px; height:34px; border-radius:10px; background:var(--green-gl); color:var(--accent); font-size:1rem; flex-shrink:0; }
.sidebar-brand strong { display:block; font-family:"Fraunces",serif; font-size:.9rem; line-height:1.2; }
.sidebar-brand span   { font-size:.7rem; color:var(--muted); font-weight:600; }
.sidebar-nav { flex:1; padding:.65rem .65rem; display:flex; flex-direction:column; gap:.15rem; }

.s-item {
  display:flex; align-items:center; gap:.7rem; padding:.65rem .8rem;
  border-radius:var(--r-sm); color:var(--soft); font-weight:600; font-size:.86rem;
  text-align:left; width:100%; transition:background .15s,color .15s;
  cursor:pointer; border:none; background:none;
}
.s-item:hover { background:var(--surface2); color:var(--text); }
.s-item.active { background:var(--green-gl); color:var(--green); font-weight:700; }
.s-item svg { flex-shrink:0; opacity:.75; }
.s-item.active svg { opacity:1; }

.sidebar-foot { padding:.9rem .65rem; border-top:1px solid var(--border); flex-shrink:0; }
.sidebar-user { display:flex; align-items:center; gap:.65rem; padding:.5rem .4rem; margin-bottom:.45rem; }
.s-avatar {
  width:32px; height:32px; border-radius:50%; background:var(--green-gl);
  border:1.5px solid rgba(116,168,122,.22); display:grid; place-items:center;
  font-weight:800; font-size:.82rem; color:var(--green); flex-shrink:0;
}
.sidebar-user strong { display:block; font-size:.84rem; }
.sidebar-user span   { font-size:.72rem; color:var(--muted); }
.sidebar-links { display:flex; flex-direction:column; gap:.05rem; }
.s-link {
  display:flex; align-items:center; gap:.55rem; padding:.48rem .55rem;
  border-radius:8px; color:var(--muted); font-size:.8rem; font-weight:600;
  transition:color .15s,background .15s; background:none; border:none;
  cursor:pointer; text-align:left; width:100%;
}
.s-link:hover { color:var(--text); background:var(--surface2); }

.sidebar-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.55); backdrop-filter:blur(4px); z-index:99; }
.sidebar-overlay.open { display:block; }

/* ── MAIN ── */
.admin-main { flex:1; margin-left:var(--sidebar-w); min-width:0; background:var(--bg); display:flex; flex-direction:column; }

.topbar {
  display:none; align-items:center; gap:1rem; padding:.85rem 1.15rem;
  background:var(--surface); border-bottom:1px solid var(--border);
  position:sticky; top:0; z-index:50;
}
.topbar-ham { display:flex; flex-direction:column; gap:5px; padding:4px; }
.topbar-ham span { display:block; width:20px; height:2px; background:var(--text); border-radius:2px; }
.topbar-title { flex:1; font-weight:700; font-size:.92rem; }
.topbar-home  { color:var(--soft); display:flex; transition:color .15s; }
.topbar-home:hover { color:var(--green); }

/* ── TAB SECTIONS ── */
.tab-section { display:none; flex-direction:column; gap:1.25rem; padding:2rem; flex:1; animation:sec-in .3s var(--ease); }
.tab-section.active { display:flex; }
@keyframes sec-in { from { opacity:0; transform:translateY(10px); } to { opacity:1; transform:none; } }

.sec-head { display:flex; align-items:flex-start; justify-content:space-between; gap:1rem; flex-wrap:wrap; }
.sec-head h2 { font-family:"Fraunces",serif; font-size:clamp(1.45rem,3vw,2.1rem); }
.sec-sub { color:var(--soft); font-size:.86rem; margin-top:.3rem; line-height:1.6; }

/* ── PANELS ── */
.panel { background:var(--surface); border:1px solid var(--border); border-radius:var(--r); padding:1.4rem; box-shadow:var(--shadow-sm); }
.panel-title { font-family:"Fraunces",serif; font-size:1.05rem; color:var(--text); margin-bottom:1.1rem; }
.panel-head-row { display:flex; align-items:center; justify-content:space-between; gap:.75rem; margin-bottom:1.1rem; }
.panel-head-row .panel-title { margin-bottom:0; }

.collapsible { display:none; }
.collapsible.open { display:block; animation:sec-in .3s var(--ease); }

.two-col { display:grid; grid-template-columns:1fr 1fr; gap:1.25rem; }

/* ── FORM GRID ── */
.form-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:.85rem; }
.field-full { grid-column:1/-1; }
.form-actions { display:flex; gap:.65rem; margin-top:1.1rem; flex-wrap:wrap; }

.check-label { display:flex; align-items:center; gap:.55rem; cursor:pointer; font-size:.86rem; font-weight:600; color:var(--soft); user-select:none; }
.check-label input[type="checkbox"] { display:none; }
.check-box { width:17px; height:17px; border-radius:5px; border:1.5px solid var(--border); background:var(--bg2); flex-shrink:0; position:relative; transition:background .18s,border-color .18s; }
.check-label input:checked + .check-box { background:var(--green); border-color:var(--green); }
.check-label input:checked + .check-box::after {
  content:''; position:absolute; left:3px; top:1px;
  width:8px; height:5px; border-left:2px solid #fff; border-bottom:2px solid #fff; transform:rotate(-45deg);
}

/* ── PROFILE ── */
.profile-layout { display:grid; grid-template-columns:auto 1fr; gap:1.5rem; align-items:start; }
.profile-left { text-align:center; }
.profile-preview { width:160px; height:160px; border-radius:18px; overflow:hidden; background:var(--surface2); border:2px solid var(--border); position:relative; }
.profile-preview img { width:100%; height:100%; object-fit:cover; }
.profile-hover { position:absolute; inset:0; background:rgba(0,0,0,.52); display:grid; place-items:center; opacity:0; transition:opacity .2s; }
.profile-preview:hover .profile-hover { opacity:1; }
.profile-hover button { background:rgba(255,255,255,.15); border:1px solid rgba(255,255,255,.25); color:#fff; padding:.45rem .85rem; border-radius:999px; font-size:.78rem; font-weight:700; cursor:pointer; }
.hint { font-size:.74rem; color:var(--muted); margin-top:.5rem; }
.profile-right { display:flex; flex-direction:column; gap:.85rem; }

/* ── DROP ZONES ── */
.drop-zone {
  border:2px dashed rgba(255,255,255,.09); border-radius:var(--r);
  padding:1.75rem 1.25rem; text-align:center; cursor:pointer;
  transition:border-color .2s,background .2s; display:flex;
  flex-direction:column; align-items:center; gap:.55rem;
}
.drop-zone p { color:var(--soft); font-size:.88rem; font-weight:600; }
.drop-zone:hover, .drop-zone:focus-visible { border-color:rgba(116,168,122,.35); background:rgba(116,168,122,.04); outline:none; }
.drop-zone.drag-over { border-color:var(--green); background:var(--green-gl); }
.drop-zone svg { color:var(--muted); }
.drop-zone-lg { padding:2.5rem 1.5rem; }

.news-img-area { display:flex; align-items:flex-start; gap:1rem; flex-wrap:wrap; }
.drop-zone-news { width:180px; min-height:140px; flex-shrink:0; padding:1.25rem .75rem; }
.news-img-preview { position:relative; width:100%; height:100%; }
.news-img-preview img { width:100%; height:100%; object-fit:cover; border-radius:var(--r-sm); }
.img-remove { position:absolute; top:-8px; right:-8px; width:22px; height:22px; border-radius:50%; background:var(--danger); color:#fff; display:grid; place-items:center; font-size:.95rem; font-weight:700; line-height:1; cursor:pointer; border:none; }
.news-img-or { display:flex; align-items:center; font-size:.78rem; color:var(--muted); font-weight:600; writing-mode:vertical-rl; text-orientation:mixed; padding:.5rem 0; }

/* ── THUMBS / GALLERY ── */
.thumb-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(88px,1fr)); gap:.65rem; }
.thumb-grid-lg { grid-template-columns:repeat(auto-fill,minmax(120px,1fr)); }
.thumb { position:relative; aspect-ratio:1; border-radius:var(--r-sm); overflow:hidden; background:var(--surface2); border:1px solid var(--border); }
.thumb img { width:100%; height:100%; object-fit:cover; transition:transform .3s; }
.thumb:hover img { transform:scale(1.06); }
.thumb-del { position:absolute; top:4px; right:4px; width:24px; height:24px; border-radius:50%; background:rgba(217,107,107,.9); color:#fff; display:grid; place-items:center; font-size:.95rem; font-weight:700; line-height:1; opacity:0; transition:opacity .18s; cursor:pointer; border:none; }
.thumb:hover .thumb-del { opacity:1; }

.pending-bar { display:flex; align-items:center; justify-content:space-between; margin:1rem 0 .65rem; }
.pending-bar span { font-size:.85rem; font-weight:700; color:var(--soft); }
.count-badge { display:inline-flex; align-items:center; justify-content:center; min-width:24px; height:24px; padding:0 .45rem; border-radius:999px; background:var(--green-gl); color:var(--green); font-size:.74rem; font-weight:800; }

/* ── NEWS LIST ── */
.news-admin-list { display:grid; gap:.65rem; }
.news-admin-card { display:grid; grid-template-columns:72px 1fr auto; gap:.9rem; align-items:center; padding:.9rem; background:var(--surface2); border:1px solid var(--border); border-radius:var(--r-sm); transition:border-color .18s; }
.news-admin-card:hover { border-color:rgba(255,255,255,.12); }
.na-thumb { width:72px; height:72px; border-radius:8px; overflow:hidden; background:var(--bg2); }
.na-thumb img { width:100%; height:100%; object-fit:cover; }
.na-info { min-width:0; }
.na-badges { display:flex; flex-wrap:wrap; gap:.3rem; margin-bottom:.35rem; }
.badge { display:inline-flex; align-items:center; min-height:20px; padding:.18rem .48rem; border-radius:999px; background:var(--green-gl); color:var(--green); font-size:.66rem; font-weight:800; text-transform:uppercase; letter-spacing:.07em; }
.badge.off { background:rgba(255,255,255,.05); color:var(--muted); }
.na-info h4 { font-family:"Fraunces",serif; font-size:.98rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.na-info p { font-size:.78rem; color:var(--soft); margin-top:.18rem; }
.na-actions { display:flex; flex-direction:column; gap:.38rem; flex-shrink:0; }

/* ── ARTISTS ADMIN ── */
.artists-admin-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:1.1rem; }
.artist-admin-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--r); overflow:hidden; transition:border-color .18s; }
.artist-admin-card:hover { border-color:rgba(255,255,255,.12); }
.aac-thumb { aspect-ratio:3/2; overflow:hidden; background:var(--bg2); }
.aac-thumb img { width:100%; height:100%; object-fit:cover; }
.aac-body { padding:1rem; }
.aac-body h4 { font-family:"Fraunces",serif; font-size:1.05rem; margin-bottom:.3rem; }
.aac-body p  { font-size:.8rem; color:var(--soft); margin-bottom:.85rem; line-height:1.5; }
.aac-actions { display:flex; gap:.5rem; flex-wrap:wrap; }
.vis-btn { display:inline-flex; align-items:center; gap:.4rem; min-height:32px; padding:.4rem .8rem; border-radius:999px; font-size:.78rem; font-weight:700; cursor:pointer; border:1px solid; transition:background .18s,color .18s; }
.vis-btn.on  { background:var(--green-gl); border-color:rgba(116,168,122,.25); color:var(--green); }
.vis-btn.off { background:rgba(255,255,255,.04); border-color:var(--border); color:var(--muted); }

/* ── TOAST ── */
.toast-container { position:fixed; bottom:1.5rem; right:1.5rem; display:flex; flex-direction:column; gap:.5rem; z-index:9999; pointer-events:none; }
.toast { display:flex; align-items:center; gap:.55rem; padding:.8rem 1.15rem; border-radius:var(--r-sm); font-weight:600; font-size:.85rem; box-shadow:0 8px 32px rgba(0,0,0,.42); pointer-events:auto; animation:toast-in .35s var(--ease); max-width:340px; }
@keyframes toast-in { from { opacity:0; transform:translateY(12px) scale(.95); } to { opacity:1; transform:none; } }
.toast.out { animation:toast-out .3s ease forwards; }
@keyframes toast-out { to { opacity:0; transform:translateY(10px) scale(.95); } }
.toast.success { background:#182b1a; border:1px solid rgba(116,168,122,.24); color:var(--green); }
.toast.error   { background:#2a1212; border:1px solid rgba(217,107,107,.24); color:#f0a0a0; }

/* ── EMPTY STATE ── */
.empty-state { padding:2.25rem; text-align:center; color:var(--muted); font-size:.88rem; border:2px dashed var(--border); border-radius:var(--r-sm); }

/* ── RESPONSIVE ── */
@media (max-width:900px) {
  .sidebar { transform:translateX(-100%); }
  .sidebar.open { transform:translateX(0); box-shadow:4px 0 40px rgba(0,0,0,.5); }
  .admin-main { margin-left:0; }
  .topbar { display:flex; }
  .tab-section { padding:1.25rem; gap:1rem; }
  .two-col { grid-template-columns:1fr; }
  .form-grid { grid-template-columns:1fr; }
  .profile-layout { grid-template-columns:1fr; }
  .profile-preview { width:140px; height:140px; }
  .news-admin-card { grid-template-columns:60px 1fr; grid-template-rows:auto auto; }
  .na-thumb { width:60px; height:60px; }
  .na-actions { grid-column:1/-1; flex-direction:row; }
  .artists-admin-grid { grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); }
}
@media (max-width:520px) {
  .login-card { padding:1.75rem 1.4rem; border-radius:22px; }
  .tab-section { padding:1rem; }
  .panel { padding:1rem; }
  .news-img-area { flex-direction:column; }
  .drop-zone-news { width:100%; min-height:120px; }
  .news-img-or { writing-mode:initial; }
  .artists-admin-grid { grid-template-columns:1fr; }
}
