/* ═══════════════════════════════════════════════════════════════
   COLLECTION — Filtres chips modernes
═══════════════════════════════════════════════════════════════ */

.coll-filter-bar {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    background: var(--card-bg);
    border: 1px solid var(--border-color);
    border-radius: 14px;
    margin-bottom: 16px;
    flex-wrap: nowrap;
    overflow-x: auto;
    box-shadow: 0 1px 4px var(--shadow-color);
}
.coll-filter-section {
    display: flex;
    align-items: center;
    gap: 7px;
    flex-wrap: wrap;
}
.coll-filter-section--pub { flex: 1; min-width: 140px; }
.coll-filter-label {
    font-size: .68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .07em;
    color: var(--gray-text);
    white-space: nowrap;
}
.coll-filter-divider {
    width: 1px;
    height: 24px;
    background: var(--border-color);
    flex-shrink: 0;
    opacity: .5;
}
.coll-chips { display: flex; gap: 5px; flex-wrap: wrap; }
.coll-chip {
    padding: 4px 12px;
    border-radius: 99px;
    font-size: .75rem;
    font-weight: 600;
    border: 1px solid var(--border-color);
    background: transparent;
    color: var(--gray-text);
    cursor: pointer;
    transition: all .17s;
    white-space: nowrap;
}
.coll-chip:hover { border-color: var(--primary-color); color: var(--primary-color); }
.coll-chip--active {
    background: var(--primary-color);
    color: #fff;
    border-color: var(--primary-color);
    box-shadow: 0 2px 8px rgba(var(--primary-rgb,99,102,241),.3);
}
.coll-chip--stopped.coll-chip--active { background: #f59e0b; border-color: #f59e0b; }
.coll-pub-select {
    background: var(--input-bg);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    padding: 5px 10px;
    font-size: .78rem;
    color: var(--text-color);
    outline: none;
    cursor: pointer;
    max-width: 160px;
}
.coll-pub-select:focus { border-color: var(--primary-color); }

/* Série arrêtée — effet grisé */
.series-stopped { opacity: .55; filter: grayscale(40%); }
.series-stopped:hover { opacity: .85; filter: none; }

/* ═══════════════════════════════════════════════════════════════
   MODALE AJOUTER SÉRIE — Redesign moderne
═══════════════════════════════════════════════════════════════ */

.sm-label {
    display: block;
    font-size: .72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--gray-text);
    margin-bottom: 5px;
}
.sm-label-hint {
    font-weight: 400;
    text-transform: none;
    letter-spacing: 0;
    font-size: .68rem;
    opacity: .8;
}
.sm-input {
    width: 100%;
    background: var(--input-bg);
    border: 1.5px solid var(--border-color);
    border-radius: 9px;
    padding: 9px 12px;
    font-size: .88rem;
    color: var(--text-color);
    outline: none;
    transition: border-color .2s;
    font-family: inherit;
}
.sm-input:focus { border-color: var(--primary-color); box-shadow: 0 0 0 3px rgba(var(--primary-rgb,99,102,241),.1); }

/* Type chips */
.sm-chips { display: flex; gap: 6px; flex-wrap: wrap; }
.sm-chip {
    padding: 6px 14px;
    border-radius: 99px;
    font-size: .78rem;
    font-weight: 600;
    border: 1.5px solid var(--border-color);
    background: transparent;
    color: var(--gray-text);
    cursor: pointer;
    transition: all .17s;
}
.sm-chip:hover { border-color: var(--primary-color); color: var(--primary-color); }
.sm-chip--active {
    background: var(--primary-color);
    color: #fff;
    border-color: var(--primary-color);
    box-shadow: 0 2px 10px rgba(var(--primary-rgb,99,102,241),.3);
}

/* Pays */
.sm-country-quick {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
}
.sm-country-btn {
    font-size: 1.5rem;
    background: transparent;
    border: 2px solid transparent;
    border-radius: 8px;
    padding: 3px 5px;
    cursor: pointer;
    transition: all .15s;
    line-height: 1;
}
.sm-country-btn:hover { background: var(--hover-bg); transform: scale(1.1); }
.sm-country-btn--active {
    border-color: var(--primary-color);
    background: rgba(var(--primary-rgb,99,102,241),.1);
    transform: scale(1.12);
}
.sm-country-divider {
    width: 1px; height: 28px;
    background: var(--border-color);
    margin: 0 2px;
}
.sm-country-select {
    background: var(--input-bg);
    border: 1.5px solid var(--border-color);
    border-radius: 8px;
    padding: 5px 8px;
    font-size: .78rem;
    color: var(--text-color);
    outline: none;
    cursor: pointer;
    flex: 1;
    min-width: 100px;
}
.sm-country-select:focus { border-color: var(--primary-color); }

/* Actions */
.sm-actions {
    display: flex;
    gap: 8px;
    padding-top: 6px;
}
.sm-btn {
    flex: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 10px 18px;
    border-radius: 10px;
    font-size: .85rem;
    font-weight: 600;
    border: 1.5px solid transparent;
    cursor: pointer;
    transition: all .18s;
}
.sm-btn--save { background: var(--primary-color); color: #fff; }
.sm-btn--save:hover { filter: brightness(1.1); transform: translateY(-1px); }
.sm-btn--cancel { background: transparent; color: var(--gray-text); border-color: var(--border-color); flex: 0 0 auto; }
.sm-btn--cancel:hover { background: var(--hover-bg); }

/* Bouton "Manuel" discret dans le header */
.btn-ghost-subtle {
    background: transparent;
    border: 1px solid var(--border-color);
    color: var(--gray-text);
    border-radius: 8px;
    padding: 6px 10px;
    cursor: pointer;
    font-size: .78rem;
    transition: all .15s;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
.btn-ghost-subtle:hover { background: var(--hover-bg); color: var(--text-color); border-color: var(--primary-color); }

/* Auto-save indicator */
.vi-autosave-indicator {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: .74rem;
    color: var(--gray-text);
    opacity: .6;
    transition: opacity .3s, color .3s;
}
.vi-autosave--saving {
    opacity: 1 !important;
    color: #10b981 !important;
}



/* ── Panel Ajout Tome BDD ── */
.avb-vol-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    cursor: pointer;
    border-radius: 8px;
    padding: 4px;
    transition: background .15s;
}
.avb-vol-card:hover { background: var(--hover-bg); }
.avb-cover-wrap {
    position: relative;
    width: 72px;
    height: 104px;
}
.avb-cover {
    width: 72px;
    height: 104px;
    object-fit: cover;
    border-radius: 6px;
    display: block;
}
.avb-cover--empty {
    background: var(--series-drawer-bg);
    border: 1.5px dashed var(--border-color);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .8rem;
    font-weight: 700;
    color: var(--gray-text);
    border-radius: 6px;
}
.avb-add-overlay {
    position: absolute;
    inset: 0;
    border-radius: 6px;
    background: rgba(0,0,0,.45);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity .18s;
    color: #fff;
    font-size: 1.5rem;
}
.avb-vol-card:hover .avb-add-overlay { opacity: 1; }
.avb-vol-card--owned .avb-cover { filter: brightness(.55) grayscale(.4); }
.avb-vol-card--owned .avb-add-overlay {
    opacity: 1 !important;
    background: rgba(34,197,94,.5);
    color: #fff;
    font-size: 1.8rem;
}
.avb-num {
    font-size: .7rem;
    color: var(--gray-text);
    font-weight: 600;
    text-align: center;
}
.avb-price {
    font-size: .65rem;
    color: var(--primary-color);
    text-align: center;
}

/* ── Carte + pour ajouter un tome manuel ── */
.vol-add-card {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 120px;
    border: 2px dashed var(--border-color);
    border-radius: 8px;
    background: transparent;
    cursor: pointer;
    transition: all .18s;
}
.vol-add-card:hover {
    border-color: var(--primary-color);
    background: rgba(var(--primary-rgb, 99, 102, 241), .06);
}
.vol-add-icon {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    color: var(--gray-text);
    font-size: 1.8rem;
    transition: color .18s;
}
.vol-add-card:hover .vol-add-icon { color: var(--primary-color); }