/* CYBOO V2 — Fond blanc + Dégradé violet/corail */
@import url('https://fonts.googleapis.com/css2?family=Fjalla+One&family=Poppins:wght@300;400;500;600;700&display=swap');

:root {
  --violet: #5e287e; --violet-dark: #3d1a54; --violet-light: #7b3fa6;
  --corail: #dd7d67; --corail-light: #e9a08f; --corail-dark: #c4614a;
  --blanc: #ffffff; --gris-50: #f7f7f9; --gris-100: #eeeef2; --gris-200: #d8d8e0;
  --gris-400: #8888a0; --gris-600: #555568; --gris-800: #2a2a38; --noir: #1a1a24;
  --rouge-urgence: #e63946; --rouge-dark: #c1121f; --vert: #2ec4b6;
  --grad: linear-gradient(135deg, #5e287e 0%, #dd7d67 100%);
  --grad-light: linear-gradient(135deg, rgba(94,40,126,.05), rgba(221,125,103,.05));
  --font-display: 'Fjalla One', sans-serif;
  --font-body: 'Poppins', sans-serif;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; -webkit-font-smoothing:antialiased; }
body { font-family:var(--font-body); background:var(--blanc); color:var(--gris-600); line-height:1.65; overflow-x:hidden; }
a { color:var(--violet); text-decoration:none; transition:color .3s; }
a:hover { color:var(--corail); }
img { max-width:100%; display:block; }
h1,h2,h3,h4 { font-family:var(--font-display); text-transform:uppercase; letter-spacing:.02em; line-height:1.1; color:var(--noir); }
h1 { font-size:clamp(2.2rem,5vw,4.5rem); }
h2 { font-size:clamp(1.6rem,3.5vw,2.8rem); }
h3 { font-size:clamp(1.1rem,2vw,1.5rem); }
p { max-width:65ch; }

.container { max-width:1200px; margin:0 auto; padding:0 clamp(1.5rem,4vw,3rem); }
.section { padding:clamp(4rem,7vw,7rem) 0; }
.text-center { text-align:center; }
.accent { background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.text-rouge { color:var(--rouge-urgence); -webkit-text-fill-color:var(--rouge-urgence); }
.text-corail { color:var(--corail); font-weight:600; }
.bg-light { background:var(--gris-50); }
.bg-gradient-light { background:var(--grad-light); }

/* NAV */
.nav { position:fixed; top:0; left:0; right:0; z-index:1000; padding:1rem 0; background:transparent; transition:all .4s; }
.nav.scrolled { background:rgba(255,255,255,.95); backdrop-filter:blur(20px); border-bottom:1px solid rgba(94,40,126,.08); padding:.6rem 0; box-shadow:0 2px 20px rgba(0,0,0,.04); }
.nav-inner { display:flex; align-items:center; justify-content:space-between; max-width:1200px; margin:0 auto; padding:0 clamp(1.5rem,4vw,3rem); }
.nav-logo img { height:38px; }
.nav-links { display:flex; gap:1.8rem; list-style:none; align-items:center; }
.nav-links a { color:var(--gris-600); font-size:.84rem; font-weight:500; text-transform:uppercase; letter-spacing:.04em; transition:color .3s; position:relative; }
.nav-links a::after { content:''; position:absolute; bottom:-4px; left:0; width:0; height:2px; background:var(--corail); transition:width .3s; }
.nav-links a:hover { color:var(--violet); }
.nav-links a:hover::after { width:100%; }
.nav-links a.active { color:var(--violet); }
.nav-urgence-link { color:var(--rouge-urgence) !important; font-weight:700 !important; }
.nav-urgence-link:hover { color:var(--rouge-dark) !important; }
.nav-dropdown { position:relative; }
.nav-dropdown-menu { position:absolute; top:100%; left:-1rem; min-width:260px; background:var(--blanc); border:1px solid var(--gris-100); border-radius:10px; padding:.5rem 0; opacity:0; visibility:hidden; transform:translateY(8px); transition:all .3s; box-shadow:0 20px 60px rgba(0,0,0,.1); }
.nav-dropdown:hover .nav-dropdown-menu { opacity:1; visibility:visible; transform:translateY(0); }
.nav-dropdown-menu a { display:block; padding:.65rem 1.2rem; font-size:.83rem; text-transform:none; letter-spacing:0; color:var(--gris-600); border-left:2px solid transparent; }
.nav-dropdown-menu a::after { display:none; }
.nav-dropdown-menu a:hover { color:var(--violet); background:rgba(94,40,126,.04); border-left-color:var(--corail); }
.nav-phone { display:flex; align-items:center; gap:.4rem; background:var(--grad); color:var(--blanc) !important; padding:.5rem 1.1rem; border-radius:6px; font-size:.82rem; font-weight:600; }
.nav-phone::after { display:none !important; }
.nav-phone:hover { opacity:.9; transform:translateY(-1px); color:var(--blanc) !important; }
.nav-phone--urgence { background:var(--rouge-urgence); }
.nav-toggle { display:none; background:none; border:none; cursor:pointer; padding:8px; }
.nav-toggle span { display:block; width:24px; height:2px; background:var(--noir); margin:5px 0; transition:all .3s; }

/* HERO GRADIENT */
.hero-gradient { height:100vh; display:flex; align-items:center; justify-content:center; background:var(--grad); position:relative; overflow:hidden; }
.hero-gradient::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 30% 50%, rgba(255,255,255,.1), transparent 70%); }
.hero-content { text-align:center; position:relative; z-index:2; }
.hero-logo-img { max-width:min(60vw,450px); height:auto; margin:0 auto; filter:drop-shadow(0 4px 40px rgba(0,0,0,.15)); }
.hero-logo-text { font-family:var(--font-display); font-size:clamp(3.5rem,9vw,7rem); color:var(--blanc); letter-spacing:.12em; text-shadow:0 4px 40px rgba(0,0,0,.2); }
.hero-tagline { margin-top:1.2rem; font-size:clamp(.85rem,1.4vw,1.1rem); color:rgba(255,255,255,.85); font-weight:300; letter-spacing:.15em; text-transform:uppercase; }
.scroll-indicator { position:absolute; bottom:2rem; left:50%; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:.5rem; color:rgba(255,255,255,.6); font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; animation:float 2s ease-in-out infinite; }
.scroll-indicator .arrow { width:14px; height:14px; border-right:1.5px solid rgba(255,255,255,.6); border-bottom:1.5px solid rgba(255,255,255,.6); transform:rotate(45deg); }
@keyframes float { 0%,100%{transform:translateX(-50%) translateY(0)} 50%{transform:translateX(-50%) translateY(8px)} }

/* PAGE HERO */
.page-hero { padding:6rem 0 4rem; border-bottom:1px solid var(--gris-100); }
.hero-sub { color:var(--gris-600); font-size:1.1rem; max-width:550px; margin:1rem auto 0; }

/* SECTION TITLE */
.section-title { text-align:center; margin-bottom:3.5rem; }
.section-title h2 { margin-bottom:.8rem; }
.section-title .subtitle { color:var(--gris-400); font-size:.95rem; max-width:500px; margin:0 auto; }

/* GRIDS */
.grid-2col { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center; }
.grid-3col { display:grid; grid-template-columns:repeat(auto-fit, minmax(300px, 1fr)); gap:1.5rem; }
.grid-4col { display:grid; grid-template-columns:repeat(auto-fit, minmax(260px, 1fr)); gap:1.5rem; }
.pillars-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(250px, 1fr)); gap:1.5rem; }
.stats-grid { display:grid; grid-template-columns:repeat(3, 1fr); gap:1.5rem; }
.trust-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(300px, 1fr)); gap:2rem; }
.plus-grid { display:grid; grid-template-columns:repeat(3, 1fr); }

/* CARDS */
.pillar-card { display:block; background:var(--blanc); border:1px solid var(--gris-100); border-radius:14px; padding:2rem; text-decoration:none; color:inherit; transition:all .3s; position:relative; overflow:hidden; }
.pillar-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--grad); transform:scaleX(0); transform-origin:left; transition:transform .4s; }
.pillar-card:hover { transform:translateY(-4px); box-shadow:0 16px 40px rgba(94,40,126,.08); border-color:var(--gris-200); color:inherit; }
.pillar-card:hover::before { transform:scaleX(1); }
.pillar-icon { width:48px; height:48px; background:var(--grad); border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:1.3rem; margin-bottom:1rem; }
.pillar-icon--rouge { background:linear-gradient(135deg, var(--rouge-urgence), var(--rouge-dark)); }
.pillar-card h3 { font-size:1rem; margin-bottom:.5rem; }
.pillar-card p { font-size:.88rem; color:var(--gris-600); line-height:1.6; }
.pillar-link { display:inline-block; margin-top:1rem; font-size:.82rem; font-weight:600; color:var(--corail); }

.stat-card { background:var(--blanc); border:1px solid var(--gris-100); border-radius:14px; padding:2rem; text-align:center; box-shadow:0 4px 20px rgba(0,0,0,.02); }
.stat-number { font-family:var(--font-display); font-size:2.8rem; background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; line-height:1; margin-bottom:.5rem; }
.stat-number.text-rouge { background:none; -webkit-text-fill-color:var(--rouge-urgence); color:var(--rouge-urgence); }
.stat-icon { font-size:2.2rem; margin-bottom:.8rem; }
.stat-card h3 { font-size:.9rem; margin-bottom:.5rem; }
.stat-card p { font-size:.85rem; color:var(--gris-600); margin:0 auto; }

.trust-card { background:var(--blanc); border:1px solid var(--gris-100); border-radius:14px; padding:2rem; position:relative; box-shadow:0 4px 20px rgba(0,0,0,.03); }
.trust-card--accent { border-color:var(--corail); }
.trust-card::before { content:'"'; position:absolute; top:.6rem; left:1.2rem; font-family:var(--font-display); font-size:3.5rem; background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; opacity:.2; line-height:1; }
.trust-text { font-style:italic; color:var(--gris-600); font-size:.92rem; margin-bottom:1rem; padding-top:1.2rem; }
.trust-author { display:flex; align-items:center; gap:.7rem; }
.trust-avatar { width:38px; height:38px; border-radius:50%; background:var(--grad); display:flex; align-items:center; justify-content:center; font-weight:700; font-size:.8rem; color:var(--blanc); flex-shrink:0; }
.trust-avatar.bg-corail { background:var(--corail); }
.trust-name { font-weight:600; color:var(--noir); font-size:.85rem; }
.trust-role { font-size:.75rem; color:var(--gris-400); }

.plus-item { padding:3rem 2rem; border-right:1px solid var(--gris-100); text-align:center; }
.plus-item:last-child { border-right:none; }
.plus-icon { font-size:2.2rem; margin-bottom:.8rem; }
.plus-item h3 { font-size:.95rem; background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; margin-bottom:.5rem; }
.plus-item p { color:var(--gris-600); font-size:.85rem; margin:0 auto; }

/* FORMATION */
.formation-card { background:var(--gris-50); border:1px solid var(--gris-100); border-radius:14px; padding:2rem; }
.formation-card h3 { font-size:.95rem; margin-bottom:.5rem; }
.formation-card p { font-size:.85rem; color:var(--gris-600); margin-bottom:1rem; line-height:1.6; }
.formation-meta { display:flex; justify-content:space-between; align-items:center; font-size:.78rem; }

/* PRODUCT */
.product-card { background:var(--blanc); border:1px solid var(--gris-100); border-radius:14px; padding:2rem; box-shadow:0 4px 20px rgba(0,0,0,.02); }
.product-card h3 { font-size:.95rem; margin-bottom:.2rem; }
.product-brand { color:var(--corail); font-size:.8rem; font-weight:600; margin-bottom:.6rem; }
.product-specs { font-size:.85rem; color:var(--gris-600); }
.product-footer { display:flex; justify-content:space-between; align-items:center; margin-top:1rem; padding-top:1rem; border-top:1px solid var(--gris-100); }
.product-price { font-family:var(--font-display); font-size:1.1rem; background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }
.product-warranty { font-size:.72rem; color:var(--vert); font-weight:600; }

/* PRICING */
.pricing-grid { display:grid; grid-template-columns:repeat(3, 1fr); gap:1.5rem; max-width:900px; margin:0 auto; }
.pricing-card { background:var(--blanc); border:1px solid var(--gris-100); border-radius:16px; padding:2.5rem 1.8rem; text-align:center; position:relative; transition:all .3s; box-shadow:0 4px 20px rgba(0,0,0,.02); }
.pricing-card--popular { border-color:var(--corail); transform:scale(1.04); box-shadow:0 20px 60px rgba(94,40,126,.1); }
.pricing-badge { position:absolute; top:-12px; left:50%; transform:translateX(-50%); background:var(--grad); color:var(--blanc); padding:.25rem 1rem; border-radius:50px; font-size:.72rem; font-weight:700; text-transform:uppercase; }
.pricing-name { font-family:var(--font-display); font-size:1.1rem; color:var(--noir); text-transform:uppercase; margin-bottom:.3rem; }
.pricing-price { font-family:var(--font-display); font-size:2.8rem; background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; line-height:1; }
.pricing-price small { font-size:.85rem; color:var(--gris-400); font-family:var(--font-body); -webkit-text-fill-color:var(--gris-400); }
.pricing-features { list-style:none; margin:1.5rem 0; text-align:left; }
.pricing-features li { padding:.45rem 0; font-size:.85rem; color:var(--gris-600); border-bottom:1px solid var(--gris-50); display:flex; gap:.5rem; }
.pricing-features li.disabled { color:var(--gris-200); }
.check { color:var(--vert); font-weight:700; flex-shrink:0; }

/* BUTTONS */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:.4rem; padding:.75rem 1.6rem; font-family:var(--font-body); font-weight:600; font-size:.88rem; border-radius:8px; border:none; cursor:pointer; text-decoration:none; transition:all .3s; }
.btn-primary { background:var(--grad); color:var(--blanc); }
.btn-primary:hover { opacity:.9; transform:translateY(-2px); box-shadow:0 8px 24px rgba(94,40,126,.2); color:var(--blanc); }
.btn-ghost { background:transparent; border:1.5px solid var(--corail); color:var(--corail); }
.btn-ghost:hover { background:var(--corail); color:var(--blanc); }
.btn-urgence { background:var(--rouge-urgence); color:var(--blanc); font-size:1rem; padding:1rem 2rem; }
.btn-urgence:hover { background:var(--rouge-dark); transform:translateY(-2px); box-shadow:0 8px 24px rgba(230,57,70,.3); color:var(--blanc); }
.btn-white { background:var(--blanc); color:var(--violet); }
.btn-white:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(255,255,255,.2); color:var(--violet); }
.btn-outline-white { background:transparent; border:1.5px solid rgba(255,255,255,.35); color:var(--blanc); }
.btn-outline-white:hover { border-color:var(--blanc); background:rgba(255,255,255,.1); color:var(--blanc); }
.btn-full { width:100%; }
.btn-big { font-size:1.2rem; padding:1.2rem 2.5rem; }
.btn-group { display:flex; gap:1rem; flex-wrap:wrap; justify-content:center; }
.btn-group-left { justify-content:flex-start; }

/* BADGES */
.badge { display:inline-block; padding:.25rem .8rem; border-radius:50px; font-size:.75rem; font-weight:600; text-transform:uppercase; letter-spacing:.06em; margin-bottom:1rem; }
.badge-corail { background:rgba(221,125,103,.1); border:1px solid rgba(221,125,103,.2); color:var(--corail); }
.badge-violet { background:rgba(94,40,126,.08); color:var(--violet); }

/* PRICING HERO */
.price-row { display:flex; gap:2rem; margin-bottom:2rem; }
.price-big { font-family:var(--font-display); font-size:2.2rem; line-height:1; }
.price-big.accent { background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }
.price-sub { font-size:.8rem; color:var(--gris-400); }
.price-sep { border-left:1px solid var(--gris-200); padding-left:2rem; }
.small-note { font-size:.78rem; color:var(--gris-400); margin-top:.8rem; }

/* FEATURE BOX */
.feature-box { background:var(--blanc); border:1px solid var(--gris-100); border-radius:16px; padding:2rem; box-shadow:0 10px 40px rgba(0,0,0,.04); }
.feature-box--center { max-width:700px; margin:0 auto; }
.feature-box h3 { font-family:var(--font-display); font-size:.95rem; color:var(--noir); margin-bottom:1rem; }
.feature-line { padding:.55rem 0; border-bottom:1px solid var(--gris-50); font-size:.88rem; color:var(--gris-600); display:flex; gap:.5rem; }
.feature-line:last-child { border-bottom:none; }

/* FORMS */
.form-box { background:var(--gris-50); border:1px solid var(--gris-100); border-radius:16px; padding:2.5rem; max-width:700px; margin:0 auto; }
.form-box--urgence { border-color:var(--rouge-urgence); border-width:2px; }
.form-group { margin-bottom:1rem; }
.form-group label { display:block; font-size:.82rem; font-weight:500; color:var(--gris-600); margin-bottom:.3rem; }
.form-group input, .form-group select, .form-group textarea { width:100%; padding:.7rem .9rem; background:var(--blanc); border:1px solid var(--gris-200); border-radius:8px; color:var(--noir); font-family:var(--font-body); font-size:.88rem; transition:border-color .3s; }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { outline:none; border-color:var(--corail); }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.form-note { font-size:.78rem; color:var(--gris-400); text-align:center; margin-top:1rem; }
.form-note a { color:var(--rouge-urgence); font-weight:600; }
.form-success { background:var(--gris-50); border:1px solid var(--gris-100); border-radius:16px; padding:3rem; max-width:700px; margin:0 auto; text-align:center; }
.success-icon { font-size:4rem; margin-bottom:1rem; color:var(--vert); }
.form-success h3 { color:var(--vert); }
.form-success p { color:var(--gris-600); margin-top:.8rem; }

/* FAQ */
.faq-list { max-width:700px; margin:0 auto; }
.faq-item { border-bottom:1px solid var(--gris-100); padding:1.2rem 0; }
.faq-item summary { cursor:pointer; font-weight:600; color:var(--noir); font-size:.92rem; list-style:none; }
.faq-item summary::-webkit-details-marker { display:none; }
.faq-item p { color:var(--gris-600); font-size:.88rem; margin-top:.6rem; }

/* URGENCE */
.urgence-hero { min-height:55vh; display:flex; align-items:center; background:linear-gradient(135deg, #0a0a0f, #1a0808); padding:6rem 0; position:relative; overflow:hidden; }
.urgence-hero::before { content:''; position:absolute; top:-40%; right:-15%; width:500px; height:500px; background:radial-gradient(circle, rgba(230,57,70,.1), transparent 70%); border-radius:50%; }
.urgence-hero-content { max-width:650px; }
.urgence-hero h1 { color:var(--blanc); }
.urgence-hero .hero-sub { color:rgba(255,255,255,.65); }
.urgence-badge { display:inline-flex; align-items:center; gap:.5rem; background:rgba(230,57,70,.12); border:1px solid rgba(230,57,70,.25); color:var(--rouge-urgence); padding:.35rem 1rem; border-radius:50px; font-size:.78rem; font-weight:600; text-transform:uppercase; letter-spacing:.08em; margin-bottom:1.5rem; }
.urgence-badge .dot { width:8px; height:8px; background:var(--rouge-urgence); border-radius:50%; animation:blink 1s infinite; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.3} }
.urgence-phone { display:block; font-family:var(--font-display); font-size:clamp(2.5rem,5vw,4rem); color:var(--blanc); margin:1.5rem 0; letter-spacing:.02em; }
.urgence-phone:hover { color:var(--rouge-urgence); }
.urgence-teaser { background:linear-gradient(135deg, #1a0808, #2a0a0a); padding:5rem 0; }
.urgence-teaser h2 { color:var(--blanc); }
.urgence-teaser-text { color:rgba(255,255,255,.6); max-width:500px; margin:0 auto 2rem; }
.urgence-cta { background:linear-gradient(135deg, #2a0a0a, #0a0a0f); padding:4rem 0; }
.urgence-cta h2 { margin-bottom:.8rem; }
.urgence-cta p { color:rgba(255,255,255,.6); margin-bottom:1.5rem; }

/* REFLEXES */
.reflexes-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(200px, 1fr)); gap:1.2rem; counter-reset:reflexe; }
.reflexe-card { background:var(--gris-50); border:1px solid var(--gris-100); border-radius:12px; padding:1.5rem; counter-increment:reflexe; position:relative; transition:all .3s; }
.reflexe-card:hover { border-color:var(--rouge-urgence); transform:translateY(-3px); }
.reflexe-card::before { content:counter(reflexe); font-family:var(--font-display); font-size:2.2rem; color:var(--rouge-urgence); opacity:.12; position:absolute; top:.5rem; right:.8rem; }
.reflexe-card h3 { font-size:.88rem; color:var(--noir); margin-bottom:.3rem; text-transform:none; }
.reflexe-card p { font-size:.8rem; color:var(--gris-400); }

/* TIMELINE */
.process-timeline { display:grid; grid-template-columns:repeat(4, 1fr); margin-top:2rem; }
.process-step { text-align:center; padding:0 1rem; }
.step-dot { width:18px; height:18px; border-radius:50%; margin:0 auto .8rem; }
.step-dot--rouge { background:var(--rouge-urgence); }
.step-dot--orange { background:#ff8c42; }
.step-dot--violet { background:var(--violet); }
.step-dot--vert { background:var(--vert); }
.step-time { font-family:monospace; font-size:.72rem; color:var(--corail); margin-bottom:.2rem; }
.process-step h4 { font-size:.82rem; color:var(--noir); text-transform:none; }

/* CTA BAND */
.cta-band { background:var(--grad); padding:4rem 0; text-align:center; position:relative; }
.cta-band h2 { color:var(--blanc); margin-bottom:.8rem; }
.cta-band p { color:rgba(255,255,255,.8); margin:0 auto 2rem; }

/* CONTACT */
.contact-info { margin-bottom:2rem; }
.contact-line { display:flex; gap:1rem; align-items:flex-start; padding:1rem 0; border-bottom:1px solid var(--gris-100); }
.contact-icon { width:40px; height:40px; background:var(--grad-light); border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:1.1rem; flex-shrink:0; }
.contact-hours { margin-top:2rem; }
.map-placeholder { background:var(--gris-100); height:300px; display:flex; align-items:center; justify-content:center; color:var(--gris-400); font-size:.9rem; }

/* VIDEO PLACEHOLDER */
.video-placeholder { background:var(--gris-50); border:1px dashed var(--gris-200); border-radius:14px; padding:4rem 2rem; text-align:center; color:var(--gris-400); font-size:.88rem; }

/* LEGAL */
.legal-content h2 { font-size:1.3rem; margin:2rem 0 .8rem; text-transform:none; }
.legal-content p { color:var(--gris-600); margin-bottom:1rem; font-size:.9rem; }

/* FOOTER */
.footer { background:var(--noir); padding:4rem 0 2rem; }
.footer-grid { display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:3rem; margin-bottom:3rem; }
.footer-brand p { color:var(--gris-400); font-size:.85rem; margin-top:.8rem; }
.footer-address { font-size:.78rem !important; margin-top:.5rem !important; }
.footer h4 { color:var(--blanc); font-size:.82rem; margin-bottom:1rem; text-transform:uppercase; letter-spacing:.06em; }
.footer-links { list-style:none; }
.footer-links li { margin-bottom:.5rem; }
.footer-links a { color:var(--gris-400); font-size:.85rem; }
.footer-links a:hover { color:var(--corail); padding-left:3px; }
.footer-bottom { padding-top:1.5rem; border-top:1px solid var(--gris-800); display:flex; justify-content:space-between; font-size:.78rem; color:var(--gris-400); }
.footer-bottom a { color:var(--gris-400); }
.footer-social a { width:34px; height:34px; border:1px solid var(--gris-800); border-radius:8px; display:flex; align-items:center; justify-content:center; color:var(--gris-400); transition:all .3s; }
.footer-social a:hover { border-color:var(--corail); color:var(--corail); }

/* WHATSAPP */
.whatsapp-float { position:fixed; bottom:1.5rem; right:1.5rem; width:54px; height:54px; background:#25d366; border-radius:50%; display:flex; align-items:center; justify-content:center; z-index:999; box-shadow:0 4px 20px rgba(37,211,102,.35); transition:all .3s; }
.whatsapp-float:hover { transform:scale(1.08); }
.whatsapp-float svg { width:26px; height:26px; fill:white; }

/* COOKIES */
.cookie-banner { position:fixed; bottom:0; left:0; right:0; background:var(--blanc); border-top:1px solid var(--gris-100); padding:1rem 2rem; display:none; align-items:center; justify-content:space-between; z-index:9998; box-shadow:0 -4px 20px rgba(0,0,0,.05); gap:1.5rem; }
.cookie-banner.visible { display:flex; }
.cookie-banner p { font-size:.8rem; color:var(--gris-600); max-width:none; }
.cookie-btns { display:flex; gap:.8rem; flex-shrink:0; }
.cookie-accept { background:var(--violet); color:var(--blanc); border:none; padding:.45rem 1rem; border-radius:6px; font-size:.78rem; font-weight:600; cursor:pointer; }
.cookie-decline { background:transparent; color:var(--gris-400); border:1px solid var(--gris-200); padding:.45rem 1rem; border-radius:6px; font-size:.78rem; cursor:pointer; }

/* RESPONSIVE */
@media (max-width:1024px) {
  .pricing-grid { grid-template-columns:1fr; max-width:400px; }
  .pricing-card--popular { transform:none; }
  .process-timeline { grid-template-columns:1fr 1fr; gap:2rem; }
}
@media (max-width:768px) {
  .nav-links { display:none; }
  .nav-toggle { display:block; }
  .grid-2col { grid-template-columns:1fr; gap:2rem; }
  .stats-grid { grid-template-columns:1fr; }
  .plus-grid { grid-template-columns:1fr; }
  .plus-item { border-right:none; border-bottom:1px solid var(--gris-100); }
  .plus-item:last-child { border-bottom:none; }
  .footer-grid { grid-template-columns:1fr 1fr; }
  .form-row { grid-template-columns:1fr; }
  .process-timeline { grid-template-columns:1fr; }
  .cookie-banner { flex-direction:column; text-align:center; }
  .price-row { flex-direction:column; gap:1rem; }
  .price-sep { border-left:none; border-top:1px solid var(--gris-200); padding:1rem 0 0; }
}
@media (max-width:480px) {
  .footer-grid { grid-template-columns:1fr; }
}

/* PATCH MENU MOBILE - À ajouter à la fin de style.css */

/* Bouton burger */
.nav-toggle {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: 8px;
  flex-direction: column;
  gap: 5px;
  z-index: 1001;
}

.nav-toggle span {
  display: block;
  width: 25px;
  height: 3px;
  background: var(--violet, #5e287e);
  transition: all 0.3s;
  border-radius: 2px;
}

/* Animation burger → X */
.nav-toggle.active span:nth-child(1) {
  transform: rotate(45deg) translateY(8px);
}

.nav-toggle.active span:nth-child(2) {
  opacity: 0;
}

.nav-toggle.active span:nth-child(3) {
  transform: rotate(-45deg) translateY(-8px);
}

/* Mobile responsive */
@media (max-width: 968px) {
  .nav-toggle {
    display: flex;
  }
  
  .nav-links {
    position: fixed;
    top: 70px;
    right: -100%;
    background: white;
    flex-direction: column;
    width: 80%;
    max-width: 320px;
    padding: 30px 20px;
    box-shadow: -5px 0 15px rgba(0,0,0,0.1);
    transition: right 0.3s ease;
    height: calc(100vh - 70px);
    overflow-y: auto;
    z-index: 1000;
  }
  
  .nav-links.nav-open {
    right: 0;
  }
  
  .nav-links li {
    margin: 0;
    padding: 15px 0;
    border-bottom: 1px solid #f0f0f0;
  }
  
  .nav-links a {
    display: block;
    padding: 5px 0;
  }
  
  /* Dropdown dans le menu mobile */
  .nav-dropdown {
    position: relative;
  }
  
  .nav-dropdown-menu {
    position: static;
    display: none;
    box-shadow: none;
    padding-left: 20px;
    margin-top: 10px;
  }
  
  .nav-dropdown:hover .nav-dropdown-menu {
    display: block;
  }
  
  /* Bloquer le scroll quand menu ouvert */
  body.menu-open {
    overflow: hidden;
  }
  
  /* Overlay derrière le menu */
  .nav-links.nav-open::before {
    content: '';
    position: fixed;
    top: 70px;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0,0,0,0.5);
    z-index: -1;
  }
}
