/* =============================================================================
   APP.CSS — Thème sombre + composants partagés
   =============================================================================
   Chargé après main.css sur : index.php, dashboard.php, admin.php
   Définit le thème sombre et tous les composants d'interface utilisés
   sur au moins deux de ces trois pages.

   Chargement :
     <link rel="stylesheet" href="assets/css/main.css">
     <link rel="stylesheet" href="assets/css/app.css">

   Conventions de nommage :
     .app-*       → layout structurel global (header, body, nav)
     .tab-nav     → navigation par onglets (partagée)
     .panel       → bloc de contenu générique
     .kpi-*       → cartes de métriques
     .chart-*     → conteneurs Chart.js
     .data-table  → tableaux de données
     .period-bar  → filtre de période
   ============================================================================= */


/* =============================================================================
   1. VARIABLES DU THÈME SOMBRE -> tokens.css
   Étend les tokens de main.css. Toute couleur de surface ou de texte
   spécifique au thème sombre doit être définie ici.
   ============================================================================= */


/* =============================================================================
   GLASS MODE — Activé par body.has-pano-bg (posé par pano-bg.js)
   Remplace les surfaces opaques par leurs équivalents translucides
   pour que le backdrop-filter: blur() du panorama de fond soit visible.
   Transition douce : les surfaces passent en glass progressivement,
   synchronisée avec l'apparition du pano (BG_FADE_DURATION dans pano-bg.js).
   ============================================================================= */

body.has-pano-bg {
}

/* Transition sur tous les éléments portant un background surface */
body.has-pano-bg .app-header,
body.has-pano-bg .burger-menu,
body.has-pano-bg .panel,
body.has-pano-bg .card,
body.has-pano-bg .signin-box .card,
body.has-pano-bg .landing-signin-box,
body.has-pano-bg .tab-nav,
body.has-pano-bg .kpi-card,
body.has-pano-bg .modal-box {
    transition:
        background 1.8s ease,
        border-color 1.8s ease,
        backdrop-filter 1.8s ease;
}

/* ── Header application ── */
body.has-pano-bg .app-header {
    background: var(--surface-glass);
    backdrop-filter: blur(14px) saturate(1.4);
    -webkit-backdrop-filter: blur(14px) saturate(1.4);
    border-bottom-color: var(--border-glass);
}

/* ── Burger menu ── */
body.has-pano-bg .burger-menu {
    background: var(--surface-glass);
    backdrop-filter: blur(18px) saturate(1.3);
    -webkit-backdrop-filter: blur(18px) saturate(1.3);
}

/* ── Panels génériques ── */
body.has-pano-bg .panel {
    background: var(--surface-glass);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-color: var(--border-glass);
}

/* ── Cards (dashboard, signin) ── */
body.has-pano-bg .card,
body.has-pano-bg .signin-box .card {
    background: var(--surface-glass);
    backdrop-filter: blur(16px) saturate(1.2);
    -webkit-backdrop-filter: blur(16px) saturate(1.2);
    border-color: var(--border-glass);
}

/* ── Bloc signin intégré dans la landing ── */
body.has-pano-bg .landing-signin-box {
    background: var(--surface-glass);
    backdrop-filter: blur(16px) saturate(1.2);
    -webkit-backdrop-filter: blur(16px) saturate(1.2);
    border-color: var(--border-glass);
}

/* ── Tab nav ── */
body.has-pano-bg .tab-nav {
    background: var(--surface-2-glass);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border-color: var(--border-glass);
}

/* ── KPI cards ── */
body.has-pano-bg .kpi-card {
    background: var(--surface-2-glass);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border-color: var(--border-glass);
}

/* ── Inputs — légèrement plus opaques pour la lisibilité ── */
body.has-pano-bg .signin-box input[type="text"],
body.has-pano-bg .signin-box input[type="email"],
body.has-pano-bg .signin-box input[type="password"] {
    background: var(--surface-3-glass);
    border-color: var(--border-glass);
}

body.has-pano-bg .signin-box input[type="text"]:focus,
body.has-pano-bg .signin-box input[type="email"]:focus {
    background: rgba(30, 30, 58, 0.85);
}


/* =============================================================================
   2. BASE — Thème sombre
   ============================================================================= */
body {
    background: var(--bg);
    color: var(--text);
}

/* Transition d'apparition douce (utilisée par dashboard.php) */
body.page-ready {
    opacity: 1;
}


/* =============================================================================
   3. HEADER APPLICATION — composant paramétrable (views/common/app_header.php)
   =============================================================================
   Classes HTML produites par le composant (référence exacte) :
     .app-header
       .app-header__brand
         a.app-header__logo-link
           img.app-header__logo
         .app-header__identity
           h1.app-header__title
           p.app-header__greeting
           div.app-header__meta
       .app-header__actions
         a|button.btn.btn-*
           span.app-header__lbl          ← label toujours visible
           span.app-header__lbl--hide    ← label masqué < 600px
         button.app-header__burger
     .burger-overlay
     nav.burger-menu
       .burger-menu__head
         img.burger-menu__logo
         button.burger-menu__close
       .burger-menu__body
         p.burger-section-label
         a|button.burger-item
         a.burger-item.burger-item--accent
         a.burger-item.burger-item--danger
         hr.burger-sep
   ============================================================================= */

/* ── Barre header ── */
.app-header {
    background: linear-gradient(135deg, var(--surface), #16213e);
    border-bottom: 1px solid var(--border);
    padding: 0 28px;
    height: 64px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    position: sticky;
    top: 0;
    z-index: 200;
    backdrop-filter: blur(5px);
}

/* ── Zone gauche ── */
.app-header__brand {
    display: flex;
    align-items: center;
    gap: 20px;          /* décollage logo ↔ identity */
    flex: 1 1 auto;
    min-width: 0;
}

.app-header__logo-link {
    display: flex;
    flex-shrink: 0;
    align-items: center;
    text-decoration: none;
}

/* Taille explicite — doit correspondre aux attributs width/height du <img> */
.app-header__logo {
    width: 110px;
    height: 44px;
    object-fit: contain;
    display: block;
}

.app-header__identity {
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-width: 0;
    gap: 1px;
}

.app-header__title {
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--accent);
    margin: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.app-header__greeting {
    font-size: 0.75rem;
    color: var(--text-sub);
    opacity: 0.65;
    margin: 0;
    line-height: 1.3;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Lien déconnexion — discret, sous le greeting */
.app-header__logout {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    font-size: 0.68rem;
    color: var(--text-dim);
    text-decoration: none;
    margin-top: 1px;
    opacity: 0.55;
    transition: opacity 0.15s, color 0.15s;
    white-space: nowrap;
    line-height: 1.2;
}
.app-header__logout .material-symbols-outlined {
    font-size: 0.85rem;
}
.app-header__logout:hover {
    opacity: 1;
    color: var(--color-danger);
}

.app-header__meta {
    font-size: 0.78rem;
    color: var(--text-dim);
    margin: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* ── Zone droite : actions ── */
.app-header__actions {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
}

/* Label dans les boutons d'action */
.app-header__lbl { display: inline; }

/* Label masqué sur mobile, visible à partir de 600px */
.app-header__lbl--hide               { display: none; }
@media (min-width: 600px) {
    .app-header__lbl--hide            { display: inline; }
}

/* Bouton burger */
.app-header__burger {
    background: none;
    border: 1px solid rgba(255,255,255,.18);
    border-radius: var(--radius-md);
    color: var(--text-sub);
    cursor: pointer;
    padding: 6px 9px;
    display: flex;
    align-items: center;
    transition: background 0.2s, color 0.2s, border-color 0.2s;
    line-height: 1;
}
.app-header__burger:hover {
    background: rgba(255,255,255,.08);
    color: #fff;
    border-color: rgba(255,255,255,.35);
}

/* ── Responsive header ── */
@media (max-width: 768px) {
    .app-header              { padding: 0 16px; height: 56px; }
    .app-header__logo        { width: 88px; height: 36px; }
    .app-header__brand       { gap: 10px; }
}
@media (max-width: 480px) {
    .app-header__actions     { gap: 4px; }
}


/* =============================================================================
   3b. BURGER MENU — Drawer latéral droit
   ============================================================================= */

/* Overlay sombre derrière le drawer */
.burger-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.55);
    z-index: 299;
    animation: fadeIn .2s ease;
}
.burger-overlay.open { display: block; }

/* Drawer */
.burger-menu {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    width: min(300px, 85vw);
    background: var(--surface);
    border-left: 1px solid var(--border);
    z-index: 300;
    display: flex;
    flex-direction: column;
    transform: translateX(100%);
    transition: transform .25s cubic-bezier(.4,0,.2,1);
    box-shadow: -4px 0 24px rgba(0,0,0,.4);
}
.burger-menu.open { transform: translateX(0); }

/* En-tête du drawer */
.burger-menu__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    border-bottom: 1px solid var(--border);
    flex-shrink: 0;
}

.burger-menu__logo {
    width: 90px;
    height: 36px;
    object-fit: contain;
    display: block;
}

.burger-menu__close {
    background: none;
    border: none;
    color: var(--text-muted);
    cursor: pointer;
    padding: 4px;
    display: flex;
    align-items: center;
    border-radius: var(--radius-sm);
    transition: color .15s, background .15s;
}
.burger-menu__close:hover {
    color: var(--text);
    background: rgba(255,255,255,.06);
}

/* Corps du drawer */
.burger-menu__body {
    flex: 1;
    overflow-y: auto;
    padding: 12px 8px 24px;
    scrollbar-width: thin;
    scrollbar-color: var(--border) transparent;
}

/* Label de section */
.burger-section-label {
    font-size: 0.68rem;
    text-transform: uppercase;
    letter-spacing: .07em;
    color: var(--text-dim);
    padding: 12px 12px 4px;
    margin: 0;
    font-weight: 600;
}

/* Élément de menu */
.burger-item {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    padding: 11px 14px;
    border-radius: var(--radius-md);
    background: none;
    border: none;
    color: var(--text-sub);
    font-size: 0.92rem;
    font-family: inherit;
    font-weight: 500;
    cursor: pointer;
    text-decoration: none;
    transition: background .15s, color .15s;
    text-align: left;
}
.burger-item:hover          { background: rgba(255,255,255,.06); color: var(--text); }
.burger-item.active         { background: var(--blue-bg); color: var(--accent); font-weight: 600; }
.burger-item--accent        { color: var(--accent); }
.burger-item--accent:hover  { background: var(--blue-bg); }
.burger-item--danger        { color: var(--color-danger); }
.burger-item--danger:hover  { background: var(--red-bg); }
.burger-item--disabled {display:none}

/* Séparateur */
.burger-sep {
    border: none;
    border-top: 1px solid var(--border);
    margin: 8px 12px;
}


/* =============================================================================
   4. NAVIGATION PAR ONGLETS
   =============================================================================
   Desktop : barre sticky sous le header (top = hauteur header 64px)
   Mobile  : barre fixée en bas de l'écran
   ============================================================================= */

.tab-nav {
    background: var(--surface-2);
    border-bottom: 1px solid var(--border);
    display: flex;
    padding: 0 28px;
    position: sticky;
    top: 64px; /* = hauteur .app-header */
    z-index: 150;
    overflow-x: auto;
    scrollbar-width: none;
}
.tab-nav::-webkit-scrollbar { display: none; }

/* Sur mobile : barre fixée en bas */
@media (max-width: 768px) {
    .tab-nav {
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        top: auto;
        padding: 0;
        border-bottom: none;
        border-top: 1px solid var(--border);
        justify-content: center;
        z-index: 200;
    }
}

/* ── Bouton d'onglet ── */
.tab-nav-btn {
    background: none;
    border: none;
    border-bottom: 3px solid transparent;
    color: var(--text-dim);
    cursor: pointer;
    font-family: inherit;
    font-size: 0.88rem;
    padding: 14px 22px;
    white-space: nowrap;
    transition: color 0.2s, border-color 0.2s;
    display: flex;
    align-items: center;
    gap: 6px;
    text-decoration: none;
}
.tab-nav-btn:hover  { color: var(--accent); background: rgba(255,255,255,.04); }
.tab-nav-btn.active {
    color: var(--accent);
    border-bottom-color: var(--color-primary);
    font-weight: 600;
}

/* Sur mobile : disposition verticale icône + label */
@media (max-width: 768px) {
    .tab-nav-btn {
        flex: 1;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        padding: 8px 4px 10px;
        font-size: 0.7rem;
        gap: 3px;
        border-bottom: none;
        border-top: 3px solid transparent;
    }
    .tab-nav-btn.active {
        border-bottom: none;
        border-top-color: var(--color-primary);
    }
    .tab-nav-btn .material-symbols-outlined {
        font-size: 1.4rem;
    }
}

/* Padding bas du contenu pour ne pas être masqué par la tab-nav mobile */
@media (max-width: 768px) {
    .container { padding-bottom: 72px; }
}


/* =============================================================================
   4b. SOUS-BARRE CONTEXTUELLE (cards-toolbar)
   Visible uniquement sur l'onglet capsules (.visible ajouté par switchTab JS)
   ============================================================================= */
.cards-toolbar {
    display: none;
    align-items: center;
    gap: 10px;
    padding: 10px 28px;
    background: var(--surface-2);
    border-bottom: 1px solid var(--border);
}
.cards-toolbar.visible { display: flex; }

@media (max-width: 768px) {
    .cards-toolbar { padding: 8px 16px; }
}


/* =============================================================================
   5. BODY / LAYOUT
   ============================================================================= */
.app-body {
    padding: 28px;
    max-width: 1400px;
    margin: 0 auto;
}

.app-two-col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}

@media (max-width: 900px) {
    .app-two-col { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
    .app-header { padding: 12px 16px; }
    .tab-nav    { padding: 0 10px; }
    .app-body   { padding: 14px; }
}


/* =============================================================================
   6. PANNEAU GÉNÉRIQUE
   ============================================================================= */
.panel {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    padding: 18px;
    margin-bottom: 18px;
}

.panel__title {
    font-size: 0.9rem;
    color: var(--accent);
    margin-bottom: 14px;
    font-weight: 600;
}

/* Variante grande (ex. profile-card dashboard) */
.panel--lg {
    border-radius: var(--radius-xl);
    padding: 24px;
    box-shadow: var(--shadow-md);
}

.panel--lg h3 {
    margin: 0 0 20px 0;
    font-size: 0.85rem;
    opacity: 0.65;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}


/* =============================================================================
   7. KPI CARDS
   ============================================================================= */
.kpi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 14px;
    margin-bottom: 28px;
}

.kpi-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 18px 16px;
    text-align: center;
    transition: border-color 0.2s, transform 0.2s, box-shadow 0.2s;
}

.kpi-card.highlight {
    border-color: var(--color-primary);
    background: linear-gradient(135deg,
        rgba(102, 126, 234, 0.12),
        rgba(118,  75, 162, 0.08)
    );
}

.kpi-card.clickable { cursor: pointer; }
.kpi-card.clickable:hover {
    border-color: var(--accent);
    transform: translateY(-2px);
    box-shadow: 0 4px 16px rgba(102, 126, 234, 0.2);
}

.kpi-value {
    font-size: 2rem;
    font-weight: 700;
    color: var(--accent);
    line-height: 1;
}

.kpi-label {
    font-size: 0.75rem;
    color: var(--text-dim);
    margin-top: 6px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.kpi-sub  { font-size: 0.7rem;  color: var(--text-dim);    margin-top: 3px; }
.kpi-hint { font-size: 0.65rem; color: var(--color-primary); margin-top: 6px; }


/* =============================================================================
   8. GRAPHIQUES CHART.JS
   ============================================================================= */
.chart-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 20px;
    margin-bottom: 20px;
}

.chart-card__title {
    font-size: 0.88rem;
    color: var(--text-muted);
    margin-bottom: 14px;
    font-weight: 600;
}

.chart-hint {
    font-size: 0.74rem;
    color: var(--text-dim);
    font-weight: 400;
}

.chart-wrap         { position: relative; height: 200px; }
.chart-wrap--tall   { height: 280px; }
.chart-wrap--bar-h  { height: 300px; }


/* =============================================================================
   9. FILTRE DE PÉRIODE
   Barre de sélection de plage de dates (dashboard + admin).
   ============================================================================= */
.period-bar {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 20px 0 12px;
    flex-wrap: wrap;
}

.period-bar__label {
    font-size: 0.82rem;
    color: var(--text-muted);
}

.period-bar__presets {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}

/* Bouton preset de période */
.period-preset {
    background: var(--surface);
    border: 1px solid var(--border);
    color: var(--text-sub);
    border-radius: 20px;
    padding: 5px 14px;
    font-size: 0.82rem;
    cursor: pointer;
    transition: all 0.2s;
    font-family: inherit;
}
.period-preset:hover { border-color: var(--color-primary); color: var(--color-primary); }
.period-preset.active {
    background: var(--color-primary);
    border-color: var(--color-primary);
    color: #fff;
    font-weight: 600;
}

/* Filtres avec date input (admin) */
.period-bar input[type="date"] {
    background: var(--surface-2);
    border: 1px solid var(--border-mid);
    color: var(--text);
    border-radius: var(--radius-sm);
    padding: 6px 10px;
    font-size: 0.82rem;
}
.period-bar input[type="date"]:focus { outline: none; border-color: var(--color-primary); }

/* Bouton appliquer */
.btn-apply {
    background: var(--color-primary);
    color: #fff;
    border: none;
    border-radius: var(--radius-sm);
    padding: 7px 16px;
    cursor: pointer;
    font-size: 0.82rem;
    font-family: inherit;
    transition: filter 0.15s;
}
.btn-apply:hover { filter: brightness(1.15); }


/* =============================================================================
   10. TABLES DE DONNÉES
   ============================================================================= */
.data-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.86rem;
}

.data-table th {
    background: var(--surface-3);
    color: var(--accent);
    padding: 9px 13px;
    text-align: left;
    border-bottom: 2px solid var(--border);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-weight: 600;
}

.data-table td {
    padding: 8px 13px;
    border-bottom: 1px solid var(--surface);
    color: var(--text-sub);
    vertical-align: middle;
}

.data-table tr:last-child td { border-bottom: none; }
.data-table tr:hover td      { background: var(--surface-3); }

/* Colonne vues : valeur + barre de proportion */
.data-views {
    text-align: right;
    white-space: nowrap;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
}

.data-views-bar-wrap {
    flex: 1;
    max-width: 80px;
    height: 6px;
    background: rgba(255, 255, 255, 0.07);
    border-radius: 3px;
    overflow: hidden;
    display: inline-block;
}

.data-views-bar {
    display: block;
    height: 100%;
    background: var(--color-primary);
    border-radius: 3px;
    min-width: 3px;
}

/* Badges de classement */
.rank-badge {
    background: #2a2a4a;
    border-radius: 50%;
    width: 22px;
    height: 22px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.72rem;
    color: var(--accent);
}
.rank-badge.gold   { background: rgba(255, 215,   0, 0.2); color: #ffd700; }
.rank-badge.silver { background: rgba(192, 192, 192, 0.2); color: #c0c0c0; }
.rank-badge.bronze { background: rgba(205, 127,  50, 0.2); color: #cd7f32; }

@media (max-width: 480px) {
    .data-views-bar-wrap { display: none; }
}


/* =============================================================================
   11. GRILLE DE CAPSULES (dashboard)
   ============================================================================= */
.cards-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 24px;
    padding-top: 24px;
}

.card-item {

    border-radius: var(--radius-xl);
    display: flex;
    flex-direction: column;
    gap: 0.5em;
    /*box-shadow: var(--shadow-md);
        background: var(--surface-3);*/
}
.card-thumb-container{
    position: relative;
  overflow: hidden;
  cursor: pointer;
    border-radius: var(--radius-md);
    transition: all 0.2s ease;
}
.card-thumb-container h3{
    position: absolute;
    top: 0;
    left: 0;
    padding: 0.5em;
    font-size: 0.8em;
    font-weight: normal;
    color: white;
    text-shadow: 0 0 5px #000;
    margin: 0;
    background: var(--color-primary-glass);
    border-radius: 0 0 var(--radius-md);
      white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width:50%;
    transition:inherit;
}
.card-thumb-container:hover h3, .card-thumb-container:active h3{
    max-width:100%;
    white-space:unset;
        background: rgba(0, 0, 0, 0.8);
    z-index:9
}
.card-thumb {
    width: 100%;
    display: block;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    transition: inherit;
}
.card-thumb-container:has(.card-thumb--draft) {
        cursor: default;
}
.card-thumb-container .card-thumb--draft {
    filter: grayscale(100%);
    pointer-events: none;
}

.card-thumb-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  background: var(--color-primary-glass);
  padding:2em;
  text-shadow: 0 0 5px #000;
}
.card-thumb-corner{
  position: absolute;
  bottom: 0;
  right: 0;
  width: 56px;
  height: 56px;
  display: flex;
    flex-direction: column;
  align-items: center;
  justify-content: center;
  background: var(--color-primary-glass);
  border-top-left-radius: 75%;
  backdrop-filter: blur(2px);
  pointer-events: none;
  font-size: 1.4em;
  color: white;
  /* 👇 important */
  transform: none;

}
.card-thumb-corner > * {
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  flex-direction: column;
}
.card-thumb-corner.left{
    font-size:0.8em;
    left: 0;
    right: auto;
    border-top-left-radius: 0;
    border-top-right-radius: 75%;
    }

.card-thumb-corner.right span {
        translate: 3px 3px;
}
.card-thumb-corner.left span {
}

  .card-thumb-container:hover .card-thumb-corner, .card-thumb-container:active .card-thumb-corner {
    transform: translate(0, 0);
    background: rgba(0, 0, 0, 0.8);
  }
    .card-thumb-container:hover .card-thumb-corner span, .card-thumb-container:active .card-thumb-corner span {
    color: white;
    scale:1.2
  }

  .card-thumb-container:hover img, .card-thumb-container:active img {
    transform: scale(1.03);
  }



.card-actions {
/*display: flex;
  justify-content: flex-end;
  gap: 10px;*/
  text-align: right;
}
.card-actions a,
.card-actions button { flex: 1; }
.card-actions a,.card-actions .btn {
    background:transparent
}
.card-actions a:hover,
.card-actions .btn:hover {
    scale:1.2;
    transition:inherit
}

/* Miniature dans un tableau */
.card-thumb-mini {
    width: 54px;
    height: 34px;
    object-fit: cover;
    border-radius: 4px;
    border: 1px solid var(--border);
    vertical-align: middle;
}


/* =============================================================================
   12. SECTION PROFIL (dashboard)
   ============================================================================= */
.profile-section {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
    padding-top: 24px;
}

@media (max-width: 768px) {
    .profile-section { grid-template-columns: 1fr; }
}

/* Surcharge formulaire dans un panneau sombre */
.panel .form-group {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-bottom: 16px;
}
.panel .form-group label {
    font-size: 0.85rem;
    opacity: 0.75;
}
.panel .form-group input {
    background: var(--surface-2);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    padding: 9px 12px;
    color: var(--text);
    font-size: 0.95rem;
    width: 100%;
}
.panel .form-group input:focus {
    outline: none;
    border-color: var(--color-primary);
}

/* Panneau changement d'email */
.email-change-panel {
    display: none;
    margin-top: 12px;
    padding: 14px;
    background: var(--surface-2);
    border-radius: var(--radius-md);
    border: 1px solid var(--border);
}
.email-change-panel.visible { display: block; }


/* =============================================================================
   13. BADGES COMPTE ET MENTIONS LÉGALES
   ============================================================================= */

/* Ligne info compte */
.account-info-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 0;
    border-bottom: 1px solid var(--border);
    font-size: 0.88rem;
    gap: 12px;
}
.account-info-row:last-child { border-bottom: none; }
.account-info-label  { opacity: 0.6; flex-shrink: 0; }
.account-info-value  { font-weight: 500; text-align: right; }
.account-info-empty  { opacity: 0.35; }

/* Badges de statut */
.account-badge                 { font-size: 0.78rem; padding: 3px 10px; border-radius: 20px; font-weight: 600; }
.account-badge--active         { background: var(--green-bg);  color: var(--color-success); }
.account-badge--pending        { background: var(--orange-bg); color: var(--color-warning); }
.account-badge--affiliate      { background: var(--blue-bg);   color: var(--color-primary); font-family: monospace; letter-spacing: 0.08em; }

/* Mentions légales */
.legal-item { display: flex; flex-direction: column; gap: 4px; }
.legal-item-header { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.legal-item-title  { font-size: 0.9rem; font-weight: 600; }
.legal-item-date   { font-size: 0.78rem; opacity: 0.55; }

.legal-badge             { font-size: 0.75rem; padding: 2px 8px; border-radius: 20px; font-weight: 600; white-space: nowrap; }
.legal-badge--ok         { background: var(--green-bg);  color: var(--color-success); }
.legal-badge--outdated   { background: var(--orange-bg); color: var(--color-warning); }
.legal-badge--missing    { background: var(--red-bg);    color: var(--color-danger);  }


/* =============================================================================
   14. BARRES DE PROGRESSION (thèmes — admin)
   ============================================================================= */
.theme-bar  { display: flex; align-items: center; gap: 10px; margin-bottom: 9px; }
.theme-name { min-width: 120px; font-size: 0.82rem; color: var(--text-sub); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.theme-track { flex: 1; background: #2a2a4a; border-radius: 4px; height: 18px; }
.theme-fill  { height: 100%; background: linear-gradient(to right, var(--color-primary), var(--color-purple)); border-radius: 4px; display: flex; align-items: center; padding-left: 6px; }
.theme-count { font-size: 0.72rem; color: #fff; font-weight: 600; }


/* =============================================================================
   15. LISTE NOIRE / BLACKLIST (admin)
   ============================================================================= */
.bl-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 9px 13px;
    background: var(--surface-2);
    border-radius: var(--radius-sm);
    margin-bottom: 5px;
}

.bl-domain { font-family: monospace; font-size: 0.88rem; color: #ff9f9f; }

.btn-remove {
    background: var(--red-bg);
    color: var(--color-danger);
    border: 1px solid rgba(255, 107, 107, 0.3);
    border-radius: var(--radius-sm);
    padding: 4px 11px;
    cursor: pointer;
    font-size: 0.78rem;
    font-family: inherit;
    transition: background 0.15s;
}
.btn-remove:hover { background: rgba(255, 107, 107, 0.3); }

.btn-add {
    background: var(--color-primary);
    color: #fff;
    border: none;
    border-radius: var(--radius-sm);
    padding: 7px 16px;
    cursor: pointer;
    font-size: 0.86rem;
    font-family: inherit;
    transition: filter 0.15s;
}
.btn-add:hover { filter: brightness(1.15); }

.domain-input {
    background: var(--surface-2);
    border: 1px solid var(--border-mid);
    color: var(--text);
    border-radius: var(--radius-sm);
    padding: 7px 11px;
    font-size: 0.86rem;
    font-family: inherit;
    flex: 1;
}

/* Feedback inline (blacklist, exports) */
.feedback {
    font-size: 0.8rem;
    padding: 5px 9px;
    border-radius: var(--radius-sm);
    margin-top: 7px;
    display: none;
}
.feedback.success { background: var(--green-bg); color: var(--color-success); }
.feedback.error   { background: var(--red-bg);   color: var(--color-danger);  }


/* =============================================================================
   16. EXPORTS (admin)
   ============================================================================= */
.export-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    padding: 22px;
}

.export-btns { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 14px; }

.btn-export {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 9px 18px;
    border-radius: var(--radius-md);
    font-size: 0.86rem;
    text-decoration: none;
    font-weight: 500;
    border: none;
    cursor: pointer;
    font-family: inherit;
    transition: filter 0.15s;
}
.btn-csv { background: #1e3a1e; color: var(--color-success); border: 1px solid #2d5a2d; }
.btn-csv:hover { filter: brightness(1.2); }
.btn-pdf { background: #3a1e1e; color: #ff9f9f; border: 1px solid #5a2d2d; }
.btn-pdf:hover { filter: brightness(1.2); }


/* =============================================================================
   17. MODALES — SYSTÈME GÉNÉRIQUE SOMBRE
   Système overlay utilisé dans admin (liste utilisateurs, liste capsules…).
   Distinct de .modal (main.css) qui est réservé à l'iframe plein écran.
   ============================================================================= */
.modal-backdrop {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.8);
    align-items: center;
    justify-content: center;
    z-index: 9999;
}
.modal-backdrop.open { display: flex; }

.modal-box {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 26px;
    position: relative;
    max-height: 90vh;
    overflow-y: auto;
    scrollbar-width: thin;
    scrollbar-color: var(--border) transparent;
}
.modal-box::-webkit-scrollbar       { width: 5px; }
.modal-box::-webkit-scrollbar-track { background: transparent; }
.modal-box::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; }

.modal-title {
    font-size: 1rem;
    font-weight: 700;
    color: var(--accent);
    margin-bottom: 16px;
    padding-right: 30px;
}

.modal-kpi-row { display: flex; gap: 12px; margin-bottom: 16px; flex-wrap: wrap; }

.modal-kpi {
    background: var(--surface-2);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    padding: 11px 16px;
    text-align: center;
    flex: 1;
    min-width: 90px;
}
.modal-kpi-val { font-size: 1.5rem; font-weight: 700; color: var(--accent); }
.modal-kpi-lbl { font-size: 0.68rem; color: var(--text-dim); margin-top: 3px; text-transform: uppercase; }

/* Aperçu iframe 16:9 dans une modale */
.preview-iframe-wrap {
    position: relative;
    width: 100%;
    padding-bottom: 56.25%;
    border-radius: var(--radius-md);
    overflow: hidden;
    background: #000;
    margin-top: 4px;
}
.preview-iframe-wrap iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: none; }

.preview-link {
    display: block;
    margin-top: 10px;
    text-align: right;
    color: var(--color-primary);
    font-size: 0.82rem;
    text-decoration: none;
}
.preview-link:hover { color: var(--accent); }

/* Header flex titre + close — modales admin */
.modal-header-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 16px;
}
.modal-header-row .modal-title {
    margin-bottom: 0;
    padding-right: 0;
    flex: 1;
    min-width: 0;
}
.modal-header-row .modal-close {
    flex-shrink: 0;
    background: none;
    border: none;
    color: var(--text-dim);
    cursor: pointer;
    padding: 4px;
    display: flex;
    align-items: center;
    border-radius: var(--radius-sm);
    transition: color .15s, background .15s;
}
.modal-header-row .modal-close:hover {
    color: var(--text);
    background: rgba(255,255,255,.08);
}

/* =============================================================================
   18. TOOLBAR DE LISTE (recherche + tri — admin)
   ============================================================================= */
.list-toolbar {
    display: flex;
    gap: 10px;
    align-items: center;
    margin-bottom: 14px;
    flex-wrap: wrap;
}

.list-search {
    flex: 1;
    min-width: 160px;
    background: var(--surface-2);
    border: 1px solid var(--border-mid);
    color: var(--text);
    border-radius: var(--radius-sm);
    padding: 7px 12px;
    font-size: 0.85rem;
    font-family: inherit;
}
.list-search:focus { outline: none; border-color: var(--color-primary); }

.sort-btn {
    background: #2a2a4a;
    color: var(--accent);
    border: none;
    border-radius: var(--radius-sm);
    padding: 6px 13px;
    cursor: pointer;
    font-size: 0.78rem;
    white-space: nowrap;
    font-family: inherit;
    transition: background 0.15s;
}
.sort-btn.active             { background: var(--color-primary); color: #fff; }
.sort-btn:hover:not(.active) { background: #3a3a6a; }

.list-count { font-size: 0.75rem; color: var(--text-dim); margin-left: auto; }


/* =============================================================================
   19. UTILITAIRES THÈME SOMBRE
   ============================================================================= */
.link-pseudo {
    color: var(--color-primary);
    cursor: pointer;
    background: none;
    border: none;
    font-size: 0.82rem;
    padding: 0;
    font-family: inherit;
    transition: color 0.15s;
}
.link-pseudo:hover { color: var(--accent); text-decoration: underline; }

.app-panel-title {
    font-size: 1.05rem;
    color: var(--accent);
    margin-bottom: 18px;
    font-weight: 600;
}
