/* =================================================================
   RSSUS.com — Thème clair / professionnel (fintech)
   Palette : bleu #2563eb, vert #10b981, blanc & gris doux.
   ================================================================= */
:root{
  --bg:#f8fafc;
  --bg-card:#ffffff;
  --bg-soft:#eff6ff;
  --primary:#2563eb;
  --primary-dark:#1d4ed8;
  --primary-soft:#dbeafe;
  --accent:#10b981;
  --accent-dark:#059669;
  --text:#0f172a;
  --text-mid:#475569;
  --text-mute:#94a3b8;
  --line:#e2e8f0;
  --line-strong:#cbd5e1;
  --bad:#dc2626;
  --good:#16a34a;
  --shadow-sm:0 1px 2px rgba(15,23,42,.06);
  --shadow-md:0 4px 16px rgba(15,23,42,.08);
  --shadow-lg:0 12px 32px rgba(37,99,235,.12);
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;font-family:-apple-system,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;}
body{background:var(--bg);color:var(--text);line-height:1.55;-webkit-font-smoothing:antialiased;}
a{color:var(--primary);text-decoration:none;}
a:hover{color:var(--primary-dark);}
img{max-width:100%;}
h1,h2,h3,h4{color:var(--text);}

/* ---------- Top bar (clair, contraste fort) ---------- */
.topbar{
  display:flex;align-items:center;gap:18px;flex-wrap:wrap;
  padding:14px 28px;
  background:#ffffff;
  border-bottom:1px solid var(--line);
  box-shadow:var(--shadow-sm);
  position:sticky;top:0;z-index:50;
}
.logo-link{display:inline-flex;align-items:center;flex-shrink:0;text-decoration:none;}
.logo-link img{height:44px;width:auto;display:block;}
.logo-text{font-weight:800;font-size:22px;color:var(--text);letter-spacing:.5px;display:flex;align-items:center;gap:8px;}
.logo-text span{color:var(--primary);}
.logo-text span{color:var(--primary);}
.topbar nav{display:flex;gap:6px;flex-wrap:wrap;flex:1;justify-content:center;padding-left:180px;background:transparent;margin-bottom:0;padding-top:0;padding-bottom:0;}
.topbar nav.nav-public{padding-left:260px;}
.topbar nav a{
  color:var(--text-mid);font-weight:500;font-size:14px;
  padding:8px 14px;border-radius:8px;
  transition:all .2s;
  display:inline-flex;align-items:center;gap:6px;
}
.topbar nav a:hover{background:var(--bg-soft);color:var(--primary);}
.topbar nav a.active{background:var(--primary-soft);color:var(--primary-dark);font-weight:600;}
.topbar nav a.admin-link{
  color:var(--accent-dark);font-weight:600;
  background:#ecfdf5;border:1px solid #a7f3d0;
}
.topbar nav a.admin-link:hover{background:#d1fae5;}
.badge-count{
  background:var(--bad);color:#fff;border-radius:999px;
  padding:2px 8px;font-size:11px;font-weight:700;margin-left:4px;
}
.lang-switch{display:flex;gap:4px;align-items:center;font-size:13px;}
.lang-switch a{padding:5px 10px;border-radius:6px;color:var(--text-mute);font-weight:600;}
.lang-switch a.active{background:var(--primary);color:#fff;}

/* ---------- Buttons ---------- */
.btn-primary{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  background:var(--primary);color:#fff;font-weight:600;
  padding:11px 22px;border:none;border-radius:8px;cursor:pointer;
  transition:all .2s;font-size:15px;text-decoration:none;
  box-shadow:var(--shadow-sm);
}
.btn-primary:hover{background:var(--primary-dark);color:#fff;transform:translateY(-1px);box-shadow:var(--shadow-md);}
.btn-ghost{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  border:1.5px solid var(--primary);color:var(--primary);background:#fff;
  padding:9px 20px;border-radius:8px;font-weight:600;text-decoration:none;
  transition:all .2s;cursor:pointer;font-size:14px;
}
.btn-ghost:hover{background:var(--primary);color:#fff;}
.btn-accent{
  background:var(--accent);color:#fff;
}
.btn-accent:hover{background:var(--accent-dark);color:#fff;}

/* ---------- Landing : Hero ---------- */
.hero{
  background:linear-gradient(135deg, #eff6ff 0%, #ffffff 50%, #ecfdf5 100%);
  padding:60px 32px 70px;text-align:center;position:relative;overflow:hidden;
}
.hero::before{
  content:'';position:absolute;top:-100px;right:-100px;
  width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle, rgba(37,99,235,.12), transparent 70%);
}
.hero::after{
  content:'';position:absolute;bottom:-100px;left:-100px;
  width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle, rgba(16,185,129,.10), transparent 70%);
}
.hero h1{
  font-size:50px;line-height:1.1;max-width:920px;margin:0 auto 24px;
  font-weight:800;letter-spacing:-.5px;position:relative;z-index:1;
}
.hero h1 .gold,.hero h1 .accent{color:var(--primary);}
.hero p.subtitle{
  font-size:19px;color:var(--text-mid);max-width:700px;margin:0 auto 38px;
  line-height:1.65;position:relative;z-index:1;
}
.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;position:relative;z-index:1;}
.hero-cta .btn-primary{padding:14px 28px;font-size:16px;}
.hero-pills{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:28px;position:relative;z-index:1;}
.hero-pills span{background:#f0f4ff;border:1px solid #c7d7fe;color:var(--primary);
  padding:6px 14px;border-radius:999px;font-size:13px;font-weight:500;}

/* Deux sections alt consécutives : réduire l'espace entre elles */
.section.alt + .section.alt{padding-top:24px;}

/* ---------- Sections ---------- */
.section{padding:56px 32px;}
.section.alt{background:var(--bg-card);}
.section h2{font-size:34px;text-align:center;margin:0 0 14px;font-weight:700;letter-spacing:-.3px;}
.section .lead{text-align:center;color:var(--text-mid);max-width:640px;margin:0 auto 36px;font-size:17px;}

/* ---------- Features grid ---------- */
.features-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));
  gap:28px;max-width:1140px;margin:0 auto;
}
.feature-card{
  background:var(--bg-card);border:1px solid var(--line);
  border-radius:14px;padding:32px 22px;text-align:center;
  transition:all .25s;
}
.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary-soft);}
.feature-icon{
  font-size:36px;margin-bottom:16px;display:inline-flex;
  width:64px;height:64px;border-radius:14px;
  background:var(--primary-soft);color:var(--primary);
  align-items:center;justify-content:center;
}
.feature-card h3{color:var(--text);font-size:19px;margin:0 0 10px;font-weight:700;}
.feature-card p{color:var(--text-mid);margin:0;font-size:15px;}

/* ---------- Tagline strip (vert/bleu accent) ---------- */
.tagline-strip{
  background:linear-gradient(90deg,var(--primary),var(--accent));
  color:#fff;padding:22px 32px;font-weight:600;
  display:flex;gap:30px;justify-content:center;flex-wrap:wrap;text-align:center;
}
.tagline-strip span{font-size:17px;letter-spacing:.3px;}

/* ---------- Method strip (conservé pour compatibilité) ---------- */
.method-strip{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:26px;max-width:1100px;margin:0 auto;
}
.method-item{text-align:center;}
.method-item .ico{
  font-size:32px;display:inline-flex;width:64px;height:64px;border-radius:50%;
  background:var(--bg-soft);color:var(--primary);
  align-items:center;justify-content:center;margin-bottom:12px;
}
.method-item h4{margin:8px 0 4px;font-weight:700;font-size:18px;}
.method-item p{color:var(--text-mid);margin:0;}

/* ---------- Steps (Comment ça marche) ---------- */
.steps-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:28px;max-width:1200px;margin:40px auto 0;
}
@media(min-width:1000px){.steps-grid-4{grid-template-columns:repeat(4,1fr);}}
.step-card{
  background:#fff;border:1px solid var(--line);border-radius:14px;
  padding:28px 20px 22px;text-align:center;position:relative;
  transition:transform .2s,box-shadow .2s;
}
.step-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);}
.step-num{
  position:absolute;top:-16px;left:50%;transform:translateX(-50%);
  background:var(--primary);color:#fff;width:32px;height:32px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:14px;font-weight:800;
}
.step-num-pro{background:linear-gradient(135deg,var(--primary),var(--accent));font-size:11px;width:38px;height:38px;top:-19px;}
.step-icon{font-size:36px;margin:8px 0 12px;}
.step-card h3{margin:0 0 10px;font-size:16px;color:var(--text);font-weight:700;}
.step-card p{color:var(--text-mid);font-size:13px;margin:0;line-height:1.6;}
.steps-cta-hint{text-align:center;margin-top:28px;font-size:14px;color:var(--text-mid);}

/* ---------- Stats sociales ---------- */
.stats-bar-social{
  background:var(--bg-card);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:32px 24px;
  display:-webkit-flex;display:flex;
  -webkit-align-items:center;align-items:center;
  -webkit-justify-content:center;justify-content:center;
}
.stats-bar-social .stat-item{
  flex:1;max-width:280px;text-align:center;padding:0 28px;
  display:flex;flex-direction:column;align-items:center;gap:4px;
}
.stats-bar-social .stat-sep{
  width:1px;height:56px;background:var(--line);flex-shrink:0;
}
.stats-bar-social .stat-num{
  font-size:38px;font-weight:800;color:var(--primary);line-height:1;
  font-variant-numeric:tabular-nums;
}
.stats-bar-social .stat-plus{
  font-size:24px;font-weight:700;color:var(--accent);
  margin-left:2px;align-self:flex-start;margin-top:4px;
}
.stats-bar-social .stat-num-wrap{display:flex;align-items:flex-start;justify-content:center;}
.stats-bar-social .stat-label{
  font-size:13px;color:var(--text-mid);font-weight:500;
}
.stats-bar-social .stat-prefix{
  font-size:24px;font-weight:700;color:var(--text-mid);align-self:flex-start;margin-top:6px;
}
.stats-bar-social .stat-suffix{
  font-size:24px;font-weight:700;color:var(--primary);align-self:flex-start;margin-top:6px;
}
@media(max-width:700px){
  .stats-bar-social{flex-wrap:wrap;gap:24px;padding:24px 16px;}
  .stats-bar-social .stat-sep{display:none;}
  .stats-bar-social .stat-item{flex:0 0 calc(50% - 12px);max-width:none;padding:0;}
  .stats-bar-social .stat-num{font-size:30px;}
}

/* ---------- Trust bar ---------- */
.trust-bar{
  background:var(--bg-card);border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:16px 32px;
  display:-webkit-flex;display:flex;
  -webkit-justify-content:center;justify-content:center;
  -webkit-flex-wrap:wrap;flex-wrap:wrap;
}
.trust-bar span{margin:0 16px;}
.trust-bar span{font-size:13px;color:var(--text-mid);font-weight:500;}

/* ---------- Auth pages ---------- */
.auth-page{
  background:linear-gradient(135deg, #eff6ff 0%, #ffffff 60%, #ecfdf5 100%);
  min-height:100vh;
}
.auth-card{
  max-width:480px;margin:60px auto;padding:42px;
  background:var(--bg-card);border:1px solid var(--line);border-radius:14px;
  box-shadow:var(--shadow-md);
}
.auth-card h1{margin:0 0 22px;font-size:24px;text-align:center;font-weight:700;}
.auth-card form label{display:block;margin:14px 0;font-size:14px;color:var(--text-mid);font-weight:500;}
.auth-card form input,
.auth-card form select,
.auth-card form textarea{
  width:100%;padding:11px 14px;margin-top:6px;
  background:#fff;border:1.5px solid var(--line-strong);
  border-radius:8px;color:var(--text);font-size:15px;
  transition:border-color .15s;
}
.auth-card form input:focus,
.auth-card form select:focus,
.auth-card form textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft);}
.auth-card .captcha-row{display:flex;align-items:center;gap:10px;color:var(--text);}
.auth-card .captcha-row input{flex:0 0 auto;width:90px !important;margin:0;}
.auth-card button.btn-primary{width:100%;margin-top:18px;padding:13px;font-size:15px;}
.auth-card .alt{margin-top:24px;text-align:center;color:var(--text-mid);font-size:14px;}
.auth-card .error{background:#fef2f2;border:1px solid #fecaca;color:var(--bad);padding:11px;border-radius:8px;margin:8px 0;font-size:14px;}
.auth-card .success{background:#f0fdf4;border:1px solid #bbf7d0;color:var(--good);padding:14px;border-radius:8px;font-size:15px;}

/* ---------- Footer ---------- */
.site-footer{
  text-align:center;color:var(--text-mute);
  padding:28px;border-top:1px solid var(--line);
  font-size:13px;background:#fff;
}

/* ---------- Mobile ---------- */
@media (max-width:700px){
  .hero h1{font-size:32px;}
  .hero{padding:60px 16px 70px;}
  .topbar{padding:10px 14px;gap:6px;flex-wrap:wrap;}
  .topbar nav{padding-left:0 !important;justify-content:center;width:100%;}
  .topbar nav a{font-size:12px;padding:5px 8px;}
  .section{padding:44px 16px;}
  .auth-card{margin:30px 16px;padding:28px;}
  .trust-bar{gap:16px;padding:14px 16px;}
  .hero-pills span{font-size:12px;padding:5px 10px;}
}
/* ---------- Mockup Assistant IA ---------- */
.mock-ai{
  padding:8px;width:100%;height:100%;
  background:linear-gradient(135deg,#eff6ff 0%,#fff 100%);
  display:flex;flex-direction:column;gap:6px;overflow:hidden;
}
.mock-ai .ai-msg{display:flex;gap:6px;align-items:flex-start;}
.mock-ai .ai-avatar{
  flex:0 0 22px;width:22px;height:22px;border-radius:50%;
  background:var(--primary-soft);display:flex;align-items:center;
  justify-content:center;font-size:12px;
}
.mock-ai .ai-bubble{
  background:#fff;border:1px solid var(--line);
  border-radius:8px;padding:5px 8px;font-size:9px;line-height:1.3;
  color:var(--text-mid);flex:1;
}
.mock-ai .ai-bubble strong{color:var(--primary);font-size:9px;}
.mock-ai .ai-bubble p{margin:2px 0 0;font-size:9px;color:var(--text);}

/* ---------- Pricing cards ---------- */
.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:22px;max-width:1100px;margin:30px auto 0;align-items:stretch;}
.pricing-grid.pricing-grid-3{max-width:1100px;}
@media(min-width:1000px){.pricing-grid.pricing-grid-3{grid-template-columns:repeat(3,1fr);}}

.pricing-card{background:#fff;border:2px solid var(--line);border-radius:14px;
  padding:32px 26px 24px;text-align:center;position:relative;
  transition:all .25s;display:flex;flex-direction:column;}
.pricing-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);}
.pricing-card.featured{border-color:var(--primary);box-shadow:var(--shadow-md);}
.pricing-card h3{margin:0 0 14px;font-size:22px;color:var(--text);}
.pricing-card .price{font-size:30px;font-weight:800;color:var(--primary);margin:8px 0 18px;}
.pricing-card .plan-desc{color:var(--text-mid);font-size:14px;margin:0 0 22px;flex:1;text-align:left;line-height:1.7;}

/* Bouton CTA aligné en bas (juste avant la zone early-bird) */
.pricing-card .plan-cta{width:100%;padding:13px;margin-top:auto;}

/* Zone réservée pour la mention "Early Bird" — toujours présente
   pour aligner les hauteurs (vide via .early-bird-spacer dans les autres cartes) */
.pricing-card .early-bird,
.pricing-card .early-bird-spacer{margin:14px 0 0;font-size:12px;font-weight:600;
  text-align:center;min-height:18px;line-height:18px;}
.pricing-card .early-bird{color:var(--accent-dark);}
.pricing-card .early-bird-spacer{visibility:hidden;}

.badge-popular{position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:var(--accent);color:#fff;padding:5px 14px;border-radius:999px;
  font-size:12px;font-weight:700;letter-spacing:.5px;}

/* ---------- Contact form ---------- */
#contact-msg-area{max-width:880px;margin:0 auto 16px;}
#contact-msg-area .ok{background:#f0fdf4;border:1px solid #16a34a;color:#16a34a;
  padding:18px 20px;border-radius:10px;text-align:center;font-weight:600;font-size:15px;
  box-shadow:var(--shadow-sm);}
#contact-form-container{max-width:880px;margin:0 auto;}
.contact-form{background:#fff;border:1px solid var(--line);border-radius:12px;padding:36px;}
.contact-form .row-2{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
@media(max-width:600px){.contact-form .row-2{grid-template-columns:1fr;}}
.contact-form label{display:block;margin:12px 0;color:var(--text-mid);font-weight:500;font-size:14px;}
.contact-form input,.contact-form textarea{width:100%;padding:11px 14px;margin-top:6px;
  border:1.5px solid var(--line-strong);border-radius:8px;font-size:15px;background:#fff;}
.contact-form textarea{resize:vertical;min-height:140px;}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--primary);
  box-shadow:0 0 0 3px var(--primary-soft);}
.contact-form .captcha-row{display:flex;align-items:center;gap:10px;margin-top:14px;}
.contact-form .captcha-row input{flex:0 0 90px;margin:0;}
.contact-form button{width:100%;margin-top:18px;padding:13px;}
.contact-form .ok{background:#f0fdf4;border:1px solid #16a34a;color:#16a34a;padding:14px;border-radius:6px;}
.contact-form .err{background:#fef2f2;border:1px solid #dc2626;color:#dc2626;padding:11px;border-radius:6px;}

/* ---------- Brokers grid (landing) ---------- */
.brokers-grid{
  display:-webkit-flex;display:flex;-webkit-flex-wrap:wrap;flex-wrap:wrap;
  justify-content:center;max-width:100%;margin:0 auto;
  padding-bottom:4px;
  /* gap fallback via margin sur les enfants */
}
.brokers-grid .broker-badge{margin:7px;}
.broker-badge{
  display:-webkit-flex;display:flex;-webkit-align-items:center;align-items:center;
  -webkit-justify-content:center;justify-content:center;flex-shrink:0;
  padding:10px 14px;border-radius:14px;
  border:1.5px solid var(--line);background:#fff;
  transition:all .2s;
}
.broker-badge:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);}
.broker-badge .b-icon{
  width:44px;height:44px;border-radius:9px;flex-shrink:0;
  display:-webkit-flex;display:flex;-webkit-align-items:center;align-items:center;
  -webkit-justify-content:center;justify-content:center;
  font-weight:800;font-size:12px;color:#fff;
}
.broker-badge .b-logo{
  background:#fff;width:110px;height:56px;border-radius:8px;padding:8px;
  overflow:hidden;flex-shrink:0;
}
.broker-badge .b-logo img{
  width:100%;height:100%;max-width:110px;max-height:56px;
  object-fit:contain;display:block;
}
.broker-badge span{font-weight:600;font-size:14px;color:var(--text);white-space:nowrap;}

/* ---------- Broker import bar (dashboard) ---------- */
.broker-import-card{
  background:#fff;border:1px solid var(--line);
  border-radius:12px;padding:18px 22px;margin:24px 24px 0;
  text-align:center;
}
.broker-import-card h3{margin:0 0 4px;font-size:15px;}
.broker-import-card .broker-sub{margin:0 0 14px;font-size:13px;color:var(--text-mid);}
.broker-btns{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;}
.broker-btn{
  display:flex;align-items:center;justify-content:center;
  padding:10px 14px;border-radius:10px;
  border:1.5px solid var(--line);background:#fff;
  cursor:pointer;transition:all .2s;
}
.broker-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--primary);}
.broker-btn .b-icon{
  width:auto;
  height:auto;
  display:flex;
  align-items:center;
  justify-content:center;
}
.broker-btn .b-logo{
  width:110px;
  height:48px;
  border-radius:8px;
  padding:4px;
  background:#fff;
  overflow:hidden;
}
.broker-btn .b-logo img{
  width:100%;
  height:100%;
  object-fit:contain;
  display:block;
}
.broker-btn .b-logo img{width:100%;height:100%;object-fit:contain;display:block;}
.broker-toast{
  display:none;margin-top:12px;padding:10px 14px;
  border-radius:8px;font-size:13px;font-weight:500;
}
.broker-toast.ok{background:#f0fdf4;color:var(--good);border:1px solid #bbf7d0;}
.broker-toast.err{background:#fef2f2;color:var(--bad);border:1px solid #fecaca;}
.csv-security-note{margin:12px 0 0;font-size:12px;color:var(--text-mid);text-align:center;}

/* Fix logos SVG avec trop d'espace blanc */
.broker-btn img[src*="scotia"]{
  transform:scale(2.2);
}

.broker-btn img[src*="cibc"]{
  transform:scale(2.0);
}

.broker-btn img[src*="national"]{
  transform:scale(2.0);
}

/* ---------- Broker how-to guide (dashboard) ---------- */
.broker-guide-card{
  background:#fff;border:1px solid var(--line);
  border-radius:12px;margin:10px 24px 0;overflow:hidden;
}
.broker-guide-header{
  position:relative;display:flex;justify-content:center;align-items:center;
  padding:13px 22px;cursor:pointer;font-weight:600;
  font-size:14px;color:var(--text);transition:background .15s;text-align:center;
}
.broker-guide-header #guide-arrow{position:absolute;right:22px;}
.broker-guide-header:hover{background:var(--bg-soft);}
.broker-guide-body{display:none;border-top:1px solid var(--line);}
.guide-tabs{
  display:flex;flex-wrap:wrap;gap:6px;
  background:#f8fafc;padding:10px 16px;
  border-bottom:1px solid var(--line);
}
.guide-tab{
  padding:5px 13px;border-radius:6px;border:1.5px solid var(--line);
  background:#fff;cursor:pointer;font-size:12px;font-weight:600;
  color:var(--text-mid);transition:all .15s;
}
.guide-tab.active{background:var(--primary);color:#fff;border-color:var(--primary);}
.guide-tab:hover:not(.active){background:var(--bg-soft);color:var(--primary);}
.guide-panels{padding:18px 24px;}
.guide-panel{display:none;}
.guide-panel.active{display:block;}
.guide-note{
  background:var(--bg-soft);border-left:3px solid var(--primary);
  padding:10px 14px;border-radius:0 8px 8px 0;
  font-size:13px;color:var(--text-mid);margin:0 0 14px;
}
.guide-steps{padding-left:20px;margin:0 0 14px;}
.guide-steps li{font-size:14px;color:var(--text);padding:4px 0;line-height:1.5;}
.guide-steps li strong{color:var(--primary);}
.guide-types{
  font-size:13px;color:var(--text-mid);
  background:#f0fdf4;border:1px solid #bbf7d0;
  padding:10px 14px;border-radius:8px;margin:0;
}
.guide-types strong{color:var(--good);}

@media(max-width:700px){
  .broker-badge{padding:10px 14px;}
  .broker-badge .b-icon{width:34px;height:34px;}
}