/* ================================================
   ITP WINGOU v6.0 — Feuille de style principale
   ================================================
   TABLE DES MATIÈRES
   ─────────────────────────────────────────────
   01. VARIABLES CSS (:root)
   02. RESET & BASE
   03. TYPOGRAPHIE
   04. LAYOUT : top-bar, nav, mobile-menu
   05. SECTION : hero
   06. SECTION : promise
   07. SECTION : wingou (modules)
   08. SECTION : verticals (tabs secteurs)
   09. SECTION : calculator
   10. SECTION : process
   11. SECTION : contact / footer
   12. CHATBOT
   13. RESPONSIVE
   14. PHASE 1+2 : sécurité, accessibilité
   15. PHASE 3+4 : animations, UX, performance
   ================================================ */

:root {
  /* ── Couleurs principales ── */
  --red: #CC1B1B;
  --red-dark: #A01414;
  --red-deep: #7A0F0F;
  --red-light: #E8443A;
  --red-pale: #FFF0F0;
  --red-tint: rgba(204,27,27,0.08);
  --red-tint2: rgba(204,27,27,0.15);

  /* ── Couleurs neutres ── */
  --white: #FFFFFF;
  --wingou-blue: #29ABE2;
  --off-white: #F7F7F7;
  --gray-50: #F4F4F4;
  --gray-100: #E8E8E8;
  --gray-200: #D0D0D0;
  --gray-400: #999;
  --gray-600: #555;
  --gray-800: #222;
  --black: #111;

  /* ── Sémantiques ── */
  --success: #1A7F4B;
  --success-bg: #E8F5EE;
  --border: #E0E0E0;

  /* ── Ombres ── */
  --shadow-sm: 0 2px 8px rgba(0,0,0,0.06);
  --shadow-md: 0 4px 24px rgba(0,0,0,0.10);
  --shadow-lg: 0 12px 48px rgba(0,0,0,0.12);

  /* ── Typographie ── */
  --font-head: 'Barlow Condensed', sans-serif;
  --font-body: 'Barlow', sans-serif;

  /* ── Géométrie ── */
  --radius: 8px;
  --radius-lg: 14px;
  --radius-xl: 20px;

  /* ── Animations (Phase 4) ── */
  --transition-fast: 0.15s ease;
  --transition-base: 0.25s ease;
  --transition-slow: 0.4s ease;
  --anim-fade-up: fadeInUp 0.6s ease-out forwards;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--white);color:var(--gray-800);overflow-x:hidden;line-height:1.6;font-weight:400}
h1,h2,h3,h4{font-family:var(--font-head);font-weight:700;line-height:1.05;text-transform:uppercase;letter-spacing:-0.01em}
h1{font-size:clamp(2.6rem,6vw,4.8rem)}
h2{font-size:clamp(2rem,4vw,3rem)}
h3{font-size:clamp(1.3rem,2.5vw,1.7rem)}
p{font-weight:300}
.label{font-family:var(--font-body);font-size:0.68rem;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;color:var(--red)}
.container{max-width:1180px;margin:0 auto;padding:0 28px}
section{padding:96px 0}

/* ── 04. LAYOUT ─────────────────────────────
   Top bar, navigation, menu mobile
   ─────────────────────────────────────────── */
/* TOP BAR */
.top-bar{
  background:var(--white);
  padding:14px 28px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-size:1rem;
  color:var(--gray-800);
  border-bottom:3px solid var(--red);
}
.top-bar a{color:var(--red);text-decoration:none;font-weight:600}
.top-bar strong{color:var(--red);font-weight:700}

/* NAV */
nav{background:var(--white);border-bottom:3px solid var(--red);position:sticky;top:0;z-index:100;box-shadow:0 2px 12px rgba(0,0,0,0.08)}
.nav-inner{max-width:1180px;margin:0 auto;padding:0 28px;display:flex;align-items:center;justify-content:space-between;height:68px}
.logo{display:flex;align-items:center;text-decoration:none}
.logo img{height:44px;width:auto;display:block}
.nav-links{display:flex;align-items:center;gap:4px;list-style:none}
.nav-links a{color:var(--gray-600);text-decoration:none;font-size:0.85rem;font-weight:500;padding:8px 14px;border-radius:6px;transition:all 0.2s;white-space:nowrap}
.nav-links a:hover{color:var(--red);background:var(--red-tint)}
.nav-cta{background:var(--red);color:var(--white);padding:10px 22px;border-radius:var(--radius);text-decoration:none;font-weight:700;font-size:0.88rem;transition:all 0.2s;border:none;cursor:pointer;font-family:var(--font-body);text-transform:uppercase;letter-spacing:0.05em;white-space:nowrap}
.nav-cta:hover{background:var(--red-dark);transform:translateY(-1px);box-shadow:0 4px 16px rgba(204,27,27,0.35)}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px}
.hamburger span{width:24px;height:2px;background:var(--gray-800);border-radius:2px;transition:all 0.3s}

/* MOBILE MENU */
.mobile-menu{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:var(--white);z-index:200;flex-direction:column;padding:24px}
.mobile-menu.open{display:flex}
.mobile-menu-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:36px;padding-bottom:20px;border-bottom:2px solid var(--red)}
.mobile-close{background:none;border:1px solid var(--border);color:var(--gray-600);width:40px;height:40px;border-radius:var(--radius);cursor:pointer;font-size:1.1rem}
.mobile-menu-links{display:flex;flex-direction:column;gap:4px;flex:1}
.mobile-menu-links a{color:var(--gray-600);text-decoration:none;font-size:1.2rem;font-family:var(--font-head);font-weight:700;text-transform:uppercase;padding:14px 0;border-bottom:1px solid var(--border);transition:color 0.2s}
.mobile-menu-links a:hover{color:var(--red)}
.mobile-cta-wrap{margin-top:28px}
.mobile-cta{display:block;background:var(--red);color:var(--white);padding:16px;border-radius:var(--radius);text-align:center;text-decoration:none;font-weight:700;font-size:1rem;text-transform:uppercase;letter-spacing:0.06em;font-family:var(--font-head)}

/* ── 05. SECTION HERO ───────────────────────── */
#hero{background:var(--white);min-height:calc(100vh - 108px);display:flex;align-items:center;position:relative;overflow:hidden;padding:60px 0}
.hero-bg-shape{position:absolute;top:0;right:0;bottom:0;width:45%;background:var(--red);clip-path:none}
.hero-bg-pattern{position:absolute;top:0;right:0;bottom:0;width:45%;clip-path:polygon(15% 0,100% 0,100% 100%,0% 100%);background-image:repeating-linear-gradient(45deg,transparent,transparent 20px,rgba(255,255,255,0.04) 20px,rgba(255,255,255,0.04) 22px)}
.hero-content{position:relative;z-index:2;max-width:1180px;margin:0 auto;padding:0 28px;display:grid;grid-template-columns:1fr 1fr;gap:15%;align-items:center}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;background:var(--red-pale);border:1px solid rgba(204,27,27,0.25);border-radius:4px;padding:5px 14px;margin-bottom:24px;font-size:0.72rem;font-weight:600;color:var(--red);letter-spacing:0.1em;text-transform:uppercase}
.hero-title{margin-bottom:24px;color:var(--gray-800)}
.hero-title em{font-style:normal;color:var(--red)}
.hero-desc{color:var(--gray-600);font-size:1.05rem;margin-bottom:36px;max-width:550px;line-height:1.75;font-weight:300}
.hero-actions{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:40px}
.btn-primary{background:var(--red);color:var(--white);padding:14px 28px;border-radius:var(--radius);font-weight:700;font-size:0.88rem;text-decoration:none;transition:all 0.25s;display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);border:2px solid var(--red);cursor:pointer;text-transform:uppercase;letter-spacing:0.06em}
.btn-primary:hover{background:var(--red-dark);border-color:var(--red-dark);transform:translateY(-2px);box-shadow:0 6px 24px rgba(204,27,27,0.3)}
.btn-outline{background:transparent;color:var(--gray-700);padding:12px 24px;border-radius:var(--radius);font-weight:600;font-size:0.88rem;text-decoration:none;transition:all 0.2s;display:inline-flex;align-items:center;gap:8px;border:2px solid var(--border);cursor:pointer;font-family:var(--font-body);text-transform:uppercase;letter-spacing:0.05em}
.btn-outline:hover{border-color:var(--red);color:var(--red)}
.btn-outline-white{background:transparent;color:var(--white);padding:12px 24px;border-radius:var(--radius);font-weight:600;font-size:0.88rem;text-decoration:none;transition:all 0.2s;display:inline-flex;align-items:center;gap:8px;border:2px solid rgba(255,255,255,0.5);cursor:pointer;font-family:var(--font-body);text-transform:uppercase;letter-spacing:0.05em}
.btn-outline-white:hover{background:rgba(255,255,255,0.15);border-color:var(--white)}
.hero-stats{display:flex;gap:0;border-top:1px solid var(--border);padding-top:32px}
.hero-stat{flex:1;padding-right:24px;border-right:1px solid var(--border);margin-right:24px}
.hero-stat:last-child{border-right:none;margin-right:0}
.hero-stat-value{font-family:var(--font-head);font-size:2rem;font-weight:800;color:var(--red);line-height:1}
.hero-stat-label{font-size:0.78rem;color:var(--gray-400);margin-top:4px}

/* HERO RIGHT — CORRIGÉ */
.hero-right{position:relative}
.hero-partners-wrap{background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.25);border-radius:var(--radius-xl);padding:32px 28px;backdrop-filter:blur(4px)}
.hero-partners-title{font-family:var(--font-head);font-size:0.75rem;font-weight:700;color:rgba(255,255,255,0.6);text-transform:uppercase;letter-spacing:0.14em;margin-bottom:6px}
.wingou-logo-wrap{background:#FFFFFF;border-radius:var(--radius-lg);padding:14px 24px;margin-bottom:16px;display:flex;align-items:center;justify-content:center;border:none;box-shadow:none}
.wingou-logo-wrap img{height:auto;width:80%;display:block;margin:0 auto}
.cert-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.cert-pill{background:rgba(255,255,255,0.15);border:1px solid rgba(255,255,255,0.3);border-radius:100px;padding:5px 14px;font-size:0.7rem;color:rgba(255,255,255,0.9);font-weight:600;letter-spacing:0.06em;text-transform:uppercase}
.cert-pill.gold{background:rgba(255,215,0,0.2);border-color:rgba(255,215,0,0.4);color:#FFD700}
.partners-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.partner-badge{background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.2);border-radius:var(--radius);padding:8px 12px;font-size:0.72rem;font-weight:700;color:rgba(255,255,255,0.8);text-transform:uppercase;letter-spacing:0.06em;text-align:center}
.partner-badge--logo{background:#fff;border:1px solid rgba(255,255,255,0.3);padding:10px 14px;display:flex;align-items:center;justify-content:center;min-height:52px}
.partner-badge--logo img{max-width:100%;max-height:36px;width:auto;height:auto;object-fit:contain;display:block}


.hero-notif{position:absolute;bottom:-18px;left:-18px;background:var(--white);border-radius:var(--radius);padding:14px 16px;min-width:200px;box-shadow:var(--shadow-lg);border-left:3px solid var(--red);animation:popIn 0.6s 0.9s ease both}
@keyframes popIn{from{opacity:0;transform:scale(0.9) translateX(-10px)}to{opacity:1;transform:scale(1) translateX(0)}}
.notif-tag{font-size:0.65rem;font-weight:700;color:var(--red);text-transform:uppercase;letter-spacing:0.1em;margin-bottom:3px}
.notif-msg{font-size:0.8rem;color:var(--gray-600);line-height:1.4}

/* ── 06. SECTION PROMISE ────────────────────── */
#promise{background:var(--gray-50);padding:80px 0}
.promise-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.pain-list{display:flex;flex-direction:column;gap:12px}
.pain-item{display:flex;gap:14px;align-items:flex-start;background:var(--white);border:1px solid var(--border);border-left:3px solid var(--red);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow-sm)}
.pain-icon{color:var(--red);font-size:1.1rem;flex-shrink:0;margin-top:1px}
.pain-text{font-size:0.9rem;color:var(--gray-600);line-height:1.5}
.pain-text strong{color:var(--gray-800);font-weight:600;display:block;margin-bottom:2px}
.solution-box{background:var(--red);color:var(--white);border-radius:var(--radius-lg);padding:40px;position:relative;overflow:hidden}
.solution-box::after{content:'';position:absolute;top:-30px;right:-30px;width:160px;height:160px;border-radius:50%;background:rgba(255,255,255,0.05)}
.solution-box h3{color:var(--white);margin-bottom:16px}
.solution-box p{color:rgba(255,255,255,0.8);font-size:0.95rem;line-height:1.75;margin-bottom:28px;font-weight:300}
.proof-row{display:flex;gap:0;border-top:1px solid rgba(255,255,255,0.2);padding-top:24px}
.proof-item{flex:1;text-align:center;border-right:1px solid rgba(255,255,255,0.15);padding:0 12px}
.proof-item:last-child{border-right:none}
.proof-val{font-family:var(--font-head);font-size:1.8rem;font-weight:800;color:var(--white)}
.proof-lbl{font-size:0.72rem;color:rgba(255,255,255,0.6)}
.btn-white{background:var(--white);color:var(--red);padding:11px 22px;border-radius:var(--radius);font-weight:700;font-size:0.82rem;text-decoration:none;transition:all 0.2s;display:inline-flex;align-items:center;gap:6px;border:2px solid var(--white);cursor:pointer;font-family:var(--font-body);text-transform:uppercase;letter-spacing:0.05em}
.btn-white:hover{background:rgba(255,255,255,0.9);transform:translateY(-1px)}

/* ── 07. SECTION WINGOU (modules) ──────────── */
#wingou{background:var(--white)}
.section-header{max-width:720px;margin:0 auto 56px;text-align:center}
.section-header .label{margin-bottom:10px;display:block}
.section-header p{color:var(--gray-500);font-size:1rem;margin-top:14px;line-height:1.7;max-width:580px;margin-left:auto;margin-right:auto}
.red-line{width:48px;height:3px;background:var(--red);margin:16px auto 0;border-radius:2px}
.wingou-section-logo{display:flex;justify-content:center;margin-bottom:28px}
.wingou-section-logo img{height:90px;width:auto}
.modules-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:40px}
.mod-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px 18px;transition:all 0.25s;cursor:default;position:relative;overflow:hidden}
.mod-card:hover{border-color:var(--red);box-shadow:var(--shadow-md);transform:translateY(-3px)}
.mod-card:hover .mod-icon-wrap{background:var(--red);color:var(--white)}
.mod-icon-wrap{width:44px;height:44px;background:var(--red-tint);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:1.2rem;margin-bottom:14px;transition:all 0.25s}
.mod-name{font-family:var(--font-head);font-size:1rem;font-weight:700;margin-bottom:6px;text-transform:uppercase;letter-spacing:0.03em;color:var(--gray-800)}
.mod-desc{font-size:0.8rem;color:var(--gray-400);line-height:1.55}
.mod-badge{display:inline-block;margin-top:10px;font-size:0.62rem;font-weight:700;padding:2px 8px;border-radius:3px;letter-spacing:0.08em;text-transform:uppercase}
.badge-red{background:var(--red-tint);color:var(--red)}
.badge-green{background:var(--success-bg);color:var(--success)}

/* Modules inclus - CORRIGÉ: pas de checkbox */
.mod-included{opacity:0.7}
.mod-included .mod-badge{background:rgba(26,127,75,0.15);color:var(--success)}

.wingou-cta-band{background:var(--gray-800);border-radius:var(--radius-lg);padding:40px 48px;display:flex;align-items:center;justify-content:space-between;gap:32px;position:relative;overflow:hidden}
.wingou-cta-band::before{content:'';position:absolute;left:0;top:0;bottom:0;width:5px;background:var(--red)}
.wingou-cta-text h3{color:var(--white);margin-bottom:8px}
.wingou-cta-text p{color:rgba(255,255,255,0.6);font-size:0.92rem;max-width:500px;font-weight:300}
.wingou-pill{background:var(--red);color:var(--white);border-radius:var(--radius);padding:22px 28px;text-align:center;flex-shrink:0}
.wingou-pill-num{font-family:var(--font-head);font-size:2.8rem;font-weight:800;line-height:1}
.wingou-pill-txt{font-size:0.72rem;color:rgba(255,255,255,0.75);margin-top:4px;text-transform:uppercase;letter-spacing:0.08em}

/* ── 08. SECTION VERTICALS (tabs) ──────────── */
#verticals{background:var(--gray-50)}
.sector-tabs{display:flex;gap:0;margin-bottom:32px;border-bottom:2px solid var(--border);justify-content:center;flex-wrap:wrap;overflow-x:visible}
.sector-tab{padding:14px 16px;font-size:0.85rem;font-weight:600;color:var(--gray-400);cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;transition:all 0.2s;white-space:nowrap;background:none;border-top:none;border-left:none;border-right:none;font-family:var(--font-body);text-transform:uppercase;letter-spacing:0.06em;flex-shrink:0}
.sector-tab.active{color:var(--red);border-bottom-color:var(--red)}
.sector-tab:hover{color:var(--gray-700)}
.sector-panel{display:none}
.sector-panel.active{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px}
.sector-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;transition:all 0.25s;box-shadow:var(--shadow-sm)}
.sector-card:hover{box-shadow:var(--shadow-md);border-color:var(--red)}
.sector-card-icon{font-size:2rem;margin-bottom:16px}
.sector-card-title{font-family:var(--font-head);font-size:1.1rem;font-weight:700;text-transform:uppercase;margin-bottom:10px}
.sector-card-desc{font-size:0.85rem;color:var(--gray-500);line-height:1.65;margin-bottom:20px}
.sector-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:16px;border-top:1px solid var(--border)}
.sector-mrr{font-family:var(--font-head);font-size:1.1rem;font-weight:700;color:var(--red)}
.sector-mrr-lbl{font-size:0.68rem;color:var(--gray-400);text-transform:uppercase;letter-spacing:0.08em}
.stars{color:var(--red);font-size:0.85rem;letter-spacing:1px}
.sector-cta-card{background:var(--red);color:var(--white);border-radius:var(--radius-lg);padding:20px 40px;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;grid-column:1/-1;max-width:660px;margin:0 auto;width:100%}
.sector-cta-card h4{color:var(--white);font-size:1.1rem;margin-bottom:6px}
.sector-cta-card p{color:rgba(255,255,255,0.8);font-size:0.82rem;line-height:1.5;margin-bottom:14px;font-weight:300}
.sector-cta-card .btn-white{padding:8px 20px;font-size:0.78rem}

/* ── 09. SECTION CALCULATOR ─────────────────── */
#calculator{background:var(--white)}
.calc-container{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-lg)}
.calc-top{background:var(--red);padding:40px 48px;color:var(--white);display:flex;align-items:center;justify-content:space-between;gap:32px}
.calc-top-text h2{color:var(--white);margin-bottom:8px}
.calc-top-text p{color:rgba(255,255,255,0.75);font-size:0.95rem;font-weight:300}
.calc-disclaimer-badge{background:rgba(255,255,255,0.15);border:1px solid rgba(255,255,255,0.3);border-radius:var(--radius);padding:12px 20px;text-align:center;flex-shrink:0;font-size:0.75rem;color:rgba(255,255,255,0.8);line-height:1.5}
.calc-disclaimer-badge strong{color:var(--white);font-size:0.9rem;display:block;margin-bottom:2px}
.calc-body{display:grid;grid-template-columns:1fr 1fr}
.calc-left{padding:40px 48px;border-right:1px solid var(--border);background:var(--gray-50)}
.calc-right{padding:40px 48px}
.calc-group{margin-bottom:28px}
.calc-lbl{font-size:0.8rem;font-weight:600;color:var(--gray-600);margin-bottom:10px;display:flex;justify-content:space-between;text-transform:uppercase;letter-spacing:0.06em}
.calc-lbl span{color:var(--red);font-weight:700;font-size:0.88rem;text-transform:none;letter-spacing:0}
.calc-slider{width:100%;-webkit-appearance:none;appearance:none;height:4px;border-radius:2px;outline:none;cursor:pointer;background:linear-gradient(to right,var(--red) 0%,var(--red) var(--pct,30%),var(--gray-200) var(--pct,30%))}
.calc-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--white);cursor:pointer;border:2px solid var(--red);box-shadow:0 2px 8px rgba(204,27,27,0.25)}
.calc-checks{display:flex;flex-direction:column;gap:8px}
.calc-check{display:flex;align-items:center;gap:12px;cursor:pointer;padding:10px 14px;background:var(--white);border:1px solid var(--border);border-radius:var(--radius);transition:all 0.2s}
.calc-check:hover{border-color:var(--red);background:var(--red-pale)}
.check-box{width:18px;height:18px;border-radius:4px;border:1.5px solid var(--gray-200);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all 0.2s;font-size:0.75rem;background:var(--white);color:var(--white)}
.calc-check:has(input:checked){border-color:var(--red)}
.calc-check:has(input:checked) .check-box{background:var(--red);border-color:var(--red);color:var(--white)}
.calc-check input{display:none}
.check-lbl{font-size:0.88rem;color:var(--gray-700);flex:1}
.check-extra{font-size:0.75rem;color:var(--gray-400)}
.result-heading{font-family:var(--font-head);font-size:1rem;font-weight:700;text-transform:uppercase;letter-spacing:0.06em;margin-bottom:22px;color:var(--gray-600)}
.result-hero{background:var(--red);border-radius:var(--radius-lg);padding:28px;text-align:center;margin-bottom:20px;position:relative;overflow:hidden}
.result-hero::after{content:'';position:absolute;top:-20px;right:-20px;width:100px;height:100px;border-radius:50%;background:rgba(255,255,255,0.07)}
.result-hero-label{font-size:0.7rem;color:rgba(255,255,255,0.75);text-transform:uppercase;letter-spacing:0.12em;margin-bottom:8px}
.result-hero-value{font-family:var(--font-head);font-size:3.2rem;font-weight:800;color:var(--white);line-height:1}
.result-hero-sub{font-size:0.8rem;color:rgba(255,255,255,0.75);margin-top:6px}
.result-rows{margin-bottom:18px}
.result-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border);font-size:0.88rem}
.result-row-lbl{color:var(--gray-500)}
.result-row-val{font-weight:600;color:var(--gray-800)}
.result-row-val.pos{color:var(--success)}
.result-row-val.neg{color:var(--red)}
.result-ltv{background:var(--success-bg);border:1px solid rgba(26,127,75,0.2);border-radius:var(--radius);padding:16px 20px;margin-bottom:18px}
.result-ltv-lbl{font-size:0.7rem;font-weight:700;color:var(--success);text-transform:uppercase;letter-spacing:0.1em;margin-bottom:4px}
.result-ltv-val{font-family:var(--font-head);font-size:1.8rem;font-weight:800;color:var(--success)}
.savings-bar-outer{margin-bottom:20px}
.savings-bar-lbl{font-size:0.75rem;color:var(--gray-400);margin-bottom:6px;text-transform:uppercase;letter-spacing:0.08em;display:flex;justify-content:space-between}
.savings-bar{height:8px;background:var(--gray-100);border-radius:4px;overflow:hidden}
.savings-bar-fill{height:100%;background:var(--red);border-radius:4px;transition:width 0.6s ease}
.result-note{font-size:0.72rem;color:var(--gray-400);text-align:center;margin-top:10px}

/* ============================================
   NOUVEAU CALCULATEUR WINGOU — MULTI-DOMAINES
   ============================================ */
#calculator { background: var(--gray-50); }

#calc-wrap { max-width: 900px; margin: 0 auto; }

/* Steps */
.calc-step { display: none; }
.calc-step.active-step { display: block; animation: fadeUp 0.35s ease both; }

.calc-step-header {
  display: flex; align-items: flex-start; gap: 18px;
  margin-bottom: 36px; padding-bottom: 24px;
  border-bottom: 2px solid var(--border);
}
.calc-step-num {
  width: 44px; height: 44px; border-radius: 50%;
  background: var(--red); color: var(--white);
  font-family: var(--font-head); font-size: 1.3rem; font-weight: 800;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.calc-step-title {
  font-family: var(--font-head); font-size: 1.4rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.03em; color: var(--gray-800);
}
.calc-step-sub { font-size: 0.88rem; color: var(--gray-400); margin-top: 4px; }

/* Domain grid */
.domain-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px;
  margin-bottom: 32px;
}
.domain-card {
  position: relative; cursor: pointer;
  background: var(--white); border: 2px solid var(--border);
  border-radius: var(--radius-lg); padding: 22px 16px 18px;
  text-align: center; transition: all 0.2s;
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  user-select: none;
}
.domain-card input { position: absolute; opacity: 0; width: 0; height: 0; }
.domain-card:hover { border-color: var(--red); box-shadow: 0 0 0 3px var(--red-tint2); }
.domain-card.selected {
  border-color: var(--red); background: var(--red-pale);
  box-shadow: 0 0 0 3px var(--red-tint2);
}
.domain-icon { font-size: 2rem; line-height: 1; }
.domain-name { font-family: var(--font-head); font-size: 0.92rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.04em; color: var(--gray-800); }
.domain-desc { font-size: 0.75rem; color: var(--gray-400); }
.domain-check {
  position: absolute; top: 10px; right: 10px;
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--red); color: var(--white);
  font-size: 0.7rem; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transform: scale(0.5); transition: all 0.2s;
}
.domain-card.selected .domain-check { opacity: 1; transform: scale(1); }

/* Step footer */
.calc-step-footer {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 24px; border-top: 1px solid var(--border);
  gap: 16px; flex-wrap: wrap;
}
.calc-domains-selected { font-size: 0.85rem; color: var(--gray-500); font-style: italic; }
.calc-btn-next {
  background: var(--red); color: var(--white);
  border: none; padding: 13px 28px; border-radius: var(--radius);
  font-weight: 700; font-size: 0.9rem; cursor: pointer;
  font-family: var(--font-body); text-transform: uppercase; letter-spacing: 0.06em;
  transition: all 0.2s;
}
.calc-btn-next:hover:not(:disabled) { background: var(--red-dark); transform: translateY(-1px); box-shadow: 0 6px 20px rgba(204,27,27,0.3); }
.calc-btn-next:disabled { background: var(--gray-200); cursor: not-allowed; }
.calc-btn-back {
  background: transparent; color: var(--gray-600);
  border: 1.5px solid var(--border); padding: 12px 22px;
  border-radius: var(--radius); font-weight: 600; font-size: 0.88rem;
  cursor: pointer; font-family: var(--font-body); transition: all 0.2s;
}
.calc-btn-back:hover { border-color: var(--gray-400); color: var(--gray-800); }
.calc-btn-send {
  background: var(--success); color: var(--white);
  border: none; padding: 13px 28px; border-radius: var(--radius);
  font-weight: 700; font-size: 0.9rem; cursor: pointer;
  font-family: var(--font-body); text-transform: uppercase; letter-spacing: 0.06em;
  transition: all 0.2s;
}
.calc-btn-send:hover { background: #155d38; transform: translateY(-1px); box-shadow: 0 6px 20px rgba(26,127,75,0.3); }

/* Domain forms */
.domain-form {
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--radius-lg); margin-bottom: 18px;
  overflow: hidden;
}
.domain-form-header {
  display: flex; align-items: center; gap: 14px;
  padding: 18px 24px; background: var(--gray-50);
  border-bottom: 1px solid var(--border);
  cursor: pointer;
}
.domain-form-icon { font-size: 1.4rem; }
.domain-form-title { font-family: var(--font-head); font-size: 1rem; font-weight: 700; text-transform: uppercase; color: var(--gray-800); }
.domain-form-toggle { margin-left: auto; font-size: 0.8rem; color: var(--gray-400); transition: transform 0.2s; }
.domain-form.open .domain-form-toggle { transform: rotate(180deg); }
.domain-form-body { padding: 24px; display: none; }
.domain-form.open .domain-form-body { display: block; }

/* Form fields inside domain */
.dfield-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 14px; }
.dfield-row-3 { grid-template-columns: 1fr 1fr 1fr; }
.dfield-row-1 { grid-template-columns: 1fr; }
.dfield { display: flex; flex-direction: column; gap: 6px; }
.dfield label { font-size: 0.75rem; font-weight: 600; color: var(--gray-600); text-transform: uppercase; letter-spacing: 0.07em; }
.dfield input, .dfield select {
  background: var(--gray-50); border: 1.5px solid var(--border);
  border-radius: var(--radius); padding: 10px 14px;
  font-family: var(--font-body); font-size: 0.9rem; color: var(--gray-800);
  outline: none; transition: border-color 0.2s;
}
.dfield input:focus, .dfield select:focus { border-color: var(--red); background: var(--red-pale); }
.dfield input::placeholder { color: var(--gray-400); }
.dfield-optional { font-size: 0.7rem; color: var(--gray-400); font-style: italic; margin-top: 2px; }

/* Maintenance toggle */
.maint-toggle {
  display: flex; align-items: center; gap: 10px;
  margin-top: 10px; cursor: pointer;
}
.maint-toggle input { cursor: pointer; width: 16px; height: 16px; accent-color: var(--red); }
.maint-toggle span { font-size: 0.83rem; color: var(--gray-600); font-weight: 500; }
.maint-block { margin-top: 14px; padding: 14px; background: var(--gray-50); border-radius: var(--radius); border: 1px solid var(--border); }

/* RESULTS */
.result-global {
  background: #A83232; border-radius: var(--radius-xl);
  padding: 36px 40px; margin-bottom: 28px;
  display: flex; align-items: center; gap: 48px;
  position: relative; overflow: hidden;
}
.result-global::before {
  content: ''; position: absolute; top: -40px; right: -40px;
  width: 180px; height: 180px; border-radius: 50%;
  background: rgba(255,255,255,0.06);
}
.result-global-left { flex: 1; }
.result-global-label { font-size: 0.72rem; color: rgba(255,255,255,0.7); text-transform: uppercase; letter-spacing: 0.12em; margin-bottom: 8px; }
.result-global-pct { font-family: var(--font-head); font-size: 5rem; font-weight: 800; color: var(--white); line-height: 1; }
.result-global-sub { font-size: 0.85rem; color: rgba(255,255,255,0.7); margin-top: 8px; }
.result-global-right { display: flex; align-items: center; gap: 24px; flex-shrink: 0; }
.result-stat { text-align: center; }
.result-stat-val { font-family: var(--font-head); font-size: 1.8rem; font-weight: 800; color: var(--white); }
.result-stat-val.green { color: #86efac; }
.result-stat-lbl { font-size: 0.72rem; color: rgba(255,255,255,0.65); text-transform: uppercase; letter-spacing: 0.08em; margin-top: 4px; }
.result-stat-arrow { font-size: 1.5rem; color: rgba(255,255,255,0.5); }

/* Domain result cards */
#res-domains { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 24px; }
.res-domain-card {
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 20px 22px;
  display: flex; align-items: center; gap: 16px;
}
.res-domain-icon { font-size: 1.6rem; flex-shrink: 0; }
.res-domain-info { flex: 1; }
.res-domain-name { font-family: var(--font-head); font-size: 0.9rem; font-weight: 700; text-transform: uppercase; color: var(--gray-800); margin-bottom: 4px; }
.res-domain-detail { font-size: 0.8rem; color: var(--gray-500); }
.res-domain-pct {
  font-family: var(--font-head); font-size: 2rem; font-weight: 800;
  color: var(--red); flex-shrink: 0;
}
.res-domain-nodata { font-size: 0.78rem; color: var(--gray-400); font-style: italic; }
.res-domain-pct.neutral { color: var(--gray-400); }
.res-domain-badge {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 0.72rem; font-weight: 600; border-radius: 100px;
  padding: 3px 10px; margin-top: 5px;
}
.res-domain-badge.info { background: #EFF6FF; color: #1D4ED8; }
.res-domain-badge.warn { background: #FFF7ED; color: #C2410C; }
.domain-special-note {
  background: #EFF6FF; border: 1px solid #BFDBFE;
  border-radius: var(--radius); padding: 10px 14px;
  font-size: 0.82rem; color: #1E40AF; margin-bottom: 16px;
  line-height: 1.5;
}

/* Mobile mode toggle */
.mobile-operateur-row { margin-bottom: 14px; }
.mobile-mode-toggle {
  display: flex; gap: 8px; margin-bottom: 20px;
  border-bottom: 2px solid var(--border); padding-bottom: 16px;
}
.mobile-mode-btn {
  flex: 1; padding: 10px 16px; border-radius: var(--radius);
  border: 1.5px solid var(--border); background: var(--white);
  font-family: var(--font-body); font-size: 0.83rem; font-weight: 600;
  cursor: pointer; color: var(--gray-600); transition: all 0.2s;
}
.mobile-mode-btn.active { background: var(--red); border-color: var(--red); color: var(--white); }
.mobile-mode-btn:hover:not(.active) { border-color: var(--red); color: var(--red); }
.mobile-detail-hint { font-size: 0.8rem; color: var(--gray-400); margin-bottom: 10px; font-style: italic; }
.mobile-detail-header {
  display: grid; grid-template-columns: 2fr 1fr 1.5fr 32px;
  gap: 8px; margin-bottom: 8px;
  font-size: 0.72rem; font-weight: 700; color: var(--gray-400);
  text-transform: uppercase; letter-spacing: 0.08em;
}
.mobile-detail-line {
  display: grid; grid-template-columns: 2fr 1fr 1.5fr 32px;
  gap: 8px; margin-bottom: 8px; align-items: center;
}
.mobile-detail-line select, .mobile-detail-line input {
  background: var(--gray-50); border: 1.5px solid var(--border);
  border-radius: var(--radius); padding: 9px 10px;
  font-family: var(--font-body); font-size: 0.88rem; color: var(--gray-800);
  outline: none; transition: border-color 0.2s; width: 100%;
}
.mobile-detail-line select:focus, .mobile-detail-line input:focus { border-color: var(--red); background: var(--red-pale); }
.mobile-line-remove {
  width: 28px; height: 28px; border-radius: 50%;
  border: 1px solid var(--border); background: var(--white);
  color: var(--gray-400); cursor: pointer; font-size: 0.75rem;
  display: flex; align-items: center; justify-content: center; transition: all 0.15s;
}
.mobile-line-remove:hover { background: var(--red-pale); border-color: var(--red); color: var(--red); }
.mobile-add-line {
  background: transparent; border: 1.5px dashed var(--border);
  border-radius: var(--radius); padding: 9px 18px;
  font-family: var(--font-body); font-size: 0.83rem;
  color: var(--gray-500); cursor: pointer; margin-top: 4px;
  transition: all 0.2s; width: 100%;
}
.mobile-add-line:hover { border-color: var(--red); color: var(--red); }
@media(max-width:480px) {
  .mobile-detail-header, .mobile-detail-line { grid-template-columns: 1.5fr 0.7fr 1fr 28px; }
}

/* Cumulative */
.result-cumul {
  background: var(--success-bg); border: 1px solid rgba(26,127,75,0.2);
  border-radius: var(--radius-lg); padding: 24px 28px; margin-bottom: 24px;
}
.result-cumul-title { font-family: var(--font-head); font-size: 0.85rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--success); margin-bottom: 18px; }
.result-cumul-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 0; }
.result-cumul-item { text-align: center; padding: 0 20px; border-right: 1px solid rgba(26,127,75,0.15); }
.result-cumul-item:last-child { border-right: none; }
.result-cumul-val { font-family: var(--font-head); font-size: 2rem; font-weight: 800; color: var(--success); }
.result-cumul-item.highlight .result-cumul-val { font-size: 2.6rem; color: var(--success); }
.result-cumul-lbl { font-size: 0.75rem; color: var(--gray-500); text-transform: uppercase; letter-spacing: 0.08em; margin-top: 4px; }

.result-disclaimer {
  background: #FFF8E1; border: 1px solid #F9A825;
  border-radius: var(--radius); padding: 14px 18px;
  font-size: 0.8rem; color: #7B5800; margin-bottom: 24px;
}

/* Engagement 36 vs 60 mois */
.result-engagement {
  margin-bottom: 24px;
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--radius-lg); overflow: hidden;
}
.result-engagement-title {
  font-family: var(--font-head); font-size: 0.95rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.05em;
  padding: 16px 24px; background: var(--gray-50);
  border-bottom: 1px solid var(--border); color: var(--gray-800);
}
.result-engagement-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; }
.result-engagement-col {
  padding: 24px 20px; text-align: center;
  border-right: 1px solid var(--border);
}
.result-engagement-col:last-child { border-right: none; }
.result-engagement-col.wingou36 { background: #F0FDF4; }
.result-engagement-col.wingou60 { background: var(--success-bg); }
.result-engagement-badge {
  display: inline-block; font-size: 0.68rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.1em;
  padding: 3px 10px; border-radius: 100px; margin-bottom: 12px;
  background: var(--gray-100); color: var(--gray-600);
}
.result-engagement-col.wingou36 .result-engagement-badge { background: #BBF7D0; color: #15803D; }
.result-engagement-col.wingou60 .result-engagement-badge { background: var(--success); color: var(--white); }
.result-engagement-price {
  font-family: var(--font-head); font-size: 2.2rem; font-weight: 800; line-height: 1;
}
.result-engagement-col.current .result-engagement-price { color: var(--red); }
.result-engagement-col.wingou36 .result-engagement-price { color: #15803D; }
.result-engagement-col.wingou60 .result-engagement-price { color: var(--success); }
.result-engagement-sub { font-size: 0.72rem; color: var(--gray-400); margin: 4px 0 10px; }
.result-engagement-eco {
  font-size: 0.82rem; font-weight: 700; color: var(--success);
  background: #D1FAE5; border-radius: 100px; padding: 3px 12px;
  display: inline-block; margin-bottom: 12px;
}
.result-engagement-note { font-size: 0.75rem; color: var(--gray-500); line-height: 1.7; }
@media(max-width:600px) {
  .result-engagement-grid { grid-template-columns: 1fr; }
  .result-engagement-col { border-right: none; border-bottom: 1px solid var(--border); }
}
.result-actions {
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px; flex-wrap: wrap;
}

/* Responsive calculator */
@media(max-width:768px) {
  .domain-grid { grid-template-columns: 1fr 1fr; }
  .dfield-row { grid-template-columns: 1fr; }
  .dfield-row-3 { grid-template-columns: 1fr; }
  .result-global { flex-direction: column; padding: 28px 24px; gap: 24px; }
  .result-global-pct { font-size: 3.5rem; }
  #res-domains { grid-template-columns: 1fr; }
  .result-cumul-grid { grid-template-columns: 1fr; gap: 16px; }
  .result-cumul-item { border-right: none; border-bottom: 1px solid rgba(26,127,75,0.15); padding: 0 0 16px; }
  .result-cumul-item:last-child { border-bottom: none; }
}
@media(max-width:480px) {
  .domain-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
  .domain-card { padding: 16px 10px; }
  .domain-icon { font-size: 1.5rem; }
  .domain-name { font-size: 0.78rem; }
}

/* ── 10. SECTION PROCESS ────────────────────── */
#process{background:var(--gray-800)}
.process-header{text-align:center;margin-bottom:56px}
.process-header h2{color:var(--white)}
.process-header .label{color:rgba(255,255,255,0.5);margin-bottom:10px;display:block}
.process-header .red-line{width:48px;height:3px;background:var(--red);margin:16px auto 0;border-radius:2px}
.steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px;position:relative}
.steps-grid::before{content:'';position:absolute;top:36px;left:12%;right:12%;height:1px;background:rgba(255,255,255,0.12)}
.step-card{position:relative;z-index:1}
.step-num-wrap{width:72px;height:72px;border-radius:50%;border:2px solid var(--red);background:var(--gray-800);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;position:relative}
.step-num-wrap::before{content:'';position:absolute;inset:-4px;border-radius:50%;background:rgba(204,27,27,0.12)}
.step-num{font-family:var(--font-head);font-size:1.4rem;font-weight:800;color:var(--red)}
.step-title{font-family:var(--font-head);font-size:1rem;font-weight:700;color:var(--white);text-align:center;margin-bottom:10px;text-transform:uppercase;letter-spacing:0.05em}
.step-desc{font-size:0.82rem;color:rgba(255,255,255,0.5);text-align:center;line-height:1.65;font-weight:300}
.process-cta{text-align:center;margin-top:48px}
.process-note{font-size:0.78rem;color:rgba(255,255,255,0.35);margin-top:10px}

/* CONTACT */
#contact{background:var(--gray-50)}
.cta-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start}
.cta-left h2{margin-bottom:14px}
.cta-left p{color:var(--gray-500);font-size:0.98rem;line-height:1.75;margin-bottom:28px;font-weight:300}
.cta-guarantees{display:flex;flex-direction:column;gap:10px;margin-bottom:32px}
.guarantee{display:flex;align-items:center;gap:12px;font-size:0.9rem;color:var(--gray-600)}
.guarantee-check{width:22px;height:22px;border-radius:50%;background:var(--red);display:flex;align-items:center;justify-content:center;color:var(--white);font-size:0.7rem;font-weight:700;flex-shrink:0}
.contact-cards{display:flex;gap:12px;flex-wrap:wrap}
.contact-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:14px 18px;box-shadow:var(--shadow-sm)}
.cc-label{font-size:0.68rem;color:var(--gray-400);text-transform:uppercase;letter-spacing:0.1em;margin-bottom:4px}
.cc-value{font-weight:600;font-size:0.9rem;color:var(--gray-800)}
.cc-value a{color:var(--red);text-decoration:none}
.maca-badge{margin-top:20px;background:var(--red-tint);border:1px solid rgba(204,27,27,0.2);border-radius:var(--radius);padding:14px 18px;display:flex;align-items:center;gap:12px}
.maca-icon{font-size:1.5rem}
.maca-text-title{font-size:0.82rem;font-weight:700;color:var(--red)}
.maca-text-sub{font-size:0.78rem;color:var(--gray-500)}
.form-box{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-xl);padding:36px;box-shadow:var(--shadow-lg);border-top:4px solid var(--red)}
.form-title{font-family:var(--font-head);font-size:1.4rem;font-weight:700;text-transform:uppercase;letter-spacing:0.04em;color:var(--gray-800);margin-bottom:24px}
.form-group{margin-bottom:14px}
.form-label{font-size:0.78rem;font-weight:600;color:var(--gray-600);margin-bottom:7px;display:block;text-transform:uppercase;letter-spacing:0.06em}
.form-input{width:100%;background:var(--gray-50);border:1px solid var(--border);border-radius:var(--radius);padding:11px 16px;color:var(--gray-800);font-family:var(--font-body);font-size:0.9rem;transition:border-color 0.2s;outline:none}
.form-input:focus{border-color:var(--red);background:var(--red-pale)}
.form-input::placeholder{color:var(--gray-300)}
.form-2col{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-select{width:100%;background:var(--gray-50);border:1px solid var(--border);border-radius:var(--radius);padding:11px 16px;color:var(--gray-800);font-family:var(--font-body);font-size:0.9rem;transition:all 0.2s;outline:none;cursor:pointer;-webkit-appearance:none;appearance:none}
.form-select:focus{border-color:var(--red)}
.form-select option{background:var(--white)}
.form-submit{width:100%;background:var(--red);color:var(--white);padding:15px;border:none;border-radius:var(--radius);font-weight:700;font-size:0.92rem;cursor:pointer;transition:all 0.2s;font-family:var(--font-body);margin-top:6px;text-transform:uppercase;letter-spacing:0.06em}
.form-submit:hover{background:var(--red-dark);transform:translateY(-1px);box-shadow:0 6px 24px rgba(204,27,27,0.3)}
.form-disclaimer{font-size:0.7rem;color:var(--gray-400);text-align:center;margin-top:10px}

/* ── 11. FOOTER ─────────────────────────────── */
footer{background:var(--gray-800);padding:64px 0 32px}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer-logo-wrap{margin-bottom:16px;border:none!important;outline:none;line-height:0;background:#1a1a1a}
.footer-logo-wrap img{height:44px;width:auto;display:block;border:none;outline:none;box-shadow:none}
.footer-brand-desc{font-size:0.83rem;color:rgba(255,255,255,0.35);line-height:1.7;margin-bottom:16px;font-weight:300}
.footer-col-title{font-family:var(--font-head);font-weight:700;font-size:0.82rem;color:rgba(255,255,255,0.7);margin-bottom:16px;text-transform:uppercase;letter-spacing:0.1em}
.footer-links{display:flex;flex-direction:column;gap:8px}
.footer-links a{color:rgba(255,255,255,0.35);text-decoration:none;font-size:0.83rem;transition:color 0.2s}
.footer-links a:hover{color:rgba(255,255,255,0.7)}
.footer-contact-line{font-size:0.83rem;color:rgba(255,255,255,0.35);margin-bottom:6px}
.footer-social{display:flex;gap:10px}
.footer-social-link{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,0.06);color:rgba(255,255,255,0.6);text-decoration:none;transition:background 0.2s,color 0.2s,transform 0.2s}
.footer-social-link:hover{background:var(--red,#e2231a);color:#fff;transform:translateY(-2px)}
.footer-contact-line a{color:var(--red);text-decoration:none}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.08);padding-top:24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.footer-copy{font-size:0.78rem;color:rgba(255,255,255,0.25)}
.footer-legal{display:flex;gap:20px}
.footer-legal a{font-size:0.78rem;color:rgba(255,255,255,0.25);text-decoration:none;transition:color 0.2s}
.footer-legal a:hover{color:rgba(255,255,255,0.5)}

/* ── 13. RESPONSIVE ─────────────────────────── */
@media(max-width:900px){.nav-links,.nav-cta{display:none}.hamburger{display:flex}h1{font-size:2.2rem}h2{font-size:1.8rem}}
@media(max-width:768px){
  section{padding:64px 0}
  .hero-bg-shape,.hero-bg-pattern{display:none}
  .hero-content{grid-template-columns:1fr;gap:40px}
  .hero-right{display:none}
  .hero-stats{flex-direction:row;flex-wrap:wrap;gap:20px}
  .hero-stat{border-right:none;margin-right:0;flex:none;min-width:120px}
  .promise-grid{grid-template-columns:1fr;gap:40px}
  .modules-grid{grid-template-columns:1fr 1fr}
  .wingou-cta-band{flex-direction:column;padding:32px 24px;text-align:center}
  .sector-panel.active{grid-template-columns:1fr}
  .calc-top{flex-direction:column;align-items:flex-start;padding:28px 24px}
  .calc-body{grid-template-columns:1fr}
  .calc-left{border-right:none;border-bottom:1px solid var(--border);padding:28px 24px}
  .calc-right{padding:28px 24px}
  .steps-grid{grid-template-columns:1fr 1fr}
  .steps-grid::before{display:none}
  .cta-grid{grid-template-columns:1fr;gap:40px}
  .footer-top{grid-template-columns:1fr 1fr;gap:32px}
  .footer-top>div:first-child{grid-column:1/-1}
  .footer-bottom{flex-direction:column;text-align:center}
  .footer-legal{justify-content:center}
}
@media(max-width:480px){
  .modules-grid{grid-template-columns:1fr}
  .steps-grid{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr}
  .form-2col{grid-template-columns:1fr}
  .hero-actions{flex-direction:column}
  .hero-actions .btn-primary,.hero-actions .btn-outline{width:100%;justify-content:center}
}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}


/* ── 12. CHATBOT ────────────────────────────── */
/* pointer-events:none : le conteneur est grand (la fenêtre chat fait ~100vw sur mobile)
   mais doit laisser passer les taps vers la page. Les enfants le ré-activent au besoin. */
#chat-bubble{position:fixed;bottom:28px;right:28px;z-index:9999;display:flex;flex-direction:column;align-items:flex-end;gap:10px;pointer-events:none}
#chat-toggle{width:60px;height:60px;border-radius:50%;background:var(--red);border:none;cursor:pointer;box-shadow:0 4px 20px rgba(204,27,27,0.45);display:flex;align-items:center;justify-content:center;transition:all 0.25s;position:relative;pointer-events:auto}
#chat-toggle:hover{background:var(--red-dark);transform:scale(1.07)}
#chat-toggle svg{width:26px;height:26px;fill:white;transition:all 0.25s}
#chat-toggle .close-icon{display:none}
#chat-toggle.open .chat-icon{display:none}
#chat-toggle.open .close-icon{display:block}
.chat-notif-badge{position:absolute;top:-4px;right:-4px;width:18px;height:18px;border-radius:50%;background:#E8443A;border:2px solid white;font-size:0.6rem;font-weight:700;color:white;display:flex;align-items:center;justify-content:center}

#chat-window{width:380px;max-height:560px;background:white;border-radius:16px;box-shadow:0 12px 60px rgba(0,0,0,0.18);display:flex;flex-direction:column;overflow:hidden;transform:scale(0.85) translateY(20px);opacity:0;pointer-events:none;transition:all 0.25s cubic-bezier(0.175,0.885,0.32,1.275);transform-origin:bottom right}
#chat-window.open{transform:scale(1) translateY(0);opacity:1;pointer-events:all} /* rétablit l'interactivité complète de la fenêtre quand elle est ouverte */

.chat-header{background:var(--red);padding:18px 20px;display:flex;align-items:center;gap:12px;flex-shrink:0}
.chat-avatar{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,0.2);display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}
.chat-header-info{flex:1}
.chat-header-name{font-family:var(--font-head);font-weight:700;color:white;font-size:1rem;text-transform:uppercase;letter-spacing:0.04em}
.chat-header-status{font-size:0.72rem;color:rgba(255,255,255,0.75);display:flex;align-items:center;gap:5px}
.status-dot{width:7px;height:7px;border-radius:50%;background:#4ade80;display:inline-block;animation:pulse-green 2s infinite}
@keyframes pulse-green{0%,100%{opacity:1}50%{opacity:0.5}}
.chat-header-close{background:none;border:none;color:rgba(255,255,255,0.7);cursor:pointer;font-size:1.1rem;padding:4px;border-radius:4px;transition:color 0.15s}
.chat-header-close:hover{color:white}

.chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px;min-height:200px;max-height:360px;background:#FAFAFA}
.chat-messages::-webkit-scrollbar{width:4px}
.chat-messages::-webkit-scrollbar-thumb{background:var(--gray-200);border-radius:4px}

.msg{display:flex;gap:8px;align-items:flex-end;max-width:88%}
.msg.bot{align-self:flex-start}
.msg.user{align-self:flex-end;flex-direction:row-reverse}
.msg-avatar{width:28px;height:28px;border-radius:50%;background:var(--red);display:flex;align-items:center;justify-content:center;font-size:0.75rem;flex-shrink:0;color:white;font-weight:700}
.msg-bubble{padding:10px 14px;border-radius:14px;font-size:0.84rem;line-height:1.55;max-width:100%}
.msg.bot .msg-bubble{background:white;border:1px solid var(--border);color:var(--gray-800);border-bottom-left-radius:4px;box-shadow:0 1px 4px rgba(0,0,0,0.06)}
.msg.user .msg-bubble{background:var(--red);color:white;border-bottom-right-radius:4px}
.msg-bubble ul{margin-top:6px;padding-left:16px;display:flex;flex-direction:column;gap:3px}
.msg-bubble li{font-size:0.82rem}
.msg-bubble a{color:var(--red);text-decoration:underline}
.msg.user .msg-bubble a{color:rgba(255,255,255,0.9)}

.chat-typing{display:flex;gap:4px;align-items:center;padding:8px 12px;background:white;border:1px solid var(--border);border-radius:12px;border-bottom-left-radius:4px;width:fit-content;box-shadow:0 1px 4px rgba(0,0,0,0.06)}
.typing-dot{width:7px;height:7px;border-radius:50%;background:var(--gray-400);animation:bounce 1.2s infinite}
.typing-dot:nth-child(2){animation-delay:0.2s}
.typing-dot:nth-child(3){animation-delay:0.4s}
@keyframes bounce{0%,80%,100%{transform:translateY(0)}40%{transform:translateY(-7px)}}

.chat-suggestions{padding:10px 14px 0;display:flex;flex-wrap:wrap;gap:6px;flex-shrink:0;background:#FAFAFA}
.sug-btn{background:white;border:1px solid var(--border);border-radius:20px;padding:6px 12px;font-size:0.75rem;color:var(--red);cursor:pointer;transition:all 0.15s;font-family:var(--font-body);font-weight:600;white-space:nowrap}
.sug-btn:hover{background:var(--red-pale);border-color:var(--red)}

.chat-input-area{padding:12px 14px;border-top:1px solid var(--border);display:flex;gap:8px;align-items:center;background:white;flex-shrink:0}
#chat-input{flex:1;border:1.5px solid var(--border);border-radius:24px;padding:9px 16px;font-size:0.84rem;font-family:var(--font-body);outline:none;transition:border-color 0.2s;color:var(--gray-800);background:var(--gray-50)}
#chat-input:focus{border-color:var(--red);background:white}
#chat-send{width:38px;height:38px;border-radius:50%;background:var(--red);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all 0.2s}
#chat-send:hover{background:var(--red-dark);transform:scale(1.05)}
#chat-send:disabled{background:var(--gray-200);cursor:not-allowed;transform:none}
#chat-send svg{width:16px;height:16px;fill:white}

@media(max-width:480px){
  #chat-window{width:calc(100vw - 32px);max-height:80vh}
  #chat-bubble{bottom:16px;right:16px}
}



/* ================================================
   WINGOU v6.0 — PHASE 1 & PHASE 2 AJOUTS
   ================================================ */

/* Skip link (accessibilité) */
.skip-link {
  position: absolute;
  top: -40px;
  left: 0;
  background: var(--red);
  color: var(--white);
  padding: 8px 16px;
  text-decoration: none;
  border-radius: 0 0 var(--radius) 0;
  z-index: 10000;
  font-weight: 700;
  font-size: 0.88rem;
  transition: top 0.2s;
}
.skip-link:focus {
  top: 0;
  outline: 2px solid var(--white);
  outline-offset: 2px;
}

/* Screen reader only utility */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}

/* Focus visible global */
:focus-visible {
  outline: 2px solid var(--red);
  outline-offset: 2px;
  border-radius: 2px;
}
:focus:not(:focus-visible) {
  outline: none;
}

/* Validation errors */
.field-error {
  display: none;
  font-size: 0.75rem;
  color: #DC2626;
  margin-top: 4px;
  font-weight: 500;
  padding: 2px 4px;
}
.field-error.show {
  display: block;
}
.calc-input-invalid {
  border-color: #DC2626 !important;
  background: #FEF2F2 !important;
}
.calc-input-valid {
  border-color: var(--success) !important;
}
.calc-hint {
  font-size: 0.72rem;
  font-weight: 400;
  color: var(--gray-400);
  text-transform: none;
  letter-spacing: 0;
  margin-left: 4px;
}

/* Email field for results */
.calc-email-section {
  background: var(--gray-50);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 24px;
  margin-top: 24px;
}
.calc-email-section label {
  display: block;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--gray-600);
  margin-bottom: 8px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.calc-email-input {
  width: 100%;
  padding: 10px 14px;
  border: 1.5px solid var(--border);
  border-radius: var(--radius);
  font-size: 0.9rem;
  font-family: var(--font-body);
  transition: border-color 0.2s;
  background: var(--white);
}
.calc-email-input:focus {
  border-color: var(--red);
  outline: none;
}
.calc-disclaimer {
  font-size: 0.72rem;
  color: var(--gray-400);
  margin-top: 8px;
}

/* Toast notifications */
.toast-notification {
  position: fixed;
  bottom: 80px;
  right: 24px;
  background: var(--gray-800);
  color: var(--white);
  padding: 12px 20px;
  border-radius: var(--radius);
  font-size: 0.88rem;
  font-weight: 500;
  z-index: 9998;
  box-shadow: var(--shadow-lg);
  animation: toastIn 0.3s ease;
  max-width: 320px;
}
.toast-notification.success {
  background: var(--success);
}
.toast-notification.error {
  background: #DC2626;
}
@keyframes toastIn {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Form aria messages */
#form-messages[role="alert"] {
  padding: 10px 14px;
  border-radius: var(--radius);
  margin-top: 8px;
  font-size: 0.85rem;
  font-weight: 500;
}

/* Sector tabs keyboard focus */
.sector-tab:focus-visible {
  outline: 2px solid var(--red);
  outline-offset: 2px;
}

/* Check-hint for accessible checkboxes */
.check-hint {
  display: block;
  font-size: 0.72rem;
  color: var(--gray-400);
  margin-top: 3px;
  font-weight: 400;
}

/* Domain card focus */
.domain-card:focus-within {
  outline: 2px solid var(--red);
  outline-offset: 2px;
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

/* High contrast improvements */
@media (forced-colors: active) {
  .btn-primary, .btn-outline, .calc-btn-next {
    border: 2px solid ButtonText;
  }
}

/* Site standalone — navbar et footer actifs */

/* ================================================
   WINGOU v6.0 — PHASE 3 & PHASE 4 AJOUTS
   Performance, UX améliorée, Animations
   ================================================ */

/* ─── PHASE 3 : CSS structuré ──────────────── */

/* Transitions boutons unifiées (var CSS) */
button,
a[href],
.btn-primary,
.btn-outline,
.btn-white,
.btn-outline-white,
.nav-cta {
  transition: all var(--transition-base);
}

/* Hover lift unifié pour les cards */
.mod-card,
.sector-card,
.step-card,
.pain-item {
  transition: transform var(--transition-base),
              box-shadow var(--transition-base),
              border-color var(--transition-base);
}

/* Progress bar calculateur */
.calc-progress-bar {
  height: 4px;
  background: var(--gray-100);
  border-radius: 2px;
  overflow: hidden;
  margin-bottom: 32px;
}
.calc-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--red-dark), var(--red-light));
  border-radius: 2px;
  transition: width 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  min-width: 4px;
}

/* ─── PHASE 4.1 : Animations scroll ─────────── */

@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes fadeInLeft {
  from { opacity: 0; transform: translateX(-20px); }
  to   { opacity: 1; transform: translateX(0); }
}

@keyframes scaleIn {
  from { opacity: 0; transform: scale(0.95); }
  to   { opacity: 1; transform: scale(1); }
}

/* État initial : éléments cachés avant animation */
.anim-hidden {
  opacity: 0;
  transform: translateY(20px);
}

/* État visible après intersection */
.anim-visible {
  animation: fadeInUp 0.55s ease-out forwards;
}

/* Stagger automatique via nth-child sur les grilles */
.modules-grid .mod-card.anim-visible:nth-child(1) { animation-delay: 0ms; }
.modules-grid .mod-card.anim-visible:nth-child(2) { animation-delay: 60ms; }
.modules-grid .mod-card.anim-visible:nth-child(3) { animation-delay: 120ms; }
.modules-grid .mod-card.anim-visible:nth-child(4) { animation-delay: 180ms; }

.sector-panel.active .sector-card.anim-visible:nth-child(1) { animation-delay: 0ms; }
.sector-panel.active .sector-card.anim-visible:nth-child(2) { animation-delay: 70ms; }
.sector-panel.active .sector-card.anim-visible:nth-child(3) { animation-delay: 140ms; }

/* Section headers */
.section-header.anim-visible {
  animation: fadeInUp 0.7s ease-out forwards;
}

/* Micro-interactions boutons */
.btn-primary:hover:not(:disabled),
.btn-white:hover {
  transform: translateY(-2px);
}
.btn-primary:active,
.btn-white:active {
  transform: translateY(0);
}

/* Card hover lift */
.mod-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
}
.sector-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
}

/* Pain item hover */
.pain-item {
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}
.pain-item:hover {
  transform: translateX(4px);
  box-shadow: var(--shadow-sm);
}

/* ─── PHASE 4.2 : UX Calculateur améliorée ── */

/* Progress steps visuels */
.calc-step-progress {
  display: flex;
  align-items: center;
  gap: 0;
  margin-bottom: 32px;
  padding: 0 4px;
}
.calc-step-dot {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--gray-100);
  color: var(--gray-400);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.82rem;
  font-weight: 700;
  font-family: var(--font-head);
  flex-shrink: 0;
  transition: all var(--transition-base);
  position: relative;
  z-index: 1;
}
.calc-step-dot.active {
  background: var(--red);
  color: var(--white);
  box-shadow: 0 0 0 4px var(--red-tint);
}
.calc-step-dot.done {
  background: var(--success);
  color: var(--white);
}
.calc-step-line {
  flex: 1;
  height: 2px;
  background: var(--gray-100);
  transition: background 0.4s;
}
.calc-step-line.done {
  background: var(--success);
}

/* Tooltips sur les champs complexes */
.tooltip-wrap {
  position: relative;
  display: inline-block;
}
.tooltip-trigger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--gray-100);
  color: var(--gray-600);
  border: none;
  cursor: help;
  font-size: 0.72rem;
  font-weight: 700;
  margin-left: 6px;
  vertical-align: middle;
  transition: all var(--transition-fast);
}
.tooltip-trigger:hover,
.tooltip-trigger:focus {
  background: var(--red);
  color: var(--white);
  outline: none;
}
.tooltip-content {
  display: none;
  position: absolute;
  bottom: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%);
  background: var(--gray-800);
  color: var(--white);
  padding: 10px 14px;
  border-radius: var(--radius);
  font-size: 0.8rem;
  line-height: 1.5;
  width: max-content;
  max-width: 260px;
  white-space: normal;
  text-align: left;
  z-index: 200;
  box-shadow: var(--shadow-md);
  pointer-events: none;
  font-family: var(--font-body);
}
.tooltip-content::after {
  content: '';
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  border: 5px solid transparent;
  border-top-color: var(--gray-800);
}
.tooltip-trigger:hover + .tooltip-content,
.tooltip-trigger:focus + .tooltip-content,
.tooltip-wrap.tip-open .tooltip-content {
  display: block;
}

/* ── Bandeau promo Win for Life ───────────────────────────── */
.winlife-banner {
  background: linear-gradient(120deg, #b3122a 0%, #7a0d1d 100%);
  color: #fff;
  border-radius: var(--radius-lg, 16px);
  padding: 22px 28px;
  display: flex;
  align-items: center;
  gap: 24px;
  flex-wrap: wrap;
  box-shadow: var(--shadow-md, 0 12px 32px rgba(0,0,0,.18));
  position: relative;
  overflow: hidden;
}
.winlife-banner::before {
  content: '🎟️';
  position: absolute;
  right: -8px;
  bottom: -18px;
  font-size: 6rem;
  opacity: 0.1;
  transform: rotate(-12deg);
  pointer-events: none;
}
.winlife-logo {
  flex: 0 0 auto;
  background: #fff;
  border-radius: 10px;
  padding: 10px 14px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.winlife-logo img { height: 40px; width: auto; display: block; }
.winlife-body { flex: 1 1 320px; min-width: 260px; position: relative; z-index: 1; }
.winlife-kicker {
  display: inline-block;
  background: #ffd54a;
  color: #5a0a16;
  font-weight: 800;
  font-size: 0.68rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 3px 10px;
  border-radius: 999px;
  margin-bottom: 8px;
}
.winlife-body h3 {
  color: #fff;
  font-size: 1.2rem;
  line-height: 1.25;
  margin: 0 0 6px;
}
.winlife-body h3 .gold { color: #ffd54a; }
.winlife-body p { color: rgba(255,255,255,0.9); margin: 0; font-size: 0.9rem; line-height: 1.5; }
.winlife-cta {
  flex: 0 0 auto;
  position: relative;
  z-index: 1;
}
.winlife-cta .btn-winlife {
  display: inline-block;
  background: #ffd54a;
  color: #5a0a16;
  font-weight: 800;
  font-size: 0.92rem;
  padding: 13px 22px;
  border-radius: 999px;
  text-decoration: none;
  white-space: nowrap;
  transition: transform var(--transition-fast, .15s ease), box-shadow var(--transition-fast, .15s ease);
  box-shadow: 0 6px 16px rgba(0,0,0,.18);
}
.winlife-cta .btn-winlife:hover { transform: translateY(-2px); box-shadow: 0 10px 22px rgba(0,0,0,.26); }
@media (max-width: 720px) {
  .winlife-banner { padding: 20px 18px; gap: 16px; }
  .winlife-body h3 { font-size: 1.1rem; }
  .winlife-cta { width: 100%; }
  .winlife-cta .btn-winlife { display: block; text-align: center; }
}

/* Version compacte sous les résultats du calculateur */
.winlife-mini {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-top: 18px;
  padding: 14px 18px;
  background: linear-gradient(120deg, #b3122a 0%, #7a0d1d 100%);
  border-radius: var(--radius, 12px);
  color: #fff;
  text-decoration: none;
  box-shadow: var(--shadow-md, 0 10px 30px rgba(0,0,0,.15));
  transition: transform var(--transition-fast, .15s ease);
}
.winlife-mini:hover { transform: translateY(-2px); }
.winlife-mini img {
  flex: 0 0 auto;
  height: 34px;
  width: auto;
  background: #fff;
  border-radius: 6px;
  padding: 5px 8px;
}
.winlife-mini span { font-size: 0.9rem; line-height: 1.4; color: rgba(255,255,255,0.95); }
.winlife-mini span strong { color: #ffd54a; }
.winlife-mini-arrow {
  margin-left: auto;
  flex: 0 0 auto;
  font-weight: 800;
  font-size: 1.2rem;
  color: #ffd54a;
}
@media (max-width: 560px) {
  .winlife-mini { flex-wrap: wrap; }
  .winlife-mini-arrow { display: none; }
}

/* Animation step transition */
.calc-step {
  animation: scaleIn 0.25s ease-out;
}

/* Bouton "Calculer" — highlight pulsant */
.calc-btn-next {
  position: relative;
  overflow: hidden;
}
.calc-btn-next::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,0.15);
  opacity: 0;
  transition: opacity var(--transition-fast);
}
.calc-btn-next:hover::after {
  opacity: 1;
}

/* ─── Reduce motion override ─────────────── */
@media (prefers-reduced-motion: reduce) {
  .anim-hidden,
  .anim-visible,
  .calc-step { animation: none !important; opacity: 1 !important; transform: none !important; }
  .calc-progress-fill { transition: none; }
}


/* ════════════════════════════════════════════════
   BANDEAU CONSENTEMENT COOKIES (RGPD)
   ════════════════════════════════════════════════ */
#cookie-banner{
  display:none;
  position:fixed;
  left:0;right:0;bottom:0;
  z-index:10001;
  background:#1a1a1a;
  color:rgba(255,255,255,0.92);
  border-top:3px solid var(--red);
  box-shadow:0 -8px 30px rgba(0,0,0,0.25);
  padding:14px 16px;
}
.cookie-banner-inner{
  max-width:1100px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;
}
.cookie-banner-text{
  font-size:0.82rem;line-height:1.4;margin:0;
  flex:1 1 0;min-width:0;color:rgba(255,255,255,0.8);font-weight:300;
}
.cookie-banner-text a{color:#fff;text-decoration:underline;font-weight:500;}
.cookie-banner-actions{display:flex;gap:8px;flex-shrink:0;}
.cookie-btn{
  border:none;cursor:pointer;border-radius:8px;
  padding:10px 18px;font-size:0.85rem;font-weight:600;font-family:inherit;
  white-space:nowrap;
  transition:filter .15s ease, background .15s ease;
  min-height:44px;
  /* Supprime le délai de 300ms sur mobile et le flash bleu au tap */
  touch-action:manipulation;
  -webkit-tap-highlight-color:transparent;
  user-select:none;
}
.cookie-btn-accept{background:var(--red);color:#fff;}
.cookie-btn-accept:hover{filter:brightness(1.08);}
.cookie-btn-decline{background:transparent;color:rgba(255,255,255,0.75);border:1px solid rgba(255,255,255,0.3);}
.cookie-btn-decline:hover{background:rgba(255,255,255,0.08);}
@media (max-width:600px){
  /* Sur mobile le bandeau empile verticalement */
  #cookie-banner{
    padding:12px 14px;
    /* Compense la "home bar" iPhone (safe-area) pour que les boutons
       ne soient jamais cachés derrière le bord de l'écran */
    padding-bottom:calc(12px + env(safe-area-inset-bottom, 0px));
  }
  .cookie-banner-inner{flex-direction:column;align-items:stretch;gap:10px;}
  .cookie-banner-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
  /* Boutons plus hauts et plus larges pour les doigts sur mobile */
  .cookie-btn{text-align:center;padding:14px 10px;font-size:1rem;min-height:52px;border-radius:10px;}
}

/* Safe-area pour tablette/iPhone en mode paysage également */
@supports (padding-bottom: env(safe-area-inset-bottom)){
  #cookie-banner{
    padding-bottom:calc(14px + env(safe-area-inset-bottom));
  }
}

/* ── Chatbot : masqué tant que le bandeau cookies est affiché ──
   display:none retire l'élément du flux ET des pointer-events.
   visibility:hidden est un filet de sécurité si un script remet
   display:flex en style inline (ex. initialisation différée). */
body.cookie-banner-open #chat-bubble{
  display:none !important;
  visibility:hidden !important;
  pointer-events:none !important;
}

/* Case de consentement du formulaire de contact */
.form-consent{
  display:flex;align-items:flex-start;gap:10px;
  margin:4px 0 18px;font-size:0.82rem;line-height:1.45;
}
.form-consent input{margin-top:3px;flex-shrink:0;width:16px;height:16px;accent-color:var(--red);cursor:pointer;}
.form-consent label{cursor:pointer;color:inherit;}
.form-consent a{color:var(--red);text-decoration:underline;font-weight:500;}
.form-input.field-error,.form-select.field-error{display:block;border-color:var(--red) !important;box-shadow:0 0 0 3px var(--red-tint);}
.form-input.input-invalid,.form-select.input-invalid{border-color:var(--red) !important;box-shadow:0 0 0 3px var(--red-tint);}

/* ═══════════════════════════════════════════════════
   ICÔNES SVG — remplacement des émojis
   Bascule couleur : changez --icon-color ci-dessous.
   Rouge marque : var(--red)   |   Gris foncé : var(--gray-800)
════════════════════════════════════════════════════ */
:root{ --icon-color: var(--red); }
.ico{
  width:1em; height:1em; display:inline-block; vertical-align:-0.14em;
  fill:none; stroke:currentColor; stroke-width:1.8;
  stroke-linecap:round; stroke-linejoin:round; flex-shrink:0;
}
.mod-icon-wrap{ color:var(--icon-color); }
.mod-icon-wrap .ico{ width:24px; height:24px; }
.sector-card-icon{ color:var(--icon-color); line-height:0; }
.maca-icon{ color:var(--icon-color); }
.pain-icon{ line-height:0; }
.chat-avatar{ color:#fff; }
/* icônes inline placées devant du texte */
.cc-label{ display:flex; align-items:center; }
.cc-label .ico,
.footer-contact-line .ico,
.sug-btn .ico{ margin-right:.4em; color:var(--icon-color); vertical-align:-0.15em; }