/* =========================
   Thème clair · Concept Bureau
   ========================= */
:root{
  /* Couleurs */
  --bg:#ffffff;
  --surface:#ffffff;
  --soft:#f7f9fb;
  --card:#ffffff;
  --border:#e6edf3;

  --text:#172026;
  --sub:#5b6673;
  --brand:#ff9f1c;        /* bouton / accent */
  --brand-600:#ff8a00;    /* hover */
  --brand-700:#e27a00;    /* active */

  --link:#0b66ff;         /* liens éventuels */
}


*{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:76px}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.55
}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
.skip-link{position:absolute;left:-9999px;top:auto}
.skip-link:focus{left:8px;top:8px;background:#fff;color:#000;padding:.5rem;border-radius:6px;z-index:1000}

/* Layout */
.container{width:min(1160px,92vw);margin-inline:auto}
.section{padding-block:48px}

/* Header / Nav */
header{
  background:#ffffff;
  position:sticky;top:0;z-index:20;
  border-bottom:1px solid var(--border)
}
nav{display:flex;justify-content:space-between;align-items:center;padding:12px 0;gap:12px}
.menu{display:flex;gap:16px}
.menu a{
  font-weight:600;
  color:var(--text);
  font-size:1rem;
  padding:.5rem .75rem;
  border-radius:6px;
  transition:all .2s ease
}
.menu a:hover,.menu a:focus{
  color:#000;
  background:rgba(255,159,28,.12);
}

/* Boutons */
.btn{
  background:var(--brand);
  color:#141414;
  padding:.7rem 1.2rem;
  border-radius:12px;
  display:inline-block;
  font-weight:800;
  border:1px solid var(--brand);
  box-shadow:0 2px 0 rgba(0,0,0,.04)
}
.btn:hover{background:var(--brand-600);border-color:var(--brand-600)}
.btn:active{background:var(--brand-700);border-color:var(--brand-700)}
.btn:focus{outline:3px solid rgba(255,159,28,.35);outline-offset:2px}

.btn.outline {
  background:transparent;
  border-color:var(--brand);
  color:var(--brand);
}
.btn.outline:hover {
  background:rgba(255,159,28,.1);
}

.actions{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:1rem}
.btn-small{
  background:transparent;border:1px solid var(--brand);color:var(--brand);
  padding:.4rem .8rem;font-size:.85rem;text-align:center;border-radius:8px;transition:all .2s
}
.btn-small:hover{background:var(--brand);color:#141414}


.hero{
  display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);
  gap:28px;align-items:center;padding-block:48px
}
.hero-text h1{font-size:clamp(1.9rem,3.2vw,3rem);line-height:1.05;margin:12px 0}
.hero-text p{color:var(--sub);max-width:62ch}
.hero-actions{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap}

/* Badge ISO */
.badge-iso{
  display:inline-block;
  background:var(--brand);
  color:#141414;
  font-weight:800;
  font-size:.9rem;
  padding:.35rem .75rem;
  border-radius:999px;
  margin-bottom:10px;
  letter-spacing:.3px;
  box-shadow:0 1px 0 rgba(0,0,0,.05)
}


.kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:14px}
.kpi,
.benefit{
  background:var(--card);
  border:1px solid var(--border);
  padding:16px;border-radius:12px;text-align:center;
  box-shadow:0 2px 8px rgba(16,24,40,.04)
}
.kpi b{font-size:1.05rem}
.benefits{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}

.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:18px}
.card{
  background:var(--card);
  padding:16px;border-radius:14px;border:1px solid var(--border);
  box-shadow:0 2px 10px rgba(16,24,40,.04)
}
.card img{border-radius:10px;margin-bottom:12px}
.card h3{margin:4px 0}
.card .meta{color:var(--sub)}
.price{font-weight:800;margin:12px 0}


.table-wrap{
  overflow:auto;border:1px solid var(--border);
  border-radius:12px;background:#fff;box-shadow:0 2px 10px rgba(16,24,40,.04)
}
table{border-collapse:collapse;min-width:720px;width:100%}
th,td{border-bottom:1px dashed #e3eaf2;padding:12px;text-align:left}
th{
  background:var(--soft);
  color:#334155;
  font-weight:700
}


.faq details{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:12px;margin:10px 0;
  box-shadow:0 2px 8px rgba(16,24,40,.04)
}
.faq summary{cursor:pointer;padding:14px 16px;font-weight:700}
.faq details>p{padding:0 16px 14px;color:var(--sub)}

/* Formulaire / CTA */
.cta{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:28px;align-items:start}
.cta-copy h2{margin:0 0 6px}
form{
  display:grid;gap:10px;background:#fff;border:1px solid var(--border);
  padding:16px;border-radius:12px;align-self:start;box-shadow:0 2px 10px rgba(16,24,40,.04)
}
input,select,textarea{
  padding:.8rem;border:1px solid #d7dee6;border-radius:10px;background:#fff;color:var(--text);width:100%
}
input:focus,select:focus,textarea:focus{
  outline:none;border-color:var(--brand);
  box-shadow:0 0 0 3px rgba(255,159,28,.25)
}


footer{
  padding:22px 0;text-align:center;color:#6b7280;
  border-top:1px solid var(--border);margin-top:34px;background:#fff
}


.logo{display:flex;align-items:center;gap:16px}
.logo .phone{font-weight:600;color:var(--text);font-size:1rem;white-space:nowrap}
.logo .phone:hover{color:var(--brand)}

/* Responsive */
@media (max-width: 1000px){
  .hero{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr 1fr}
  .benefits{grid-template-columns:1fr 1fr}
}
@media (max-width: 640px){
  .menu{display:none}
  .cards,.benefits{grid-template-columns:1fr}
  .kpis{grid-template-columns:1fr 1fr}
}

/* ===== Hero plein écran à la France Bureau ===== */
.hero-full{
  position:relative;
  background-size:cover;
  background-position:center;
  color:#fff;
  text-align:center;
  padding:160px 20px;
}
.hero-full .overlay{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.55);
}
.hero-full .hero-content{
  position:relative;
  z-index:1;
  max-width:860px;
  margin:0 auto;
}
.hero-full h1{
  font-size:clamp(2rem,4vw,3.2rem);
  line-height:1.2;
  margin:18px 0;
}
.hero-full p{
  font-size:1.125rem;
  color:#e2e8f0;
  margin-bottom:24px;
}
.hero-full .hero-actions{
  display:flex;
  gap:12px;
  justify-content:center;
  flex-wrap:wrap;
}
@media (max-width: 640px){
  .hero-full{padding:120px 16px}
}
.models-container {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 20px;
  margin: 40px 0;
}

.card {
  background: #fff;
  border-radius: 8px;
  padding: 20px;
  text-align: center;
  box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}

.models-container .card {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.models-container .card img {
  width: 100%;
  height: 220px;           
  object-fit: contain;      
  object-position: center;  
  display: block;
  margin: 0 auto 12px;      
}

.models-container .card h3,
.models-container .card p {
  margin-bottom: 8px;
}

.models-container .card a {
  margin-top: auto; /* pousse les boutons en bas */
}

.models-container .card .btn,
.models-container .card .btn-small {
  display: inline-block;
  margin: 6px 0;
}

@media (max-width: 640px){
  .models-container .card img { height: 180px; }
}
/* ===== Bloc Vérin ===== */
.verin h2{margin-top:0}
.verin-wrap{
  display:grid;
  grid-template-columns:minmax(0,0.95fr) minmax(0,1.05fr);
  gap:24px; align-items:start;
}
.verin-media img{border-radius:12px; box-shadow:0 6px 20px rgba(16,24,40,.08)}
.verin-media figcaption{font-size:.9rem; color:var(--sub); margin-top:8px}

.verin-copy p{color:var(--text)}
.verin-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px; margin:16px 0 6px;
}
.verin-card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:12px; padding:14px;
  box-shadow:0 2px 10px rgba(16,24,40,.04)
}
.verin-card h3{margin:4px 0 8px; font-size:1.05rem}
.verin-card ul{margin:0; padding-left:18px}
.verin-card li{margin:6px 0}

.verin-cta{font-weight:600; margin:14px 0 10px}

@media (max-width: 980px){
  .verin-wrap{grid-template-columns:1fr; gap:16px}
  .verin-grid{grid-template-columns:1fr 1fr}
}
@media (max-width: 640px){
  .verin-grid{grid-template-columns:1fr}
}
/* ===== Carrousel Réalisations ===== */
.realisations h2 {
  text-align: left;
  margin-bottom: 20px;
}

/* Conteneur fixe = flèches stables */
.carousel{
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 500px; /* ← ajuste la hauteur vitrine ici */
}

/* ===== Carrousel Réalisations ===== */
.realisations h2 {
  text-align: left;
  margin-bottom: 20px;
}

/* Conteneur fixe = flèches stables */
.carousel{
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 500px; /* ← ajuste la hauteur vitrine ici */
}

/* La piste et chaque slide occupent 100% de la hauteur */
.carousel-track{
  display: flex;
  transition: transform 0.5s ease;
  height: 100%;
}

.carousel-item{
  min-width: 100%;
  flex-shrink: 0;
  height: 100%;
  position: relative; /* pour la légende en overlay */
}

/* Image recadrée proprement dans le cadre vitrine */
.carousel-item img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 14px;
  box-shadow: 0 6px 20px rgba(16,24,40,.08);
}

/* Légende en overlay (option vitrine) */
.carousel-item p{
  position: absolute;
  left: 16px;
  bottom: 12px;
  margin: 0;
  padding: 6px 12px;
  background: rgba(0,0,0,0.5);
  color: #fff;
  border-radius: 8px;
  font-weight: 500;
  font-size: 0.9rem;
}

/* Flèches centrées verticalement sur le conteneur fixe */
.carousel-btn{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(0,0,0,0.4);
  color: #fff;
  border: none;
  padding: 12px;
  border-radius: 50%;
  cursor: pointer;
  transition: background .3s;
  z-index: 10;   /* ↑ assure que ça passe AU-DESSUS de l'image */
}
.carousel-btn:hover{ background: rgba(0,0,0,0.6); }
.carousel-btn.prev{ left: 10px; }
.carousel-btn.next{ right: 10px; }

/* Responsive : vitrine plus basse sur mobile */
@media (max-width: 768px){
  .carousel{ height: 320px; } /* ajuste si besoin */
  .carousel-item p{
    left: 12px;
    bottom: 10px;
    font-size: 0.85rem;
    padding: 5px 10px;
  }
}
.more-models {
  text-align: center;
  margin-top: 20px;
}

.more-models .btn-outline {
  border: 2px solid #ff8c00;   /* orange contour */
  color: #ff8c00;              /* texte orange */
  padding: 12px 28px;
  border-radius: 8px;
  font-weight: 600;
  text-decoration: none;
  display: inline-block;
  transition: all 0.3s ease;
}

.more-models .btn-outline:hover {
  background: #ff8c00;
  color: #fff;
}