/* =========================================================
   Premium IPTV France — main.css — 2026
   ========================================================= */

/* ---------- Variables ---------- */
:root {
  --bg:      #eef2ff;
  --bg-alt:  #ffffff;
  --text:    #111827;
  --muted:   #6b7280;
  --primary: #4f46e5;
  --secondary:#7c3aed;
  --accent:  #ec4899;
  --dark:    #111827;
  --white:   #fff;
  --radius:  1.2rem;
  --shadow:  0 4px 24px rgba(0,0,0,0.07);
  --shadow-h:0 10px 36px rgba(0,0,0,0.13);
}

/* ---------- Reset ---------- */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
body {
  font-family: "Inter", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  background: var(--bg);
  color: var(--text);
  line-height: 1.65;
  overflow-x: hidden;
}
img { max-width:100%; height:auto; display:block; }
a   { color:inherit; }

/* ---------- Typography ---------- */
.h1 { font-size:clamp(2rem,5vw,3.4rem); font-weight:800; line-height:1.15; margin-bottom:1.2rem; }
.h2 { font-size:clamp(1.6rem,3.5vw,2.4rem); font-weight:700; margin-bottom:1rem; text-align:center; }
.sub { color:var(--muted); text-align:center; margin:.4rem 0 2.5rem; font-size:1.05rem; }

/* ---------- Layout ---------- */
.container { width:90%; max-width:1200px; margin:0 auto; }
.section    { padding:5rem 0; }
.section.alt{ background:var(--bg-alt); }
.grid-3     { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:1.5rem; }

/* ---------- Header ---------- */
.header {
  position:sticky; top:0; z-index:1000;
  background:rgba(255,255,255,0.96);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  box-shadow:0 1px 0 rgba(0,0,0,0.07);
}
.nav {
  display:flex; justify-content:space-between; align-items:center;
  padding:.9rem 0;
}
.brand {
  display:flex; align-items:center; gap:.6rem;
  font-weight:800; font-size:1.05rem; color:var(--text); text-decoration:none;
}
.logo { width:42px; height:auto; }
.menu { display:flex; gap:1.8rem; align-items:center; }
.menu a {
  text-decoration:none; color:var(--text); font-weight:500; font-size:.92rem;
  transition:color .2s;
}
.menu a:hover { color:var(--primary); }

/* Hamburger */
.hamburger {
  display:none; flex-direction:column; gap:.34rem;
  background:none; border:none; cursor:pointer; padding:.5rem;
}
.hamburger span { width:24px; height:2.5px; background:var(--text); border-radius:2px; transition:.3s; }

/* ---------- Hero ---------- */
.hero {
  background: linear-gradient(140deg,#eef2ff 0%,#f5f8ff 50%,#f0f4ff 100%);
  text-align:center;
  padding:7rem 1rem 5.5rem;
  position:relative;
  overflow:hidden;
}
.hero::before {
  content:''; position:absolute; top:-40%; left:-15%;
  width:500px; height:500px; pointer-events:none;
  background:radial-gradient(circle,rgba(79,70,229,.07) 0%,transparent 70%);
}
.hero::after {
  content:''; position:absolute; bottom:-25%; right:-8%;
  width:420px; height:420px; pointer-events:none;
  background:radial-gradient(circle,rgba(124,58,237,.05) 0%,transparent 70%);
}
.hero__content { position:relative; z-index:1; text-align:center; }

.badge-top {
  display:block;
  width:fit-content;
  margin:0 auto 1.4rem;
  background:linear-gradient(135deg,#fce7f3,#fdf2f8);
  color:#be185d;
  border:1px solid #fbcfe8;
  padding:.38rem 1.1rem;
  border-radius:999px;
  font-size:.82rem; font-weight:700;
  letter-spacing:.07em; text-transform:uppercase;
  text-align:center;
}
.lead {
  font-size:1.15rem; color:var(--muted);
  margin-bottom:1.2rem; max-width:620px;
  margin-left:auto; margin-right:auto;
}
.clients { font-size:1rem; margin-bottom:2rem; color:var(--primary); font-weight:600; }
.seo-intro { color:var(--muted); font-size:.93rem; max-width:700px; margin:0 auto 1rem; }
.seo-intro.small { font-size:.87rem; }

/* CTA */
.cta { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; margin-top:2rem; }

/* ---------- Buttons ---------- */
.btn {
  display:inline-flex; align-items:center; justify-content:center;
  padding:.82rem 1.8rem; border-radius:999px;
  font-weight:600; font-size:.93rem;
  text-decoration:none; transition:all .25s ease; cursor:pointer;
  border:2px solid transparent;
}
.btn--primary {
  background:var(--primary); color:var(--white);
  box-shadow:0 4px 18px rgba(79,70,229,.3);
}
.btn--primary:hover {
  background:var(--secondary);
  box-shadow:0 6px 24px rgba(79,70,229,.4);
  transform:translateY(-1px);
}
.btn--ghost {
  border-color:rgba(79,70,229,.3); color:var(--primary);
  background:transparent;
}
.btn--ghost:hover {
  border-color:var(--primary); background:rgba(79,70,229,.05);
}

/* ---------- Hero Deco ---------- */
.hero-deco {
  position:absolute; pointer-events:none;
  display:flex; align-items:center; justify-content:center;
  border-radius:22%;
}
.hero-deco--play {
  width:68px; height:68px;
  background:linear-gradient(135deg,#f9a8d4,#ec4899);
  top:14%; left:5%; font-size:1.7rem; color:white;
  box-shadow:0 8px 24px rgba(236,72,153,.3);
  animation:floatA 4s ease-in-out infinite;
}
.hero-deco--tv {
  width:74px; height:74px;
  background:linear-gradient(135deg,#a78bfa,#7c3aed);
  bottom:18%; right:5%; font-size:1.5rem; color:white;
  box-shadow:0 8px 24px rgba(124,58,237,.3);
  animation:floatB 5s ease-in-out infinite;
}
.hero-deco--dot {
  width:17px; height:17px; border-radius:50%;
  background:rgba(124,58,237,.22);
  top:24%; right:22%;
  animation:floatC 6s ease-in-out infinite;
}
.hero-deco--dot2 {
  width:13px; height:13px; border-radius:50%;
  background:rgba(236,72,153,.18);
  top:60%; left:14%;
  animation:floatC 7s ease-in-out infinite reverse;
}
.hero-deco--sport {
  width:54px; height:54px; border-radius:50%;
  background:#ec4899; color:white;
  font-size:.68rem; font-weight:700; letter-spacing:.05em;
  bottom:14%; left:7%;
  box-shadow:0 6px 20px rgba(236,72,153,.3);
  animation:floatA 5.5s ease-in-out infinite .5s;
}
.hero-deco--circle {
  width:34px; height:34px; border-radius:50%;
  border:3px solid rgba(79,70,229,.18);
  bottom:28%; right:6%;
  animation:floatB 8s ease-in-out infinite;
}
@keyframes floatA { 0%,100%{transform:translateY(0) rotate(-4deg)} 50%{transform:translateY(-15px) rotate(4deg)} }
@keyframes floatB { 0%,100%{transform:translateY(0) rotate(4deg)} 50%{transform:translateY(-12px) rotate(-4deg)} }
@keyframes floatC { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)} }

/* ---------- Channel Ticker ---------- */
.channels-ticker {
  background:var(--bg-alt);
  padding:1.4rem 0 1.8rem;
  border-top:1px solid rgba(0,0,0,0.06);
  border-bottom:1px solid rgba(0,0,0,0.06);
  overflow:hidden;
}
.ticker-label {
  text-align:center; font-size:.75rem; font-weight:700;
  color:var(--muted); letter-spacing:.12em; text-transform:uppercase;
  margin-bottom:.8rem;
}
.ticker-wrap { position:relative; overflow:hidden; }
.ticker-wrap::before,
.ticker-wrap::after {
  content:''; position:absolute; top:0; z-index:2;
  width:80px; height:100%; pointer-events:none;
}
.ticker-wrap::before { left:0;  background:linear-gradient(to right,white,transparent); }
.ticker-wrap::after  { right:0; background:linear-gradient(to left,white,transparent); }
.ticker-track {
  display:flex; gap:1rem; width:max-content;
  animation:ticker-scroll 40s linear infinite;
  padding:.2rem .5rem;
}
.ticker-track--reverse {
  animation-name:ticker-scroll-reverse;
  animation-duration:38s;
}
.ticker-wrap:hover .ticker-track,
.ticker-wrap--reverse:hover .ticker-track--reverse { animation-play-state:paused; }
.ticker-wrap--reverse { margin-top:.6rem; }
.ticker-wrap--reverse::before { background:linear-gradient(to right,var(--bg-alt),transparent); }
.ticker-wrap--reverse::after  { background:linear-gradient(to left,var(--bg-alt),transparent); }
.channel-pill {
  display:flex; align-items:center; gap:.5rem;
  background:var(--bg); border:1px solid rgba(0,0,0,0.07);
  border-radius:999px; padding:.45rem 1.1rem;
  white-space:nowrap; font-weight:600; font-size:.88rem; color:var(--text);
  transition:transform .2s;
}
.channel-pill:hover { transform:scale(1.05); }
.ch-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; }
@keyframes ticker-scroll {
  0%   { transform:translateX(0); }
  100% { transform:translateX(-50%); }
}
@keyframes ticker-scroll-reverse {
  0%   { transform:translateX(-50%); }
  100% { transform:translateX(0); }
}

/* ---------- Cards ---------- */
.card {
  background:var(--bg-alt); border-radius:var(--radius);
  padding:2rem 1.5rem; text-align:center;
  box-shadow:var(--shadow);
  transition:transform .3s,box-shadow .3s;
}
.card:hover { transform:translateY(-4px); box-shadow:var(--shadow-h); }
.card .icon {
  margin-bottom:1rem;
  display:flex; align-items:center; justify-content:center;
  width:56px; height:56px;
  background:rgba(79,70,229,.08);
  border-radius:1rem;
  margin-left:auto; margin-right:auto;
}
.card .icon svg { color:var(--primary); }
.features-grid .card:nth-child(2) .icon,
.why-grid .card:nth-child(2) .icon { background:rgba(255,255,255,.12); }
.features-grid .card:nth-child(2) .icon svg,
.why-grid .card:nth-child(2) .icon svg { color:white; }
.card h3 { font-size:1.05rem; font-weight:700; margin-bottom:.45rem; }
.card p  { color:var(--muted); font-size:.93rem; }

/* Dark 2nd card */
.features-grid .card:nth-child(2),
.why-grid .card:nth-child(2) {
  background:var(--dark); color:white;
}
.features-grid .card:nth-child(2) h3,
.why-grid .card:nth-child(2) h3 { color:white; }
.features-grid .card:nth-child(2) p,
.why-grid .card:nth-child(2) p  { color:rgba(255,255,255,.72); }

/* ---------- Steps ---------- */
.steps { display:flex; gap:2rem; justify-content:center; flex-wrap:wrap; margin:2rem 0 3rem; }
.step  { flex:1; min-width:180px; text-align:center; }
.step__num {
  display:inline-flex; align-items:center; justify-content:center;
  width:44px; height:44px;
  background:linear-gradient(135deg,var(--primary),var(--secondary));
  color:white; border-radius:50%; margin-bottom:.7rem;
  font-weight:700; font-size:1.1rem;
  box-shadow:0 4px 16px rgba(79,70,229,.3);
}
.step h3 { font-size:1rem; font-weight:600; }

/* ---------- Tabs Tarifs ---------- */
.tabs { display:flex; justify-content:center; gap:.6rem; flex-wrap:wrap; margin-bottom:2rem; }
.tab-btn {
  background:var(--bg-alt); border:2px solid rgba(79,70,229,.15);
  padding:.6rem 1.5rem; border-radius:999px;
  cursor:pointer; font-weight:600; font-size:.9rem;
  transition:all .25s; color:var(--text);
}
.tab-btn.active,
.tab-btn:hover { background:var(--primary); color:white; border-color:var(--primary); }
.tab-content        { display:none; }
.tab-content.active { display:block; }

.pricing { display:grid; gap:1.5rem; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); }
.p-card {
  background:var(--bg); border-radius:var(--radius);
  padding:2.5rem 2rem; text-align:center;
  box-shadow:var(--shadow); position:relative;
  transition:transform .3s,box-shadow .3s;
  border:2px solid transparent;
}
.p-card:hover { transform:translateY(-5px); box-shadow:var(--shadow-h); }
.p-card--recommended {
  background:var(--dark); color:white;
}
.p-card--recommended .p-name  { color:rgba(255,255,255,.55); }
.p-card--recommended .p-price { color:white; }
.p-card--recommended .p-feats { color:rgba(255,255,255,.78); }
.p-card--recommended .p-feats li::before { color:#60a5fa; }
.p-name  { font-weight:600; color:var(--muted); font-size:.82rem; letter-spacing:.08em; text-transform:uppercase; }
.p-price { font-size:2.2rem; font-weight:800; margin:.8rem 0; }
.p-feats { list-style:none; text-align:left; margin:1rem 0 1.5rem; color:var(--muted); }
.p-feats li {
  padding:.28rem 0; font-size:.9rem;
  display:flex; align-items:center; gap:.5rem;
}
.p-feats li::before { content:'✓'; color:var(--primary); font-weight:700; flex-shrink:0; }
.badge {
  position:absolute; top:-12px; right:18px;
  background:var(--primary); color:white;
  padding:.3rem .9rem; border-radius:999px;
  font-size:.76rem; font-weight:700;
  letter-spacing:.05em; text-transform:uppercase;
}

/* ---------- Stats ---------- */
.stat { text-align:center; }
.stat h3 { font-size:2.5rem; font-weight:800; margin-bottom:.3rem; }
.stat p  { color:var(--muted); }

/* ---------- Comparatif ---------- */
.comparatif {
  width:100%; border-collapse:collapse; margin-top:2rem;
  border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow);
}
.comparatif th, .comparatif td { padding:1.1rem; text-align:center; font-size:.93rem; }
.comparatif th { background:var(--primary); color:white; font-weight:600; }
.comparatif tr:nth-child(even) td { background:rgba(79,70,229,.03); }
.comparatif td { border-bottom:1px solid rgba(0,0,0,.05); }

/* ---------- Testimonials Slider ---------- */
#avis { overflow:hidden; }
.avis-slider-wrapper {
  overflow:hidden;
  position:relative;
  padding:1.5rem 0 2rem;
  cursor:grab;
  user-select:none;
  -webkit-user-select:none;
}
.avis-slider-wrapper.is-dragging { cursor:grabbing; }
.avis-track {
  display:flex;
  gap:1.5rem;
  padding:0 2rem;
  will-change:transform;
  /* JS drives the transform — no CSS animation */
}
.testi-card {
  flex:0 0 320px;
  background:var(--bg-alt);
  border-radius:var(--radius);
  padding:1.8rem;
  box-shadow:var(--shadow);
  pointer-events:none;  /* let wrapper handle drag */
}
.testi-stars { color:#f59e0b; font-size:1.1rem; margin-bottom:.8rem; letter-spacing:.05em; }
.testi-text {
  color:var(--text); font-size:.91rem; line-height:1.7;
  margin-bottom:1.2rem;
}
.testi-author { display:flex; align-items:center; gap:.8rem; }
.testi-avatar {
  width:40px; height:40px; border-radius:50%;
  color:white; font-size:.78rem; font-weight:700;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0;
}
.testi-name    { display:block; font-weight:600; font-size:.9rem; color:var(--text); }
.testi-verified{ display:block; font-size:.76rem; color:#22c55e; font-weight:500; margin-top:.1rem; }

/* ---------- Movie Slider ---------- */
.movie-slider-section { padding:4rem 0; overflow:hidden; }
.movie-slider-section .h2 { margin-bottom:2rem; }
.movie-slider-wrapper {
  position:relative;
  padding:0 2rem;
  overflow:hidden;
}
.movie-track {
  display:flex; gap:1rem;
  width:max-content;
  animation:movie-scroll 45s linear infinite;
  padding:.5rem .2rem 1rem;
}
.movie-track:hover { animation-play-state:paused; }
.movie-track.paused { animation-play-state:paused; }
.movie-card {
  flex:0 0 160px; border-radius:1rem; overflow:hidden;
  box-shadow:var(--shadow); position:relative;
  transition:transform .3s; cursor:pointer;
}
.movie-card:hover { transform:scale(1.06); box-shadow:var(--shadow-h); }
.movie-card img { width:100%; height:240px; object-fit:cover; display:block; }
.movie-title {
  position:absolute; bottom:0; left:0; right:0;
  background:linear-gradient(transparent,rgba(0,0,0,.75));
  color:white; font-size:.72rem; font-weight:700;
  padding:.5rem .6rem .5rem;
  letter-spacing:.04em;
}
.movie-nav-btn {
  position:absolute; top:50%; transform:translateY(-50%);
  background:white; border:none; border-radius:50%;
  width:44px; height:44px;
  display:flex; align-items:center; justify-content:center;
  font-size:1.5rem; font-weight:300;
  box-shadow:var(--shadow); cursor:pointer; z-index:3;
  transition:box-shadow .2s,transform .2s;
  color:var(--text);
}
.movie-nav-btn:hover { box-shadow:var(--shadow-h); transform:translateY(-50%) scale(1.1); }
.movie-nav-btn.prev { left:.2rem; }
.movie-nav-btn.next { right:.2rem; }
@keyframes movie-scroll {
  0%   { transform:translateX(0); }
  100% { transform:translateX(-50%); }
}

/* ---------- Garanties ---------- */
#garanties .card h3 { margin-bottom:.5rem; color:var(--primary); }

/* ---------- Revendeur teaser ---------- */
#revendeur-teaser { text-align:center; }
#revendeur-teaser p { margin:1rem 0 2rem; color:var(--muted); }

/* ---------- SEO block ---------- */
#seo-block p { color:var(--muted); margin-bottom:1rem; line-height:1.8; }

/* ---------- FAQ ---------- */
.faq {
  margin-bottom:.7rem;
  border:1px solid rgba(0,0,0,.08);
  border-radius:var(--radius);
  background:var(--bg-alt); overflow:hidden;
}
.faq summary {
  font-weight:600; cursor:pointer;
  padding:1.15rem 1.5rem;
  list-style:none;
  display:flex; justify-content:space-between; align-items:center;
  font-size:.97rem; user-select:none;
}
.faq summary::-webkit-details-marker { display:none; }
.faq summary::after {
  content:'+'; font-size:1.5rem; color:var(--primary);
  font-weight:300; line-height:1;
  transition:transform .3s; flex-shrink:0; margin-left:1rem;
}
details[open] > summary::after { transform:rotate(45deg); }
.faq p { padding:0 1.5rem 1.2rem; color:var(--muted); font-size:.93rem; }

/* ---------- Contact ---------- */
.contact { text-align:center; }
.contact-list { list-style:none; margin-top:1.5rem; }
.contact-list li { margin-bottom:1rem; font-size:1.05rem; }
.contact-list a { color:var(--primary); text-decoration:none; font-weight:500; }
.contact-list a:hover { text-decoration:underline; }

/* ---------- Footer ---------- */
.footer {
  background:#f8f9fb;
  border-top:1px solid rgba(0,0,0,.06);
  padding:2.5rem 0; text-align:center;
}
.foot p { color:var(--muted); font-size:.9rem; }
.footer nav { margin-top:1rem; display:flex; gap:1.5rem; justify-content:center; flex-wrap:wrap; }
.footer nav a { text-decoration:none; color:var(--muted); font-size:.84rem; transition:color .2s; }
.footer nav a:hover { color:var(--primary); }

/* ---------- WhatsApp Float ---------- */
.whatsapp-float {
  position:fixed; bottom:80px; right:20px;
  background:#25d366; color:white;
  width:56px; height:56px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:1.6rem;
  box-shadow:0 4px 20px rgba(37,211,102,.4);
  z-index:1000; text-decoration:none;
  transition:transform .3s;
}
.whatsapp-float:hover { transform:scale(1.1); }

/* ---------- Sticky Bar ---------- */
.sticky-bar {
  position:fixed; bottom:0; left:0; width:100%;
  background:var(--bg-alt);
  border-top:1px solid rgba(0,0,0,.07);
  padding:.8rem 1.5rem;
  display:flex; justify-content:space-between; align-items:center;
  z-index:999; box-shadow:0 -4px 16px rgba(0,0,0,.07);
}
.sticky-bar a { font-weight:600; text-decoration:none; color:var(--text); }

/* ---------- Shimmer ---------- */
.shimmer {
  position:relative; display:inline-block;
  background:linear-gradient(135deg,var(--primary),var(--secondary));
  -webkit-background-clip:text; background-clip:text;
  color:transparent; overflow:hidden;
}
.shimmer::before {
  content:""; position:absolute; inset:0;
  background:linear-gradient(120deg,transparent 0%,rgba(255,255,255,.5) 50%,transparent 100%);
  transform:translateX(-100%);
  animation:shimmer-move 3s infinite; pointer-events:none;
}
@keyframes shimmer-move {
  0%   { transform:translateX(-100%); }
  60%  { transform:translateX(100%); }
  100% { transform:translateX(100%); }
}

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width:768px) {
  .menu {
    display:none; flex-direction:column; gap:.8rem;
    background:white; padding:1.2rem; position:absolute;
    top:65px; right:10px; box-shadow:var(--shadow);
    border-radius:var(--radius); min-width:180px; z-index:999;
  }
  .menu.show { display:flex; }
  .hamburger { display:flex; }
  .hero { padding:5rem 1rem 4rem; }
  .hero-deco--tv { display:none; }
  .hero-deco--play { width:54px; height:54px; font-size:1.3rem; left:2%; top:12%; }
  .hero-deco--sport { width:44px; height:44px; font-size:.62rem; left:3%; }
  .movie-card { flex:0 0 130px; }
  .movie-card img { height:195px; }
}

@media (max-width:480px) {
  html,body { font-size:15px; overflow-x:hidden; }
  .hero { padding:4rem 1rem 3rem; }
  .h1  { font-size:1.85rem; line-height:1.25; }
  .lead { font-size:.95rem; }
  .cta { flex-direction:column; }
  .btn { width:100%; text-align:center; }
  .grid-3 { grid-template-columns:1fr; gap:1rem; }
  .card { padding:1.3rem; }
  .steps { flex-direction:column; gap:1.2rem; }
  .comparatif { font-size:.8rem; }
  .comparatif th,.comparatif td { padding:.6rem .4rem; }
  .testis { flex-direction:column; }
  .testi { max-width:100%; }
  .sticky-bar { flex-direction:column; gap:.5rem; padding:.8rem 1rem; }
  .sticky-bar a { width:100%; text-align:center; }
  .whatsapp-float { bottom:80px; right:12px; }
  .footer nav { flex-direction:column; gap:.4rem; }

  /* Tarifs mobile */
  .tab-content.active { display:block; }
  .pricing { display:flex; flex-direction:column; align-items:center; gap:1.2rem; }
  .p-card { width:95%; max-width:380px; }

  .movie-card { flex:0 0 110px; }
  .movie-card img { height:165px; }
  .movie-nav-btn { display:none; }
  .hero-deco--dot,.hero-deco--dot2,.hero-deco--circle { display:none; }
}
