
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#000000;
  --surface:#0d0d0d;
  --surface2:#1a1a1a;
  --border:rgba(255,255,255,0.08);
  --border2:rgba(255,255,255,0.15);
  --text:#ffffff;
  --muted:#5a5a5a;
  --muted2:#9a9a9a;
  --accent:#e60026;
  --accent-dim:rgba(230,0,38,0.08);
  --accent-glow:rgba(230,0,38,0.15);
  --radius:14px;
  --font-display:'Syne',sans-serif;
  --font-mono:'DM Mono',monospace;
}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--font-display);min-height:100vh;overflow-x:hidden}

.resource-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 15px; }
.res-item {
    padding: 15px;
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    text-decoration: none;
    transition: 0.3s;
}

/* debut pop up */
.modal-overlay {
    display: none; /* Masqué par défaut */
    position: fixed;
    top: 0; left: 0;
    width: 100%; height: 100%;
    background: rgba(0,0,0,0.85);
    z-index: 1000;
    justify-content: center;
    align-items: center;
}

.modal-container {
    background: white;
    width: 90%;
    max-width: 600px;
    display: flex;
    border-radius: 20px;
    position: relative;
    overflow: visible; /* CRUCIAL pour que la tête dépasse */
}

.modal-left {
    background: #FF0000;
    flex: 1;
    border-top-left-radius: 20px;
    border-bottom-left-radius: 20px;
    
    /* ÉTAPE CRUCIAL : On coupe tout ce qui dépasse de ce bloc */
    overflow: hidden; 
    
    display: flex;
    align-items: flex-end; /* Pour que tu sois bien posé en bas */
    justify-content: center;
}

.profile-img {
    /* ÉTAPE CRUCIAL : L'image doit s'adapter à la largeur du bloc rouge */
    width: 100%; 
    height: 100%;
    
    /* "object-fit: cover" permet de remplir le cadre sans déformer ton visage */
    object-fit: cover; 
    
    display: block;
}

.modal-right {
    flex: 1.5;
    padding: 40px 30px;
    text-align: center;
    color: #1a1a1a;
}

.modal-right h1 { font-size: 40px; margin-bottom: 10px; font-weight: 900; }
.modal-right p { font-size: 16px; line-height: 1.5; color: #555; }

.social-links { margin-top: 30px; }
.social-links span { font-size: 12px; font-weight: bold; color: #999; letter-spacing: 1px; }

.icons { margin-top: 15px; display: flex; justify-content: center; gap: 20px; }
.icons a { font-size: 20px; color: #333; transition: 0.3s; }
.icons a:hover { color: #FF0000; }

.close-x {
    position: absolute;
    top: 15px; right: 20px;
    background: none; border: none;
    font-size: 30px; cursor: pointer;
    color: #ccc;
}







/* fin pop up */
.res-item:hover { border-color: var(--accent); transform: translateY(-3px); }
.res-item strong { display: block; color: var(--text); font-size: 14px; }
.res-item span { color: var(--muted2); font-size: 11px; }

iframe{
    border:none;
    border-radius:var(--radius);
    box-shadow:0 4px 12px rgba(0,0,0,0.5);
    transition:transform .15s;
    background-color: var(--bg);
}
a{
    color:inherit;
    text-decoration:none;
    cursor:pointer;
}
/* NAV */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 2rem;height:60px;
  background:rgba(0,0,0,0.9);
  backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
}
.nav-logo{
    font-size:16px;
    font-weight:800;
    letter-spacing:-.03em;
    cursor:pointer;
    color:var(--text)
}

.nav-logo span{
    color:var(--accent)
}
.nav-links{
    display:flex;
    gap:2rem;
    align-items:center
}
.nav-links a{
    font-size:13px;
    color:var(--muted2);
    text-decoration:none;
    cursor:pointer;
    transition:color .15s;
    font-weight:600
}

.nav-links a:hover,.nav-links a.active{
    color:var(--accent);
}
.nav-cta{
  background:var(--accent);color:#fff;
  border:none;border-radius:8px;
  padding:8px 18px;font-size:13px;font-weight:700;
  cursor:pointer;font-family:var(--font-display);
  transition:opacity .15s,transform .15s;
  letter-spacing:.01em;
}
.nav-cta:hover{
    opacity:.88;
    transform:translateY(-1px);
}

/* PAGE SYSTEM */
.page{
    display:none;
    padding-top:60px;
    min-height:100vh
}

.page.active{
    display:block
}

/* ═══════════════════════════════ LANDING ═══════════════════════════════ */
.hero{
  position:relative;
  padding:8rem 2rem 5rem;
  text-align:center;
  overflow:hidden;
}

/* Subtle scanline texture */
.hero::before{
  content:'';
  position:absolute;inset:0;
  background-image:repeating-linear-gradient(
    0deg,
    transparent,
    transparent 2px,
    rgba(255,255,255,0.015) 2px,
    rgba(255,255,255,0.015) 4px
  );
  pointer-events:none;
}

.hero-glow{
  position:absolute;top:-60px;left:50%;transform:translateX(-50%);
  width:700px;height:500px;
  background:radial-gradient(ellipse at 50% 0%,rgba(230,0,38,0.18) 0%,transparent 65%);
  pointer-events:none;
}
.hero-line{
  position:absolute;bottom:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--accent),transparent);
  opacity:.4;
}

.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  border:1px solid rgba(230,0,38,0.3);
  border-radius:4px;padding:5px 14px;
  font-size:11px;color:var(--accent);font-family:var(--font-mono);
  margin-bottom:2.5rem;letter-spacing:.08em;text-transform:uppercase;
  animation:fadeDown .6s ease both;
}
.hero-badge::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--accent);animation:blink 1.4s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
@keyframes fadeDown{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:none}}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}

.hero h1{
  font-size:clamp(3rem,8vw,5.5rem);font-weight:800;
  line-height:1.02;letter-spacing:-.05em;
  margin-bottom:1.5rem;
  animation:fadeUp .7s .1s ease both;
}
.hero h1 em{font-style:normal;color:var(--accent)}
.hero h1 .underline-red{
  position:relative;display:inline-block;
}
.hero h1 .underline-red::after{
  content:'';position:absolute;bottom:-4px;left:0;right:0;height:3px;
  background:var(--accent);border-radius:2px;
}

.hero-sub{
  font-size:1.05rem;color:var(--muted2);
  max-width:460px;margin:0 auto 2.5rem;line-height:1.65;
  animation:fadeUp .7s .2s ease both;font-weight:400;
}
.hero-actions{
  display:flex;gap:12px;justify-content:center;flex-wrap:wrap;
  animation:fadeUp .7s .3s ease both;
}
.btn-primary{
  background:var(--accent);color:#fff;
  border:none;border-radius:6px;
  padding:13px 28px;font-size:14px;font-weight:700;
  cursor:pointer;font-family:var(--font-display);
  transition:transform .15s,opacity .15s;letter-spacing:.02em;
}
.btn-primary:hover{transform:translateY(-2px);opacity:.9}
.btn-ghost{
  background:none;border:1px solid var(--border2);border-radius:6px;
  padding:13px 28px;font-size:14px;color:var(--text);
  cursor:pointer;font-family:var(--font-display);font-weight:600;
  transition:border-color .15s,background .15s;
}
.btn-ghost:hover{border-color:rgba(255,255,255,.3);background:rgba(255,255,255,.04)}

/* DEMO MOCK */
.demo-preview{
  margin:4rem auto 0;max-width:680px;padding:0 2rem;
  animation:fadeUp .8s .4s ease both;
}
.demo-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-top:2px solid var(--accent);
  border-radius:12px;overflow:hidden;
}
.demo-card-header{
  padding:10px 16px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:8px;
}
.dot-r{width:10px;height:10px;border-radius:50%;background:#ff5f57}
.dot-y{width:10px;height:10px;border-radius:50%;background:#ffbd2e}
.dot-g{width:10px;height:10px;border-radius:50%;background:#28c840}
.demo-inner{padding:1.5rem}
.demo-img-row{display:flex;gap:20px;align-items:center;flex-wrap:wrap}
.demo-img-placeholder{
  width:120px;height:85px;border-radius:8px;flex-shrink:0;
  background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460,#533483);
}
.demo-colors{flex:1;display:flex;flex-direction:column;gap:8px;min-width:200px}
.demo-color-row{display:flex;align-items:center;gap:10px}
.demo-swatch{width:28px;height:28px;border-radius:5px;border:1px solid rgba(255,255,255,0.08);flex-shrink:0}
.demo-hex{font-family:var(--font-mono);font-size:12px;color:var(--text);flex:1}
.demo-tag{font-family:var(--font-mono);font-size:10px;color:var(--muted2);background:var(--surface2);border-radius:3px;padding:2px 7px;border:1px solid var(--border)}
.demo-css{
  margin-top:1rem;padding:14px;background:var(--surface2);
  border-radius:8px;border-left:2px solid var(--accent);
  font-family:var(--font-mono);font-size:11px;line-height:1.9;
}
.demo-css .kw{color:#e60026}
.demo-css .prop{color:#ff6b6b}
.demo-css .val{color:#a8d8a8}

/* FEATURES */
.features{padding:6rem 2rem;max-width:960px;margin:0 auto}
.section-label{
  font-size:11px;font-family:var(--font-mono);color:var(--accent);
  letter-spacing:.15em;text-transform:uppercase;margin-bottom:1rem;
  display:flex;align-items:center;gap:8px;
}
.section-label::before{content:'';width:20px;height:1px;background:var(--accent)}
.section-title{font-size:2.4rem;font-weight:800;letter-spacing:-.04em;margin-bottom:3rem;line-height:1.1}
.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1px;border:1px solid var(--border);border-radius:12px;overflow:hidden}
.feature-card{
  background:var(--surface);padding:1.75rem;
  transition:background .2s;
}
.feature-card:hover{background:var(--surface2)}
.feature-num{
  font-family:var(--font-mono);font-size:11px;color:var(--accent);
  margin-bottom:1rem;letter-spacing:.06em;
}
.feature-title{font-size:15px;font-weight:700;margin-bottom:8px}
.feature-desc{font-size:13px;color:var(--muted2);line-height:1.65}

/* HOW */
.how{padding:2rem 2rem 6rem;max-width:760px;margin:0 auto}
.steps{border:1px solid var(--border);border-radius:12px;overflow:hidden}
.step{
  display:flex;gap:20px;padding:1.75rem;
  border-bottom:1px solid var(--border);
  transition:background .2s;
}
.step:last-child{border-bottom:none}
.step:hover{background:var(--surface)}
.step-num{
  font-size:11px;font-family:var(--font-mono);color:var(--accent);
  width:28px;flex-shrink:0;padding-top:3px;letter-spacing:.04em;
}
.step-title{font-size:15px;font-weight:700;margin-bottom:5px}
.step-desc{font-size:13px;color:var(--muted2);line-height:1.6}

/* BANNER */
.cta-banner{
  margin:0 2rem 5rem;
  background:var(--accent);border-radius:12px;
  padding:3rem 2rem;text-align:center;
  position:relative;overflow:hidden;
}
.cta-banner::before{
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(-45deg,transparent,transparent 20px,rgba(0,0,0,0.06) 20px,rgba(0,0,0,0.06) 40px);
}
.cta-banner h3{font-size:1.8rem;font-weight:800;color:#fff;margin-bottom:.5rem;position:relative;letter-spacing:-.03em}
.cta-banner p{font-size:14px;color:rgba(255,255,255,.8);margin-bottom:1.5rem;position:relative}
.btn-white{
  background:#fff;color:var(--accent);border:none;border-radius:6px;
  padding:12px 28px;font-size:14px;font-weight:800;
  cursor:pointer;font-family:var(--font-display);
  transition:transform .15s,opacity .15s;position:relative;
}
.btn-white:hover{transform:translateY(-2px)}

/* ═══════════════════════════════ TOOL ═══════════════════════════════ */
.tool-wrap{max-width:820px;margin:0 auto;padding:3rem 2rem}
.tool-header{margin-bottom:2.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}
.tool-header h2{font-size:1.8rem;font-weight:800;letter-spacing:-.04em;margin-bottom:6px}
.tool-header h2 span{color:var(--accent)}
.tool-header p{font-size:13px;color:var(--muted2)}

.drop-zone{
  border:1px solid var(--border);border-radius:12px;
  background:var(--surface);padding:4rem 2rem;
  text-align:center;cursor:pointer;position:relative;overflow:hidden;
  transition:border-color .2s,background .2s;
}
.drop-zone:hover,.drop-zone.drag{
  border-color:var(--accent);
  background:rgba(230,0,38,0.04);
}
.drop-zone::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 50% at 50% 50%,rgba(230,0,38,0.04),transparent);
  opacity:0;transition:opacity .3s;
}
.drop-zone:hover::before{opacity:1}
.drop-zone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.dz-icon{
  width:52px;height:52px;border-radius:10px;
  border:1px solid var(--border2);background:var(--surface2);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 1.2rem;
}
.dz-icon svg{width:24px;height:24px;stroke:var(--muted2)}
.dz-title{font-size:16px;font-weight:700;margin-bottom:6px}
.dz-sub{font-size:13px;color:var(--muted);font-family:var(--font-mono)}
.dz-hint{font-size:11px;color:var(--muted);margin-top:8px;font-family:var(--font-mono)}

.result-area{display:none;margin-top:2rem}
.result-area.visible{display:block}
.result-top{display:flex;gap:24px;align-items:flex-start;flex-wrap:wrap;margin-bottom:1.5rem}
.result-img{
  width:160px;height:110px;object-fit:cover;
  border-radius:10px;border:1px solid var(--border);flex-shrink:0;
}

.count-bar{display:flex;gap:6px;margin-bottom:1.2rem;flex-wrap:wrap}
.count-btn{
  background:none;border:1px solid var(--border);border-radius:5px;
  padding:5px 12px;font-size:12px;color:var(--muted2);
  cursor:pointer;font-family:var(--font-mono);transition:all .15s;
}
.count-btn.active{border-color:var(--accent);color:var(--accent);background:rgba(230,0,38,0.08)}
.count-btn:hover:not(.active){border-color:var(--border2);color:var(--text)}
.pro-tag{font-size:9px;background:rgba(230,0,38,0.12);color:var(--accent);border-radius:3px;padding:1px 5px;margin-left:4px;vertical-align:middle;font-family:var(--font-display)}

.palette-list{flex:1;min-width:220px}
.pal-row{
  display:flex;align-items:center;gap:10px;
  padding:9px 0;border-bottom:1px solid var(--border);
  animation:rowIn .3s ease both;
}
@keyframes rowIn{from{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:none}}
.pal-row:last-child{border-bottom:none}
.pal-swatch{
  width:36px;height:36px;border-radius:7px;
  border:1px solid rgba(255,255,255,0.08);
  cursor:pointer;transition:transform .15s,box-shadow .15s;flex-shrink:0;
}
.pal-swatch:hover{transform:scale(1.12);box-shadow:0 0 0 2px var(--accent)}
.pal-info{flex:1}
.pal-hex{font-family:var(--font-mono);font-size:13px;font-weight:500}
.pal-rgb{font-family:var(--font-mono);font-size:11px;color:var(--muted);margin-top:2px}
.copy-btn{
  background:none;border:1px solid var(--border);border-radius:5px;
  padding:4px 9px;font-size:11px;color:var(--muted);
  cursor:pointer;font-family:var(--font-mono);transition:all .15s;white-space:nowrap;
}
.copy-btn:hover,.copy-btn.ok{border-color:var(--accent);color:var(--accent)}

.css-panel{
  background:var(--surface);border:1px solid var(--border);
  border-left:2px solid var(--accent);
  border-radius:10px;overflow:hidden;margin-top:1.5rem;
  display:none;
}
.css-panel.visible{display:block}
.css-panel-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 16px;border-bottom:1px solid var(--border);
}
.css-label-tag{font-size:12px;color:var(--muted2);font-family:var(--font-mono)}
.css-copy-btn{
  background:var(--accent);color:#fff;border:none;border-radius:5px;
  padding:5px 14px;font-size:12px;font-weight:700;
  cursor:pointer;font-family:var(--font-display);transition:opacity .15s;
}
.css-copy-btn:hover{opacity:.85}
.css-code{padding:16px;font-family:var(--font-mono);font-size:12px;line-height:1.9;white-space:pre;overflow-x:auto}
.css-code .kw{color:#e60026}
.css-code .prop{color:#ff7070}
.css-code .val{color:#a8d8a8}

.tool-actions{margin-top:1.5rem;display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.reset-btn{
  background:none;border:1px solid var(--border);border-radius:6px;
  padding:8px 18px;font-size:13px;color:var(--muted2);
  cursor:pointer;font-family:var(--font-display);font-weight:600;transition:all .15s;
}
.reset-btn:hover{border-color:var(--border2);color:var(--text)}

/* ═══════════════════════════════ PRICING ═══════════════════════════════ */
.pricing-wrap{max-width:720px;margin:0 auto;padding:4rem 2rem}
.pricing-header{text-align:center;margin-bottom:3.5rem}
.pricing-header h2{font-size:2.6rem;font-weight:800;letter-spacing:-.05em;margin-bottom:.75rem;line-height:1.05}
.pricing-header h2 em{font-style:normal;color:var(--accent)}
.pricing-header p{font-size:15px;color:var(--muted2)}
.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}

.plan{
  background:var(--surface);border:1px solid var(--border);
  border-radius:12px;padding:2rem;
}
.plan.pro{
  border-color:var(--accent);
  background:linear-gradient(160deg,rgba(230,0,38,0.06) 0%,var(--surface) 60%);
}
.plan-badge{
  display:inline-block;
  background:var(--accent);color:#fff;
  border-radius:3px;font-size:10px;font-weight:800;
  padding:3px 10px;margin-bottom:1.2rem;letter-spacing:.06em;
  font-family:var(--font-display);text-transform:uppercase;
}
.plan-name{font-size:14px;font-weight:700;color:var(--muted2);margin-bottom:.5rem;font-family:var(--font-mono);letter-spacing:.04em}
.plan-price{font-size:3.2rem;font-weight:800;letter-spacing:-.06em;line-height:1;margin-bottom:.3rem;color:var(--text)}
.plan-price span{font-size:14px;font-weight:400;color:var(--muted)}
.plan-desc{font-size:13px;color:var(--muted2);margin-bottom:1.5rem;line-height:1.55;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}
.plan-features{list-style:none;margin-bottom:2rem}
.plan-features li{
  font-size:13px;padding:7px 0;
  border-bottom:1px solid rgba(255,255,255,0.04);
  display:flex;align-items:center;gap:10px;color:var(--muted2);
}
.plan-features li:last-child{border-bottom:none}
.check{width:16px;height:16px;flex-shrink:0;border-radius:50%;display:flex;align-items:center;justify-content:center}
.check.yes{background:rgba(230,0,38,0.12);border:1px solid rgba(230,0,38,0.3)}
.check.yes::after{content:'✓';font-size:9px;color:var(--accent);font-weight:700}
.check.no{background:var(--surface2);border:1px solid var(--border)}
.plan-features li.yes-item{color:var(--text)}
.plan-features li.no-item{opacity:.4;text-decoration:line-through}

.plan-btn{
  width:100%;padding:13px;border-radius:7px;font-size:14px;font-weight:700;
  cursor:pointer;font-family:var(--font-display);transition:all .15s;letter-spacing:.02em;
}
.plan-btn.free{background:none;border:1px solid var(--border2);color:var(--text)}
.plan-btn.free:hover{border-color:rgba(255,255,255,.3);background:rgba(255,255,255,.03)}
.plan-btn.paid{background:var(--accent);border:none;color:#fff}
.plan-btn.paid:hover{opacity:.9;transform:translateY(-2px)}

.faq{max-width:620px;margin:4rem auto 0;padding:0 2rem}
.faq-title{font-size:1.4rem;font-weight:800;margin-bottom:1.5rem;letter-spacing:-.03em}
.faq-item{border-bottom:1px solid var(--border);padding:1.25rem 0}
.faq-q{font-size:14px;font-weight:700;margin-bottom:.5rem}
.faq-a{font-size:13px;color:var(--muted2);line-height:1.7}

/* FOOTER */
footer{
  border-top:1px solid var(--border);
  padding:2rem;text-align:center;
  font-size:12px;color:var(--muted);font-family:var(--font-mono);
  margin-top:4rem;
}
footer a{color:var(--muted2);text-decoration:none;cursor:pointer}
footer a:hover{color:var(--text)}
.footer-logo{font-size:14px;font-weight:800;font-family:var(--font-display);margin-bottom:.5rem}
.footer-logo span{color:var(--accent)}

/* TOAST */
.toast-global{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%);
  background:var(--accent);color:#fff;
  font-size:12px;font-weight:700;padding:8px 20px;border-radius:4px;
  opacity:0;transition:opacity .2s;pointer-events:none;z-index:999;
  font-family:var(--font-display);letter-spacing:.02em;
}
.toast-global.show{opacity:1}

/* SCROLLBAR */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}

/* responive */

/* ═══ RESPONSIVE DESIGN ═══ */

/* --- Tablettes et écrans moyens (max 1024px) --- */
@media (max-width: 1024px) {
  .hero h1 { font-size: 4.5rem; } /* Réduction du titre */
  
  .features-grid {
    grid-template-columns: repeat(2, 1fr); /* Passage à 2 colonnes */
  }
}

/* --- Mobiles (max 768px) --- */
@media (max-width: 768px) {
  /* Navigation */
  nav {
    padding: 0 1rem;
    height: 60px;
  }
  .nav-links { display: none; } /* On cache les liens simples pour mobile */
  .nav-cta { padding: 8px 15px; font-size: 12px; }

  /* Hero Section */
  .hero { padding: 100px 1.5rem 40px; }
  .hero h1 { font-size: 3rem; line-height: 1.1; }
  .hero-sub { font-size: 16px; }
  .hero-actions { flex-direction: column; width: 100%; }
  .hero-actions button { width: 100%; }

  /* Grilles et Sections */
  .features-grid {
    grid-template-columns: 1fr; /* Tout en une seule colonne */
  }
  
  .pricing-grid {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }
  
  .steps {
    flex-direction: column; /* Les étapes se superposent */
    gap: 2rem;
  }

  /* L'outil (Tool Area) */
  .result-top {
    flex-direction: column; /* L'image au-dessus de la palette */
  }
  .result-img {
    max-width: 100%;
    height: auto;
  }
  .palette-list { padding-left: 0; margin-top: 1.5rem; }
  
  .count-bar {
    flex-wrap: wrap;
    justify-content: center;
  }

  /* Divers */
  .cta-banner h3 { font-size: 1.8rem; }
}

/* temoins */
/* ==========================================
   CSS SECTION TÉMOIGNAGES (MARQUEE)
   ========================================== */

#testimonials {
  background-color: var(--bg); /* Fond sombre profond, idéal pour le contraste */
  padding: 60px 0;
  border-top: 1px solid rgba(255, 255, 255, 0.05);
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  width: 100%;
  overflow: hidden; /* Empêche l'apparition d'une barre de défilement horizontale */
}

.testimonials-container {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
}

.testimonials-title {
  text-align: center;
  font-family: sans-serif;
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--text);
  margin-top: 0;
  margin-bottom: 40px;
}

.marquee-wrapper {
  position: relative;
  width: 100%;
  overflow: hidden;
  display: flex;
}

/* Effets de fondu (Fade) sur les bords droit et gauche */
.marquee-wrapper::before,
.marquee-wrapper::after {
  content: "";
  position: absolute;
  top: 0;
  width: 100px;
  height: 100%;
  z-index: 2;
  pointer-events: none;
}

.marquee-wrapper::before {
  left: 0;
  background: linear-gradient(to right, #0d1117, transparent);
}

.marquee-wrapper::after {
  right: 0;
  background: linear-gradient(to left, #0d1117, transparent);
}

/* Le conteneur qui défile */
.marquee-content {
  display: flex;
  align-items: center;
  gap: 80px; /* Espace régulier entre chaque logo */
  list-style: none;
  padding: 0;
  margin: 0;
  width: max-content; /* Règle d'or : force la liste à s'étendre sur une seule ligne */
  animation: scroll-marquee 35s linear infinite;
}

/* Met l'animation en pause quand l'utilisateur survole les logos */
.marquee-content:hover {
  animation-play-state: paused;
}

.marquee-content li {
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Style des logos (Images) */
.marquee-content li img {
  display: block;
  height: 35px; /* Force une taille homogène */
  width: auto;
  
  /* --- LA MAGIE EST ICI --- */
  filter: brightness(0) invert(1); /* Transforme le noir en blanc pur */
  opacity: 0.6; /* Légèrement transparent pour ne pas être trop agressif */
  /* ------------------------ */
  
  transition: all 0.3s ease-in-out;
}

/* Effet au survol : le logo redevient clair et net */
.marquee-content li img:hover {
  opacity: 1;
  transform: scale(1.1);
}

/* L'animation magique */
@keyframes scroll-marquee {
  0% {
    transform: translateX(0);
  }
  100% {
    /* Décale exactement de 50% pour créer la boucle parfaite avec la liste doublée */
    transform: translateX(-50%);
  }
}

/* Adaptation pour les écrans de téléphone */
@media (max-width: 768px) {
  .marquee-content {
    gap: 50px;
    animation-duration: 25s; /* Défilement un peu plus rapide sur petit écran */
  }
  .marquee-wrapper::before,
  .marquee-wrapper::after {
    width: 40px; /* Réduit la zone de fondu pour laisser plus de place aux logos */
  }
  .marquee-content li img {
    transform: scale(0.85); /* Réduit légèrement la taille des images */
  }
}