/* ==============================
   PAGE : MA PRATIQUE
   ============================== */

.page-practice {
    position: relative;
}

/* ========== SECTION 1 : HERO + PRATIQUE ========== */

.practice-hero {
    position: relative;
    padding-block: var(--space-xl);
    background-color: var(--color-bg-alt);
}

.practice-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
            linear-gradient(
                    135deg,
                    rgba(169, 181, 168, 0.18) 0%,
                    rgba(247, 247, 245, 0) 60%
            ),
            radial-gradient(
                    circle at 80% 0%,
                    rgba(47, 82, 67, 0.08),
                    transparent 70%
            );
    opacity: 0.9;
    pointer-events: none;
}

.practice-hero .container {
    position: relative;
    z-index: 1;
}

.practice-header {
    max-width: 42rem;
    margin-bottom: var(--space-lg);
}

.practice-kicker {
    font-size: 0.8rem;
    color: var(--color-text-soft);
    margin-bottom: var(--space-xs);
}

.practice-header h1 {
    margin-bottom: var(--space-sm);
}

/* ========== LAYOUT SPLIT (réutilisable) ========== */

.practice-block,
.practice-space__block {
    position: relative;
}

.split-section {
    display: grid;
    gap: var(--space-xl);
    align-items: center;
}

.split-section__text {
    max-width: 40rem;
    transition: transform 0.3s ease;
}

.split-section__media {
    margin: 0;
}

.split-section h2 {
    margin-bottom: var(--space-md);
}

/* Portrait & paysage */

.practice-portrait,
.practice-landscape {
    position: relative;
    max-width: 420px;
    margin-inline: auto;
}

.practice-portrait::before,
.practice-landscape::before {
    content: "";
    position: absolute;
    inset: 8%;
    border-radius: var(--radius-lg);
    border: 1px solid rgba(99, 135, 118, 0.35);
    transform: translate(-10px, 10px);
    z-index: -1;
}

.practice-landscape::before {
    transform: translate(10px, 10px);
}

.practice-portrait img,
.practice-landscape img {
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-soft);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

/* Micro-interactions */

.split-section:hover .practice-portrait img,
.split-section:hover .practice-landscape img {
    transform: translateY(-4px);
    box-shadow: 0 16px 32px rgba(0, 0, 0, 0.10);
}

.split-section:hover .split-section__text {
    transform: translateY(-2px);
}

/* ========== SECTION 2 : ESPACE PSYCHOTHÉRAPIE ========== */

.practice-space {
    background-color: transparent;
}

/* ========== SECTION 3+4 : MA FORMATION + MES SPÉCIALITÉS ========== */

.practice-expertise {
    position: relative;
    padding-block: var(--space-xl);
}

.practice-expertise__grid {
    display: grid;
    gap: var(--space-xxl);
    align-items: flex-start;
}

.practice-section-header {
    margin-bottom: var(--space-sm);
}

.practice-section-header h2 {
    margin-bottom: 0;
}

/* ----- Colonne gauche : timeline formation ----- */

.practice-training__content p {
    margin-bottom: var(--space-sm);
}

.practice-timeline {
    list-style: none;
    margin: var(--space-sm) 0 0;
    padding: 0;
    position: relative;
}

/* Ligne verticale de la timeline */

.practice-timeline::before {
    content: "";
    position: absolute;
    left: 0.6rem;
    top: 0;
    bottom: 0;
    width: 2px;
    background: linear-gradient(
            to bottom,
            rgba(99, 135, 118, 0.35),
            rgba(99, 135, 118, 0.08)
    );
}

.practice-timeline__item {
    position: relative;
    padding-left: 2.2rem;
    margin-bottom: var(--space-md);
}

.practice-timeline__marker {
    position: absolute;
    left: 0;
    top: 0.2rem;
    width: 0.9rem;
    height: 0.9rem;
    border-radius: 999px;
    border: 2px solid var(--color-lichen);
    background-color: #ffffff;
    box-shadow: 0 0 0 2px rgba(99, 135, 118, 0.15);
    transition: background-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.practice-timeline__card {
    background-color: #ffffff;
    border-radius: var(--radius-md);
    padding: var(--space-xs) var(--space-md);
    border: 1px solid rgba(213, 221, 212, 0.9);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.04);
    transition:
            transform 0.2s ease,
            box-shadow 0.2s ease,
            border-color 0.2s ease,
            background-color 0.2s ease;
}

.practice-timeline__card p {
    margin-bottom: 0;
}

/* Hover timeline (reste doux) */

.practice-timeline__item:hover .practice-timeline__card,
.practice-timeline__item:focus-within .practice-timeline__card {
    transform: translateY(-2px);
    box-shadow: 0 10px 22px rgba(0, 0, 0, 0.10);
    border-color: var(--color-lichen);
    background-color: #f9faf8;
}

.practice-timeline__item:hover .practice-timeline__marker,
.practice-timeline__item:focus-within .practice-timeline__marker {
    background-color: var(--color-lichen);
    transform: scale(1.04);
    box-shadow: 0 0 0 3px rgba(99, 135, 118, 0.22);
}

/* ----- Colonne droite : liste des spécialités (bulletpoints simples) ----- */

.practice-specialties__content {
    max-width: 34rem;
}

.practice-specialties__content p {
    margin-bottom: var(--space-sm);
}

.practice-specialties__list {
    margin: 0;
    padding-left: 1.4rem;
    list-style: disc;
    color: var(--color-text-soft);
}

/* on laisse respirer, sans styles chelou */

.practice-specialties__list li {
    margin-bottom: var(--space-xs);
    line-height: 1.5;
}

/* ========== SECTION : MES SPÉCIALITÉS ========== */

.practice-specialties-section {
    padding-block: var(--space-xl);
    background-color: transparent;
}

.practice-specialties-section .split-section__text {
    max-width: 40rem;
}

.practice-specialties-section .practice-specialties__content p {
    margin-bottom: var(--space-sm);
}

/* Optionnel : légèrement adoucir la couleur des puces */
.practice-specialties-section .practice-specialties__list {
    color: var(--color-text-soft);
}

/* ========== RESPONSIVE ========== */

@media (min-width: 768px) {
    .split-section {
        grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
    }

    .split-section--reverse {
        grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr);
    }

    .split-section--reverse .split-section__text {
        order: 2;
    }

    .split-section--reverse .split-section__media {
        order: 1;
        justify-self: start;
    }

    .split-section__media {
        justify-self: end;
    }
}

@media (min-width: 900px) {
    .practice-expertise__grid {
        grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
    }
}

@media (max-width: 899px) {
    .practice-expertise__grid {
        grid-template-columns: 1fr;
    }

    .practice-timeline::before {
        left: 0.5rem;
    }

    .practice-timeline__item {
        padding-left: 2rem;
    }
}

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

    .practice-hero {
        padding-block: var(--space-lg);
    }

    .practice-header {
        margin-bottom: var(--space-md);
    }

    .practice-portrait,
    .practice-landscape {
        max-width: 100%;
    }
}

/* Réduction des mouvements */

@media (prefers-reduced-motion: reduce) {
    .split-section,
    .practice-portrait img,
    .practice-landscape img,
    .practice-timeline__card,
    .practice-timeline__marker {
        transition: none !important;
        transform: none !important;
    }
}
