/* =========================================================
   RESET & VARIABLES
   ========================================================= */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden}
body{
    font-family:'Roboto',sans-serif;
    color:#111;
    background:#fff;
    overflow-x:hidden;
    line-height:1.4;
}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer;border:none;background:none}
a{text-decoration:none;color:inherit}
ul{list-style:none}

:root{
    --red:#ED2939;            /* rouge drapeau français */
    --red-deep:#D81E2D;
    --blue:#0A2DA8;           /* bleu identité */
    --blue-dark:#0A1850;      /* bleu nuit (FAQ, footer, fonds) */
    --blue-deep:#061040;
    --yellow:#FFD500;
    --black:#000;
    --white:#fff;
    --grey-soft:#F4F4F4;

    --shadow-btn:0 8px 20px rgba(237,41,57,.45), 0 2px 6px rgba(0,0,0,.15);
    --shadow-btn-blue:0 8px 20px rgba(10,45,168,.45), 0 2px 6px rgba(0,0,0,.15);
    --shadow-card:0 10px 30px rgba(0,0,0,.12);
}

/* =========================================================
   1. NAVBAR + HERO
   ========================================================= */
.navbar{
    position:absolute;
    top:0;left:0;right:0;
    z-index:50;
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding:22px 60px;
}
.navbar .logo{height:48px;width:auto}
.navbar .nav-links{display:flex;align-items:center;gap:48px}
.navbar .nav-links a{
    color:#fff;
    font-weight:700;
    font-size:15px;
    letter-spacing:.04em;
    text-transform:uppercase;
}
.navbar .nav-cta{
    background:var(--red);
    color:#fff;
    padding:14px 28px;
    border-radius:14px;
    font-weight:900;
    font-size:14px;
    letter-spacing:.06em;
    text-transform:uppercase;
    box-shadow:var(--shadow-btn);
    transition:transform .2s ease;
}
.navbar .nav-cta:hover{transform:translateY(-2px)}

.hero{
    position:relative;
    min-height:100vh;
    color:#fff;
    overflow:hidden;
    padding:120px 60px 60px;
    background:
        linear-gradient(105deg, rgba(10,24,80,.92) 0%, rgba(10,45,168,.78) 45%, rgba(10,45,168,.35) 100%),
        url('../img/banner/hero-bg.webp') center/cover no-repeat;
}
.hero-inner{
    max-width:1400px;
    margin:0 auto;
    display:grid;
    grid-template-columns:1.05fr .95fr;
    gap:60px;
    align-items:center;
}

/* hero left */
.hero-badge{
    display:inline-block;
    background:var(--red);
    color:#fff;
    font-weight:900;
    font-size:20px;
    letter-spacing:.06em;
    padding:10px 22px;
    border-radius:15px;
    text-transform:uppercase;
    box-shadow:var(--shadow-btn);
    margin-bottom:20px;
}
.hero-title{
    font-size:54px;
    font-weight:500;
    line-height:1.05;
    margin-bottom:18px;
    text-shadow:0 4px 18px rgba(0,0,0,.4);
}
.hero-title strong{color:var(--red);font-weight:900;text-transform:uppercase}
.hero-sub{
    font-size:24px;
    font-weight:300;
    line-height:1.35;
    margin-bottom:28px;
}
.hero-sub strong{font-weight:700}
.hero-list{margin-bottom:22px}
.hero-list li{
    display:flex;
    align-items:center;
    gap:4px;
    font-size:20px;
    font-weight:400;
    text-transform:uppercase;
    letter-spacing:.02em;
    margin-bottom:10px;
}
.hero-list li strong{font-weight:700}
.check-icon{
    flex-shrink:0;
    width:30px;height:30px;
    display:grid;place-items:center;
    color:var(--red);
    font-size:24px;
    font-weight:900;
}
.hero-cta-row{display:flex;align-items:center;gap:26px;flex-wrap:wrap}
.btn-hero{
    background:var(--red);
    color:#fff;
    padding:22px 44px;
    border-radius:18px;
    font-weight:900;
    font-size:18px;
    letter-spacing:.04em;
    text-transform:uppercase;
    box-shadow:var(--shadow-btn);
    animation:pulse-hero 1.8s infinite;
    position:relative;
}
@keyframes pulse-hero{
    0%,100%{box-shadow:0 8px 20px rgba(237,41,57,.45), 0 0 0 0 rgba(237,41,57,.7), 0 2px 6px rgba(0,0,0,.15)}
    50%{box-shadow:0 8px 20px rgba(237,41,57,.55), 0 0 0 18px rgba(237,41,57,0), 0 2px 6px rgba(0,0,0,.15)}
}
.hero-guarantee{font-size:18px;font-weight:400}

/* hero right - VIP card */
.vip-card{
    border:2px solid rgba(255,255,255,.55);
    border-radius:22px;
    padding:34px 32px;
    background:linear-gradient(180deg, rgba(0,0,0,.15) 0%, rgba(0,0,0,.05) 100%);
    backdrop-filter:blur(2px);
}
.vip-title{
    font-size:30px;
    font-weight:900;
    text-transform:uppercase;
    margin-bottom:22px;
    letter-spacing:.01em;
    text-align: center;
}
.vip-title em{color:var(--red);font-style:normal}
.vip-offers{display:flex;flex-direction:column;gap:14px;margin-bottom:18px}
.vip-offer{
    display:grid;
    grid-template-columns:1fr auto;
    align-items:center;
    border-radius:14px;
    padding:18px 22px;
    color:#fff;
}
.vip-offer.--blue{background:var(--blue-dark);border-left:6px solid var(--red)}
.vip-offer.--red{background:var(--red);border-left:6px solid #fff}
.vip-offer-screens{font-size:24px;font-weight:900;letter-spacing:.01em;line-height:1.05}
.vip-offer-months{font-size:18px;font-weight:400;letter-spacing:.02em;text-transform:uppercase}
.vip-offer-prices{display:flex;align-items:baseline;gap:10px}
.vip-price-old{
    font-size:28px;
    font-weight:700;
    color:rgba(255,255,255,.85);
    text-decoration:line-through;
    text-decoration-color:var(--red);
    text-decoration-thickness:3px;
}
.vip-offer.--red .vip-price-old{text-decoration-color:#fff}
.vip-price-new{
    font-size:42px;
    font-weight:900;
    color:var(--red);
}
.vip-offer.--red .vip-price-new{color:#fff}
.vip-footer-line{
    text-align:center;
    font-size:19px;
    font-weight:900;
    text-transform:uppercase;
    letter-spacing:.02em;
}
.vip-footer-line em{color:var(--yellow);font-style:normal}

/* =========================================================
   2. FUYEZ LES SERVEURS SATURÉS
   ========================================================= */
.section-saturated{
    position:relative;
    background:#fff;
    padding:80px 0 0;
    overflow:hidden;
}
.saturated-inner{
    position:relative;
    z-index:2;
    max-width:1400px;
    margin:0 auto;
    padding:0 60px 60px;
}
.saturated-left{max-width:55%}
.saturated-left h2{
    font-size:40px;
    font-weight:900;
    line-height:1.05;
    text-transform:uppercase;
    color:#111;
    margin-bottom:14px;
    text-shadow:0 4px 14px rgba(0,0,0,.08);
}
.saturated-left .word-red{
    color:var(--red);
    font-size:120px;
    display:block;
    line-height:1;
    margin-top:4px;
}
.saturated-left p{
    font-size:30px;
    font-weight:400;
    text-transform:uppercase;
    line-height:1.35;
    color:#111;
    margin-top:18px;
}
.saturated-left p strong{font-weight:900}
.saturated-photo{
    position:absolute;
    right:300px;
    bottom:50px;
    z-index:2;
    max-height:580px;
    width:auto;
    display:block;
    pointer-events:none;
}
.saturated-strip{
    position:relative;
    padding:36px 0;
    background:linear-gradient(180deg, #fff 0%, #cad9f1 50%, var(--blue) 100%);
    width:100%;
}
.saturated-strip .marquee{
    position:relative;
    z-index:3;
}
.marquee{
    overflow:hidden;
    position:relative;
    -webkit-mask-image:linear-gradient(90deg, transparent, #000 5%, #000 95%, transparent);
    mask-image:linear-gradient(90deg, transparent, #000 5%, #000 95%, transparent);
}
.marquee-track{
    display:flex;
    gap:32px;
    width:max-content;
    animation:marquee-rtl 35s linear infinite;
}
@keyframes marquee-rtl{
    0%{transform:translateX(0)}
    100%{transform:translateX(-50%)}
}
.chain-logo{
    flex-shrink:0;
    border-radius:16px;
    display:grid;place-items:center;
    padding:14px 0px;
    box-shadow:0 4px 14px rgba(0,0,0,.08);
}
.chain-logo img{max-height:100%;max-width:100%;object-fit:contain;border-radius:10px}

/* =========================================================
   3. CATALOGUE TIVIZER
   ========================================================= */
.section-catalogue{
    background:var(--blue);
    color:#fff;
    padding:80px -100px;
}
.catalogue-inner{max-width:1300px;margin:0 auto}
.catalogue-title{
    text-align:center;
    font-size:54px;
    font-weight:900;
    text-transform:uppercase;
    letter-spacing:.01em;
    margin-bottom:44px;
}
.catalogue-title em{color:var(--red);font-style:normal}
.catalogue-controls{
    display:grid;
    grid-template-columns:1.4fr 1fr;
    gap:24px;
    margin-bottom:26px;
}
.dropdown{
    background:var(--red);
    color:#fff;
    border-radius:18px;
    padding:22px 34px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    font-size:24px;
    font-weight:900;
    text-transform:uppercase;
    letter-spacing:.03em;
    box-shadow:var(--shadow-btn);
}
.dropdown svg{width:30px;height:30px;fill:#fff}
.search-input{
    background:rgba(255,255,255,.18);
    border:none;
    color:#fff;
    border-radius:18px;
    padding:22px 34px;
    font-size:22px;
    font-weight:500;
    letter-spacing:.04em;
    text-transform:uppercase;
    width:100%;
    font-family:inherit;
}
.search-input::placeholder{color:rgba(255,255,255,.85)}
.catalogue-list-wrap{
    background:#fff;
    border:3px solid var(--red);
    border-radius:22px;
    padding:30px 40px;
    position:relative;
    max-height:270px;
    overflow-y:auto;
}
.catalogue-list-wrap::-webkit-scrollbar{width:8px}
.catalogue-list-wrap::-webkit-scrollbar-thumb{background:var(--red);border-radius:4px}
.catalogue-list{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:18px 50px;
}
.catalogue-list li{
    display:flex;
    align-items:center;
    gap:18px;
    font-size:15px;
    font-weight:200;
    color:#111;
    text-transform:uppercase;
    letter-spacing:.01em;
}
.catalogue-list li::before{
    content:'';
    display:inline-block;
    width:0;height:0;
    border-top:11px solid transparent;
    border-bottom:11px solid transparent;
    border-left:16px solid var(--red);
    flex-shrink:0;
    filter:drop-shadow(0 2px 3px rgba(0,0,0,.18));
}

/* =========================================================
   4. REGARDEZ
   ========================================================= */
.section-regardez{
    background:#fff;
    padding:70px 0 0;
    overflow:visible;
    position:relative;
    z-index:5;
}
.regardez-content{
    text-align:center;
    padding:0 60px 30px;
    max-width:1400px;
    margin:0 auto;
}
.regardez-title{
    font-size:140px;
    font-weight:900;
    color:var(--red);
    text-transform:uppercase;
    line-height:.95;
    letter-spacing:-.01em;
    text-shadow:0 6px 22px rgba(237,41,57,.18);
}
.regardez-sub{
    font-size:38px;
    font-weight:900;
    text-transform:uppercase;
    color:#111;
    line-height:1.15;
    margin-top:10px;
}
.regardez-strip{
     width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    margin-top:-30px;
    margin-bottom:-60px;
    padding:30px 0;
    background:linear-gradient(180deg, transparent 0%, #1a1a1a 35%, #000 100%);
    position:relative;
    z-index:6;
    overflow:hidden;
}
.league-track{
    display:flex;
    gap:18px;
    width:max-content;
    animation:marquee-rtl 40s linear infinite;
    align-items:flex-end;
}
.league-logo{
    flex-shrink:0;
    width:170px;
    height:240px;
    background:transparent;
    overflow:hidden;
    display:flex;
    align-items:center;
    justify-content:center;
}
.league-logo img{
    max-width:100%;
    max-height:100%;
    width:auto;
    height:auto;
    object-fit:contain;
    border-radius:14px;
}

/* =========================================================
   5. VERROUILLAGE / COUNTDOWN
   ========================================================= */
.section-countdown{
    background:#000;
    color:#fff;
    padding:90px 60px;
    text-align:center;
    position:relative;
}
.countdown-title{
    font-size:80px;
    font-weight:900;
    color:var(--red);
    text-transform:uppercase;
    line-height:1;
    margin-bottom:6px;
    text-shadow:0 4px 18px rgba(237,41,57,.3);
}
.countdown-subtitle{
    font-size:46px;
    font-weight:300;
    text-transform:uppercase;
    margin-bottom:14px;
    letter-spacing:.02em;
}
.countdown-line{
    position:relative;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:18px;
    margin-bottom:30px;
}
.countdown-line::before,
.countdown-line::after{
    content:'';
    flex:1;
    height:2px;
    background:var(--red);
    box-shadow:0 0 8px var(--red);
}
.countdown-cell{
    background:#000;
    border:2px solid var(--red);
    border-radius:16px;
    padding:18px 28px;
    min-width:140px;
    text-align:center;
    box-shadow:0 8px 24px rgba(237,41,57,.25);
}
.countdown-cell-num{
    font-size:78px;
    font-weight:300;
    line-height:1;
    color:#fff;
}
.countdown-cell-label{
    font-size:18px;
    font-weight:500;
    letter-spacing:.08em;
    color:#fff;
    margin-top:6px;
    text-transform:uppercase;
}
.countdown-text{
    font-size:26px;
    font-weight:400;
    margin:10px 0 14px;
    letter-spacing:.01em;
}
.countdown-text strong{font-weight:900}
.btn-countdown{
    display:inline-flex;
    align-items:center;
    gap:18px;
    background:var(--red);
    color:#fff;
    padding:22px 50px;
    border-radius:14px;
    font-size:22px;
    font-weight:900;
    letter-spacing:.04em;
    text-transform:uppercase;
    box-shadow:var(--shadow-btn);
    transition:transform .2s;
}
.btn-countdown:hover{transform:translateY(-2px)}
.btn-countdown svg{width:22px;height:22px;fill:#fff}
.countdown-footnote{
    margin-top:8px;
    font-size:16px;
    font-weight:500;
    letter-spacing:.06em;
    text-transform:uppercase;
}

/* =========================================================
   6. COMMENT ÇA MARCHE
   ========================================================= */
.section-howitworks{
    background:#fff;
    padding:0 60px 80px;
    position:relative;
}
.howitworks-cap{
    background:#000;
    height:38px;
    margin:0 -60px;
    position:relative;
}
.howitworks-badge{
    position:absolute;
    left:50%;top:100%;
    transform:translate(-50%,-50%);
    background:var(--red);
    color:#fff;
    width:74px;height:74px;
    border-radius:18px;
    display:grid;place-items:center;
    font-size:42px;
    font-weight:900;
    box-shadow:var(--shadow-btn);
}
.howitworks-title{
    text-align:center;
    font-size:46px;
    font-weight:900;
    text-transform:uppercase;
    margin:80px 0 50px;
    color:#111;
    text-shadow:0 4px 14px rgba(0,0,0,.18);
    letter-spacing:.02em;
}
.howitworks-cards{
    max-width:1400px;
    margin:0 auto;
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:38px;
}
.how-card{position:relative;padding-top:4px}
.how-card h3{
    font-size:30px;
    font-weight:900;
    color:var(--red);
    text-transform:uppercase;
    margin-bottom:1px;
    letter-spacing:.01em;
}
.how-card-body{
    background:var(--red);
    color:#fff;
    border-radius:16px;
    padding:12px 26px;
    font-size:20px;
    font-weight:200;
    line-height:1.2;
    box-shadow:var(--shadow-btn);
}

/* =========================================================
   7. FILMS & SÉRIES
   ========================================================= */
.section-films{
    background:#fff;
    padding:70px 0 50px;
    text-align:center;
    overflow:hidden;
    position:relative;
}
.films-header{padding:0 60px}
.films-pretitle{
    font-size:42px;
    font-weight:300;
    text-transform:uppercase;
    letter-spacing:.02em;
    color:#111;
    margin-bottom:6px;
}
.films-title{
    font-size:110px;
    font-weight:900;
    color:var(--red);
    text-transform:uppercase;
    line-height:.95;
    text-shadow:0 6px 22px rgba(237,41,57,.2);
}
.films-strip{
      width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    margin-top:36px;
    padding:30px 0 40px;
    background:#000;
    position:relative;
    overflow:visible;
}
.films-strip .marquee{overflow:hidden}
.films-track{
    display:flex;
    gap:22px;
    width:max-content;
    animation:marquee-rtl 50s linear infinite;
}
.film-poster{
    flex-shrink:0;
    width:230px;
    height:330px;
    border-radius:12px;
    overflow:hidden;
    box-shadow:0 8px 24px rgba(0,0,0,.6);
}
.film-poster img{width:100%;height:100%;object-fit:cover}
.popcorn{
    position:absolute;
    right:60px;
    bottom:-20px;
    transform:rotate(-8deg);
    width:110px;
    z-index:5;
    pointer-events:none;
    filter:drop-shadow(0 10px 18px rgba(0,0,0,.45));
}

.films-footer{
    position:relative;
    padding:20px 0;
    max-width:1400px;
    margin:0 auto;
}
.films-footer-text{text-align:center}
.films-tagline{
    font-size:36px;
    font-weight:900;
    color:var(--red);
    text-transform:uppercase;
    margin-bottom:6px;
}
.films-subtagline{
    font-size:26px;
    font-weight:700;
    text-transform:uppercase;
    color:#111;
}

/* =========================================================
   8. FEATURES TV + TOUT INCLUS
   ========================================================= */
.section-features{
    background:linear-gradient(180deg, #fff 0%, #fff 80%, var(--red) 100%);
    padding:60px 60px 80px;
    overflow:hidden;
}
.features-grid{
    max-width:1400px;
    margin:0 auto;
    display:grid;
    grid-template-columns:1fr 2fr 1fr;
    gap:30px;
    align-items:center;
}
.features-col{display:flex;flex-direction:column;gap:24px}
.feature-card{
    background:var(--red);
    color:#fff;
    border-radius:14px;
    padding:0 14px;
    height:90px;
    display:flex;
    align-items:center;
    justify-content:center;
    text-align:center;
    box-shadow:var(--shadow-btn);
    font-size:19px;
    font-weight:300;
    line-height:1.2;
    text-transform:uppercase;
    letter-spacing:.01em;
}
.feature-card span{margin-right:.28em}
.feature-card br{display:none}
.feature-card strong{font-weight:900}
.features-tv{
    display:grid;
    place-items:center;
}
.features-tv img{
    width:100%;
    max-width:680px;
    height:auto;
}
.tout-inclus-wrap{
    max-width:1400px;
    margin:46px auto 0;
    text-align:center;
}
.tout-inclus-title{
    font-size:48px;
    font-weight:900;
    color:#111;
    text-transform:uppercase;
    margin-bottom:30px;
    letter-spacing:.01em;
}
.platforms-grid{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:22px;
    max-width:1100px;
    margin:0 auto;
}
.platform-tile{
    background:#fff;
    border-radius:18px;
    height:110px;
    display:grid;place-items:center;
    padding:18px 30px;
    box-shadow:0 6px 20px rgba(0,0,0,.12);
}
.platform-tile img{max-height:65px;max-width:100%;object-fit:contain}

/* =========================================================
   9. CTA ROUGE (PLUS QUE 15 ACCÈS)
   ========================================================= */
.section-cta-red{
    background:var(--red);
    color:#fff;
    text-align:center;
    padding:10px 60px 70px;
}
.cta-red-title{
    font-size:54px;
    font-weight:900;
    text-transform:uppercase;
    line-height:1;
    margin-bottom:8px;
    letter-spacing:.01em;
}
.cta-red-sub{
    font-size:42px;
    font-weight:300;
    text-transform:uppercase;
    margin-bottom:32px;
    letter-spacing:.02em;
}
.btn-cta-red{
    display:inline-flex;
    align-items:center;
    gap:20px;
    background:var(--blue);
    color:#fff;
    padding:22px 42px;
    border-radius:14px;
    font-size:24px;
    font-weight:900;
    text-transform:uppercase;
    letter-spacing:.04em;
    box-shadow:var(--shadow-btn-blue);
}
.btn-cta-red-arrow{
    width:28px;height:28px;
    display:grid;place-items:center;
}
.btn-cta-red .price{color:var(--red);background:#fff;padding:2px 10px;border-radius:8px}
.btn-cta-red svg{width:22px;height:22px;fill:#fff}
.cta-red-footnote{
    margin-top:22px;
    font-size:18px;
    font-weight:500;
    letter-spacing:.06em;
    text-transform:uppercase;
}

/* =========================================================
   10. TÉMOIGNAGES TRUSTPILOT
   ========================================================= */
.section-reviews{
    background:#fff;
    padding:0 60px 60px;
    position:relative;
}
.reviews-cap{
    background:var(--red);
    height:22px;
    margin:0 -60px 0;
    position:relative;
}
.reviews-badge{
    position:absolute;
    left:50%;top:100%;
    transform:translate(-50%,-50%);
    background:var(--blue);
    color:#fff;
    padding:14px 28px;
    border-radius:14px;
    display:flex;gap:8px;
    box-shadow:var(--shadow-btn-blue);
}
.reviews-badge svg{width:30px;height:30px;fill:#fff}
.reviews-titles{text-align:center;margin:70px 0 36px}
.reviews-title-1{
    font-size:32px;
    font-weight:900;
    text-transform:uppercase;
    letter-spacing:.02em;
    margin-bottom:6px;
    color:#111;
}
.reviews-title-2{
    font-size:30px;
    font-weight:400;
    text-transform:uppercase;
    color:#111;
}
.reviews-grid-wrap{
    margin:0 -60px;
    overflow:hidden;
    position:relative;
}
.reviews-grid-wrap::before,
.reviews-grid-wrap::after{
    content:'';
    position:absolute;
    top:0;bottom:0;
    width:80px;
    z-index:2;
    pointer-events:none;
}
.reviews-grid-wrap::before{left:0;background:linear-gradient(90deg, #fff, transparent)}
.reviews-grid-wrap::after{right:0;background:linear-gradient(-90deg, #fff, transparent)}
.reviews-track{
    display:flex;
    gap:30px;
    width:max-content;
    animation:marquee-rtl 55s linear infinite;
    padding:10px 30px;
}
.review-card{
    flex-shrink:0;
    width:440px;
    background:var(--blue);
    color:#fff;
    border-radius:16px;
    padding:24px 26px;
    box-shadow:0 8px 22px rgba(0,0,0,.18);
}
.review-head{
    display:flex;
    justify-content:space-between;
    align-items:center;
    margin-bottom:18px;
}
.review-author{font-weight:700;font-size:20px;color:var(--red)}
.review-date{font-size:13px;font-weight:300;opacity:.85;margin-top:2px}
.review-stars{display:flex;gap:3px}
.review-star{
    width:26px;height:26px;
    background:var(--red);
    display:grid;place-items:center;
    border-radius:3px;
}
.review-star svg{width:20px;height:20px;fill:#fff}
.review-text{font-size:16px;font-weight:400;line-height:1.45}
.trustpilot-row{
    text-align:center;
    margin-top:36px;
    font-size:20px;
    font-weight:400;
    color:#111;
}
.trustpilot-row strong{font-weight:900}
.trustpilot-row .tp-mark{
    display:inline-flex;
    align-items:center;
    gap:8px;
    margin-left:12px;
    vertical-align:middle;
    width:134px;
}
.trustpilot-row .tp-star{
    color:#00B67A;
    font-size:18px;
    background:#00B67A;
    color:#fff;
    width:34px;height:34px;
    display:inline-grid;
    place-items:center;
    border-radius:4px;
}
.trustpilot-row .tp-name{font-weight:700}

/* =========================================================
   11. MARCHE AVEC TOUS VOS APPAREILS
   ========================================================= */
.section-devices{
    background:linear-gradient(180deg, #fff 0%, #fff 20%, #a8b9e0 55%, var(--blue) 85%);
    padding:80px 60px 0;
    overflow:hidden;
    position:relative;
}
.devices-grid{
    max-width:1400px;
    margin:0 auto;
    display:grid;
    grid-template-columns:repeat(7,1fr);
    gap:18px;
}
.device-tile{
    aspect-ratio:1/1;
    overflow:hidden;
}
.device-tile img{
    width:100%;
    height:100%;
    object-fit:cover;
    border-radius:18px;
    display:block;
}
.devices-strip{
    background:var(--blue);
    margin:60px -60px 0;
    padding:28px 0;
    text-align:center;
}
.devices-strip h3{
    font-size:42px;
    font-weight:300;
    color:#fff;
    text-transform:uppercase;
    letter-spacing:.02em;
}
.devices-strip h3 strong{font-weight:900}

/* =========================================================
   12. BÉNÉFICES + TV JOUEUR
   ========================================================= */
.section-benefits{
    background:var(--blue);
    color:#fff;
    padding:80px 60px;
}
.benefits-grid{
    max-width:1400px;
    margin:0 auto;
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:50px;
    align-items:center;
}
.benefits-list{margin-bottom:0}
.benefits-list li{
    display:flex;
    align-items:flex-start;
    gap:4px;
    font-size:22px;
    font-weight:400;
    margin-bottom:6px;
    line-height:1.25;
}
.benefits-list li strong{font-weight:900}
.benefits-check{
    flex-shrink:0;
    width:26px;height:26px;
    display:grid;place-items:center;
    color:var(--red);
    font-size:22px;
    font-weight:700;
    margin-top:2px;
}
.btn-benefits{
    display:inline-block;
    margin-top:20px;
    background:var(--red);
    color:#fff;
    padding:22px 38px;
    border-radius:14px;
    font-size:20px;
    font-weight:900;
    text-transform:uppercase;
    letter-spacing:.02em;
    box-shadow:var(--shadow-btn);
}
.benefits-tv img{
    width:100%;
    max-width:680px;
    height:auto;
    margin-left:auto;
}

/* =========================================================
   13. FAQ
   ========================================================= */
.section-faq{
    background:#fff;
    padding:0 60px 80px;
    position:relative;
}
.faq-cap{
    background:var(--blue);
    height:60px;
    margin:0 -60px 0;
    position:relative;
}
.faq-badge{
    position:absolute;
    left:50%;top:100%;
    transform:translate(-50%,-50%);
    background:var(--red);
    color:#fff;
    padding:14px 36px;
    border-radius:16px;
    font-size:24px;
    font-weight:900;
    letter-spacing:.04em;
    box-shadow:var(--shadow-btn);
}
.faq-title{
    text-align:center;
    font-size:52px;
    font-weight:900;
    color:var(--red);
    text-transform:uppercase;
    margin:70px 0 40px;
    letter-spacing:.01em;
}
.faq-list{
    max-width:1000px;
    margin:0 auto;
    display:flex;
    flex-direction:column;
    gap:18px;
}
.faq-item{
    background:var(--blue-dark);
    border-radius:14px;
    overflow:hidden;
    box-shadow:0 4px 14px rgba(0,0,0,.12);
}
.faq-head{
    display:flex;
    justify-content:space-between;
    align-items:center;
    padding:20px 26px;
    color:#fff;
    cursor:pointer;
    user-select:none;
}
.faq-head h3{
    font-size:15px;
    font-weight:400;
    text-transform:uppercase;
    letter-spacing:.02em;
    transition:all .3s ease;
}
.faq-item.--open .faq-head h3{
    text-transform:none;
    letter-spacing:0;
}
.faq-toggle{
    flex-shrink:0;
    width:54px;height:42px;
    background:var(--red);
    border-radius:10px;
    display:grid;place-items:center;
    color:#fff;
    margin-left:18px;
    box-shadow:0 4px 10px rgba(237,41,57,.4);
    transition:transform .3s ease;
}
.faq-toggle svg{width:22px;height:22px;fill:#fff;transition:transform .3s ease}
.faq-item.--open .faq-toggle svg{transform:rotate(90deg)}
.faq-body{
    max-height:0;
    overflow:hidden;
    padding:0 26px;
    color:#d9d9d9;
    font-size:16px;
    font-weight:100;
    line-height:1.55;
    transition:max-height .4s ease, padding .4s ease;
}
.faq-item.--open .faq-body{
    max-height:500px;
    padding:0 26px 22px;
}

/* =========================================================
   14. FOOTER
   ========================================================= */
.footer{
    background:var(--blue-dark);
    color:#fff;
    padding:60px 60px 30px;
}
.footer-grid{
    max-width:1400px;
    margin:0 auto;
    display:grid;
    grid-template-columns:1.3fr 1fr 1fr 1.2fr;
    gap:48px;
    margin-bottom:50px;
}
.footer-brand .logo{height:54px;margin-bottom:16px}
.footer-brand p{
    font-size:18px;
    font-weight:700;
    line-height:1.4;
    margin-bottom:18px;
    color:#9ca7c4;
}
.footer-pay img{
    height:34px;
    width:auto;
    filter:brightness(0) invert(1);
    opacity:.85;
}
.footer-col h4{
    font-size:18px;
    font-weight:900;
    text-transform:uppercase;
    color:var(--red);
    margin-bottom:18px;
    letter-spacing:.02em;
}
.footer-col ul li{margin-bottom:10px}
.footer-col ul li a{
    font-size:17px;
    font-weight:700;
    color:#9ca7c4;
    transition:color .2s;
}
.footer-col ul li a:hover{color:#fff}
.footer-col ul li.--support a{
    display:flex;
    align-items:center;
    gap:10px;
}
.footer-col ul li.--support a::before{
    content:none;
}
.support-ic{
    width:18px;height:18px;flex-shrink:0;color:var(--red);
}
.footer-bottom{
    text-align:center;
    font-size:15px;
    font-weight:300;
    color:rgba(255,255,255,.5);
    padding-top:24px;
    border-top:1px solid rgba(255,255,255,.08);
}

/* selection */
::selection{background:var(--red);color:#fff}
/* =========================================================
   Catalogue — menu déroulant des catégories (ajout fonctionnel)
   ========================================================= */
.dropdown{position:relative;cursor:pointer}
.dropdown-menu{
    display:none;
    position:absolute;
    top:calc(100% + 10px);
    left:0;right:0;
    background:#fff;
    border:3px solid var(--red);
    border-radius:18px;
    max-height:340px;
    overflow-y:auto;
    z-index:60;
    box-shadow:var(--shadow-card);
    padding:10px;
    margin:0;
    list-style:none;
}
.dropdown-menu.--open{display:block}
.dropdown-menu li{
    padding:14px 20px;
    border-radius:10px;
    color:#111;
    font-size:18px;
    font-weight:600;
    text-transform:uppercase;
    letter-spacing:.01em;
    cursor:pointer;
}
.dropdown-menu li:hover,
.dropdown-menu li.--active{background:var(--red);color:#fff}
.dropdown-menu::-webkit-scrollbar{width:8px}
.dropdown-menu::-webkit-scrollbar-thumb{background:var(--red);border-radius:4px}
.catalogue-empty{grid-column:1 / -1;text-align:center;color:#777;font-weight:500;text-transform:none}

/* =================================================================
   RESPONSIVE — Tablettes & Mobiles
   Navbar non-sticky (reste absolute) · logo gauche + burger droite
   ================================================================= */

/* Burger caché en desktop */
.nav-burger{display:none}
.nav-overlay{display:none}
.device-tile.dup{display:none}

/* ---------------- TABLETTE (≤ 992px) ---------------- */
@media (max-width: 992px){
    /* NAVBAR : logo gauche, burger droite */
    .navbar{padding:18px 24px}
    .navbar .logo{height:40px}
    .nav-burger{
        display:flex;flex-direction:column;justify-content:center;gap:6px;
        width:40px;height:40px;background:transparent;z-index:70;
    }
    .nav-burger span{display:block;height:3px;width:30px;background:#fff;border-radius:3px;transition:transform .25s,opacity .25s}
    .nav-burger.--open span:nth-child(1){transform:translateY(9px) rotate(45deg)}
    .nav-burger.--open span:nth-child(2){opacity:0}
    .nav-burger.--open span:nth-child(3){transform:translateY(-9px) rotate(-45deg)}

    .nav-links{
        position:fixed;top:0;left:0;right:0;width:100%;
        background:var(--blue-dark);flex-direction:column;align-items:flex-start;
        gap:0;padding:88px 26px 26px;transform:translateY(-100%);
        transition:transform .32s ease;z-index:65;box-shadow:0 14px 40px rgba(0,0,0,.4);
    }
    .nav-links.--open{transform:translateY(0)}
    .nav-links a{
        color:#fff;padding:16px 0;font-size:18px;width:100%;text-align:left;
        border-bottom:1px solid rgba(255,255,255,.12);text-transform:uppercase;
    }
    .nav-links .nav-cta{
        margin-top:20px;width:auto;align-self:flex-start;text-align:left;justify-content:center;
        border-bottom:none;font-size:15px;padding:14px 26px;display:inline-flex;
    }
    .nav-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:60}
    .nav-overlay.--open{display:block}

    /* Réduire les paddings horizontaux des sections */
    .hero,
    .section-saturated,.section-catalogue,.section-regardez,.section-countdown,
    .section-howitworks,.section-films,.section-features,.section-cta-red,
    .section-reviews,.section-devices,.section-benefits,.section-faq,.footer{
        padding-left:28px;padding-right:28px;
    }

    /* Grilles → empilées */
    .hero-inner{grid-template-columns:1fr;gap:40px}
    .hero-left,.hero-right{min-width:0}
    .features-grid{grid-template-columns:1fr;gap:30px}
    .benefits-grid{margin-right:20px;grid-template-columns:1fr;gap:34px}
    .howitworks-cards{grid-template-columns:1fr;gap:20px}
    .footer-grid{grid-template-columns:1fr 1fr;gap:34px}

    /* Saturated : photo remise dans le flux, texte aligné à gauche */
    .saturated-left{max-width:100%;text-align:left}
    .saturated-photo{position:static;margin:16px 0 0;max-height:none;max-width:70%;bottom:auto;right:auto}
    .section-saturated{padding-bottom:0}

    /* Titres géants réduits */
    .regardez-title{font-size:74px}
    .films-title{font-size:60px}
    .saturated-left .word-red{font-size:74px}
    .countdown-title{font-size:54px}
    .countdown-subtitle{font-size:28px}
}

/* ---------------- MOBILE (≤ 600px) ---------------- */
@media (max-width: 600px){
    .navbar{padding:14px 18px}
    .navbar .logo{height:36px}

    /* ---------- HERO ---------- */
    .hero-inner{grid-template-columns:1fr;gap:30px}
    .hero-left,.hero-right{min-width:0;max-width:100%}
    .hero-badge{display:block;width:100%;white-space:nowrap;font-size:12px;padding:6px 16px;text-align:center;letter-spacing:.02em}
    .hero-title{font-size:30px}
    .hero-sub{font-size:18px;line-height:1.3}
    .hero-guarantee{
        display:block;text-align:center;width:100%;margin-top: -30px;}
    /* checks : chaque ligne entière, mots gras non séparés */
    .hero-list li{white-space:nowrap;font-size:13.5px;flex-wrap:nowrap}
    .hero-list li strong{white-space:nowrap}
    /* panneau prix : pleine largeur */
    .hero-right{width:100%}
    .vip-card{width:100%;max-width:100%;min-width:0;padding:20px 16px}
    .vip-title{white-space:nowrap;font-size:21px}
    .vip-offer{padding:14px 14px}
    .vip-offer-screens{white-space:nowrap;font-size:17px}
    .vip-offer-months{white-space:nowrap}
    .vip-price-new{font-size:32px}
    .vip-price-old{font-size:18px}
    .vip-footer-line{white-space:nowrap;text-align:center;font-size:13px}

    /* ---------- SATURATED : centré ---------- */
    .section-saturated{padding-bottom:0;position:relative;overflow:hidden}
    .saturated-inner{padding-left:0px;padding-right:0px;padding-bottom:0}
    .saturated-left{max-width:100%;text-align:center;font-size:16px}
    .saturated-left h2{white-space:nowrap;font-size:26px}
    .saturated-left .word-red{
        display:block;font-size:70px;white-space:nowrap;text-align:center}
    .saturated-left p{white-space:nowrap;font-size:20px;line-height:1.3;margin-top:14px;text-align:center}
    /* players pleine largeur ; logos remontés (leur centre au-dessus de l'extrême bas des joueurs) */
    .saturated-photo{position:relative;z-index:2;margin:6px auto -90px;max-height:none;max-width:100%;width:100%;display:block}
    .saturated-strip{position:relative;background:none;padding:48px 0 26px;z-index:auto}
    .saturated-strip::before{
        content:'';position:absolute;z-index:0;top:-120px;bottom:0;
        left:calc(50% - 50vw);width:100vw;
        background:linear-gradient(180deg,#fff 0%,#cad9f1 50%,var(--blue) 100%);
    }
    .saturated-strip .marquee{position:relative;z-index:3}
    .chain-logo{padding:10px 0}
    .chain-logo img{max-height:34px}
    .marquee-track{gap:14px}

    /* ---------- CATALOGUE : liste 2 colonnes ---------- */
    .catalogue-controls{grid-template-columns:1fr;gap:14px}
    .catalogue-list{grid-template-columns:1fr 1fr;gap:10px 14px}
    .dropdown{font-size:18px;padding:16px 20px}
    .search-input{font-size:16px;padding:16px 20px}
    .catalogue-list li{font-size:12px;gap:8px}

    /* ---------- REGARDEZ (centré) ---------- */
    .regardez-content{padding-left:16px;padding-right:16px;text-align:center}
    .regardez-title{font-size:55px;text-align:center}
    .regardez-sub{white-space:nowrap;text-align:center;font-size:17px}
    .league-logo{width:100px;height:140px}

    /* ---------- COUNTDOWN ---------- */
    .section-countdown{padding:60px 18px}
    .countdown-title{font-size:40px;white-space:nowrap}
    .countdown-subtitle{font-size:28px;white-space:nowrap}
    .countdown-cell-num{font-size:48px}
    .countdown-line{gap:10px}
    .countdown-line::before,.countdown-line::after{flex:0 0 12px}
    .countdown-cell{min-width:0;flex:1;padding:14px 6px;border-radius:12px}
    .countdown-cell-label{font-size:11px;letter-spacing:.02em;margin-top:4px}
    .countdown-text,.countdown-text *{white-space:nowrap}
    .countdown-footnote{white-space:nowrap}

    /* ---------- FILMS (centré) ---------- */
    .films-header{padding-left:16px;padding-right:16px;text-align:center}
    .films-pretitle{white-space:nowrap;font-size:17px;text-align:center}
    .films-title{white-space:nowrap;font-size:40px;text-align:center}
    .film-poster{width:108px;height:156px}
    .popcorn{margin-right:-30px;left:auto;width:64px;bottom:-14px}
    .films-footer-text{text-align:center}
    .films-tagline{white-space:nowrap;font-size:20px;text-align:center}
    .films-subtagline{white-space:nowrap;font-size:20px;text-align:center}
    .films-footer-text *{white-space:nowrap}

    /* ---------- CINÉMA : 6 badges, texte sur 2 lignes ---------- */
    .features-grid{grid-template-columns:1fr;gap:18px;max-width:100%}
    .features-col{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
    .feature-card{font-size:12px;line-height:1.2;padding:12px 4px;height:auto;min-height:66px;border-radius:10px;flex-direction:column;gap:2px}
    .feature-card span{margin-right:0}
    .feature-card br{display:none}
    .features-tv img{max-width:100%}

    /* ---------- PLATEFORMES : 4 col, AUCUNE bordure/fond, coins arrondis sur l'image ---------- */
    .platforms-grid{grid-template-columns:repeat(4,1fr);gap:10px}
    .platform-tile{background:none;box-shadow:none;padding:0;height:auto;border:none}
    .platform-tile img{max-height:none;width:100%;height:auto;border-radius:12px}

    /* ---------- TOUT INCLUS CTA ---------- */
    .cta-red-title{font-size:30px;line-height:1.05}
    .cta-red-sub{font-size:24px;line-height:1.05;margin-bottom:22px}
    .section-cta-red .btn-cta-red{
        width:100%;display:flex;align-items:center;justify-content:space-between;
        gap:8px;text-align:left;font-size:14px;padding:16px 16px;
    }
    .section-cta-red .btn-cta-red > span:first-child{flex:0 0 auto;text-align:left}
    .section-cta-red .btn-cta-red svg{flex:0 0 auto;width:18px}
    .section-cta-red .btn-cta-red .price{white-space:nowrap;margin-left:auto;font-size:12px;padding:3px 7px}
    .cta-red-footnote{white-space:nowrap;text-align:center;font-size:13px}

    /* ---------- AVIS : collé à la section précédente ---------- */
    .section-reviews{padding-top:0;margin-top:0}
    .reviews-titles{text-align:center}
    .reviews-title-1{white-space:nowrap;font-size:18px}
    .reviews-title-2{white-space:nowrap;font-size:17px}
    .reviews-trust,.reviews-cap{font-size:14px}

    /* ---------- APPAREILS : bandeau défilant ---------- */
    .section-devices{overflow:hidden}
    .devices-grid{
        display:flex;grid-template-columns:none;width:max-content;max-width:none;
        margin:0;gap:14px;animation:marquee-rtl 18s linear infinite;
    }
    .device-tile{width:84px;flex-shrink:0}
    .device-tile.dup{display:block}
    .devices-strip{width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);margin-top:0;padding:18px 0}
    .devices-strip h3{font-size:24px;line-height:1.1}

    /* ---------- BENEFITS : checks 1 ligne, gauche, pleine largeur ---------- */
    .benefits-list li{white-space:nowrap;font-size:15px;width:100%;text-align:left}
    .benefits-list li strong{white-space:nowrap}
    .btn-benefits{width:100%;text-align:center;justify-content:center}

    /* ---------- FAQ : textes réduits ---------- */
    .faq-title{font-size:26px;white-space:nowrap;text-align:center}
    .faq-head{padding:16px 18px}
    .faq-q{font-size:14px;line-height:1.3}
    .faq-body{font-size:13.5px;padding-left:18px;padding-right:18px}
    .faq-item.--open .faq-body{padding-left:18px;padding-right:18px}
    .faq-toggle{width:44px;height:38px;margin-left:12px}

    /* ---------- BADGES (?, FAQ, ★★★) réduits ---------- */
    .faq-badge{padding:9px 22px;font-size:14px}
    .reviews-badge{padding:8px 16px;font-size:12px}
    .howitworks-badge{width:54px;height:54px;font-size:26px}

    /* ---------- TITRES DE SECTION ---------- */
    .catalogue-title,.features-title,.benefits-title,
    .howitworks-title,.cta-red-title,.tout-inclus-title{font-size:25px;line-height:1.15}

    /* ---------- BOUTONS : texte agrandi, lisible, une seule ligne ---------- */
    .btn-hero,.btn-countdown,.btn-benefits,.nav-cta{
        font-size:17px;padding:19px 22px;width:100%;justify-content:center;text-align:center;white-space:nowrap;
    }
    .btn-hero span,.btn-countdown span,.btn-benefits span,.btn-cta-red span{white-space:nowrap}

    /* ---------- GRADIENTS pleine largeur ---------- */
    .saturated-strip,.devices-strip{width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw)}

    /* ---------- SECTIONS COLLÉES : espaces verticaux réduits ---------- */
    .section-devices{margin-bottom: -60px}
    .section-catalogue,.section-regardez,.section-howitworks,.section-films,
    .section-features,.section-cta-red,.section-reviews,.section-devices,
    .section-benefits,.section-faq{padding-top:-30px;padding-bottom:30px}
    .section-countdown{padding:34px 18px}
    .section-saturated{padding-top:34px}
    .hero{padding-bottom:30px}
    .footer{padding-top:34px}
    .footer-grid{grid-template-columns:1fr;gap:30px;text-align:left}
}

/* =================================================================
   AJOUTS GLOBAUX (desktop + mobile)
   ================================================================= */

/* Bouton "Accéder à toutes les chaînes" : shake doux et fluide */
@keyframes shake-smooth{
    0%,70%,100%{transform:translateX(0)}
    74%{transform:translateX(-5px)}
    78%{transform:translateX(5px)}
    82%{transform:translateX(-4px)}
    86%{transform:translateX(4px)}
    90%{transform:translateX(-2px)}
    94%{transform:translateX(2px)}
}
.btn-hero,.btn-countdown,.btn-cta-red,.btn-benefits,.nav-cta{animation:shake-smooth 3.4s ease-in-out infinite;will-change:transform}
.btn-hero:hover,.btn-countdown:hover,.btn-cta-red:hover,.btn-benefits:hover,.nav-cta:hover{animation-play-state:paused}
@media (prefers-reduced-motion: reduce){.btn-hero,.btn-countdown,.btn-cta-red,.btn-benefits,.nav-cta{animation:none}}

/* Gradients (bandeaux) sur toute la largeur — DESKTOP/TABLETTE */
@media (min-width: 601px){
    .saturated-strip,.devices-strip{width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw)}
    .devices-strip{margin-top:60px;margin-bottom:0}
}
