/* ===== MODE TABLATURE - AFFICHAGE ASCII ===== */

/* Zone d'affichage principale */
#tab-display {
    width: 100%;
    margin-top: var(--margin-lg);
    background: var(--fond-clair);
    border: var(--bordure-normale) solid var(--bordure-claire);
    border-radius: var(--rayon-lg);
    padding: var(--padding-xl);
    min-height: 10rem;
    position: relative;
}

/* Info (gamme + box) */
.tab-info {
    font-size: var(--texte-sm);
    font-weight: var(--poids-semi-bold);
    color: var(--couleur-primaire-foncee);
    text-transform: uppercase;
    letter-spacing: 0.03em;
    margin-bottom: var(--margin-md);
    text-align: center;
}

/* Tablature ASCII */
.tab-ascii {
    font-family: 'Courier New', Courier, monospace;
    font-size: var(--texte-base);
    line-height: 1.8;
    color: var(--texte-principal);
    white-space: pre-wrap;
    overflow-x: auto;
    margin: 0;
    padding: 0;
    background: transparent;
}

/* État vide */
#tab-display:empty::after,
#tab-display.empty::after {
    content: attr(data-placeholder);
    color: var(--texte-tertiaire);
    font-size: var(--texte-sm);
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
    pointer-events: none;
}

/* Barre d'actions (bouton copier) */
.tab-actions {
    display: flex;
    justify-content: flex-end;
    margin-top: var(--margin-md);
    margin-right: 2rem;
}

.tab-copy-btn {
    display: flex;
    align-items: center;
    gap: var(--gap-sm);
    height: var(--hauteur-bouton);
    padding: 0 var(--padding-xl);
    background: transparent;
    border: var(--bordure-normale) solid var(--couleur-primaire);
    border-radius: var(--rayon-md);
    color: var(--couleur-primaire);
    font-size: var(--texte-sm);
    font-weight: var(--poids-semi-bold);
    cursor: pointer;
    transition: background-color var(--transition-normale),
                color var(--transition-normale);
}

.tab-copy-btn:hover {
    background: var(--couleur-primaire);
    color: var(--texte-blanc);
}

.tab-copy-btn:disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

.tab-copy-btn.copied {
    background: var(--couleur-primaire-foncee);
    color: var(--texte-blanc);
    border-color: var(--couleur-primaire-foncee);
}

/* Scrollbar personnalisée */
.tab-ascii::-webkit-scrollbar {
    height: var(--margin-xs);
}

.tab-ascii::-webkit-scrollbar-track {
    background: var(--fond-creme);
    border-radius: var(--rayon-sm);
}

.tab-ascii::-webkit-scrollbar-thumb {
    background: var(--couleur-primaire);
    border-radius: var(--rayon-sm);
}

/* Responsive mobile */
@media (max-width: 47.9375rem) {
    #tab-display {
        padding: var(--padding-md);
    }

    .tab-ascii {
        font-size: 0.75rem;
        line-height: 1.7;
    }

    .tab-copy-btn {
        width: 100%;
        justify-content: center;
    }

    .tab-actions {
        justify-content: stretch;
    }
}

/* Préférence mouvement réduit */
@media (prefers-reduced-motion: reduce) {
    .tab-generate-btn,
    .tab-copy-btn {
        transition: none;
        transform: none;
    }
}

/* ========================================
   MODE ACTION BAR
   ======================================== */

.mode-action-bar {
    display: flex;
    align-items: center;
    justify-content: flex-end;
}

.mode-banner-actions {
    display: flex;
    gap: var(--gap-sm);
    align-items: center;
}

.mode-action-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    background: var(--couleur-primaire);
    border: var(--bordure-normale) solid var(--couleur-primaire-foncee);
    border-radius: var(--rayon-md);
    color: var(--texte-blanc);
    font-size: var(--texte-sm);
    cursor: pointer;
    transition: background-color var(--transition-normale),
                border-color var(--transition-normale);
}

.mode-action-btn:hover {
    background: var(--couleur-primaire-foncee);
    border-color: var(--couleur-primaire-foncee);
}

/* ========================================
   MODAL PARAMÈTRES
   ======================================== */

/* ========================================
   BLOCS TABLATURE EMPILÉS
   ======================================== */

.tab-block {
    margin-bottom: var(--margin-xl);
    padding-bottom: var(--padding-xl);
    border-bottom: var(--bordure-fine) solid var(--bordure-claire);
}

.tab-block:last-child {
    border-bottom: none;
    margin-bottom: 0;
}
