:root{
  --black:#0b0b0b;
  --gold:#c99b2b;
  --white:#ffffff;
  --text:#111;
  --muted:#6a6a6a;
  --border:#eaeaea;
  --radius:18px;
  --shadow:0 10px 25px rgba(0,0,0,0.08);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial;
  color:var(--text);
  background:var(--white);
  line-height:1.55;
}

a{color:var(--gold);text-decoration:none}
a:hover{color:var(--black)}

.container{
  width:min(1100px, calc(100% - 40px));
  margin:0 auto;
}

section{scroll-margin-top:90px}

/* HEADER */
.site-header{
  position:sticky;
  top:0;
  z-index:1000;
  background:rgba(255,255,255,0.92);
  backdrop-filter: blur(8px);
  border-bottom:1px solid var(--border);
}

.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:10px 0;
}

.logo{height:28px;display:block}

.nav{
  display:flex;
  gap:18px;
  align-items:center;
  justify-content:center;
  flex-wrap:wrap;
}

.nav a{
  color:var(--gold);
  font-weight:600;
  font-size:14px;
  padding:8px 10px;
  border-radius:12px;
}
.nav a:hover{
  background:rgba(201,155,43,0.10);
  color:var(--black);
}

.nav-toggle{
  display:none;
  border:1px solid #ddd;
  background:#fff;
  padding:8px 10px;
  border-radius:12px;
  cursor:pointer;
  font-size:18px;
}

/* Switch langue */
.lang-switch{
  display:flex;
  gap:8px;
  align-items:center;
  font-weight:700;
  font-size:13px;
}
.lang-switch a{color:var(--gold)}
.lang-switch a.active{color:var(--black)}
.lang-switch .sep{color:#9a9a9a}

/* HERO */
.hero{
  position:relative;
  overflow:hidden;
  min-height: 70vh;
  display:flex;
  align-items:center;
}

.hero-media{
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(90deg, rgba(255,255,255,0.92) 0%, rgba(255,255,255,0.65) 45%, rgba(255,255,255,0.25) 100%),
    url("/assets/images/hero.jpg");
  background-size:cover;
  background-position:center;
  transform:scale(1.02);
}

.hero-inner{
  position:relative;
  padding:70px 0;
  display:grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap:22px;
  align-items:start;
}

.hero h1{
  margin:0 0 10px 0;
  font-size:44px;
  letter-spacing:-0.5px;
  color:var(--black);
}

.lead{
  font-size:16px;
  color:var(--muted);
  margin:0 0 18px 0;
}

.hero-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin:0 0 18px 0;
}

.hero-points{
  margin:0;
  padding-left:18px;
  color:#404040;
}
.hero-points li{margin:6px 0}

.hero-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:18px;
}
.hero-card h3{
  margin:0 0 8px 0;
  color:var(--black);
  font-size:18px;
}
.hero-card p{margin:0 0 12px 0;color:var(--muted)}
.hero-card-row{display:flex;gap:10px;flex-wrap:wrap}

.badge{
  display:inline-flex;
  align-items:center;
  border:1px solid rgba(201,155,43,0.35);
  background:rgba(201,155,43,0.10);
  color:var(--black);
  padding:6px 10px;
  border-radius:999px;
  font-weight:700;
  font-size:12px;
}

/* SECTIONS */
.section{
  padding:70px 0;
}
.section.alt{
  background:#fafafa;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.section-head{
  margin-bottom:20px;
}
.section-head h2{
  margin:0 0 6px 0;
  font-size:28px;
  color:var(--black);
}
.muted{color:var(--muted)}
.small{font-size:12px}

/* Cards services */
.cards{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:16px;
  margin-top:18px;
}

.card{
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  background:#fff;
  box-shadow:0 6px 18px rgba(0,0,0,0.05);
}
.card-media{
  height:180px;
  background-size:cover;
  background-position:center;
}

.card-body{
  padding:16px;
}
.card-body h3{
  margin:0 0 8px 0;
  font-size:18px;
  color:var(--black);
}
.card-body p{margin:0 0 10px 0;color:var(--muted)}
.list{
  margin:0;
  padding-left:18px;
  color:#333;
}
.list li{margin:6px 0}

/* CTA strip */
.cta-strip{
  margin-top:22px;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:#fff;
  padding:18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  box-shadow:0 6px 18px rgba(0,0,0,0.05);
}

/* About section layout */
.two-col{
  display:grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap:18px;
  align-items:start;
}

.kpis{
  margin:16px 0;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:10px;
}
.kpi{
  background:#fff;
  border:1px solid var(--border);
  border-radius:16px;
  padding:12px;
}
.kpi-number{
  font-size:20px;
  font-weight:900;
  color:var(--black);
}
.kpi-label{
  color:var(--muted);
  font-size:12px;
  font-weight:700;
}

.about-visual{
  display:grid;
  gap:12px;
}
.about-box{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:16px;
  box-shadow:0 6px 18px rgba(0,0,0,0.05);
}
.about-box h3{margin:0 0 10px 0;color:var(--black)}
.about-img{
  height:220px;
  border-radius:var(--radius);
  border:1px solid var(--border);
  background-image:
    linear-gradient(135deg, rgba(201,155,43,0.18), rgba(255,255,255,0)),
    url("/assets/images/about-team.jpg");
  background-size:cover;
  background-position:center;
}


/* Contact grid */
.contact-grid{
  display:grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap:16px;
  margin-top:18px;
}

.info-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:16px;
  box-shadow:0 6px 18px rgba(0,0,0,0.05);
}
.info-card h3{margin:0 0 8px 0;color:var(--black)}
.info-line{
  display:flex;
  justify-content:space-between;
  gap:10px;
  padding:10px 0;
  border-top:1px solid var(--border);
}
.info-line:first-of-type{border-top:none;padding-top:0}
.info-label{color:var(--muted);font-weight:700;font-size:12px}
.info-value{color:var(--black);font-weight:800;font-size:12px}

/* Form */
.form{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:16px;
  box-shadow:0 6px 18px rgba(0,0,0,0.05);
}

.field{margin-bottom:12px}
label{
  display:block;
  font-weight:800;
  font-size:12px;
  margin-bottom:6px;
  color:var(--black);
}
input, textarea{
  width:100%;
  border:1px solid #ddd;
  border-radius:14px;
  padding:11px 12px;
  font-size:14px;
  outline:none;
}
input:focus, textarea:focus{
  border-color:rgba(201,155,43,0.65);
  box-shadow:0 0 0 4px rgba(201,155,43,0.12);
}

.form-actions{
  display:flex;
  justify-content:flex-end;
  margin-top:10px;
}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius:14px;
  border:1px solid var(--black);
  background:var(--black);
  color:#fff;
  font-weight:800;
  font-size:14px;
  cursor:pointer;
}
.btn:hover{
  border-color:var(--gold);
  background:var(--gold);
  color:var(--black);
}

.btn.btn-outline{
  background:transparent;
  color:var(--black);
  border-color:var(--black);
}
.btn.btn-outline:hover{
  background:rgba(201,155,43,0.10);
  border-color:var(--gold);
  color:var(--black);
}

/* Alerts */
.alert{
  border-radius:14px;
  padding:10px 12px;
  font-weight:800;
  font-size:13px;
  margin:0 0 12px 0;
}
.alert.success{
  background:rgba(46, 204, 113, 0.12);
  border:1px solid rgba(46, 204, 113, 0.35);
}
.alert.error{
  background:rgba(231, 76, 60, 0.12);
  border:1px solid rgba(231, 76, 60, 0.35);
}

/* Footer (au cas où) */
.site-footer{
  border-top:1px solid var(--border);
  padding:18px 0;
  background:#fff;
}
.footer-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
.footer-links{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  align-items:center;
}
.footer-links a{font-weight:700}

/* Responsive */
@media (max-width: 900px){
  .hero-inner{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr}
  .two-col{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .kpis{grid-template-columns:1fr}
}

@media (max-width: 768px){
  .nav-toggle{display:inline-flex}

  .nav{
    display:none;
    position:absolute;
    top:100%;
    left:0;
    right:0;
    background:#fff;
    border-top:1px solid var(--border);
    padding:12px 20px;
    flex-direction:column;
    gap:10px;
    align-items:flex-start;
  }
  .nav.open{display:flex}

  .hero h1{font-size:36px}
}

.nav a.is-active{ color: var(--black); }


.form-title{
  margin:0 0 6px 0;
  color:var(--black);
}

.form-subtitle{
  margin:0 0 14px 0;
}

