/* ============================================================================
   MangaSphere — Blog & Article (dépend de manga-theme.css)
   ========================================================================== */

/* En-tête de page (bandeau) */
.ms-page-head { padding: clamp(2.5rem, 6vw, 4rem) 0 1rem; position: relative; overflow: hidden; }
.ms-page-head::before { content: ""; position: absolute; inset: 0; z-index: -1; background: var(--ms-grad-hero); }
.ms-page-head h1 { font-size: clamp(2rem, 5vw, 3.2rem); margin: .4rem 0 .3rem; }
.ms-page-head h1 .grad { background: var(--ms-grad-brand); -webkit-background-clip: text; background-clip: text; color: transparent; }
.ms-page-head p { color: var(--ms-text-soft); max-width: 56ch; margin: 0; }
.ms-breadcrumb { display: flex; gap: .4rem; align-items: center; color: var(--ms-text-dim); font-size: .85rem; margin-bottom: .6rem; }
.ms-breadcrumb a { color: var(--ms-primary-soft); }

/* Filtres de catégorie */
.ms-filters { display: flex; flex-wrap: wrap; gap: .5rem; margin: 1.4rem 0; }
.ms-chip {
  padding: .45rem .9rem; border-radius: 999px; font-size: .85rem; font-weight: 600;
  background: var(--ms-surface); border: 1px solid var(--ms-border); color: var(--ms-text-soft);
  cursor: pointer; transition: all .2s var(--ms-ease);
}
.ms-chip:hover { border-color: var(--ms-border-strong); color: var(--ms-text); }
.ms-chip.is-active { background: var(--ms-grad-cta); color: #fff; border-color: transparent; }

/* État vide / chargement */
.ms-empty { text-align: center; padding: 3rem 1rem; color: var(--ms-text-dim); }
.ms-empty svg { width: 48px; height: 48px; margin-bottom: 1rem; color: var(--ms-primary-soft); opacity: .7; }
.ms-skeleton { background: linear-gradient(100deg, var(--ms-surface) 30%, var(--ms-surface-2) 50%, var(--ms-surface) 70%); background-size: 200% 100%; animation: ms-shimmer 1.4s infinite; border-radius: var(--ms-radius); }
@keyframes ms-shimmer { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }

/* Pied de carte article : catégorie + temps de lecture */
.ms-post-foot .ms-readtime { display: inline-flex; align-items: center; gap: .3rem; }

/* ---------- Lecture d'un article ---------- */
.ms-article { max-width: 760px; margin-inline: auto; }
.ms-article-cover { width: 100%; aspect-ratio: 21/9; border-radius: var(--ms-radius-lg); overflow: hidden; margin-bottom: 1.6rem; box-shadow: var(--ms-shadow); }
.ms-article-cat { font-size: .76rem; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: var(--ms-action-soft); }
.ms-article h1 { font-size: clamp(1.9rem, 4.5vw, 3rem); margin: .5rem 0 .8rem; line-height: 1.12; }
.ms-article-meta { display: flex; flex-wrap: wrap; gap: 1rem; align-items: center; color: var(--ms-text-dim); font-size: .9rem; padding-bottom: 1.4rem; margin-bottom: 1.6rem; border-bottom: 1px solid var(--ms-border); }
.ms-article-author { display: inline-flex; align-items: center; gap: .5rem; }
.ms-article-author .av { width: 34px; height: 34px; border-radius: 50%; background: var(--ms-grad-brand); display: grid; place-items: center; color: #fff; font-family: "Russo One", sans-serif; font-size: .85rem; }
.ms-article-body { font-size: 1.08rem; line-height: 1.85; color: var(--ms-text); }
.ms-article-body p { margin: 0 0 1.3rem; }
.ms-article-body h2 { font-size: 1.5rem; margin: 2rem 0 .8rem; }
.ms-article-body h3 { font-size: 1.2rem; margin: 1.6rem 0 .6rem; }
.ms-article-body a { color: var(--ms-primary-soft); text-decoration: underline; }
.ms-article-body img { border-radius: var(--ms-radius); margin: 1rem 0; }
.ms-article-body blockquote { margin: 1.4rem 0; padding: .8rem 1.2rem; border-left: 3px solid var(--ms-action); background: var(--ms-surface); border-radius: 0 12px 12px 0; color: var(--ms-text-soft); }
.ms-article-tags { display: flex; flex-wrap: wrap; gap: .4rem; margin-top: 2rem; padding-top: 1.4rem; border-top: 1px solid var(--ms-border); }

/* ---------- Administration du blog ---------- */
.ms-admin { min-height: 100vh; }
.ms-admin-bar { background: var(--ms-surface); border-bottom: 1px solid var(--ms-border); padding: .8rem 0; position: sticky; top: 0; z-index: var(--z-nav); }
.ms-admin-bar .ms-container { display: flex; align-items: center; gap: 1rem; }
.ms-admin-bar .ms-logo { font-size: 1.15rem; }
.ms-admin-bar .badge-admin { font-size: .7rem; font-weight: 700; letter-spacing: 1px; padding: .2rem .55rem; border-radius: 6px; background: rgba(244,63,94,.16); color: var(--ms-action-soft); border: 1px solid rgba(244,63,94,.35); }
.ms-admin-grid { display: grid; grid-template-columns: 1.1fr 1fr; gap: 1.5rem; align-items: start; padding: 1.8rem 0; }
.ms-panel { background: var(--ms-surface); border: 1px solid var(--ms-border); border-radius: var(--ms-radius); padding: 1.3rem; }
.ms-panel h2 { font-size: 1.15rem; margin: 0 0 1rem; display: flex; align-items: center; justify-content: space-between; }

/* Liste admin */
.ms-post-row { display: flex; gap: .9rem; align-items: center; padding: .8rem; border-radius: 12px; border: 1px solid var(--ms-border); margin-bottom: .7rem; transition: border-color .2s; }
.ms-post-row:hover { border-color: var(--ms-border-strong); }
.ms-post-row .thumb { width: 46px; height: 46px; flex: 0 0 46px; border-radius: 10px; }
.ms-post-row .info { flex: 1; min-width: 0; }
.ms-post-row .info b { display: block; font-size: .95rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ms-post-row .info small { color: var(--ms-text-dim); font-size: .78rem; }
.ms-status { font-size: .7rem; font-weight: 700; padding: .15rem .5rem; border-radius: 6px; text-transform: uppercase; letter-spacing: .5px; }
.ms-status.published { background: rgba(52,211,153,.16); color: #34d399; }
.ms-status.draft { background: rgba(251,191,36,.16); color: var(--ms-gold); }
.ms-post-row .acts { display: flex; gap: .35rem; }
.ms-post-row .acts button { width: 34px; height: 34px; border-radius: 9px; border: 1px solid var(--ms-border); background: var(--ms-bg-2); color: var(--ms-text-soft); display: grid; place-items: center; }
.ms-post-row .acts button:hover { color: var(--ms-text); border-color: var(--ms-border-strong); }
.ms-post-row .acts button svg { width: 16px; height: 16px; }
.ms-post-row .acts .danger:hover { color: var(--ms-action-soft); border-color: rgba(244,63,94,.4); }

/* Éditeur */
.ms-editor { display: grid; gap: .9rem; }
.ms-editor textarea { resize: vertical; min-height: 200px; line-height: 1.6; }
.ms-editor .row2 { display: grid; grid-template-columns: 1fr 1fr; gap: .9rem; }
.ms-editor-actions { display: flex; gap: .6rem; flex-wrap: wrap; margin-top: .4rem; }
.ms-count { font-size: .75rem; color: var(--ms-text-dim); text-align: right; }

/* Toast */
.ms-toast { position: fixed; bottom: 1.4rem; left: 50%; transform: translateX(-50%) translateY(120%); background: var(--ms-elevated); border: 1px solid var(--ms-border-strong); color: var(--ms-text); padding: .8rem 1.2rem; border-radius: 12px; box-shadow: var(--ms-shadow); z-index: var(--z-modal); transition: transform .3s var(--ms-ease); font-size: .9rem; }
.ms-toast.is-show { transform: translateX(-50%) translateY(0); }
.ms-toast.ok { border-color: rgba(52,211,153,.5); }
.ms-toast.err { border-color: rgba(244,63,94,.5); }

@media (max-width: 880px) {
  .ms-admin-grid { grid-template-columns: 1fr; }
}
