/* ============================================================================
   StarterPass — Admin « Papier & Pin »
   Interface privée d'administration. Réutilise les variables de app.css.
   Sidebar vert pin, surfaces crème, éditorial. Mobile-first.
   ========================================================================== */

.adm-body { background: var(--paper-2); padding-bottom: 0; }

/* --- Coquille authentifiée (sidebar + main) ------------------------------- */
.adm { min-height: 100vh; }
.adm-main { padding: 22px 18px 60px; max-width: 1080px; margin-inline: auto; }

/* --- Sidebar -------------------------------------------------------------- */
.adm-side {
    position: sticky; top: 0; z-index: 30;
    display: flex; align-items: center; gap: 8px;
    background: var(--pin-800); color: var(--cream);
    padding: 10px 14px; padding-top: calc(10px + var(--safe-top));
    overflow-x: auto; scrollbar-width: none;
}
.adm-side::-webkit-scrollbar { display: none; }
.adm-side__foot { display: contents; }

.adm-brand { display: inline-flex; align-items: baseline; gap: 6px; flex: none; margin-right: 6px; }
.adm-brand:hover { text-decoration: none; }
.adm-brand__name { font-family: var(--serif); font-weight: 600; font-size: 1.15rem; color: var(--cream); letter-spacing: -.02em; }
.adm-brand__tag { font-family: var(--sans); font-size: .62rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--amber); }

.adm-nav { display: flex; gap: 4px; flex: none; }
.adm-nav__link {
    display: inline-flex; align-items: center; gap: 8px; white-space: nowrap;
    padding: 9px 13px; border-radius: 10px; border: 0; background: transparent; cursor: pointer;
    color: color-mix(in srgb, var(--cream) 78%, transparent); font-weight: 600; font-size: .9rem;
    transition: background .15s, color .15s;
}
.adm-nav__link:hover { background: color-mix(in srgb, var(--cream) 12%, transparent); color: var(--cream); text-decoration: none; }
.adm-nav__link.is-active { background: var(--pin); color: var(--cream); }
.adm-nav__ico { display: inline-grid; place-items: center; }
.adm-nav__badge {
    min-width: 19px; height: 19px; padding: 0 5px; border-radius: 999px;
    background: var(--amber); color: #3a2a06; font-size: .7rem; font-weight: 800;
    display: inline-grid; place-items: center;
}
.adm-logout { margin: 0; display: inline-flex; }
.adm-nav__link--btn { font: inherit; font-weight: 600; }

/* --- Bandeaux flash / alertes --------------------------------------------- */
.adm-flash { display: grid; gap: 10px; margin-bottom: 18px; }
.adm-alert { padding: 12px 15px; border-radius: var(--radius-sm); font-size: .92rem; font-weight: 500; border: 1px solid; }
.adm-alert--success { background: color-mix(in srgb, var(--pin) 10%, var(--card)); border-color: color-mix(in srgb, var(--pin) 35%, var(--line)); color: var(--pin-800); }
.adm-alert--error   { background: #fbecec; border-color: #f0c9c9; color: #9a2b2b; }
.adm-alert--info    { background: color-mix(in srgb, var(--amber) 12%, var(--card)); border-color: color-mix(in srgb, var(--amber) 40%, var(--line)); color: var(--amber-600); }

/* --- Titres / en-têtes ---------------------------------------------------- */
.adm-h1 { font-family: var(--serif); font-size: 1.7rem; font-weight: 560; margin: 0; letter-spacing: -.02em; }
.adm-h2 { font-family: var(--serif); font-size: 1.2rem; font-weight: 560; margin: 0; }
.adm-head { display: flex; align-items: center; justify-content: space-between; gap: 14px; margin-bottom: 22px; flex-wrap: wrap; }
.adm-muted { color: var(--ink-soft); }
.adm-link { color: var(--pin); font-weight: 600; font-size: .88rem; }

/* --- Cartes / grilles ----------------------------------------------------- */
.adm-card { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 18px; box-shadow: var(--shadow-sm); }
.adm-card__head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 14px; }
.adm-grid2 { display: grid; grid-template-columns: 1fr; gap: 18px; }

/* --- Statistiques --------------------------------------------------------- */
.adm-stats { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; margin-bottom: 24px; }
.adm-stat { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 16px 18px; box-shadow: var(--shadow-sm); }
.adm-stat--link:hover { border-color: var(--line-strong); text-decoration: none; transform: translateY(-1px); transition: transform .12s; }
.adm-stat--alert { border-color: color-mix(in srgb, var(--amber) 55%, var(--line)); background: color-mix(in srgb, var(--amber) 9%, var(--card)); }
.adm-stat__num { display: block; font-family: var(--serif); font-weight: 560; font-size: 2.1rem; line-height: 1; color: var(--pin); }
.adm-stat--alert .adm-stat__num { color: var(--amber-600); }
.adm-stat__label { display: block; margin-top: 6px; font-size: .82rem; color: var(--ink-soft); font-weight: 600; }

/* --- Listes (dashboard) --------------------------------------------------- */
.adm-list { list-style: none; margin: 0; padding: 0; }
.adm-list__row { border-top: 1px solid var(--line); }
.adm-list__row:first-child { border-top: 0; }
.adm-list__main { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; padding: 11px 2px; color: var(--ink); }
.adm-list__main:hover { text-decoration: none; }
.adm-list__title { font-weight: 600; }
.adm-list__sub { color: var(--ink-soft); font-size: .85rem; flex: 1; min-width: 0; }

/* --- Badges --------------------------------------------------------------- */
.adm-badge { font-size: .7rem; font-weight: 700; padding: 3px 9px; border-radius: 999px; letter-spacing: .02em; }
.adm-badge--ok { background: color-mix(in srgb, var(--pin) 15%, var(--card)); color: var(--pin); }
.adm-badge--muted { background: var(--paper-2); color: var(--ink-soft); }
.adm-badge--alert { background: var(--amber); color: #3a2a06; }

.adm-empty { text-align: center; display: grid; gap: 14px; justify-items: center; padding: 40px 20px; }
.adm-danger { color: #9a2b2b; border-color: transparent; }
.adm-danger:hover { background: #fbecec; border-color: #f0c9c9; }

/* --- Tableaux ------------------------------------------------------------- */
.adm-table-wrap { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow-sm); }
.adm-table { width: 100%; border-collapse: collapse; font-size: .92rem; }
.adm-table th { text-align: left; font-size: .72rem; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-soft); font-weight: 700; padding: 12px 14px; border-bottom: 1px solid var(--line); background: var(--paper-2); }
.adm-table td { padding: 13px 14px; border-bottom: 1px solid var(--line); vertical-align: middle; }
.adm-table tr:last-child td { border-bottom: 0; }
.adm-table tr:hover td { background: color-mix(in srgb, var(--paper-2) 50%, transparent); }
.adm-table__title { font-weight: 600; color: var(--ink); }
.adm-table__title:hover { color: var(--pin); }
.adm-table__lang { font-size: .68rem; font-weight: 700; color: var(--ink-soft); border: 1px solid var(--line-strong); border-radius: 5px; padding: 1px 5px; margin-left: 6px; }
.adm-actions { display: inline-flex; gap: 6px; align-items: center; }

/* --- Formulaires ---------------------------------------------------------- */
.adm-form { display: grid; gap: 16px; }
.adm-field { display: grid; gap: 6px; }
.adm-field > label { font-weight: 650; font-size: .82rem; letter-spacing: .01em; color: var(--ink); }
.adm-input, .adm-field input[type=text], .adm-field input[type=email], .adm-field input[type=password],
.adm-field input[type=date], .adm-field textarea, .adm-field select {
    width: 100%; font-family: var(--sans); font-size: 1rem; color: var(--ink);
    padding: 11px 13px; border: 1.5px solid var(--line-strong); border-radius: var(--radius-sm);
    background: var(--paper); -webkit-appearance: none; appearance: none;
}
.adm-field textarea { line-height: 1.55; resize: vertical; min-height: 80px; }
.adm-field input:focus, .adm-field textarea:focus, .adm-field select:focus, .adm-input:focus {
    outline: none; border-color: var(--pin); box-shadow: 0 0 0 3px rgba(28, 74, 56, .12);
}
.adm-hint { font-size: .78rem; color: var(--ink-soft); margin: 2px 0 0; }
.adm-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }

/* --- Auth (login / setup) ------------------------------------------------- */
.adm-auth { min-height: 100vh; display: grid; place-items: center; padding: 28px 18px; background:
    radial-gradient(60% 50% at 50% 0%, rgba(224,162,43,.14), transparent 70%), var(--paper-2); }
.adm-auth__card { width: 100%; max-width: 400px; background: var(--card); border: 1px solid var(--line); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); padding: 28px 26px; }
.adm-brand--auth { justify-content: center; margin-bottom: 18px; }
.adm-brand--auth .adm-brand__name { color: var(--ink); }
.adm-auth__title { font-family: var(--serif); font-size: 1.5rem; font-weight: 560; margin: 0 0 6px; letter-spacing: -.02em; }
.adm-auth__lead { color: var(--ink-soft); font-size: .92rem; margin: 0 0 20px; }
.adm-auth .btn { margin-top: 4px; }

/* ========================================================================== */
/*  Éditeur d'article                                                         */
/* ========================================================================== */
.adm-editor { display: grid; grid-template-columns: 1fr; gap: 20px; }
.adm-editor__main { display: grid; gap: 18px; }
.adm-editor__side { display: grid; gap: 18px; align-content: start; }

/* Onglets de langue (FR / NL) */
.adm-tabs { display: inline-flex; gap: 4px; background: var(--paper-2); border: 1px solid var(--line); border-radius: 999px; padding: 4px; margin-bottom: 4px; }
.adm-tab { border: 0; background: transparent; padding: 8px 16px; border-radius: 999px; font-weight: 650; font-size: .9rem; color: var(--ink-soft); cursor: pointer; }
.adm-tab.is-active { background: var(--pin); color: var(--cream); }
.adm-pane { display: none; }
.adm-pane.is-active { display: grid; gap: 16px; }

/* Sous-onglets (Contenu / SEO) */
.adm-subtabs { display: flex; gap: 16px; border-bottom: 1.5px solid var(--line); margin-bottom: 2px; }
.adm-subtab { border: 0; background: transparent; padding: 8px 2px; font-weight: 650; font-size: .9rem; color: var(--ink-soft); cursor: pointer; border-bottom: 2px solid transparent; margin-bottom: -1.5px; }
.adm-subtab.is-active { color: var(--pin); border-bottom-color: var(--amber); }
.adm-section { display: none; }
.adm-section.is-active { display: grid; gap: 16px; }

/* Barre d'outils WYSIWYG */
.adm-wysiwyg { border: 1.5px solid var(--line-strong); border-radius: var(--radius-sm); background: var(--paper); overflow: hidden; }
.adm-wysiwyg:focus-within { border-color: var(--pin); box-shadow: 0 0 0 3px rgba(28,74,56,.12); }
.adm-toolbar { display: flex; flex-wrap: wrap; gap: 2px; padding: 6px; background: var(--card); border-bottom: 1px solid var(--line); position: sticky; top: 0; z-index: 2; }
.adm-tool { width: 34px; height: 34px; display: grid; place-items: center; border: 0; background: transparent; border-radius: 8px; cursor: pointer; color: var(--ink-soft); font-weight: 700; font-size: .9rem; }
.adm-tool:hover { background: var(--paper-2); color: var(--ink); }
.adm-tool.is-active { background: var(--pin); color: var(--cream); }
.adm-tool__sep { width: 1px; align-self: stretch; margin: 4px 4px; background: var(--line); }
.adm-content {
    min-height: 320px; max-height: 60vh; overflow-y: auto; padding: 16px 18px;
    font-family: var(--serif); font-size: 1.08rem; line-height: 1.7; color: var(--ink); outline: none;
}
.adm-content:empty::before { content: attr(data-placeholder); color: var(--ink-soft); font-style: italic; }
.adm-content h2 { font-size: 1.5rem; margin: 1em 0 .4em; }
.adm-content h3 { font-size: 1.2rem; margin: 1em 0 .4em; }
.adm-content p { margin: 0 0 .8em; }
.adm-content ul, .adm-content ol { margin: 0 0 .8em; padding-left: 1.4em; }
.adm-content blockquote { margin: 0 0 .8em; padding: 4px 0 4px 16px; border-left: 3px solid var(--amber); color: var(--ink-soft); font-style: italic; }
.adm-content img { border-radius: 10px; margin: 8px 0; }
.adm-content a { color: var(--pin); text-decoration: underline; }

/* Image de couverture */
.adm-imagefield { display: grid; gap: 10px; }
.adm-imagedrop {
    border: 1.5px dashed var(--line-strong); border-radius: var(--radius-sm); background: var(--paper);
    padding: 18px; text-align: center; cursor: pointer; color: var(--ink-soft); font-size: .88rem; font-weight: 600;
}
.adm-imagedrop:hover { border-color: var(--pin); color: var(--pin); }
.adm-imagepreview { position: relative; border-radius: var(--radius-sm); overflow: hidden; border: 1px solid var(--line); }
.adm-imagepreview img { width: 100%; display: block; }
.adm-imagepreview__rm {
    position: absolute; top: 8px; right: 8px; background: rgba(22,21,15,.78); color: #fff;
    border: 0; border-radius: 8px; padding: 6px 10px; font-size: .8rem; font-weight: 600; cursor: pointer;
}
.adm-sticky-actions { position: sticky; bottom: 0; display: flex; gap: 10px; flex-wrap: wrap; padding: 14px 0 0; }

/* ========================================================================== */
/*  Messages (boîte de réception)                                            */
/* ========================================================================== */
.adm-filters { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 18px; }
.adm-filter { padding: 8px 13px; border-radius: 999px; border: 1px solid var(--line-strong); background: var(--card); color: var(--ink-soft); font-weight: 650; font-size: .85rem; }
.adm-filter:hover { text-decoration: none; border-color: var(--ink-soft); color: var(--ink); }
.adm-filter.is-active { background: var(--pin); color: var(--cream); border-color: var(--pin); }
.adm-filter__n { opacity: .7; margin-left: 4px; }

.adm-msg { background: var(--card); border: 1px solid var(--line); border-radius: var(--radius); padding: 18px 20px; box-shadow: var(--shadow-sm); }
.adm-msg__head { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; flex-wrap: wrap; margin-bottom: 12px; }
.adm-msg__from { font-weight: 700; font-size: 1.05rem; }
.adm-msg__email { color: var(--pin); font-size: .9rem; }
.adm-msg__meta { color: var(--ink-soft); font-size: .82rem; }
.adm-msg__subject { font-family: var(--serif); font-size: 1.25rem; margin: 6px 0 10px; }
.adm-msg__body { white-space: pre-wrap; line-height: 1.65; color: var(--ink); background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius-sm); padding: 14px 16px; }
.adm-msg__toolbar { display: flex; gap: 8px; flex-wrap: wrap; margin: 16px 0; align-items: center; }
.adm-msg__toolbar form { display: inline-flex; margin: 0; }

.adm-unread { font-weight: 700; }
.adm-dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; background: var(--amber); margin-right: 6px; vertical-align: middle; }

/* --- Élargissements ------------------------------------------------------- */
@media (min-width: 760px) {
    .adm-grid2 { grid-template-columns: 1fr 1fr; }
    .adm-stats { grid-template-columns: repeat(4, 1fr); }
}
@media (min-width: 960px) {
    .adm { display: grid; grid-template-columns: 248px 1fr; min-height: 100vh; }
    .adm-side {
        position: sticky; top: 0; height: 100vh; flex-direction: column; align-items: stretch;
        gap: 4px; padding: 22px 16px; overflow-y: auto;
    }
    .adm-brand { margin: 0 8px 18px; }
    .adm-nav { flex-direction: column; gap: 2px; }
    .adm-nav__link { width: 100%; }
    .adm-side__foot { display: flex; flex-direction: column; gap: 2px; margin-top: auto; padding-top: 14px; border-top: 1px solid color-mix(in srgb, var(--cream) 14%, transparent); }
    .adm-main { padding: 32px 36px 80px; }
    .adm-editor { grid-template-columns: 1fr 320px; align-items: start; }
    .adm-editor__main { order: 1; }
    .adm-editor__side { order: 2; position: sticky; top: 24px; }
}
