/* =============================================
   testvpn.fr — Styles communs
   Fichier unique : modifier ici = toutes les pages
   ============================================= */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:#060912;
  --surface:#0d1525;
  --surface2:#131e33;
  --border:#1e2d4a;
  --accent:#00d4ff;
  --green:#00e599;
  --yellow:#ffd166;
  --red:#ff6b6b;
  --text:#e8edf5;
  --muted:#6b7a99;
  --fh:'Syne',system-ui,sans-serif;
  --fb:'DM Sans',system-ui,sans-serif;
  --radius:14px;
}

body{
  font-family:var(--fb);
  background:var(--bg);
  color:var(--text);
  line-height:1.5;
}
body::before{
  content:'';position:fixed;inset:0;
  background:
    radial-gradient(ellipse 80% 50% at 20% -10%,rgba(0,212,255,.07) 0%,transparent 60%),
    radial-gradient(ellipse 60% 40% at 80% 110%,rgba(123,94,167,.08) 0%,transparent 60%);
  pointer-events:none;z-index:0;
}

/* ── SKIP TO CONTENT (accessibilité) ── */
.skip-link{
  position:absolute;top:-100%;left:16px;
  background:var(--accent);color:#000;
  padding:8px 16px;border-radius:8px;
  font-weight:700;font-size:13px;z-index:200;
  text-decoration:none;
}
.skip-link:focus{top:8px}

/* ── NAV ── */
nav{
  position:sticky;top:0;z-index:100;
  background:rgba(6,9,18,.85);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
  padding:12px 20px;
  display:flex;align-items:center;justify-content:space-between;
}
.nav-logo{
  font-family:var(--fh);font-size:1rem;font-weight:800;
  color:var(--text);text-decoration:none;
}
.nav-logo span{color:var(--accent)}
.nav-cta{
  background:linear-gradient(135deg,var(--accent),#0099cc);
  color:#000;font-family:var(--fh);
  font-size:11px;font-weight:700;
  padding:7px 14px;border-radius:8px;
  text-decoration:none;white-space:nowrap;
}
.nav-back{color:var(--muted);font-size:13px;text-decoration:none}
.nav-back:hover{color:var(--accent)}
.nav-links{display:flex;align-items:center;gap:16px}

.wrap{position:relative;z-index:1;max-width:1080px;margin:0 auto;padding:0 16px}
.wrap--narrow{max-width:760px;padding:40px 20px 80px}
.wrap--form{max-width:600px;padding:40px 20px 80px}

/* ── HEADER (index) ── */
header{text-align:center;padding:40px 0 28px}
.badge{
  display:inline-block;
  background:rgba(0,212,255,.1);border:1px solid rgba(0,212,255,.3);
  color:var(--accent);font-size:11px;font-weight:600;
  letter-spacing:2px;text-transform:uppercase;
  padding:5px 14px;border-radius:100px;margin-bottom:16px;
}
h1{font-family:var(--fh);font-size:clamp(1.8rem,6vw,3.4rem);font-weight:800;line-height:1.15;margin-bottom:14px}
h1 span{background:linear-gradient(90deg,var(--accent),#7b5ea7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
h1 .h1-year{font-family:var(--fb);font-weight:700;background:none;-webkit-background-clip:unset;-webkit-text-fill-color:var(--text);background-clip:unset}
.cur{font-size:.72em;margin-left:1px}
.subtitle{color:var(--muted);font-size:clamp(.9rem,2.5vw,1rem);max-width:520px;margin:0 auto 28px}

/* ── FILTRES ── */
.filters{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-bottom:36px}
.filter-btn{
  background:var(--surface);border:1px solid var(--border);
  color:var(--muted);font-family:var(--fb);
  font-size:13px;font-weight:500;
  padding:7px 16px;border-radius:100px;
  cursor:pointer;transition:all .2s;white-space:nowrap;
}
.filter-btn:hover,.filter-btn.active{background:rgba(0,212,255,.1);border-color:var(--accent);color:var(--accent)}

/* ── CARDS ── */
.cards{display:flex;flex-direction:column;gap:14px;margin-bottom:64px}

.card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:20px;
  position:relative;
  overflow:hidden;
  transition:border-color .3s,transform .2s;
  animation:fadeUp .4s ease both;
}
.card:hover{border-color:rgba(0,212,255,.3);transform:translateY(-2px)}
.card.top-pick{border-color:rgba(0,212,255,.45);background:linear-gradient(160deg,#0d1525,#0f1d33)}

/* Rang */
.card-rank{
  position:absolute;top:0;left:0;
  background:var(--border);color:var(--muted);
  font-family:var(--fb);font-size:10px;font-weight:700;
  padding:4px 10px;
  border-radius:var(--radius) 0 8px 0;
}
.card.top-pick .card-rank{background:linear-gradient(90deg,var(--accent),#0099cc);color:#000}

/* Logo + note */
.card-head{display:flex;align-items:center;gap:14px;margin-bottom:16px;padding-top:4px}
.logo-box{
  height:46px;width:140px;padding:4px 8px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;overflow:hidden;
}
.logo-box img{height:38px;width:120px;object-fit:contain}
.logo-pia img{filter:brightness(2.5)}
.card-rating{display:flex;flex-direction:column;gap:4px}
.stars{display:flex;gap:2px}
.star{color:var(--yellow);font-size:13px}
.star.empty{color:var(--border)}
.rating-text{font-size:12px;color:var(--muted)}
.best-for{font-size:10px;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.5px}

/* Specs */
.card-specs{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:10px 16px;margin-bottom:12px;
  padding:12px 14px;background:rgba(0,0,0,.25);border-radius:10px;
}
@media(min-width:480px){
  .card-specs{grid-template-columns:repeat(4,1fr);gap:8px}
}
.spec{display:flex;flex-direction:column;gap:3px}
.spec-label{font-size:9px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-weight:600}
.spec-value{font-family:'DM Sans',system-ui,sans-serif;font-size:.9rem;font-weight:700}
.spec-value.good{color:var(--green)}
.spec-value.ok{color:var(--yellow)}

/* Features */
.features{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:16px}
.feat{font-size:11px;padding:3px 9px;border-radius:100px;border:1px solid var(--border);color:var(--muted)}
.feat.green{border-color:rgba(0,229,153,.3);color:var(--green);background:rgba(0,229,153,.05)}

/* CTA */
.card-cta{
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;
  background:rgba(0,0,0,.2);
  border-radius:10px;padding:12px 14px;
}
.price-block{display:flex;flex-direction:column;gap:2px}
.price-from{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}
.price-amount{font-family:var(--fb);font-size:1.6rem;font-weight:700;line-height:1.2;letter-spacing:-.5px}
.price-period{font-size:10px;color:var(--muted)}
.price-save{font-size:11px;color:var(--green);font-weight:600}
.cta-right{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0}
.btn-cta{
  display:block;text-align:center;text-decoration:none;
  font-family:var(--fh);font-size:12px;font-weight:700;
  padding:11px 18px;border-radius:8px;
  transition:all .2s;white-space:nowrap;
}
.btn-primary{background:linear-gradient(135deg,var(--accent),#0099cc);color:#000}
.btn-primary:hover{opacity:.9;transform:scale(1.02)}
.btn-secondary{background:var(--surface2);border:1px solid var(--border);color:var(--text)}
.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}
.btn-review{background:transparent;border:1px solid var(--accent);color:var(--accent);font-size:11px !important}
.btn-review:hover{background:rgba(0,212,255,.1)}
.affiliate-note{font-size:10px;color:var(--muted)}

/* ── DESKTOP CARDS (min 760px) ── */
@media(min-width:760px){
  .wrap{padding:0 28px}
  .card{
    padding:24px 28px;
    display:grid;
    grid-template-columns:180px 1fr 190px;
    grid-template-rows:auto auto auto;
    column-gap:28px;row-gap:12px;
    align-items:start;
  }
  .card-head{
    grid-column:1;grid-row:1/4;
    flex-direction:column;align-items:flex-start;
    justify-content:center;align-self:center;
    margin-bottom:0;padding-top:8px;
  }
  .card-specs{grid-column:2;grid-row:1;margin-bottom:0;grid-template-columns:repeat(4,1fr)}
  .features{grid-column:2;grid-row:2;margin-bottom:0}
  .card-cta{
    grid-column:3;grid-row:1/4;
    flex-direction:column;align-items:center;align-self:center;
    padding:16px;gap:10px;
  }
  .price-block{align-items:center}
  .price-from,.price-period,.price-save{text-align:center}
  .price-amount{font-size:1.9rem;text-align:center}
  .cta-right{align-items:center;width:100%}
  .btn-cta{width:100%}
  .affiliate-note{text-align:center}
}
@media(min-width:760px) and (max-width:920px){
  .card{grid-template-columns:160px 1fr 170px}
  .card-specs{grid-template-columns:repeat(2,1fr)}
}

/* ── SCORE BAR ── */
.score-bar{display:flex;align-items:center;gap:8px;margin-top:4px}
.score-track{flex:1;height:4px;background:var(--border);border-radius:2px;overflow:hidden}
.score-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,var(--accent),var(--green))}
.score-num{font-family:'DM Sans',system-ui,sans-serif;font-size:12px;font-weight:700;color:var(--accent);white-space:nowrap}

/* ── SECTION TITLES ── */
.section-title{font-family:var(--fh);font-size:clamp(1.2rem,4vw,1.5rem);font-weight:800;text-align:center;margin-bottom:20px}

/* ── TABLE ── */
.table-wrap{overflow-x:auto;margin-bottom:64px;border-radius:var(--radius);border:1px solid var(--border);-webkit-overflow-scrolling:touch}
table{width:100%;border-collapse:collapse;min-width:540px}
thead{background:var(--surface2)}
th{font-family:var(--fh);font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--muted);padding:14px 16px;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap}
td{padding:13px 16px;font-size:13px;border-bottom:1px solid rgba(30,45,74,.5);white-space:nowrap}
tr:last-child td{border-bottom:none}
tr:hover td{background:rgba(13,21,37,.5)}
.vpn-name{font-family:var(--fh);font-weight:700;font-size:.85rem}
.check{color:var(--green)}
.cross{color:var(--red)}
.partial{color:var(--yellow);font-size:12px}

/* ── FAQ ── */
.faq-wrap{max-width:720px;margin:0 auto 64px;display:flex;flex-direction:column;gap:10px}
details{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:18px 20px;cursor:pointer}
details summary{font-family:var(--fh);font-weight:700;font-size:.95rem;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px}
details summary::-webkit-details-marker{display:none}
.faq-icon{color:var(--accent);font-size:1.1rem;flex-shrink:0;transition:transform .2s}
details[open] .faq-icon{transform:rotate(45deg)}
.faq-answer{margin-top:12px;color:var(--muted);line-height:1.7;font-size:.9rem}
.faq-answer strong{color:var(--text)}

/* ── FOOTER ── */
footer{border-top:1px solid var(--border);padding:32px 0;text-align:center}
.footer-links{display:flex;justify-content:center;gap:24px;margin-bottom:20px;flex-wrap:wrap}
.footer-links a{color:var(--muted);font-size:13px;text-decoration:none}
.footer-links a:hover{color:var(--accent)}
.disclaimer{font-size:11px;color:var(--muted);max-width:680px;margin:0 auto;line-height:1.7}

/* ── PAGES SECONDAIRES (à propos, contact, mentions) ── */
.page-title{font-family:var(--fh);font-size:2rem;font-weight:800;margin-bottom:20px}
.page-title span{background:linear-gradient(90deg,var(--accent),#7b5ea7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.page-subtitle{color:var(--muted);margin-bottom:40px;font-size:.95rem}
.page-h2{font-family:var(--fh);font-size:1.1rem;font-weight:700;color:var(--accent);margin:32px 0 12px}
.page-p{color:var(--muted);margin-bottom:14px;font-size:.95rem}
.page-p strong{color:var(--text)}
.page-p a{color:var(--accent);text-decoration:none}
.page-p a:hover{text-decoration:underline}

/* Valeurs (à propos) */
.values{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin:24px 0}
.value-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px}
.value-icon{font-size:1.5rem;margin-bottom:8px}
.value-title{font-family:var(--fh);font-weight:700;font-size:.95rem;margin-bottom:6px;color:var(--text)}
.value-desc{font-size:.85rem;color:var(--muted)}
.affiliation-box{background:rgba(0,212,255,.05);border:1px solid rgba(0,212,255,.2);border-radius:12px;padding:20px 24px;margin:24px 0}

/* Formulaire (contact) */
label{display:block;font-size:13px;font-weight:500;color:var(--muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}
input,textarea,select{
  width:100%;background:var(--surface);
  border:1px solid var(--border);border-radius:10px;
  padding:12px 16px;color:var(--text);
  font-family:var(--fb);font-size:.95rem;
  outline:none;transition:border-color .2s;margin-bottom:20px;
}
input:focus,textarea:focus,select:focus{border-color:var(--accent)}
textarea{min-height:140px;resize:vertical}
.btn-submit{
  width:100%;background:linear-gradient(135deg,var(--accent),#0099cc);
  color:#000;font-family:var(--fh);
  font-size:14px;font-weight:700;
  padding:14px;border-radius:10px;border:none;
  cursor:pointer;transition:opacity .2s;
}
.btn-submit:hover{opacity:.9}
.contact-alt{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px 24px;margin-top:32px;text-align:center}
.contact-alt p{color:var(--muted);font-size:.9rem;margin-bottom:6px}
.contact-alt a{color:var(--accent);font-weight:600;text-decoration:none}

/* Mentions légales */
.mentions-h2{font-family:var(--fh);font-size:1.1rem;font-weight:700;color:var(--accent);margin:32px 0 12px;padding-bottom:8px;border-bottom:1px solid var(--border)}
.box{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px 24px;margin-bottom:14px}

/* ── COOKIE BANNER ── */
.cookie-banner{
  position:fixed;bottom:0;left:0;right:0;z-index:999;
  background:var(--surface);
  border-top:1px solid var(--border);
  padding:16px 20px;
  display:flex;align-items:center;justify-content:center;
  gap:16px;flex-wrap:wrap;
  animation:slideUp .3s ease;
}
.cookie-banner p{font-size:13px;color:var(--muted);margin:0;max-width:600px}
.cookie-banner a{color:var(--accent);text-decoration:underline}
.cookie-btn{
  font-family:var(--fh);font-size:12px;font-weight:700;
  padding:9px 18px;border-radius:8px;border:none;
  cursor:pointer;transition:opacity .2s;white-space:nowrap;
}
.cookie-accept{background:linear-gradient(135deg,var(--accent),#0099cc);color:#000}
.cookie-refuse{background:var(--surface2);border:1px solid var(--border);color:var(--muted)}
.cookie-refuse:hover{border-color:var(--accent);color:var(--accent)}

/* ── ANIMATIONS ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.card:nth-child(1){animation-delay:.05s}
.card:nth-child(2){animation-delay:.1s}
.card:nth-child(3){animation-delay:.15s}
.card:nth-child(4){animation-delay:.2s}
.card:nth-child(5){animation-delay:.25s}
.card:nth-child(6){animation-delay:.3s}

/* ── ARTICLES (avis, blog, comparatif) ── */
.wrap--article{max-width:780px;padding:40px 20px 80px}
.article-meta{font-size:12px;color:var(--muted);margin-bottom:32px}
.article-meta time{color:var(--accent)}
.article-h2{font-family:var(--fh);font-size:1.25rem;font-weight:700;color:var(--text);margin:36px 0 14px;padding-bottom:8px;border-bottom:1px solid var(--border)}
.article-h3{font-family:var(--fh);font-size:1.05rem;font-weight:700;color:var(--accent);margin:24px 0 10px}
.article-p{color:var(--muted);margin-bottom:16px;font-size:.95rem;line-height:1.8}
.article-p strong{color:var(--text)}
.article-p a{color:var(--accent);text-decoration:none}
.article-p a:hover{text-decoration:underline}
.article-ul{color:var(--muted);margin:0 0 16px 20px;font-size:.95rem;line-height:2}

/* Verdict box */
.verdict-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;margin-bottom:32px}
.verdict-score{display:flex;align-items:center;gap:16px;margin-bottom:16px}
.verdict-num{font-family:var(--fb);font-size:2.4rem;font-weight:700;color:var(--accent);line-height:1}
.verdict-label{font-size:.85rem;color:var(--muted)}
.verdict-label strong{color:var(--text);font-size:1rem}
.verdict-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
@media(max-width:500px){.verdict-grid{grid-template-columns:1fr}}
.verdict-pros,.verdict-cons{font-size:.9rem;line-height:1.9}
.verdict-pros{color:var(--green)}
.verdict-cons{color:var(--red)}
.verdict-pros span,.verdict-cons span{display:block}

/* Info box */
.info-box{background:rgba(0,212,255,.05);border:1px solid rgba(0,212,255,.2);border-radius:12px;padding:18px 22px;margin:20px 0}
.info-box p{color:var(--muted);font-size:.9rem;margin:0}
.info-box strong{color:var(--text)}

/* Article CTA */
.article-cta{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;background:var(--surface);border:1px solid rgba(0,212,255,.3);border-radius:var(--radius);padding:20px 24px;margin:28px 0}
.article-cta .price-tag{font-family:var(--fb);font-size:1.4rem;font-weight:700;color:var(--text)}
.article-cta .price-tag .cur{font-size:.72em}
.article-cta .price-detail{font-size:.8rem;color:var(--muted)}

/* TOC */
.toc{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px 24px;margin-bottom:32px}
.toc-title{font-family:var(--fh);font-size:.95rem;font-weight:700;margin-bottom:10px;color:var(--text)}
.toc a{display:block;font-size:.9rem;color:var(--muted);text-decoration:none;padding:4px 0}
.toc a:hover{color:var(--accent)}

/* Article table */
.article-table{width:100%;border-collapse:collapse;margin:16px 0 24px;font-size:.9rem}
.article-table th{text-align:left;padding:10px 14px;background:var(--surface2);color:var(--muted);font-family:var(--fh);font-size:.8rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border)}
.article-table td{padding:10px 14px;border-bottom:1px solid rgba(30,45,74,.4);color:var(--muted)}
.article-table td strong{color:var(--text)}
