/* ════════════════════════════════════════ */
/* INNOVQUEST — STYLES GLOBAUX */
/* ════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --blue:#1a5fdb;--blue-dark:#0d2d6e;--blue-light:#e8f0fd;
  --blue-mid:#2d7cf6;--salmon:#f9e8e0;--white:#ffffff;
  --ink:#0d1b3e;--muted:#5a6a8a;--border:rgba(26,95,219,.12);
  --ff:'Syne',sans-serif;--fb:'DM Sans',sans-serif;
}
html{scroll-behavior:smooth}
body{font-family:var(--fb);background:var(--white);color:var(--ink);overflow-x:hidden}

/* ════════════════════════════════════════ */
/* CURSEUR PERSONNALISÉ */
/* ════════════════════════════════════════ */
.cursor,.cursor-ring{display:none;pointer-events:none;position:fixed;top:0;left:0;z-index:9999;transform:translate(-50%,-50%)}
.cursor{width:10px;height:10px;background:var(--blue);border-radius:50%;z-index:9999}
.cursor-ring{width:38px;height:38px;border:2px solid var(--blue);border-radius:50%;opacity:.5;z-index:9998;transition:width .25s,height .25s,border-color .25s}
@media(hover:hover) and (pointer:fine){
  body{cursor:none}
  .cursor,.cursor-ring{display:block}
  a,button{cursor:none}
}

/* ════════════════════════════════════════ */
/* NAVIGATION */
/* ════════════════════════════════════════ */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:1.2rem 3rem;display:flex;align-items:center;justify-content:space-between;background:rgba(255,255,255,.95);backdrop-filter:blur(14px);border-bottom:1px solid var(--border);animation:slideDown .7s ease both}
@keyframes slideDown{from{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}
.logo{font-family:var(--ff);font-weight:800;font-size:1.35rem;letter-spacing:-.03em;color:var(--blue-dark);text-decoration:none;display:flex;align-items:center}

.nav-links{display:flex;gap:2rem;list-style:none;align-items:center}
.nav-links a{font-size:.875rem;font-weight:500;color:var(--ink);text-decoration:none;position:relative;transition:color .2s}
.nav-links a:hover{color:var(--blue)}
.nav-links a::after{content:'';position:absolute;bottom:-3px;left:0;width:0;height:2px;background:var(--blue);transition:width .3s;border-radius:2px}
.nav-links a:hover::after{width:100%}
.nav-cta{background:var(--blue)!important;color:var(--white)!important;padding:.55rem 1.3rem!important;border-radius:2rem;transition:background .3s!important}
.nav-cta::after{display:none!important}
.nav-cta:hover{background:var(--blue-dark)!important}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;background:none;border:none;z-index:200}
.hamburger span{display:block;width:24px;height:2px;background:var(--ink);border-radius:2px;transition:transform .3s,opacity .3s}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-menu{display:none;position:fixed;inset:0;z-index:150;background:var(--white);flex-direction:column;align-items:center;justify-content:center;gap:2rem;}
.mobile-menu.open{display:flex}
.mobile-menu a{font-family:var(--ff);font-size:1.6rem;font-weight:700;color:var(--ink);text-decoration:none;transition:color .2s}
.mobile-menu a:hover{color:var(--blue)}
.mob-close{position:absolute;top:1.5rem;right:1.5rem;background:none;border:none;font-size:1.5rem;color:var(--muted);cursor:pointer;padding:.5rem;line-height:1;transition:color .2s}
.mob-close:hover{color:var(--ink)}

/* ════════════════════════════════════════ */
/* HERO */
/* ════════════════════════════════════════ */
.hero{min-height:100vh;background:linear-gradient(145deg,var(--blue-dark) 0%,var(--blue) 60%,#2d7cf6 100%);display:grid;grid-template-columns:1fr 1fr;align-items:center;padding:7rem 3rem 4rem;position:relative;overflow:hidden;gap:2rem}
.hero-pattern{position:absolute;inset:0;background-image:repeating-linear-gradient(45deg,rgba(255,255,255,.03) 0,rgba(255,255,255,.03) 1px,transparent 1px,transparent 40px);pointer-events:none}
.hero-wm{position:absolute;font-family:var(--ff);font-size:9rem;font-weight:800;color:rgba(255,255,255,.04);letter-spacing:-.04em;top:50%;left:50%;transform:translate(-50%,-50%);white-space:nowrap;pointer-events:none;user-select:none}
.hero-blob{position:absolute;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.08) 0%,transparent 70%);pointer-events:none}
.hero-blob.b1{width:500px;height:500px;top:-150px;right:-100px}
.hero-blob.b2{width:300px;height:300px;bottom:-80px;left:22%;animation:float 8s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-20px)}}
.hero-left{display:flex;flex-direction:column;justify-content:center;position:relative;z-index:1;animation:fadeUp .9s .3s ease both}
@keyframes fadeUp{from{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}
h1{font-family:var(--ff);font-size:clamp(2rem,3.5vw,3.2rem);font-weight:800;line-height:1.1;letter-spacing:-.04em;color:var(--white);margin-bottom:1.2rem}
h1 em{font-style:normal;background:linear-gradient(135deg,#f9e8e0,#ffb89a);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}
.btn-white{background:var(--white);color:var(--blue);padding:.85rem 1.8rem;border-radius:3rem;font-weight:700;font-size:.9rem;text-decoration:none;transition:transform .2s,box-shadow .2s;display:inline-block}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,0,0,.2)}
.btn-outline{border:2px solid rgba(255,255,255,.4);color:var(--white);padding:.85rem 1.6rem;border-radius:3rem;font-weight:500;font-size:.9rem;text-decoration:none;display:inline-flex;align-items:center;gap:.5rem;transition:border-color .2s,background .2s}
.btn-outline:hover{border-color:var(--white);background:rgba(255,255,255,.08)}
.hero-right{display:flex;align-items:center;justify-content:center;position:relative;z-index:1;animation:fadeUp .9s .5s ease both}
.hero-illus{width:100%;max-width:480px;display:flex;align-items:center;justify-content:center}
.hero-illus svg{width:100%;height:auto}

/* ════════════════════════════════════════ */
/* MARQUEE */
/* ════════════════════════════════════════ */
.marquee-section{padding:1.5rem 0;overflow:hidden;background:var(--blue-light);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.marquee-track{display:flex;gap:3.5rem;animation:marquee 40s linear infinite;white-space:nowrap}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.marquee-item{font-family:var(--ff);font-size:.8rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);display:inline-flex;align-items:center;gap:1.2rem;flex-shrink:0}
.marquee-item span{color:var(--blue);font-size:1rem}

/* ════════════════════════════════════════ */
/* SECTIONS COMMUNES */
/* ════════════════════════════════════════ */
.section-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:4rem}
.section-label{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--blue);font-weight:600;margin-bottom:.7rem}
h2{font-family:var(--ff);font-size:clamp(1.6rem,2.8vw,2.4rem);font-weight:800;letter-spacing:-.03em;line-height:1.15;color:var(--blue-dark)}

/* ════════════════════════════════════════ */
/* SERVICES */
/* ════════════════════════════════════════ */
.services{padding:8rem 3rem}
.services-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:1.5rem}
.service-card{border-radius:1.5rem;padding:1.8rem 1.8rem 1.5rem;position:relative;overflow:hidden;transition:transform .3s,box-shadow .3s;display:flex;flex-direction:column}
.service-card:hover{transform:translateY(-6px);box-shadow:0 20px 60px rgba(26,95,219,.12)}
.service-card.light{background:var(--blue-light);border:1px solid rgba(26,95,219,.12)}
.service-card.dark{background:linear-gradient(145deg,var(--blue-dark),var(--blue));color:var(--white)}
.service-card.salmon{background:var(--salmon);border:1px solid rgba(249,232,224,.8)}
.services-grid .service-card:nth-child(4){grid-column:1/span 2}
.services-grid .service-card:nth-child(5){grid-column:3/4}
.service-icon{width:42px;height:42px;border-radius:1rem;display:flex;align-items:center;justify-content:center;font-size:1.3rem;margin-bottom:1rem;flex-shrink:0}
.service-card.light .service-icon{background:rgba(26,95,219,.1)}
.service-card.dark .service-icon{background:rgba(255,255,255,.12)}
.service-card.salmon .service-icon{background:rgba(26,95,219,.08)}
.service-num{font-family:var(--ff);font-size:.6rem;font-weight:700;letter-spacing:.1em;opacity:.35;margin-bottom:.6rem;display:block}
.service-card.dark .service-num{opacity:.5;color:var(--white)}
.service-card h3{font-family:var(--ff);font-size:1.1rem;font-weight:700;margin-bottom:.8rem;line-height:1.2;color:var(--blue-dark)}
.service-card.dark h3{color:var(--white);font-size:1.25rem}
.service-card p{font-size:.88rem;line-height:1.75;color:var(--muted);margin-bottom:1.2rem;text-align:justify;flex:1}
.service-card.dark p{color:rgba(255,255,255,.65)}
/* Flèche inline — ne déborde plus sur le texte */
.service-arrow{width:36px;height:36px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:.95rem;transition:transform .3s;margin-top:auto;flex-shrink:0;align-self:flex-start}
.service-card.light .service-arrow,.service-card.salmon .service-arrow{background:var(--blue);color:var(--white)}
.service-card.dark .service-arrow{background:var(--salmon);color:var(--blue-dark)}
.service-card:hover .service-arrow{transform:rotate(45deg)}

/* ════════════════════════════════════════ */
/* WHY */
/* ════════════════════════════════════════ */
.why{padding:7rem 3rem;background:linear-gradient(145deg,var(--blue-dark) 0%,#1040a0 100%);border-radius:2.5rem;margin:4rem 2rem;position:relative;overflow:hidden}
.why::before{content:'';position:absolute;inset:0;background-image:repeating-linear-gradient(45deg,rgba(255,255,255,.03) 0,rgba(255,255,255,.03) 1px,transparent 1px,transparent 40px)}
.why .section-label{color:rgba(249,232,224,.7)}
.why h2{color:var(--white);margin-bottom:3.5rem}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;position:relative;z-index:1}
.why-item{border-top:1px solid rgba(255,255,255,.12);padding-top:1.5rem}
.why-num{font-family:var(--ff);font-size:2.5rem;font-weight:800;color:var(--salmon);line-height:1;margin-bottom:.5rem}
.why-item h4{font-family:var(--ff);color:var(--white);font-size:1rem;font-weight:700;margin-bottom:.7rem}
.why-item p{font-size:.83rem;color:rgba(255,255,255,.45);line-height:1.65;text-align:justify}

/* ════════════════════════════════════════ */
/* À PROPOS */
/* ════════════════════════════════════════ */
.apropos{padding:8rem 3rem}
.apropos-grid{display:flex;flex-direction:column;gap:2rem;margin-top:2rem}

.apropos-text{font-size:.9rem;line-height:1.7;color:var(--muted);margin-bottom:1rem;font-weight:300;text-align:justify}

.apropos-right{display:flex;flex-direction:column;gap:1.2rem}

.apropos-mission{background:linear-gradient(135deg,var(--blue),var(--blue-mid));border-radius:1.5rem;padding:2rem}
.apropos-mission p{font-size:.92rem;color:rgba(255,255,255,.9);line-height:1.75;font-style:italic;font-weight:300;text-align:justify}
.apropos-mission span{display:block;font-size:.72rem;color:rgba(255,255,255,.5);margin-top:.8rem;letter-spacing:.08em;text-transform:uppercase}

/* ════════════════════════════════════════ */
/* PROCESS */
/* ════════════════════════════════════════ */
.process{padding:8rem 3rem}
.process-steps{display:grid;grid-template-columns:repeat(5,1fr);gap:0;margin-top:4rem;position:relative}
.process-steps::before{content:'';position:absolute;top:2.5rem;left:10%;right:10%;height:1px;background:linear-gradient(90deg,transparent,var(--blue),transparent);z-index:0}
.process-step{text-align:center;position:relative;z-index:1}
.process-step h4{font-family:var(--ff);font-size:.93rem;font-weight:700;margin-bottom:.5rem;color:var(--blue-dark)}
.process-step p{font-size:.78rem;color:var(--muted);line-height:1.55;padding:0 .3rem;text-align:center}
.step-circle{width:50px;height:50px;border-radius:50%;background:var(--white);border:2px solid var(--border);display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;font-family:var(--ff);font-weight:700;font-size:.82rem;color:var(--blue-dark);transition:background .3s,color .3s,border-color .3s}
.process-step:hover .step-circle{background:var(--blue);color:var(--white);border-color:var(--blue)}


/* ════════════════════════════════════════ */
/* ════════════════════════════════════════ */
/* CTA */
/* ════════════════════════════════════════ */
.cta-section{padding:6rem 3rem}
.cta-box{background:linear-gradient(145deg,var(--blue-dark) 0%,var(--blue) 100%);border-radius:2.5rem;padding:5rem 3rem;text-align:center;position:relative;overflow:hidden}
.cta-box::before{content:"Osez l'innovation !";font-family:var(--ff);font-size:6rem;font-weight:800;color:rgba(255,255,255,.04);position:absolute;bottom:-10px;right:3rem;pointer-events:none;white-space:nowrap;letter-spacing:-.02em}
.cta-tagline{color:var(--salmon);font-style:italic;font-size:1.1rem;margin-bottom:.8rem;display:block}
.cta-box h2{color:var(--white);margin-bottom:1.2rem;font-size:clamp(1.6rem,3vw,2.4rem);word-break:keep-all}
.cta-box p{color:rgba(255,255,255,.55);font-size:1rem;margin-bottom:2.5rem}
.cta-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;position:relative;z-index:1}
.btn-salmon{background:var(--salmon);color:var(--blue-dark);padding:1rem 2rem;border-radius:3rem;font-weight:700;font-size:.95rem;text-decoration:none;transition:transform .2s,box-shadow .2s;display:inline-block}
.btn-salmon:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,0,0,.2)}

/* ════════════════════════════════════════ */
/* CONTACT */
/* ════════════════════════════════════════ */
.contact-strip{background:var(--blue-dark);padding:1.5rem 3rem;display:flex;justify-content:center;align-items:center;gap:3rem;flex-wrap:wrap}
.contact-item{display:flex;align-items:center;gap:.7rem;color:rgba(255,255,255,.7);font-size:.88rem;text-decoration:none;transition:color .2s}
.contact-item:hover{color:var(--salmon)}

/* ════════════════════════════════════════ */
/* FOOTER */
/* ════════════════════════════════════════ */
footer{padding:4rem 3rem 2rem;background:var(--white);border-top:1px solid var(--border)}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}
.footer-brand-title{font-family:var(--ff);font-weight:800;font-size:1.2rem;letter-spacing:-.03em;color:var(--blue-dark);margin-bottom:.5rem}
.footer-brand p{font-size:.87rem;color:var(--muted);line-height:1.7;margin-top:.5rem;max-width:270px;text-align:justify}

.footer-col h5{font-family:var(--ff);font-weight:700;font-size:.83rem;letter-spacing:.05em;margin-bottom:1.2rem;color:var(--blue-dark)}
.footer-col ul{list-style:none}
.footer-col ul li{margin-bottom:.65rem}
.footer-col ul li a{font-size:.85rem;color:var(--muted);text-decoration:none;transition:color .2s}
.footer-col ul li a:hover{color:var(--blue)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:2rem;border-top:1px solid var(--border);font-size:.78rem;color:var(--muted);flex-wrap:wrap;gap:1rem}
.footer-socials{display:flex;gap:.8rem}
.social-link{padding:.4rem .9rem;border-radius:2rem;border:1px solid var(--border);display:inline-flex;align-items:center;gap:.4rem;text-decoration:none;color:var(--muted);font-size:.8rem;font-weight:600;transition:background .2s,color .2s,border-color .2s;white-space:nowrap}
.social-link:hover{background:var(--blue);color:var(--white);border-color:var(--blue)}

/* ════════════════════════════════════════ */
/* CONTACT FORM */
/* ════════════════════════════════════════ */
.contact-form-section{padding:8rem 3rem;background:var(--blue-light)}
.contact-container{display:grid;grid-template-columns:1fr 1fr;gap:4rem;margin-top:4rem;align-items:start}
.contact-form{background:var(--white);border-radius:1.5rem;padding:2.5rem;border:1px solid var(--border)}
.form-group{margin-bottom:1.8rem}
.form-label{display:block;font-size:.85rem;font-weight:600;color:var(--blue-dark);margin-bottom:.6rem;letter-spacing:.02em}
.form-input{width:100%;padding:.85rem 1.1rem;border:1px solid var(--border);border-radius:.8rem;font-size:.9rem;font-family:var(--fb);background:var(--white);color:var(--ink);transition:border-color .2s}
.form-input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(26,95,219,.1)}
.form-input::placeholder{color:rgba(90,106,138,.4)}
.form-textarea{resize:vertical;min-height:120px;font-family:var(--fb)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.checkbox{display:flex;align-items:center}
.checkbox-label{margin-left:.7rem;font-size:.85rem;color:var(--muted);cursor:pointer}
.form-submit{width:100%;padding:1rem 2rem;background:var(--salmon);border:none;border-radius:.8rem;font-weight:700;font-size:.9rem;color:var(--blue-dark);cursor:pointer;transition:transform .2s,box-shadow .2s;display:flex;align-items:center;justify-content:center;gap:.5rem}
.form-submit:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.12)}
.form-note{font-size:.8rem;color:var(--blue);margin-top:.8rem;text-align:center;display:none}
.form-note.success{display:block;color:#6bcb77}
.form-note.error{display:block;color:#ff6b6b}
.contact-info{display:flex;flex-direction:column;gap:1.5rem}
.info-block{background:var(--white);border-radius:1rem;padding:1.8rem;border:1px solid var(--border)}
.info-block h4{font-family:var(--ff);font-weight:700;font-size:.95rem;color:var(--blue-dark);margin-bottom:.5rem}
.info-block p{font-size:.85rem;color:var(--muted);line-height:1.6}
.info-block a{color:var(--blue);text-decoration:none;font-weight:600}
.info-block a:hover{text-decoration:underline}

/* ════════════════════════════════════════ */
/* ANIMATIONS & UTILITIES */
/* ════════════════════════════════════════ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ════════════════════════════════════════ */
/* RESPONSIVE : TABLETTE (601–1024px) */
/* ════════════════════════════════════════ */
@media(max-width:1024px){
  nav{padding:1.2rem 2rem}
  .nav-links{gap:1.2rem}
  .nav-links a{font-size:.8rem}
  .nav-cta{padding:.5rem 1rem!important;font-size:.8rem!important}
  .hero{padding:8rem 2rem 5rem;gap:1.5rem}
  h1{font-size:clamp(2rem,4vw,3rem)}
  .hero-illus{max-width:340px}
  .services{padding:6rem 2rem}
  .services-grid{grid-template-columns:1fr 1fr}
  .service-card.dark{grid-column:span 2}
  .services-grid .service-card:nth-child(4){grid-column:span 1}
  .services-grid .service-card:nth-child(5){grid-column:span 1}
  .why{margin:0 1.5rem;padding:5rem 2rem}
  .why-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .apropos{padding:6rem 2rem}
  .process{padding:6rem 2rem}
  .process-steps{grid-template-columns:repeat(3,1fr);gap:2rem}
  .process-steps::before{display:none}
  .contact-form-section{padding:6rem 2rem}
  .contact-container{grid-template-columns:1fr;gap:2rem}
  .form-row{grid-template-columns:1fr 1fr}
  .cta-section{padding:5rem 2rem}
  .contact-strip{gap:1.5rem;padding:1.5rem 2rem;flex-wrap:wrap;justify-content:center}
  footer{padding:4rem 2rem 2rem}
  .footer-top{grid-template-columns:1fr 1fr;gap:2rem}
}

/* ════════════════════════════════════════ */
/* HAMBURGER dès 900px */
/* ════════════════════════════════════════ */
@media(max-width:900px){
  .nav-links{display:none}
  .hamburger{display:flex}
  nav{padding:1rem 1.5rem}
}

/* ════════════════════════════════════════ */
/* RESPONSIVE : MOBILE (≤600px) */
/* ════════════════════════════════════════ */
@media(max-width:600px){
  nav{padding:1rem 1.2rem}
  .hero{grid-template-columns:1fr;padding:5.5rem 1.2rem 3rem;min-height:auto;gap:0}
  .hero-right,.hero-wm{display:none}
  h1{font-size:2rem;margin-bottom:1rem}
  .hero-actions{flex-direction:column;gap:.75rem}
  .btn-white,.btn-outline{width:100%;text-align:center;justify-content:center;padding:.9rem 1.5rem}
  .services,.apropos,.process,.cta-section,.contact-form-section{padding:3.5rem 1.2rem}
  .why{margin:0;border-radius:0;padding:3.5rem 1.2rem}
  h2{font-size:1.6rem}
  .section-header{flex-direction:column;align-items:flex-start;gap:.6rem;margin-bottom:2rem}
  .services-grid{grid-template-columns:1fr;gap:1rem}
  .service-card.dark,
  .services-grid .service-card:nth-child(4),
  .services-grid .service-card:nth-child(5){grid-column:span 1}
  .service-card{padding:1.5rem}
  .service-icon{width:40px;height:40px;font-size:1.2rem;margin-bottom:1rem}
  .why-grid{grid-template-columns:1fr 1fr;gap:1rem}
  .why-num{font-size:1.8rem}
  .why-item p{font-size:.78rem}
  .apropos-text{text-align:left;font-size:.88rem;line-height:1.65}
  .apropos-mission{padding:1.5rem}
  .process-steps{grid-template-columns:1fr 1fr;gap:1.2rem}
  .process-steps::before{display:none}
  .step-circle{width:42px;height:42px;font-size:.75rem;margin-bottom:1rem}
  .process-step p{font-size:.75rem}
  .form-row{grid-template-columns:1fr}
  .contact-container{gap:1.5rem}
  .contact-form{padding:1.5rem}
  .info-block{padding:1.2rem}
  .cta-box{padding:2.5rem 1.2rem}
  .cta-box::before{display:none}
  .cta-actions{flex-direction:column;gap:.75rem}
  .btn-salmon{width:100%;text-align:center}
  .cta-section .btn-outline{width:100%;text-align:center;justify-content:center;border-color:rgba(255,255,255,.4);color:var(--white)}
  .contact-strip{flex-direction:column;gap:.8rem;padding:1.2rem;align-items:flex-start}
  .contact-item{font-size:.82rem}
  footer{padding:3rem 1.2rem 1.5rem}
  .footer-top{grid-template-columns:1fr;gap:1.5rem}
  .footer-brand p{max-width:100%}
  .footer-brand-title{font-size:1.1rem}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:.8rem;font-size:.75rem}
  .footer-socials{flex-wrap:wrap;gap:.6rem}
  .logo{font-size:1.15rem}
}

/* ════════════════════════════════════════ */
/* TRÈS PETIT MOBILE (≤380px) */
/* ════════════════════════════════════════ */
@media(max-width:380px){
  h1{font-size:1.75rem}
  h2{font-size:1.4rem}
  .hero{padding:5rem 1rem 2.5rem}
  .services,.apropos,.process,.cta-section,.contact-form-section,.why{padding:3rem 1rem}
  .why-grid{grid-template-columns:1fr}
  .process-steps{grid-template-columns:1fr}
  .service-card{padding:1.2rem}
  .cta-box{padding:2rem 1rem}
  .contact-strip{padding:1rem}
  footer{padding:2.5rem 1rem 1.2rem}
  .mobile-menu a{font-size:1.3rem}
}
