/*
Theme Name: Tradelo
Theme URI: https://tradelo.eu
Description: Thème professionnel comparatif courtiers trading
Version: 1.0.0
Author: Tradelo
Text Domain: tradelo
*/

/* === VARIABLES === */
:root{
  --primary:#0f2044;--primary2:#1a3a6c;--cta:#e8750a;--cta2:#cf5e00;
  --green:#16a34a;--red:#dc2626;--yellow:#f59e0b;
  --bg:#f1f5f9;--card:#fff;--text:#1e293b;--muted:#64748b;
  --border:#e2e8f0;--r:8px;--rl:14px;
  --sh:0 1px 4px rgba(0,0,0,.07),0 2px 10px rgba(0,0,0,.05);
  --shm:0 4px 20px rgba(0,0,0,.10);
  --font:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;
  --mw:1180px;
}

/* === RESET === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:17px}
body{font-family:var(--font);color:var(--text);background:var(--bg);line-height:1.72}
img{max-width:100%;height:auto;display:block}
a{color:var(--primary2);text-decoration:none}
a:hover{color:var(--cta)}
ul,ol{padding-left:1.5rem}

/* === TYPO === */
h1,h2,h3,h4{font-weight:700;line-height:1.28;color:var(--text)}
h1{font-size:clamp(1.7rem,4.5vw,2.3rem)}
h2{font-size:clamp(1.2rem,3vw,1.55rem);margin:2.2rem 0 .9rem}
h3{font-size:1.1rem;margin:1.5rem 0 .6rem}
p{margin-bottom:1.15rem}

/* === LAYOUT === */
.container{max-width:var(--mw);margin:0 auto;padding:0 1.5rem}

/* === HEADER === */
#site-header{
  background:var(--primary);position:sticky;top:0;z-index:200;
  box-shadow:0 2px 14px rgba(0,0,0,.25)
}
.hdr{
  display:flex;align-items:center;justify-content:space-between;
  height:62px;max-width:var(--mw);margin:0 auto;padding:0 1.5rem
}
.logo{font-size:1.45rem;font-weight:900;color:#fff;letter-spacing:-.5px}
.logo em{color:var(--cta);font-style:normal}
.nav-list{
  display:flex;align-items:center;gap:.2rem;
  list-style:none;padding:0;margin:0
}
.nav-list a{
  color:rgba(255,255,255,.82);font-size:.875rem;font-weight:500;
  padding:.45rem .8rem;border-radius:var(--r);transition:all .18s
}
.nav-list a:hover{color:#fff;background:rgba(255,255,255,.1)}
.nav-cta{
  background:var(--cta)!important;color:#fff!important;
  padding:.42rem 1.1rem!important;border-radius:50px!important;
  font-weight:700!important
}
.nav-cta:hover{background:var(--cta2)!important}
.burger{
  display:none;background:none;border:none;cursor:pointer;padding:.4rem
}
.burger span{display:block;width:22px;height:2px;background:#fff;margin:5px 0;border-radius:2px;transition:.3s}

/* === HERO === */
.hero{
  background:linear-gradient(135deg,var(--primary) 0%,var(--primary2) 55%,#1e4fa3 100%);
  color:#fff;padding:5rem 1.5rem 0;text-align:center;position:relative;overflow:hidden
}
.hero::before{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg width='52' height='52' viewBox='0 0 52 52' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23fff' fill-opacity='0.03'%3E%3Ccircle cx='26' cy='26' r='4'/%3E%3C/g%3E%3C/svg%3E")
}
.hero-inner{position:relative;max-width:720px;margin:0 auto;padding-bottom:3rem}
.hero h1{color:#fff;margin-bottom:.9rem;line-height:1.18;font-size:clamp(1.9rem,5vw,2.75rem)}
.hero p{font-size:1.07rem;color:rgba(255,255,255,.78);margin-bottom:2rem;max-width:560px;margin-left:auto;margin-right:auto}
.hero-btns{display:flex;gap:.9rem;justify-content:center;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;gap:.45rem;
  padding:.78rem 1.75rem;border-radius:50px;font-weight:700;
  font-size:.92rem;transition:all .18s;cursor:pointer;border:none;text-decoration:none
}
.btn-cta{background:var(--cta);color:#fff;box-shadow:0 4px 18px rgba(232,117,10,.35)}
.btn-cta:hover{background:var(--cta2);color:#fff;transform:translateY(-1px);box-shadow:0 6px 22px rgba(232,117,10,.45)}
.btn-ghost{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.45)}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.08);color:#fff}

/* === TRUST BAR === */
.trust-bar{
  background:rgba(0,0,0,.18);border-top:1px solid rgba(255,255,255,.1);
  padding:.85rem 1.5rem;margin-top:0
}
.trust-inner{
  display:flex;justify-content:center;gap:2.5rem;flex-wrap:wrap;
  max-width:var(--mw);margin:0 auto
}
.trust-item{color:rgba(255,255,255,.7);font-size:.82rem;display:flex;align-items:center;gap:.45rem}
.trust-item strong{color:#fff}

/* === ARTICLE GRID === */
.section-posts{padding:3.5rem 0}
.sec-title{
  font-size:1.3rem;margin-bottom:1.75rem;display:flex;align-items:center;gap:.8rem
}
.sec-title::after{content:'';flex:1;height:2px;background:var(--border)}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:1.5rem}
.card{
  background:var(--card);border-radius:var(--rl);overflow:hidden;
  box-shadow:var(--sh);transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column
}
.card:hover{transform:translateY(-3px);box-shadow:var(--shm)}
.card-thumb{
  height:172px;background:linear-gradient(135deg,var(--primary) 0%,#2a5298 100%);
  display:flex;align-items:center;justify-content:center;font-size:2.8rem;
  color:rgba(255,255,255,.25);position:relative;overflow:hidden
}
.card-thumb img{width:100%;height:100%;object-fit:cover}
.cat-tag{
  position:absolute;top:.7rem;left:.7rem;background:var(--cta);color:#fff;
  font-size:.69rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;
  padding:.28rem .65rem;border-radius:4px
}
.card-body{padding:1.35rem;flex:1;display:flex;flex-direction:column}
.card-body h2{font-size:1rem;margin:0 0 .55rem;line-height:1.4}
.card-body h2 a{color:var(--text)}
.card-body h2 a:hover{color:var(--primary2)}
.card-excerpt{
  color:var(--muted);font-size:.875rem;line-height:1.62;margin-bottom:.9rem;flex:1;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden
}
.card-meta{
  display:flex;align-items:center;gap:1rem;font-size:.77rem;color:var(--muted);
  border-top:1px solid var(--border);padding-top:.7rem
}

/* === ARTICLE PAGE === */
.post-wrap{
  display:grid;grid-template-columns:1fr 290px;gap:2.5rem;
  max-width:var(--mw);margin:0 auto;padding:2.5rem 1.5rem;align-items:start
}
.post-main{min-width:0}
.breadcrumb{
  display:flex;align-items:center;gap:.5rem;font-size:.79rem;
  color:var(--muted);margin-bottom:1.4rem;flex-wrap:wrap
}
.breadcrumb a{color:var(--primary2)}
.post-header{
  background:var(--card);border-radius:var(--rl);padding:1.85rem;
  margin-bottom:1.4rem;box-shadow:var(--sh)
}
.post-header h1{margin-bottom:.85rem}
.post-meta{
  display:flex;align-items:center;gap:1.1rem;
  font-size:.8rem;color:var(--muted);flex-wrap:wrap
}
.post-body{background:var(--card);border-radius:var(--rl);padding:2rem;box-shadow:var(--sh)}

/* Content elements */
.post-body h2{border-left:4px solid var(--cta);padding-left:.8rem;margin-top:2.5rem}
.post-body h3{color:var(--primary2)}
.post-body a{color:var(--primary2);text-decoration:underline}
.post-body a:hover{color:var(--cta)}
.post-body li{margin-bottom:.35rem}

/* Mention légale */
.post-body .mention-legale{
  background:#fef9ec;border:1px solid #f59e0b;border-left:4px solid #f59e0b;
  border-radius:var(--r);padding:.9rem 1.1rem;font-size:.85rem;color:#78350f;margin:1.5rem 0
}
/* CTA affilié */
.post-body .cta-affilie{
  background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1px solid #86efac;
  border-radius:var(--rl);padding:1.4rem;text-align:center;margin:2rem 0
}
.post-body .cta-affilie .btn-cta{
  display:inline-block;background:var(--green);color:#fff;
  padding:.8rem 1.9rem;border-radius:50px;font-weight:700;font-size:.97rem;
  text-decoration:none;transition:all .18s;box-shadow:0 4px 14px rgba(22,163,74,.28)
}
.post-body .cta-affilie .btn-cta:hover{background:#15803d;color:#fff;transform:translateY(-1px)}
.post-body .cta-affilie small{display:block;color:#6b7280;font-size:.75rem;margin-top:.45rem}

/* Tables */
.post-body table{
  width:100%;border-collapse:collapse;margin:1.4rem 0;
  font-size:.875rem;border-radius:var(--r);overflow:hidden;box-shadow:var(--sh)
}
.post-body thead{background:var(--primary);color:#fff}
.post-body thead th{padding:.8rem 1rem;text-align:left;font-weight:600}
.post-body tbody tr:nth-child(even){background:#f8fafc}
.post-body tbody tr:hover{background:#f0f9ff}
.post-body tbody td{padding:.7rem 1rem;border-bottom:1px solid var(--border)}

/* FAQ */
.post-body [itemtype*="FAQPage"] h2{margin-top:2rem}
.post-body [itemtype*="Question"]{
  border:1px solid var(--border);border-radius:var(--r);
  margin-bottom:.65rem;overflow:hidden
}
.post-body [itemtype*="Question"] h3{
  background:#f8fafc;padding:.9rem 1.1rem;margin:0;font-size:.93rem
}
.post-body [itemtype*="Answer"] p{
  padding:.9rem 1.1rem;margin:0;font-size:.875rem;color:var(--muted)
}

/* TOC */
.toc-box{
  background:#f8fafc;border:1px solid var(--border);border-radius:var(--r);
  padding:1.1rem 1.25rem;margin:1.5rem 0
}
.toc-box h3{
  font-size:.8rem;text-transform:uppercase;letter-spacing:.5px;
  color:var(--muted);margin-bottom:.65rem
}
.toc-box ol{padding-left:1.1rem;margin:0}
.toc-box li{font-size:.84rem;margin-bottom:.28rem}
.toc-box a{color:var(--primary2);text-decoration:none}
.toc-box a:hover{color:var(--cta);text-decoration:underline}

/* Author */
.author-box{
  background:var(--card);border-radius:var(--rl);padding:1.4rem;
  box-shadow:var(--sh);margin-top:1.75rem;display:flex;gap:1.1rem;align-items:flex-start
}
.author-av{
  width:54px;height:54px;border-radius:50%;background:var(--primary2);
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;font-weight:700;flex-shrink:0
}
.author-info h4{margin-bottom:.2rem;font-size:.97rem}
.author-info p{font-size:.82rem;color:var(--muted);margin:0}

/* === SIDEBAR === */
.post-sidebar{position:sticky;top:76px;display:flex;flex-direction:column;gap:1.2rem}
.sb-card{background:var(--card);border-radius:var(--rl);padding:1.2rem;box-shadow:var(--sh)}
.sb-card h3{font-size:.88rem;margin-bottom:.9rem;padding-bottom:.45rem;border-bottom:2px solid var(--border)}
.pick-badge{
  background:var(--cta);color:#fff;font-size:.68rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.5px;padding:.22rem .65rem;
  border-radius:4px;display:inline-block;margin-bottom:.7rem
}
.pick-name{font-size:1.08rem;font-weight:700;color:var(--text);margin-bottom:.2rem}
.pick-desc{font-size:.8rem;color:var(--muted);margin-bottom:.9rem}
.pick-cta{
  display:block;background:var(--cta);color:#fff;padding:.7rem .9rem;
  border-radius:50px;font-weight:700;font-size:.84rem;margin-bottom:.4rem;
  text-align:center;transition:background .18s;text-decoration:none
}
.pick-cta:hover{background:var(--cta2);color:#fff}
.pick-disc{font-size:.68rem;color:var(--muted)}

/* === FOOTER === */
#site-footer{background:var(--primary);color:rgba(255,255,255,.72);margin-top:5rem}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr;gap:3rem;
  padding:4rem 1.5rem 2.5rem;max-width:var(--mw);margin:0 auto
}
.f-brand .logo{font-size:1.35rem;font-weight:900;color:#fff;margin-bottom:.65rem}
.f-brand .logo em{color:var(--cta);font-style:normal}
.f-brand p{font-size:.82rem;line-height:1.75}
.f-col h4{
  color:#fff;font-size:.82rem;text-transform:uppercase;
  letter-spacing:.5px;margin-bottom:.9rem
}
.f-col ul{list-style:none;padding:0}
.f-col li{margin-bottom:.45rem}
.f-col a{color:rgba(255,255,255,.62);font-size:.82rem;transition:color .18s}
.f-col a:hover{color:#fff}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.1);
  padding:1.4rem 1.5rem;max-width:var(--mw);margin:0 auto
}
.f-disc{
  background:rgba(255,255,255,.05);border-radius:var(--r);
  padding:.9rem 1.1rem;margin-bottom:.9rem;
  font-size:.75rem;color:rgba(255,255,255,.48);line-height:1.75
}
.footer-bottom>p{font-size:.75rem;color:rgba(255,255,255,.4)}

/* === RESPONSIVE === */
@media(max-width:920px){
  .post-wrap{grid-template-columns:1fr}
  .post-sidebar{position:static}
  .footer-grid{grid-template-columns:1fr 1fr}
  .f-brand{grid-column:1/-1}
}
@media(max-width:640px){
  .nav-list{
    display:none;flex-direction:column;position:absolute;
    top:62px;left:0;right:0;background:var(--primary);
    padding:1rem;gap:0
  }
  .nav-list.open{display:flex}
  .burger{display:block}
  .hero{padding:2.75rem 1.5rem 0}
  .post-wrap{padding:1.5rem 1rem}
  .post-body,.post-header{padding:1.1rem}
  .footer-grid{grid-template-columns:1fr;gap:1.75rem}
  .trust-inner{gap:1rem}
  .grid{grid-template-columns:1fr}
  .hero-btns{flex-direction:column;align-items:center}
}
