/* =========================================================
   BATIELEC - GLOBAL.CSS
   Base globale : variables, reset, typo, layout, responsive
========================================================= */

/* =========================
   VARIABLES
========================= */
:root {
  --jaune: #F5A800;
  --jaune-clair: #FFE135;
  --orange: #E86B00;
  --grad: linear-gradient(135deg, #E86B00 0%, #F5A800 50%, #FFE135 100%);

  --noir: #0F0F0F;
  --gris-fonce: #1A1A1A;
  --gris-moyen: #2E2E2E;
  --gris-clair: #8A8A8A;
  --gris-clair-2: #B8B8B8;
  --blanc: #F8F6F1;
  --rouge: #E84040;

  --border-soft: 1px solid rgba(255, 255, 255, 0.06);
  --border-gold: 1px solid rgba(245, 168, 0, 0.20);

  --shadow-soft: 0 10px 24px rgba(0, 0, 0, 0.22);
  --shadow-card: 0 12px 30px rgba(0, 0, 0, 0.28);

  --radius-s: 8px;
  --radius-m: 12px;
  --radius-l: 18px;

  --container: 1280px;
  --section-x: 80px;
  --section-y: 100px;

  --nav-h: 96px;
  --telbar-h: 40px;
}

/* =========================
   RESET
========================= */
*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  padding: 0;
  background: var(--noir);
  color: var(--blanc);
  font-family: Verdana, Geneva, sans-serif;
  font-weight: 400;
  font-size: 15px;
  line-height: 1.7;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

img,
svg,
video,
iframe {
  display: block;
  max-width: 100%;
}

a {
  color: inherit;
}

button,
input,
select,
textarea {
  font: inherit;
}

ul,
ol {
  margin: 0;
  padding: 0;
}

body.menu-open {
  overflow: hidden;
}

/* =========================
   TYPO
========================= */
h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0;
  font-weight: 400;
}

p {
  margin: 0;
}

.be-card-txt,
.be-body,
.be-eng-txt,
.be-assur-txt,
.be-zone-extra,
.be-cta p,
.be-urgence p,
.be-sec-sub,
.be-hero-sub,
.be-zone-list li,
.be-assur-ttl,
.be-assur-lnk,
.be-eng-ttl,
.be-card-ttl,
.be-sec-lbl,
.be-stat-l,
.be-badge-txt,
.be-cta-addr,
.be-review-name,
.be-post-link,
.page-breadcrumb,
.page-hero-lbl,
.page-hero-sub,
.presta-lbl,
.presta-txt,
.presta-list li,
.presta-marque,
.contact-label,
.contact-desc,
.form-label,
.ml-body,
.ml-value,
.gallery-section-sub,
.partner-name,
.rating-total,
.rating-desc {
  font-size: clamp(12px, 1.1vw, 15px);
  line-height: 1.8;
}

.be-hero-title,
.page-hero-ttl,
.be-sec-ttl,
.presta-ttl,
.form-title,
.rating-label,
.be-sec-cta-ttl,
.ml-section-title,
.gallery-section-ttl {
  font-family: 'Bebas Neue', sans-serif;
  letter-spacing: 2px;
  line-height: 1;
  color: var(--blanc);
}

.be-hero-title {
  font-size: clamp(60px, 6vw, 96px);
  line-height: 0.92;
}

.page-hero-ttl {
  font-size: clamp(52px, 6vw, 90px);
  line-height: 0.95;
}

.be-sec-ttl,
.be-sec-cta-ttl {
  font-size: clamp(44px, 5vw, 68px);
}

.presta-ttl,
.rating-label,
.form-title {
  font-size: clamp(36px, 4vw, 52px);
}

.gallery-section-ttl,
.ml-section-title {
  font-size: clamp(28px, 3vw, 44px);
}

.acc {
  background: var(--grad);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.be-sec-lbl,
.page-hero-lbl,
.presta-lbl,
.gallery-section-lbl,
.contact-label,
.ml-label {
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--jaune);
}

/* =========================
   LAYOUT
========================= */
.be-wrap,
.be-container {
  width: min(100% - 0px, var(--container));
  margin: 0 auto;
}

.be-sec,
.be-about,
.be-zone,
.be-cta,
.page-hero,
.gallery-section,
.rating-global,
.reviews-section,
.ml-content,
.contact-form-wrap,
.contact-infos {
  padding-left: var(--section-x);
  padding-right: var(--section-x);
}

.be-sec,
.be-about,
.be-zone,
.be-cta,
.gallery-section,
.reviews-section {
  padding-top: var(--section-y);
  padding-bottom: var(--section-y);
}

.be-sec.alt,
.be-about,
.be-zone,
.rating-global,
.be-footer,
.be-footer-mobile,
.contact-infos {
  background: var(--gris-fonce);
}

.be-sec,
.be-cta,
.page-hero,
.gallery-section,
.reviews-section,
.contact-form-wrap,
.ml-content {
  background: var(--noir);
}

.be-page-hero {
  background: var(--noir);
  padding: 80px var(--section-x) 60px;
}

.be-page-breadcrumb {
  color: var(--gris-clair);
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-bottom: 18px;
  font-size: 13px;
}

.be-page-breadcrumb a {
  color: var(--jaune);
  text-decoration: none;
}

.be-page-intro {
  max-width: 980px;
}

/* =========================
   SECTIONS COMMUNES
========================= */
.be-sec-lbl {
  margin-bottom: 6px;
}

.be-sec-ttl {
  margin-bottom: 10px;
}

.be-sec-sub {
  color: var(--gris-clair);
  max-width: 760px;
  margin-bottom: 40px;
}

.be-seo-copy {
  max-width: 980px;
}

.be-seo-copy p + p,
.be-body p + p,
.ml-body + .ml-body {
  margin-top: 18px;
}

.be-seo-copy a,
.be-zone a,
.be-zone a:visited,
.be-cta a:not(.be-btn-p):not(.be-btn-s),
.ml-value a,
.page-breadcrumb a,
.be-page-breadcrumb a {
  color: var(--jaune);
  text-decoration: none;
}

.be-body {
  color: var(--gris-clair);
  line-height: 1.9;
}

/* =========================
   UTILITAIRES
========================= */
.text-center {
  text-align: center;
}

.text-right {
  text-align: right;
}

.mt-0 { margin-top: 0; }
.mb-0 { margin-bottom: 0; }

/* =========================
   RESPONSIVE 1024
========================= */
@media (max-width: 1024px) {
  :root {
    --section-x: 28px;
    --section-y: 72px;
    --nav-h: 82px;
  }

  .be-page-hero {
    padding: 72px 28px 56px;
  }

  .be-sec,
  .be-about,
  .be-zone,
  .be-cta,
  .page-hero,
  .gallery-section,
  .reviews-section,
  .ml-content,
  .contact-form-wrap,
  .contact-infos {
    padding-left: 28px;
    padding-right: 28px;
  }

  .be-sec,
  .be-about,
  .be-zone,
  .be-cta,
  .gallery-section,
  .reviews-section {
    padding-top: 72px;
    padding-bottom: 72px;
  }

  .be-sec-sub {
    margin-bottom: 32px;
  }
}

/* =========================
   RESPONSIVE 600
========================= */
@media (max-width: 600px) {
  :root {
    --section-x: 20px;
    --section-y: 48px;
    --nav-h: 76px;
  }

  body {
    font-size: 14px;
  }

  .be-page-hero {
    padding: 48px 20px !important;
  }

  .be-sec,
  .be-about,
  .be-zone,
  .be-cta,
  .page-hero,
  .gallery-section,
  .reviews-section,
  .ml-content,
  .contact-form-wrap,
  .contact-infos {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }

  .be-sec,
  .be-about,
  .be-zone,
  .be-cta,
  .gallery-section,
  .reviews-section {
    padding-top: 48px !important;
    padding-bottom: 48px !important;
  }

  .be-sec-ttl,
  .be-sec-cta-ttl {
    font-size: 36px !important;
  }

  .page-hero-ttl {
    font-size: 42px !important;
  }

  .be-hero-title {
    font-size: 42px !important;
  }

  .be-sec-sub {
    margin-bottom: 24px;
  }
}