/* Base */
*{ box-sizing: border-box; }

body{
  margin: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial;
  background: #0b1220;
  color: #ffffff;
}

/* Header */
.site-header{
  background: #081526;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  position: sticky;
  top: 0;
  z-index: 1000;
}

/* Ligne du haut: logo + nom + boutons langue */
.topbar{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 16px;
}

.branding{
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}

.branding img{
  height: 44px;
  width: auto;
  display: block;
  background: #fff;
  padding: 6px;
  border-radius: 10px;
}

/* Nom de la compagnie */
.branding span{
  color: #fff;
  font-weight: 700;
  font-size: 18px;
  white-space: nowrap;
}

/* Menu */
.main-nav{
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  padding: 10px 16px 14px;
}

.main-nav a{
  color: #7fb0ff;
  text-decoration: none;
  font-weight: 600;
}

.main-nav a:hover{
  color: #ffffff;
}

/* Boutons FR / EN */
.lang button{
  background: transparent;
  border: 2px solid #2bd072;
  color: #2bd072;
  padding: 6px 12px;
  border-radius: 999px;
  font-weight: 700;
}

/* Mobile */
@media (max-width: 480px){
  .branding img{ height: 36px; }
  .branding span{ font-size: 16px; }
}

/* Contenu global (IMPORTANT: pas de padding ici, chaque section gère son spacing) */
main{ padding: 0; }

/* ===== HERO ===== */
.hero{
  max-width: 1100px;
  margin: 0 auto;
  padding: 44px 16px;
  display: grid;
  grid-template-columns: 1.15fr 0.85fr;
  gap: 28px;
  align-items: center;
}

.hero h1{
  margin: 0;
  line-height: 1.05;
}

/* Accent sous les titres principaux (uniquement dans hero/page-hero) */
.hero h1::after,
.page-hero h1::after{
  content: "";
  display: block;
  width: 60px;
  height: 4px;
  background: #2bd072;
  margin-top: 12px;
  border-radius: 2px;
}

.hero p{
  margin: 18px 0 0;
  opacity: 0.9;
  max-width: 46ch;
}

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

.btn-primary,
.btn-secondary{
  display: inline-block;
  padding: 10px 14px;
  border-radius: 12px;
  text-decoration: none;
  font-weight: 800;
}

.btn-primary{
  background: #2bd072;
  color: #081526;
}

.btn-secondary{
  border: 2px solid rgba(255,255,255,0.18);
  color: #ffffff;
}

.hero-media img{
  width: 100%;
  height: auto;
  display: block;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,0.08);
}

/* Mobile */
@media (max-width: 820px){
  .hero{
    grid-template-columns: 1fr;
    padding: 34px 16px;
  }
  .hero-media{ order: -1; }
}

/* ===== Services (section sur index) ===== */
.services{
  padding: 60px 16px;
  background: linear-gradient(180deg, #081526 0%, #0b1f33 100%);
}

.services-header{
  max-width: 900px;
  margin-bottom: 40px;
}

.services-header h2{
  font-size: 32px;
  margin-bottom: 10px;
}

.services-header p{
  color: #cfe1ff;
  max-width: 700px;
}

.services-grid{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 20px;
  margin-bottom: 40px;
}

.service-card{
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 14px;
  padding: 20px;
}

.service-card h3{
  margin-bottom: 8px;
  font-size: 18px;
  color: #ffffff;
}

.service-card p{
  color: #cbd9f2;
  font-size: 15px;
  line-height: 1.5;
}

.services-reassurance ul{
  list-style: none;
  padding: 0;
  max-width: 700px;
}

.services-reassurance li{
  margin-bottom: 10px;
  color: #9fe7b3;
  font-weight: 600;
}

/* ===== About preview (index) ===== */
.about-preview{
  padding: 48px 16px;
  background: #0b1220;
}

.about-box{
  max-width: 900px;
  margin: 0 auto;
  padding: 22px;
  border-radius: 16px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
}

.about-box h2{
  margin: 0 0 10px;
  font-size: 26px;
}

.about-box p{
  margin: 0;
  color: #cbd9f2;
  line-height: 1.6;
  max-width: 70ch;
}

.about-actions{
  margin-top: 18px;
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

/* ===== Contact preview (index) ===== */
.contact-preview{
  padding: 60px 16px;
  background: linear-gradient(180deg, #081526, #0b1e34);
}

.contact-box{
  max-width: 900px;
  margin: 0 auto;
  background: rgba(255,255,255,0.03);
  border-radius: 20px;
  padding: 36px 28px;
  border: 1px solid rgba(255,255,255,0.08);
}

.contact-box h2{
  font-size: 28px;
  margin-bottom: 12px;
}

.contact-box p{
  color: #cfd8e3;
  max-width: 600px;
}

.contact-actions{
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  margin-top: 24px;
  align-items: center;
}

.contact-location{
  color: #9fb4cc;
  font-weight: 500;
}

/* Email bouton style */
.contact-actions .btn-secondary{
  border: 2px solid #2bd072;
  color: #2bd072;
  background: transparent;
}

/* ===== Page layout (pages internes: services/about/work) ===== */
.page-content{
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 16px 40px;
}

.page-hero{
  padding: 42px 0 26px;
}

.page-hero-actions{
  margin-top: 18px;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.trust-badges{
  margin-top: 16px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.badge{
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  padding: 8px 10px;
  border-radius: 999px;
  color: #cbd9f2;
  font-weight: 600;
  font-size: 14px;
}

/* Lists in service cards (pages internes si besoin) */
.service-list{
  margin: 12px 0 0;
  padding-left: 18px;
  color: #cbd9f2;
  line-height: 1.55;
  font-size: 14px;
}

/* Info blocks */
.info-block{
  margin-top: 36px;
  padding: 22px;
  border-radius: 16px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
}

/* Steps */
.steps{
  margin-top: 14px;
  display: grid;
  gap: 14px;
}

.step{
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 12px;
  align-items: start;
  padding: 14px;
  border-radius: 14px;
  background: rgba(0,0,0,0.15);
  border: 1px solid rgba(255,255,255,0.06);
}

.step-num{
  width: 36px;
  height: 36px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  background: #2bd072;
  color: #081526;
  font-weight: 900;
}

.step h3{ margin: 0 0 6px; }
.step p{ margin: 0; color: #cbd9f2; }

/* FAQ */
.faq{
  margin-top: 12px;
  display: grid;
  gap: 10px;
}

details{
  background: rgba(0,0,0,0.15);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 14px;
  padding: 12px 14px;
}

summary{
  cursor: pointer;
  font-weight: 800;
}

details p{
  margin: 10px 0 0;
  color: #cbd9f2;
  line-height: 1.55;
}

/* Final CTA */
.final-cta{
  margin-top: 36px;
  padding: 26px;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(43,208,114,0.18), rgba(255,255,255,0.03));
  border: 1px solid rgba(255,255,255,0.10);
}

.final-cta p{ color: #cbd9f2; }

/* ===== Gallery (services/about/work) ===== */
.services-gallery{
  padding: 60px 16px;
}

.gallery-header{
  max-width: 900px;
  margin-bottom: 32px;
}

.gallery-grid{
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 16px;
}

.gallery-grid figure{
  background: #081526;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.08);
}

.gallery-grid img{
  width: 100%;
  height: 220px;
  object-fit: cover;
  display: block;
}

.gallery-grid figcaption{
  padding: 12px;
  font-size: 14px;
  color: #cfe9dc;
}

/* Petite touche pro: hover */
.service-card,
.about-box,
.contact-box,
.info-block,
.gallery-grid figure{
  transition: transform 0.15s ease, border-color 0.15s ease;
}

.service-card:hover,
.gallery-grid figure:hover{
  transform: translateY(-2px);
  border-color: rgba(255,255,255,0.14);
}
/* ===== Contact page form ===== */
.contact-form{
  margin-top: 16px;
  display: grid;
  gap: 14px;
}

.contact-form label{
  display: grid;
  gap: 8px;
}

.contact-form span{
  font-weight: 700;
  color: #cfe1ff;
}

.contact-form input,
.contact-form select,
.contact-form textarea{
  width: 100%;
  padding: 12px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(0,0,0,0.18);
  color: #fff;
  outline: none;
}

.contact-form input::placeholder,
.contact-form textarea::placeholder{
  color: rgba(255,255,255,0.45);
}

.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus{
  border-color: rgba(43,208,114,0.6);
  box-shadow: 0 0 0 3px rgba(43,208,114,0.12);
}