@charset "UTF-8";
@import url(main.css);
/* ========================================================================== 1. VARIABLES GLOBALES ========================================================================== */
:root { --bloc-a7f3-navy: #0f1c2e; --bloc-a7f3-navy-mid: #162438; --bloc-a7f3-gold: #f0b429; --bloc-a7f3-gold-dark: #d9a020; --bloc-a7f3-text-light: #cdd5de; --bloc-a7f3-white: #ffffff; }

/* ========================================================================== 2. NAVBAR & HEADER ========================================================================== */
nav#navigation-bar-hide { padding-bottom: 1rem; padding-top: 1rem; }

i.bi.bi-telephone.fs-6 { display: none; }

#navbarSupportedContent > div > a { border: 2px solid #f5be0c !important; color: #f5be0c !important; border-radius: 4px !important; font-family: "Teko", sans-serif; font-size: 24px !important; padding: 5px 15px !important; background: transparent !important; transition: all 0.2s; }

#navbarSupportedContent > div > a:hover { background: #f5be0c !important; color: #162438 !important; }

.animated-border-button:after { background-color: #f5be0a; }

/* ========================================================================== 3. HERO VIDÉO (Page d'accueil Haut) ========================================================================== */
#fullHeight .videoTitle { width: 100% !important; }

#fullHeight .videoTitle h1 { margin-bottom: 4rem; font-size: clamp(2.5rem, 8vw, 4.5rem) !important; font-weight: 900 !important; line-height: 1.1 !important; text-transform: uppercase !important; }

#phone-analytics-tag-video-bloc { display: inline-block; border: 2px solid #f5be0c !important; color: #f5be0c !important; border-radius: 4px !important; background: transparent !important; font-family: "Teko", sans-serif; font-size: 30px !important; font-weight: 700 !important; padding: 12px 50px !important; transition: all 0.2s; }

#phone-analytics-tag-video-bloc:hover { background: #f5be0c !important; color: #0f1c2f !important; }

/* ========================================================================== 4. HERO PRINCIPAL (Pages Services / Avec Image de fond) ========================================================================== */
.bloc-a7f3-hero { position: relative; display: flex; align-items: center; min-height: 70vh; padding-top: 72px; padding-bottom: 5rem; overflow: hidden; background-color: var(--bloc-a7f3-navy); background-image: url("https://storage.googleapis.com/refpro-app-ca244.appspot.com/customers%2FIWfRDhfU0kMfIOkkSkOYtTm3jmo1%2Fimages%2FFOND_CLC_PLAQUISTE_lcc7.webp"); background-position: center right; background-repeat: no-repeat; background-size: cover; }

.bloc-a7f3-hero-overlay { position: absolute; inset: 0; z-index: 0; background: linear-gradient(to right, rgba(15, 28, 46, 0.9) 0%, rgba(15, 28, 46, 0.4) 50%, transparent 100%); }

.bloc-a7f3-hero-accent { position: absolute; top: -80px; right: -80px; width: 500px; height: 500px; z-index: 1; border-radius: 50%; pointer-events: none; background: radial-gradient(circle, rgba(240, 180, 41, 0.08) 0%, transparent 70%); }

.bloc-a7f3-hero-content { position: relative; z-index: 2; width: 100%; max-width: 1600px; padding: 80px 4% 80px 80px; }

.bloc-a7f3-hero-tag { display: inline-flex; align-items: center; gap: 8px; width: 100% !important; margin-bottom: 24px; color: var(--bloc-a7f3-gold); font-size: 0.75rem; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; white-space: normal !important; }

.bloc-a7f3-hero-tag::before { content: ""; width: 28px; height: 2px; background: currentColor; }

.bloc-a7f3-hero-title { width: 100% !important; max-width: 780px; margin-bottom: 20px; color: var(--bloc-a7f3-white); font-size: clamp(2.8rem, 4vw, 4.5rem) !important; font-weight: 700; line-height: 1.08; letter-spacing: 0.3px; white-space: normal !important; word-break: normal !important; }

/* Écrasement des styles parasites du CMS pour le titre Hero */
.bloc-a7f3-hero-title *, .bloc-a7f3-hero-title p, .bloc-a7f3-hero-title span, .bloc-a7f3-hero-title strong { font-size: inherit !important; line-height: inherit !important; }

.bloc-a7f3-hero-title p, .bloc-a7f3-hero-title div { display: block !important; margin: 0 !important; }

.bloc-a7f3-hero-title span, .bloc-a7f3-hero-title strong, .bloc-a7f3-hero-title em { display: inline !important; width: auto !important; }

.bloc-a7f3-hero-title em { font-style: normal !important; color: var(--bloc-a7f3-gold) !important; }

.bloc-a7f3-hero-sub { max-width: 1000px; margin-bottom: 36px; color: var(--bloc-a7f3-text-light); font-size: 0.95rem; line-height: 1.7; }

.bloc-a7f3-hero-actions { display: flex; align-items: center; gap: 16px; flex-wrap: nowrap; }

.btn.bloc-a7f3-btn-gold, .btn.bloc-a7f3-btn-outline { display: inline-flex; align-items: center; justify-content: center; flex: 0 0 auto; padding: 12px 30px; border-radius: 4px; font-family: "Teko", sans-serif; font-size: 1.5rem; font-weight: 800; text-decoration: none; white-space: nowrap; transition: all 0.2s; }

.btn.bloc-a7f3-btn-gold { border: 2px solid var(--bloc-a7f3-gold); background: var(--bloc-a7f3-gold); color: var(--bloc-a7f3-navy); }

.btn.bloc-a7f3-btn-gold:hover { background: var(--bloc-a7f3-gold-dark); border-color: var(--bloc-a7f3-gold-dark); transform: translateY(-2px); }

.btn.bloc-a7f3-btn-outline { border: 2px solid var(--bloc-a7f3-gold); color: var(--bloc-a7f3-gold); background: transparent; }

.btn.bloc-a7f3-btn-outline:hover { background: var(--bloc-a7f3-gold); color: var(--bloc-a7f3-navy); }

/* ========================================================================== 5. BLOC PRESTATIONS (CMS Card Grid) ========================================================================== */
.bloc-a7f3-services { position: relative; padding: 90px 8% 9rem; background: var(--bloc-a7f3-navy-mid); }

.bloc-a7f3-services::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 4px; background: linear-gradient(90deg, transparent, var(--bloc-a7f3-gold), transparent); }

.bloc-a7f3-header { margin-bottom: 100px; text-align: center; }

.bloc-a7f3-title { color: var(--bloc-a7f3-white); font-family: "Teko", sans-serif; font-size: clamp(2.4rem, 4vw, 3.8rem); font-weight: 700; line-height: 1; text-transform: uppercase; }

/* Force la taille du h3 et de ses spans pour "Mes Prestations" */
.bloc-a7f3-title h3 { font-size: 1.75rem !important; margin: 0 !important; }

.bloc-a7f3-title h3 span { font-size: 1.8em !important; }

.bloc-a7f3-divider { width: 300px; height: 3px; margin: 18px auto 0; background: var(--bloc-a7f3-gold); }

.bloc-a7f3-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 22px; max-width: 1800px; margin: 0 auto; }

.bloc-a7f3-card { padding: 26px 20px; border: 1px solid rgba(240, 180, 41, 0.18); border-radius: 8px; background: var(--bloc-a7f3-navy); text-align: left; transition: transform 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease; }

.bloc-a7f3-card:hover { transform: translateY(-3px); border-color: rgba(240, 180, 41, 0.5); box-shadow: 0 10px 24px rgba(0, 0, 0, 0.18); }

.bloc-a7f3-icon { display: flex; align-items: center; justify-content: center; width: 42px; height: 42px; margin-bottom: 16px; border: 1px solid rgba(240, 180, 41, 0.22); border-radius: 8px; background: rgba(240, 180, 41, 0.08); font-size: 1.2rem; line-height: 1; }

.bloc-a7f3-name { margin-bottom: 10px; color: var(--bloc-a7f3-white); font-family: "Teko", sans-serif; font-size: 1.8rem; font-weight: 700; line-height: 1; text-transform: uppercase; }

.bloc-a7f3-desc { color: var(--bloc-a7f3-text-light); font-size: 0.95rem; line-height: 1.7; }

/* ========================================================================== 6. GALERIE RÉALISATIONS (Filtres JS) ========================================================================== */
.realisations-section { position: relative; padding: 90px 5%; background: var(--bloc-a7f3-navy-mid); }

.realisations-section::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 4px; background: linear-gradient(90deg, transparent, var(--bloc-a7f3-gold), transparent); }

.realisations-section .overlay { max-width: 1280px; margin: 0 auto; }

.realisations-main-title { margin: 0 0 36px; color: var(--bloc-a7f3-white); font-family: "Teko", sans-serif; font-size: clamp(2rem, 3.5vw, 3.15rem); font-weight: 700 !important; line-height: 1; text-align: center; text-transform: uppercase; }

.filter-tabs { display: flex; justify-content: center; flex-wrap: wrap; gap: 12px; margin-bottom: 40px; }

.filter-tabs .filter-btn p { margin: 0 !important; }

.filter-btn { padding: 12px 22px; border: 1px solid rgba(240, 180, 41, 0.35); border-radius: 6px; background: var(--bloc-a7f3-navy); color: var(--bloc-a7f3-white); font-family: "Teko", sans-serif; font-size: 1.25rem; font-weight: 600; letter-spacing: 0.5px; text-transform: uppercase; cursor: pointer; transition: all 0.25s ease; }

.filter-btn:hover { border-color: var(--bloc-a7f3-gold); color: var(--bloc-a7f3-gold); transform: translateY(-2px); }

.filter-btn.active { border-color: var(--bloc-a7f3-gold); background: var(--bloc-a7f3-gold); color: var(--bloc-a7f3-navy); }

.realisations-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 24px; }

.realisation-card { overflow: hidden; border: 1px solid rgba(240, 180, 41, 0.14); border-radius: 10px; background: var(--bloc-a7f3-navy); transition: transform 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease; }

.realisation-card:hover { transform: translateY(-4px); border-color: rgba(240, 180, 41, 0.42); box-shadow: 0 14px 30px rgba(0, 0, 0, 0.22); }

.realisation-card img { display: block; width: 100%; height: 320px; object-fit: cover; cursor: pointer; transition: transform 0.35s ease; }

.realisation-card:hover img { transform: scale(1.03); }

.realisation-card.hidden { display: none; }

/* Modale image */
.modal { display: none; position: fixed; inset: 0; z-index: 1000; align-items: center; justify-content: center; padding: 24px; background: rgba(15, 28, 46, 0.92); }

.clc-modal-image { display: block; width: auto; height: auto; max-width: 92vw; max-height: 90vh; border-radius: 10px; background: transparent; object-fit: contain; box-shadow: none; }

.modal-close { position: absolute; top: 18px; right: 24px; z-index: 1100; color: var(--bloc-a7f3-white); font-size: 40px; font-weight: 700; line-height: 1; cursor: pointer; transition: color 0.2s ease, transform 0.2s ease; }

.modal-close:hover { color: var(--bloc-a7f3-gold); transform: scale(1.08); }

/* ========================================================================== 7. FORMULAIRE CONTACT ========================================================================== */
#formContact { padding: 28px 28px 30px; border: 1px solid rgba(240, 180, 41, 0.18) !important; border-radius: 14px; background: var(--bloc-a7f3-navy-mid) !important; }

#formContact .form-floating { display: flex; flex-direction: column; }

#formContact .form-floating > .form-control { height: 52px; padding: 12px 14px; }

#formContact .form-floating > label { position: static !important; height: auto !important; margin-bottom: 8px; padding: 0 !important; transform: none !important; opacity: 1 !important; color: rgba(255, 255, 255, 0.85) !important; font-size: 0.95rem; }

#formContact .form-control, #formContact .form-select, #formContact textarea.form-control { min-height: 52px; border: 1px solid rgba(255, 255, 255, 0.12) !important; border-radius: 6px !important; background: var(--bloc-a7f3-navy) !important; color: var(--bloc-a7f3-white) !important; -webkit-text-fill-color: var(--bloc-a7f3-white) !important; caret-color: var(--bloc-a7f3-gold) !important; box-shadow: none !important; }

#formContact textarea.form-control { min-height: 120px; padding-top: 14px; resize: vertical; }

#formContact .form-control::placeholder, #formContact textarea.form-control::placeholder, #formContact input::placeholder { color: transparent !important; opacity: 0 !important; }

#formContact .form-control:focus, #formContact .form-select:focus, #formContact textarea.form-control:focus { border-color: var(--bloc-a7f3-gold) !important; background: var(--bloc-a7f3-navy) !important; box-shadow: 0 0 0 1px var(--bloc-a7f3-gold) !important; }

#formContact input:-webkit-autofill, #formContact input:-webkit-autofill:hover, #formContact input:-webkit-autofill:focus, #formContact textarea:-webkit-autofill, #formContact textarea:-webkit-autofill:hover, #formContact textarea:-webkit-autofill:focus, #formContact select:-webkit-autofill, #formContact select:-webkit-autofill:hover, #formContact select:-webkit-autofill:focus { border: 1px solid rgba(255, 255, 255, 0.12) !important; -webkit-box-shadow: 0 0 0 1000px var(--bloc-a7f3-navy) inset !important; box-shadow: 0 0 0 1000px var(--bloc-a7f3-navy) inset !important; -webkit-text-fill-color: var(--bloc-a7f3-white) !important; caret-color: var(--bloc-a7f3-gold) !important; transition: background-color 9999s ease-out 0s !important; }

#formContact .row { row-gap: 6px; }

#formContact input[type="file"]::file-selector-button { margin-right: 14px; padding: 10px 14px; border: 1px solid rgba(240, 180, 41, 0.25); border-radius: 6px; background: transparent; color: var(--bloc-a7f3-gold); cursor: pointer; }

#formContact .checkbox, #formContact .form-check-label, #formContact label { color: rgba(255, 255, 255, 0.85); }

#formContact input[type="checkbox"] { accent-color: var(--bloc-a7f3-gold); }

#formContact a { color: var(--bloc-a7f3-gold); }

#formContact button[type="submit"] { display: inline-flex; align-items: center; justify-content: center; width: 100%; min-height: 52px; padding: 12px 30px; border: 2px solid var(--bloc-a7f3-gold) !important; border-radius: 4px; background: var(--bloc-a7f3-gold) !important; color: var(--bloc-a7f3-navy) !important; font-family: "Teko", sans-serif; font-size: 1.5rem; font-weight: 800; letter-spacing: 1.5px; text-transform: uppercase; text-decoration: none; white-space: nowrap; transition: all 0.2s; }

#formContact button[type="submit"]:hover { background: var(--bloc-a7f3-gold-dark) !important; border-color: var(--bloc-a7f3-gold-dark) !important; color: var(--bloc-a7f3-navy) !important; }

#contact > div.background-image-div-opacity { background-attachment: local !important; }

/* ========================================================================== 8. BOUTONS CTA GLOBAUX CMS & BACKGROUND FIXED ========================================================================== */
.cta_banner { padding-top: 4rem !important; padding-bottom: 2rem !important; margin-bottom: 4rem; }

body > main > div.wrapper > div > div:nth-child(7) > div.background-image-div-opacity { background-attachment: local !important; }

body > main > div.wrapper > div > div:nth-child(6) > div.background-image-div-opacity { background-attachment: local !important; }

/* FIX EFFET PARALLAXE (Background fixe) */
.background-image-div-opacity { background-attachment: fixed !important; background-position: center center !important; background-size: cover !important; }

.ctaLinks-button { display: inline-flex; align-items: center; justify-content: center; padding: 12px 30px !important; border: 2px solid #f5be0c !important; border-radius: 4px !important; background: transparent !important; color: #f5be0c !important; transition: all 0.2s; text-decoration: none !important; }

.ctaLinks-button p, .ctaLinks-button span { margin: 0 !important; }

.ctaLinks-button:hover, .ctaLinks-button:hover *, .ctaLinks-button:hover p, .ctaLinks-button:hover span, .ctaLinks-button:hover strong { background: #f5be0c !important; color: #162438 !important; }

/* Centre les boutons quand il y en a plusieurs */
.d-grid.gap-2.d-sm-flex.justify-content-sm-center { display: flex !important; justify-content: center; gap: 16px; flex-wrap: wrap; }

/* ========================================================================== 9. SECTIONS SECONDAIRES (Étapes, Maps, Avant/Après) ========================================================================== */
.accompagnement_text { margin-top: 7rem; padding: 0 1rem; }

.accompagnement_text .content > div { margin-top: 0 !important; padding-top: 0 !important; }

.maps-section { padding-top: 3rem !important; padding-bottom: 3rem !important; }

.maps-section .item-content { display: none; }

.mb-4.text-center.display-6.titles { text-align: left !important; padding-left: 4rem; }

/* Fix plugin avant-après */
.slider-before-after-images { border: 3px solid #09182a !important; background: #09182a !important; }

.slider-before-after-images:before, .slider-before-after-images:after { background: #09182a !important; }

.bi-chevron-left::before, .bi-chevron-right::before { color: white; }

/* Nettoyage margin CMS */
body > main > div.wrapper > div > div:nth-child(3) > div > div.col-lg-12.mx-auto > div > a > p, body > main > div.wrapper > div > div:nth-child(4) > div > div.col-lg-12.mx-auto > div > a > p, body > main > div.wrapper > div > div:nth-child(6) > div.content > div.col-lg-12.mx-auto > div:nth-child(3) > a > p, body > main > div.wrapper > div > div:nth-child(7) > div.content > div.col-lg-12.mx-auto > div.d-grid.gap-2.d-sm-flex.justify-content-sm-center > a > p, body > main > div.wrapper > div > div:nth-child(9) > div.content > div.col-lg-12.mx-auto > div.d-grid.gap-2.d-sm-flex.justify-content-sm-center > a > p { margin: 0 !important; }

body > main > div.wrapper > div > div.container { padding-bottom: 5rem; }

body > main > div.wrapper > div > div:nth-child(5) > div > div.col-lg-12.mx-auto { display: none; }

/* ========================================================================== 10. MEDIA QUERIES GLOBALES (Tablette & Mobile) ========================================================================== */
@media (max-width: 1200px) and (min-width: 901px) { .bloc-a7f3-hero-title { font-size: 2.6rem !important; } }

@media (max-width: 900px) { .bloc-a7f3-hero { background-image: none; background-position: center; } .bloc-a7f3-hero-content { max-width: 100% !important; width: 100% !important; padding: 100px 5%; text-align: center; } .bloc-a7f3-hero-tag, .bloc-a7f3-hero-actions { justify-content: center; } .bloc-a7f3-hero-actions { flex-wrap: wrap; } .bloc-a7f3-hero-sub { margin-left: auto; margin-right: auto; } .bloc-a7f3-services { padding: 70px 5%; } .bloc-a7f3-grid { grid-template-columns: 1fr; } .realisations-section { padding: 70px 5%; } .filter-tabs { gap: 10px; margin-bottom: 30px; } .filter-btn { padding: 10px 18px; font-size: 1.05rem; } .realisations-grid { grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 16px; } .realisation-card img { height: 240px; } .modal-content { max-width: 92%; max-height: 82vh; } }

@media (max-width: 767px) { #formContact { padding: 22px 20px 24px; } #formContact .form-floating > label { font-size: 0.9rem; } .mb-4.text-center.display-6.titles { text-align: center !important; padding-left: 2rem !important; padding-right: 2rem !important; } }

@media (max-width: 600px) { .realisations-main-title { margin-bottom: 28px; } .filter-btn { width: 100%; max-width: 280px; } .realisations-grid { grid-template-columns: 1fr; } .realisation-card img { height: auto; max-height: 70vh; background: var(--bloc-a7f3-navy); object-fit: contain; } }

/*# sourceMappingURL=custom.css.map */