@charset "UTF-8";
/***!  /media/templates/site/cassiopeia/css/user.css?af3948  !***/

/* =========================================================
   FORMATEUR-RUCQUOY.BE
   CSS GLOBAL PREMIUM - CASSIOPEIA
   Header + menu + contenu + boutons + cartes
   ========================================================= */

/* =========================================================
   1. RÉGLAGES GLOBAUX
   ========================================================= */
:root {
    --nru-blue-dark: #001b4c;
    --nru-blue: #22356f;
    --nru-blue-mid: #2c438b;
    --nru-blue-light: #3450a2;
    --nru-text: #1c2430;
    --nru-text-soft: #4b5a70;
    --nru-border: #dbe4f0;
    --nru-border-soft: #e3e8ef;
    --nru-bg-soft: #f4f7fb;
    --nru-bg-soft-2: #f8fafc;
    --nru-white: #ffffff;
    --nru-radius-sm: 10px;
    --nru-radius: 16px;
    --nru-radius-lg: 22px;
    --nru-shadow-soft: 0 8px 24px rgba(0, 0, 0, 0.04);
    --nru-shadow-card: 0 10px 28px rgba(0, 27, 76, 0.06);
    --nru-shadow-strong: 0 14px 34px rgba(0, 27, 76, 0.12);
    --nru-transition: all 0.25s ease;
}

html {
    scroll-behavior: smooth;
}

body {
    color: var(--nru-text);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Typographie générale */
.site-grid,
.com-content-article,
.item-page,
main {
    color: var(--nru-text);
}

p {
    line-height: 1.75;
}

h1, h2, h3, h4 {
    color: var(--nru-blue-dark);
    line-height: 1.25;
    letter-spacing: -0.01em;
}

h1 {
    font-weight: 800;
}

h2 {
    font-weight: 800;
}

h3 {
    font-weight: 700;
}

/* Liens généraux */
a {
    transition: color 0.2s ease, opacity 0.2s ease, transform 0.2s ease, box-shadow 0.25s ease;
}

a:hover,
a:focus {
    text-decoration: none;
}

/* Images */
img {
    max-width: 100%;
    height: auto;
}

/* =========================================================
   2. HEADER + MENU PRINCIPAL
   ========================================================= */

/* ---------- HEADER GLOBAL ---------- */
.container-header {
    position: relative;
    z-index: 100;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.10);
}

/* Fond général de la zone navigation */
.container-header .grid-child.container-nav {
    background: linear-gradient(90deg, #22356f 0%, #2c438b 55%, #3450a2 100%);
    padding: 8px 20px;
    min-height: 74px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}

/* Fine ligne décorative en bas */
.container-header .grid-child.container-nav::after {
    content: "";
    position: absolute;
    left: 20px;
    right: 20px;
    bottom: 0;
    height: 1px;
    background: rgba(255, 255, 255, 0.12);
}

/* ---------- ZONE LOGO / BRAND ---------- */
.container-header .navbar-brand {
    margin-right: 24px;
    display: flex;
    align-items: center;
    gap: 12px;
    text-decoration: none;
}

.container-header .navbar-brand img,
.container-header .navbar-brand svg {
    max-height: 56px;
    width: auto;
    transition: transform 0.25s ease;
}

.container-header .navbar-brand:hover img,
.container-header .navbar-brand:hover svg {
    transform: scale(1.02);
}

/* Texte éventuel de marque */
.container-header .navbar-brand span,
.container-header .navbar-brand .site-title {
    color: #ffffff;
    font-weight: 700;
    letter-spacing: 0.2px;
}

/* ---------- NAVIGATION ---------- */
.container-header nav {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
}

/* Menu principal */
.container-header .mod-menu {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: 6px;
    margin: 0;
    padding: 0;
    list-style: none;
}

/* Items */
.container-header .mod-menu > li {
    margin: 0;
    padding: 0;
    display: flex;
    align-items: center;
    position: relative;
}

/* Liens */
.container-header .mod-menu > li > a {
    display: block;
    position: relative;
    padding: 13px 18px;
    border-radius: 12px;
    color: #ffffff !important;
    text-decoration: none;
    text-align: center;
    font-size: 0.98rem;
    font-weight: 600;
    line-height: 1.2;
    letter-spacing: 0.15px;
    transition:
        background-color 0.25s ease,
        color 0.25s ease,
        transform 0.18s ease,
        box-shadow 0.25s ease;
}

/* Hover / focus */
.container-header .mod-menu > li > a:hover,
.container-header .mod-menu > li > a:focus,
.container-header .mod-menu > li > a:active {
    background: rgba(255, 255, 255, 0.13);
    color: #ffffff !important;
    text-decoration: none;
    transform: translateY(-1px);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08);
    outline: none;
}

/* Page active */
.container-header .mod-menu > li.active > a,
.container-header .mod-menu > li.current > a,
.container-header .mod-menu > li > a[aria-current="page"] {
    background: rgba(255, 255, 255, 0.18);
    color: #ffffff !important;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.10);
}

/* Soulignement élégant de la page active */
.container-header .mod-menu > li.active > a::after,
.container-header .mod-menu > li.current > a::after,
.container-header .mod-menu > li > a[aria-current="page"]::after {
    content: "";
    position: absolute;
    left: 18px;
    right: 18px;
    bottom: 7px;
    height: 2px;
    border-radius: 3px;
    background: rgba(255, 255, 255, 0.96);
}

/* ---------- SOUS-MENUS ---------- */
.container-header .mod-menu .mod-menu__sub {
    margin-top: 10px;
    border-radius: 14px;
    overflow: hidden;
    background: #ffffff;
    border: 1px solid rgba(34, 53, 111, 0.10);
    box-shadow: 0 12px 28px rgba(0, 0, 0, 0.16);
    padding: 6px 0;
}

.container-header .mod-menu .mod-menu__sub li {
    margin: 0;
}

.container-header .mod-menu .mod-menu__sub a {
    display: block;
    padding: 11px 16px;
    color: #22356f !important;
    text-decoration: none;
    font-size: 0.95rem;
    font-weight: 500;
    transition: background-color 0.2s ease, color 0.2s ease, padding-left 0.2s ease;
}

.container-header .mod-menu .mod-menu__sub a:hover,
.container-header .mod-menu .mod-menu__sub a:focus {
    background: rgba(34, 53, 111, 0.06);
    color: #1c2d5f !important;
    padding-left: 18px;
    text-decoration: none;
}

/* ---------- BOUTON MENU MOBILE ---------- */
.container-header .navbar-toggler {
    border: 1px solid rgba(255, 255, 255, 0.20);
    border-radius: 10px;
    padding: 8px 12px;
    background: rgba(255, 255, 255, 0.08);
    color: #ffffff;
    box-shadow: none;
    transition: background-color 0.25s ease, transform 0.2s ease, border-color 0.25s ease;
}

.container-header .navbar-toggler:hover,
.container-header .navbar-toggler:focus {
    background: rgba(255, 255, 255, 0.14);
    border-color: rgba(255, 255, 255, 0.35);
    color: #ffffff;
    transform: translateY(-1px);
    outline: none;
}

/* Icône du bouton mobile */
.container-header .navbar-toggler-icon {
    filter: brightness(0) invert(1);
}

/* ---------- AJUSTEMENTS DE MISE EN PAGE ---------- */
.container-header .container-nav {
    align-items: center;
}

.container-header .container-nav .navbar {
    width: 100%;
    justify-content: center;
    align-items: center;
}

/* Si logo + menu sont côte à côte */
.container-header .container-nav .navbar-brand + .mod-menu,
.container-header .container-nav .navbar-brand + nav .mod-menu {
    margin-left: auto;
    margin-right: auto;
}

/* =========================================================
   3. CONTENU PRINCIPAL - FINITIONS ESTHÉTIQUES
   ========================================================= */

/* Zone principale de contenu */
.site-grid .container-component,
.site-grid .grid-child.container-component,
main .com-content-article,
.item-page {
    position: relative;
}

/* Meilleure lisibilité du contenu d’article */
.com-content-article,
.item-page {
    color: var(--nru-text);
}

/* Titre principal des pages */
.com-content-article h1,
.item-page h1 {
    margin-bottom: 0.8rem;
}

/* Titres secondaires */
.com-content-article h2,
.item-page h2 {
    margin-top: 0;
    margin-bottom: 0.7rem;
}

/* Cartes/blocs avec style inline : hover discret */
.com-content-article div[style*="border-radius: 14px"],
.com-content-article div[style*="border-radius: 16px"],
.com-content-article div[style*="border-radius: 18px"],
.com-content-article div[style*="border-radius: 22px"],
.com-content-article a[style*="border-radius: 14px"],
.com-content-article a[style*="border-radius: 16px"],
.com-content-article a[style*="border-radius: 18px"],
.com-content-article a[style*="border-radius: 22px"],
.item-page div[style*="border-radius: 14px"],
.item-page div[style*="border-radius: 16px"],
.item-page div[style*="border-radius: 18px"],
.item-page div[style*="border-radius: 22px"],
.item-page a[style*="border-radius: 14px"],
.item-page a[style*="border-radius: 16px"],
.item-page a[style*="border-radius: 18px"],
.item-page a[style*="border-radius: 22px"] {
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease, background-color 0.25s ease;
}

/* Hover sur cartes */
.com-content-article a[style*="border-radius: 14px"]:hover,
.com-content-article a[style*="border-radius: 16px"]:hover,
.com-content-article a[style*="border-radius: 18px"]:hover,
.com-content-article a[style*="border-radius: 22px"]:hover,
.item-page a[style*="border-radius: 14px"]:hover,
.item-page a[style*="border-radius: 16px"]:hover,
.item-page a[style*="border-radius: 18px"]:hover,
.item-page a[style*="border-radius: 22px"]:hover {
    transform: translateY(-3px);
    box-shadow: 0 14px 28px rgba(0, 27, 76, 0.12) !important;
}

/* Hover discret sur blocs non cliquables */
.com-content-article div[style*="box-shadow"]:hover,
.item-page div[style*="box-shadow"]:hover {
    transform: translateY(-2px);
    box-shadow: 0 14px 30px rgba(0, 27, 76, 0.08) !important;
}

/* Boutons inline de la page */
.com-content-article a[style*="padding: 12px 22px"],
.com-content-article a[style*="padding: 13px 24px"],
.com-content-article a[style*="padding: 13px 22px"],
.item-page a[style*="padding: 12px 22px"],
.item-page a[style*="padding: 13px 24px"],
.item-page a[style*="padding: 13px 22px"] {
    transition: transform 0.2s ease, box-shadow 0.25s ease, background-color 0.25s ease, color 0.25s ease;
}

.com-content-article a[style*="padding: 12px 22px"]:hover,
.com-content-article a[style*="padding: 13px 24px"]:hover,
.com-content-article a[style*="padding: 13px 22px"]:hover,
.item-page a[style*="padding: 12px 22px"]:hover,
.item-page a[style*="padding: 13px 24px"]:hover,
.item-page a[style*="padding: 13px 22px"]:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 24px rgba(0, 27, 76, 0.16) !important;
}

/* Liens texte dans le contenu */
.com-content-article p a,
.com-content-article li a,
.item-page p a,
.item-page li a {
    color: var(--nru-blue-dark);
    font-weight: 600;
}

.com-content-article p a:hover,
.com-content-article li a:hover,
.item-page p a:hover,
.item-page li a:hover {
    color: var(--nru-blue-mid);
}

/* Listes plus propres */
.com-content-article ul,
.item-page ul {
    line-height: 1.75;
}

/* Petits textes */
.com-content-article small,
.item-page small {
    color: var(--nru-text-soft);
}

/* =========================================================
   4. BLOCS JOOMLA COURANTS
   ========================================================= */

.com-content-article,
.item-page {
    font-size: 1rem;
}

/* Pagination si présente */
.pagination {
    gap: 8px;
}

.pagination .page-link {
    border-radius: 10px;
    color: var(--nru-blue-dark);
}

.pagination .active .page-link {
    background: var(--nru-blue-dark);
    border-color: var(--nru-blue-dark);
    color: #fff;
}

/* =========================================================
   5. FOOTER / BAS DE PAGE
   ========================================================= */
.footer,
.container-footer {
    border-top: 1px solid rgba(0, 27, 76, 0.08);
}

.footer a,
.container-footer a {
    transition: opacity 0.2s ease, color 0.2s ease;
}

.footer a:hover,
.container-footer a:hover {
    opacity: 0.85;
}

/* =========================================================
   6. VERSION TABLETTE
   ========================================================= */
@media (max-width: 991px) {
    .container-header .grid-child.container-nav {
        min-height: 68px;
        padding: 8px 14px;
    }

    .container-header .navbar-brand {
        margin-right: 14px;
    }

    .container-header .navbar-brand img,
    .container-header .navbar-brand svg {
        max-height: 48px;
    }

    .container-header .mod-menu {
        gap: 4px;
    }

    .container-header .mod-menu > li > a {
        padding: 11px 14px;
        font-size: 0.94rem;
        border-radius: 10px;
    }

    .container-header .mod-menu > li.active > a::after,
    .container-header .mod-menu > li.current > a::after,
    .container-header .mod-menu > li > a[aria-current="page"]::after {
        left: 14px;
        right: 14px;
        bottom: 6px;
    }

    .com-content-article,
    .item-page {
        font-size: 0.98rem;
    }
}

/* =========================================================
   7. VERSION MOBILE
   ========================================================= */
@media (max-width: 767px) {
    .container-header .grid-child.container-nav {
        min-height: auto;
        padding: 10px 10px 8px 10px;
    }

    .container-header .grid-child.container-nav::after {
        left: 10px;
        right: 10px;
    }

    .container-header .navbar-brand {
        margin-right: 10px;
    }

    .container-header .navbar-brand img,
    .container-header .navbar-brand svg {
        max-height: 42px;
    }

    .container-header .mod-menu {
        width: 100%;
        justify-content: center;
        gap: 4px;
        padding-top: 8px;
    }

    .container-header .mod-menu > li {
        width: 100%;
    }

    .container-header .mod-menu > li > a {
        width: 100%;
        padding: 11px 12px;
        font-size: 0.93rem;
        border-radius: 9px;
        line-height: 1.15;
    }

    .container-header .mod-menu > li.active > a::after,
    .container-header .mod-menu > li.current > a::after,
    .container-header .mod-menu > li > a[aria-current="page"]::after {
        left: 12px;
        right: 12px;
        bottom: 5px;
    }

    .container-header .mod-menu .mod-menu__sub {
        margin-top: 6px;
        border-radius: 10px;
    }

    .container-header .mod-menu .mod-menu__sub a {
        padding: 10px 12px;
        font-size: 0.92rem;
    }

    .com-content-article,
    .item-page {
        font-size: 0.97rem;
    }

    .com-content-article h1,
    .item-page h1 {
        font-size: 1.9rem;
    }

    .com-content-article h2,
    .item-page h2 {
        font-size: 1.5rem;
    }

    .com-content-article h3,
    .item-page h3 {
        font-size: 1.2rem;
    }
}

/* =========================================================
   8. PETIT BONUS VISUEL
   ========================================================= */
.container-header,
.container-header *,
.com-content-article,
.item-page {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* =========================================================
   ACTUALITÉS / SESSIONS
   ========================================================= */

.fr-session-card {
    max-width: 980px;
    margin: 20px auto 40px auto;
    background: #ffffff;
    border: 1px solid #dfe7f3;
    border-radius: 20px;
    padding: 28px;
    box-shadow: 0 10px 30px rgba(20, 40, 90, 0.08);
}

.fr-session-badge {
    display: inline-block;
    background: #eaf2ff;
    color: #22356f;
    border: 1px solid #c9d9f5;
    border-radius: 999px;
    padding: 7px 14px;
    font-size: 0.88rem;
    font-weight: 700;
    margin-bottom: 16px;
}

.fr-session-card h1 {
    margin: 0 0 10px 0;
    font-size: 2rem;
    line-height: 1.2;
    color: #1c2e5a;
}

.fr-session-subtitle {
    margin: 0 0 22px 0;
    font-size: 1.08rem;
    color: #4b5b78;
}

.fr-session-infos {
    display: grid;
    grid-template-columns: repeat(2, minmax(220px, 1fr));
    gap: 12px;
    margin: 0 0 26px 0;
    padding: 18px;
    background: #f7faff;
    border: 1px solid #dce8f8;
    border-radius: 16px;
}

.fr-session-infos div {
    font-size: 1rem;
    color: #22324d;
}

.fr-session-content h2 {
    margin: 24px 0 10px 0;
    font-size: 1.25rem;
    color: #22356f;
}

.fr-session-content p,
.fr-session-content li {
    font-size: 1rem;
    line-height: 1.7;
    color: #2c3d5a;
}

.fr-session-content ul {
    margin: 0 0 0 20px;
    padding: 0;
}

.fr-session-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 28px;
}

.fr-btn-primary,
.fr-btn-secondary {
    display: inline-block;
    text-decoration: none;
    font-weight: 700;
    border-radius: 12px;
    padding: 13px 20px;
    transition: all 0.25s ease;
}

.fr-btn-primary {
    background: linear-gradient(90deg, #22356f 0%, #3450a2 100%);
    color: #ffffff;
    border: 1px solid #22356f;
}

.fr-btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 20px rgba(34, 53, 111, 0.20);
    color: #ffffff;
}

.fr-btn-secondary {
    background: #ffffff;
    color: #22356f;
    border: 1px solid #c9d9f5;
}

.fr-btn-secondary:hover {
    background: #f3f7ff;
    color: #22356f;
}

@media (max-width: 768px) {
    .fr-session-card {
        padding: 20px;
        border-radius: 16px;
    }

    .fr-session-card h1 {
        font-size: 1.6rem;
    }

    .fr-session-infos {
        grid-template-columns: 1fr;
    }

    .fr-session-actions {
        flex-direction: column;
    }

    .fr-btn-primary,
    .fr-btn-secondary {
        text-align: center;
        width: 100%;
    }
}

/* =========================================================
   AVIS PARTICIPANTS - VERSION PREMIUM SANS JAVASCRIPT
   ========================================================= */

.fr-reviews {
    max-width: 1280px;
    margin: 0 auto;
    padding: 42px 18px 72px 18px;
}

.fr-reviews__inner {
    max-width: 1160px;
    margin: 0 auto;
}

.fr-reviews__header {
    max-width: 920px;
    margin: 0 auto 34px auto;
    text-align: center;
}

.fr-reviews__kicker {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 9px 18px;
    border-radius: 999px;
    background: linear-gradient(180deg, #eef4ff 0%, #e7efff 100%);
    border: 1px solid #d8e3f5;
    color: #22356f;
    font-size: 0.92rem;
    font-weight: 700;
    letter-spacing: 0.02em;
    margin-bottom: 14px;
    box-shadow: 0 6px 18px rgba(34, 53, 111, 0.05);
}

.fr-reviews__header h2 {
    margin: 0 0 14px 0;
    font-size: 2.45rem;
    line-height: 1.14;
    color: #1f3163;
    letter-spacing: -0.02em;
}

.fr-reviews__header p {
    margin: 0;
    font-size: 1.08rem;
    line-height: 1.8;
    color: #66758d;
}

.fr-reviews__stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(220px, 1fr));
    gap: 22px;
    max-width: 1060px;
    margin: 0 auto 34px auto;
}

.fr-rstat {
    position: relative;
    text-align: center;
    padding: 28px 22px 24px 22px;
    border-radius: 24px;
    background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
    border: 1px solid #dde7f4;
    box-shadow: 0 16px 36px rgba(25, 45, 90, 0.07), 0 4px 12px rgba(25, 45, 90, 0.03);
    overflow: hidden;
}

.fr-rstat::before {
    content: "";
    position: absolute;
    inset: 0 auto auto 0;
    width: 100%;
    height: 6px;
    background: linear-gradient(90deg, #22356f 0%, #3450a2 55%, #5f7ccc 100%);
}

.fr-rstat__icon {
    width: 46px;
    height: 46px;
    margin: 0 auto 12px auto;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #fff4d8;
    color: #d8a31d;
    font-size: 1.15rem;
    font-weight: 800;
    box-shadow: inset 0 0 0 1px #f0deab;
}

.fr-rstat__value {
    margin-bottom: 8px;
    font-size: 2.25rem;
    line-height: 1;
    font-weight: 800;
    color: #22356f;
}

.fr-rstat__label {
    font-size: 0.96rem;
    line-height: 1.55;
    color: #687892;
}

.fr-rbox {
    max-width: 1140px;
    margin: 0 auto;
    background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
    border: 1px solid #dde7f4;
    border-radius: 30px;
    box-shadow: 0 18px 42px rgba(25, 45, 90, 0.08), 0 4px 12px rgba(25, 45, 90, 0.03);
    overflow: hidden;
}

.fr-rbox__top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 14px;
    padding: 20px 24px;
    border-bottom: 1px solid #e8eef8;
    background: rgba(255,255,255,0.86);
    flex-wrap: wrap;
}

.fr-rbox__pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 8px 14px;
    border-radius: 999px;
    background: #f4f7fc;
    border: 1px solid #dbe5f2;
    color: #22356f;
    font-size: 0.89rem;
    font-weight: 700;
}

.fr-rbox__more,
.fr-rbox__bottom-link {
    appearance: none;
    border: none;
    background: transparent;
    color: #22356f;
    font-weight: 700;
    cursor: pointer;
    padding: 0;
    border-bottom: 1px solid transparent;
    transition: all 0.2s ease;
}

.fr-rbox__more:hover,
.fr-rbox__bottom-link:hover {
    color: #3450a2;
    border-bottom-color: #3450a2;
}

.fr-rtable-wrap {
    overflow-x: auto;
}

.fr-rtable {
    width: 100%;
    border-collapse: collapse;
}

.fr-rtable thead th {
    background: linear-gradient(90deg, #22356f 0%, #3450a2 100%);
    color: #ffffff;
    text-align: center;
    padding: 16px 14px;
    font-size: 0.93rem;
    font-weight: 700;
    white-space: nowrap;
}

.fr-rtable tbody td {
    padding: 18px 16px;
    border-bottom: 1px solid #e8eef8;
    vertical-align: middle;
    text-align: center;
    font-size: 0.97rem;
    line-height: 1.68;
    color: #42536f;
}

.fr-rtable tbody tr:hover {
    background: #f7faff;
}

.fr-rtable tbody tr:last-child td {
    border-bottom: none;
}

.fr-rtable tbody td:nth-child(1),
.fr-rtable tbody td:nth-child(2) {
    white-space: nowrap;
    color: #22356f;
    font-weight: 700;
}

.fr-rtable tbody td:nth-child(3) {
    min-width: 240px;
    color: #60718b;
}

.fr-rtable tbody td:nth-child(4) {
    min-width: 130px;
}

.fr-rtable tbody td:nth-child(5) {
    min-width: 360px;
    text-align: left;
}

.fr-score {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
}

.fr-score__stars {
    font-size: 0.95rem;
    letter-spacing: 2px;
    color: #e1ac22;
    font-weight: 800;
    line-height: 1;
}

.fr-score__badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 92px;
    padding: 9px 13px;
    border-radius: 999px;
    font-size: 0.88rem;
    font-weight: 800;
    white-space: nowrap;
}

.fr-score__badge--excellent {
    background: linear-gradient(180deg, #ecf9f1 0%, #e3f5ea 100%);
    color: #157347;
    border: 1px solid #cce9d8;
}

.fr-score__badge--good {
    background: linear-gradient(180deg, #eef4ff 0%, #e7efff 100%);
    color: #22356f;
    border: 1px solid #d8e3f5;
}

.fr-rtext {
    position: relative;
    padding-left: 30px !important;
}

.fr-rtext__quote {
    position: absolute;
    left: 10px;
    top: 10px;
    font-size: 1.7rem;
    line-height: 1;
    color: #d8e3f5;
    font-weight: 800;
}

.fr-rpagination {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    padding: 24px 18px 10px 18px;
    flex-wrap: wrap;
}

.fr-rpagination__btn {
    min-width: 48px;
    height: 48px;
    border: 1px solid #d7e2f4;
    background: #ffffff;
    color: #22356f;
    border-radius: 14px;
    font-size: 0.97rem;
    font-weight: 700;
    cursor: pointer;
    box-shadow: 0 4px 10px rgba(25, 45, 90, 0.03);
    transition: all 0.22s ease;
}

.fr-rpagination__btn:hover {
    background: #eef4ff;
    border-color: #cbd9ef;
    transform: translateY(-1px);
}

.fr-rpagination__btn.is-active {
    background: linear-gradient(90deg, #22356f 0%, #3450a2 100%);
    color: #ffffff;
    border-color: #22356f;
    box-shadow: 0 10px 22px rgba(34, 53, 111, 0.20);
}

.fr-rbox__bottom {
    text-align: center;
    padding: 10px 18px 28px 18px;
}

.fr-rarchive {
    max-width: 1140px;
    margin: 24px auto 0 auto;
    padding: 28px 26px;
    border-radius: 28px;
    background: linear-gradient(180deg, #ffffff 0%, #f9fbff 100%);
    border: 1px solid #dde7f4;
    box-shadow: 0 14px 34px rgba(25, 45, 90, 0.06);
}

.fr-rarchive__head {
    text-align: center;
    max-width: 760px;
    margin: 0 auto 24px auto;
}

.fr-rarchive__head h3 {
    margin: 0 0 10px 0;
    font-size: 1.7rem;
    color: #22356f;
}

.fr-rarchive__head p {
    margin: 0;
    color: #687892;
    line-height: 1.7;
}

.fr-rarchive__list {
    display: grid;
    gap: 12px;
}

.fr-rarchive__item {
    padding: 14px 16px;
    border-radius: 16px;
    background: #f7faff;
    border: 1px solid #e3ebf7;
    color: #45556f;
    line-height: 1.7;
}

.fr-rarchive__item strong {
    color: #22356f;
}

@media (max-width: 980px) {
    .fr-reviews__stats {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    .fr-reviews {
        padding: 28px 12px 48px 12px;
    }

    .fr-reviews__header h2 {
        font-size: 1.85rem;
    }

    .fr-reviews__header p {
        font-size: 1rem;
    }

    .fr-rbox__top {
        justify-content: center;
        text-align: center;
        padding: 16px;
    }

    .fr-rtable {
        min-width: 1020px;
    }

    .fr-rarchive {
        padding: 22px 18px;
    }
}

/* =========================================================
   MISE EN PAGE PLUS LARGE DES CADRES CENTRAUX
   ========================================================= */

/* Zone principale du composant */
.site-grid .container-component,
.site-grid .grid-child.container-component {
    width: 100%;
}

/* Les grands cadres/blocs centraux */
.com-content-article > div[style*="max-width: 1100px"],
.com-content-article > div[style*="max-width: 1000px"],
.com-content-article > div[style*="max-width: 980px"],
.com-content-article > div[style*="max-width: 920px"],
.item-page > div[style*="max-width: 1100px"],
.item-page > div[style*="max-width: 1000px"],
.item-page > div[style*="max-width: 980px"],
.item-page > div[style*="max-width: 920px"] {
    max-width: 1280px !important;
    width: min(100%, 1280px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 18px !important;
    padding-right: 18px !important;
    box-sizing: border-box !important;
}

/* Les cartes internes principales si elles sont centrées dans un wrapper */
.com-content-article div[style*="margin: 0 auto"][style*="border-radius"],
.item-page div[style*="margin: 0 auto"][style*="border-radius"] {
    width: min(100%, 1180px) !important;
    box-sizing: border-box !important;
}

/* Les encadrés type hero / intro / bienvenue */
.com-content-article div[style*="border-radius: 16px"],
.com-content-article div[style*="border-radius: 18px"],
.com-content-article div[style*="border-radius: 20px"],
.com-content-article div[style*="border-radius: 22px"],
.item-page div[style*="border-radius: 16px"],
.item-page div[style*="border-radius: 18px"],
.item-page div[style*="border-radius: 20px"],
.item-page div[style*="border-radius: 22px"] {
    box-sizing: border-box;
}

/* =========================================================
   TABLETTE
   ========================================================= */
@media (max-width: 991px) {
    .com-content-article > div[style*="max-width: 1100px"],
    .com-content-article > div[style*="max-width: 1000px"],
    .com-content-article > div[style*="max-width: 980px"],
    .com-content-article > div[style*="max-width: 920px"],
    .item-page > div[style*="max-width: 1100px"],
    .item-page > div[style*="max-width: 1000px"],
    .item-page > div[style*="max-width: 980px"],
    .item-page > div[style*="max-width: 920px"] {
        width: 100% !important;
        max-width: 100% !important;
        padding-left: 14px !important;
        padding-right: 14px !important;
    }

    .com-content-article div[style*="margin: 0 auto"][style*="border-radius"],
    .item-page div[style*="margin: 0 auto"][style*="border-radius"] {
        width: 100% !important;
    }
}

/* =========================================================
   SMARTPHONE
   ========================================================= */
@media (max-width: 767px) {
    .com-content-article > div[style*="max-width: 1100px"],
    .com-content-article > div[style*="max-width: 1000px"],
    .com-content-article > div[style*="max-width: 980px"],
    .com-content-article > div[style*="max-width: 920px"],
    .item-page > div[style*="max-width: 1100px"],
    .item-page > div[style*="max-width: 1000px"],
    .item-page > div[style*="max-width: 980px"],
    .item-page > div[style*="max-width: 920px"] {
        padding-left: 10px !important;
        padding-right: 10px !important;
    }
}
/* Harmoniser les blocs principaux de l'accueil */
.home .com-content-article > div,
.home .item-page > div {
    box-sizing: border-box;
}
.blog-items .blog-item {
  margin-bottom: 24px;
}

.blog-items .blog-item .item-content,
.blog-items .blog-item .article-body,
.blog-items .blog-item .introtext,
.blog-items .blog-item .card-body {
  background: #f5f7fb;
  border: 1px solid #dbe4f0;
  border-top: 4px solid #2c438b;
  border-radius: 18px;
  padding: 22px;
  box-shadow: 0 8px 20px rgba(0,0,0,0.05);
}

.blog-items .blog-item h2,
.blog-items .blog-item .page-header h2,
.blog-items .blog-item .item-title {
  margin: 0 0 10px 0;
  font-size: 1.45rem;
  line-height: 1.3;
}

.blog-items .blog-item h2 a,
.blog-items .blog-item .page-header h2 a,
.blog-items .blog-item .item-title a {
  color: #22356f;
  text-decoration: none;
  font-weight: 700;
}

.blog-items .blog-item h2 a:hover,
.blog-items .blog-item .page-header h2 a:hover,
.blog-items .blog-item .item-title a:hover {
  color: #1a2a57;
  text-decoration: underline;
}

.blog-items .blog-item .published {
  display: inline-block;
  margin: 6px 0 14px 0;
  color: #31456f;
  font-size: 0.98rem;
}

.blog-items .blog-item .btn-reserver {
  display: inline-block;
  margin-top: 12px;
  background: #2c438b;
  color: #fff !important;
  text-decoration: none;
  padding: 10px 16px;
  border-radius: 10px;
  font-weight: 700;
  box-shadow: 0 4px 12px rgba(44,67,139,0.20);
}

.blog-items .blog-item .btn-reserver:hover {
  background: #1f3163;
  color: #fff !important;
  text-decoration: none;
}

.blog-items .blog-item p:last-child {
  margin-bottom: 0;
}
.session-title-link:hover {
  color: #3450a2 !important;
  text-decoration: underline !important;
}

.btn-reserver:hover {
  opacity: 0.92;
}
.sessions-sidebar {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.session-mini-card {
  background: #f5f7fb;
  border: 1px solid #dbe4f0;
  border-top: 4px solid #2c438b;
  border-radius: 18px;
  padding: 16px;
  box-shadow: 0 8px 20px rgba(0,0,0,0.05);
}

.session-mini-card h3 {
  margin: 0 0 8px 0;
  font-size: 1.05rem;
  line-height: 1.35;
}

.session-mini-card h3 a {
  color: #22356f;
  text-decoration: none;
  font-weight: 700;
}

.session-mini-card h3 a:hover {
  text-decoration: underline;
}

.session-mini-card p {
  margin: 0 0 10px 0;
  color: #31456f;
  font-size: 0.95rem;
}

.btn-reserver-mini {
  display: inline-block;
  background: #2c438b;
  color: #fff !important;
  text-decoration: none;
  padding: 9px 14px;
  border-radius: 10px;
  font-weight: 700;
  font-size: 0.92rem;
}

.btn-reserver-mini:hover {
  background: #1f3163;
  color: #fff !important;
  text-decoration: none;
}
/* =========================================================
   ACTUALITÉS PREMIUM V7 - VERSION AFFINÉE
   ========================================================= */

.home-actus-premium {
    margin: 40px 0;
    padding: 26px;
    background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%);
    border: 1px solid #e3e8ef;
    border-radius: 24px;
    box-shadow: 0 14px 36px rgba(15, 23, 42, 0.06);
    position: relative;
    overflow: hidden;
}

.home-actus-premium::before {
    content: "Actualités & prochaines sessions";
    display: table;
    margin: 0 auto 18px auto;
    padding: 8px 18px;
    border-radius: 999px;
    background: linear-gradient(180deg, #eef4ff 0%, #e7efff 100%);
    border: 1px solid #d8e3f5;
    color: #22356f;
    font-size: 14px;
    font-weight: 800;
    letter-spacing: 0.2px;
}

.home-actus-premium > h3,
.home-actus-premium > .module-title,
.home-actus-premium > .moduletable-title {
    text-align: center;
    font-size: 2rem;
    line-height: 1.2;
    color: #1f3163;
    margin: 0 0 24px 0;
    font-weight: 800;
}

.home-actus-premium .mod-articles {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
    margin: 0;
    padding: 0;
}

.home-actus-premium .mod-articles > * {
    list-style: none;
}

.home-actus-premium .mod-articles-item {
    position: relative;
    background: #ffffff;
    border: 1px solid #e6ebf2;
    border-radius: 18px;
    padding: 54px 16px 14px 16px !important;
    overflow: hidden;
    min-height: auto !important;
    transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
    box-shadow:
        inset 0 4px 0 #3450a2,
        0 10px 24px rgba(15, 23, 42, 0.05);
}

.home-actus-premium .mod-articles-item:hover {
    transform: translateY(-3px);
    border-color: #cfdbeb;
    box-shadow:
        inset 0 4px 0 #3450a2,
        0 18px 34px rgba(15, 23, 42, 0.10);
}

.home-actus-premium .readmore,
.home-actus-premium .mod-articles-readmore,
.home-actus-premium a.readmore {
    display: none !important;
}

.home-actus-premium .mod-articles-item::before {
    content: "Réserver ma place";
    position: absolute;
    top: 14px;
    left: 16px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 7px 12px;
    border-radius: 9px;
    background: linear-gradient(90deg, #22356f 0%, #3450a2 100%);
    color: #ffffff;
    font-size: 11.8px;
    line-height: 1.2;
    font-weight: 700;
    letter-spacing: 0.01em;
    box-shadow: 0 5px 12px rgba(34, 53, 111, 0.16);
    pointer-events: none;
    z-index: 2;
    white-space: nowrap;
}

.home-actus-premium .mod-articles-item:hover::before {
    box-shadow: 0 8px 18px rgba(34, 53, 111, 0.22);
}

.home-actus-premium .mod-articles-title {
    display: block;
    margin: 0 0 6px 0;
    position: relative;
}

.home-actus-premium .mod-articles-title,
.home-actus-premium .mod-articles-title a {
    color: #1f3163;
    text-decoration: none;
    font-size: 1.02rem;
    line-height: 1.34;
    font-weight: 800;
}

.home-actus-premium .mod-articles-title a {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.home-actus-premium .mod-articles-title a::before {
    content: "→";
    display: inline-block;
    color: #3450a2;
    font-size: 15px;
    font-weight: 800;
    line-height: 1;
    transform: translateY(-1px);
    opacity: 0.9;
}

.home-actus-premium .mod-articles-title a:hover {
    color: #22356f;
    text-decoration: underline;
}

.home-actus-premium .mod-articles-title a:hover::before {
    color: #22356f;
}

.home-actus-premium .mod-articles-item-info,
.home-actus-premium .article-info {
    margin: 0;
}

.home-actus-premium time,
.home-actus-premium .mod-articles-item-date,
.home-actus-premium .published {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: #22356f;
    font-size: 11.8px;
    font-weight: 700;
    margin: 2px 0 0 0;
    padding: 0;
    background: transparent;
    border: none;
    border-radius: 0;
    box-shadow: none;
    opacity: 0.92;
}

.home-actus-premium .mod-articles-item-content,
.home-actus-premium .introtext,
.home-actus-premium p {
    color: #4b5563;
    font-size: 0.92rem;
    line-height: 1.45;
    margin: 8px 0 0 0;
}

.home-actus-premium img {
    width: 100%;
    display: block;
    border-radius: 14px;
    margin-bottom: 12px;
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.08);
}

@media (max-width: 767px) {
    .home-actus-premium {
        padding: 18px;
        border-radius: 18px;
    }

    .home-actus-premium > h3,
    .home-actus-premium > .module-title,
    .home-actus-premium > .moduletable-title {
        font-size: 1.45rem;
        margin-bottom: 18px;
    }

    .home-actus-premium .mod-articles {
        gap: 10px;
    }

    .home-actus-premium .mod-articles-item {
        padding: 50px 14px 13px 14px !important;
    }

    .home-actus-premium .mod-articles-item::before {
        top: 13px;
        left: 14px;
        padding: 6px 11px;
        font-size: 11.2px;
    }

    .home-actus-premium .mod-articles-title,
    .home-actus-premium .mod-articles-title a {
        font-size: 0.96rem;
        line-height: 1.3;
    }

    .home-actus-premium .mod-articles-title a::before {
        font-size: 14px;
    }

    .home-actus-premium time,
    .home-actus-premium .mod-articles-item-date,
    .home-actus-premium .published {
        font-size: 11.4px;
    }
}
.btn-resa {
    display: inline-block;
    padding: 12px 20px;
    background: #22356f;
    color: #fff !important;
    border-radius: 8px;
    text-decoration: none;
    font-weight: bold;
    transition: background 0.2s ease-in-out;
}

.cf-powered-by,
.chronoforms-powered,
#chronoforms8-poweredby,
a[href*="chronoengine.com"] {
    display: none !important;
}
#chronoforms8 {
    max-width: 800px;
    margin: 0 auto;
}

#chronoforms8 input,
#chronoforms8 select,
#chronoforms8 textarea {
    border-radius: 8px;
    border: 1px solid #dbe4f0;
    padding: 10px;
}

#chronoforms8 button {
    background: #22356f;
    color: white;
    border-radius: 8px;
    padding: 12px 18px;
    font-weight: bold;
}
/* =========================================================
   FORMULAIRE CHRONOFORMS - VERSION PRO PREMIUM
   formateur-rucquoy.be
   ========================================================= */

/* ---------- CONTENEUR GLOBAL ---------- */
body.com_chronoforms8 {
    background: #f8fafc;
}

body.com_chronoforms8 .site-grid,
body.com_chronoforms8 .container-component,
body.com_chronoforms8 main {
    background: transparent !important;
}

body.com_chronoforms8 #chronoforms8,
body.com_chronoforms8 form[id*="chronoforms"],
body.com_chronoforms8 .chronoforms8_form {
    max-width: 920px;
    margin: 28px auto 40px auto !important;
    padding: 28px 28px 24px 28px !important;
    background: #ffffff;
    border: 1px solid #e3e8ef;
    border-radius: 22px;
    box-shadow: 0 10px 28px rgba(0, 0, 0, 0.05);
    box-sizing: border-box;
}

/* ---------- FIL D'ARIANE / TITRES ---------- */
body.com_chronoforms8 .breadcrumbs {
    margin-bottom: 18px;
}

body.com_chronoforms8 h1,
body.com_chronoforms8 h2,
body.com_chronoforms8 h3 {
    color: #22356f;
}

/* ---------- LIGNES / BLOCS ---------- */
body.com_chronoforms8 .field,
body.com_chronoforms8 .form-group,
body.com_chronoforms8 .gcore-form-row,
body.com_chronoforms8 .gcore-form-group,
body.com_chronoforms8 .chrono-row,
body.com_chronoforms8 .chrono-field {
    margin-bottom: 18px !important;
}

/* ---------- LABELS ---------- */
body.com_chronoforms8 label,
body.com_chronoforms8 .gcore-label,
body.com_chronoforms8 .control-label {
    display: block;
    margin-bottom: 7px !important;
    color: #1f3163 !important;
    font-size: 0.98rem;
    font-weight: 700 !important;
    line-height: 1.35;
}

/* ---------- CHAMPS ---------- */
body.com_chronoforms8 input[type="text"],
body.com_chronoforms8 input[type="email"],
body.com_chronoforms8 input[type="tel"],
body.com_chronoforms8 input[type="number"],
body.com_chronoforms8 input[type="password"],
body.com_chronoforms8 input[type="date"],
body.com_chronoforms8 input[type="time"],
body.com_chronoforms8 select,
body.com_chronoforms8 textarea {
    width: 100% !important;
    min-height: 48px;
    padding: 12px 14px !important;
    background: #ffffff !important;
    border: 1px solid #d7e0ec !important;
    border-radius: 12px !important;
    color: #1f2937 !important;
    font-size: 0.98rem !important;
    line-height: 1.45;
    box-shadow: inset 0 1px 2px rgba(15, 23, 42, 0.03);
    transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
    box-sizing: border-box;
}

body.com_chronoforms8 textarea {
    min-height: 130px;
    resize: vertical;
}

/* ---------- FOCUS ---------- */
body.com_chronoforms8 input[type="text"]:focus,
body.com_chronoforms8 input[type="email"]:focus,
body.com_chronoforms8 input[type="tel"]:focus,
body.com_chronoforms8 input[type="number"]:focus,
body.com_chronoforms8 input[type="password"]:focus,
body.com_chronoforms8 input[type="date"]:focus,
body.com_chronoforms8 input[type="time"]:focus,
body.com_chronoforms8 select:focus,
body.com_chronoforms8 textarea:focus {
    border-color: #3450a2 !important;
    box-shadow: 0 0 0 4px rgba(52, 80, 162, 0.12) !important;
    outline: none !important;
    background: #ffffff !important;
}

/* ---------- PLACEHOLDERS ---------- */
body.com_chronoforms8 input::placeholder,
body.com_chronoforms8 textarea::placeholder {
    color: #94a3b8;
    opacity: 1;
}

/* ---------- SELECT ---------- */
body.com_chronoforms8 select {
    cursor: pointer;
}

/* ---------- CHAMPS OBLIGATOIRES ---------- */
body.com_chronoforms8 .required,
body.com_chronoforms8 .star,
body.com_chronoforms8 .asterisk,
body.com_chronoforms8 .gcore-required {
    color: #c0392b !important;
    font-weight: 800;
}

/* ---------- BOUTON PRINCIPAL ---------- */
body.com_chronoforms8 button,
body.com_chronoforms8 input[type="submit"],
body.com_chronoforms8 .btn,
body.com_chronoforms8 .gcore-btn,
body.com_chronoforms8 .ui.button,
body.com_chronoforms8 button[type="submit"] {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    padding: 12px 22px !important;
    background: linear-gradient(180deg, #22356f 0%, #2d468f 100%) !important;
    border: 1px solid #22356f !important;
    border-radius: 12px !important;
    color: #ffffff !important;
    font-size: 0.98rem !important;
    font-weight: 800 !important;
    text-decoration: none !important;
    letter-spacing: 0.01em;
    box-shadow: 0 8px 20px rgba(34, 53, 111, 0.18);
    cursor: pointer;
    transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.2s ease;
}

body.com_chronoforms8 button:hover,
body.com_chronoforms8 input[type="submit"]:hover,
body.com_chronoforms8 .btn:hover,
body.com_chronoforms8 .gcore-btn:hover,
body.com_chronoforms8 .ui.button:hover,
body.com_chronoforms8 button[type="submit"]:hover {
    background: linear-gradient(180deg, #2a4287 0%, #3655ab 100%) !important;
    color: #ffffff !important;
    transform: translateY(-1px);
    box-shadow: 0 10px 24px rgba(34, 53, 111, 0.24);
}

/* ---------- ALIGNEMENT BOUTON ---------- */
body.com_chronoforms8 .actions,
body.com_chronoforms8 .form-actions,
body.com_chronoforms8 .gcore-actions {
    margin-top: 18px !important;
}

/* ---------- MESSAGES / ALERTES ---------- */
body.com_chronoforms8 .alert,
body.com_chronoforms8 .message,
body.com_chronoforms8 .gcore-message,
body.com_chronoforms8 .success,
body.com_chronoforms8 .error {
    border-radius: 12px !important;
    padding: 14px 16px !important;
    margin-bottom: 18px !important;
    border: 1px solid #dbe4f0 !important;
}

/* ---------- DÉTAILS / BLOCS SECONDAIRES ---------- */
body.com_chronoforms8 details,
body.com_chronoforms8 summary {
    color: #334155;
}

/* ---------- CREDIT CHRONOFORMS ---------- */
body.com_chronoforms8 a[href*="chronoengine.com"],
body.com_chronoforms8 .cf-powered-by,
body.com_chronoforms8 .chronoforms-powered,
body.com_chronoforms8 #chronoforms8-poweredby {
    display: none !important;
}

/* ---------- PETITS TEXTES ---------- */
body.com_chronoforms8 small,
body.com_chronoforms8 .help-block,
body.com_chronoforms8 .form-text {
    color: #64748b !important;
    font-size: 0.88rem !important;
}

/* ---------- RESPONSIVE ---------- */
@media (max-width: 768px) {
    body.com_chronoforms8 #chronoforms8,
    body.com_chronoforms8 form[id*="chronoforms"],
    body.com_chronoforms8 .chronoforms8_form {
        margin: 18px 10px 28px 10px !important;
        padding: 18px 16px 18px 16px !important;
        border-radius: 18px;
    }

    body.com_chronoforms8 input[type="text"],
    body.com_chronoforms8 input[type="email"],
    body.com_chronoforms8 input[type="tel"],
    body.com_chronoforms8 input[type="number"],
    body.com_chronoforms8 input[type="password"],
    body.com_chronoforms8 input[type="date"],
    body.com_chronoforms8 input[type="time"],
    body.com_chronoforms8 select,
    body.com_chronoforms8 textarea {
        font-size: 16px !important; /* évite le zoom iPhone */
    }

    body.com_chronoforms8 button,
    body.com_chronoforms8 input[type="submit"],
    body.com_chronoforms8 .btn,
    body.com_chronoforms8 .gcore-btn,
    body.com_chronoforms8 .ui.button,
    body.com_chronoforms8 button[type="submit"] {
        width: 100% !important;
    }
}
/* =========================================================
   EVENTS BOOKING - ULTRA PREMIUM
   ========================================================= */

.eb-container,
.eb-events-container,
#eb-events,
.eb-event-list {
    max-width: 1100px;
    margin: 0 auto;
}

.eb-event-item,
.eb-event-container,
.event-booking-row {
    background: #ffffff;
    border: 1px solid #e4eaf3;
    border-radius: 18px;
    padding: 22px 24px;
    margin: 0 0 22px 0;
    box-shadow: 0 8px 28px rgba(31, 49, 99, 0.07);
    transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
    position: relative;
    overflow: hidden;
}

.eb-event-item:hover,
.eb-event-container:hover,
.event-booking-row:hover {
    transform: translateY(-3px);
    box-shadow: 0 14px 36px rgba(31, 49, 99, 0.12);
    border-color: #cfdcf0;
}

.eb-event-item::before,
.eb-event-container::before,
.event-booking-row::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, #22356f 0%, #2f4b99 50%, #3b63c6 100%);
}

.eb-event-title,
.eb_title,
.eb-event-item h2,
.eb-event-item h3,
.eb-event-container h2,
.eb-event-container h3 {
    margin: 0 0 10px 0 !important;
    font-size: 1.45rem !important;
    line-height: 1.3 !important;
    font-weight: 800 !important;
    color: #1f3163 !important;
}

.eb-event-title a,
.eb_title a,
.eb-event-item h2 a,
.eb-event-item h3 a,
.eb-event-container h2 a,
.eb-event-container h3 a {
    color: #1f3163 !important;
    text-decoration: none !important;
}

.eb-event-title a:hover,
.eb_title a:hover,
.eb-event-item h2 a:hover,
.eb-event-item h3 a:hover,
.eb-event-container h2 a:hover,
.eb-event-container h3 a:hover {
    color: #29448d !important;
}

.eb-event-date,
.eb-event-time,
.eb-event-location,
.eb-event-price,
.eb-event-capacity,
.eb-event-item .eb-meta,
.eb-event-container .eb-meta {
    color: #5f6d88 !important;
    font-size: 0.97rem !important;
    line-height: 1.7 !important;
}

.eb-description,
.eb-event-short-description,
.eb-event-item .description,
.eb-event-container .description {
    color: #33415c !important;
    font-size: 1rem !important;
    line-height: 1.75 !important;
    margin-top: 12px !important;
}

.eb-register-button,
.btn-eb-register,
a.eb-register-button,
a.btn-eb-register,
input.eb-register-button,
button.eb-register-button {
    display: inline-block !important;
    background: linear-gradient(90deg, #22356f 0%, #2f4b99 60%, #3c63c7 100%) !important;
    color: #ffffff !important;
    border: none !important;
    border-radius: 999px !important;
    padding: 12px 22px !important;
    font-size: 0.96rem !important;
    font-weight: 700 !important;
    line-height: 1.2 !important;
    text-decoration: none !important;
    box-shadow: 0 8px 20px rgba(34, 53, 111, 0.22) !important;
    transition: transform 0.2s ease, box-shadow 0.2s ease, opacity 0.2s ease !important;
}

.eb-register-button:hover,
.btn-eb-register:hover,
a.eb-register-button:hover,
a.btn-eb-register:hover,
input.eb-register-button:hover,
button.eb-register-button:hover {
    transform: translateY(-1px) !important;
    box-shadow: 0 12px 24px rgba(34, 53, 111, 0.28) !important;
    opacity: 0.96 !important;
    color: #ffffff !important;
}

.eb-available-spots,
.eb-places-left,
.eb-event-available-spots {
    display: inline-block;
    background: #eef4ff;
    border: 1px solid #d6e4fb;
    color: #1f4a9a;
    border-radius: 999px;
    padding: 6px 12px;
    font-size: 0.88rem;
    font-weight: 700;
    margin-top: 10px;
}

.eb-event-price,
.eb-price,
.eb-event-item .price {
    font-weight: 800 !important;
    color: #163a7a !important;
}

#eb-registration-form,
.eb-registration-form {
    max-width: 900px;
    margin: 0 auto;
    background: #ffffff;
    border: 1px solid #e4eaf3;
    border-radius: 20px;
    padding: 28px 24px;
    box-shadow: 0 10px 30px rgba(31, 49, 99, 0.08);
}

#eb-registration-form label,
.eb-registration-form label {
    font-weight: 700;
    color: #1f3163;
    margin-bottom: 6px;
}

#eb-registration-form input[type="text"],
#eb-registration-form input[type="email"],
#eb-registration-form input[type="tel"],
#eb-registration-form input[type="number"],
#eb-registration-form select,
#eb-registration-form textarea,
.eb-registration-form input[type="text"],
.eb-registration-form input[type="email"],
.eb-registration-form input[type="tel"],
.eb-registration-form input[type="number"],
.eb-registration-form select,
.eb-registration-form textarea {
    width: 100%;
    border: 1px solid #d9e2f0 !important;
    border-radius: 12px !important;
    padding: 12px 14px !important;
    background: #fbfcfe !important;
    color: #24324f !important;
    box-shadow: none !important;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

#eb-registration-form input:focus,
#eb-registration-form select:focus,
#eb-registration-form textarea:focus,
.eb-registration-form input:focus,
.eb-registration-form select:focus,
.eb-registration-form textarea:focus {
    border-color: #8ea9dd !important;
    box-shadow: 0 0 0 4px rgba(59, 99, 198, 0.12) !important;
    outline: none !important;
    background: #ffffff !important;
}

.eb-event-information,
.eb-event-details,
.eb-event-summary {
    background: linear-gradient(180deg, #f8fbff 0%, #f3f7fc 100%);
    border: 1px solid #dfe8f4;
    border-radius: 16px;
    padding: 18px 18px;
    margin-bottom: 20px;
}

@media (max-width: 768px) {
    .eb-event-item,
    .eb-event-container,
    .event-booking-row,
    #eb-registration-form,
    .eb-registration-form {
        padding: 18px 16px;
        border-radius: 16px;
    }

    .eb-event-title,
    .eb_title,
    .eb-event-item h2,
    .eb-event-item h3,
    .eb-event-container h2,
    .eb-event-container h3 {
        font-size: 1.2rem !important;
    }

    .eb-register-button,
    .btn-eb-register,
    a.eb-register-button,
    a.btn-eb-register,
    input.eb-register-button,
    button.eb-register-button {
        width: 100%;
        text-align: center;
        padding: 13px 18px !important;
    }
}
/* ===== AGENDA / SESSIONS PREMIUM ===== */

.eb-container,
.eb-events,
.events-calendar-container {
    max-width: 1100px;
    margin: 35px auto 50px auto;
    padding: 0 15px;
}

/* Masque le titre anglais brut si nécessaire */
.page-header + h2,
h2.eb-heading,
.events-calendar-container h2 {
    text-align: center;
    font-size: 2rem;
    color: #22356f;
    margin-bottom: 25px;
    font-weight: 800;
}

/* ===== vue tableau / calendrier par défaut ===== */
table.table,
.eb-table,
.events-calendar-container table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0 14px;
    background: transparent;
}

table.table thead th,
.eb-table thead th,
.events-calendar-container table thead th {
    background: transparent;
    border: none;
    color: #22356f;
    font-size: 0.9rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    padding: 0 14px 8px 14px;
}

table.table tbody tr,
.eb-table tbody tr,
.events-calendar-container table tbody tr {
    background: #ffffff;
    box-shadow: 0 8px 25px rgba(0,0,0,0.05);
    transition: all 0.25s ease;
}

table.table tbody tr:hover,
.eb-table tbody tr:hover,
.events-calendar-container table tbody tr:hover {
    transform: translateY(-2px);
    box-shadow: 0 14px 30px rgba(0,0,0,0.08);
}

table.table tbody td,
.eb-table tbody td,
.events-calendar-container table tbody td {
    border-top: 1px solid #e6ebf3;
    border-bottom: 1px solid #e6ebf3;
    border-left: none;
    border-right: none;
    padding: 18px 16px;
    vertical-align: middle;
    font-size: 0.98rem;
    color: #24324f;
    background: #fff;
}

table.table tbody td:first-child,
.eb-table tbody td:first-child,
.events-calendar-container table tbody td:first-child {
    border-left: 1px solid #e6ebf3;
    border-top-left-radius: 16px;
    border-bottom-left-radius: 16px;
    font-weight: 700;
    color: #1f3163;
}

table.table tbody td:last-child,
.eb-table tbody td:last-child,
.events-calendar-container table tbody td:last-child {
    border-right: 1px solid #e6ebf3;
    border-top-right-radius: 16px;
    border-bottom-right-radius: 16px;
}

/* liens */
table.table a,
.eb-table a,
.events-calendar-container table a {
    color: #22356f;
    font-weight: 700;
    text-decoration: none;
}

table.table a:hover,
.eb-table a:hover,
.events-calendar-container table a:hover {
    color: #3450a2;
    text-decoration: none;
}

/* bouton type action */
.btn,
.eb-btn,
a.btn,
input.btn {
    border-radius: 999px !important;
    padding: 10px 18px !important;
    font-weight: 700 !important;
    border: none !important;
    background: linear-gradient(90deg, #22356f 0%, #3450a2 100%) !important;
    color: #fff !important;
    box-shadow: 0 8px 18px rgba(34,53,111,0.18);
}

.btn:hover,
.eb-btn:hover,
a.btn:hover,
input.btn:hover {
    transform: translateY(-1px);
    background: #1d2f65 !important;
    color: #fff !important;
}

/* responsive */
@media (max-width: 768px) {
    table.table thead,
    .eb-table thead,
    .events-calendar-container table thead {
        display: none;
    }

    table.table,
    table.table tbody,
    table.table tr,
    table.table td,
    .eb-table,
    .eb-table tbody,
    .eb-table tr,
    .eb-table td,
    .events-calendar-container table,
    .events-calendar-container table tbody,
    .events-calendar-container table tr,
    .events-calendar-container table td {
        display: block;
        width: 100%;
    }

    table.table tbody tr,
    .eb-table tbody tr,
    .events-calendar-container table tbody tr {
        margin-bottom: 16px;
        border-radius: 16px;
        overflow: hidden;
    }

    table.table tbody td,
    .eb-table tbody td,
    .events-calendar-container table tbody td {
        border: none !important;
        border-bottom: 1px solid #eef2f7 !important;
        border-radius: 0 !important;
        padding: 14px 16px;
    }

    table.table tbody td:last-child,
    .eb-table tbody td:last-child,
    .events-calendar-container table tbody td:last-child {
        border-bottom: none !important;
    }
}
/* =========================================================
   EVENTS BOOKING - DETAIL EVENEMENT PREMIUM GLOBAL V2
   Pour toutes les fiches événement
   ========================================================= */


/* =========================================================
   1. CONTENEUR GLOBAL
   ========================================================= */
#eb-event-page,
.eb-event-page,
.eb-container,
.event-details-container {
    max-width: 1180px;
    margin: 32px auto 60px auto;
    padding: 0 16px;
    box-sizing: border-box;
}


/* =========================================================
   2. ZONE PRINCIPALE
   ========================================================= */
#eb-event-page .eb-box,
.eb-event-page .eb-box,
#eb-event-page .event-main-box,
.eb-event-page .event-main-box,
.event-details-container .event-main-box,
#eb-event-page .eb-event-container,
.eb-event-page .eb-event-container {
    background: #ffffff;
    border: 1px solid #e3e8f2;
    border-radius: 24px;
    box-shadow: 0 16px 40px rgba(0, 0, 0, 0.05);
    padding: 28px;
    overflow: hidden;
    box-sizing: border-box;
}


/* =========================================================
   3. FIL D’ARIANE
   ========================================================= */
.breadcrumb {
    margin-bottom: 18px;
    font-size: 0.95rem;
}

.breadcrumb a {
    color: #4b5d8a;
    text-decoration: none;
}

.breadcrumb a:hover {
    color: #22356f;
}


/* =========================================================
   4. TITRES
   ========================================================= */
#eb-event-page h1,
.eb-event-page h1,
.page-header h1,
.eb-event-title {
    margin: 0 0 18px 0;
    font-size: 2.35rem;
    line-height: 1.15;
    font-weight: 800;
    color: #1f3163;
    text-align: center;
    letter-spacing: -0.02em;
}

#eb-event-page h2,
.eb-event-page h2,
#eb-event-page h3,
.eb-event-page h3 {
    color: #22356f;
    font-weight: 800;
    line-height: 1.25;
}

#eb-event-page h2,
.eb-event-page h2 {
    font-size: 1.5rem;
    margin: 8px 0 16px 0;
}

#eb-event-page h3,
.eb-event-page h3 {
    font-size: 1.2rem;
    margin: 24px 0 14px 0;
}


/* =========================================================
   5. BLOC INTRO / HERO
   ========================================================= */
#eb-event-page .eb-description,
.eb-event-page .eb-description,
#eb-event-page .event-description,
.eb-event-page .event-description,
#eb-event-page .event-header,
.eb-event-page .event-header,
#eb-event-page .eb-event-description,
.eb-event-page .eb-event-description {
    background: linear-gradient(180deg, #f5f8fd 0%, #eef3fb 100%);
    border: 1px solid #dbe4f0;
    border-radius: 22px;
    padding: 28px 26px;
    margin-bottom: 28px;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9);
}


/* =========================================================
   6. TEXTE GENERAL
   ========================================================= */
#eb-event-page p,
.eb-event-page p,
#eb-event-page li,
.eb-event-page li,
#eb-event-page div,
.eb-event-page div {
    color: #33415c;
    font-size: 1rem;
    line-height: 1.75;
}

#eb-event-page ul,
.eb-event-page ul {
    padding-left: 20px;
}

#eb-event-page li,
.eb-event-page li {
    margin-bottom: 6px;
}


/* =========================================================
   7. LIENS
   ========================================================= */
#eb-event-page a,
.eb-event-page a {
    color: #22356f;
    text-decoration: none;
    transition: color 0.2s ease;
}

#eb-event-page a:hover,
.eb-event-page a:hover {
    color: #3450a2;
}


/* =========================================================
   8. DATE / META EVENEMENT
   Mise en valeur si Events Booking utilise ces classes
   ========================================================= */
#eb-event-page .eb-event-date,
.eb-event-page .eb-event-date,
#eb-event-page .event-date,
.eb-event-page .event-date,
#eb-event-page .eb-event-info,
.eb-event-page .eb-event-info,
#eb-event-page .event-meta,
.eb-event-page .event-meta {
    display: inline-block;
    background: #ffffff;
    border: 1px solid #dbe4f0;
    border-radius: 999px;
    padding: 10px 18px;
    margin: 6px 0 20px 0;
    color: #22356f;
    font-size: 0.98rem;
    font-weight: 700;
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.04);
}

#eb-event-page .eb-event-date *,
.eb-event-page .eb-event-date *,
#eb-event-page .event-date *,
.eb-event-page .event-date *,
#eb-event-page .eb-event-info *,
.eb-event-page .eb-event-info *,
#eb-event-page .event-meta *,
.eb-event-page .event-meta * {
    display: inline !important;
    margin: 0 4px 0 0;
    color: inherit;
    font-size: inherit;
    line-height: inherit;
}


/* =========================================================
   9. BOUTONS PREMIUM
   ========================================================= */
#eb-event-page .btn,
.eb-event-page .btn,
#eb-event-page .eb-btn,
.eb-event-page .eb-btn,
#eb-event-page a.btn,
.eb-event-page a.btn,
#eb-event-page input.btn,
.eb-event-page input.btn,
#eb-event-page button.btn,
.eb-event-page button.btn,
#eb-event-page .btn-primary,
.eb-event-page .btn-primary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    padding: 12px 22px !important;
    margin: 6px 10px 10px 0;
    border: none !important;
    border-radius: 999px !important;
    background: linear-gradient(90deg, #22356f 0%, #3450a2 100%) !important;
    color: #ffffff !important;
    font-weight: 800 !important;
    font-size: 0.95rem !important;
    letter-spacing: 0.01em;
    text-decoration: none !important;
    box-shadow: 0 10px 24px rgba(34, 53, 111, 0.18);
    transition: all 0.25s ease;
    cursor: pointer;
}

#eb-event-page .btn:hover,
.eb-event-page .btn:hover,
#eb-event-page .eb-btn:hover,
.eb-event-page .eb-btn:hover,
#eb-event-page a.btn:hover,
.eb-event-page a.btn:hover,
#eb-event-page input.btn:hover,
.eb-event-page input.btn:hover,
#eb-event-page button.btn:hover,
.eb-event-page button.btn:hover,
#eb-event-page .btn-primary:hover,
.eb-event-page .btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 16px 30px rgba(34, 53, 111, 0.22);
    background: linear-gradient(90deg, #1c2d61 0%, #2d4695 100%) !important;
    color: #ffffff !important;
}


/* =========================================================
   BOUTONS INSCRIPTION - CORRECTION COULEUR COMPLETE
   ========================================================= */
#eb-event-page .btn,
.eb-event-page .btn,
#eb-event-page .eb-btn,
.eb-event-page .eb-btn,
#eb-event-page a.btn,
.eb-event-page a.btn,
#eb-event-page input.btn,
.eb-event-page input.btn,
#eb-event-page button.btn,
.eb-event-page button.btn,
#eb-event-page .btn-primary,
.eb-event-page .btn-primary,
#eb-event-page .eb-register-buttons a,
.eb-event-page .eb-register-buttons a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    padding: 12px 22px !important;
    margin: 6px 10px 10px 0;
    border: none !important;
    border-radius: 999px !important;
    background: linear-gradient(90deg, #22356f 0%, #3450a2 100%) !important;
    color: #ffffff !important;
    font-weight: 800 !important;
    font-size: 0.95rem !important;
    letter-spacing: 0.01em;
    text-decoration: none !important;
    box-shadow: 0 10px 24px rgba(34, 53, 111, 0.18);
    transition: all 0.25s ease;
    cursor: pointer;
}

/* force aussi la couleur sur le texte interne */
#eb-event-page .btn *,
.eb-event-page .btn *,
#eb-event-page .eb-btn *,
.eb-event-page .eb-btn *,
#eb-event-page a.btn *,
.eb-event-page a.btn *,
#eb-event-page .btn-primary *,
.eb-event-page .btn-primary *,
#eb-event-page .eb-register-buttons a *,
.eb-event-page .eb-register-buttons a * {
    color: #ffffff !important;
    fill: #ffffff !important;
}

/* hover */
#eb-event-page .btn:hover,
.eb-event-page .btn:hover,
#eb-event-page .eb-btn:hover,
.eb-event-page .eb-btn:hover,
#eb-event-page a.btn:hover,
.eb-event-page a.btn:hover,
#eb-event-page input.btn:hover,
.eb-event-page input.btn:hover,
#eb-event-page button.btn:hover,
.eb-event-page button.btn:hover,
#eb-event-page .btn-primary:hover,
.eb-event-page .btn-primary:hover,
#eb-event-page .eb-register-buttons a:hover,
.eb-event-page .eb-register-buttons a:hover {
    transform: translateY(-2px);
    box-shadow: 0 16px 30px rgba(34, 53, 111, 0.22);
    background: linear-gradient(90deg, #1c2d61 0%, #2d4695 100%) !important;
    color: #ffffff !important;
}

/* hover aussi sur texte interne */
#eb-event-page .btn:hover *,
.eb-event-page .btn:hover *,
#eb-event-page .eb-btn:hover *,
.eb-event-page .eb-btn:hover *,
#eb-event-page a.btn:hover *,
.eb-event-page a.btn:hover *,
#eb-event-page .btn-primary:hover *,
.eb-event-page .btn-primary:hover *,
#eb-event-page .eb-register-buttons a:hover *,
.eb-event-page .eb-register-buttons a:hover * {
    color: #ffffff !important;
    fill: #ffffff !important;
}


/* =========================================================
   11. CARTE INFOS PRATIQUES / PROPRIETES
   ========================================================= */
#eb-event-page .eb-event-properties,
.eb-event-page .eb-event-properties,
#eb-event-page .event-properties,
.eb-event-page .event-properties,
#eb-event-page .eb-property-container,
.eb-event-page .eb-property-container,
#eb-event-page dl,
.eb-event-page dl {
    background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
    border: 1px solid #dfe8f3;
    border-radius: 22px;
    padding: 24px;
    margin: 28px 0 22px 0;
    box-shadow: 0 12px 30px rgba(20, 40, 90, 0.06);
    box-sizing: border-box;
}

/* structure générique */
#eb-event-page .row,
.eb-event-page .row,
#eb-event-page .eb-property-row,
.eb-event-page .eb-property-row,
#eb-event-page dt,
.eb-event-page dt,
#eb-event-page dd,
.eb-event-page dd {
    box-sizing: border-box;
}

/* lignes internes */
#eb-event-page .eb-event-properties .row,
.eb-event-page .eb-event-properties .row,
#eb-event-page .event-properties .row,
.eb-event-page .event-properties .row,
#eb-event-page .eb-property-container .row,
.eb-event-page .eb-property-container .row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 18px;
    padding: 12px 0;
    border-bottom: 1px solid #e7edf5;
}

#eb-event-page .eb-event-properties .row:last-child,
.eb-event-page .eb-event-properties .row:last-child,
#eb-event-page .event-properties .row:last-child,
.eb-event-page .event-properties .row:last-child,
#eb-event-page .eb-property-container .row:last-child,
.eb-event-page .eb-property-container .row:last-child {
    border-bottom: none;
}

/* labels / valeurs */
#eb-event-page strong,
.eb-event-page strong,
#eb-event-page b,
.eb-event-page b,
#eb-event-page dt,
.eb-event-page dt,
#eb-event-page .eb-label,
.eb-event-page .eb-label {
    color: #22356f;
    font-weight: 800;
}

#eb-event-page dd,
.eb-event-page dd,
#eb-event-page .eb-value,
.eb-event-page .eb-value {
    color: #33415c;
    margin-bottom: 10px;
}


/* =========================================================
   12. BAS DE PAGE / INFOS COMPLEMENTAIRES
   ========================================================= */
#eb-event-page .event-footer,
.eb-event-page .event-footer,
#eb-event-page .in-practice,
.eb-event-page .in-practice,
#eb-event-page .eb-footer-box,
.eb-event-page .eb-footer-box {
    margin-top: 28px;
    padding: 18px 20px;
    border: 1px solid #e6edf5;
    border-radius: 18px;
    background: #ffffff;
}


/* =========================================================
   13. MASQUER DOUBLONS COURANTS
   ========================================================= */

/* Titre répété sous le H1 */
#eb-event-page .page-header + .event-title-link,
.eb-event-page .page-header + .event-title-link,
#eb-event-page .eb-event-link-title,
.eb-event-page .eb-event-link-title,
#eb-event-page .event-title-link,
.eb-event-page .event-title-link {
    display: none !important;
}

/* Certains liens répétés juste sous le titre */
#eb-event-page a[href*="/agenda/"][title],
.eb-event-page a[href*="/agenda/"][title] {
    display: none !important;
}

/* Lien retour si brut */
#eb-event-page .back-link,
.eb-event-page .back-link {
    opacity: 0.85;
    font-weight: 600;
}

/* Cache éventuel second bloc d’actions en bas si doublon */
#eb-event-page .event-actions-bottom,
.eb-event-page .event-actions-bottom,
#eb-event-page .booking-buttons-bottom,
.eb-event-page .booking-buttons-bottom {
    display: none !important;
}


/* =========================================================
   14. IMAGES
   ========================================================= */
#eb-event-page img,
.eb-event-page img {
    max-width: 100%;
    height: auto;
    border-radius: 14px;
}


/* =========================================================
   15. TABLEAUX EVENTUELS
   ========================================================= */
#eb-event-page table,
.eb-event-page table {
    width: 100%;
    border-collapse: collapse;
    margin: 18px 0;
}

#eb-event-page table td,
.eb-event-page table td,
#eb-event-page table th,
.eb-event-page table th {
    border: 1px solid #e6edf5;
    padding: 12px 14px;
    text-align: left;
}

#eb-event-page table th,
.eb-event-page table th {
    background: #f5f8fd;
    color: #22356f;
    font-weight: 800;
}


/* =========================================================
   16. RESPONSIVE TABLET
   ========================================================= */
@media (max-width: 991px) {
    #eb-event-page h1,
    .eb-event-page h1,
    .page-header h1,
    .eb-event-title {
        font-size: 1.95rem;
    }

    #eb-event-page .eb-box,
    .eb-event-page .eb-box,
    #eb-event-page .event-main-box,
    .eb-event-page .event-main-box,
    .event-details-container .event-main-box,
    #eb-event-page .eb-event-container,
    .eb-event-page .eb-event-container {
        padding: 22px;
    }
}


/* =========================================================
   17. RESPONSIVE MOBILE
   ========================================================= */
@media (max-width: 768px) {
    #eb-event-page,
    .eb-event-page,
    .eb-container,
    .event-details-container {
        padding: 0 12px;
    }

    #eb-event-page h1,
    .eb-event-page h1,
    .page-header h1,
    .eb-event-title {
        font-size: 1.7rem;
        line-height: 1.2;
    }

    #eb-event-page .eb-description,
    .eb-event-page .eb-description,
    #eb-event-page .event-description,
    .eb-event-page .event-description,
    #eb-event-page .event-header,
    .eb-event-page .event-header,
    #eb-event-page .eb-event-description,
    .eb-event-page .eb-event-description,
    #eb-event-page .eb-event-properties,
    .eb-event-page .eb-event-properties,
    #eb-event-page .event-properties,
    .eb-event-page .event-properties,
    #eb-event-page .eb-property-container,
    .eb-event-page .eb-property-container {
        padding: 18px 16px;
    }

    #eb-event-page .btn,
    .eb-event-page .btn,
    #eb-event-page .eb-btn,
    .eb-event-page .eb-btn,
    #eb-event-page a.btn,
    .eb-event-page a.btn,
    #eb-event-page input.btn,
    .eb-event-page input.btn,
    #eb-event-page button.btn,
    .eb-event-page button.btn,
    #eb-event-page .btn-primary,
    .eb-event-page .btn-primary {
        display: flex;
        width: 100%;
        margin-right: 0 !important;
    }

    #eb-event-page .eb-event-properties .row,
    .eb-event-page .eb-event-properties .row,
    #eb-event-page .event-properties .row,
    .eb-event-page .event-properties .row,
    #eb-event-page .eb-property-container .row,
    .eb-event-page .eb-property-container .row {
        display: block;
    }

    #eb-event-page .eb-event-date,
    .eb-event-page .eb-event-date,
    #eb-event-page .event-date,
    .eb-event-page .event-date,
    #eb-event-page .eb-event-info,
    .eb-event-page .eb-event-info,
    #eb-event-page .event-meta,
    .eb-event-page .event-meta {
        display: block;
        border-radius: 18px;
        padding: 12px 14px;
    }
}
