/*
*****************************************************************************************************
 *  Fichier : custom-deco-carte-visite.css
 *  👉 Styles propres au composant carte-de-visite
 *  🔁 Modification du fichier custom-deco-carte-visite.css pour la version 6.3.3 horodatée 20260529-1629
 *  	✅ Ajout du mode "multi-oeuvres/artistes" nécessaire pour l'étape 1 de création commande
*****************************************************************************************************
*/

/* ==========================================================================
   Base composant (agnostique)
   ========================================================================== */

.cd-visitcard {
    box-sizing: border-box;
}

.cd-visitcard *,
.cd-visitcard *::before,
.cd-visitcard *::after {
    box-sizing: border-box;
}

.cd-visitcard__panel {
    background: #fffdf8;
    border-radius: 18px;
    box-shadow: 0 18px 38px rgba(0, 0, 0, 0.55);
    padding: 18px 20px 20px 20px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    overflow: hidden;
}

.cd-visitcard__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 4px;
}

.cd-visitcard__id {
    display: flex;
    align-items: center;
    gap: 12px;
}

.cd-visitcard__avatar {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    overflow: hidden;
    flex-shrink: 0;
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.28);
    background: #f4f4f4;
}

.cd-visitcard__avatar-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.cd-visitcard__titles {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.cd-visitcard__title {
    margin: 0;
    font-size: 1.25rem;
    line-height: 1.2;
    font-weight: 600;
    color: #1f3550;
}

.cd-visitcard__subtitle {
    margin: 0;
    font-size: 0.95rem;
    line-height: 1.35;
    color: #3b4d60;
    font-style: italic;
}

.cd-visitcard__header-actions {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 8px;
}

.cd-visitcard__body {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.cd-visitcard__body--cols {
    flex-direction: row;
    align-items: stretch;
    gap: 14px;
}

.cd-visitcard__col {
    flex: 1 1 0;
    min-width: 0;
    min-height: 0;
    display: flex;
    align-items: stretch;
}

.cd-visitcard__card {
    width: 100%;
    height: 100%;
    background: #ffffff;
    border-radius: 12px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.10);
    display: flex;
    flex-direction: column;
}

/* ==========================================================================
   Mode POPUP (dépendant)
   ========================================================================== */

.cd-visitcard--popup {
    position: fixed;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
    padding: 12px;
    z-index: 1120;
}

.cd-visitcard--popup.is-open {
    pointer-events: auto;
}

.cd-visitcard__backdrop {
    position: fixed;
    inset: 0;
    background: rgba(8, 12, 26, 0.55);
}

.cd-visitcard--popup .cd-visitcard__panel {
    position: relative;
    z-index: 1;
    width: min(720px, 100%);
    max-height: 100%;
}

/* Lock scroll (piloté par JS) */
html.cd-visitcard-opened {
    height: 100%;
    overflow: hidden;
}

/* ==========================================================================
   Mode INLINE (dépendant)
   ========================================================================== */

.cd-visitcard--inline {
    position: static;
    display: block;
    pointer-events: auto;
    padding: 0;
}

.cd-visitcard--inline .cd-visitcard__panel {
    width: 100%;
    max-height: none;
}

/* ==========================================================================
   INLINE artist mono-œuvre : pixel perfect du panel popup (sans popup)
   ========================================================================== */

.cd-visitcard--inline.cd-visitcard--artist .cd-visitcard__panel{
    max-height: 460px;
    overflow: hidden;
}

.cd-visitcard--inline.cd-visitcard--artist .cd-visitcard__body{
    overflow-y: auto;
    padding-right: 4px;
}

/* En inline mono-œuvre : pas de nav. En multi-œuvres, les flèches restent visibles. */
.cd-visitcard--inline.cd-visitcard--artist .cd-visitcard__frame--single .cd-visitcard__nav {
    display: none;
}

/* ==========================================================================
   Presets — Ratio 40/60 + scroll interne (clone popup artistes)
   On applique aux presets artist + generic pour “pixel perfect” du look premium.
   ========================================================================== */

/* Panel : même contrainte que popup artiste */
.cd-visitcard--artist.cd-visitcard--popup .cd-visitcard__panel,
.cd-visitcard--generic.cd-visitcard--popup .cd-visitcard__panel {
    max-height: 460px;
    overflow: hidden;
}

/* Body : scroll interne + marge scrollbar */
.cd-visitcard--artist.cd-visitcard--popup .cd-visitcard__body,
.cd-visitcard--generic.cd-visitcard--popup .cd-visitcard__body {
    overflow-y: auto;
    padding-right: 4px;
}

/* Colonnes : ratio 40% / 60% */
.cd-visitcard--artist .cd-visitcard__col--bio,
.cd-visitcard--generic .cd-visitcard__col--bio {
    flex: 1 1 40%;
    max-width: 40%;
    min-width: 0;
}

.cd-visitcard--artist .cd-visitcard__col--media,
.cd-visitcard--generic .cd-visitcard__col--media {
    flex: 1 1 60%;
    max-width: 60%;
    min-width: 0;
}

/* Cards : padding/gap identiques artiste */
.cd-visitcard--artist .cd-visitcard__card,
.cd-visitcard--generic .cd-visitcard__card {
    padding: 8px 8px 10px 8px;
    gap: 8px;
}

.cd-visitcard__card--bio {
    justify-content: space-between;
}

/* Résumé */
.cd-visitcard__resume {
    margin: 0;
    font-size: 0.92rem;
    line-height: 1.45;
    color: #27384a;
}

/* Bloc actions : clone artiste */
.cd-visitcard__more {
    margin-top: 4px;
    padding-top: 10px;
    border-top: 1px solid rgba(0, 0, 0, 0.06);
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.cd-visitcard__more[data-cd-vc-actions-empty="1"] {
    display: none;
}

.cd-visitcard__more-title {
    margin: 0 0 2px 0;
    font-size: 0.75rem;
    font-weight: 600;
    color: #6b7280;
}

.cd-visitcard__actions-row {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    align-items: center;
}

.cd-visitcard__action-icon {
    width: 18px;
    height: 18px;
    display: block;
}

/* ==========================================================================
   Frame média / artwork : écrin sombre + 4/3 (clone artiste)
   ========================================================================== */

.cd-visitcard__card--media {
    align-items: stretch;
}

.cd-visitcard__frame {
    position: relative;
    width: 100%;
    aspect-ratio: 4 / 3;
    border-radius: 14px;
    overflow: hidden;
    background:
        radial-gradient(circle at 20% 20%, rgba(67, 56, 202, 0.85), transparent 60%),
        radial-gradient(circle at 80% 80%, rgba(239, 68, 68, 0.85), transparent 60%),
        #050816;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Base neutre : l'image s'adapte au preset via modificateurs */
.cd-visitcard__media-img{
    display: block;
}

/* Artist/Generic : image contenue + tapis blanc (pixel perfect artiste) */
.cd-visitcard--artist .cd-visitcard__media-img,
.cd-visitcard--generic .cd-visitcard__media-img{
    max-width: 88%;
    max-height: 88%;
    object-fit: contain;

    background-color: #ffffff;
    padding: 8px;
    border-radius: 12px;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.12);
}


.cd-visitcard__media-title {
    margin: 6px 2px 0 2px;
    font-size: 0.9rem;
    line-height: 1.3;
    font-weight: 500;
    color: #1f2933;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Nav buttons : position bords */
.cd-visitcard__nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
}

.cd-visitcard__nav--prev {
    left: 10px;
}

.cd-visitcard__nav--next {
    right: 10px;
}

/* Pas de nav si mono-image */
.cd-visitcard__frame--single .cd-visitcard__nav{
    display: none;
}

/* ==========================================================================
   Preset LUTHIER — alignement général & image atelier = cover plein cadre (pixel perfect luthier)
   ========================================================================== */

/* Luthier : mêmes colonnes que home (souvent 40/60 aussi) */
.cd-visitcard--luthier .cd-visitcard__col--bio {
    flex: 1 1 40%;
    max-width: 40%;
    min-width: 0;
}

.cd-visitcard--luthier .cd-visitcard__col--media {
    flex: 1 1 60%;
    max-width: 60%;
    min-width: 0;
}

.cd-visitcard--luthier.cd-visitcard--popup .cd-visitcard__panel {
    max-height: 460px;
    overflow: hidden;
}

.cd-visitcard--luthier.cd-visitcard--popup .cd-visitcard__body {
    overflow-y: auto;
    padding-right: 4px;
}

.cd-visitcard--luthier .cd-visitcard__card {
    padding: 8px 8px 10px 8px;
    gap: 8px;
}


/* La carte media luthier n'a pas de fond/ombre et pas de padding (comme popup luthier) */
.cd-visitcard--luthier .cd-visitcard__card--media{
    background: transparent;
    box-shadow: none;
    padding: 0;
    border-radius: 12px;
}

/* Le cadre luthier = fond gris clair, radius 12px (pas 14px) */
.cd-visitcard--luthier .cd-visitcard__frame{
    border-radius: 12px;
    background: #f6f6f6;
    display: block;
}

/* Image luthier = plein cadre */
.cd-visitcard--luthier .cd-visitcard__media-img{
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;

    /* cover comme luthier */
    object-fit: cover;

    /* annule l'esthétique "artiste" */
    max-width: none;
    max-height: none;
    padding: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
}

/* ==========================================================================
   Variante Artiste: sans résumé (et typiquement sans actions) => priorité à l’œuvre
   ========================================================================== */

.cd-visitcard--no-resume.cd-visitcard--artist .cd-visitcard__col--bio {
    flex: 0 0 0;
    max-width: 0;
    padding: 0;
}

.cd-visitcard--no-resume.cd-visitcard--artist .cd-visitcard__col--media {
    flex: 1 1 100%;
    max-width: 100%;
}

/* évite que la colonne bio “fantôme” garde de la place via min-width */
.cd-visitcard--no-resume.cd-visitcard--artist .cd-visitcard__col--bio > * {
    display: none;
}

/* ==========================================================================
   Variante luthier : sans résumé => priorité au média (LUTHIER)
   ========================================================================== */

.cd-visitcard--no-resume.cd-visitcard--luthier .cd-visitcard__col--bio{
    flex: 0 0 0;
    max-width: 0;
    padding: 0;
}

.cd-visitcard--no-resume.cd-visitcard--luthier .cd-visitcard__col--media{
    flex: 1 1 100%;
    max-width: 100%;
}

.cd-visitcard--no-resume.cd-visitcard--luthier .cd-visitcard__col--bio > *{
    display: none;
}

/* 	Ajout du règle optionnelle 
	pour que le média prenne vraiment “toute la carte” 
	sans laisser un vide dû au gap du body */
.cd-visitcard--no-resume.cd-visitcard--luthier .cd-visitcard__body--cols{
    gap: 0;
}

/* ==========================================================================
   Responsive — breakpoint 960px (clone artiste)
   ========================================================================== */

@media (max-width: 960px) {

    .cd-visitcard__panel {
        padding: 12px;
        border-radius: 12px;
        gap: 4px;
        margin-top: 0;
    }

    .cd-visitcard__avatar {
        width: 48px;
        height: 48px;
    }

    .cd-visitcard__title {
        font-size: 1.05rem;
    }

    .cd-visitcard__subtitle {
        font-size: 0.85rem;
    }

    .cd-visitcard__card {
        padding: 6px 6px 8px 6px;
        gap: 6px;
    }

    .cd-visitcard__media-title {
        font-size: 0.85rem;
    }

    .cd-visitcard--popup .cd-visitcard__panel {
        max-height: calc(100vh - 80px);
    }
}

/* Portrait : empilement */
@media (max-width: 960px) and (orientation: portrait) {

    .cd-visitcard__body--cols {
        flex-direction: column;
        gap: 12px;
    }

    .cd-visitcard__col--bio,
    .cd-visitcard__col--media {
        flex: none;
        width: 100%;
        max-width: 100%;
    }

    .cd-visitcard__frame {
        width: 100%;
        max-width: 100%;
        aspect-ratio: 4 / 3;
        margin-left: 0;
        margin-right: 0;
        max-height: none;
    }
}

/* ==========================================================================
   Mobile landscape : INLINE luthier identique popup HP
   - Scroll interne sur le PANEL (comme custom-deco-hp-popup-luthiers.css)
   - Le BODY ne doit pas scroller ici, sinon tu perds de la hauteur utile
   ========================================================================== */

@media (max-width: 959px) and (orientation: landscape) {

    .cd-visitcard--inline.cd-visitcard--luthier .cd-visitcard__panel {
        /* mêmes valeurs que le popup HP */
        border-radius: 14px;
        padding: 14px;

        /* même enveloppe “viewport” */
        max-height: calc(100dvh - 80px);

        /* IMPORTANT : scroll interne sur le panel, pas hidden */
        overflow: auto;

        /* on garde ton centrage */
        margin-left: auto;
        margin-right: auto;

        /* largeur gérée par le parent (Step2), le patch Step2 ci-dessous fera sauter la contrainte */
        width: auto;
        max-width: calc(100% - 24px);
    }

    /* Comme HP : body visible (pas de scroll ici) */
    .cd-visitcard--inline.cd-visitcard--luthier .cd-visitcard__body {
        overflow: visible;
        padding-right: 0;
    }

    .cd-visitcard--inline.cd-visitcard--luthier .cd-visitcard__body--cols {
        flex-direction: row;
        align-items: stretch;
        gap: 14px;
    }

    .cd-visitcard--inline.cd-visitcard--luthier .cd-visitcard__col--bio {
        flex: 0 0 300px;
        max-width: 300px;
        min-width: 0;
    }

    .cd-visitcard--inline.cd-visitcard--luthier .cd-visitcard__col--media {
        flex: 1 0 auto;
        min-width: 0;
        max-width: none;
    }

    .cd-visitcard--inline.cd-visitcard--luthier .cd-visitcard__frame {
        max-height: calc(100dvh - 160px);
        max-width: min(
            calc(100vw - 340px),
            calc((100dvh - 160px) * 4 / 3)
        );
        width: 100%;
        margin: 0 auto;
    }
}
