/* =========================================================
   ADMIN RECETTES — CSS (responsive)
   ========================================================= */

/* ---------- Reset léger ---------- */
*,
*::before,
*::after { box-sizing: border-box; }

html, body { height: 100%; }

body {
  margin: 0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color: #241b35;
  background: radial-gradient(1200px 800px at 20% 10%, #efe9ff 0%, transparent 60%),
              radial-gradient(900px 700px at 90% 10%, #e7ddff 0%, transparent 50%),
              linear-gradient(180deg, #f6f1ff 0%, #f5f3ff 100%);
}

/* ---------- Variables ---------- */
:root{
  --purple-50:#f6f1ff;
  --purple-100:#efe7ff;
  --purple-200:#e3d7ff;
  --purple-300:#c9b5ff;
  --purple-400:#a586ff;
  --purple-500:#7c4dff;
  --purple-600:#6a35ff;

  --ink:#241b35;
  --muted:#6e6682;

  --card:#ffffffcc;      /* blanc translucide */
  --card-strong:#ffffff;
  --line:#e8ddff;

  --shadow: 0 18px 60px rgba(30, 10, 70, .08);
  --shadow-soft: 0 10px 30px rgba(30, 10, 70, .08);

  --radius-xl: 24px;
  --radius-lg: 18px;
  --radius-md: 14px;
  --radius-sm: 10px;

  --gap: 18px;

  --ok:#24a163;
  --no:#f35b78;

  --pending:#7c4dff;
  --withdraw:#f0b74a;
  --refused:#f35b78;
}

/* =========================================================
   SIDEBAR (version "menu texte" existant)
   ========================================================= */
.adminShell{
  min-height: 100vh;
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 0;
}

.adminSidebar{
  position: sticky;
  top: 0;
  height: 100vh;
  padding: 18px 14px;
  border-right: 1px solid rgba(140, 110, 255, .25);
  background: linear-gradient(180deg, rgba(255,255,255,.55) 0%, rgba(255,255,255,.25) 100%);
  backdrop-filter: blur(10px);
}

.adminSidebar__brand{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 10px 12px 18px;
}

.adminSidebar__title{
  margin: 0;
  font-size: 14px;
  letter-spacing: .14em;
  color: rgba(64, 35, 140, .85);
}

.adminSidebar__nav{ margin-top: 6px; }

.adminSidebar__list{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  flex-direction:column;
  gap: 8px;
}

.adminSidebar__link{
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 12px 12px;
  border-radius: 14px;
  text-decoration:none;
  color: rgba(36, 27, 53, .82);
  background: transparent;
  transition: .2s ease;
}

.adminSidebar__link:hover{
  background: rgba(124, 77, 255, .10);
  color: rgba(36, 27, 53, 1);
}

.adminSidebar__link.is-active{
  background: linear-gradient(90deg, rgba(124,77,255,.22), rgba(124,77,255,.10));
  color: rgba(36, 27, 53, 1);
  box-shadow: 0 8px 22px rgba(124,77,255,.12);
}

.adminSidebar__logout{
  width:100%;
  margin-top: 18px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(124,77,255,.25);
  background: rgba(255,255,255,.45);
  color: rgba(36,27,53,.9);
  cursor:pointer;
  transition: .2s ease;
}
.adminSidebar__logout:hover{
  background: rgba(124,77,255,.10);
}

/* =========================================================
   PAGE / TOP
   ========================================================= */
.adminPage{
  padding: 26px 26px 30px;
}

.adminTop{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap: 16px;
  margin-bottom: 18px;
}

.adminTop__title h1{
  margin: 0;
  font-size: 32px;
  letter-spacing: -0.02em;
}
.adminTop__title p{
  margin: 6px 0 0;
  color: var(--muted);
  font-size: 14px;
}

.adminTop__search{
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 10px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.55);
  border: 1px solid rgba(124,77,255,.20);
  box-shadow: var(--shadow-soft);
  backdrop-filter: blur(10px);
  min-width: 420px;
}

.adminTop__search input{
  width: 100%;
  border: 0;
  outline: none;
  font-size: 14px;
  background: transparent;
  color: var(--ink);
}
.adminTop__search input::placeholder{ color: rgba(110,102,130,.8); }

.adminTop__search button{
  border: 0;
  cursor: pointer;
  padding: 10px 16px;
  border-radius: 999px;
  background: linear-gradient(180deg, var(--purple-500), var(--purple-600));
  color: white;
  font-weight: 700;
  box-shadow: 0 10px 24px rgba(124,77,255,.25);
  transition: transform .15s ease;
}
.adminTop__search button:hover{ transform: translateY(-1px); }

/* =========================================================
   STATS (pills)
   ========================================================= */
.adminStats{
  display:flex;
  gap: 14px;
  flex-wrap: wrap;
  margin: 10px 0 18px;
}

.adminStat{
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 12px 16px;
  border-radius: 999px;
  background: rgba(255,255,255,.55);
  border: 1px solid rgba(124,77,255,.16);
  box-shadow: var(--shadow-soft);
  backdrop-filter: blur(10px);
}

.adminStat__dot{
  width: 10px;
  height: 10px;
  border-radius: 99px;
  background: var(--pending);
  box-shadow: 0 0 0 4px rgba(124,77,255,.12);
}

.adminStat--withdraw .adminStat__dot{
  background: var(--withdraw);
  box-shadow: 0 0 0 4px rgba(240,183,74,.18);
}
.adminStat--refused .adminStat__dot{
  background: var(--refused);
  box-shadow: 0 0 0 4px rgba(243,91,120,.18);
}

.adminStat__label{
  font-weight: 650;
  color: rgba(36,27,53,.85);
  font-size: 14px;
}
.adminStat__value{
  font-weight: 800;
  color: rgba(36,27,53,1);
  padding-left: 2px;
}

/* =========================================================
   LAYOUT (main + aside)
   ========================================================= */
.adminLayout{
  display:grid;
  grid-template-columns: 1fr 340px;
  gap: var(--gap);
  align-items:start;
}

/* =========================================================
   CARD
   ========================================================= */
.adminCard{
  background: var(--card);
  border: 1px solid rgba(124,77,255,.16);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow);
  backdrop-filter: blur(12px);
  overflow: hidden;
}

.adminCard__head{
  padding: 18px 18px 12px;
  display:flex;
  flex-direction:column;
  gap: 10px;
}

.adminCard__headLeft h2{
  margin:0;
  font-size: 18px;
  letter-spacing: -0.01em;
}

.adminCard__headRight{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
}

.adminTabs{
  display:flex;
  gap: 10px;
  background: rgba(124,77,255,.08);
  border: 1px solid rgba(124,77,255,.16);
  padding: 6px;
  border-radius: 999px;
}

.adminTab{
  display:flex;
  align-items:center;
  gap: 10px;
  text-decoration:none;
  padding: 10px 12px;
  border-radius: 999px;
  color: rgba(36,27,53,.78);
  font-weight: 700;
  transition: .2s ease;
}
.adminTab:hover{ background: rgba(255,255,255,.55); }

.adminTab.is-active{
  background: linear-gradient(180deg, rgba(124,77,255,.22), rgba(124,77,255,.12));
  color: rgba(36,27,53,1);
  box-shadow: 0 8px 20px rgba(124,77,255,.14);
}

.adminTab__count{
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.65);
  border: 1px solid rgba(124,77,255,.18);
  font-weight: 800;
  font-size: 12px;
}

/* mini search à droite */
.adminMiniSearch{
  display:flex;
  align-items:center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.55);
  border: 1px solid rgba(124,77,255,.16);
}
.adminMiniSearch input{
  border:0;
  outline:0;
  background: transparent;
  width: 220px;
  font-size: 13px;
}
.adminMiniSearch button{
  border:0;
  cursor:pointer;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  background: rgba(124,77,255,.16);
  color: rgba(36,27,53,.9);
}
.adminMiniSearch button:hover{
  background: rgba(124,77,255,.22);
}

/* =========================================================
   LISTE / ROWS
   ========================================================= */
.adminRows{
  padding: 10px 14px 16px;
  display:flex;
  flex-direction:column;
  gap: 12px;
}

.adminEmpty{
  padding: 26px 14px;
  color: var(--muted);
}

.adminRow{
  display:grid;
  grid-template-columns: 1.2fr 1.5fr 220px;
  gap: 14px;
  padding: 14px;
  border-radius: var(--radius-lg);
  background: rgba(255,255,255,.70);
  border: 1px solid rgba(124,77,255,.12);
  box-shadow: 0 10px 24px rgba(30, 10, 70, .06);
}

.adminRow__left{
  display:flex;
  gap: 12px;
  min-width: 0;
}

.adminRow__cover{
  width: 64px;
  height: 64px;
  border-radius: 14px;
  overflow:hidden;
  flex: 0 0 auto;
  border: 1px solid rgba(124,77,255,.18);
  background: rgba(124,77,255,.06);
}
.adminRow__cover img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
}

.adminRow__info{
  min-width: 0;
  display:flex;
  flex-direction:column;
  gap: 6px;
}

.adminRow__name{
  font-weight: 900;
  color: rgba(36,27,53,1);
  text-decoration:none;
  display: inline-block;
  max-width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.adminRow__name:hover{ text-decoration: underline; }

.adminRow__meta{
  display:flex;
  align-items:center;
  gap: 8px;
  font-size: 12px;
  color: rgba(110,102,130,.95);
}

.adminDot{ opacity:.7; }

.adminBadge{
  font-size: 12px;
  font-weight: 800;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(124,77,255,.12);
  border: 1px solid rgba(124,77,255,.20);
  color: rgba(64,35,140,.9);
}

.adminRow__seoLabel{
  margin-top: 4px;
  font-size: 12px;
  font-weight: 750;
  color: rgba(110,102,130,.85);
}

.adminRow__seo{
  display:flex;
  align-items:center;
  gap: 10px;
  min-width: 0;
}

.adminRow__seoLink{
  font-size: 13px;
  color: rgba(64,35,140,.95);
  text-decoration:none;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.70);
  border: 1px solid rgba(124,77,255,.16);
  max-width: 100%;
  overflow:hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.adminRow__seoLink:hover{ background: rgba(124,77,255,.10); }

.adminIconBtn{
  width: 34px;
  height: 34px;
  border-radius: 999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  border: 1px solid rgba(124,77,255,.18);
  background: rgba(124,77,255,.10);
  color: rgba(36,27,53,.95);
}
.adminIconBtn:hover{ background: rgba(124,77,255,.16); }

/* center */
.adminRow__center{
  display:flex;
  flex-direction:column;
  gap: 10px;
  min-width: 0;
}

.adminSlugEdit{
  display:flex;
  align-items:center;
  gap: 10px;
}

.adminSlugEdit input{
  flex: 1 1 auto;
  min-width: 0;
  border: 1px solid rgba(124,77,255,.18);
  background: rgba(255,255,255,.70);
  border-radius: 999px;
  padding: 10px 12px;
  outline: none;
  font-size: 13px;
}
.adminSlugEdit input:focus{
  border-color: rgba(124,77,255,.45);
  box-shadow: 0 0 0 4px rgba(124,77,255,.12);
}

.adminSlugEdit button{
  border:0;
  cursor:pointer;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(124,77,255,.16);
  color: rgba(36,27,53,.92);
  font-weight: 800;
}
.adminSlugEdit button:hover{
  background: rgba(124,77,255,.22);
}

.adminRow__actions{
  display:flex;
  flex-wrap: wrap;
  gap: 10px;
}

.adminBtn{
  border: 1px solid rgba(124,77,255,.18);
  background: rgba(255,255,255,.70);
  padding: 10px 12px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 800;
  color: rgba(36,27,53,.92);
  text-decoration:none;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap: 8px;
  transition: .2s ease;
}
.adminBtn:hover{
  background: rgba(124,77,255,.10);
}

.adminBtn--ok{
  border-color: rgba(36,161,99,.25);
  background: rgba(36,161,99,.10);
}
.adminBtn--ok:hover{ background: rgba(36,161,99,.14); }

.adminBtn--no{
  border-color: rgba(243,91,120,.25);
  background: rgba(243,91,120,.10);
}
.adminBtn--no:hover{ background: rgba(243,91,120,.14); }

.adminBtn--open{
  border-color: rgba(124,77,255,.24);
  background: linear-gradient(180deg, rgba(124,77,255,.22), rgba(124,77,255,.12));
}

/* right */
.adminRow__right{
  display:flex;
  align-items:center;
  justify-content:flex-end;
}

.adminAuthor{
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 999px;
  border: 1px solid rgba(124,77,255,.16);
  background: rgba(255,255,255,.70);
}

.adminAvatar{
  width: 36px;
  height: 36px;
  border-radius: 999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-weight: 900;
  color: white;
  background: linear-gradient(180deg, var(--purple-500), var(--purple-600));
  box-shadow: 0 10px 24px rgba(124,77,255,.25);
}
.adminAuthor__name{
  font-weight: 850;
  max-width: 120px;
  white-space: nowrap;
  overflow:hidden;
  text-overflow: ellipsis;
}

/* =========================================================
   ASIDE — DemandES de retrait
   ========================================================= */
.adminCard--small .adminCard__head{
  padding: 18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-direction:row;
}

.adminCard__more{
  text-decoration:none;
  font-weight: 850;
  color: rgba(124,77,255,.95);
}
.adminCard__more:hover{ text-decoration: underline; }

.withdrawList{
  padding: 0 14px 16px;
  display:flex;
  flex-direction:column;
  gap: 12px;
}

.withdrawItem{
  padding: 14px;
  border-radius: var(--radius-lg);
  background: rgba(255,255,255,.70);
  border: 1px solid rgba(124,77,255,.12);
  box-shadow: 0 10px 24px rgba(30, 10, 70, .06);
}

.withdrawItem__title{
  font-weight: 950;
  margin-bottom: 6px;
}
.withdrawItem__desc{
  color: rgba(110,102,130,.95);
  font-size: 13px;
  margin-bottom: 8px;
  line-height: 1.35;
}
.withdrawItem__meta{
  color: rgba(110,102,130,.85);
  font-size: 12px;
}

/* =========================================================
   RESPONSIVE
   ========================================================= */

/* --- <= 1200px : aside passe sous le main (ou réduit) --- */
@media (max-width: 1200px){
  .adminLayout{
    grid-template-columns: 1fr;
  }
  .adminAside{
    order: 2;
  }
  .adminTop__search{
    min-width: 360px;
  }
}

/* --- <= 980px : sidebar rétrécie, row en 2 blocs --- */
@media (max-width: 980px){
  .adminShell{
    grid-template-columns: 90px 1fr;
  }

  .adminSidebar{
    padding: 14px 10px;
  }
  .adminSidebar__brand{
    padding: 8px 8px 12px;
    justify-content:center;
  }
  .adminSidebar__title{
    font-size: 12px;
    letter-spacing: .12em;
  }

  /* navigation: garde le look mais plus compact */
  .adminSidebar__link{
    padding: 12px 10px;
    justify-content:center;
    text-align:center;
  }

  .adminPage{
    padding: 20px 16px 24px;
  }

  .adminTop{
    flex-direction: column;
    align-items: stretch;
  }
  .adminTop__search{
    min-width: unset;
    width: 100%;
  }

  .adminRow{
    grid-template-columns: 1fr;
  }
  .adminRow__right{
    justify-content:flex-start;
  }
  .adminMiniSearch input{
    width: 180px;
  }
}

/* --- <= 640px : mobile (tout en colonne, tabs scroll) --- */
@media (max-width: 640px){
  .adminShell{
    grid-template-columns: 1fr;
  }

  .adminSidebar{
    position: relative;
    height: auto;
    border-right: 0;
    border-bottom: 1px solid rgba(124,77,255,.20);
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap: 10px;
  }
  .adminSidebar__nav{
    flex: 1;
  }
  .adminSidebar__list{
    flex-direction: row;
    overflow-x: auto;
    padding-bottom: 6px;
    gap: 8px;
  }
  .adminSidebar__item{ flex: 0 0 auto; }
  .adminSidebar__logout{
    width: auto;
    margin-top: 0;
    white-space: nowrap;
  }

  .adminTop__title h1{ font-size: 26px; }

  .adminStats{
    gap: 10px;
  }
  .adminStat{
    width: 100%;
    justify-content:space-between;
  }

  .adminCard__headRight{
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
  }

  .adminTabs{
    overflow-x: auto;
    white-space: nowrap;
  }

  .adminMiniSearch{
    width: 100%;
  }
  .adminMiniSearch input{
    width: 100%;
  }

  .adminRow{
    padding: 12px;
  }
  .adminRow__left{
    align-items:flex-start;
  }
  .adminRow__cover{
    width: 56px;
    height: 56px;
  }
  .adminRow__actions{
    gap: 8px;
  }
  .adminBtn{
    width: 100%;
    justify-content:center;
  }
/* --- Slug form states --- */
.adminSlugEdit { display:flex; align-items:center; gap:10px; }
.adminSlugEdit__field { flex: 1 1 auto; min-width: 0; }
.adminSlugEdit__input { width:100%; }

/* message d'erreur */
.adminSlugEdit__error{
  display:none;
  margin-top:6px;
  font-size:12px;
  font-weight:700;
  color:#f35b78;
}

/* état erreur sur le form (à toggle en JS) */
.adminSlugEdit.is-error .adminSlugEdit__input{
  border-color: rgba(243,91,120,.55);
  box-shadow: 0 0 0 4px rgba(243,91,120,.14);
}
.adminSlugEdit.is-error .adminSlugEdit__error{ display:block; }

/* loader bouton */
.adminSlugEdit__btn{ position:relative; }
.adminSlugEdit__loader{
  display:none;
  width:16px;
  height:16px;
  border-radius:999px;
  border:2px solid rgba(36,27,53,.25);
  border-top-color: rgba(36,27,53,.9);
  animation: adminSpin .8s linear infinite;
  margin-left:10px;
}

/* état loading sur le form (à toggle en JS) */
.adminSlugEdit.is-loading .adminSlugEdit__btn{ opacity:.8; pointer-events:none; }
.adminSlugEdit.is-loading .adminSlugEdit__loader{ display:inline-block; }

@keyframes adminSpin{ to { transform: rotate(360deg); } }

.adminMiniSearch { position: relative; }

.acDropdown{
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  right: 0;
  background: #fff;
  border: 1px solid rgba(0,0,0,.12);
  border-radius: 12px;
  box-shadow: 0 10px 25px rgba(0,0,0,.12);
  overflow: hidden;
  z-index: 50;
}

.acItem{
  padding: 10px 12px;
  cursor: pointer;
}

.acItem:hover,
.acItem.is-active{
  background: rgba(0,0,0,.06);
}

.acTitle{ font-weight: 600; }
.acMeta{ font-size: 12px; opacity: .75; margin-top: 2px; }

/* --- Accessibilité : focus visible --- */
:focus-visible{
  outline: 3px solid rgba(124,77,255,.35);
  outline-offset: 2px;
}

/* --- Préfère réduire les animations --- */
@media (prefers-reduced-motion: reduce){
  *{ scroll-behavior: auto !important; transition: none !important; }
}
