@charset "UTF-8";
@import url(main.css);
.logo-footer > .logo_nav { height: 15vh !important; }

.navbar-brand { height: 8vh !important; width: 8vw !important; }

.logo_nav { height: 9vh !important; transition: all 0.3s ease; }

.navbar .logo_nav { padding-left: 2rem; }

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

a.grow.button_header.text-color-fourth.mx-3.mx-lg-2.my-2.my-lg-1.p-2.rounded-pill.text-decoration-none.button-header-telephone { border-radius: 0px !important; }

/*--------------------------------------------------------------HERO----------------------------------------------------------------------------------------*/
/* ========================================= BASE & CONTAINER ========================================= */
* { margin: 0; padding: 0; box-sizing: border-box; }

.armor-container { width: 100%; max-width: 100%; /* Pleine largeur (full-bleed) comme sur l'image */ margin: 0; padding: 0; /* Suppression des marges pour coller aux bords */ }

/* ========================================= HERO SECTION ========================================= */
.armor-hero { position: relative; width: 100%; min-height: 85vh; /* Plus haut pour un effet d'immersion totale */ padding: 80px 10%; /* Espacement interne aligné avec l'image */ display: flex; align-items: center; justify-content: flex-start; background-image: url("https://storage.googleapis.com/refpro-app-ca244.appspot.com/customers%2F6GlJAExRpXMFcj1Z4EN8yAjS9sX2%2Fimages%2FDesign_sans_titre_-_2026-06-16T143256945_4ggn.webp"); background-size: cover; background-position: center; border-radius: 0px; /* Bords stricts */ overflow: hidden; }

/* 🔵 FILTRE : Assombrissement global et uniforme comme sur l'image */
.armor-hero::before { content: ""; position: absolute; inset: 0; background: rgba(25, 25, 25, 0.65); /* Voile noir/gris semi-transparent uniforme */ z-index: 1; }

/* ========================================= CONTENU INTÉRIEUR ========================================= */
.armor-hero__inner { position: relative; z-index: 2; max-width: 1000px; /* Plus large pour accueillir la typo géante */ width: 100%; color: #ffffff; }

.armor-hero__logo { width: 160px; height: auto; margin-bottom: 30px; display: block; filter: drop-shadow(0 4px 12px rgba(0, 0, 0, 0.4)); transition: transform 0.4s ease; }

.armor-hero:hover .armor-hero__logo { transform: translateY(-4px); }

/* Typographie très imposante et majuscule comme sur l'image */
.armor-hero h1 { font-size: 72px; /* Taille massive */ line-height: 1.05; /* Lignes très resserrées */ font-weight: 800; /* Extra bold */ text-transform: uppercase; /* Forcé en majuscule */ margin-bottom: 30px; letter-spacing: -2px; /* Lettres rapprochées */ color: #ffffff; }

.armor-hero p { font-size: 18px; line-height: 1.6; color: #ffffff; margin-bottom: 45px; max-width: 600px; font-weight: 400; }

/* BOUTON CTA : Rectangle blanc minimaliste */
.armor-cta { display: inline-flex; align-items: center; justify-content: center; padding: 18px 40px; background: #ffffff; /* Fond blanc pur */ color: #111111; /* Texte très sombre/noir */ font-weight: 800; /* Texte gras */ font-size: 14px; text-decoration: none; text-transform: uppercase; letter-spacing: 1px; border: none; border-radius: 0px; /* Angles parfaitement droits */ transition: all 0.3s ease; cursor: pointer; }

.armor-cta:hover { background: #E2C07A; /* Rappel du beige doré au survol */ color: #0F2F44; /* Rappel du bleu foncé */ transform: translateY(-3px); box-shadow: 0 10px 20px rgba(0, 0, 0, 0.3); }

/* ========================================= RESPONSIVE : TABLETTE ========================================= */
@media (max-width: 1024px) { .armor-hero { min-height: 60vh; padding: 60px 6%; } .armor-hero h1 { font-size: 56px; letter-spacing: -1px; } }

/* ========================================= RESPONSIVE : MOBILE ========================================= */
@media (max-width: 768px) { .armor-hero { min-height: 70vh; padding: 40px 25px; } .armor-hero__logo { width: 130px; margin-bottom: 25px; } .armor-hero h1 { font-size: 42px; line-height: 1.1; margin-bottom: 20px; } .armor-hero p { font-size: 16px; margin-bottom: 30px; } .armor-cta { padding: 16px 32px; width: 100%; /* Bouton pleine largeur sur mobile */ text-align: center; } }

@media (max-width: 480px) { .armor-hero h1 { font-size: 34px; } .armor-hero p { font-size: 15px; } }

/* ========================================= TRÈS GRANDS ÉCRANS (ULTRAWIDE 1600px+) ========================================= */
@media (min-width: 1600px) { .armor-hero { min-height: 85vh; padding: 80px 12%; } .armor-hero__inner { max-width: 1200px; } .armor-hero__logo { width: 200px; margin-bottom: 40px; } .armor-hero h1 { font-size: 90px; /* Encore plus massif sur grand écran */ margin-bottom: 35px; } .armor-hero p { font-size: 22px; max-width: 700px; margin-bottom: 50px; } .armor-cta { padding: 22px 50px; font-size: 16px; } }

/*--------------------------------------------------------------INTRO----------------------------------------------------------------------------------------*/
/* ========================================= SECTION GLOBALE ========================================= */
.av-section { position: relative; background: #FAFAFA; /* Fond clair pour faire ressortir le logo et le texte foncé */ padding: 100px 5%; overflow: hidden; }

/* ========================================= GRILLE DE MISE EN PAGE ========================================= */
.av-grid { max-width: 1200px; margin: 0 auto; display: grid; /* Colonne 1 (Logo) : 300px | Colonne 2 (Texte) : le reste */ grid-template-columns: 350px 1fr; gap: 80px; align-items: center; }

/* ========================================= COLONNE GAUCHE (LOGO) ========================================= */
.av-logo-container { display: flex; justify-content: center; align-items: center; }

.av-logo-container img { width: 100%; max-width: 300px; /* Logo beaucoup plus grand */ height: auto; filter: drop-shadow(0 10px 20px rgba(15, 47, 68, 0.1)); }

/* ========================================= COLONNE DROITE (TEXTE & SERVICES) ========================================= */
.av-content { display: flex; flex-direction: column; justify-content: center; }

.av-eyebrow { font-size: 13px; letter-spacing: 0.2em; text-transform: uppercase; color: #E2C07A; /* Beige doré */ font-weight: 700; margin: 0 0 16px; }

.av-title { font-size: 46px; font-weight: 600; color: #0F2F44; /* Bleu principal */ line-height: 1.15; margin: 0 0 24px; letter-spacing: -0.5px; }

.av-text { font-size: 18px; line-height: 1.7; color: #3A4A55; max-width: 600px; margin-bottom: 40px; }

.av-text p { margin: 0 0 16px; }

.av-text p:last-child { margin-bottom: 0; }

/* ========================================= SERVICES (BADGES) ========================================= */
.av-services { display: flex; flex-wrap: wrap; gap: 12px; }

.av-service-tag { background: #466B7A; /* Bleu secondaire */ color: #FFFFFF; padding: 10px 20px; border-radius: 4px; font-size: 14px; font-weight: 600; letter-spacing: 0.5px; text-transform: uppercase; transition: all 0.3s ease; }

.av-service-tag:hover { background: #E2C07A; /* Change en doré au survol */ color: #0F2F44; transform: translateY(-2px); }

/* ========================================= RESPONSIVE ========================================= */
@media (max-width: 1024px) { .av-grid { grid-template-columns: 250px 1fr; gap: 50px; } .av-title { font-size: 40px; } }

@media (max-width: 768px) { .av-section { padding: 70px 20px; } .av-grid { grid-template-columns: 1fr; /* Passage en 1 colonne */ gap: 40px; text-align: center; /* On centre le texte sur mobile */ } .av-logo-container img { max-width: 220px; } .av-title { font-size: 34px; } .av-text { font-size: 16px; margin-left: auto; margin-right: auto; } .av-services { justify-content: center; /* On centre les badges sur mobile */ } }

/*--------------------------------------------------------------SERVICES----------------------------------------------------------------------------------------*/
/* DESIGN GLOBAL ET POLICES SYSTÈMES */
.services-armor { max-width: 1400px; margin: 0 auto 80px auto; padding: 60px 40px; background: #FAFAFA; color: #111; font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif; }

.services-armor__title-main { font-size: 52px; text-transform: uppercase; color: #0f2f44; line-height: 1.1; margin-bottom: 10px; font-weight: 800 !important; letter-spacing: -1px; border: none !important; }

.services-armor__subtitle { font-size: 22px; font-weight: 400 !important; color: #555; margin-bottom: 50px; max-width: 800px; line-height: 1.4; border: none !important; }

/* GRILLE 3 COLONNES */
.services-armor__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 40px; align-items: start; }

.services-armor__col { display: flex; flex-direction: column; gap: 50px; }

/* BASE DES BLOCS (Remplacement de "card") */
.services-armor__box { width: 100%; position: relative; display: flex; flex-direction: column; background: transparent !important; border: none !important; box-shadow: none !important; outline: none !important; margin: 0 !important; padding: 0 !important; }

.services-armor__img-wrapper { width: 100%; overflow: hidden; position: relative; border-radius: 0px !important; border: none !important; }

.services-armor__img-wrapper img { width: 100%; height: 100%; display: block; object-fit: cover; transition: transform 0.6s ease; border-radius: 0px !important; }

.services-armor__box:hover .services-armor__img-wrapper img { transform: scale(1.03); }

/* DIMENSIONS DES IMAGES */
.img-horizontal { height: 350px; }

.img-vertical { height: 580px; }

/* HEADER CLIQUABLE */
.services-armor__header { display: flex; justify-content: space-between; align-items: flex-start; width: 100%; cursor: pointer; gap: 15px; border: none !important; background: transparent !important; }

.services-armor__header:hover .services-armor__toggle { background: #111; color: #fff; border-color: #111; }

/* TEXTES ET TITRES */
.services-armor__info { display: flex; flex-direction: column; width: 100%; border: none !important; box-shadow: none !important; background: transparent !important; }

.services-armor__box-title { font-size: 24px; font-weight: 700 !important; text-transform: uppercase; line-height: 1.2; margin: 0; flex: 1; border: none !important; }

/* BOUTON FLÈCHE */
.services-armor__toggle { background: transparent; border: 2px solid #111 !important; border-radius: 50% !important; width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; font-size: 18px; font-weight: bold !important; color: #111; transition: all 0.3s ease; flex-shrink: 0; animation: pulse 2s infinite; }

.services-armor__toggle.active { transform: rotate(180deg); animation: none; }

@keyframes pulse { 0% { box-shadow: 0 0 0 0 rgba(17, 17, 17, 0.2); }
  70% { box-shadow: 0 0 0 10px rgba(17, 17, 17, 0); }
  100% { box-shadow: 0 0 0 0 rgba(17, 17, 17, 0); } }

/* CONTENU ACCORDÉON */
.services-armor__content { max-height: 0; overflow: hidden; transition: max-height 0.4s ease-in-out, margin-top 0.4s ease-in-out, opacity 0.4s ease-in-out; width: 100%; opacity: 0; border: none !important; }

.services-armor__content p { font-size: 16px; line-height: 1.6; margin: 0; border: none !important; }

.services-armor__content.active { max-height: 300px; margin-top: 15px; opacity: 1; }

/* HORIZONTAL (Texte en dessous) */
.services-armor__box--horizontal .services-armor__info { padding-top: 20px; }

.services-armor__box--horizontal .services-armor__content p { color: #444; }

/* VERTICAL (Texte en overlay) */
.services-armor__box--vertical .services-armor__img-wrapper::after { content: ''; position: absolute; bottom: 0; left: 0; width: 100%; height: 70%; background: linear-gradient(to top, rgba(0, 0, 0, 0.9) 0%, rgba(0, 0, 0, 0.5) 50%, transparent 100%); pointer-events: none; }

.services-armor__box--vertical .services-armor__info { position: absolute; bottom: 0; left: 0; width: 100%; padding: 30px; color: #fff; z-index: 2; }

.services-armor__box--vertical .services-armor__toggle { color: #fff; border-color: #fff !important; animation: pulse-white 2s infinite; }

@keyframes pulse-white { 0% { box-shadow: 0 0 0 0 rgba(255, 255, 255, 0.3); }
  70% { box-shadow: 0 0 0 10px rgba(255, 255, 255, 0); }
  100% { box-shadow: 0 0 0 0 rgba(255, 255, 255, 0); } }

.services-armor__header:hover .services-armor__toggle { background: #fff; color: #111; }

.services-armor__box--vertical .services-armor__content p { color: #ddd; }

/* RESPONSIVE TABLETTE */
@media (max-width: 1100px) { .services-armor__grid { gap: 25px; } .img-horizontal { height: 280px; } .img-vertical { height: 480px; } .services-armor__box-title { font-size: 20px; } }

/* TABLETTES ET MOBILES */
@media (max-width: 900px) { .services-armor__title-main { font-size: 40px; } .services-armor__subtitle { font-size: 18px; margin-bottom: 30px; } .services-armor__grid { grid-template-columns: 1fr; gap: 30px; } .services-armor__col { gap: 30px; } .img-horizontal, .img-vertical { height: 350px; } .services-armor__box--vertical .services-armor__info { position: relative; background: transparent !important; padding: 20px 0 0 0; color: #111; } .services-armor__box--vertical .services-armor__img-wrapper::after { display: none; } .services-armor__box--vertical .services-armor__toggle { color: #111; border-color: #111 !important; animation: pulse 2s infinite; } .services-armor__header:hover .services-armor__toggle { background: #111; color: #fff; } .services-armor__box--vertical .services-armor__content p { color: #444; } }

/* PETITS MOBILES */
@media (max-width: 480px) { .services-armor__title-main { font-size: 32px; } .img-horizontal, .img-vertical { height: 250px; } .services-armor__box-title { font-size: 18px; } .services-armor__toggle { width: 34px; height: 34px; font-size: 16px; } }

/*--------------------------------------------------------------CTA----------------------------------------------------------------------------------------*/
.action-armor { position: relative; padding: 90px 20px; background: #f6f8f9; text-align: center; overflow: hidden; }

/* 🔵 lignes haut / bas */
.action-armor::before, .action-armor::after { content: ""; position: absolute; left: 50%; transform: translateX(-50%); width: 80%; height: 2px; background: #466b7a; opacity: 0.6; }

.action-armor::before { top: 20px; }

.action-armor::after { bottom: 20px; }

/* motif technique */
.action-armor__bg { position: absolute; inset: 0; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cpath d='M0 40 H120 M0 80 H120 M40 0 V120 M80 0 V120' stroke='%230F2F44' stroke-width='1' opacity='0.04'/%3E%3C/svg%3E"); pointer-events: none; }

/* contenu */
.action-armor__content { position: relative; max-width: 720px; margin: 0 auto; }

.action-armor__label { font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase; color: #466b7a; font-weight: 700; margin-bottom: 14px; display: inline-block; }

.action-armor__title { font-size: 36px; line-height: 1.2; color: #0F2F44; margin-bottom: 14px; }

.action-armor__text { font-size: 19px; line-height: 1.6; color: #3a4a55; margin-bottom: 28px; }

.action-armor__btn { display: inline-block; padding: 14px 34px; background: #0F2F44; color: #fff; text-decoration: none; font-weight: 700; font-size: 13px; letter-spacing: 0.08em; transition: 0.3s ease; border: 1px solid #0F2F44; }

.action-armor__btn:hover { background: #466b7a; border-color: #466b7a; }

/* responsive */
@media (max-width: 768px) { .action-armor__title { font-size: 26px; } .action-armor { padding: 70px 16px; } }

/*--------------------------------------------------------------CARTE----------------------------------------------------------------------------------------*/
.carte-armor { background: #f6f8f9; padding: clamp(60px, 10vw, 150px) clamp(20px, 6vw, 120px); border-top: 1px solid rgba(70, 107, 122, 0.2); }

.carte-armor__inner { max-width: 1500px; margin: 0 auto; display: grid; grid-template-columns: 1.2fr 0.8fr; gap: clamp(40px, 7vw, 120px); align-items: center; }

/* TITRE */
.carte-armor__title { font-size: clamp(2rem, 3.2vw, 3.2rem); font-weight: 600; color: #0F2F44; line-height: 1.2; margin-bottom: 12px; }

.carte-armor__title em { font-style: normal; color: #466b7a; font-weight: 500; }

/* TEXTE */
.carte-armor__text { font-size: 1.05rem; color: #3a4a55; line-height: 1.8; margin-bottom: 28px; max-width: 650px; }

/* ZONE */
.carte-armor__cities { margin-bottom: 40px; padding: 26px 28px; background: #ffffff; border-left: 3px solid #466b7a; font-size: 1rem; color: #3a4a55; line-height: 1.8; box-shadow: 0 10px 30px rgba(15, 47, 68, 0.06); }

/* MAP */
.carte-armor__map-wrap { display: flex; justify-content: center; }

.carte-armor__map { width: 100%; max-width: 520px; aspect-ratio: 1 / 1; /* Garde la carte carrée */ border-radius: 0px; overflow: hidden; box-shadow: 0 20px 60px rgba(15, 47, 68, 0.18); border: 1px solid rgba(70, 107, 122, 0.25); }

.carte-armor__map iframe { width: 100%; height: 100%; border: 0; }

/* RESPONSIVE */
@media (max-width: 1024px) { .carte-armor__inner { gap: 40px; } }

@media (max-width: 850px) { .carte-armor__inner { grid-template-columns: 1fr; text-align: center; } .carte-armor__cities { text-align: left; /* Garde le texte aligné à gauche dans la box */ } .carte-armor__text { margin-left: auto; margin-right: auto; } .carte-armor__map { max-width: 450px; } }

@media (max-width: 480px) { .carte-armor__cities { padding: 20px; } }

/* ============================== HEADER PAGE ARMOR ============================== */
.page-armor, .page-armor * { box-sizing: border-box; }

.page-armor { position: relative; width: 100%; height: 55vh; min-height: 400px; overflow: hidden; background-color: #000000; font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif; }

.page-armor__bg { position: absolute; inset: 0; background-size: cover; background-position: center; background-repeat: no-repeat; z-index: 0; }

.page-armor__overlay { position: absolute; inset: 0; /* Filtre passé en noir */ background: linear-gradient(120deg, rgba(0, 0, 0, 0.4) 0%, rgba(0, 0, 0, 0.75) 55%, rgba(0, 0, 0, 0.95) 100%); z-index: 1; }

.page-armor__container { position: relative; z-index: 2; max-width: 1200px; height: 100%; margin: 0 auto; padding: 0 50px; display: grid; grid-template-columns: 1fr 2fr; align-items: center; gap: 60px; }

.page-armor__logo { display: flex; align-items: center; justify-content: flex-start; }

.page-armor__logo img { max-width: 380px; /* Logo considérablement agrandi */ width: 100%; height: auto; display: block; filter: drop-shadow(0 4px 10px rgba(0, 0, 0, 0.3)); }

.page-armor__text-wrapper { display: flex; align-items: stretch; gap: 40px; }

.page-armor__line { width: 4px; background-color: #E2C07A; border-radius: 2px; flex-shrink: 0; }

.page-armor__text h1 { margin: 0 0 1rem; color: #ffffff; font-size: 38px; font-weight: 800; line-height: 1.15; letter-spacing: -0.5px; text-transform: uppercase; }

.page-armor__text h2 { margin: 0 0 1.5rem; color: #E2C07A; font-size: 18px; font-weight: 600; text-transform: uppercase; letter-spacing: 1px; }

.page-armor__text p { max-width: 540px; margin: 0; color: rgba(255, 255, 255, 0.9); font-size: 18px; line-height: 1.6; }

/* ============================== RESPONSIVE ============================== */
@media (max-width: 900px) { .page-armor { height: auto; min-height: 520px; } .page-armor__container { grid-template-columns: 1fr; gap: 30px; padding: 70px 35px; justify-items: center; text-align: center; } .page-armor__logo { justify-content: center; } .page-armor__logo img { max-width: 280px; /* Logo agrandi sur tablette */ } .page-armor__text-wrapper { flex-direction: column; align-items: center; gap: 20px; } .page-armor__line { width: 60px; height: 4px; } .page-armor__text h1 { font-size: clamp(30px, 6vw, 38px); } .page-armor__text p { max-width: 620px; } }

@media (max-width: 600px) { .page-armor { min-height: auto; } .page-armor__container { padding: 90px 22px 60px 22px; } .page-armor__logo img { max-width: 220px; /* Logo agrandi sur mobile */ } .page-armor__text h1 { font-size: 28px; line-height: 1.2; } .page-armor__text h2 { font-size: 15px; } .page-armor__text p { font-size: 16px; } }

.armor-bandeau { position: relative; background: #3d5d6a; padding: 48px 20px; color: #fff; overflow: hidden; font-family: system-ui, -apple-system, "Segoe UI", sans-serif; }

.armor-bandeau::before { content: ''; position: absolute; inset: 0; background-image: radial-gradient(circle at 15% 30%, rgba(255, 255, 255, 0.05) 0%, transparent 40%), radial-gradient(circle at 85% 70%, rgba(255, 255, 255, 0.04) 0%, transparent 45%); pointer-events: none; }

.armor-bandeau__container { position: relative; max-width: 1300px; margin: 0 auto; display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; }

.armor-bandeau__item { display: flex; align-items: flex-start; gap: 18px; padding: 4px 32px; position: relative; }

.armor-bandeau__item:not(:last-child)::after { content: ''; position: absolute; top: 6px; bottom: 6px; right: 0; width: 1px; background: rgba(255, 255, 255, 0.14); }

.armor-bandeau__icon { width: 50px; height: 50px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; border-radius: 14px; background: rgba(255, 255, 255, 0.1); transition: background 0.25s, transform 0.25s; }

.armor-bandeau__item:hover .armor-bandeau__icon { background: #E2C07A; transform: translateY(-2px); }

.armor-bandeau__item:hover .armor-bandeau__icon svg { stroke: #0F2F44; }

.armor-bandeau__icon svg { width: 24px; height: 24px; stroke: #fff; stroke-width: 1.8; fill: none; stroke-linecap: round; stroke-linejoin: round; transition: stroke 0.25s; }

.armor-bandeau__text { font-size: 14.5px; line-height: 1.6; color: rgba(255, 255, 255, 0.72); padding-top: 2px; }

.armor-bandeau__text strong { display: block; font-size: 16.5px; font-weight: 600; color: #fff; margin-bottom: 5px; letter-spacing: -0.01em; }

@media (max-width: 900px) { .armor-bandeau__container { grid-template-columns: 1fr; gap: 28px; } .armor-bandeau__item { padding: 0; } .armor-bandeau__item:not(:last-child)::after { display: none; } }

@media (max-width: 480px) { .armor-bandeau { padding: 36px 18px; } .armor-bandeau__icon { width: 44px; height: 44px; border-radius: 12px; } .armor-bandeau__icon svg { width: 21px; height: 21px; } .armor-bandeau__text strong { font-size: 16px; } .armor-bandeau__text { font-size: 14px; } }

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