/* ===================================================
   Zonnex — Abonnement IPTV Premium France
   Inspiration cloned: dark navy + vivid green accent
   =================================================== */

:root{
  --bg:#0F1729;
  --bg-2:#0b1124;
  --nav-bg:rgba(15,23,41,0.82);
  --card-bg:rgba(255,255,255,0.04);
  --card-bg-strong:rgba(255,255,255,0.06);
  --primary:#22c55e;
  --primary-hover:#1ea34d;
  --primary-glow:rgba(34,197,94,0.20);
  --text:#F8FAFC;
  --text-muted:#94a3b8;
  --text-dim:#cbd5e1;
  --border:rgba(255,255,255,0.10);
  --border-strong:rgba(255,255,255,0.18);
  --whatsapp:#25D366;
  --whatsapp-hover:#20bd5a;
  --gradient-overlay:linear-gradient(180deg,rgba(15,23,41,0.55) 0%,rgba(15,23,41,0.95) 100%);
  --radius:14px;
  --radius-lg:20px;
  --radius-pill:9999px;
  --shadow-glow:0 10px 40px -10px rgba(34,197,94,0.35);
  --max:1180px;
  --font-heading:'Manrope','Plus Jakarta Sans','Inter',system-ui,sans-serif;
  --font-body:'Inter','Plus Jakarta Sans',system-ui,sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;padding:0;
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color .2s ease}

h1,h2,h3,h4,h5{font-family:var(--font-heading);color:#fff;line-height:1.2;letter-spacing:-.01em;margin:0 0 .8rem}
h1{font-size:clamp(2rem,5vw,3.5rem);font-weight:800}
h2{font-size:clamp(1.5rem,3.5vw,2.4rem);font-weight:800}
h3{font-size:clamp(1.15rem,2vw,1.45rem);font-weight:700}
p{margin:0 0 1rem;color:var(--text-dim)}

.container{max-width:var(--max);margin:0 auto;padding:0 1.25rem}

/* ===== Nav ===== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:60;
  background:var(--nav-bg);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--border);
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:78px;
  max-width:var(--max);margin:0 auto;padding:0 1.25rem;
}
.logo{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--font-heading);font-weight:800;letter-spacing:.5px;
  color:#fff;font-size:1.55rem;
}
.logo .logo-mark{
  width:38px;height:38px;border-radius:10px;
  background:linear-gradient(135deg,var(--primary) 0%,#16a34a 100%);
  display:inline-flex;align-items:center;justify-content:center;
  color:#072e15;font-size:1rem;font-weight:900;
  box-shadow:0 6px 18px -6px var(--primary-glow);
}
.logo span{color:var(--primary)}
.nav-menu{display:flex;align-items:center;gap:1.8rem}
.nav-menu a{
  color:var(--text-dim);font-weight:500;font-size:.92rem;
  transition:color .2s;
}
.nav-menu a:hover{color:#fff}
.nav-cta{
  background:var(--primary);color:#072e15;
  padding:.65rem 1.4rem;border-radius:var(--radius-pill);
  font-weight:800;font-size:.85rem;letter-spacing:.6px;
  text-transform:uppercase;border:none;cursor:pointer;
  transition:background .2s,transform .2s;
}
.nav-cta:hover{background:var(--primary-hover);transform:translateY(-1px)}
.nav-toggle{display:none;background:none;border:none;color:#fff;font-size:1.6rem;cursor:pointer;padding:.4rem}

@media (max-width:880px){
  .nav-menu{
    position:absolute;top:78px;left:0;right:0;
    flex-direction:column;align-items:stretch;gap:0;
    background:var(--bg);padding:1rem 1.25rem;
    border-bottom:1px solid var(--border);
    display:none;
  }
  .nav-menu.open{display:flex}
  .nav-menu a{padding:.85rem 0;border-bottom:1px solid var(--border)}
  .nav-cta{margin-top:.5rem;text-align:center}
  .nav-toggle{display:inline-flex}
}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.95rem 1.7rem;font-weight:700;font-size:.95rem;
  border-radius:var(--radius-pill);
  border:none;cursor:pointer;text-decoration:none;
  min-height:48px;
  transition:transform .2s,background .2s,box-shadow .2s;
  letter-spacing:.3px;
}
.btn-primary{background:var(--primary);color:#072e15;box-shadow:var(--shadow-glow)}
.btn-primary:hover{background:var(--primary-hover);transform:translateY(-2px)}
.btn-secondary{background:transparent;color:#fff;border:1.5px solid var(--border-strong)}
.btn-secondary:hover{background:rgba(255,255,255,.06)}
.btn-whatsapp{background:var(--whatsapp);color:#fff}
.btn-whatsapp:hover{background:var(--whatsapp-hover)}
.btn-lg{padding:1.1rem 2rem;font-size:1.05rem}
.btn-block{width:100%}

/* ===== Hero ===== */
.hero{
  position:relative;padding:9rem 0 6rem;overflow:hidden;
  background:radial-gradient(900px 600px at 80% 10%,rgba(34,197,94,0.10),transparent 60%),
             radial-gradient(700px 500px at 10% 90%,rgba(34,197,94,0.06),transparent 60%),
             var(--bg);
}
.hero-bg{
  position:absolute;inset:0;z-index:0;
  background:var(--gradient-overlay),url('../images/hero-bg.webp') center/cover no-repeat;
  opacity:.45;
}
.hero-inner{position:relative;z-index:1;text-align:center;max-width:880px;margin:0 auto}
.hero .eyebrow{
  display:inline-block;padding:.45rem 1rem;border-radius:var(--radius-pill);
  background:rgba(34,197,94,.10);color:var(--primary);
  font-size:.78rem;letter-spacing:1.6px;text-transform:uppercase;
  font-weight:700;border:1px solid rgba(34,197,94,.25);margin-bottom:1.4rem;
}
.hero h1{font-size:clamp(2.2rem,5.6vw,4rem);margin-bottom:1.2rem}
.hero h1 .accent{
  background:linear-gradient(120deg,var(--primary) 0%,#86efac 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero p.lead{font-size:clamp(1.05rem,1.5vw,1.2rem);color:var(--text-dim);max-width:680px;margin:0 auto 2rem}
.hero-cta-row{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-top:1.5rem}

/* ===== Stats bar ===== */
.stats{
  background:rgba(255,255,255,.02);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:2.5rem 0;
}
.stats-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;text-align:center;
}
.stat-val{
  font-family:var(--font-heading);font-weight:800;
  font-size:clamp(1.6rem,3vw,2.2rem);color:var(--primary);display:block;
}
.stat-lbl{color:var(--text-muted);font-size:.85rem;text-transform:uppercase;letter-spacing:1.2px;margin-top:.35rem}
@media (max-width:680px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:2rem}}

/* ===== Sections ===== */
.section{padding:5.5rem 0;position:relative}
.section-light{background:#0c1322}
.section-head{text-align:center;max-width:760px;margin:0 auto 3rem}
.section-head .eyebrow{
  display:inline-block;color:var(--primary);font-weight:700;font-size:.82rem;
  letter-spacing:2px;text-transform:uppercase;margin-bottom:.8rem;
}
.section-head h2{margin-bottom:.8rem}
.section-head p{color:var(--text-muted);font-size:1.05rem}

/* ===== Pricing ===== */
.pricing-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem;
}
@media (max-width:980px){.pricing-grid{grid-template-columns:1fr;max-width:480px;margin:0 auto}}
.price-card{
  background:var(--card-bg);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:2.2rem 1.8rem;position:relative;
  transition:transform .25s,border-color .25s,background .25s;
}
.price-card:hover{transform:translateY(-4px);border-color:rgba(34,197,94,.35);background:var(--card-bg-strong)}
.price-card.featured{border-color:var(--primary);background:linear-gradient(180deg,rgba(34,197,94,.07),rgba(34,197,94,.02))}
.price-card.featured::before{
  content:"PLUS POPULAIRE";position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:var(--primary);color:#072e15;
  padding:.35rem 1rem;border-radius:var(--radius-pill);
  font-size:.7rem;font-weight:800;letter-spacing:1.2px;
}
.price-name{font-size:1rem;text-transform:uppercase;letter-spacing:2px;color:var(--primary);font-weight:700;margin-bottom:.6rem}
.price-amount{font-family:var(--font-heading);font-weight:800;font-size:2.8rem;line-height:1;color:#fff;margin-bottom:.3rem}
.price-amount sup{font-size:1.1rem;font-weight:700;vertical-align:top;margin-right:.15rem}
.price-period{color:var(--text-muted);font-size:.92rem;margin-bottom:1.6rem}
.price-list{list-style:none;padding:0;margin:0 0 1.8rem;color:var(--text-dim)}
.price-list li{
  padding:.55rem 0;border-bottom:1px solid rgba(255,255,255,.05);
  display:flex;align-items:flex-start;gap:.6rem;font-size:.93rem;
}
.price-list li::before{content:"✓";color:var(--primary);font-weight:900;flex-shrink:0}
.price-list li:last-child{border-bottom:none}

/* ===== Features grid ===== */
.features-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;
}
@media (max-width:900px){.features-grid{grid-template-columns:1fr;max-width:560px;margin:0 auto}}
.feature-card{
  background:var(--card-bg);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:1.8rem;transition:border-color .25s,transform .25s;
}
.feature-card:hover{border-color:rgba(34,197,94,.30);transform:translateY(-2px)}
.feature-icon{
  width:54px;height:54px;border-radius:14px;
  background:rgba(34,197,94,.10);color:var(--primary);
  display:inline-flex;align-items:center;justify-content:center;
  font-size:1.5rem;margin-bottom:1rem;
  border:1px solid rgba(34,197,94,.20);
}
.feature-card h3{font-size:1.15rem;margin-bottom:.5rem}
.feature-card p{color:var(--text-muted);font-size:.95rem;margin:0}

/* ===== FAQ ===== */
.faq-list{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:.85rem}
.faq-item{
  background:var(--card-bg);
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
}
.faq-item summary{
  list-style:none;cursor:pointer;
  padding:1.1rem 1.3rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;
  font-weight:600;color:#fff;font-size:1rem;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:"+";color:var(--primary);font-size:1.5rem;font-weight:300;
  transition:transform .25s;flex-shrink:0;
}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-answer{padding:0 1.3rem 1.2rem;color:var(--text-muted);font-size:.95rem;line-height:1.7}

/* ===== Article / SEO content ===== */
.article-wrap{max-width:860px;margin:0 auto;color:var(--text-dim)}
.article-wrap h2{margin-top:2.2rem}
.article-wrap h3{margin-top:1.8rem;color:#fff}
.article-wrap p{line-height:1.75;font-size:1rem}
.article-wrap ul{padding-left:1.4rem;color:var(--text-dim)}
.article-wrap ul li{margin-bottom:.5rem}
.article-wrap a{color:var(--primary)}
.article-wrap a:hover{color:var(--primary-hover);text-decoration:underline}

/* ===== Forms ===== */
.form-wrap{
  background:var(--card-bg-strong);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:2.2rem;max-width:560px;margin:0 auto;
}
.form-wrap h3{margin-bottom:.4rem}
.form-wrap .form-sub{color:var(--text-muted);font-size:.92rem;margin-bottom:1.5rem}
.field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1.1rem}
.field label{font-size:.85rem;font-weight:600;color:var(--text-dim);letter-spacing:.3px}
.field input,.field select,.field textarea{
  background:rgba(255,255,255,.04);
  border:1px solid var(--border-strong);
  color:#fff;
  padding:.85rem 1rem;border-radius:10px;
  font-family:inherit;font-size:1rem;
  min-height:48px;outline:none;
  transition:border-color .2s,background .2s;
}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--primary);background:rgba(34,197,94,.04)}
.field textarea{resize:vertical;min-height:120px}
.honeypot{position:absolute;left:-9999px;opacity:0;pointer-events:none}
.trust-row{
  display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;
  color:var(--text-muted);font-size:.82rem;margin-top:1rem;
}
.trust-row span::before{content:"🔒 ";color:var(--primary)}
.form-message{margin-top:1rem;padding:.85rem 1rem;border-radius:10px;font-size:.92rem}
.form-message--success{background:rgba(34,197,94,.12);color:#86efac;border:1px solid rgba(34,197,94,.30)}
.form-message--error{background:rgba(239,68,68,.12);color:#fca5a5;border:1px solid rgba(239,68,68,.30)}

/* ===== Channels ===== */
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
@media (max-width:900px){.cat-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.cat-grid{grid-template-columns:1fr}}
.cat-card{
  background:var(--card-bg);border:1px solid var(--border);
  border-radius:var(--radius);padding:1.2rem;text-align:center;
  transition:border-color .25s,transform .25s;
}
.cat-card:hover{border-color:rgba(34,197,94,.30);transform:translateY(-2px)}
.cat-card .cat-icon{font-size:1.8rem;display:block;margin-bottom:.4rem;color:var(--primary)}
.cat-card h4{color:#fff;margin:.2rem 0;font-size:1rem}
.cat-card p{color:var(--text-muted);font-size:.82rem;margin:0}

/* ===== Steps ===== */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;margin-top:2rem}
@media (max-width:980px){.steps{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.steps{grid-template-columns:1fr}}
.step{
  background:var(--card-bg);border:1px solid var(--border);
  border-radius:var(--radius);padding:1.5rem;position:relative;
}
.step-num{
  position:absolute;top:-15px;left:1.2rem;
  width:34px;height:34px;border-radius:50%;
  background:var(--primary);color:#072e15;
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:.9rem;
}
.step h4{color:#fff;margin:.4rem 0 .4rem;font-size:1.05rem}
.step p{color:var(--text-muted);font-size:.9rem;margin:0}

/* ===== Contact / Cards row ===== */
.duo-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;max-width:860px;margin:0 auto}
@media (max-width:780px){.duo-grid{grid-template-columns:1fr}}
.info-card{
  background:var(--card-bg-strong);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:2rem;
}
.info-card h3{display:flex;align-items:center;gap:.6rem;font-size:1.25rem;margin-bottom:1rem}
.info-card h3 .ico{color:var(--primary);font-size:1.3rem}
.info-card p{color:var(--text-dim);margin-bottom:1.2rem}

/* ===== CTA banner ===== */
.cta-banner{
  background:linear-gradient(135deg,rgba(34,197,94,.10) 0%,rgba(34,197,94,.04) 100%);
  border:1px solid rgba(34,197,94,.25);
  border-radius:var(--radius-lg);
  padding:3rem 2rem;text-align:center;
  max-width:880px;margin:0 auto;
}
.cta-banner h2{margin-bottom:.8rem}
.cta-banner p{color:var(--text-dim);margin-bottom:1.5rem}

/* ===== Footer ===== */
.footer{background:#0a1020;border-top:1px solid var(--border);padding:4rem 0 1.5rem;margin-top:2rem}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2.5rem;margin-bottom:2.5rem}
@media (max-width:900px){.footer-grid{grid-template-columns:1fr 1fr;gap:2rem}}
@media (max-width:520px){.footer-grid{grid-template-columns:1fr}}
.footer-brand p{color:var(--text-muted);font-size:.92rem;line-height:1.7;margin-top:.8rem}
.footer h4{font-size:.95rem;color:#fff;margin-bottom:1.1rem;font-weight:700}
.footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.6rem}
.footer ul li a,.footer ul li{color:var(--text-muted);font-size:.9rem;transition:color .2s}
.footer ul li a:hover{color:var(--primary)}
.footer-bottom{
  border-top:1px solid var(--border);padding-top:1.6rem;
  text-align:center;color:var(--text-muted);font-size:.82rem;
}
.footer-bottom p{margin:.4rem auto;max-width:780px;color:var(--text-muted)}

/* ===== Utilities ===== */
.text-center{text-align:center}
.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}
.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}

/* ===== Legal pages ===== */
.legal{padding:7rem 0 4rem}
.legal-wrap{max-width:820px;margin:0 auto}
.legal-wrap h1{margin-bottom:.5rem}
.legal-wrap .updated{color:var(--text-muted);font-size:.9rem;margin-bottom:2rem}
.legal-wrap h2{margin-top:2.2rem;font-size:1.4rem;color:#fff}
.legal-wrap h3{margin-top:1.5rem;color:#fff;font-size:1.1rem}
.legal-wrap p,.legal-wrap li{color:var(--text-dim);line-height:1.75;font-size:.98rem}
.legal-wrap ul,.legal-wrap ol{padding-left:1.3rem}
.legal-wrap table{width:100%;border-collapse:collapse;margin:1rem 0;background:var(--card-bg);border-radius:10px;overflow:hidden}
.legal-wrap table th,.legal-wrap table td{padding:.7rem 1rem;text-align:left;border-bottom:1px solid var(--border);font-size:.92rem}
.legal-wrap table th{background:rgba(34,197,94,.08);color:#fff;font-weight:700}
.legal-wrap a{color:var(--primary)}
.legal-wrap a:hover{text-decoration:underline}

/* spacing for pages with fixed nav */
.page-pad{padding-top:8rem;padding-bottom:5rem}
