/* ============================================================
   BASE — composants CMS hérités (vues non encore migrées)
   Surchargés par le thème FDM ci-dessous pour les sélecteurs communs.
   ============================================================ */
/* =====================================================
   FDM 35 - CSS global (toutes pages)
   Thème : orange #f59c00 / noir #050505 — police Tanker + Montserrat
   Les anciennes variables (--red/--blue/--dark/--navy) sont conservées
   comme alias vers la palette FDM : tous les composants héritent du thème.
   ===================================================== */

@font-face{
  font-family:"Tanker";
  src:url("../fonts/Tanker-Regular.woff2") format("woff2"),
      url("../fonts/Tanker-Regular.woff") format("woff");
  font-weight:400;
  font-style:normal;
  font-display:swap;
}

:root {
  /* Palette FDM */
  --orange: #f59c00;
  --black:  #050505;
  --text:   #181818;
  --white:  #ffffff;
  --font-title: "Tanker",Impact,sans-serif;
  --font-body:  "Montserrat",Arial,Helvetica,sans-serif;
  --radius: 14px;

  /* Alias de compatibilité (anciens composants Godet) → thème FDM */
  --red:   var(--orange);
  --blue:  var(--orange);
  --dark:  var(--black);
  --navy:  var(--black);
  --grey:  #e7e7e7;
  --light: #f7f7f7;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0;color:var(--text);background:var(--white);font-family:var(--font-body);font-size:16px;line-height:1.55;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
button{font:inherit;}
.container{width:min(1200px,calc(100% - 40px));margin:0 auto;}
.section{padding:54px 0;}
h1,h2,h3,h4{font-family:var(--font-title);text-transform:uppercase;font-weight:400;margin:0;line-height:.96;letter-spacing:-.5px;color:var(--black);}
h2{font-size:clamp(34px,4vw,48px);}
h3{font-size:22px;}
h4{font-size:16px;color:var(--orange);margin-bottom:8px;letter-spacing:0;}

/* ================= HEADER (FDM : sticky, fond blanc) ================= */
.site-header{position:sticky;top:0;left:auto;transform:none;z-index:50;width:100%;background:#fff;border-radius:0;box-shadow:0 1px 8px rgba(0,0,0,.08);backdrop-filter:none;}
.header-inner{width:min(1320px,calc(100% - 40px));margin:0 auto;min-height:70px;display:flex;align-items:center;justify-content:space-between;gap:30px;padding:0;}
.logo{display:inline-flex;align-items:center;min-width:0;}
.logo img{height:56px;width:auto;display:block;}
.main-nav{display:flex;align-items:center;gap:28px;color:var(--black);margin-left:auto;}
.nav-item{position:relative;}
.nav-link{border:0;background:transparent;color:var(--black);cursor:pointer;padding:24px 0;font-family:var(--font-body);font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;}
.nav-link:hover{color:var(--orange);}
.has-dropdown>.nav-link::after{content:'';display:inline-block;width:7px;height:7px;margin-left:5px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg) translateY(-3px);}
.simple-link{display:inline-flex;align-items:center;}
.dropdown-menu{position:absolute;left:-16px;top:calc(100% - 4px);min-width:188px;padding:10px 0;background:white;border-radius:0 0 12px 12px;box-shadow:0 16px 28px rgba(0,0,0,.14);opacity:0;visibility:hidden;transform:translateY(8px);transition:.2s ease;}
.dropdown-menu a{display:block;padding:9px 16px;font-size:13px;font-weight:600;text-transform:uppercase;color:var(--black);}
.dropdown-menu a:hover{background:rgba(245,156,0,.12);color:var(--orange);}
.has-dropdown:hover .dropdown-menu,.has-dropdown.open .dropdown-menu{opacity:1;visibility:visible;transform:translateY(0);}
.header-actions{display:flex;align-items:center;gap:20px;white-space:nowrap;}
.phone-link{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-title);font-size:19px;color:var(--black);font-weight:400;}
.phone-link:hover{color:var(--orange);}
.phone-icon{font-family:Arial,sans-serif;font-size:20px;line-height:1;}
.project-btn{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:0 22px;border-radius:999px;background:var(--orange);color:#000;font-family:var(--font-title);text-transform:uppercase;font-size:17px;font-weight:400;}
.project-btn:hover{filter:brightness(.95);}
.menu-toggle{display:none;background:#000;border:0;width:40px;height:40px;padding:9px;cursor:pointer;border-radius:50%;}
.menu-toggle span{display:block;height:2px;background:#fff;margin:5px 0;border-radius:10px;}

/* ================= HERO ACCUEIL ================= */
.hero{position:relative;min-height:560px;width:100%;margin:0;overflow:hidden;border-radius:0;display:grid;place-items:center;background:linear-gradient(90deg,rgba(5,5,5,.88) 0%,rgba(5,5,5,.45) 45%,rgba(5,5,5,.05) 100%),url('../img/hero.jpg') center/cover no-repeat;background-size:cover;background-position:center;}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 45%,rgba(255,255,255,.05),transparent 34%);pointer-events:none;}
.hero-content{position:relative;z-index:2;width:min(1120px,calc(100% - 32px));padding:140px 0 40px;text-align:center;color:white;}
.hero h1{color:white;font-size:clamp(38px,4.6vw,68px);line-height:.98;text-transform:none;letter-spacing:.2px;text-shadow:0 5px 18px rgba(0,0,0,.35);}
.hero h1 span{display:inline-block;font-size:.72em;}
.hero-actions{display:flex;align-items:center;flex-wrap:wrap;gap:48px;margin-top:34px;}
.btn{display:inline-flex;align-items:center;justify-content:center;min-width:200px;padding:13px 26px;border-radius:999px;background:#000;color:#fff;font-family:var(--font-title);font-weight:400;text-transform:uppercase;font-size:18px;line-height:1;letter-spacing:.3px;transition:transform .2s ease,filter .2s ease;}
.btn:hover{transform:translateY(-2px);filter:brightness(1.05);}
.btn-red,.btn-blue,.btn-orange{background:var(--orange);color:#000;}
.btn-dark{background:#000;color:#fff;}
.btn-white{background:#fff;color:#000;}
.btn-outline{background:transparent;border:2px solid #fff;color:#fff;}
/* FDM : variantes utilisées dans les vues retravaillées */
.btn.orange{background:var(--orange);color:#000;}
.btn.white{background:#fff;color:#000;}
.btn-primary{background:var(--orange);color:#000;}
.btn-secondary{background:#000;color:#fff;}
.btn-lg{min-width:240px;padding:15px 32px;font-size:20px;}
.btn-sm{min-width:auto;padding:9px 18px;font-size:15px;}
.page-hero-sub{color:rgba(255,255,255,.88);font-size:18px;margin-top:8px;}

/* ================= PAGE HERO (pages intérieures) ================= */
.page-hero{position:relative;min-height:320px;width:100%;margin:0;overflow:hidden;border-radius:0;display:grid;place-items:center;background:var(--black);background-size:cover;background-position:center;}
.page-hero::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(5,5,5,.85) 0%,rgba(5,5,5,.5) 50%,rgba(5,5,5,.2) 100%);pointer-events:none;}
.page-hero-content{position:relative;z-index:2;width:min(1120px,calc(100% - 32px));padding:130px 0 54px;text-align:center;color:white;}
.page-hero-content h1{color:white;font-size:clamp(32px,4vw,60px);line-height:.98;text-shadow:0 4px 14px rgba(0,0,0,.35);margin-bottom:18px;}
.page-hero-content p{color:rgba(255,255,255,.88);font-size:18px;max-width:640px;margin:0 auto;}

/* Breadcrumb */
.breadcrumb{display:flex;align-items:center;justify-content:center;gap:8px;font-size:13px;color:rgba(255,255,255,.78);margin-bottom:16px;font-weight:600;}
.breadcrumb a{color:rgba(255,255,255,.78);}
.breadcrumb a:hover{color:white;}
.breadcrumb span{color:rgba(255,255,255,.5);}

/* Hero variants */
.hero-transport{background-image:linear-gradient(180deg,rgba(0,40,70,.12) 0%,rgba(0,40,70,.42) 50%,rgba(0,69,112,.85) 100%),url('https://images.unsplash.com/photo-1601584115197-04ecc0da31d7?auto=format&fit=crop&w=2200&q=80');}
.hero-tp{background-image:linear-gradient(180deg,rgba(0,40,70,.12) 0%,rgba(0,40,70,.42) 50%,rgba(0,69,112,.85) 100%),url('https://images.unsplash.com/photo-1504307651254-35680f356dfd?auto=format&fit=crop&w=2200&q=80');}
.hero-terrassement{background-image:linear-gradient(180deg,rgba(0,40,70,.12) 0%,rgba(0,40,70,.42) 50%,rgba(0,69,112,.85) 100%),url('https://images.unsplash.com/photo-1581578731548-c64695cc6952?auto=format&fit=crop&w=2200&q=80');}
.hero-grue{background-image:linear-gradient(180deg,rgba(0,40,70,.12) 0%,rgba(0,40,70,.42) 50%,rgba(0,69,112,.85) 100%),url('https://images.unsplash.com/photo-1558618666-fcd25c85cd64?auto=format&fit=crop&w=2200&q=80');}
.hero-demolition{background-image:linear-gradient(180deg,rgba(0,40,70,.12) 0%,rgba(0,40,70,.42) 50%,rgba(0,69,112,.85) 100%),url('https://images.unsplash.com/photo-1590496793929-36417d3117de?auto=format&fit=crop&w=2200&q=80');}
.hero-agricole{background-image:linear-gradient(180deg,rgba(0,40,70,.12) 0%,rgba(0,40,70,.42) 50%,rgba(0,69,112,.85) 100%),url('https://images.unsplash.com/photo-1530267981375-f0de937f5f13?auto=format&fit=crop&w=2200&q=80');}
.hero-entreprise{background-image:linear-gradient(180deg,rgba(0,40,70,.12) 0%,rgba(0,40,70,.42) 50%,rgba(0,69,112,.85) 100%),url('https://images.unsplash.com/photo-1521791136064-7986c2920216?auto=format&fit=crop&w=2200&q=80');}
.hero-blog{background-image:linear-gradient(180deg,rgba(0,40,70,.12) 0%,rgba(0,40,70,.42) 50%,rgba(0,69,112,.85) 100%),url('https://images.unsplash.com/photo-1471107340929-a87cd0f5b5f3?auto=format&fit=crop&w=2200&q=80');}
.hero-portfolio{background-image:linear-gradient(180deg,rgba(0,40,70,.12) 0%,rgba(0,40,70,.42) 50%,rgba(0,69,112,.85) 100%),url('https://images.unsplash.com/photo-1503387762-592deb58ef4e?auto=format&fit=crop&w=2200&q=80');}
.hero-contact{background-image:linear-gradient(180deg,rgba(0,40,70,.12) 0%,rgba(0,40,70,.42) 50%,rgba(0,69,112,.85) 100%),url('https://images.unsplash.com/photo-1423666639041-f56000c27a9a?auto=format&fit=crop&w=2200&q=80');}
.hero-services{background-image:linear-gradient(180deg,rgba(0,40,70,.12) 0%,rgba(0,40,70,.42) 50%,rgba(0,69,112,.85) 100%),url('https://images.unsplash.com/photo-1504307651254-35680f356dfd?auto=format&fit=crop&w=2200&q=80');}
.hero-zone{background-image:linear-gradient(180deg,rgba(0,40,70,.12) 0%,rgba(0,40,70,.42) 50%,rgba(0,69,112,.85) 100%),url('https://images.unsplash.com/photo-1508450859948-4e04fabaa4ea?auto=format&fit=crop&w=2200&q=80');}
.hero-clients{background-image:linear-gradient(180deg,rgba(0,40,70,.12) 0%,rgba(0,40,70,.42) 50%,rgba(0,69,112,.85) 100%),url('https://images.unsplash.com/photo-1552664730-d307ca884978?auto=format&fit=crop&w=2200&q=80');}
.hero-team{background-image:linear-gradient(180deg,rgba(0,40,70,.12) 0%,rgba(0,40,70,.42) 50%,rgba(0,69,112,.85) 100%),url('https://images.unsplash.com/photo-1521791136064-7986c2920216?auto=format&fit=crop&w=2200&q=80');}
.hero-materiel{background-image:linear-gradient(180deg,rgba(0,40,70,.12) 0%,rgba(0,40,70,.42) 50%,rgba(0,69,112,.85) 100%),url('https://images.unsplash.com/photo-1581094794329-c8112a89af12?auto=format&fit=crop&w=2200&q=80');}
.hero-rse{background-image:linear-gradient(180deg,rgba(0,40,70,.12) 0%,rgba(0,40,70,.42) 50%,rgba(0,69,112,.85) 100%),url('https://images.unsplash.com/photo-1497435334941-8c899ee9e8e9?auto=format&fit=crop&w=2200&q=80');}
.hero-projects{background-image:linear-gradient(180deg,rgba(0,40,70,.12) 0%,rgba(0,40,70,.42) 50%,rgba(0,69,112,.85) 100%),url('https://images.unsplash.com/photo-1503387762-592deb58ef4e?auto=format&fit=crop&w=2200&q=80');}

/* ================= ACCENTS & COMMUNS ================= */
.red-line{display:block;width:46px;height:5px;background:var(--red);margin:0 0 14px;border-radius:999px;}
.section-accent{display:block;width:74px;height:9px;border-radius:999px;background:var(--red);margin:0 0 18px;}
.center{text-align:center;}
.center .red-line{margin-left:auto;margin-right:auto;}
.center .section-accent{margin-left:auto;margin-right:auto;}
.intro{margin:20px 0 32px;max-width:620px;}
.tag{display:inline-flex;align-items:center;padding:4px 14px;border-radius:999px;font-size:12px;font-weight:700;font-family:var(--font-title);text-transform:uppercase;letter-spacing:.5px;}
.tag-red{background:rgba(226,6,19,.1);color:var(--red);}
.tag-blue{background:rgba(0,105,179,.1);color:var(--blue);}
.tag-dark{background:rgba(29,29,27,.08);color:var(--dark);}

/* ================= PRESTATIONS (accueil) ================= */
.prestations-section{padding:70px 0 78px;background:var(--white);}
.prestations-container{max-width:1380px;}
.prestations-heading{margin:0 0 42px 8px;}
.prestations-heading h2{color:var(--navy);font-size:clamp(40px,4.5vw,68px);line-height:1.08;letter-spacing:-.5px;}
.prestations-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:26px;}
.prestation-card{position:relative;min-height:410px;overflow:hidden;border-radius:30px;background-size:cover;background-position:center;box-shadow:0 18px 34px rgba(0,40,70,.12);transition:transform .25s ease,box-shadow .25s ease;}
.prestation-card:hover{transform:translateY(-6px);box-shadow:0 24px 44px rgba(0,40,70,.18);}
.prestation-card a{position:absolute;inset:0;display:flex;align-items:flex-end;color:#fff;}
.prestation-card::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,40,70,.02) 0%,rgba(0,40,70,.28) 46%,rgba(0,40,70,.92) 100%);z-index:1;}
.prestation-content{position:relative;z-index:2;width:100%;padding:0 38px 38px;}
.prestation-content h3{color:#fff;font-size:clamp(26px,2.1vw,38px);line-height:.95;margin:0 0 16px;}
.prestation-content p{margin:0 0 22px;color:rgba(255,255,255,.92);font-size:15.5px;line-height:1.32;font-weight:700;}
.prestation-content span{display:inline-flex;color:#fff;font-family:var(--font-title);text-transform:uppercase;font-size:17px;font-weight:900;}
.prestation-tp{background-image:linear-gradient(125deg,rgba(255,172,73,.16),rgba(0,105,179,.08)),url('https://images.unsplash.com/photo-1581094794329-c8112a89af12?auto=format&fit=crop&w=900&q=80');}
.prestation-terrassement{background-image:linear-gradient(125deg,rgba(255,255,255,.05),rgba(0,105,179,.10)),url('https://images.unsplash.com/photo-1504307651254-35680f356dfd?auto=format&fit=crop&w=900&q=80');}
.prestation-demolition{background-image:linear-gradient(125deg,rgba(255,255,255,.05),rgba(0,105,179,.10)),url('https://images.unsplash.com/photo-1590496793929-36417d3117de?auto=format&fit=crop&w=900&q=80');}
.prestation-agricole{background-image:linear-gradient(125deg,rgba(255,255,255,.06),rgba(0,105,179,.12)),url('https://images.unsplash.com/photo-1530267981375-f0de937f5f13?auto=format&fit=crop&w=900&q=80');}

/* ================= SERVICES GRID ================= */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:0 auto;}
.service-card{text-align:center;}
.photo{height:118px;border-radius:14px;background-size:cover;background-position:center;box-shadow:inset 0 0 0 1px rgba(0,0,0,.05);}
.service-card h3{margin-top:12px;font-size:16px;color:var(--navy);}
.service-card p{margin:1px 0 0;font-family:var(--font-title);text-transform:uppercase;font-size:13px;color:var(--navy);}
.ph-transport{background-image:linear-gradient(135deg,#d8e5ed 0 35%,#fff 36% 48%,#0069b3 49% 62%,#48515a 63% 100%);}
.ph-grue{background-image:linear-gradient(140deg,#ffd49b 0 22%,#1d1d1b 23% 38%,#f6f6f6 39% 56%,#0069b3 57% 72%,#696969 73% 100%);}
.ph-benne{background-image:linear-gradient(135deg,#eef4f8 0 34%,#fff 35% 51%,#0069b3 52% 63%,#777 64% 100%);}
.ph-pelle{background-image:linear-gradient(135deg,#c9e5ad 0 35%,#f0c22d 36% 59%,#333 60% 73%,#9f7a4d 74% 100%);}
.ph-remorque{background-image:linear-gradient(135deg,#e9f1f3 0 28%,#fff 29% 42%,#0069b3 43% 54%,#c5b8a0 55% 100%);}
.ph-chantier{background-image:linear-gradient(135deg,#f7bd20 0 46%,#2a2a2a 47% 62%,#ba8a45 63% 100%);}
.ph-plateau{background-image:linear-gradient(135deg,#97c3e1 0 35%,#1d1d1b 36% 42%,#e8e8e8 43% 58%,#0069b3 59% 100%);}
.ph-mini{background-image:linear-gradient(135deg,#ded6be 0 30%,#f6b52a 31% 55%,#2b2b2b 56% 72%,#947351 73% 100%);}

/* ================= HISTOIRE (accueil) ================= */
.story-grid{display:grid;grid-template-columns:1.1fr .9fr;align-items:center;gap:60px;}
.values-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:25px 34px;}
.values-grid p{margin:0;font-size:14px;}
.story-collage{min-height:360px;position:relative;}
.collage-img{position:absolute;border-radius:15px;box-shadow:0 16px 32px rgba(0,0,0,.15);background-size:cover;}
.img-a{width:46%;height:125px;right:18%;top:10px;background-image:linear-gradient(135deg,#dfebe9,#fff 38%,#0069b3 39% 58%,#333 59%);}
.img-b{width:52%;height:150px;left:3%;top:115px;background-image:linear-gradient(135deg,#d8c49f,#f2c13a 40%,#1d1d1b 41% 55%,#eee 56%);}
.img-c{width:55%;height:120px;right:0;top:190px;background-image:linear-gradient(135deg,#d7d7d7,#fff 36%,#0069b3 37% 52%,#6d6d6d 53%);}
.img-d{width:42%;height:115px;left:18%;bottom:0;background-image:linear-gradient(135deg,#eee,#1d1d1b 38%,#0069b3 39% 55%,#fff 56%);}

/* ================= CTA CARDS ================= */
.cta-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.big-card{min-height:210px;border-radius:18px;color:#fff;padding:40px 28px 24px;display:flex;flex-direction:column;justify-content:flex-end;font-family:var(--font-title);text-transform:uppercase;font-size:35px;line-height:1.02;transition:transform .25s ease;}
.big-card:hover{transform:translateY(-5px);}
.big-card span{display:block;margin-top:16px;font-family:var(--font-body);font-size:14px;text-transform:none;opacity:.92;}
.big-card.red{background:var(--red);}
.big-card.dark{background:var(--dark);}
.big-card.blue{background:var(--blue);}

/* ================= MATERIELS SLIDER ================= */
.section-title p{margin-top:4px;color:var(--red);font-family:var(--font-title);text-transform:uppercase;font-size:17px;}
.slider{position:relative;margin-top:38px;}
.slider-track{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
.equipment-card{display:none;text-align:center;}
.equipment-card.active{display:block;}
.equipment-card p{font-size:14px;margin:11px 0 0;}
.slider-btn{position:absolute;top:42px;width:38px;height:38px;border:0;border-radius:50%;background:var(--dark);color:white;font-size:28px;line-height:1;cursor:pointer;z-index:2;}
.prev{left:-54px;}.next{right:-54px;}
.dots{display:flex;justify-content:center;gap:10px;margin-top:25px;}
.dot{width:11px;height:11px;border:0;border-radius:50%;background:#d2d2d2;cursor:pointer;}
.dot.active{background:var(--dark);}

/* ================= ZONE ================= */
.zone{background:var(--grey);padding:70px 0;}
.zone-grid{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:60px;}
.zone p{max-width:580px;}
.map-france{height:260px;position:relative;display:grid;place-items:center;color:var(--blue);font-family:var(--font-title);text-transform:uppercase;}
.map-france::before{content:'';width:260px;height:230px;background:#fff;clip-path:polygon(39% 2%,58% 9%,60% 22%,75% 29%,69% 43%,82% 57%,68% 70%,61% 92%,43% 81%,28% 88%,22% 70%,8% 61%,20% 44%,14% 27%,30% 18%);box-shadow:0 10px 22px rgba(0,0,0,.08);}
.map-france span,.map-france strong{position:absolute;}
.map-france span{top:70px;left:80px;background:var(--blue);color:white;padding:8px 12px;border-radius:50%;transform:rotate(-12deg);}
.map-france strong{font-family:Georgia,serif;font-size:34px;bottom:82px;right:130px;}

/* ================= CONTACT / FORMULAIRE ================= */
.contact{background:var(--blue);color:white;padding:70px 0;}
.contact-grid{display:grid;grid-template-columns:.75fr 1.25fr;gap:60px;align-items:center;}
.contact h2{color:white;}
.truck-placeholder{min-height:320px;border-radius:26px;background:radial-gradient(circle at 68% 56%,rgba(255,255,255,.85) 0 7%,transparent 8%),linear-gradient(135deg,#fff 0 18%,#e8edf2 19% 38%,var(--blue) 39% 58%,#f8f8f8 59% 75%,#b8c1ca 76% 100%);box-shadow:0 24px 50px rgba(0,0,0,.14);position:relative;}
.truck-placeholder::after{content:'';position:absolute;left:9%;right:9%;bottom:13%;height:34px;background:var(--dark);border-radius:999px;opacity:.95;}
.contact-truck{min-height:240px;box-shadow:none;background-color:transparent;}
.phone-badge{position:absolute;left:10%;bottom:-18px;background:white;color:var(--red);padding:8px 18px;border-radius:12px;text-align:center;font-family:var(--font-title);text-transform:uppercase;box-shadow:0 10px 20px rgba(0,0,0,.18);}
.phone-badge strong{color:var(--navy);font-size:28px;display:block;line-height:1;}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin-top:20px;}
input,textarea,select{width:100%;border:0;border-radius:3px;padding:14px 15px;font:inherit;outline:none;background:white;color:var(--dark);}
textarea{grid-column:1 / -1;min-height:110px;resize:vertical;}
.submit-btn{margin-top:10px;float:right;background:white;color:var(--dark);border:0;border-radius:5px;padding:10px 38px;font-family:var(--font-title);text-transform:uppercase;cursor:pointer;font-size:15px;}
.submit-btn:hover{background:var(--navy);color:white;}
.form-message{min-height:22px;margin:12px 0 0;font-weight:700;}

/* ================= SERVICE DETAIL ================= */
.service-intro{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;padding:70px 0;}
.service-intro-img{border-radius:24px;overflow:hidden;min-height:380px;background-size:cover;background-position:center;box-shadow:0 20px 40px rgba(0,40,70,.14);}
.service-intro-text .red-line{margin-bottom:18px;}
.service-intro-text p{margin:18px 0;line-height:1.7;color:#444;}
.service-features{padding:60px 0;background:var(--light);}
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:40px;}
.feature-item{background:white;border-radius:18px;padding:32px 26px;box-shadow:0 8px 24px rgba(0,40,70,.08);transition:transform .22s ease;}
.feature-item:hover{transform:translateY(-4px);}
.feature-icon{width:52px;height:52px;border-radius:14px;background:var(--blue);display:grid;place-items:center;margin-bottom:18px;font-size:24px;}
.feature-icon svg{fill:none;stroke:white;stroke-width:2;}
.feature-item h3{font-size:18px;margin-bottom:10px;color:var(--navy);}
.feature-item p{margin:0;font-size:14px;color:#555;line-height:1.6;}
.related-services{padding:60px 0;}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:38px;}
.related-card{border-radius:18px;overflow:hidden;min-height:220px;position:relative;background-size:cover;background-position:center;box-shadow:0 12px 28px rgba(0,40,70,.12);transition:transform .22s ease;}
.related-card:hover{transform:translateY(-4px);}
.related-card::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,rgba(0,40,70,.85) 100%);}
.related-card-content{position:absolute;bottom:0;left:0;right:0;padding:20px 22px;color:white;}
.related-card-content h3{font-size:18px;color:white;margin-bottom:6px;}
.related-card-content span{font-size:13px;font-family:var(--font-title);text-transform:uppercase;color:rgba(255,255,255,.8);}
.cta-band{background:var(--navy);color:white;padding:60px 0;text-align:center;}
.cta-band h2{color:white;margin-bottom:18px;}
.cta-band p{color:rgba(255,255,255,.8);max-width:560px;margin:0 auto 30px;}
.cta-band-btns{display:flex;justify-content:center;gap:18px;flex-wrap:wrap;}

/* ================= BLOG ================= */
.blog-layout{display:grid;grid-template-columns:1fr 340px;gap:50px;padding:60px 0;}
.blog-grid-full{padding:60px 0;}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.blog-card{border-radius:18px;overflow:hidden;background:white;box-shadow:0 8px 24px rgba(0,40,70,.08);transition:transform .22s ease;}
.blog-card:hover{transform:translateY(-4px);}
.blog-card-img{height:200px;background-size:cover;background-position:center;position:relative;}
.blog-card-img .tag{position:absolute;top:14px;left:14px;}
.blog-card-body{padding:22px 24px 26px;}
.blog-meta{display:flex;align-items:center;gap:14px;font-size:12px;color:#888;margin-bottom:10px;}
.blog-meta span{display:flex;align-items:center;gap:4px;}
.blog-card-body h3{font-size:17px;color:var(--navy);margin-bottom:10px;line-height:1.25;text-transform:none;}
.blog-card-body p{margin:0;font-size:14px;color:#555;line-height:1.6;}
.blog-card-footer{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;border-top:1px solid #eee;}
.read-more{font-family:var(--font-title);font-size:13px;text-transform:uppercase;color:var(--blue);font-weight:900;}
.read-more:hover{color:var(--red);}

/* Blog post / single */
.blog-featured{display:block;min-height:420px;border-radius:24px;overflow:hidden;position:relative;margin-bottom:50px;background-size:cover;background-position:center;}
.blog-featured::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 20%,rgba(0,40,70,.9) 100%);}
.blog-featured-content{position:absolute;bottom:0;left:0;right:0;padding:40px;}
.blog-featured-content .tag{margin-bottom:14px;}
.blog-featured-content h2{color:white;font-size:clamp(26px,3vw,42px);text-transform:none;margin-bottom:14px;}
.blog-featured-content .blog-meta{color:rgba(255,255,255,.75);}
.blog-featured-content a{color:white;}
.article-excerpt{font-size:17px;color:var(--navy);font-weight:700;line-height:1.6;margin:0 0 28px;padding:0 0 28px;border-bottom:2px solid var(--grey);}
.article-content{line-height:1.8;color:#333;}
.article-content h2{font-size:28px;margin:40px 0 16px;text-transform:none;}
.article-content h3{font-size:20px;margin:30px 0 12px;text-transform:none;}
.article-content p{margin:0 0 20px;}
.article-content img{border-radius:16px;margin:30px 0;width:100%;}
.article-content blockquote{margin:30px 0;padding:22px 30px;border-left:4px solid var(--red);background:var(--light);border-radius:0 12px 12px 0;font-style:italic;font-size:17px;color:var(--navy);}
.article-tags{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:26px 0;border-top:1px solid #eee;margin-top:40px;}
.article-tags strong{font-size:13px;color:#888;}
.author-box{display:grid;grid-template-columns:auto 1fr;gap:22px;align-items:center;padding:30px;background:var(--light);border-radius:18px;margin-top:36px;}
.author-avatar{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--navy));display:grid;place-items:center;font-family:var(--font-title);font-size:28px;color:white;}
.author-box h4{margin-bottom:6px;}
.author-box p{margin:0;font-size:14px;color:#555;}
.related-posts{padding:50px 0;border-top:1px solid #eee;margin-top:20px;}
.related-posts h3{font-size:22px;margin-bottom:28px;}

/* Sidebar */
.sidebar{display:flex;flex-direction:column;gap:28px;}
.sidebar-widget{background:var(--light);border-radius:18px;padding:26px;}
.sidebar-widget h4{font-size:16px;color:var(--navy);margin-bottom:16px;padding-bottom:10px;border-bottom:2px solid var(--red);}
.sidebar-search{display:flex;gap:10px;}
.sidebar-search input{border-radius:8px;border:1px solid #ddd;padding:10px 14px;flex:1;}
.sidebar-search button{background:var(--blue);color:white;border:0;border-radius:8px;padding:10px 16px;cursor:pointer;}
.sidebar-cats{list-style:none;margin:0;padding:0;}
.sidebar-cats li{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #e4e4e4;font-size:14px;}
.sidebar-cats li:last-child{border-bottom:0;}
.sidebar-cats a:hover{color:var(--blue);}
.sidebar-cats .count{background:var(--grey);border-radius:999px;padding:1px 8px;font-size:12px;}
.recent-posts{display:flex;flex-direction:column;gap:14px;}
.recent-post{display:grid;grid-template-columns:64px 1fr;gap:12px;align-items:center;}
.recent-post-img{width:64px;height:64px;border-radius:10px;background-size:cover;background-position:center;flex-shrink:0;}
.recent-post h5{font-size:13px;font-family:var(--font-body);font-weight:700;color:var(--navy);text-transform:none;margin:0 0 4px;line-height:1.3;}
.recent-post span{font-size:11px;color:#888;}
.tags-cloud{display:flex;flex-wrap:wrap;gap:8px;}
.tags-cloud a{display:inline-flex;padding:5px 12px;border-radius:999px;border:1px solid #ddd;font-size:12px;color:#555;transition:.2s;}
.tags-cloud a:hover{background:var(--blue);color:white;border-color:var(--blue);}

/* Pagination */
.pagination{display:flex;align-items:center;justify-content:center;gap:8px;padding:40px 0;}
.page-btn{width:40px;height:40px;border-radius:10px;border:1px solid #ddd;background:white;display:grid;place-items:center;font-size:14px;font-weight:700;color:var(--dark);cursor:pointer;transition:.2s;}
.page-btn:hover{background:var(--blue);color:white;border-color:var(--blue);}
.page-btn.active{background:var(--navy);color:white;border-color:var(--navy);}
.page-btn.arrow{font-size:18px;}

/* ================= PORTFOLIO ================= */
.portfolio-filters{display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap;margin-bottom:40px;}
.filter-btn{padding:8px 22px;border-radius:999px;border:2px solid var(--grey);background:transparent;font-family:var(--font-title);text-transform:uppercase;font-size:13px;font-weight:700;cursor:pointer;transition:.2s;color:var(--dark);}
.filter-btn:hover,.filter-btn.active{background:var(--navy);color:white;border-color:var(--navy);}
.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.portfolio-card{border-radius:20px;overflow:hidden;position:relative;min-height:260px;background-size:cover;background-position:center;box-shadow:0 10px 28px rgba(0,40,70,.1);cursor:pointer;transition:transform .25s ease;}
.portfolio-card:hover{transform:translateY(-5px);}
.portfolio-card::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 35%,rgba(0,40,70,.88) 100%);opacity:0;transition:.3s;}
.portfolio-card:hover::before{opacity:1;}
.portfolio-card-info{position:absolute;bottom:0;left:0;right:0;padding:22px;color:white;transform:translateY(10px);opacity:0;transition:.3s;}
.portfolio-card:hover .portfolio-card-info{transform:translateY(0);opacity:1;}
.portfolio-card-info h3{font-size:18px;color:white;margin-bottom:4px;}
.portfolio-card-info span{font-size:13px;color:rgba(255,255,255,.75);font-family:var(--font-title);text-transform:uppercase;}
.portfolio-card.large{grid-column:span 2;}

/* Lightbox */
.lb{position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,.92);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .25s ease;}
.lb.is-open{opacity:1;}
.lb[hidden]{display:none!important;}
.lb-fig{position:relative;max-width:min(1100px,calc(100vw - 130px));max-height:calc(100vh - 90px);display:flex;align-items:center;justify-content:center;}
.lb-fig img{max-width:100%;max-height:calc(100vh - 90px);border-radius:12px;box-shadow:0 20px 60px rgba(0,0,0,.5);display:block;transition:opacity .2s ease;}
.lb-caption{position:absolute;bottom:-34px;left:0;right:0;text-align:center;color:rgba(255,255,255,.7);font-size:13px;line-height:1.4;}
.lb-close{position:fixed;top:18px;right:20px;background:rgba(255,255,255,.12);border:0;color:white;width:44px;height:44px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.2s;z-index:1001;}
.lb-close:hover{background:rgba(255,255,255,.28);}
.lb-prev,.lb-next{position:fixed;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.12);border:0;color:white;width:52px;height:52px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.2s;z-index:1001;}
.lb-prev{left:14px;}.lb-next{right:14px;}
.lb-prev:hover,.lb-next:hover{background:rgba(255,255,255,.28);}
.lb-counter{position:fixed;bottom:18px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.55);font-size:13px;font-family:var(--font-title);letter-spacing:.5px;}
.lb-trigger{cursor:pointer;}
.lb-zoom{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,40,70,.25);opacity:0;transition:.25s;pointer-events:none;}
.lb-trigger:hover .lb-zoom{opacity:1;}
@media(max-width:580px){.lb-prev{left:4px;}.lb-next{right:4px;}.lb-fig{max-width:calc(100vw - 20px);}}.lb-caption[hidden]{display:none;}

/* Portfolio single */
.portfolio-single-header{padding:50px 0 30px;}
.portfolio-meta-bar{display:flex;gap:40px;padding:24px 0;border-top:1px solid #eee;border-bottom:1px solid #eee;margin:24px 0 40px;flex-wrap:wrap;}
.portfolio-meta-item{display:flex;flex-direction:column;gap:4px;}
.portfolio-meta-item strong{font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:#888;font-family:var(--font-title);}
.portfolio-meta-item span{font-size:15px;font-weight:700;color:var(--navy);}
.portfolio-gallery{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:40px 0;}
.gallery-img{border-radius:16px;overflow:hidden;min-height:240px;background-size:cover;background-position:center;}
.gallery-img.tall{grid-row:span 2;}

/* ================= TEAM ================= */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;margin-top:40px;}
.team-card{border-radius:20px;overflow:hidden;background:white;box-shadow:0 8px 24px rgba(0,40,70,.08);transition:transform .22s ease;}
.team-card:hover{transform:translateY(-4px);}
.team-card-photo{height:230px;background-size:cover;background-position:top center;position:relative;}
.team-card-photo::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(0,40,70,.3) 100%);}
.team-card-body{padding:20px 22px 24px;}
.team-card-body h3{font-size:18px;color:var(--navy);margin-bottom:4px;text-transform:none;}
.team-card-body .role{font-family:var(--font-title);text-transform:uppercase;font-size:13px;color:var(--red);display:block;margin-bottom:12px;}
.team-card-body p{font-size:13px;color:#555;line-height:1.55;margin:0;}
.team-card-body .social{display:flex;gap:10px;margin-top:14px;}
.team-card-body .social a{width:32px;height:32px;border-radius:8px;background:var(--light);display:grid;place-items:center;font-size:14px;color:var(--dark);transition:.2s;}
.team-card-body .social a:hover{background:var(--blue);color:white;}

/* Team single */
.team-single-grid{display:grid;grid-template-columns:360px 1fr;gap:60px;align-items:start;padding:60px 0;}
.team-single-photo{border-radius:24px;overflow:hidden;min-height:440px;background-size:cover;background-position:top center;box-shadow:0 20px 40px rgba(0,40,70,.14);}
.team-single-info .role-badge{display:inline-flex;padding:6px 18px;background:var(--red);color:white;border-radius:999px;font-family:var(--font-title);text-transform:uppercase;font-size:13px;margin-bottom:18px;}
.team-single-info h1{font-size:clamp(32px,3.5vw,52px);margin-bottom:20px;text-transform:none;}
.team-single-info .bio{color:#444;line-height:1.75;margin-bottom:30px;}
.team-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:30px 0;}
.team-stat{text-align:center;background:var(--light);border-radius:14px;padding:20px 12px;}
.team-stat strong{display:block;font-family:var(--font-title);font-size:32px;color:var(--red);margin-bottom:4px;}
.team-stat span{font-size:13px;color:#666;}
.team-contact-card{background:var(--navy);border-radius:18px;padding:26px;color:white;margin-top:28px;}
.team-contact-card h4{color:white;margin-bottom:16px;}
.team-contact-card a{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.85);margin:10px 0;font-size:14px;}
.team-contact-card a:hover{color:white;}

/* ================= CLIENTS / TESTIMONIALS ================= */
.clients-logos{display:grid;grid-template-columns:repeat(5,1fr);gap:22px;align-items:center;padding:50px 0;}
.client-logo{border:1px solid var(--grey);border-radius:14px;padding:22px;display:grid;place-items:center;min-height:90px;transition:.2s;background:white;}
.client-logo:hover{border-color:var(--blue);box-shadow:0 8px 20px rgba(0,105,179,.1);}
.client-logo span{font-family:var(--font-title);text-transform:uppercase;font-size:17px;color:#bbb;font-weight:900;}
.client-logo:hover span{color:var(--navy);}
.testimonials{background:var(--light);padding:70px 0;}
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:40px;}
.testimonial-card{background:white;border-radius:18px;padding:28px;box-shadow:0 8px 20px rgba(0,40,70,.07);}
.testimonial-card .stars{color:#f5a623;font-size:16px;margin-bottom:14px;}
.testimonial-card blockquote{margin:0 0 20px;font-style:italic;color:#444;line-height:1.65;font-size:14px;}
.testimonial-author{display:flex;align-items:center;gap:14px;}
.testimonial-avatar{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--navy));display:grid;place-items:center;font-family:var(--font-title);font-size:18px;color:white;flex-shrink:0;}
.testimonial-author h5{margin:0 0 2px;font-size:14px;color:var(--navy);}
.testimonial-author span{font-size:12px;color:#888;}
.stats-band{background:var(--navy);padding:60px 0;}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center;}
.stat-item strong{display:block;font-family:var(--font-title);font-size:clamp(42px,5vw,68px);color:var(--red);line-height:1;}
.stat-item span{font-size:14px;color:rgba(255,255,255,.75);margin-top:8px;display:block;}

/* ================= RSE ================= */
.rse-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px;margin-top:40px;}
.rse-card{border-radius:18px;padding:32px;background:white;box-shadow:0 8px 22px rgba(0,40,70,.08);}
.rse-card-icon{width:56px;height:56px;border-radius:16px;margin-bottom:18px;display:grid;place-items:center;font-size:26px;}
.rse-card h3{font-size:19px;color:var(--navy);margin-bottom:12px;}
.rse-card p{margin:0;font-size:14px;color:#555;line-height:1.65;}
.rse-timeline{padding:60px 0;}
.timeline{position:relative;padding-left:40px;}
.timeline::before{content:'';position:absolute;left:12px;top:0;bottom:0;width:2px;background:var(--grey);}
.timeline-item{position:relative;margin-bottom:36px;}
.timeline-item::before{content:'';position:absolute;left:-34px;top:6px;width:16px;height:16px;border-radius:50%;background:var(--red);border:3px solid white;box-shadow:0 0 0 2px var(--red);}
.timeline-item h4{font-size:15px;color:var(--navy);margin-bottom:6px;}
.timeline-item p{margin:0;font-size:14px;color:#555;}
.timeline-year{font-family:var(--font-title);font-size:22px;color:var(--red);margin-bottom:8px;display:block;}

/* ================= FORM WIZARD ================= */
.wizard-section{padding:60px 0;}
.wizard-container{max-width:720px;margin:0 auto;}
.wizard-steps-nav{display:flex;align-items:center;margin-bottom:46px;}
.wizard-step-item{display:flex;align-items:center;gap:10px;flex:1;}
.wizard-step-item:last-child{flex:0;}
.wizard-step-num{width:38px;height:38px;border-radius:50%;border:2px solid var(--grey);background:white;display:grid;place-items:center;font-family:var(--font-title);font-size:16px;font-weight:900;color:#aaa;flex-shrink:0;transition:.3s;}
.wizard-step-num.done{background:var(--blue);border-color:var(--blue);color:white;}
.wizard-step-num.active{background:var(--navy);border-color:var(--navy);color:white;}
.wizard-step-label{font-size:12px;font-weight:700;text-transform:uppercase;color:#aaa;font-family:var(--font-title);}
.wizard-step-label.active{color:var(--navy);}
.wizard-step-label.done{color:var(--blue);}
.wizard-connector{flex:1;height:2px;background:var(--grey);margin:0 8px;transition:.3s;}
.wizard-connector.done{background:var(--blue);}
.wizard-panel{display:none;animation:fadeIn .3s ease;}
.wizard-panel.active{display:block;}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}
.wizard-form{background:white;border-radius:24px;padding:40px;box-shadow:0 16px 40px rgba(0,40,70,.1);}
.wizard-form h3{font-size:22px;color:var(--navy);margin-bottom:6px;text-transform:none;}
.wizard-form .subtitle{font-size:14px;color:#888;margin-bottom:28px;}
.wizard-field{margin-bottom:18px;}
.wizard-field label{display:block;font-size:13px;font-weight:700;color:var(--dark);margin-bottom:6px;text-transform:uppercase;letter-spacing:.3px;}
.wizard-field input,.wizard-field select,.wizard-field textarea{border:1.5px solid #e0e0e0;border-radius:10px;padding:12px 16px;font-size:15px;transition:.2s;background:white;}
.wizard-field input:focus,.wizard-field select:focus,.wizard-field textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(0,105,179,.12);}
.wizard-options{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;}
.wizard-option{border:2px solid #e0e0e0;border-radius:12px;padding:16px;cursor:pointer;transition:.2s;display:flex;align-items:center;gap:12px;}
.wizard-option:hover{border-color:var(--blue);}
.wizard-option.selected{border-color:var(--navy);background:rgba(0,40,70,.04);}
.wizard-option-icon{font-size:24px;}
.wizard-option strong{display:block;font-size:14px;color:var(--navy);}
.wizard-option span{font-size:12px;color:#888;}
.wizard-nav{display:flex;justify-content:space-between;align-items:center;margin-top:32px;}
.wizard-btn-prev{background:var(--light);border:0;border-radius:10px;padding:12px 28px;font-family:var(--font-title);text-transform:uppercase;font-size:15px;cursor:pointer;color:var(--dark);}
.wizard-btn-next,.wizard-btn-submit{background:var(--navy);border:0;border-radius:10px;padding:12px 32px;font-family:var(--font-title);text-transform:uppercase;font-size:15px;cursor:pointer;color:white;transition:.2s;}
.wizard-btn-next:hover,.wizard-btn-submit:hover{background:var(--blue);}
.wizard-progress{height:4px;background:var(--grey);border-radius:999px;margin-bottom:36px;}
.wizard-progress-bar{height:100%;background:var(--blue);border-radius:999px;transition:.4s ease;}
.wizard-success{text-align:center;padding:50px 30px;}
.wizard-success .check{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--navy));display:grid;place-items:center;margin:0 auto 24px;font-size:36px;}

/* ================= MENTIONS LÉGALES ================= */
.legal-content{padding:60px 0;max-width:760px;}
.legal-content h2{font-size:24px;text-transform:none;margin:36px 0 14px;padding-top:36px;border-top:1px solid #eee;}
.legal-content h2:first-child{border-top:0;margin-top:0;padding-top:0;}
.legal-content p{line-height:1.75;color:#444;margin:0 0 14px;}
.legal-content a{color:var(--blue);}

/* ================= FOOTER (FDM : fond noir) ================= */
.footer{background:var(--black);color:white;padding:62px 0;}
.footer-grid{display:grid;grid-template-columns:1.4fr repeat(3,1fr);gap:40px;}
.footer-logo{display:inline-block;margin-bottom:18px;}
.footer-logo img{height:46px;width:auto;}
.footer h4{color:var(--orange);margin-bottom:14px;font-size:15px;letter-spacing:0;}
.footer a{display:block;opacity:.82;margin:7px 0;}
.footer a:hover{opacity:1;color:var(--orange);}
.footer p{opacity:.82;margin:8px 0;}
.footer-bottom{background:#000;padding:16px 0;text-align:center;font-size:13px;opacity:.7;}

/* ================= CMS EXTRAS (alertes, images PHP) ================= */
.alert-success{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0;border-radius:10px;padding:14px 18px;margin-bottom:20px;}
.alert-error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca;border-radius:10px;padding:14px 18px;margin-bottom:20px;}
.portfolio-card img,.gallery-img img{width:100%;height:100%;object-fit:cover;display:block;}
picture img{display:block;width:100%;height:100%;object-fit:cover;}
.empty-state{text-align:center;padding:60px 0;color:#888;}

/* ================= RESPONSIVE ================= */
@media (max-width:1280px){
  .header-inner{gap:18px;}
  .main-nav{gap:18px;}
  .phone-link{font-size:17px;}
  .project-btn{font-size:16px;padding:0 18px;}
  .team-grid{grid-template-columns:repeat(3,1fr);}
  .prestations-grid{gap:20px;}
}
@media (max-width:1100px){
  .prev{left:0;}.next{right:0;}
  .header-actions{display:none;}
  .main-nav{justify-content:flex-end;}
  .blog-layout{grid-template-columns:1fr;}
  .sidebar{display:grid;grid-template-columns:repeat(2,1fr);}
  .team-grid{grid-template-columns:repeat(2,1fr);}
  .clients-logos{grid-template-columns:repeat(4,1fr);}
}
@media (max-width:900px){
  .hero{min-height:560px;}
  .menu-toggle{display:block;}
  .main-nav{position:absolute;top:70px;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;background:white;border-radius:0 0 18px 18px;box-shadow:0 16px 26px rgba(0,0,0,.14);transform:scaleY(0);transform-origin:top;transition:.25s ease;overflow:hidden;}
  .main-nav.open{transform:scaleY(1);}
  .nav-link{width:100%;text-align:left;padding:15px 24px;border-top:1px solid #eee;}
  .simple-link{display:block;}
  .dropdown-menu{position:static;min-width:0;box-shadow:none;border-radius:0;padding:0 0 8px 18px;opacity:1;visibility:visible;transform:none;display:none;background:#f7f7f7;}
  .has-dropdown.open .dropdown-menu{display:block;}
  .hero-content{padding-top:128px;}
  .hero-actions{gap:14px;}
  .btn{width:min(100%,310px);}
  .story-grid,.zone-grid,.contact-grid,.service-intro,.team-single-grid,.project-single-layout{grid-template-columns:1fr;}
  .services-grid{grid-template-columns:repeat(2,1fr);}
  .cta-grid,.slider-track,.footer-grid{grid-template-columns:1fr 1fr;}
  .story-collage{order:-1;}
  .features-grid,.testimonials-grid,.rse-grid{grid-template-columns:repeat(2,1fr);}
  .blog-grid{grid-template-columns:repeat(2,1fr);}
  .portfolio-grid,.projects-grid{grid-template-columns:repeat(2,1fr);}
  .portfolio-card.large{grid-column:span 1;}
  .team-grid{grid-template-columns:repeat(2,1fr);}
  .clients-logos{grid-template-columns:repeat(3,1fr);}
  .stats-grid{grid-template-columns:repeat(2,1fr);}
  .project-card{grid-template-columns:1fr;}
  .project-card-img{min-height:180px;}
  .prestations-section{padding:54px 0 58px;}
  .prestations-grid{grid-template-columns:repeat(2,1fr);}
  .sidebar{grid-template-columns:1fr;}
}
@media (max-width:580px){
  .container{width:min(100% - 24px,1080px);}
  .section,.zone,.contact{padding:42px 0;}
  .hero{min-height:520px;margin-top:0;}
  .hero h1{font-size:38px;}
  .hero-actions{flex-direction:column;margin-top:28px;}
  .services-grid,.values-grid,.cta-grid,.slider-track,.footer-grid,.form-grid{grid-template-columns:1fr;}
  .big-card{min-height:160px;font-size:29px;}
  .story-collage{min-height:290px;}
  .contact-truck{min-height:210px;}
  .submit-btn{width:100%;float:none;}
  .logo-main{font-size:38px;}
  .logo-sub{margin-left:42px;}
  .blog-grid,.portfolio-grid,.team-grid,.projects-grid,.features-grid,.testimonials-grid,.rse-grid,.departments-list{grid-template-columns:1fr;}
  .clients-logos{grid-template-columns:repeat(2,1fr);}
  .stats-grid{grid-template-columns:repeat(2,1fr);}
  .wizard-options{grid-template-columns:1fr;}
  .portfolio-meta-bar{gap:20px;}
  .prestations-section{padding:44px 0;}
  .prestations-heading h2{font-size:38px;}
  .prestations-grid{grid-template-columns:1fr;gap:18px;}
  .prestation-card{min-height:360px;border-radius:24px;}
}


/* ============================================================
   THÈME FDM — fidèle à pages/index.html (référence)
   ============================================================ */
@font-face{
  font-family:"Tanker";
  src:url("../fonts/Tanker-Regular.woff2") format("woff2"),
      url("../fonts/Tanker-Regular.woff") format("woff");
  font-weight:400;
  font-style:normal;
  font-display:swap;
}

:root{
  --orange:#f59c00;
  --black:#050505;
  --text:#181818;
  --white:#fff;
  --font-title:"Tanker",Impact,sans-serif;
  --font-body:"Montserrat",Arial,sans-serif;
}

*{box-sizing:border-box}

body{
  margin:0;
  background:#fff;
  color:var(--text);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.45;
}

img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}

.wrap{
  width:calc(100% - 40px);
  max-width:1320px;
  margin:0 auto;
}

h1,h2,h3,
.btn,
.breadcrumb,
.hero p,
.nav-cta,
.link,
.phone,
.vanbox,
.vertical-card span,
.sector-card span{
  font-family:var(--font-title);
  text-transform:uppercase;
  font-weight: 100;
}

h1{
  margin:0;
  font-size:clamp(42px,5.6vw,50px);
  line-height:.92;
  letter-spacing:-1px;
  color:#fff;
  max-width:560px;
}

h2{
  margin:0;
  font-size:clamp(34px,4vw,45px);
  line-height:.92;
  letter-spacing:-.5px;
}

h3{
  margin:0;
  font-size:26px;
  line-height:1;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  padding:12px 24px;
  font-size:17px;
  background:#000;
  color:#fff;
}

.btn.orange{background:var(--orange);color:#000}
.btn.white{background:#fff;color:#000}

.stripe {
    margin-bottom: 25px;
}
.stripe.center .pic{
    text-align: center;
    margin: 0 auto;
}
.stripe .pic{
    max-width: 230px;
}

header{
  background:#fff;
  position:sticky;
  top:0;
  z-index:10;
  box-shadow:0 1px 8px rgba(0,0,0,.08);
}

.nav{
  height:70px;
  display:flex;
  align-items:center;
  justify-content:space-between;
}

.brand img{height:70px;}

.menu{
  display:flex;
  gap:30px;
  font-size:13px;
  font-weight:700;
  text-transform:uppercase;
}

.nav-cta{
  background:var(--orange);
  border-radius:999px;
  padding:10px 18px;
  font-size:17px;
}

.hamb{
  display:none;
  border:0;
  background:#000;
  color:#fff;
  border-radius:50%;
  width:39px;
  height:39px;
  cursor:pointer;
}

.hero{
  min-height:420px;
  background:
    linear-gradient(90deg,rgba(0,0,0,.88),rgba(0,0,0,.45),rgba(0,0,0,.05)),
    url("../img/hero.jpg") center/cover no-repeat;
  display:grid;
  align-items:center;
}

.hero .subtitle{
  color:#fff;
  font-size:18px;
  margin-bottom:18px;
  letter-spacing:.8px;
  border-bottom: 2px solid var(--orange);
  font-family:var(--font-title);
  display: inline-block;
}
.hero .wrap{
    margin: 40px auto;
}

.hero h1{
    line-height: 60px;
}
.hero p{
  color:var(--orange);
  font-size:25px;
  margin:12px 0 22px;
}

.hero-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}

section{padding:58px 0}

.services{
  background:var(--orange);
  text-align:center;
}

.services .intro{
  max-width:780px;
  margin:10px auto 34px;
  color:#311c00;
}

.service-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
  margin:0 auto;
}
.service-grid h3{
    text-align: center;
}
.service-grid h3 span{
    font-size: 0.7em;
    color: var(--orange);
    display: block;
}
.card{
  background:#fff;
  border-radius:12px;
  overflow:hidden;
  text-align:left;
  box-shadow:0 9px 22px rgba(0,0,0,.18);
}

.card .pic{
  height:250px;
  width:100%;
  object-fit:cover;
  border:8px solid #fff;
  border-radius:15px;
}

.card-body{
  padding:10px 13px 16px;
}

.link{
  color:var(--orange);
  font-size:16px;
}

.products{
  background:#fff;
}

.product-row{
  display:grid;
  grid-template-columns:1.1fr 2.4fr;
  gap:34px;
  align-items:center;
}

.product-cards{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:17px;
}

.vertical-card{
  height:320px;
  border-radius:13px;
  overflow:hidden;
  position:relative;
  background:#000;
  box-shadow:0 9px 22px rgba(0,0,0,.18);
}

.vertical-card img{
  width:100%;
  height:100%;
  object-fit:cover;
  opacity:.86;
}

.vertical-card span{
  position:absolute;
  left:14px;
  bottom:50px;
  color:#fff;
  font-size:24px;
  line-height:.9;
}

.vertical-card small{
  position:absolute;
  left:14px;
  bottom:16px;
  color:#fff;
  font-size:13px;
}

.sectors{
  background:#e5e5e5;
}

.sector-row{
  display:grid;
  grid-template-columns:2fr 1fr;
  gap:40px;
  align-items:center;
}

.sector-cards{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
}

.sector-card{
  height:320px;
  border-radius:13px;
  overflow:hidden;
  position:relative;
  background:#000;
}

.sector-card img{
  width:100%;
  height:100%;
  object-fit:cover;
  opacity:.84;
}

.sector-card span{
  position:absolute;
  left:13px;
  bottom:34px;
  color:#fff;
  font-size:24px;
  line-height:.9;
}

.sector-card small{
  position:absolute;
  left:13px;
  bottom:14px;
  color:#fff;
  font-size:11px;
}

.orange-txt{color:var(--orange)}
.white-txt{color:var(--white)}

.maintenance{
  padding:0;
  background:#000;
}

.maintenance .subtitle{
    font-family: "Tanker";
    color: var(--white);
    font-size: 25px;;
}

.maintenance-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  min-height:420px;
}

.maintenance-text{
  color:#fff;
  padding:64px max(4vw,28px) 55px calc((100vw - min(1320px, calc(100vw - 40px))) / 2);
}

.maintenance-text h2{
  color:var(--orange);
  max-width:450px;
}

.maintenance-text ul{
  columns:2;
  padding-left:18px;
  margin:22px 0;
}

.maintenance-img{
  background:url("../img/maintenance.jpg") center/cover no-repeat;
}

.gallery{text-align:center}

.gallery-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  margin:26px auto 0;
}

.gallery-grid img{
  height:300px;
  width:100%;
  object-fit:cover;
  border-radius:8px;
}

.zone{
  background:#e9e9e9;
}

.zone-grid{
  display:grid;
  grid-template-columns:1.05fr 1fr;
  gap:50px;
  align-items:center;
}

.zone img{
  width:100%;
  max-height:100%;
  object-fit:contain;
}

.zone h2{color:var(--orange)}

.news{text-align:center}

.news-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  margin:30px auto;
}

.news-card{
  background:#fff;
  border:1px solid #ddd;
  border-radius:13px;
  overflow:hidden;
  text-align:left;
  box-shadow:0 3px 12px rgba(0,0,0,.12);
}

.news-card img{
  height:155px;
  width:100%;
  object-fit:cover;
  border:8px solid #fff;
  border-radius:13px;
}

.news-card div{
  padding:0 15px 16px;
}

.trust{
  text-align:center;
  padding-top:20px;
}

.logos{
  display:flex;
  justify-content:center;
  gap:42px;
  align-items:center;
  flex-wrap:wrap;
  filter:grayscale(1);
  opacity:.38;
  margin-top:30px;
}

.logos span{
  font-family:Georgia,serif;
  font-size:28px;
  font-weight:700;
  color:#777;
}

.contact{
  background:var(--orange);
  padding:45px 0;
}

.contact h2{
    margin-bottom: 25px;
}

.contact-grid{
  display:grid;
  grid-template-columns:.9fr 1.3fr;
  gap:40px;
  align-items:center;
}

.vanbox{
  position:relative;
  width:100%;
  max-width:350px;
  margin:auto;
  padding-top:22px;
  text-align:center;
  font-family:"Tanker",sans-serif;
  text-transform:uppercase;
}

.vanbox img{
  margin:0 auto 20px;
}

.vanbox .pushline{
  position:absolute;
  bottom: 95px;
  left:50%;
  transform:translateX(-50%) rotate(2deg);

  background:#5f5f5f;
  color:#fff;

  padding:6px 16px;
  font-size:18px;
  line-height:1;

  white-space:nowrap;

  z-index:3;
  box-shadow:0 3px 6px rgba(0,0,0,.25);
}
.vanbox .phone{
  background:#ffffff;
  color:#000000;
  border-radius:60px;
  font-size:42px;
  line-height:1;
  padding:20px 15px 14px;
  box-shadow:0 8px 15px rgba(0,0,0,.25);
  position:relative;
  z-index:2;
}
.vanbox .subtitle{
  width:78%;
  margin:-6px auto 0;
  background:#000;
  color:#fff;
  font-size:16px;
  line-height:1;
  padding:14px 10px 10px;
  border-radius:0 0 10px 10px;
  position:relative;
  z-index:1;
}

.contact form{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}

.contact input,
.contact textarea{
  border:0;
  border-radius:5px;
  padding:14px 15px;
  font-family:var(--font-body);
}

.contact textarea{
  grid-column:1/-1;
  min-height:96px;
  resize:vertical;
}

.contact button[type=submit]{
  grid-column:2;
  justify-self:end;
  border:0;
  cursor:pointer;
  padding-inline:36px;
}

footer{
  background:#030303;
  color:#fff;
  padding:50px 0;
}

.foot-grid{
  display:grid;
  grid-template-columns:1.3fr repeat(3,1fr);
  gap:40px;
}

footer img{
  height:70px;
}

footer h3{
  color:#fff;
  margin-bottom:12px;
}

footer p,
footer li{
  font-size:13px;
  color:#ccc;
}

footer ul{
  list-style:none;
  margin:0;
  padding:0;
}

@media(max-width:850px){
  .wrap{
    width:calc(100% - 30px);
  }

  .menu,
  .nav-cta{
    display:none;
  }

  .hamb{
    display:block;
  }

  .menu.open{
    display:flex;
    position:absolute;
    left:0;
    right:0;
    top:58px;
    background:#fff;
    flex-direction:column;
    padding:20px;
    box-shadow:0 10px 20px rgba(0,0,0,.15);
  }

  .service-grid,
  .product-cards,
  .sector-cards,
  .news-grid{
    grid-template-columns:1fr 1fr;
  }

  .product-row,
  .sector-row,
  .maintenance-grid,
  .zone-grid,
  .contact-grid,
  .foot-grid{
    grid-template-columns:1fr;
  }

  .maintenance-text{
    padding:44px 6vw;
  }

  .maintenance-img{
    min-height:280px;
  }
}

@media(max-width:560px){
  .service-grid,
  .product-cards,
  .sector-cards,
  .news-grid,
  .gallery-grid{
    grid-template-columns:1fr;
  }

  form{
    grid-template-columns:1fr;
  }

  button[type=submit]{
    grid-column:1;
    width:100%;
  }

  .hero{
    min-height:520px;
  }

  .btn{
    width:100%;
  }
}

/* ============================================================
   PAGES INTERNES (services, blog, photos, mentions légales)
   ============================================================ */

/* --- Bannière de page + fil d'ariane --- */
.page-hero{
  background:
    linear-gradient(90deg,rgba(0,0,0,.92),rgba(0,0,0,.55)),
    var(--black);
  color:#fff;
  padding:64px 0 58px;
}

.page-hero .breadcrumb{
  font-size:13px;
  color:#bdbdbd;
  letter-spacing:.5px;
  margin-bottom:16px;
}

.page-hero .breadcrumb a{color:var(--orange)}
.page-hero .breadcrumb span{margin:0 8px;color:#666}

.page-hero h1{
  color:#fff;
  max-width:760px;
}

.page-hero .lead{
  color:#ccc;
  font-size:18px;
  max-width:680px;
  margin-top:16px;
}

.page-hero .accent{
  display:inline-block;
  font-family:var(--font-title);
  text-transform:uppercase;
  color:#fff;
  font-size:16px;
  letter-spacing:.8px;
  border-bottom:2px solid var(--orange);
  margin-bottom:18px;
}

/* --- Blocs détail alternés (page services) --- */
.detail{padding:56px 0}
.detail:nth-child(even){background:#f5f5f5}

.detail-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:46px;
  align-items:center;
}

.detail-row.reverse .detail-media{order:2}

.detail-media img{
  width:100%;
  height:360px;
  object-fit:cover;
  border-radius:14px;
  box-shadow:0 12px 28px rgba(0,0,0,.18);
}

.detail-text h2{margin-bottom:14px}
.detail-text .accent{
  display:inline-block;
  font-family:var(--font-title);
  text-transform:uppercase;
  color:var(--orange);
  font-size:15px;
  letter-spacing:.8px;
  margin-bottom:8px;
}

.detail-text ul{
  list-style:none;
  margin:18px 0 24px;
  padding:0;
}

.detail-text li{
  position:relative;
  padding-left:26px;
  margin-bottom:9px;
}

.detail-text li::before{
  content:"";
  position:absolute;
  left:0;
  top:7px;
  width:12px;
  height:12px;
  border-radius:50%;
  background:var(--orange);
}

/* --- Bandeau CTA --- */
.cta-band{
  background:var(--orange);
  text-align:center;
  padding:54px 0;
}
.cta-band h2{margin-bottom:22px}
.cta-band .hero-actions{justify-content:center}

/* ===== Composants CTA réutilisables (dans .rich / le contenu) ===== */

/* Encadré CTA clair */
.cta-box{
  background:#faf6ef;
  border:1px solid #f0e6d4;
  border-left:5px solid var(--orange);
  border-radius:14px;
  padding:28px 30px;
  margin:28px 0;
}
.cta-box h3{margin:0 0 8px;font-size:22px}
.cta-box p{margin:0 0 16px}
.cta-box .hero-actions{margin:0;flex-wrap:wrap}

/* Variante sombre */
.cta-box.dark{
  background:var(--black);
  border-color:var(--black);
  border-left-color:var(--orange);
  color:#fff;
}
.cta-box.dark h3{color:#fff}
.cta-box.dark p{color:#d9d9d9}

/* Barre CTA : texte à gauche, bouton à droite */
.cta-inline{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  flex-wrap:wrap;
  background:#fff;
  border:1px solid #e7e7e7;
  border-radius:14px;
  padding:22px 26px;
  margin:26px 0;
  box-shadow:0 8px 22px rgba(0,0,0,.06);
}
.cta-inline .cta-inline-txt{flex:1 1 320px}
.cta-inline .cta-inline-txt strong{display:block;font-size:19px;margin-bottom:2px}
.cta-inline .cta-inline-txt span{color:#666;font-size:15px}

/* Bloc téléphone / urgence */
.cta-phone{
  display:flex;
  align-items:center;
  gap:18px;
  flex-wrap:wrap;
  background:var(--black);
  color:#fff;
  border-radius:14px;
  padding:24px 28px;
  margin:26px 0;
}
.cta-phone .cta-phone-ico{font-size:30px;line-height:1}
.cta-phone .cta-phone-num{
  font-family:var(--font-title);
  font-size:30px;
  color:var(--orange);
  text-decoration:none;
  line-height:1.1;
}
.cta-phone .cta-phone-num small{display:block;font-family:var(--font-body);font-size:13px;color:#cfcfcf;font-weight:500}

/* Lien-flèche discret */
.cta-link{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-weight:700;
  color:var(--orange);
  text-decoration:none;
}
.cta-link::after{content:"→";transition:transform .2s ease}
.cta-link:hover::after{transform:translateX(4px)}

@media(max-width:560px){
  .cta-inline{flex-direction:column;align-items:flex-start}
  .cta-phone{flex-direction:column;align-items:flex-start;text-align:left}
}

/* --- Liste de blog --- */
.blog-list{padding:56px 0}

.blog-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:26px;
}

.blog-card{
  background:#fff;
  border:1px solid #e4e4e4;
  border-radius:14px;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  box-shadow:0 4px 14px rgba(0,0,0,.08);
  transition:transform .15s ease, box-shadow .15s ease;
}

.blog-card:hover{
  transform:translateY(-4px);
  box-shadow:0 12px 26px rgba(0,0,0,.14);
}

.blog-card img{
  height:190px;
  width:100%;
  object-fit:cover;
}

.blog-card .blog-body{
  padding:18px 20px 22px;
  display:flex;
  flex-direction:column;
  flex:1;
}

.blog-meta{
  font-family:var(--font-title);
  text-transform:uppercase;
  font-size:12px;
  letter-spacing:.6px;
  color:var(--orange);
  margin-bottom:10px;
}

.blog-card h3{margin-bottom:10px;font-size:22px}
.blog-card p{flex:1;margin:0 0 14px}

/* --- Pagination --- */
.pagination{
  display:flex;
  justify-content:center;
  gap:8px;
  margin-top:40px;
}

.pagination a{
  font-family:var(--font-title);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:42px;
  height:42px;
  padding:0 12px;
  border-radius:8px;
  border:1px solid #ddd;
  background:#fff;
}

.pagination a.active{
  background:var(--orange);
  border-color:var(--orange);
  color:#000;
}

/* --- Article de blog --- */
.article{padding:54px 0}

.article-wrap{
  max-width:760px;
  margin:0 auto;
}

.article-cover{
  width:100%;
  height:380px;
  object-fit:cover;
  border-radius:16px;
  margin-bottom:30px;
}

.article-body p{margin:0 0 20px;font-size:17px;line-height:1.7}
.article-body h2{margin:36px 0 14px}
.article-body h3{margin:28px 0 12px}

.article-body ul,
.article-body ol{margin:0 0 20px;padding-left:22px}
.article-body li{margin-bottom:8px}

.article-body blockquote{
  margin:26px 0;
  padding:16px 22px;
  border-left:4px solid var(--orange);
  background:#f6f6f6;
  font-style:italic;
}

.article-share{
  margin-top:40px;
  padding-top:24px;
  border-top:1px solid #e4e4e4;
}

/* --- Liste de photos / albums --- */
.albums{padding:56px 0}

.album-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
}

.album-card{
  position:relative;
  height:280px;
  border-radius:14px;
  overflow:hidden;
  background:#000;
  box-shadow:0 8px 20px rgba(0,0,0,.16);
}

.album-card img{
  width:100%;
  height:100%;
  object-fit:cover;
  opacity:.86;
  transition:transform .25s ease;
}

.album-card:hover img{transform:scale(1.05)}

.album-card .album-overlay{
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  padding:18px 18px 16px;
  background:linear-gradient(transparent,rgba(0,0,0,.78));
  color:#fff;
}

.album-card .album-overlay span{
  font-family:var(--font-title);
  text-transform:uppercase;
  font-size:22px;
  line-height:1;
  display:block;
}

.album-card .album-overlay small{
  font-size:12px;
  color:#ddd;
}

/* --- Galerie d'un album --- */
.photo-gallery{padding:56px 0}

.photo-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}

.photo-grid img{
  width:100%;
  height:260px;
  object-fit:cover;
  border-radius:10px;
  cursor:pointer;
  transition:opacity .15s ease;
}

.photo-grid img:hover{opacity:.85}

/* --- Page de contenu légal --- */
.legal{padding:54px 0}

.legal-wrap{
  max-width:820px;
  margin:0 auto;
}

.legal-wrap h2{
  margin:34px 0 14px;
  font-size:26px;
  color:var(--orange);
}

.legal-wrap h2:first-child{margin-top:0}
.legal-wrap p{margin:0 0 16px}
.legal-wrap ul{margin:0 0 16px;padding-left:22px}
.legal-wrap li{margin-bottom:7px}
.legal-wrap a{color:var(--orange)}

@media(max-width:850px){
  .detail-row,
  .blog-grid,
  .album-grid{
    grid-template-columns:1fr 1fr;
  }

  .detail-row{grid-template-columns:1fr}
  .detail-row.reverse .detail-media{order:0}

  .photo-grid{grid-template-columns:1fr 1fr}
}

@media(max-width:560px){
  .blog-grid,
  .album-grid,
  .photo-grid{
    grid-template-columns:1fr;
  }
}

/* ============================================================
   LIGHTBOX
   ============================================================ */
.lightbox{
  position:fixed;
  inset:0;
  z-index:200;
  display:none;
  align-items:center;
  justify-content:center;
  padding:40px;
  background:rgba(0,0,0,.93);
}

.lightbox.open{display:flex}

.lightbox-img{
  max-width:92vw;
  max-height:84vh;
  border-radius:8px;
  box-shadow:0 14px 50px rgba(0,0,0,.55);
}

.lightbox-caption{
  position:absolute;
  bottom:24px;
  left:0;
  right:0;
  text-align:center;
  color:#eee;
  font-family:var(--font-title);
  text-transform:uppercase;
  font-size:14px;
  letter-spacing:.6px;
}

.lb-btn{
  position:absolute;
  background:rgba(255,255,255,.12);
  color:#fff;
  border:0;
  cursor:pointer;
  font-family:var(--font-title);
  display:flex;
  align-items:center;
  justify-content:center;
  transition:background .15s ease;
}

.lb-btn:hover{background:var(--orange);color:#000}

.lb-close{
  top:22px;
  right:24px;
  width:46px;
  height:46px;
  border-radius:50%;
  font-size:24px;
}

.lb-prev,
.lb-next{
  top:50%;
  transform:translateY(-50%);
  width:54px;
  height:54px;
  border-radius:50%;
  font-size:26px;
}

.lb-prev{left:24px}
.lb-next{right:24px}

@media(max-width:560px){
  .lb-prev{left:12px}
  .lb-next{right:12px}
  .lb-btn{width:44px;height:44px}
}

/* ============================================================
   PAGE CONTACT
   ============================================================ */
.contact-info{
  background:#fff;
  border:1px solid #e4e4e4;
  border-radius:14px;
  padding:26px 28px;
  box-shadow:0 4px 14px rgba(0,0,0,.06);
}

.contact-info h3{margin-bottom:16px;font-size:22px}

.info-list{
  list-style:none;
  margin:0 0 6px;
  padding:0;
}

.info-list li{
  display:flex;
  gap:12px;
  align-items:flex-start;
  padding:12px 0;
  border-bottom:1px solid #efefef;
}

.info-list li:last-child{border-bottom:0}

.info-list .ico{
  flex:0 0 38px;
  width:38px;
  height:38px;
  border-radius:50%;
  background:var(--orange);
  color:#000;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:18px;
}

.info-list .lbl{
  font-family:var(--font-title);
  text-transform:uppercase;
  font-size:12px;
  letter-spacing:.5px;
  color:#888;
  display:block;
}

.info-list .val{font-size:16px}
.info-list a{color:inherit}

.contact-form-card{
  background:#fff;
  border:1px solid #e4e4e4;
  border-radius:14px;
  padding:26px 28px;
  box-shadow:0 4px 14px rgba(0,0,0,.06);
}

.contact-map img{
  width:100%;
  border-radius:14px;
  margin-top:30px;
}

/* ============================================================
   PAGE PRODUIT (portes coulissantes)
   ============================================================ */
.product-intro{padding:54px 0}
.product-intro .lead-text{max-width:820px}
.product-intro .lead-text p{font-size:17px;line-height:1.7;margin:0 0 16px}

.feature-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
  margin-top:14px;
}

.feature{
  background:#fff;
  border:1px solid #e8e8e8;
  border-radius:13px;
  padding:24px 22px;
  box-shadow:0 4px 14px rgba(0,0,0,.06);
}

.feature .ico{
  width:46px;
  height:46px;
  border-radius:12px;
  background:var(--orange);
  color:#000;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:22px;
  margin-bottom:14px;
}

.feature h3{font-size:20px;margin-bottom:8px}

/* --- FAQ --- */
.faq{padding:54px 0;background:#f5f5f5}
.faq-wrap{max-width:820px;margin:0 auto}

.faq-item{
  background:#fff;
  border:1px solid #e6e6e6;
  border-radius:12px;
  padding:18px 22px;
  margin-bottom:14px;
}

.faq-item h3{
  font-size:19px;
  margin-bottom:8px;
  color:var(--orange);
}

.faq-item p{margin:0}

@media(max-width:850px){
  .feature-grid{grid-template-columns:1fr 1fr}
}

@media(max-width:560px){
  .feature-grid{grid-template-columns:1fr}
}

/* ============================================================
   CARROUSEL / SLIDER (gamme produits, secteurs)
   ============================================================ */
.carousel{position:relative}

.car-viewport{
  overflow:hidden;
  padding:10px 0 30px;
  touch-action:pan-y;
}

.car-track{
  display:flex;
  gap:18px;
  will-change:transform;
  transition:transform .45s ease;
}

/* Largeur des slides identique à la grille d'origine (4 / 3 / 2 / 1) */
.car-track > *{
  flex:0 0 calc((100% - 54px) / 4);
  user-select:none;
}

@media(max-width:1100px){
  .car-track > *{flex-basis:calc((100% - 36px) / 3)}
}
@media(max-width:850px){
  .car-track > *{flex-basis:calc((100% - 18px) / 2)}
}
@media(max-width:560px){
  .car-track > *{flex-basis:100%}
}

.car-track img{pointer-events:none}

.car-btn{
  position:absolute;
  top:calc(50% - 10px);
  transform:translateY(-50%);
  z-index:6;
  width:46px;
  height:46px;
  border:0;
  border-radius:50%;
  background:var(--orange);
  color:#000;
  cursor:pointer;
  font-family:var(--font-title);
  font-size:26px;
  line-height:1;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 6px 16px rgba(0,0,0,.25);
  transition:background .15s ease, color .15s ease;
}

.car-btn:hover{background:#000;color:#fff}
.car-prev{left:6px}
.car-next{right:6px}

@media(max-width:560px){
  .car-btn{width:40px;height:40px;font-size:22px}
}

/* ============================================================
   TABLEAU COMPARATIF (contrats de maintenance)
   ============================================================ */
.compare{padding:56px 0}

.table-wrap{
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  border-radius:16px;
  box-shadow:0 10px 30px rgba(0,0,0,.10);
}

.compare-table{
  width:100%;
  min-width:720px;
  border-collapse:collapse;
  background:#fff;
}

.compare-table th,
.compare-table td{
  padding:16px 18px;
  text-align:center;
  border-bottom:1px solid #ededed;
}

.compare-table thead th{
  background:var(--black);
  color:#fff;
  font-family:var(--font-title);
  text-transform:uppercase;
  font-size:18px;
  letter-spacing:.5px;
  vertical-align:top;
}

.compare-table thead th .price{
  display:block;
  color:var(--orange);
  font-size:15px;
  margin-top:6px;
}

.compare-table thead th.featured{
  background:var(--orange);
  color:#000;
  position:relative;
}

.compare-table thead th.featured .price{color:#000}

.compare-table thead th.featured::before{
  content:"Recommandé";
  position:absolute;
  top:8px;
  left:50%;
  transform:translateX(-50%);
  font-size:10px;
  letter-spacing:1px;
  background:#000;
  color:#fff;
  padding:2px 8px;
  border-radius:999px;
}

.compare-table tbody th{
  text-align:left;
  font-weight:600;
  background:#fafafa;
  font-family:var(--font-body);
  min-width:240px;
}

.compare-table tbody td.featured{background:#fff7ea}

.compare-table .yes{color:var(--orange);font-size:20px;font-weight:700}
.compare-table .no{color:#c9c9c9;font-size:18px}

.compare-table tfoot td{
  padding:22px 18px;
  background:#fafafa;
}

.compare-note{
  margin-top:16px;
  font-size:13px;
  color:#777;
  text-align:center;
}

/* ============================================================
   GRILLE DES VILLES (zones d'intervention)
   ============================================================ */
.city-intro{max-width:820px;margin-bottom:6px}

.city-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
  margin-top:26px;
}

.city-card{
  display:flex;
  align-items:center;
  gap:10px;
  background:#fff;
  border:1px solid #e6e6e6;
  border-radius:10px;
  padding:14px 16px;
  font-family:var(--font-title);
  text-transform:uppercase;
  font-size:15px;
  color:var(--text);
  transition:border-color .15s ease, box-shadow .15s ease;
}

.city-card::before{
  content:"⚲";
  color:var(--orange);
  font-size:18px;
}

.city-card:hover{
  border-color:var(--orange);
  box-shadow:0 6px 16px rgba(0,0,0,.10);
}

@media(max-width:850px){.city-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.city-grid{grid-template-columns:1fr 1fr}}

/* ============================================================
   FAQ — accordéon natif (details/summary)
   ============================================================ */
.accordion{max-width:840px;margin:0 auto}

.acc-item{
  background:#fff;
  border:1px solid #e6e6e6;
  border-radius:12px;
  margin-bottom:14px;
  overflow:hidden;
}

.acc-item summary{
  cursor:pointer;
  padding:18px 22px;
  font-family:var(--font-title);
  text-transform:uppercase;
  font-size:18px;
  letter-spacing:.4px;
  list-style:none;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
}

.acc-item summary::-webkit-details-marker{display:none}

.acc-item summary::after{
  content:"+";
  color:var(--orange);
  font-size:26px;
  line-height:1;
  flex:0 0 auto;
}

.acc-item[open] summary::after{content:"–"}

.acc-item .acc-body{
  padding:0 22px 20px;
}

.acc-item .acc-body p{margin:0}

.faq-cats{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  justify-content:center;
  margin-bottom:34px;
}

.faq-cats a{
  font-family:var(--font-title);
  text-transform:uppercase;
  font-size:13px;
  padding:8px 16px;
  border-radius:999px;
  background:#efefef;
}

.faq-cats a:hover{background:var(--orange);color:#000}

/* ============================================================
   CONTENU ÉDITABLE (WYSIWYG) — texte, Hn, images en colonnes
   Markup volontairement simple : <h2> <h3> <p> <ul> <img>
   et des rangées <div class="cols ..."> de 2 colonnes.
   ============================================================ */
.content{padding:54px 0}

.rich{max-width:1040px;margin:0 auto}

.rich > h2{
  font-size:clamp(28px,3.4vw,38px);
  line-height:1.05;
  margin:42px 0 16px;
}
.rich > h2:first-child{margin-top:0}

.rich > h3{
  font-size:24px;
  margin:28px 0 10px;
  color:var(--orange);
}

.rich p{font-size:17px;line-height:1.75;margin:0 0 18px}

.rich ul{margin:0 0 18px;padding-left:22px}
.rich li{margin-bottom:8px}

/* Liste de réassurance à puces "✓" */
.rich ul.check{list-style:none;padding-left:0;margin:0 0 22px}
.rich ul.check li{position:relative;padding-left:30px;margin-bottom:10px;font-weight:600}
.rich ul.check li::before{content:"✓";position:absolute;left:0;top:-1px;width:20px;height:20px;
  display:flex;align-items:center;justify-content:center;border-radius:50%;
  background:var(--orange);color:#000;font-size:12px;font-weight:700}

.rich img{
  width:100%;
  height:auto;
  border-radius:14px;
  display:block;
  box-shadow:0 10px 26px rgba(0,0,0,.14);
}

.rich a{color:var(--orange)}

/* Rangée 2 colonnes (image + texte ou texte + image) */
.cols{
  display:flex;
  gap:38px;
  align-items:center;
  margin:34px 0;
}

.cols.top{align-items:flex-start}
.cols > *{flex:1 1 0;min-width:0}      /* 50 / 50 par défaut */

/* Autres proportions */
.cols.c-60-40 > :first-child{flex:6}
.cols.c-60-40 > :last-child{flex:4}
.cols.c-40-60 > :first-child{flex:4}
.cols.c-40-60 > :last-child{flex:6}
.cols.c-70-30 > :first-child{flex:7}
.cols.c-70-30 > :last-child{flex:3}
.cols.c-30-70 > :first-child{flex:3}
.cols.c-30-70 > :last-child{flex:7}

@media(max-width:760px){
  .cols{flex-direction:column;gap:22px;align-items:stretch;margin:26px 0}
  .cols > *{flex:1 1 auto}
}

/* Élements de texte additionnels utilisables dans .rich */
.rich h4{font-size:19px;margin:22px 0 8px}
.rich ol{margin:0 0 18px;padding-left:22px}
.rich blockquote{
  margin:26px 0;
  padding:14px 22px;
  border-left:4px solid var(--orange);
  background:#f6f6f6;
  font-style:italic;
}
.rich hr{border:0;border-top:2px solid #ececec;margin:34px 0}
mark{background:#ffe6b8;padding:0 4px;border-radius:3px}

/* ============================================================
   GUIDE DE CONTENU / STYLEGUIDE (rendu + code à copier)
   ============================================================ */
.sg-section{padding:40px 0;border-bottom:1px solid #ececec}
.sg-section:last-child{border-bottom:0}

.sg-eyebrow{
  font-family:var(--font-title);
  text-transform:uppercase;
  color:var(--orange);
  font-size:13px;
  letter-spacing:.6px;
  margin-bottom:4px;
}

.sg-demo{
  margin:18px 0;
  padding:22px;
  border:1px dashed #d8d8d8;
  border-radius:12px;
  background:#fff;
}

.sg-code{
  background:#1e1e1e;
  color:#e8e8e8;
  border-radius:10px;
  padding:16px 18px;
  overflow:auto;
  font-size:13px;
  line-height:1.55;
  margin:0;
}

.sg-code code{
  color:inherit;
  font-family:Consolas,"SF Mono",Menlo,monospace;
  white-space:pre;
}

.sg-cap{font-size:13px;color:#888;margin-top:8px}

.sg-toc{
  position:sticky;
  top:78px;
  z-index:5;
  background:#fff;
  border:1px solid #eee;
  border-radius:12px;
  padding:14px 16px;
  box-shadow:0 4px 14px rgba(0,0,0,.06);
}

/* réconciliation legacy → FDM */
.btn{min-width:0}

/* page-hero : rendu identique à _blank.html (annule les restes du thème hérité) */
.page-hero{
  display:block;
  min-height:0;
  overflow:visible;
  text-align:left;
  width:100%;
  margin:0;
  border-radius:0;
}
.page-hero::before{content:none;display:none}
.page-hero .wrap{width:calc(100% - 40px);max-width:1320px;margin:0 auto}
.page-hero .breadcrumb{
  display:block;
  justify-content:flex-start;
  text-align:left;
  margin-bottom:16px;
}
.page-hero .breadcrumb a{color:var(--orange)}
.page-hero .breadcrumb span{margin:0 8px;color:#666}
.page-hero h1{color:#fff;max-width:760px}
.page-hero .lead{color:#ccc;font-size:18px;max-width:680px;margin-top:16px}

/* ===== Dropdown du menu général (style FDM) ===== */
.menu .has-dropdown{position:relative;display:inline-flex;align-items:center}
.menu .has-dropdown > .dd-toggle{display:inline-flex;align-items:center;gap:5px;cursor:pointer}
.menu .dd-caret{font-size:10px;transition:transform .2s ease}
.menu .dropdown-menu{
  position:absolute;left:0;top:100%;min-width:220px;
  background:#fff;border-radius:0 0 12px 12px;
  box-shadow:0 16px 30px rgba(0,0,0,.16);
  padding:8px 0;display:none;z-index:30;
}
/* pont invisible pour ne pas perdre le survol entre le lien et le panneau */
.menu .dropdown-menu::before{content:"";position:absolute;left:0;right:0;top:-16px;height:16px}
.menu .dropdown-menu a{
  display:block;padding:11px 18px;font-size:13px;font-weight:700;
  text-transform:uppercase;color:var(--black);white-space:nowrap;
}
.menu .dropdown-menu a:hover{background:rgba(245,156,0,.12);color:var(--orange)}

/* clic (mobile + tactile) : valable partout */
.menu .has-dropdown.open > .dropdown-menu{display:block}
.menu .has-dropdown.open > .dd-toggle .dd-caret{transform:rotate(180deg)}

/* survol : uniquement sur les appareils dotés d'un vrai survol (souris) */
@media (hover:hover){
  .menu .has-dropdown:hover > .dropdown-menu{display:block}
  .menu .has-dropdown:hover > .dd-toggle .dd-caret{transform:rotate(180deg)}
}

@media(max-width:850px){
  .menu .has-dropdown{display:block;width:100%}
  .menu .has-dropdown > .dd-toggle{justify-content:space-between;width:100%}
  .menu .dropdown-menu{
    position:static;box-shadow:none;border-radius:0;margin:4px 0;
    padding:0 0 0 14px;min-width:0;border-left:2px solid rgba(245,156,0,.4);
  }
  .menu .dropdown-menu::before{display:none}
}

/* ===== Galerie d'accueil : images-liens vers la page galerie ===== */
.gallery-grid a{display:block;border-radius:8px;overflow:hidden;cursor:pointer}
.gallery-grid a img{transition:transform .3s ease}
.gallery-grid a:hover img{transform:scale(1.05)}
