/**
 * Style Quentin Cards Plus v0.7
 * Grid de cartes avancées avec système de couleurs
 */

/* ==========================================================================
   GRID PARENT
   ========================================================================== */

.qba-cards-plus-grid {
    display: grid;
    /* Toujours au moins 2 colonnes, même sur mobile */
    grid-template-columns: repeat(auto-fit, minmax(min(300px, 45%), 1fr));
    gap: 2rem;
    max-width: 1600px;
    margin: 0 auto;

    padding: 2rem 1rem;
    border: 1px solid red;
}

/* Tablettes : 2 cartes côte à côte */
@media (max-width: 1024px) {
    .qba-cards-plus-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 1.5rem;
    }
}

/* Mobile : minimum 2 cartes par ligne */
@media (max-width: 768px) {
    .qba-cards-plus-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 1rem;
        padding: 1rem 0.5rem;
    }
}

/* Très petit mobile : toujours 2 colonnes mais plus compact */
@media (max-width: 480px) {
    .qba-cards-plus-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 0.75rem;
    }
}


/* ==========================================================================
   CARD PLUS (Bloc enfant)
   ========================================================================== */

.qba-card-plus {
    background: rgba(255, 255, 255, 0.03);
    border: 2px solid var(--card-border-color, #4a7c59);
    border-radius: 15px;
    overflow: hidden;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    display: flex;
    flex-direction: column;
}

.qba-card-plus:hover {
    transform: translateY(-10px);
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
}



/* ==========================================================================
   BIG CARD - Mode pleine largeur avec layout 2 colonnes
   ========================================================================== */

.qba-card-plus-big {
    grid-column: 1 / -1; /* Prend toute la largeur de la grid */
}

.qba-card-big-layout {
    display: grid;
    grid-template-columns: 1fr 1.5fr;
    gap: 0;
    min-height: 500px;
}

/* Colonne gauche : Header + Bouton */
.qba-card-big-left {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 0;

    border: 4px solid red;
}

.qba-card-big-left .qba-card-plus-header {
    border-bottom: none;
    border-right: 2px solid var(--card-border-color, #4a7c59);
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.qba-card-big-left .qba-card-cta {
    margin: 2rem;
    margin-top: auto;
}

/* Colonne droite : Image + Contenu */
.qba-card-big-right {
    display: flex;
    flex-direction: column;
}

.qba-card-big-right .qba-card-visual {
    height: 300px;
    flex-shrink: 0;
}

.qba-card-big-right .qba-card-content {
    flex: 1;
}

/* Mobile : retour en colonne simple pour big cards */
@media (max-width: 1024px) {
    .qba-card-big-layout {
        grid-template-columns: 1fr;
        min-height: auto;
    }
    
    .qba-card-big-left .qba-card-plus-header {
        border-right: none;
        border-bottom: 2px solid var(--card-border-color, #4a7c59);
    }
    
    .qba-card-big-right .qba-card-visual {
        height: 250px;
    }
}





/* ==========================================================================
   EN-TÊTE DE CARTE (ajustements mobile)
   ========================================================================== */

.qba-card-plus-header {
    padding: 2rem;
    border-bottom: 2px solid var(--card-border-color, #4a7c59);
    background: linear-gradient(135deg, var(--card-bg-color, rgba(74, 124, 89, 0.1)), transparent);
}

/* Mobile : padding réduit */
@media (max-width: 768px) {
    .qba-card-plus-header {
        padding: 1.25rem;
    }
}

.qba-card-number {
    width: 60px;
    height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
    font-weight: 700;
    border: 3px solid var(--card-border-color, #4a7c59);
    color: var(--card-border-color, #4a7c59);
    border-radius: 50%;
    margin-bottom: 1rem;
}

/* Mobile : taille réduite du numéro */
@media (max-width: 768px) {
    .qba-card-number {
        width: 45px;
        height: 45px;
        font-size: 1.5rem;
        border-width: 2px;
        margin-bottom: 0.75rem;
    }
}

.qba-card-title {
    font-size: clamp(1.75rem, 4vw, 2.5rem);
    font-weight: 700;
    line-height: 1.2;
    margin: 0 0 1rem 0;
    color: inherit;
}

/* Mobile : titre plus petit */
@media (max-width: 768px) {
    .qba-card-title {
        font-size: clamp(1.1rem, 3.5vw, 1.5rem);
        margin-bottom: 0.5rem;
    }
}

.qba-card-subtitle {
    font-size: 1rem;
    opacity: 0.7;
    letter-spacing: 0.05em;
    margin: 0;
}

/* Mobile : sous-titre plus petit */
@media (max-width: 768px) {
    .qba-card-subtitle {
        font-size: 0.75rem;
        line-height: 1.3;
    }
}

/* ==========================================================================
   IMAGE VISUELLE (ajustements mobile)
   ========================================================================== */

.qba-card-visual {
    position: relative;
    height: 350px;
    overflow: hidden;
}

/* Mobile : hauteur réduite */
@media (max-width: 768px) {
    .qba-card-visual {
        height: 200px;
    }
}

.qba-visual-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(10, 10, 10, 0.9), transparent);
    display: flex;
    align-items: flex-end;
    padding: 2rem;
}

/* Mobile : padding réduit */
@media (max-width: 768px) {
    .qba-visual-overlay {
        padding: 1rem;
    }
}

.qba-overlay-text {
    font-size: 3rem;
    font-weight: 700;
    opacity: 0.3;
    color: white;
}

/* Mobile : texte plus petit */
@media (max-width: 768px) {
    .qba-overlay-text {
        font-size: 1.75rem;
    }
}

/* ==========================================================================
   CONTENU (InnerBlocks) - ajustements mobile
   ========================================================================== */

.qba-card-content {
    padding: 2rem;
    flex: 1;
}

/* Mobile : padding réduit */
@media (max-width: 768px) {
    .qba-card-content {
        padding: 1rem;
        font-size: 0.9rem;
    }
}

/* PAR DÉFAUT : 1 colonne */
.qba-card-content {
    display: block;
}

/* CARTE SEULE : 2 colonnes */
.qba-cards-plus-grid.qba-single-card .qba-card-content {
    column-count: 2;
    column-gap: 2rem;
}

.qba-cards-plus-grid.qba-single-card .qba-card-content > * {
    break-inside: avoid;
    margin-bottom: 1rem;
}

/* Responsive : retour à 1 colonne sur mobile même si carte seule */
@media (max-width: 768px) {
    .qba-cards-plus-grid.qba-single-card .qba-card-content {
        column-count: 1;
    }
}

/* ==========================================================================
   BOUTON CTA - ajustements mobile
   ========================================================================== */

.qba-card-cta {
    display: block;
    margin: 2rem;
    padding: 1.2rem;
    text-align: center;
    font-size: 1.1rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    border: 2px solid var(--card-border-color, #4a7c59);
    color: var(--card-border-color, #4a7c59);
    border-radius: 50px;
    text-decoration: none;
    transition: all 0.3s ease;
}

/* Mobile : bouton plus compact */
@media (max-width: 768px) {
    .qba-card-cta {
        margin: 1rem;
        padding: 0.9rem;
        font-size: 0.9rem;
    }
}


/* ==========================================================================
   MODE ÉDITEUR
   ========================================================================== */

.editor-styles-wrapper .qba-cards-plus-grid {
    border: 2px dotted black;
}

.editor-styles-wrapper .qba-cards-plus-grid .block-editor-block-list__layout {
    /*border: 6px dotted red;*/
}

.qba-cards-plus-grid > .block-editor-inner-blocks > .block-editor-block-list__layout {
    display: flex;
}

.editor-styles-wrapper .qba-card-plus {
    margin-bottom: 0;
}

.editor-styles-wrapper .qba-card-content {
    min-height: 150px;
}

/* Placeholder pour contenu vide */
.qba-card-content .block-editor-inner-blocks > .block-editor-block-list__layout:empty::before {
    content: 'Ajoutez du contenu ici...';
    display: block;
    padding: 1rem;
    text-align: center;
    color: #999;
    font-style: italic;
}

/* ==========================================================================
   ANIMATIONS
   ========================================================================== */

@keyframes cardAppear {
    from {
        opacity: 0;
        transform: translateY(30px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.qba-card-plus {
    animation: cardAppear 0.5s ease-out;
}

/* ==========================================================================
   PRINT STYLES
   ========================================================================== */

@media print {
    .qba-card-plus {
        break-inside: avoid;
        box-shadow: none;
        border: 1px solid #ccc;
    }
    
    .qba-card-cta {
        display: none;
    }
}
