/*
Theme Name: TailPress
Theme URI: https://github.com/jeffreyvr/tailpress
Author: Jeffrey van Rossum
Author URI: https://vanrossum.dev
Description: TailPress is a simple boilerplate WordPress theme with Tailwind CSS.
Version: 3.4.0
License: MIT
License URI: https://github.com/jeffreyvr/tailpress/blob/master/LICENSE
Text Domain: tailpress
*/


:root :where(a:where(:not(.wp-element-button))) {
  text-decoration: inherit;
}
.wp-singular.sensei-tailpress .entry-content ul .course{
    list-style: none;
}

.sensei-course-theme .wp-block-post-content>.boutonsensei.buttonCustom{
    max-width:300px!important;
    height:4rem;
}
.sensei-course-theme .wp-block-post-content>.boutonsensei.buttonCustom > .buttonHover{
    top:4rem;
}
.sensei-course-theme .wp-block-post-content>.boutonsensei.buttonCustom:hover > .buttonNormal {
    top: -4rem;
}
.lesson-meta,
.wp-block-sensei-lms-button-lesson-completed{
    display:none!important;
}
.sensei-course-theme .wp-block-post-content>.boutonsensei.buttonCustom:hover > .buttonHover {
    top: 0;
}
.conteneur_archive_lecons h2,
.wp-block-sensei-button{
    background-color: rgb(152 123 89 / var(--tw-bg-opacity))!important;
    border-radius: 50px!important;
    margin-bottom: 20px!important;
}
.conteneur_archive_lecons h2 a,
.wp-block-sensei-button button{
    width:100%!important;
}
.sensei-course-theme .wp-block-button .wp-block-button__link,
.wp-block-button__link,
.wp-block-sensei-button button,
.conteneur_archive_lecons h2 a{
    border:0 none!important;
    color:#FFF!important;
    background-color:unset!important;
    border-radius: 50px!important;
}
.sensei-course-theme .wp-block-button .wp-block-button__link:hover,
.wp-block-button__link:hover,
.wp-block-sensei-button button:hover,
.conteneur_archive_lecons h2:hover{
    color:#FFF!important;
    border-radius: 50px!important;
}
.sensei-course-theme .wp-block-button .wp-block-button__link:hover,
.wp-block-button__link:hover,
.conteneur_archive_lecons h2:hover{
    background-color: rgb(181 158 131 / var(--tw-bg-opacity))!important;
}
.sensei-lesson-footer{
    display:flex;
    justify-content: center;
}
.wp-block-sensei-lms-course-list--is-list-view .sensei-cta .wp-block-button__link{
    float:none!important;
}
.wp-block-sensei-lms-course-list ul li{
    list-style:none!important;
}
.sensei #section_1{
    max-height:350px!important;
}
.sensei .wp-video{
    max-width:100%!important;
    display: flex;
  justify-content: center;
}
.sensei.single-lesson .entry-content h3{
    margin-bottom:15px;
}

.site-main .woocommerce-breadcrumb{
    margin: 0 auto;
    max-width:1400px;
    padding:20px;
}
.sensei .entry-header{
    display:none;
}
.conteneur_archive_lecons .type-lesson.post{
    display: flex;
    justify-content: center;
}
.conteneur_archive_lecons h2 a{
    font-weight:400;
    font-size:0.8em;
}
.conteneur_archive_lecons h2{
    padding:10px 25px 15px 25px;
}

/* Style du bouton "Lire la suite" de la description principale */
.main-description-read-more {
    display: inline-block;
    margin-top: 15px;
    font-weight: bold;
    cursor: pointer;
    color: #0073aa;
    text-decoration: underline;
    font-size: 1.1em;
}

.main-description-read-more:hover {
    color: #005177;
}
.read-more-container{
    margin-bottom: 40px;
}

.woocommerce-tabs iframe{
    max-width: 100%;
}
.woocommerce-page #section_1,
.woocommerce #section_1{
    max-height: 30vh;
}

.woocommerce-checkout .entry-content ul:not(.block-editor-block-variation-picker__variations) li{
    list-style: none;
}

.home #section_4{
    padding-top: 20px;
}

/* ============================================================
 * Physical Way - Carrousel d'avis clients
 * ============================================================ */

/* Le wrapper a un padding latéral pour laisser de la place aux flèches À L'EXTÉRIEUR */
.pw-avis-carousel-wrapper {
    width: 100%;
    max-width: 1400px;
    margin: 0 auto;
    padding: 30px 70px 50px;
    box-sizing: border-box;
    position: relative;
    overflow: hidden; /* on clippe au niveau du wrapper, pas du swiper */
}

.pw-avis-swiper {
    padding: 15px 5px 40px; /* le 40px en bas laisse vivre l'ombre */
    overflow: visible !important;
    /* SUPPRIMER clip-path : c'est lui qui cassait le mobile */
}

.pw-avis-swiper .swiper-wrapper {
    overflow: visible;
    align-items: stretch;
    display: flex;
}

.pw-avis-swiper .swiper-slide {
    height: auto;
    display: flex;
    overflow: visible;
}

.pw-avis-card {
    background: #fff;
    border-radius: 12px;
    padding: 28px 24px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    width: 100%;
    display: flex;
    flex-direction: column;
    box-sizing: border-box;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.pw-avis-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.12);
}

.pw-avis-card__head {
    margin-bottom: 14px;
}

.pw-avis-card__name {
    font-size: 1.05rem;
    font-weight: 600;
    margin: 0 0 8px;
    color: #1a1a1a;
    line-height: 1.3;
}

/* --- Étoiles --- */
.pw-avis-card__rating {
    display: inline-flex;
    align-items: center;
    gap: 2px;
    color: #f5a623;
}
.pw-star {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    fill: currentColor;
}
.pw-star--empty {
    color: #d0d0d0;
}

/* --- Texte de l'avis --- */
.pw-avis-card__text {
    font-size: 0.93rem;
    line-height: 1.55;
    color: #444;
    margin: 0;
    flex: 1;
}

/* --- Bouton "Lire la suite" --- */
.pw-avis-card__body {
    display: flex;
    flex-direction: column;
    flex: 1;
}

.pw-avis-card__toggle {
    margin-top: 12px;
    padding: 6px 0;
    background: none;
    border: none;
    color: #b08b4f;
    font-size: 0.88rem;
    font-weight: 600;
    cursor: pointer;
    align-self: flex-start;
    text-decoration: underline;
    text-underline-offset: 3px;
    transition: color 0.2s ease;
    font-family: inherit;
}
.pw-avis-card__toggle:hover {
    color: #8a6b3a;
}

.pw-avis-card__text-full {
    overflow: hidden;
}

/* ============================================================
 * Navigation flèches - POSITIONNÉES À L'EXTÉRIEUR
 * On accroche les flèches au .pw-avis-carousel-wrapper plutôt qu'au swiper
 * pour qu'elles soient bien dans la zone de padding latéral.
 * ============================================================ */
.pw-avis-carousel-wrapper .swiper-button-prev,
.pw-avis-carousel-wrapper .swiper-button-next {
    color: #1a1a1a;
    width: 44px;
    height: 44px;
    background: #fff;
    border-radius: 50%;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.15);
    border: none;
    cursor: pointer;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    margin-top: 0;
    z-index: 10;
    transition: background 0.2s ease, transform 0.2s ease;
}

.pw-avis-carousel-wrapper .swiper-button-prev {
    left: 10px;
}
.pw-avis-carousel-wrapper .swiper-button-next {
    right: 10px;
}

.pw-avis-carousel-wrapper .swiper-button-prev:hover,
.pw-avis-carousel-wrapper .swiper-button-next:hover {
    background: #f7f7f7;
    transform: translateY(-50%) scale(1.05);
}

.pw-avis-carousel-wrapper .swiper-button-prev::after,
.pw-avis-carousel-wrapper .swiper-button-next::after {
    font-size: 16px;
    font-weight: 700;
}

/* État désactivé (en bout de liste si loop désactivé) */
.pw-avis-carousel-wrapper .swiper-button-disabled {
    opacity: 0.35;
    cursor: default;
}

/* --- Responsive --- */
@media (max-width: 1023px) {
    .pw-avis-carousel-wrapper {
        padding: 25px 60px 45px;
    }
}

@media (max-width: 767px) {
    .pw-avis-carousel-wrapper {
        padding: 20px 50px 40px;
    }
    .pw-avis-carousel-wrapper .swiper-button-prev,
    .pw-avis-carousel-wrapper .swiper-button-next {
        width: 36px;
        height: 36px;
    }
    .pw-avis-carousel-wrapper .swiper-button-prev {
        left: 5px;
    }
    .pw-avis-carousel-wrapper .swiper-button-next {
        right: 5px;
    }
    .pw-avis-carousel-wrapper .swiper-button-prev::after,
    .pw-avis-carousel-wrapper .swiper-button-next::after {
        font-size: 13px;
    }
}


/*Media QUeries*/
@media(min-width: 1240px){
    .lg-hidden{
        display: none!important;
    }
    .mg-block{
        display: block!important;
    }
}



@media(max-width: 440px){
    .home #section_1 img.breathe {
        -o-object-position: -950px 0;
        object-position: -950px 0;

    }   
}






/* ============================================================
 * Physical Way - Archive Ressources Premium
 * ============================================================ */

.pw-ressources-page {
    max-width: 1400px;
    margin: 0 auto;
    padding: 40px 20px 80px;
    box-sizing: border-box;
}
/* État loading AJAX */
.pw-ressources-main {
    transition: opacity 0.2s;
}
.pw-ressources-main.is-loading {
    opacity: 0.5;
    pointer-events: none;
    position: relative;
}
.pw-ressources-main.is-loading::after {
    content: '';
    position: absolute;
    top: 100px;
    left: 50%;
    transform: translateX(-50%);
    width: 36px;
    height: 36px;
    border: 3px solid #ebebeb;
    border-top-color: #b08b4f;
    border-radius: 50%;
    animation: pw-spin 0.8s linear infinite;
}
@keyframes pw-spin {
    to { transform: translateX(-50%) rotate(360deg); }
}

/* ============================================================
 * En-tête : titre + recherche + filtres type
 * ============================================================ */
.pw-ressources-header {
    margin-bottom: 32px;
}

.pw-ressources-header__inner {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.pw-ressources-title {
    font-size: 2rem;
    font-weight: 700;
    margin: 0;
    color: #1a1a1a;
}

/* Barre de recherche */
.pw-ressources-search {
    position: relative;
    max-width: 500px;
    width: 100%;
}
.pw-ressources-search input[type="search"] {
    width: 100%;
    padding: 12px 48px 12px 16px;
    border: 1px solid #d4d4d4;
    border-radius: 50px;
    font-size: 0.95rem;
    background: #fff;
    box-sizing: border-box;
    transition: border-color 0.2s, box-shadow 0.2s;
    font-family: inherit;
}
.pw-ressources-search input[type="search"]:focus {
    outline: none;
    border-color: #b08b4f;
    box-shadow: 0 0 0 3px rgba(176, 139, 79, 0.15);
}
.pw-ressources-search button {
    position: absolute;
    right: 6px;
    top: 50%;
    transform: translateY(-50%);
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: none;
    background: #b08b4f;
    color: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.2s;
}
.pw-ressources-search button:hover {
    background: #8a6b3a;
}

/* Pills filtre type */
.pw-ressources-types {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}
.pw-ressources-pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    border-radius: 50px;
    background: #fff;
    border: 1px solid #d4d4d4;
    color: #444;
    font-size: 0.9rem;
    font-weight: 500;
    text-decoration: none;
    cursor: pointer;
    transition: all 0.2s ease;
}
.pw-ressources-pill:hover {
    border-color: #b08b4f;
    color: #b08b4f;
}
.pw-ressources-pill.is-active {
    background: #b08b4f;
    border-color: #b08b4f;
    color: #fff;
}
.pw-pill-icon {
    font-size: 0.85em;
}

/* ============================================================
 * Body : sidebar + main
 * ============================================================ */
.pw-ressources-body {
    display: grid;
    grid-template-columns: 240px 1fr;
    gap: 40px;
}

/* ============================================================
 * Sidebar
 * ============================================================ */
.pw-ressources-sidebar {
    position: relative;
}

.pw-sidebar-toggle {
    display: none; /* visible uniquement en mobile */
    width: 100%;
    padding: 12px 16px;
    background: #fff;
    border: 1px solid #d4d4d4;
    border-radius: 8px;
    font-size: 0.95rem;
    font-weight: 600;
    cursor: pointer;
    align-items: center;
    justify-content: space-between;
    font-family: inherit;
    color: #1a1a1a;
}
.pw-sidebar-toggle svg {
    transition: transform 0.2s;
}
.pw-sidebar-toggle[aria-expanded="true"] svg {
    transform: rotate(180deg);
}

.pw-sidebar-content {
    background: #fff;
    border-radius: 8px;
    padding: 20px;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.04);
}

.pw-sidebar-title {
    font-size: 1rem;
    font-weight: 700;
    margin: 0 0 16px;
    color: #1a1a1a;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.pw-categories-list {
    list-style: none;
    padding: 0;
    margin: 0;
}
.pw-categories-list > li {
    margin-bottom: 4px;
}

/* Ligne catégorie : flex pour aligner le bouton + le lien */
.pw-cat-row {
    display: flex;
    align-items: center;
    gap: 4px;
}
.pw-cat-row .pw-cat-link {
    flex: 1;
    min-width: 0;
}

/* Bouton toggle +/- placé AVANT le lien */
.pw-cat-toggle {
    flex-shrink: 0;
    width: 28px;
    height: 28px;
    background: transparent;
    border: none;
    color: #999;
    cursor: pointer;
    padding: 0;
    font-size: 0.9rem;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: color 0.15s;
}
.pw-cat-toggle:hover {
    color: #b08b4f;
}
/* État par défaut : on affiche le + et on cache le - */
.pw-cat-toggle__icon-minus { display: none !important; }
.pw-cat-toggle__icon-plus { display: inline-block !important; }
/* État déplié : on inverse */
.pw-cat-item.is-expanded .pw-cat-toggle__icon-plus { display: none !important; }
.pw-cat-item.is-expanded .pw-cat-toggle__icon-minus { display: inline-block !important; }

/* Spacer pour aligner les items sans sous-catégories avec ceux qui en ont */
.pw-categories-list > li:not(.pw-cat-item--has-children) .pw-cat-row::before {
    content: "";
    flex-shrink: 0;
    width: 28px;
    height: 28px;
}
/* Cas du premier item "Toutes les catégories" qui n'est pas un .pw-cat-item */
.pw-categories-list > li:first-child:not(.pw-cat-item) {
    margin-bottom: 8px;
}

/* Sous-catégories : masquées par défaut, visibles quand le parent est .is-expanded */
.pw-categories-sublist {
    list-style: none;
    padding: 0;
    margin: 4px 0 8px 24px;
    border-left: 2px solid #ebebeb;
    display: none;
}
.pw-cat-item.is-expanded .pw-categories-sublist {
    display: block;
}
.pw-categories-sublist li {
    margin-bottom: 2px;
}

.pw-cat-link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    padding: 7px 10px;
    border-radius: 6px;
    color: #444;
    font-size: 0.92rem;
    text-decoration: none;
    transition: background 0.15s, color 0.15s;
}
.pw-cat-link:hover {
    background: #f7f3ed;
    color: #b08b4f;
}
.pw-cat-link.is-active {
    background: #b08b4f;
    color: #fff;
    font-weight: 600;
}
.pw-cat-link--child {
    padding-left: 14px;
    font-size: 0.88rem;
}
.pw-cat-count {
    background: #ebebeb;
    color: #666;
    font-size: 0.75rem;
    padding: 2px 8px;
    border-radius: 12px;
    font-weight: 500;
    min-width: 20px;
    text-align: center;
}
.pw-cat-link.is-active .pw-cat-count {
    background: rgba(255, 255, 255, 0.25);
    color: #fff;
}

/* ============================================================
 * Main (résultats)
 * ============================================================ */
.pw-ressources-main {
    min-width: 0; /* important pour le bon fonctionnement du grid */
}

/* Toolbar : compteur + tri */
.pw-ressources-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 16px;
    margin-bottom: 16px;
    padding-bottom: 16px;
    border-bottom: 1px solid #ebebeb;
}
.pw-results-count {
    font-size: 0.95rem;
    color: #666;
    font-weight: 500;
}
.pw-ressources-sort {
    display: flex;
    align-items: center;
    gap: 8px;
}
.pw-ressources-sort label {
    font-size: 0.9rem;
    color: #666;
}
.pw-ressources-sort select {
    padding: 6px 12px;
    border: 1px solid #d4d4d4;
    border-radius: 6px;
    background: #fff;
    font-size: 0.9rem;
    cursor: pointer;
    font-family: inherit;
    color: #1a1a1a;
}
.pw-ressources-sort select:focus {
    outline: none;
    border-color: #b08b4f;
}

/* Filtres actifs */
.pw-active-filters {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    margin-bottom: 20px;
}
.pw-active-filters__label {
    font-size: 0.85rem;
    color: #666;
    margin-right: 4px;
}
.pw-active-filter {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 12px;
    background: #f7f3ed;
    color: #b08b4f;
    border-radius: 50px;
    font-size: 0.85rem;
    text-decoration: none;
    transition: background 0.15s;
}
.pw-active-filter:hover {
    background: #ece2cf;
}
.pw-active-filter span {
    font-size: 1.1em;
    line-height: 1;
}
.pw-active-filter--reset {
    background: transparent;
    color: #b08b4f;
    text-decoration: underline;
    text-underline-offset: 2px;
}
.pw-active-filter--reset:hover {
    background: transparent;
    color: #8a6b3a;
}

/* ============================================================
 * Grille de cartes
 * ============================================================ */
.pw-ressources-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    margin-bottom: 40px;
}

.pw-resource-card {
    background: #fff;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
    transition: transform 0.25s ease, box-shadow 0.25s ease;
    display: flex;
    flex-direction: column;
}
.pw-resource-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
}

.pw-resource-card__link {
    display: flex;
    flex-direction: column;
    height: 100%;
    color: inherit;
    text-decoration: none;
}

.pw-resource-card__thumb {
    position: relative;
    aspect-ratio: 16 / 10;
    background: #f0ece5;
    overflow: hidden;
}
.pw-resource-card__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.4s ease;
}
.pw-resource-card:hover .pw-resource-card__thumb img {
    transform: scale(1.05);
}
.pw-resource-card__thumb-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #f7f3ed 0%, #ece2cf 100%);
}
.pw-resource-card__thumb-placeholder span {
    font-size: 3rem;
    opacity: 0.5;
}

.pw-resource-card__badge {
    position: absolute;
    top: 12px;
    left: 12px;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 5px 12px;
    background: rgba(26, 26, 26, 0.85);
    color: #fff;
    font-size: 0.78rem;
    font-weight: 600;
    border-radius: 50px;
    backdrop-filter: blur(4px);
}
.pw-badge-icon {
    font-size: 0.9em;
}

/* Variantes badge selon type (couleurs subtiles) */
.pw-resource-card--video .pw-resource-card__badge { background: rgba(192, 57, 43, 0.9); }
.pw-resource-card--podcast .pw-resource-card__badge { background: rgba(142, 68, 173, 0.9); }
.pw-resource-card--pdf .pw-resource-card__badge { background: rgba(211, 84, 0, 0.9); }
.pw-resource-card--article .pw-resource-card__badge { background: rgba(39, 174, 96, 0.9); }

.pw-resource-card__body {
    padding: 18px 20px 22px;
    flex: 1;
    display: flex;
    flex-direction: column;
}

.pw-resource-card__title {
    font-size: 1.05rem;
    font-weight: 600;
    margin: 0 0 10px;
    color: #1a1a1a;
    line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.pw-resource-card:hover .pw-resource-card__title {
    color: #b08b4f;
}

.pw-resource-card__excerpt {
    font-size: 0.88rem;
    line-height: 1.5;
    color: #666;
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* ============================================================
 * Pagination
 * ============================================================ */
.pw-ressources-pagination {
    display: flex;
    justify-content: center;
    gap: 6px;
    flex-wrap: wrap;
    margin-top: 20px;
}
.pw-ressources-pagination .page-numbers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    height: 40px;
    padding: 0 12px;
    border-radius: 8px;
    background: #fff;
    color: #444;
    font-size: 0.9rem;
    font-weight: 500;
    text-decoration: none;
    border: 1px solid #ebebeb;
    transition: all 0.15s;
}
.pw-ressources-pagination .page-numbers:hover {
    background: #f7f3ed;
    color: #b08b4f;
    border-color: #b08b4f;
}
.pw-ressources-pagination .page-numbers.current {
    background: #b08b4f;
    color: #fff;
    border-color: #b08b4f;
}
.pw-ressources-pagination .dots {
    border: none;
    background: none;
}

/* No results */
.pw-no-results {
    padding: 60px 20px;
    text-align: center;
    background: #fff;
    border-radius: 12px;
    border: 1px dashed #ddd;
}
.pw-no-results p {
    color: #666;
    margin: 0 0 20px;
}
.pw-no-results .pw-btn {
    display: inline-block;
    padding: 10px 24px;
    background: #b08b4f;
    color: #fff;
    border-radius: 50px;
    text-decoration: none;
    font-weight: 500;
    transition: background 0.2s;
}
.pw-no-results .pw-btn:hover {
    background: #8a6b3a;
}

/* ============================================================
 * Responsive
 * ============================================================ */
@media (max-width: 1023px) {
    .pw-ressources-body {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .pw-sidebar-toggle {
        display: flex;
    }

    .pw-sidebar-content {
        display: none;
    }
    .pw-sidebar-content.is-open {
        display: block;
        margin-top: 8px;
    }

    .pw-ressources-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 600px) {
    .pw-ressources-page {
        padding: 24px 16px 60px;
    }
    .pw-ressources-title {
        font-size: 1.5rem;
    }
    .pw-ressources-grid {
        grid-template-columns: 1fr;
        gap: 16px;
    }
    .pw-ressources-toolbar {
        flex-direction: column;
        align-items: flex-start;
    }
    .pw-ressources-sort {
        width: 100%;
    }
    .pw-ressources-sort select {
        flex: 1;
    }
}




/* ============================================================
 * Physical Way - Single Ressource Premium
 * ============================================================ */

.pw-resource-single {
    max-width: 900px;
    margin: 0 auto;
    padding: 40px 20px 60px;
    box-sizing: border-box;
}

/* Fil d'ariane */
.pw-resource-breadcrumb {
    margin-bottom: 24px;
}
.pw-back-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: #666;
    text-decoration: none;
    font-size: 0.92rem;
    transition: color 0.2s;
}
.pw-back-link:hover {
    color: #b08b4f;
}

/* En-tête : meta + titre */
.pw-resource-header {
    margin-bottom: 32px;
}
.pw-resource-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
}
.pw-resource-badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 5px 12px;
    border-radius: 50px;
    color: #fff;
    font-size: 0.82rem;
    font-weight: 600;
    background: #1a1a1a;
}
.pw-resource-badge--video   { background: #c0392b; }
.pw-resource-badge--podcast { background: #8e44ad; }
.pw-resource-badge--pdf     { background: #d35400; }
.pw-resource-badge--article { background: #27ae60; }

.pw-resource-cat {
    display: inline-flex;
    padding: 5px 12px;
    border: 1px solid #d4d4d4;
    border-radius: 50px;
    color: #444;
    font-size: 0.85rem;
    text-decoration: none;
    transition: all 0.2s;
}
.pw-resource-cat:hover {
    border-color: #b08b4f;
    color: #b08b4f;
}
.pw-resource-date {
    color: #999;
    font-size: 0.85rem;
}

.pw-resource-title {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.2;
    color: #1a1a1a;
    margin: 0;
}

/* Contenu */
.pw-resource-content {
    margin-bottom: 40px;
}

/* Lecteur vidéo */
.pw-resource-player--video {
    width: 100%;
    margin-bottom: 28px;
    border-radius: 12px;
    overflow: hidden;
    background: #000;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
}
.pw-resource-player--video video {
    width: 100%;
    height: auto;
    display: block;
    max-height: 70vh;
}

/* Lecteur audio (podcast) */
.pw-resource-player--audio {
    margin-bottom: 28px;
}
.pw-resource-player__cover {
    margin-bottom: 16px;
    border-radius: 12px;
    overflow: hidden;
    aspect-ratio: 16 / 9;
    background: #f0ece5;
}
.pw-resource-player__cover img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.pw-resource-player--audio audio {
    width: 100%;
    display: block;
}

/* PDF card */
.pw-resource-player--pdf {
    margin-bottom: 28px;
}
.pw-pdf-card {
    background: linear-gradient(135deg, #f7f3ed 0%, #ece2cf 100%);
    border-radius: 12px;
    padding: 40px 30px;
    text-align: center;
    border: 1px solid #ddd;
}
.pw-pdf-card__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 80px;
    height: 80px;
    background: #fff;
    border-radius: 50%;
    color: #d35400;
    margin-bottom: 16px;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.06);
}
.pw-pdf-card__title {
    font-size: 1.2rem;
    font-weight: 600;
    margin: 0 0 20px;
    color: #1a1a1a;
}
.pw-pdf-card__btn {
    display: inline-block;
    padding: 12px 28px;
    background: #d35400;
    color: #fff;
    border-radius: 50px;
    text-decoration: none;
    font-weight: 600;
    transition: background 0.2s;
}
.pw-pdf-card__btn:hover {
    background: #a04200;
    color: #fff;
}

/* Description (WYSIWYG) sous le lecteur */
.pw-resource-description {
    font-size: 1rem;
    line-height: 1.7;
    color: #333;
}
.pw-resource-description img {
    max-width: 100%;
    height: auto;
    border-radius: 8px;
    margin: 16px 0;
}
.pw-resource-description h2,
.pw-resource-description h3 {
    margin-top: 28px;
    color: #1a1a1a;
}
.pw-resource-description p {
    margin: 0 0 16px;
}

/* Article — contenu + zone bloquée */
.pw-resource-article {
    font-size: 1.05rem;
    line-height: 1.7;
    color: #333;
}
.pw-resource-article p {
    margin: 0 0 18px;
}
.pw-resource-article img {
    max-width: 100%;
    height: auto;
    border-radius: 8px;
    margin: 20px 0;
}
.pw-resource-article h2,
.pw-resource-article h3 {
    margin-top: 32px;
    color: #1a1a1a;
}
.pw-resource-article__locked {
    position: relative;
    margin-top: 20px;
}
.pw-resource-article__fadeout {
    height: 100px;
    margin-top: -100px;
    background: linear-gradient(to bottom, rgba(249, 244, 240, 0) 0%, rgba(249, 244, 240, 0.95) 60%, #F9F4F0 100%);
    position: relative;
    z-index: 1;
    pointer-events: none;
}

/* Encart d'incitation */
.pw-incitation {
    background: linear-gradient(135deg, #f7f3ed 0%, #ece2cf 100%);
    border: 1px solid #d4c5a5;
    border-radius: 16px;
    padding: 40px 30px;
    text-align: center;
    margin: 20px 0;
}
.pw-incitation__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 80px;
    height: 80px;
    background: #b08b4f;
    color: #fff;
    border-radius: 50%;
    margin-bottom: 20px;
}
.pw-incitation__title {
    font-size: 1.5rem;
    font-weight: 700;
    color: #1a1a1a;
    margin: 0 0 12px;
}
.pw-incitation__text {
    font-size: 1rem;
    line-height: 1.6;
    color: #555;
    max-width: 500px;
    margin: 0 auto 24px;
}
.pw-incitation__btn {
    display: inline-block;
    padding: 14px 32px;
    background: #b08b4f;
    color: #fff;
    border-radius: 50px;
    text-decoration: none;
    font-weight: 600;
    font-size: 1rem;
    transition: background 0.2s, transform 0.2s;
}
.pw-incitation__btn:hover {
    background: #8a6b3a;
    color: #fff;
    transform: translateY(-2px);
}

/* Footer : tags */
.pw-resource-footer {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px;
    padding-top: 24px;
    border-top: 1px solid #ebebeb;
}
.pw-resource-tags-label {
    color: #666;
    font-size: 0.9rem;
    font-weight: 500;
}
.pw-resource-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.pw-resource-tag {
    display: inline-block;
    padding: 4px 12px;
    background: #f5f5f5;
    color: #666;
    border-radius: 50px;
    font-size: 0.82rem;
    text-decoration: none;
    transition: all 0.15s;
}
.pw-resource-tag:hover {
    background: #b08b4f;
    color: #fff;
}

/* Suggestions */
.pw-resource-suggestions {
    max-width: 1400px;
    margin: 0 auto;
    padding: 40px 20px 80px;
    box-sizing: border-box;
    border-top: 1px solid #ebebeb;
}
.pw-resource-suggestions__title {
    font-size: 1.5rem;
    font-weight: 700;
    color: #1a1a1a;
    margin: 0 0 28px;
}
.pw-resource-suggestions .pw-ressources-grid {
    grid-template-columns: repeat(4, 1fr);
}

/* Espacements entre texte avant/après et lecteur */
.pw-resource-description--before {
    margin-bottom: 24px;
}
.pw-resource-description--after {
    margin-top: 24px;
}

.single-ressource #section_1,
.post-type-archive-ressource #section_1{
    display: none;
}
.single-ressource h2{
    font-size: 1.5em;
    font-weight: bold;
}
.single-ressource h3{
    font-size: 1.3em;
    font-weight: bold;
}
.single-ressource h4{
    font-size: 1.25em;
    font-weight: bold;
}


/* Responsive */
@media (max-width: 1023px) {
    .pw-resource-suggestions .pw-ressources-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 600px) {
    .pw-resource-single {
        padding: 24px 16px 40px;
    }
    .pw-resource-title {
        font-size: 1.5rem;
    }
    .pw-incitation {
        padding: 30px 20px;
    }
    .pw-incitation__title {
        font-size: 1.25rem;
    }
    .pw-resource-suggestions .pw-ressources-grid {
        grid-template-columns: 1fr;
    }
}


/* ============================================================
 * Physical Way - Espace VIP (Onboarding + Flash Info)
 * ============================================================ */

.pw-vip-space {
    max-width: 1400px;
    margin: 0 auto 30px;
    padding: 0 20px;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    gap: 24px;
}

/* === Conteneur Onboarding === */
.pw-onboarding {
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
    overflow: hidden;
    transition: box-shadow 0.2s;
}
.pw-onboarding:hover {
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.09);
}

/* Header (toujours visible) */
.pw-onboarding__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    padding: 18px 24px;
    background: linear-gradient(135deg, #f7f3ed 0%, #ece2cf 100%);
}

.pw-onboarding__title {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 1.1rem;
    font-weight: 700;
    color: #1a1a1a;
    margin: 0;
    line-height: 1.3;
}

.pw-onboarding__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    background: #b08b4f;
    color: #fff;
    border-radius: 50%;
    font-size: 0.75rem;
    flex-shrink: 0;
}

/* Bouton toggle */
.pw-onboarding__toggle {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    background: #fff;
    border: 1px solid #d4c5a5;
    border-radius: 50px;
    color: #8a6b3a;
    font-size: 0.88rem;
    font-weight: 600;
    cursor: pointer;
    font-family: inherit;
    flex-shrink: 0;
    transition: all 0.2s;
}
.pw-onboarding__toggle:hover {
    background: #b08b4f;
    color: #fff;
    border-color: #b08b4f;
}

.pw-onboarding__toggle-label-collapsed { display: none; }
.pw-onboarding.is-collapsed .pw-onboarding__toggle-label-expanded { display: none; }
.pw-onboarding.is-collapsed .pw-onboarding__toggle-label-collapsed { display: inline; }

.pw-onboarding__chevron {
    transition: transform 0.3s;
}
.pw-onboarding.is-collapsed .pw-onboarding__chevron {
    transform: rotate(-90deg);
}

/* Body (vidéo + texte) avec animation slide */
.pw-onboarding__body {
    max-height: 2000px;
    overflow: hidden;
    transition: max-height 0.4s ease, opacity 0.3s ease, padding 0.3s ease;
    padding: 24px;
    opacity: 1;
}
.pw-onboarding.is-collapsed .pw-onboarding__body {
    max-height: 0;
    opacity: 0;
    padding-top: 0;
    padding-bottom: 0;
}

.pw-onboarding__video {
    width: 100%;
    max-width: 800px;
    margin: 0 auto 20px;
    border-radius: 8px;
    overflow: hidden;
    background: #000;
}
.pw-onboarding__video video {
    width: 100%;
    height: auto;
    display: block;
    max-height: 60vh;
}

.pw-onboarding__text {
    max-width: 800px;
    margin: 0 auto;
    font-size: 0.95rem;
    line-height: 1.65;
    color: #444;
}
.pw-onboarding__text p {
    margin: 0 0 12px;
}
.pw-onboarding__text img {
    max-width: 100%;
    height: auto;
    border-radius: 6px;
}

/* === Bloc Flash Info === */
.pw-flashinfo {
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
    padding: 24px;
    position: relative;
}

.pw-flashinfo__title {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 1.1rem;
    font-weight: 700;
    color: #1a1a1a;
    margin: 0 0 20px;
}
.pw-flashinfo__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    background: #d35400;
    color: #fff;
    border-radius: 50%;
    font-size: 0.95rem;
    flex-shrink: 0;
}

/* Swiper */
.pw-flashinfo-swiper {
    padding: 4px 4px 40px;
    overflow: visible !important;
    clip-path: inset(-20px 0 -20px 0);
    position: relative;
}
.pw-flashinfo-swiper .swiper-wrapper {
    overflow: visible;
    align-items: stretch;
    display: flex;
}
.pw-flashinfo-swiper .swiper-slide {
    height: auto;
    display: flex;
    overflow: visible;
}

/* Carte annonce */
.pw-flashinfo-card {
    background: linear-gradient(135deg, #fff8f0 0%, #ffeed8 100%);
    border: 1px solid #f0d9b5;
    border-radius: 10px;
    padding: 20px 24px;
    width: 100%;
    display: flex;
    flex-direction: column;
    box-sizing: border-box;
}

.pw-flashinfo-card__title {
    font-size: 1.05rem;
    font-weight: 700;
    color: #1a1a1a;
    margin: 0 0 8px;
    line-height: 1.3;
}

.pw-flashinfo-card__description {
    font-size: 0.92rem;
    line-height: 1.55;
    color: #555;
    margin: 0 0 16px;
    flex: 1;
}

.pw-flashinfo-card__btn {
    align-self: flex-start;
    display: inline-block;
    padding: 9px 22px;
    background: #d35400;
    color: #fff;
    border-radius: 50px;
    text-decoration: none;
    font-weight: 600;
    font-size: 0.88rem;
    transition: background 0.2s, transform 0.2s;
}
.pw-flashinfo-card__btn:hover {
    background: #a04200;
    color: #fff;
    transform: translateY(-1px);
}

/* Pagination + flèches Swiper Flash */
.pw-flashinfo-pagination {
    bottom: 0 !important;
}
.pw-flashinfo-swiper .swiper-pagination-bullet {
    background: #d35400;
    opacity: 0.3;
}
.pw-flashinfo-swiper .swiper-pagination-bullet-active {
    opacity: 1;
}
.pw-flashinfo-swiper .swiper-button-prev,
.pw-flashinfo-swiper .swiper-button-next {
    color: #d35400;
    width: 30px;
    height: 30px;
    background: #fff;
    border-radius: 50%;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.12);
    border: none;
    cursor: pointer;
    margin-top: -15px;
}
.pw-flashinfo-swiper .swiper-button-prev::after,
.pw-flashinfo-swiper .swiper-button-next::after {
    font-size: 11px;
    font-weight: 700;
}
.pw-flashinfo-swiper .swiper-button-prev { left: -8px; }
.pw-flashinfo-swiper .swiper-button-next { right: -8px; }

/* === Intégration dans Mon Compte WooCommerce === */
.woocommerce-account .pw-vip-space {
    max-width: 100%;
    padding: 0;
    margin-bottom: 30px;
}

/* === Responsive === */
@media (max-width: 600px) {
    .pw-onboarding__header {
        padding: 14px 16px;
        flex-wrap: wrap;
    }
    .pw-onboarding__title {
        font-size: 1rem;
    }
    .pw-onboarding__body {
        padding: 16px;
    }
    .pw-flashinfo {
        padding: 18px;
    }
    .pw-flashinfo-card {
        padding: 16px 18px;
    }
    .pw-flashinfo-swiper .swiper-button-prev,
    .pw-flashinfo-swiper .swiper-button-next {
        display: none;
    }
}

/* ============================================================
 * Filtre Mots-clés (tags) — sidebar archive ressources
 * ============================================================ */
.pw-sidebar-title--tags {
    margin-top: 28px;
    padding-top: 22px;
    border-top: 1px solid #ebebeb;
}

.pw-tags-list {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.pw-tag-chip {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 5px 12px;
    background: #f5f5f5;
    color: #555;
    border-radius: 50px;
    font-size: 0.82rem;
    text-decoration: none;
    transition: background-color 0.15s, color 0.15s;
    line-height: 1.3;
    cursor: pointer;
    border: none;
}

.pw-tag-chip:hover {
    background: #f7f3ed;
    color: #b08b4f;
}

.pw-tag-chip.is-active {
    background: #b08b4f;
    color: #fff;
    font-weight: 600;
}

.pw-tag-count {
    background: rgba(0, 0, 0, 0.08);
    color: inherit;
    font-size: 0.72rem;
    padding: 1px 7px;
    border-radius: 12px;
    font-weight: 500;
    min-width: 18px;
    text-align: center;
    line-height: 1.4;
}

.pw-tag-chip.is-active .pw-tag-count {
    background: rgba(255, 255, 255, 0.25);
}



/* ============================================================
 * Médias additionnels — single ressource
 * (vidéos, podcasts ou PDF additionnels sous le média principal)
 * ============================================================ */
.pw-resource-media-additional {
    margin-top: 32px;
    padding-top: 32px;
    border-top: 1px solid #ebebeb;
}

.pw-resource-media-additional__title {
    font-size: 1.25rem;
    font-weight: 600;
    margin: 0 0 16px 0;
    color: #2a2a2a;
}

/* Espacement vertical réduit entre médias additionnels successifs */
.pw-resource-media-additional + .pw-resource-media-additional {
    margin-top: 24px;
    padding-top: 24px;
}