/* ============================================================================
 * recetteModeration.css — TripCooking · Admin « Modération des recettes »
 * ----------------------------------------------------------------------------
 * Thème SOMBRE (console) du site, façon tableau de bord admin pro.
 * 100 % CSS : aucun changement de PHP, de JS ni de formulaire. On cible
 * uniquement les classes déjà présentes (tcModo, tcmSide, adminRow…).
 * Responsive inclus. À charger après la feuille globale du site.
 * ========================================================================== */

.tcModo{
  --chrome:#16171B; --chrome-2:#1C1E23; --chrome-3:#23262C; --chrome-4:#2A2D34;
  --line:#2A2D34; --line-2:#363A43;
  --text:#ECEDE9; --text-2:#C2C6CC; --muted:#8A8F98; --muted-2:#6A6F79;
  --accent:#CA4A82; --accent-deep:#B6306B; --accent-2:#E14B7A; --accent-soft:rgba(225,75,122,.12);
  --gold:#E8A93C; --gold-soft:rgba(232,169,60,.14);
  --live:#34D27B; --live-soft:rgba(52,210,123,.14);
  --danger:#F2647B; --danger-soft:rgba(242,100,123,.12);
  --blue:#5BA8F0; --blue-soft:rgba(91,168,240,.12);
  --ui:'Plus Jakarta Sans',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --mono:'IBM Plex Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  --r:16px; --r2:20px; --rsm:12px;
  --sh:0 24px 60px -24px rgba(0,0,0,.7);
  --sh-sm:0 14px 34px -20px rgba(0,0,0,.7);

  display:grid;
  grid-template-columns:248px 1fr;
  gap:24px;
  align-items:start;
  max-width:1480px;
  margin:0 auto;
  padding:84px 24px 64px;   /* 84px = dégagement sous la topbar fixe du site (ajuste si besoin) */
  color:var(--text);
  font-family:var(--ui);
  min-height:100vh;
  background:
    radial-gradient(1100px 560px at 10% -4%, rgba(225,75,122,.10), transparent 60%),
    radial-gradient(900px 520px at 95% 0%, rgba(124,92,255,.08), transparent 55%),
    var(--chrome);
  -webkit-font-smoothing:antialiased;
}
.tcModo *{box-sizing:border-box}
.tcModo a{color:inherit;text-decoration:none}
.tcModo button,.tcModo input,.tcModo select,.tcModo textarea{font:inherit}

/* =========================================================
   SIDEBAR ADMIN
========================================================= */
.tcmSide{
  position:sticky; top:84px;
  background:var(--chrome-2); border:1px solid var(--line); border-radius:var(--r2);
  padding:18px 14px; box-shadow:var(--sh-sm); display:flex; flex-direction:column; gap:6px;
}
.tcmSide__brand{display:flex;align-items:center;gap:11px;padding:6px 8px 14px}
.tcmSide__brand::before{
  content:"A"; width:40px; height:40px; border-radius:12px; display:grid; place-items:center; color:#fff;
  font-weight:800; font-size:16px; background:linear-gradient(135deg,var(--accent-2),var(--accent-deep));
  box-shadow:0 10px 22px -8px rgba(225,75,122,.7);
}
.tcmSide__title{font-size:15px;font-weight:800;letter-spacing:.06em;color:var(--text)}
.tcmSide__nav{margin-top:2px}
.tcmSide__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:3px}
.tcmSide__link{
  display:flex; align-items:center; gap:11px; padding:11px 13px; border-radius:12px;
  color:var(--text-2); font-weight:600; font-size:14.5px; transition:background .14s ease,color .14s ease;
}
.tcmSide__link::before{content:"";width:8px;height:8px;border-radius:3px;background:var(--line-2);flex:0 0 auto;transition:.14s}
.tcmSide__link:hover{background:var(--chrome-3);color:var(--text)}
.tcmSide__link.is-active{
  background:linear-gradient(135deg,var(--accent),var(--accent-deep)); color:#fff; font-weight:800;
  box-shadow:0 12px 26px -10px rgba(182,48,107,.8);
}
.tcmSide__link.is-active::before{background:#fff}
.tcmSide__logout{
  margin-top:auto; height:44px; border-radius:12px; cursor:pointer; font-weight:700; font-size:14px;
  color:var(--danger); background:var(--danger-soft); border:1px solid rgba(242,100,123,.28);
  transition:background .14s ease;
}
.tcmSide__logout:hover{background:rgba(242,100,123,.18)}

/* =========================================================
   PAGE
========================================================= */
.tcmPage{min-width:0;display:flex;flex-direction:column;gap:18px}

/* ----- Top ----- */
.tcmTop{
  background:var(--chrome-2); border:1px solid var(--line); border-radius:var(--r2);
  padding:20px 24px; box-shadow:var(--sh-sm); display:flex; align-items:center; gap:16px; flex-wrap:wrap;
}
.tcmTop__title h1{font-size:24px;font-weight:800;letter-spacing:-.02em}
.tcmTop__title p{color:var(--muted);font-size:13.5px;margin-top:4px}

/* ----- Stats ----- */
.tcmStats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.tcmStat{
  position:relative; overflow:hidden;
  background:var(--chrome-2); border:1px solid var(--line); border-radius:var(--r2);
  padding:18px 18px 18px 20px; box-shadow:var(--sh-sm);
  display:grid; grid-template-columns:1fr auto; align-items:center; gap:6px;
}
.tcmStat::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:4px;background:var(--muted-2)}
.tcmStat__dot{width:10px;height:10px;border-radius:50%;background:var(--muted-2);grid-row:1;justify-self:start}
.tcmStat__label{grid-column:1;color:var(--muted);font-size:13px;font-weight:700}
.tcmStat__value{grid-column:2;grid-row:1 / span 2;font-family:var(--mono);font-size:34px;font-weight:700;color:var(--text);line-height:1}
.tcmStat--pending::before{background:var(--gold)} .tcmStat--pending .tcmStat__dot{background:var(--gold);box-shadow:0 0 0 4px var(--gold-soft)}
.tcmStat--withdraw::before{background:var(--accent-2)} .tcmStat--withdraw .tcmStat__dot{background:var(--accent-2);box-shadow:0 0 0 4px var(--accent-soft)}
.tcmStat--refused::before{background:var(--danger)} .tcmStat--refused .tcmStat__dot{background:var(--danger);box-shadow:0 0 0 4px var(--danger-soft)}

/* ----- Layout main + aside ----- */
.tcmLayout{display:grid;grid-template-columns:1fr 330px;gap:18px;align-items:start}
.tcmMain{min-width:0;display:flex;flex-direction:column;gap:18px}

/* ----- Card ----- */
.tcmCard{
  background:var(--chrome-2); border:1px solid var(--line); border-radius:var(--r2);
  box-shadow:var(--sh-sm); overflow:hidden;
}
.tcmCard__head{
  display:flex; align-items:center; gap:16px; flex-wrap:wrap; justify-content:space-between;
  padding:18px 20px; border-bottom:1px solid var(--line);
}
.tcmCard__head h2{font-size:17px;font-weight:800}
.tcmCard__headRight{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.tcmCard__more{color:var(--accent-2);font-weight:700;font-size:13px}
.tcmCard__more:hover{color:var(--accent)}

/* tabs */
.tcmTabs{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.tcmTab{
  display:inline-flex; align-items:center; gap:8px; height:36px; padding:0 14px; border-radius:11px;
  border:1px solid var(--line); background:var(--chrome); color:var(--muted); font-weight:700; font-size:13px;
  transition:.14s;
}
.tcmTab:hover{color:var(--text);border-color:var(--line-2)}
.tcmTab.is-active{color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent-deep));border-color:transparent;
  box-shadow:0 10px 22px -12px rgba(182,48,107,.9)}
.tcmTab__count{
  font-family:var(--mono); font-size:11px; font-weight:700; color:var(--text-2);
  background:var(--chrome-3); border-radius:999px; padding:2px 8px;
}
.tcmTab.is-active .tcmTab__count{color:#fff;background:rgba(255,255,255,.22)}

/* mini search + autocomplete */
.tcmSearch{position:relative;display:flex;align-items:center;gap:0}
.tcmSearch input[type="search"],.tcModo #recetteSearchInput{
  height:38px; width:230px; border-radius:11px 0 0 11px; border:1px solid var(--line); border-right:none;
  background:var(--chrome); color:var(--text); padding:0 14px; outline:none; font-size:13.5px;
}
.tcmSearch input::placeholder{color:var(--muted-2)}
.tcmSearch input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);position:relative;z-index:1}
.tcmSearch button{
  height:38px; padding:0 14px; border-radius:0 11px 11px 0; cursor:pointer; font-size:16px;
  border:none; color:#fff; background:linear-gradient(135deg,var(--accent-2),var(--accent-deep));
}
.tcmSearch button:hover{filter:brightness(1.07)}
.tcModo .acDropdown{
  position:absolute; top:calc(100% + 8px); left:0; right:0; z-index:40; min-width:260px;
  background:var(--chrome-2); border:1px solid var(--line); border-radius:14px; padding:7px;
  box-shadow:var(--sh); max-height:360px; overflow:auto;
}
.tcModo .acDropdown[hidden]{display:none}
.acDropdown a,.acDropdown .acItem,.acDropdown li,.acDropdown > div{
  display:block; padding:10px 12px; border-radius:10px; color:var(--text-2); font-size:13.5px; cursor:pointer;
}
.acDropdown a:hover,.acDropdown .acItem:hover,.acDropdown li:hover,.acDropdown > div:hover{background:var(--chrome-3);color:#fff}

/* alerts */
.tcmAlert{margin:16px 20px 0;padding:12px 14px;border-radius:12px;font-weight:700;font-size:.9rem;display:flex;align-items:center;gap:9px}
.tcmAlert::before{font-size:1rem}
.tcmAlert--ok{background:var(--live-soft);color:var(--live);border:1px solid rgba(52,210,123,.3)}
.tcmAlert--ok::before{content:"✔"}
.tcmAlert--error{background:var(--danger-soft);color:var(--danger);border:1px solid rgba(242,100,123,.3)}
.tcmAlert--error::before{content:"⚠"}

/* =========================================================
   BULK BAR
========================================================= */
.tcmBulkForm{padding:0}
.tcmBulkBar{
  display:flex; align-items:center; gap:14px; flex-wrap:wrap;
  padding:14px 20px; border-bottom:1px solid var(--line); background:rgba(255,255,255,.02);
}
.tcmBulkStatus{font-size:13px;color:var(--muted);font-weight:600}

.tcmCheck{display:inline-flex;align-items:center;gap:9px;cursor:pointer;font-size:13.5px;font-weight:600;color:var(--text-2)}
.tcmCheck input[type="checkbox"]{width:17px;height:17px;accent-color:var(--accent-2);cursor:pointer}
.tcmCheck--all{font-weight:700;color:var(--text)}

/* boutons admin */
.tcmBtn{
  display:inline-flex; align-items:center; justify-content:center; gap:7px; height:38px; padding:0 14px;
  border-radius:11px; cursor:pointer; font-weight:700; font-size:13px; white-space:nowrap; text-decoration:none;
  background:var(--chrome-3); color:var(--text); border:1px solid var(--line-2);
  transition:transform .12s ease, background .12s ease, border-color .12s ease, filter .12s ease;
}
.tcmBtn:hover{transform:translateY(-1px);border-color:var(--accent);color:#fff}
.tcmBtn--ok{border:none;color:#06231a;background:linear-gradient(135deg,#46e29a,var(--live));box-shadow:0 10px 20px -12px rgba(52,210,123,.7)}
.tcmBtn--ok:hover{color:#06231a;filter:brightness(1.05)}
.tcmBtn--no{color:var(--danger);background:var(--danger-soft);border:1px solid rgba(242,100,123,.3)}
.tcmBtn--no:hover{background:rgba(242,100,123,.18);color:var(--danger)}
.tcmBtn--open{color:var(--accent-2);background:transparent;border:1px solid rgba(225,75,122,.4)}
.tcmBtn--open:hover{background:var(--accent-soft);color:#fff}
.tcModo #bulkSaveAllBtn,.tcmBtn--bulk{border-color:rgba(91,168,240,.4);color:var(--blue);background:var(--blue-soft)}
.tcModo #bulkSaveAllBtn:hover,.tcmBtn--bulk:hover{background:rgba(91,168,240,.2);color:#fff;border-color:var(--blue)}

/* =========================================================
   ROWS
========================================================= */
.tcmRows{display:flex;flex-direction:column}
.tcmEmpty{padding:40px 20px;text-align:center;color:var(--muted);font-weight:600}

.tcModo .adminRow{
  display:grid; grid-template-columns:minmax(240px,1.1fr) minmax(330px,1.5fr) auto; gap:18px;
  padding:18px 20px; border-bottom:1px solid var(--line); align-items:start;
}
.tcmRows .adminRow:last-child{border-bottom:none}
.tcModo .adminRow:hover{background:rgba(225,75,122,.04)}

/* left */
.tcmRow__left{display:flex;gap:14px;min-width:0}
.tcmRow__cover{width:78px;height:78px;border-radius:14px;overflow:hidden;flex:0 0 auto;
  border:1px solid var(--line-2);background:var(--chrome-3);display:block}
.tcmRow__cover img{width:100%;height:100%;object-fit:cover;display:block}
.tcmRow__info{min-width:0;display:flex;flex-direction:column;gap:4px}
.tcmRow__name{font-weight:800;font-size:15.5px;letter-spacing:-.01em;color:var(--text);line-height:1.25}
.tcmRow__name:hover{color:var(--accent-2)}
.tcmRow__meta{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--muted);font-family:var(--mono)}
.tcmDot{color:var(--muted-2)}
.tcmBadge{
  font-family:var(--ui); font-weight:800; font-size:11px; border-radius:999px; padding:3px 10px;
  background:var(--chrome-3); color:var(--text-2);
}
.tcmBadge--pending{background:var(--gold-soft);color:var(--gold)}
.tcmBadge--ok{background:var(--live-soft);color:var(--live)}
.tcmBadge--no{background:var(--danger-soft);color:var(--danger)}
.tcmRow__seoLabel{margin-top:6px;font-size:10.5px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--muted-2)}
.tcmRow__seo{display:flex;align-items:center;gap:8px;min-width:0}
.tcmRow__seoLink{font-family:var(--mono);font-size:12px;color:var(--blue);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tcmRow__seoLink:hover{text-decoration:underline}
.tcmIconBtn{width:28px;height:28px;border-radius:8px;display:grid;place-items:center;flex:0 0 auto;
  background:var(--chrome-3);border:1px solid var(--line-2);color:var(--text-2);font-size:13px}
.tcmIconBtn:hover{border-color:var(--accent);color:#fff}

/* center */
.tcmRow__center{min-width:0;display:flex;flex-direction:column;gap:12px}
.tcmSlug__field{position:relative}
.tcmSlug__input{
  width:100%; height:42px; border-radius:11px; padding:0 13px; font-family:var(--mono); font-size:13px;
  background:var(--chrome-3); border:1px solid var(--line-2); color:var(--text); outline:none;
  transition:border-color .14s ease, box-shadow .14s ease;
}
.tcmSlug__input::placeholder{color:var(--muted-2)}
.tcmSlug__input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.tcmSlug__error{color:var(--danger);font-size:.78rem;font-weight:700;margin-top:5px;min-height:0}
.tcmSlug__error:not(:empty){margin-top:6px}

.tcmRow__actions{display:flex;flex-direction:column;gap:10px}
.tcmRow__actionGroup{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.tcmRow__actionGroup form{margin:0}
.tcmRow__actionGroup--edit{padding-top:2px}
.tcmRow__status,.js-rowStatus{font-size:12px;color:var(--muted);font-weight:600}

/* right */
.tcmRow__right{display:flex;justify-content:flex-end}
.tcmAuthor{display:flex;align-items:center;gap:10px}
.tcmAvatar{
  width:40px; height:40px; border-radius:12px; display:grid; place-items:center; flex:0 0 auto;
  color:#fff; font-weight:800; font-size:15px; text-transform:uppercase;
  background:linear-gradient(135deg,var(--accent),#7C5CFC); box-shadow:0 10px 20px -10px rgba(124,92,255,.7);
}
.tcmAuthor__name{font-weight:700;font-size:13.5px;color:var(--text-2);max-width:140px;line-height:1.3}

/* =========================================================
   ASIDE (Demandes de retrait)
========================================================= */
.tcmAside{display:flex;flex-direction:column;gap:18px;position:sticky;top:84px}
.tcmCard--small .tcmCard__head{padding:16px 18px}
.tcmCard--small .tcmCard__head h2{font-size:15px}
.tcmWithList{display:flex;flex-direction:column}
.tcmWithItem{padding:14px 18px;border-bottom:1px solid var(--line)}
.tcmWithList .tcmWithItem:last-child{border-bottom:none}
.tcmWithItem__title{font-weight:800;font-size:14px;color:var(--text)}
.tcmWithItem__desc{margin-top:4px;font-size:13px;color:var(--text-2);font-style:italic;line-height:1.4}
.tcmWithItem__meta{margin-top:6px;font-family:var(--mono);font-size:11.5px;color:var(--muted)}

/* accès refusé (hors .tcModo) */
.tcmDenied{max-width:680px;margin:120px auto;text-align:center;
  color:#C2C6CC;font-family:'Plus Jakarta Sans',system-ui,sans-serif;font-size:1.1rem}

/* =========================================================
   RESPONSIVE
========================================================= */
@media (max-width:1180px){
  .tcmLayout{grid-template-columns:1fr}
  .tcmAside{position:static;flex-direction:row;flex-wrap:wrap}
  .tcmAside .tcmCard{flex:1 1 280px}
}
@media (max-width:1024px){
  .tcModo{grid-template-columns:212px 1fr;gap:18px}
  .tcModo .adminRow{grid-template-columns:minmax(220px,1fr) minmax(280px,1.3fr);}
  .tcmRow__right{grid-column:1 / -1;justify-content:flex-start;border-top:1px dashed var(--line);padding-top:12px}
}
@media (max-width:880px){
  .tcModo{grid-template-columns:1fr;padding-top:80px}
  .tcmSide{position:static}
  .tcmSide__list{flex-direction:row;flex-wrap:wrap;gap:6px}
  .tcmSide__link{flex:0 0 auto}
  .tcmSide__logout{margin-top:8px}
  .tcmStats{grid-template-columns:1fr}
}
@media (max-width:640px){
  .tcModo{padding:74px 14px 48px}
  .tcmTop{padding:16px 18px}
  .tcmTop__title h1{font-size:21px}
  .tcmCard__head{padding:16px}
  .tcmSearch{width:100%}
  .tcmSearch input[type="search"],.tcModo #recetteSearchInput{width:100%;flex:1}
  .tcModo .adminRow{grid-template-columns:1fr;gap:14px;padding:16px}
  .tcmRow__left{flex-direction:row}
  .tcmRow__actions .tcmBtn{flex:1 1 auto}
}
@media (prefers-reduced-motion:reduce){
  .tcModo *{animation:none !important;transition:none !important}
}