/* ================================================================
   FICHIER  : assets/css/style.css
   PROJET   : Bambey Sérère TV
   COULEURS : Extraites du logo BSTV
              - Bleu  : #1E6FD9 (diamant bleu logo)
              - Rouge : #D42B2B (arc rouge logo)
              - Blanc : #FFFFFF
              - Noir  : #0A0A0A
================================================================ */

/* ================================================================
   01. VARIABLES & RESET
================================================================ */
:root {
    --bleu          : #1E6FD9;
    --bleu-fonce    : #1455A8;
    --bleu-clair    : #3D8EF0;
    --bleu-pale     : #EAF2FF;
    --rouge         : #D42B2B;
    --rouge-fonce   : #A81E1E;
    --rouge-clair   : #F04040;
    --noir          : #0D0D0D;
    --gris-sombre   : #1A1A2E;
    --gris-moyen    : #1F2637;
    --gris-clair    : #F4F6FB;
    --blanc         : #FFFFFF;

    --texte-titre     : #0D1225;
    --texte-corps     : #374060;
    --texte-secondaire: #6B7A99;
    --texte-muted     : #9BAABE;
    --texte-clair     : #E8ECF5;
    --texte-tres-clair: #B0BBCC;

    --bordure       : #E2E8F5;
    --bordure-sombre: #1E2840;

    --ombre-xs : 0 1px 4px  rgba(0,0,0,0.06);
    --ombre-sm : 0 2px 12px rgba(0,0,0,0.08);
    --ombre-md : 0 6px 24px rgba(0,0,0,0.11);
    --ombre-lg : 0 14px 48px rgba(0,0,0,0.16);
    --ombre-xl : 0 24px 70px rgba(0,0,0,0.22);

    --font-titre : 'Oswald', sans-serif;
    --font-corps : 'Source Sans 3', sans-serif;

    --r-xs  : 4px;
    --r-sm  : 8px;
    --r-md  : 14px;
    --r-lg  : 20px;
    --r-xl  : 28px;
    --r-pill: 999px;

    --tr : 0.24s ease;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior: smooth; }

body {
    font-family: var(--font-corps);
    background : var(--blanc);
    color      : var(--texte-corps);
    font-size  : 1rem;
    line-height: 1.65;
    -webkit-font-smoothing: antialiased;
}

img { max-width:100%; height:auto; display:block; }
a   { color:var(--bleu); transition:color var(--tr); }

/* ================================================================
   02. TYPOGRAPHIE
================================================================ */
h1,h2,h3,h4,h5,h6 {
    font-family: var(--font-titre);
    line-height: 1.15;
    color      : var(--texte-titre);
}

/* ================================================================
   03. TOPBAR
================================================================ */
.topbar {
    background   : var(--bleu);
    color        : var(--blanc);
    font-size    : 0.76rem;
    padding      : 7px 0;
    border-bottom: 3px solid var(--rouge);
    overflow     : hidden;
}

.topbar .live-badge {
    background    : var(--rouge);
    color         : var(--blanc);
    font-weight   : 700;
    font-size     : 0.68rem;
    padding       : 3px 12px;
    letter-spacing: 2px;
    text-transform: uppercase;
    white-space   : nowrap;
    flex-shrink   : 0;
    animation     : pulse-badge 2s infinite;
}

@keyframes pulse-badge {
    0%,100% { opacity:1; }
    50%     { opacity:0.6; }
}

.topbar .ticker-text {
    white-space : nowrap;
    overflow    : hidden;
    flex        : 1;
    padding-left: 16px;
}

.topbar .ticker-text span {
    display  : inline-block;
    animation: ticker-scroll 34s linear infinite;
    font-size: 0.78rem;
    color    : rgba(255,255,255,0.9);
}

@keyframes ticker-scroll {
    0%   { transform: translateX(100%); }
    100% { transform: translateX(-100%); }
}

.topbar .social-icons a {
    color          : rgba(255,255,255,0.8);
    margin-left    : 14px;
    font-size      : 0.92rem;
    text-decoration: none;
    transition     : color var(--tr);
}

.topbar .social-icons a:hover { color: var(--blanc); }

/* ================================================================
   04. NAVBAR
================================================================ */
.navbar-bstv {
    background   : var(--blanc);
    padding      : 0;
    min-height   : 72px;
    position     : sticky;
    top          : 0;
    z-index      : 1030;
    box-shadow   : 0 2px 16px rgba(0,0,0,0.10);
    border-bottom: 3px solid var(--rouge);
}

/* Logo */
.navbar-bstv .navbar-brand {
    display        : flex;
    align-items    : center;
    gap            : 12px;
    padding        : 8px 0;
    text-decoration: none;
}

.logo-img-wrap {
    width          : 56px;
    height         : 56px;
    border-radius  : var(--r-sm);
    overflow       : hidden;
    flex-shrink    : 0;
    display        : flex;
    align-items    : center;
    justify-content: center;
    background     : var(--blanc);
}

.logo-img-wrap img {
    width     : 100%;
    height    : 100%;
    object-fit: contain;
}

.logo-text {
    display       : flex;
    flex-direction: column;
    line-height   : 1.1;
}

.logo-text .brand-main {
    font-family   : var(--font-titre);
    font-size     : 1.35rem;
    font-weight   : 700;
    color         : var(--texte-titre);
    letter-spacing: 0.4px;
}

.logo-text .brand-main span { color: var(--rouge); }

.logo-text .brand-sub {
    font-size     : 0.60rem;
    color         : var(--texte-secondaire);
    letter-spacing: 2.5px;
    text-transform: uppercase;
    font-weight   : 400;
    margin-top    : 2px;
}

/* Liens menu */
.navbar-bstv .navbar-nav {
    gap        : 3px;
    align-items: center;
}

.navbar-bstv .nav-link {
    font-family   : var(--font-titre);
    font-size     : 0.92rem;
    font-weight   : 500;
    letter-spacing: 0.8px;
    color         : var(--texte-titre) !important;
    text-transform: uppercase;
    padding       : 8px 14px !important;
    border-radius : var(--r-sm);
    position      : relative;
    transition    : color var(--tr), background var(--tr);
    white-space   : nowrap;
}

.navbar-bstv .nav-link::after {
    content      : '';
    position     : absolute;
    bottom       : 0;
    left         : 50%;
    transform    : translateX(-50%) scaleX(0);
    width        : 68%;
    height       : 2px;
    background   : var(--rouge);
    border-radius: 2px;
    transition   : transform 0.28s ease;
}

.navbar-bstv .nav-link:hover::after,
.navbar-bstv .nav-link.active::after { transform: translateX(-50%) scaleX(1); }

.navbar-bstv .nav-link:hover {
    color     : var(--bleu) !important;
    background: var(--bleu-pale);
}

.navbar-bstv .nav-link.active {
    color     : var(--bleu) !important;
    background: var(--bleu-pale);
}

/* Bouton LIVE */
.nav-btn-live {
    font-family   : var(--font-titre) !important;
    font-size     : 0.84rem !important;
    font-weight   : 700 !important;
    letter-spacing: 1.5px !important;
    text-transform: uppercase !important;
    color         : var(--blanc) !important;
    background    : var(--rouge) !important;
    border        : none !important;
    padding       : 7px 20px !important;
    border-radius : var(--r-pill) !important;
    margin-left   : 10px !important;
    transition    : all 0.2s !important;
    box-shadow    : 0 4px 16px rgba(212,43,43,0.35) !important;
}

.nav-btn-live::after { display:none !important; }

.nav-btn-live:hover {
    background: var(--rouge-fonce) !important;
    transform : translateY(-2px) !important;
    box-shadow: 0 8px 22px rgba(212,43,43,0.5) !important;
    color     : var(--blanc) !important;
}

.live-dot {
    display      : inline-block;
    width        : 7px;
    height       : 7px;
    background   : var(--blanc);
    border-radius: 50%;
    margin-right : 5px;
    vertical-align: middle;
    animation    : blink-dot 1.2s infinite;
}

@keyframes blink-dot {
    0%,100% { opacity:1; }
    50%     { opacity:0; }
}

/* Hamburger mobile */
.navbar-toggler {
    border       : 2px solid var(--bleu) !important;
    border-radius: var(--r-sm) !important;
    padding      : 5px 9px !important;
    width        : 42px !important;
    height       : 38px !important;
}

.navbar-toggler-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(30,111,217,1)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2.5' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") !important;
}

@media (max-width: 991.98px) {
    .navbar-bstv .navbar-collapse {
        background   : var(--blanc);
        border-top   : 2px solid var(--bordure);
        padding      : 14px 16px;
        border-radius: 0 0 14px 14px;
        box-shadow   : 0 8px 24px rgba(0,0,0,0.10);
        margin-top   : 4px;
    }

    .navbar-bstv .nav-link {
        padding      : 11px 14px !important;
        border-radius: var(--r-sm);
        color        : var(--texte-titre) !important;
    }

    .navbar-bstv .nav-link::after { display:none; }

    .nav-btn-live {
        margin-left: 0 !important;
        margin-top : 10px !important;
        display    : inline-block !important;
    }
}

/* ================================================================
   05. FOOTER
================================================================ */
.site-footer {
    background : var(--gris-sombre);
    color      : var(--texte-secondaire);
    padding-top: 64px;
    font-size  : 0.91rem;
}

.footer-separator {
    height    : 4px;
    background: linear-gradient(90deg, var(--bleu), var(--rouge));
}

.footer-brand .brand-title {
    font-family   : var(--font-titre);
    font-size     : 1.5rem;
    font-weight   : 700;
    color         : var(--blanc);
}

.footer-brand .brand-title span { color: var(--rouge); }

.footer-brand .brand-tagline {
    font-size     : 0.62rem;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    color         : #4A5A7A;
    margin-top    : 3px;
    display       : block;
}

.footer-desc { color:#4A5A7A; line-height:1.75; font-size:0.87rem; }

.social-label {
    font-size     : 0.68rem;
    text-transform: uppercase;
    letter-spacing: 2px;
    color         : #3A4A68;
    font-weight   : 600;
}

.social-links { display:flex; gap:10px; flex-wrap:wrap; }

.social-btn {
    width          : 40px;
    height         : 40px;
    border-radius  : 50%;
    background     : #121826;
    color          : #6680AA;
    font-size      : 1rem;
    text-decoration: none;
    border         : 1px solid #1E2840;
    display        : flex;
    align-items    : center;
    justify-content: center;
    transition     : all 0.25s;
}

.social-btn:hover              { transform:translateY(-3px); color:var(--blanc); }
.social-btn.facebook:hover     { background:#1877F2; border-color:#1877F2; }
.social-btn.youtube:hover      { background:#FF0000; border-color:#FF0000; }
.social-btn.twitter:hover      { background:#14171A; border-color:#555; }
.social-btn.instagram:hover    { background:linear-gradient(45deg,#F09433,#E6683C,#DC2743,#CC2366,#BC1888); border-color:transparent; }
.social-btn.tiktok:hover       { background:#010101; border-color:#69C9D0; color:#69C9D0; }

.footer-heading {
    font-family   : var(--font-titre);
    font-size     : 0.95rem;
    font-weight   : 600;
    color         : var(--blanc);
    text-transform: uppercase;
    letter-spacing: 1.8px;
    margin-bottom : 22px;
    padding-bottom: 10px;
    position      : relative;
}

.footer-heading::after {
    content      : '';
    position     : absolute;
    bottom       : 0; left:0;
    width        : 32px;
    height       : 2px;
    background   : var(--rouge);
    border-radius: 2px;
}

.footer-links { list-style:none; padding:0; margin:0; }
.footer-links li { margin-bottom:11px; }

.footer-links a {
    color          : #4A5A7A;
    text-decoration: none;
    display        : flex;
    align-items    : center;
    gap            : 7px;
    font-size      : 0.87rem;
    transition     : color 0.2s, padding-left 0.2s;
}

.footer-links a:hover { color:var(--blanc); padding-left:4px; }

.footer-contact-list {
    list-style    : none;
    padding       : 0; margin:0;
    display       : flex;
    flex-direction: column;
    gap           : 14px;
}

.footer-contact-list li { display:flex; align-items:flex-start; gap:13px; }

.contact-icon {
    width          : 38px;
    height         : 38px;
    background     : rgba(30,111,217,0.14);
    border         : 1px solid rgba(30,111,217,0.28);
    border-radius  : var(--r-sm);
    display        : flex;
    align-items    : center;
    justify-content: center;
    color          : var(--bleu);
    font-size      : 0.92rem;
    flex-shrink    : 0;
}

.contact-text {
    display       : flex;
    flex-direction: column;
    color         : #4A5A7A;
    font-size     : 0.87rem;
    line-height   : 1.5;
}

.contact-text a { color:#4A5A7A; text-decoration:none; transition:color 0.2s; }
.contact-text a:hover { color:var(--bleu); }

.btn-contact-footer {
    display        : inline-flex;
    align-items    : center;
    gap            : 7px;
    background     : transparent;
    border         : 1.5px solid var(--bleu);
    color          : var(--bleu);
    padding        : 9px 20px;
    border-radius  : var(--r-pill);
    font-size      : 0.84rem;
    font-weight    : 600;
    text-decoration: none;
    transition     : all 0.24s;
}

.btn-contact-footer:hover {
    background: var(--bleu);
    color     : var(--blanc);
    transform : translateY(-2px);
}

.footer-bottom {
    background : rgba(0,0,0,0.3);
    border-top : 1px solid var(--bordure-sombre);
    padding    : 18px 0;
    margin-top : 52px;
    font-size  : 0.8rem;
    color      : #3A4A68;
}

.footer-legal-links { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.footer-legal-links a { color:#3A4A68; text-decoration:none; font-size:0.8rem; transition:color 0.2s; }
.footer-legal-links a:hover { color:var(--bleu); }
.footer-legal-links .separator { color:#1A2A48; }

/* ================================================================
   06. BOUTON RETOUR EN HAUT
================================================================ */
.back-to-top {
    position       : fixed;
    bottom         : 28px; right:28px;
    width          : 46px; height:46px;
    border-radius  : 50%;
    background     : var(--rouge);
    color          : var(--blanc);
    border         : none;
    font-size      : 1.5rem;
    display        : flex;
    align-items    : center;
    justify-content: center;
    cursor         : pointer;
    opacity        : 0;
    visibility     : hidden;
    transition     : all 0.3s;
    z-index        : 999;
    box-shadow     : 0 4px 18px rgba(212,43,43,0.45);
}

.back-to-top.visible { opacity:1; visibility:visible; }
.back-to-top:hover   { background:var(--rouge-fonce); transform:translateY(-3px); }

/* ================================================================
   07. COMPOSANTS COMMUNS
================================================================ */

/* Hero page intérieure */
.page-hero {
    background: linear-gradient(135deg, var(--bleu-fonce) 0%, var(--bleu) 100%);
    padding   : 72px 0 52px;
    color     : var(--blanc);
    position  : relative;
    overflow  : hidden;
}

.page-hero::after {
    content         : '';
    position        : absolute;
    inset           : 0;
    background-image: radial-gradient(rgba(255,255,255,0.04) 1px, transparent 1px);
    background-size : 30px 30px;
}

.page-hero .container { position:relative; z-index:1; }

.page-hero h1 {
    font-family: var(--font-titre);
    font-size  : 2.5rem;
    font-weight: 700;
    color      : var(--blanc);
}

.page-hero p { color:rgba(255,255,255,0.75); font-size:1rem; }

.breadcrumb-bstv { font-size:0.8rem; }
.breadcrumb-bstv .breadcrumb-item a { color:rgba(255,255,255,0.6); text-decoration:none; transition:color var(--tr); }
.breadcrumb-bstv .breadcrumb-item a:hover { color:var(--blanc); }
.breadcrumb-bstv .breadcrumb-item.active { color:rgba(255,255,255,0.85); }
.breadcrumb-bstv .breadcrumb-item + .breadcrumb-item::before { color:rgba(255,255,255,0.35); }

/* En-tête section */
.section-header { text-align:center; margin-bottom:52px; }

.section-label {
    display       : inline-block;
    font-size     : 0.7rem;
    font-weight   : 700;
    letter-spacing: 3px;
    text-transform: uppercase;
    color         : var(--rouge);
    margin-bottom : 12px;
}

.section-label.light { color:#FF8A80; }

.section-title {
    font-family: var(--font-titre);
    font-size  : 2.2rem;
    font-weight: 700;
    color      : var(--texte-titre);
    margin     : 0;
    line-height: 1.15;
}

.section-title.light { color:var(--blanc); }
.section-title span  { color:var(--rouge); }

.section-line {
    width        : 52px;
    height       : 3px;
    background   : linear-gradient(90deg, var(--bleu), var(--rouge));
    border-radius: 2px;
    margin       : 16px auto 0;
}

/* Bouton voir tout */
.btn-voir-tout {
    font-family    : var(--font-titre);
    font-size      : 0.84rem;
    font-weight    : 600;
    letter-spacing : 1.2px;
    text-transform : uppercase;
    color          : var(--bleu);
    text-decoration: none;
    display        : inline-flex;
    align-items    : center;
    gap            : 7px;
    border         : 2px solid var(--bleu);
    padding        : 9px 24px;
    border-radius  : var(--r-pill);
    transition     : all 0.24s;
}

.btn-voir-tout:hover { background:var(--bleu); color:var(--blanc); transform:translateX(4px); }

.btn-voir-tout.light { color:#7ABAFF; border-color:rgba(122,186,255,0.35); }
.btn-voir-tout.light:hover { background:rgba(122,186,255,0.14); color:var(--blanc); }

/* Boutons principaux */
.btn-bstv-rouge {
    background     : var(--rouge);
    color          : var(--blanc);
    border         : none;
    padding        : 12px 30px;
    border-radius  : var(--r-pill);
    font-family    : var(--font-titre);
    font-size      : 0.94rem;
    font-weight    : 600;
    letter-spacing : 1px;
    text-transform : uppercase;
    text-decoration: none;
    display        : inline-flex;
    align-items    : center;
    gap            : 8px;
    transition     : all 0.24s;
    box-shadow     : 0 4px 18px rgba(212,43,43,0.35);
    cursor         : pointer;
}

.btn-bstv-rouge:hover { background:var(--rouge-fonce); color:var(--blanc); transform:translateY(-3px); box-shadow:0 8px 28px rgba(212,43,43,0.5); }

.btn-bstv-bleu {
    background     : var(--bleu);
    color          : var(--blanc);
    border         : none;
    padding        : 12px 30px;
    border-radius  : var(--r-pill);
    font-family    : var(--font-titre);
    font-size      : 0.94rem;
    font-weight    : 600;
    letter-spacing : 1px;
    text-transform : uppercase;
    text-decoration: none;
    display        : inline-flex;
    align-items    : center;
    gap            : 8px;
    transition     : all 0.24s;
    box-shadow     : 0 4px 18px rgba(30,111,217,0.35);
    cursor         : pointer;
}

.btn-bstv-bleu:hover { background:var(--bleu-fonce); color:var(--blanc); transform:translateY(-3px); }

.btn-bstv-outline {
    background     : transparent;
    color          : var(--bleu);
    border         : 2px solid var(--bleu);
    padding        : 11px 30px;
    border-radius  : var(--r-pill);
    font-family    : var(--font-titre);
    font-size      : 0.94rem;
    font-weight    : 600;
    letter-spacing : 1px;
    text-transform : uppercase;
    text-decoration: none;
    display        : inline-flex;
    align-items    : center;
    gap            : 8px;
    transition     : all 0.24s;
}

.btn-bstv-outline:hover { background:var(--bleu); color:var(--blanc); }

/* ================================================================
   08. PAGE ACCUEIL — Hero
================================================================ */
.hero-section {
    background : linear-gradient(150deg, #0D1B3E 0%, #1455A8 50%, #1E6FD9 100%);
    min-height : 88vh;
    display    : flex;
    align-items: center;
    position   : relative;
    overflow   : hidden;
}

.hero-section::before {
    content   : '';
    position  : absolute;
    inset     : 0;
    background:
        radial-gradient(circle at 80% 20%, rgba(212,43,43,0.18) 0%, transparent 45%),
        radial-gradient(circle at 10% 80%, rgba(255,255,255,0.04) 0%, transparent 40%);
}

.hero-section::after {
    content         : '';
    position        : absolute;
    inset           : 0;
    background-image: radial-gradient(rgba(255,255,255,0.04) 1px, transparent 1px);
    background-size : 32px 32px;
}

.hero-content { position:relative; z-index:2; }

.hero-badge {
    display       : inline-flex;
    align-items   : center;
    gap           : 8px;
    background    : rgba(255,255,255,0.10);
    border        : 1px solid rgba(255,255,255,0.22);
    color         : rgba(255,255,255,0.90);
    font-size     : 0.72rem;
    font-weight   : 600;
    letter-spacing: 2px;
    text-transform: uppercase;
    padding       : 6px 17px;
    border-radius : var(--r-pill);
    margin-bottom : 24px;
}

.hero-badge .dot {
    width        : 7px; height:7px;
    background   : var(--rouge);
    border-radius: 50%;
    animation    : blink-dot 1.3s infinite;
}

.hero-title {
    font-family  : var(--font-titre);
    font-size    : clamp(2.6rem, 6vw, 5rem);
    font-weight  : 700;
    color        : var(--blanc);
    line-height  : 1.04;
    margin-bottom: 24px;
}

.hero-title .accent { color:var(--rouge); }

.hero-desc {
    font-size    : 1.05rem;
    color        : rgba(255,255,255,0.72);
    max-width    : 520px;
    line-height  : 1.85;
    margin-bottom: 38px;
}

.hero-btns { display:flex; gap:14px; flex-wrap:wrap; }

.hero-visual { position:relative; z-index:2; }

.hero-tv-frame {
    background     : rgba(255,255,255,0.06);
    border         : 1px solid rgba(255,255,255,0.12);
    border-radius  : var(--r-xl);
    padding        : 22px;
    backdrop-filter: blur(10px);
}

.hero-stats-row {
    display        : flex;
    gap            : 18px;
    margin-top     : 18px;
    justify-content: center;
    flex-wrap      : wrap;
}

.hero-stat { text-align:center; }

.hero-stat strong {
    display    : block;
    font-family: var(--font-titre);
    font-size  : 1.45rem;
    color      : var(--rouge);
    line-height: 1.1;
}

.hero-stat span {
    font-size     : 0.7rem;
    color         : rgba(255,255,255,0.5);
    text-transform: uppercase;
    letter-spacing: 1.2px;
}

/* Stats bleu */
.section-bleu { background:linear-gradient(135deg, var(--bleu-fonce), var(--bleu)); padding:72px 0; }

.stat-item { text-align:center; color:var(--blanc); }

.stat-number {
    font-family  : var(--font-titre);
    font-size    : 3rem;
    font-weight  : 700;
    line-height  : 1;
    margin-bottom: 6px;
}

.stat-label {
    font-size     : 0.78rem;
    text-transform: uppercase;
    letter-spacing: 2px;
    opacity       : 0.72;
}

/* Carte vidéo */
.video-card {
    background    : var(--blanc);
    border-radius : var(--r-md);
    overflow      : hidden;
    box-shadow    : var(--ombre-sm);
    transition    : transform 0.3s, box-shadow 0.3s;
    height        : 100%;
    display       : flex;
    flex-direction: column;
    border        : 1px solid var(--bordure);
}

.video-card:hover { transform:translateY(-7px); box-shadow:var(--ombre-xl); }

.video-thumb {
    position    : relative;
    aspect-ratio: 16/9;
    background  : var(--noir);
    overflow    : hidden;
}

.video-thumb img { width:100%; height:100%; object-fit:cover; transition:transform 0.4s; }
.video-card:hover .video-thumb img { transform:scale(1.06); }

.video-thumb-placeholder {
    width          : 100%; height:100%;
    background     : linear-gradient(135deg, var(--bleu-fonce), var(--bleu));
    display        : flex;
    align-items    : center;
    justify-content: center;
    font-size      : 3rem;
}

.video-play-btn {
    position       : absolute;
    inset          : 0;
    display        : flex;
    align-items    : center;
    justify-content: center;
    background     : rgba(0,0,0,0.38);
    opacity        : 0;
    transition     : opacity 0.3s;
    text-decoration: none;
    border         : none;
    cursor         : pointer;
    width          : 100%;
}

.video-card:hover .video-play-btn { opacity:1; }

.play-icon {
    width          : 58px; height:58px;
    background     : var(--rouge);
    border-radius  : 50%;
    display        : flex;
    align-items    : center;
    justify-content: center;
    color          : var(--blanc);
    font-size      : 1.5rem;
    box-shadow     : 0 4px 22px rgba(212,43,43,0.6);
    transform      : scale(0.8);
    transition     : transform 0.22s;
}

.video-card:hover .play-icon { transform:scale(1); }

.video-cat-badge {
    position      : absolute;
    top:10px; left:10px;
    background    : var(--rouge);
    color         : var(--blanc);
    font-size     : 0.63rem;
    font-weight   : 700;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    padding       : 3px 10px;
    border-radius : var(--r-pill);
}

.video-vues-badge {
    position     : absolute;
    bottom:10px; right:10px;
    background   : rgba(0,0,0,0.7);
    color        : var(--blanc);
    font-size    : 0.7rem;
    padding      : 3px 8px;
    border-radius: var(--r-xs);
    display      : flex;
    align-items  : center;
    gap          : 4px;
}

.video-body {
    padding       : 16px;
    flex          : 1;
    display       : flex;
    flex-direction: column;
}

.video-titre {
    font-family       : var(--font-titre);
    font-size         : 1rem;
    font-weight       : 600;
    color             : var(--texte-titre);
    margin-bottom     : 8px;
    line-height       : 1.3;
    display           : -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp        : 2;
    -webkit-box-orient: vertical;
    overflow          : hidden;
}

.video-date {
    font-size  : 0.77rem;
    color      : var(--texte-muted);
    margin-top : auto;
    display    : flex;
    align-items: center;
    gap        : 5px;
}

/* Carte actualité */
.actu-card {
    background    : var(--blanc);
    border-radius : var(--r-md);
    overflow      : hidden;
    transition    : transform 0.3s, box-shadow 0.3s;
    height        : 100%;
    display       : flex;
    flex-direction: column;
    border        : 1px solid var(--bordure);
    box-shadow    : var(--ombre-xs);
}

.actu-card:hover { transform:translateY(-6px); box-shadow:var(--ombre-md); }

.actu-img { width:100%; aspect-ratio:16/7; object-fit:cover; }

.actu-img-placeholder {
    width          : 100%; aspect-ratio:16/7;
    background     : linear-gradient(135deg, var(--bleu-fonce), var(--bleu));
    display        : flex;
    align-items    : center;
    justify-content: center;
    font-size      : 3rem;
}

.actu-body { padding:20px; flex:1; display:flex; flex-direction:column; }

.actu-cat {
    font-size     : 0.67rem;
    font-weight   : 700;
    letter-spacing: 2px;
    text-transform: uppercase;
    color         : var(--rouge);
    margin-bottom : 8px;
}

.actu-titre { font-family:var(--font-titre); font-size:1.08rem; font-weight:600; color:var(--texte-titre); margin-bottom:10px; line-height:1.3; }

.actu-resume {
    font-size         : 0.87rem;
    color             : var(--texte-secondaire);
    line-height       : 1.65;
    flex              : 1;
    display           : -webkit-box;
    -webkit-line-clamp: 3;
    line-clamp        : 3;
    -webkit-box-orient: vertical;
    overflow          : hidden;
}

.actu-footer {
    display        : flex;
    justify-content: space-between;
    align-items    : center;
    margin-top     : 16px;
    padding-top    : 12px;
    border-top     : 1px solid var(--bordure);
}

.actu-date { font-size:0.74rem; color:var(--texte-muted); display:flex; align-items:center; gap:4px; }

.actu-lire { font-size:0.77rem; font-weight:600; color:var(--bleu); text-decoration:none; display:flex; align-items:center; gap:4px; transition:gap 0.2s, color 0.2s; }
.actu-lire:hover { gap:8px; color:var(--rouge); }

/* Carte événement */
.event-card {
    background    : rgba(255,255,255,0.04);
    border        : 1px solid rgba(255,255,255,0.08);
    border-radius : var(--r-md);
    overflow      : hidden;
    transition    : transform 0.3s, border-color 0.3s;
    height        : 100%;
    display       : flex;
    flex-direction: column;
}

.event-card:hover { transform:translateY(-6px); border-color:var(--rouge); }

.event-date-band {
    padding    : 16px 20px;
    display    : flex;
    align-items: center;
    gap        : 14px;
    background : linear-gradient(135deg, var(--rouge), var(--rouge-fonce));
}

.event-date-num { font-family:var(--font-titre); font-size:2.3rem; font-weight:700; color:var(--blanc); line-height:1; }

.event-date-mois  { font-size:0.84rem; font-weight:600; text-transform:uppercase; letter-spacing:1px; color:rgba(255,255,255,0.9); }
.event-date-heure { font-size:0.73rem; opacity:0.75; display:flex; align-items:center; gap:4px; color:rgba(255,255,255,0.85); }

.event-live-badge {
    margin-left   : auto;
    background    : rgba(255,255,255,0.18);
    color         : var(--blanc);
    font-size     : 0.63rem;
    font-weight   : 700;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    padding       : 4px 10px;
    border-radius : var(--r-pill);
    border        : 1px solid rgba(255,255,255,0.35);
    animation     : blink-dot 1.3s infinite;
}

.event-body { padding:20px; flex:1; display:flex; flex-direction:column; }

.event-titre {
    font-family       : var(--font-titre);
    font-size         : 1.08rem;
    font-weight       : 600;
    color             : var(--blanc);
    margin-bottom     : 10px;
    line-height       : 1.3;
    display           : -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp        : 2;
    -webkit-box-orient: vertical;
    overflow          : hidden;
}

.event-desc {
    font-size         : 0.84rem;
    color             : #4A5A7A;
    line-height       : 1.6;
    flex              : 1;
    display           : -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp        : 2;
    -webkit-box-orient: vertical;
    overflow          : hidden;
}

.event-lieu { display:flex; align-items:center; gap:6px; font-size:0.78rem; color:#5A6A88; margin-top:14px; padding-top:14px; border-top:1px solid rgba(255,255,255,0.06); }
.event-lieu .bi { color:var(--rouge); }

.section-events-dark { background:var(--gris-sombre); padding:80px 0; }

.cta-section { background:var(--blanc); padding:80px 0; text-align:center; border-top:1px solid var(--bordure); }

/* ================================================================
   09. PAGE ABOUT
================================================================ */
.about-lead { font-size:1.12rem; color:var(--texte-corps); line-height:1.9; }

.about-img-wrap {
    border-radius  : var(--r-xl);
    overflow       : hidden;
    box-shadow     : var(--ombre-xl);
    aspect-ratio   : 4/3;
    background     : linear-gradient(135deg, var(--bleu-fonce), var(--bleu));
    display        : flex;
    align-items    : center;
    justify-content: center;
    font-size      : 5rem;
}

.about-img-wrap img { width:100%; height:100%; object-fit:cover; }

.about-values-section { background:var(--gris-clair); padding:80px 0; }

.value-card {
    background   : var(--blanc);
    border-radius: var(--r-md);
    padding      : 34px 26px;
    text-align   : center;
    border       : 1px solid var(--bordure);
    transition   : transform 0.3s, box-shadow 0.3s;
    height       : 100%;
}

.value-card:hover { transform:translateY(-6px); box-shadow:var(--ombre-md); }

.value-icon {
    width          : 66px; height:66px;
    border-radius  : 50%;
    background     : linear-gradient(135deg, var(--bleu), var(--bleu-clair));
    display        : flex;
    align-items    : center;
    justify-content: center;
    font-size      : 1.7rem;
    color          : var(--blanc);
    margin         : 0 auto 22px;
    box-shadow     : 0 6px 22px rgba(30,111,217,0.35);
}

.value-card h3 { font-family:var(--font-titre); font-size:1.1rem; font-weight:600; color:var(--texte-titre); margin-bottom:10px; }
.value-card p  { font-size:0.87rem; color:var(--texte-secondaire); line-height:1.65; margin:0; }

.team-card {
    background   : var(--blanc);
    border-radius: var(--r-md);
    overflow     : hidden;
    border       : 1px solid var(--bordure);
    text-align   : center;
    transition   : transform 0.3s, box-shadow 0.3s;
}

.team-card:hover { transform:translateY(-6px); box-shadow:var(--ombre-md); }

.team-avatar {
    width          : 90px; height:90px;
    border-radius  : 50%;
    background     : linear-gradient(135deg, var(--bleu-fonce), var(--bleu));
    display        : flex;
    align-items    : center;
    justify-content: center;
    font-size      : 2.3rem;
    margin         : 26px auto 16px;
    border         : 3px solid var(--bordure);
}

.team-name { font-family:var(--font-titre); font-size:1.1rem; font-weight:600; color:var(--texte-titre); }

.team-role {
    font-size     : 0.8rem;
    color         : var(--rouge);
    font-weight   : 600;
    letter-spacing: 0.5px;
    margin-bottom : 16px;
    padding-bottom: 16px;
    border-bottom : 1px solid var(--bordure);
}

/* ================================================================
   10. CONTACT
================================================================ */
.contact-section { background:var(--gris-clair); padding:80px 0; }

.contact-info-card {
    background   : var(--blanc);
    border-radius: var(--r-md);
    padding      : 34px;
    border       : 1px solid var(--bordure);
    height       : 100%;
    box-shadow   : var(--ombre-xs);
}

.contact-info-item {
    display    : flex;
    align-items: flex-start;
    gap        : 16px;
    padding    : 18px 0;
    border-bottom: 1px solid var(--bordure);
}

.contact-info-item:last-child  { border-bottom:none; }
.contact-info-item:first-child { padding-top:0; }

.contact-info-icon {
    width          : 46px; height:46px;
    border-radius  : var(--r-sm);
    background     : linear-gradient(135deg, var(--bleu), var(--bleu-clair));
    display        : flex;
    align-items    : center;
    justify-content: center;
    color          : var(--blanc);
    font-size      : 1.1rem;
    flex-shrink    : 0;
    box-shadow     : 0 4px 14px rgba(30,111,217,0.28);
}

.contact-info-text h4 { font-family:var(--font-titre); font-size:0.9rem; font-weight:600; color:var(--texte-titre); margin-bottom:3px; }
.contact-info-text p,
.contact-info-text a  { font-size:0.87rem; color:var(--texte-secondaire); text-decoration:none; margin:0; transition:color 0.2s; }
.contact-info-text a:hover { color:var(--bleu); }

.contact-form-card { background:var(--blanc); border-radius:var(--r-md); padding:42px; border:1px solid var(--bordure); box-shadow:var(--ombre-sm); }

.form-label-bstv { font-family:var(--font-titre); font-size:0.86rem; font-weight:600; letter-spacing:0.5px; text-transform:uppercase; color:var(--texte-titre); margin-bottom:6px; display:block; }

.form-control-bstv {
    border       : 2px solid var(--bordure);
    border-radius: var(--r-sm);
    padding      : 11px 14px;
    font-size    : 0.95rem;
    font-family  : var(--font-corps);
    color        : var(--texte-titre);
    background   : var(--blanc);
    width        : 100%;
    transition   : border-color 0.2s, box-shadow 0.2s;
    outline      : none;
    appearance   : none;
}

.form-control-bstv:focus { border-color:var(--bleu); box-shadow:0 0 0 3px rgba(30,111,217,0.10); }
.form-control-bstv::placeholder { color:#B0BAD0; }
textarea.form-control-bstv { resize:vertical; min-height:145px; }

/* ================================================================
   11. UTILITAIRES & RESPONSIVE
================================================================ */
.section-light { background:var(--blanc);      padding:80px 0; }
.section-grey  { background:var(--gris-clair); padding:80px 0; }
.section-dark  { background:var(--gris-sombre); padding:80px 0; }

.empty-state { text-align:center; padding:80px 20px; color:var(--texte-muted); }
.empty-state .bi { font-size:3.5rem; margin-bottom:18px; display:block; opacity:0.3; color:var(--bleu); }
.empty-state h3  { font-family:var(--font-titre); font-size:1.3rem; color:#BCC5D8; margin-bottom:8px; }
.empty-state p   { font-size:0.9rem; }

.filter-bar {
    background   : var(--blanc);
    border-bottom: 1px solid var(--bordure);
    padding      : 16px 0;
    position     : sticky;
    top          : 75px;
    z-index      : 100;
    box-shadow   : 0 2px 10px rgba(0,0,0,0.05);
}

.filter-btn {
    font-family    : var(--font-titre);
    font-size      : 0.83rem;
    font-weight    : 600;
    letter-spacing : 0.9px;
    text-transform : uppercase;
    padding        : 7px 20px;
    border-radius  : var(--r-pill);
    border         : 2px solid var(--bordure);
    color          : var(--texte-secondaire);
    background     : var(--blanc);
    text-decoration: none;
    transition     : all 0.2s;
    white-space    : nowrap;
    cursor         : pointer;
    display        : inline-flex;
    align-items    : center;
    gap            : 5px;
}

.filter-btn:hover,
.filter-btn.active { background:var(--bleu); border-color:var(--bleu); color:var(--blanc); }

.fade-in-up { opacity:0; transform:translateY(28px); transition:opacity 0.58s ease, transform 0.58s ease; }
.fade-in-up.visible { opacity:1; transform:translateY(0); }

/* Responsive */
@media (max-width: 991.98px) {
    .hero-section  { min-height:auto; padding:70px 0 50px; }
    .hero-title    { font-size:2.8rem; }
    .page-hero h1  { font-size:2rem; }
    .section-title { font-size:1.85rem; }
    .filter-bar    { position:static; }
}

@media (max-width: 767.98px) {
    .hero-title         { font-size:2.2rem; }
    .hero-desc          { font-size:1rem; }
    .section-title      { font-size:1.6rem; }
    .stat-number        { font-size:2.4rem; }
    .contact-form-card  { padding:26px; }
    .hero-btns          { flex-direction:column; }
    .hero-btns a        { text-align:center; justify-content:center; }
    .footer-legal-links { justify-content:center; }
    .topbar .social-icons { display:none !important; }
    .ticker-text span   { font-size:0.70rem; animation-duration:22s; }
    .live-badge         { font-size:0.60rem; padding:2px 6px; }
}

@media (max-width: 575.98px) {
    .hero-stats-row   { gap:10px; }
    .hero-stat strong { font-size:1.2rem; }
    .event-date-num   { font-size:1.85rem; }
    .back-to-top      { bottom:18px; right:18px; width:42px; height:42px; }
}