/* =========================================================
   FAQ — Styles 2025 (public + admin)
   ========================================================= */

/* ---------- PUBLIC ---------- */
.wo-faq { display:flex; flex-direction:column; gap:1rem; margin: 8px 10px 10px 15px;}
.wo-faq__header { display:flex; flex-direction:column; gap:.75rem; }
.wo-faq__filters { display:flex; gap:.75rem; flex-wrap:wrap; align-items:center; }
.wo-faq__filters .input { min-height:42px; }
.wo-faq__search { flex:1 1 260px; }
.wo-faq__select { flex:0 0 220px; }

.wo-faq__accordion { display:flex; flex-direction:column; gap:.6rem; }

.faq-group{
  border:1px solid var(--line);
  border-radius:14px;
  background:var(--surface);
  box-shadow:var(--shadow);
  overflow:hidden;
  transition:transform .2s ease, border-color .2s ease;
}
.faq-group:hover{ transform:translateY(-1px); border-color:rgba(0,0,0,.08); }
.faq-group__header{ display:flex; justify-content:space-between; align-items:center; padding:.95rem 1rem; cursor:pointer; user-select:none; }
.faq-group__title{ margin:0; font-weight:700; letter-spacing:.2px; }
.faq-group__chev{ transform:rotate(0deg); transition:transform .2s ease; font-size:1.05rem; opacity:.7; }
.faq-group.open .faq-group__chev{ transform:rotate(180deg); }
.faq-group__body{ display:none; padding:.25rem 1rem 1rem; }
.faq-group.open .faq-group__body{ display:block; }
.faq-item{ border-top:1px dashed var(--line); padding:.8rem 0; }
.faq-q{ font-weight:700; margin:0 0 .35rem; }
.faq-a{ color:var(--text-2); line-height:1.55; }

/* ---------- ADMIN SHELL ---------- */
.wo-faq-admin .wo-admin-grid{ display:grid; grid-template-columns: 380px 1fr; gap:1rem; }
@media (max-width:1080px){ .wo-faq-admin .wo-admin-grid{ grid-template-columns:1fr; } }

.wo-card{ background:var(--surface); border:1px solid var(--line); border-radius:14px; box-shadow:var(--shadow); }
.wo-card__header{ padding:.95rem 1rem; border-bottom:1px solid var(--line); background:linear-gradient(180deg, rgba(0,0,0,.02), transparent); }
.wo-card__header h2{ margin:0; font-weight:700; }
.wo-card__body{ padding:1rem; }
.wo-card__body > hr{ border:none; height:1px; background:var(--line); opacity:.5; margin:1rem 0; }

/* ---------- FORM LAYOUTS ---------- */
.wo-form .right{ display:flex; justify-content:flex-end; gap:.6rem; }
.wo-form .split{ display:flex; justify-content:space-between; align-items:center; gap:.6rem; }

.form-field{ display:flex; flex-direction:column; gap:.35rem; margin-bottom:.8rem; }
.form-field > label{ font-size:.92rem; color:var(--text-2); }
.w-120{ max-width:140px; }

.form-cols{ display:grid; grid-template-columns: 1fr 140px; gap:.6rem; }
@media (max-width:640px){ .form-cols{ grid-template-columns:1fr; } }

.wo-faq-admin .input{ width:100%; min-height:42px; padding:.6rem .8rem; border:1px solid var(--line); border-radius:10px; background:var(--base); box-shadow:inset 0 1px 0 rgba(0,0,0,.02); transition:border-color .15s ease, box-shadow .15s ease, background .15s ease; }
.wo-faq-admin .input:focus{ outline:none; border-color:#587fbc; box-shadow:0 0 0 3px rgba(88,127,188,.15); background:var(--surface); }

/* boutons */
.btn{ padding:.55rem .9rem; border-radius:10px; border:1px solid var(--line); background:var(--base); cursor:pointer; line-height:1; font-weight:600; transition:transform .12s ease, box-shadow .12s ease, background .12s ease, border-color .12s ease; }
.btn:hover{ transform:translateY(-1px); }
.btn:active{ transform:translateY(0); }
.btn.primary{ background:#587fbc; color:#fff; border-color:#587fbc; box-shadow:0 1px 0 rgba(0,0,0,.05), 0 6px 12px rgba(88,127,188,.15); }
.btn.danger{ background:#ef4444; color:#fff; border-color:#ef4444; box-shadow:0 1px 0 rgba(0,0,0,.05), 0 6px 12px rgba(239,68,68,.15); }
.btn.ghost{ background:transparent; border-color:#cfd6e4; }
.btn.small{ padding:.45rem .7rem; border-radius:999px; }

/* ---------- GROUPES (accordéons) ---------- */
.wo-qgroup{ border:1px solid var(--line); border-radius:14px; margin-bottom:1rem; overflow:hidden; background:var(--surface); }
.wo-qgroup__header{ display:flex; align-items:center; justify-content:space-between; gap:1rem; padding:.9rem 1rem; cursor:pointer; background:linear-gradient(180deg, rgba(0,0,0,.02), transparent); }
.wo-qgroup__title{ display:flex; align-items:center; gap:.6rem; }
.wo-qgroup__badge{ display:inline-flex; align-items:center; gap:.25rem; font-size:.85rem; padding:.25rem .5rem; border:1px solid var(--line); border-radius:999px; color:var(--text-2); background:var(--base); }
.wo-qgroup__actions{ display:flex; align-items:center; gap:.6rem; }
.wo-qgroup .chev{ opacity:.65; }
.wo-qgroup__body{ padding:1rem; }
.wo-qgroup__body[hidden]{ display:none; }

/* ---------- CARTE FAQ (édit) ---------- */
.wo-faq-card{ padding:1rem; border:1px solid var(--line); border-radius:12px; background:linear-gradient(180deg, rgba(0,0,0,.02), transparent); margin-bottom:1rem; }
.wo-faq-card:hover{ border-color:rgba(0,0,0,.12); }
.wo-form.faq-item:focus-within .wo-faq-card{ border-color:#587fbc; box-shadow:0 0 0 3px rgba(88,127,188,.12); }

/* meta ligne (catégorie/position/publiée) */
.form-meta{ display:grid; grid-template-columns: 1fr 140px 160px; gap:.6rem; margin: .2rem 0 .8rem; }
@media (max-width:880px){ .form-meta{ grid-template-columns:1fr; } }
.meta-field{ display:flex; flex-direction:column; gap:.35rem; }
.meta-field > label{ font-size:.92rem; color:var(--text-2); }

/* toggle publiée */
.toggle{ display:inline-flex; align-items:center; gap:.5rem; }
.toggle input{ width:18px; height:18px; }

/* WYSIWYG */
.wys-toolbar{ display:flex; gap:.5rem; flex-wrap:wrap; margin-bottom:.5rem; }
.wys-toolbar button{ min-width:36px; height:36px; padding:.35rem .6rem; border:1px solid var(--line); border-radius:9px; background:var(--surface); cursor:pointer; font-weight:700; transition:background .12s ease, border-color .12s ease, transform .12s ease; }
.wys-toolbar button:hover{ background:rgba(0,0,0,.03); transform:translateY(-1px); }

.wys-area{ min-height:160px; border:1px solid var(--line); border-radius:10px; padding:.75rem .85rem; background:var(--surface); line-height:1.55; }
.wys-area:focus{ outline:none; border-color:#587fbc; box-shadow:0 0 0 3px rgba(88,127,188,.15); }
.hidden{ display:none; }

/* flashes */
.wo-flashes{ display:flex; flex-direction:column; gap:.5rem; margin:.75rem 0 1rem; }
.flash{ padding:.6rem .8rem; border-radius:10px; border:1px solid var(--line); background:var(--base); }
.flash.success{ border-color:#16a34a; background:rgba(22,163,74,.08); }
.flash.error{ border-color:#ef4444; background:rgba(239,68,68,.08); }

/* --- Hero FAQ (Mia) --- */
.wo-hero{
  margin: .25rem 0 1rem;
  text-align:center;
}
.wo-hero__img{
  max-width: 300px;
  width: 100%;
  height: auto;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(0,0,0,.1);
}
.wo-hero__caption{
  margin-top: 8px;
  font-size: .95rem;
  color: var(--text-2);
}
@media (min-width: 992px){
  .wo-hero__img{ max-width: 300px; }
}
