@charset "UTF-8";
@import url(main.css);
h2.display-6.fw-bold.p-3.pt-lg-3.m-0.titles { color: black; }

h1.display-4.fw-bold.bandeauTitre.titles.text-color-seventh { color: black !important; }

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

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: 10px !important; background: #e10600 !important; }

.mb-5.googleReviews-div { background: #ebebeb !important; padding-top: 10rem !important; padding-bottom: 5rem !important; }

nav#navigation-bar-show { border-bottom: 1px solid #fff !important; }

.mx-auto.first-activity-div.col-lg-11.px-4.py-4.mb-5.mt-5.bg-primaryColor.text-color-primary.rounded-3.shadow-lg.position-relative { border: 1px solid #de2217 !important; border-radius: 5px !important; box-shadow: none !important; transition: 0.3s ease; }

.mx-auto.third-activity-div.col-lg-11.px-4.py-4.mb-4.mt-5.bg-primaryColor.text-color-primary.rounded-3.shadow-lg.position-relative { border: 1px solid #de2217 !important; border-radius: 5px !important; box-shadow: none !important; transition: 0.3s ease; }

.mx-auto.second-activity-div.col-lg-11.px-4.py-4.mb-5.mt-5.rounded-3.shadow-lg.bg-primaryColor.text-color-primary.position-relative { border: 1px solid #de2217 !important; border-radius: 5px !important; box-shadow: none !important; transition: 0.3s ease; }

/*----------------------------------------------------------------------------------------------ACCUEIL-------------------------------------------------------------------------------------------------------*/
/* =========================== HERO — ACCUEIL AUTO =========================== */
.accueil-auto { position: relative; width: 100%; min-height: 60vh; padding: 100px 0; display: flex; align-items: center; overflow: hidden; margin: 0; }

/* Vidéo de fond */
.accueil-auto-bg { position: absolute; inset: 0; z-index: 0; }

.accueil-auto-bg video { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Overlay dégradé sombre */
.accueil-auto-bg::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0.75)); }

/* Contenu */
.accueil-auto-content { position: relative; z-index: 2; max-width: 800px; margin-left: 80px; color: #ffffff; }

/* Logo */
.accueil-auto-logo { display: inline-block; margin-bottom: 10px; }

.accueil-auto-logo img { max-width: 250px; height: auto; }

/* Titre */
.accueil-auto-content h1 { font-size: 3.2rem; font-weight: 600; line-height: 1.2; margin-bottom: 20px; color: #ffffff; }

.accueil-auto-content h1 em { display: block; font-style: normal; font-weight: 400; font-size: 2.8rem; font-family: Arvo !important; color: #d73128; margin-top: 8px; }

/* Texte */
.accueil-auto-content p { font-size: 1.15rem; line-height: 1.7; margin-bottom: 40px; max-width: 680px; color: rgba(255, 255, 255, 0.9); }

/* =========================== CTA =========================== */
/* Groupe CTA */
.accueil-auto-cta-group { display: flex; gap: 20px; align-items: center; }

/* CTA principal (vert) */
.accueil-auto-cta { display: inline-flex; align-items: center; gap: 10px; padding: 16px 32px; background-color: #d73128; color: #fff; font-weight: 600; text-transform: capitalize; letter-spacing: 0.3px; text-decoration: none; border-radius: 8px; border: none; transition: all 0.3s ease; }

.accueil-auto-cta:hover { background-color: #d73128; transform: translateY(-3px); box-shadow: 0 5px 50px #d73128; color: #fff; text-decoration: none; }

/* CTA secondaire (glass / blur) */
.accueil-auto-cta-secondary { display: inline-flex; align-items: center; gap: 10px; padding: 16px 32px; background: rgba(255, 255, 255, 0.1); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); border: 1px solid rgba(255, 255, 255, 0.3); color: #ffffff; font-weight: 600; text-transform: capitalize; letter-spacing: 0.3px; text-decoration: none; border-radius: 8px; transition: all 0.3s ease; }

.accueil-auto-cta-secondary:hover { border-color: rgba(255, 255, 255, 0.5); background: rgba(255, 255, 255, 0.15); box-shadow: 0 6px 20px rgba(255, 255, 255, 0.2); color: #ffffff; text-decoration: none; }

/* SVG dans les boutons */
.accueil-auto-cta svg, .accueil-auto-cta-secondary svg { flex-shrink: 0; }

/* =========================== ANTI CTA PARASITE =========================== */
.accueil-auto .hero-button, .accueil-auto .hero-buttons { display: none !important; }

/* =========================== RESPONSIVE =========================== */
@media (max-width: 1024px) { .accueil-auto-content { margin-left: 40px; } .accueil-auto-content h1 { font-size: 2.8rem; } .accueil-auto-content h1 em { font-size: 2.4rem; } }

@media (max-width: 768px) { .accueil-auto { padding: 70px 20px; min-height: 50vh; } .accueil-auto-content { margin-left: 0; text-align: center; } .accueil-auto-logo { margin-bottom: 25px; } .accueil-auto-cta-group { justify-content: center; flex-wrap: wrap; } .accueil-auto-content h1 { font-size: 2.2rem; } .accueil-auto-content h1 em { font-size: 1.9rem; } .accueil-auto-content p { margin-left: auto; margin-right: auto; font-size: 1.05rem; } }

@media (max-width: 480px) { .accueil-auto-content h1 { font-size: 1.9rem; } .accueil-auto-content h1 em { font-size: 1.6rem; } .accueil-auto-cta, .accueil-auto-cta-secondary { padding: 14px 24px; font-size: 0.95rem; } }

/*----------------------------------------------------------------------------------------------INTRO-------------------------------------------------------------------------------------------------------*/
/* =============================== HISTOIRE GARAGE ================================ */
.histoire-garage { position: relative; padding: 120px 20px; background: linear-gradient(180deg, #1f2329, #191d22); color: #ffffff; overflow: hidden; clip-path: polygon(0 0, 100% 0, 100% calc(100% - 80px), 0 100%); }

/* IMAGE DE FOND (OVERLAY) */
.histoire-garage-bg { position: absolute; inset: 0; background-image: url("https://storage.googleapis.com/refpro-app-ca244.appspot.com/customers%2FkfuiW4UuewbUgbKrZ4j5XWu4Fk82%2Fimages%2FDesign_sans_titre_-_2026-02-06T091435204_4rmu.webp"); background-size: cover; background-position: center; opacity: 0.18; z-index: 0; }

/* CONTENU */
.histoire-garage-inner { position: relative; z-index: 1; max-width: 1400px; margin: 0 auto; display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 80px; align-items: center; }

/* ===== TEXTE ===== */
.histoire-badge { display: inline-block; background: rgba(222, 34, 23, 0.15); color: #de2217; padding: 10px 16px; border-radius: 10px; font-size: 18px; font-weight: 600; margin-bottom: 25px; }

.histoire-content h2 { font-size: 44px; line-height: 1.2; margin-bottom: 24px; }

.histoire-content p { font-size: 18px; line-height: 1.7; color: #d1d5db; margin-bottom: 18px; }

/* LISTE */
.histoire-points { list-style: none; padding: 0; margin: 36px 0 0; display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px 28px; }

.histoire-points li { position: relative; padding-left: 28px; font-size: 16px; }

.histoire-points li::before { content: "✔"; position: absolute; left: 0; top: 0; color: #de2217; font-weight: bold; }

/* ===== IMAGE ===== */
.histoire-image-wrapper img { width: 90%; height: auto; border-radius: 50px; display: block; }

/* =============================== RESPONSIVE AMÉLIORÉ ================================ */
/* ---------- Tablette ---------- */
@media (max-width: 1024px) { .histoire-garage-inner { grid-template-columns: 1fr; gap: 60px; text-align: center; } .histoire-badge { margin-left: auto; margin-right: auto; } .histoire-content p { max-width: 700px; margin-left: auto; margin-right: auto; } .histoire-points { grid-template-columns: 1fr; max-width: 520px; margin-left: auto; margin-right: auto; } .histoire-points li { padding-left: 0; } .histoire-points li::before { position: static; margin-right: 8px; } .histoire-image-wrapper img { width: 70%; margin: 0 auto; border-radius: 40px; } }

/* ---------- Mobile ---------- */
@media (max-width: 600px) { .histoire-garage { padding: 90px 16px; clip-path: polygon(0 0, 100% 0, 100% calc(100% - 40px), 0 100%); } .histoire-badge { font-size: 16px; padding: 8px 14px; } .histoire-content h2 { font-size: 30px; line-height: 1.25; } .histoire-content p { font-size: 16px; } .histoire-image-wrapper img { width: 85%; border-radius: 30px; } }

/* ---------- Très petit mobile ---------- */
@media (max-width: 400px) { .histoire-content h2 { font-size: 26px; } .histoire-image-wrapper img { width: 100%; border-radius: 22px; } }

/*----------------------------------------------------------------------------------------------SERVICES-------------------------------------------------------------------------------------------------------*/
/* =============================== SERVICES AUTO — CMS FRIENDLY ================================ */
.services-auto, .services-auto * { box-sizing: border-box; }

/* =============================== FOND (IMAGE + COULEUR) ================================ */
.services-auto { position: relative; padding: 140px 20px; background-color: #ebebeb; text-align: center; overflow: hidden; clip-path: polygon(0 0, 100% 80px, 100% calc(100% - 80px), 0 100%); margin-top: -80px; padding-top: 220px; }

/* Image de fond */
.services-auto::before { content: ""; position: absolute; inset: 0; background-image: url("https://storage.googleapis.com/refpro-app-ca244.appspot.com/customers%2FkfuiW4UuewbUgbKrZ4j5XWu4Fk82%2Fimages%2FDesign_sans_titre_-_2026-02-06T093918445_9b3s.webp"); background-size: cover; background-position: center; background-repeat: no-repeat; opacity: 0.25; z-index: 0; }

/* Contenu au-dessus */
.services-auto > * { position: relative; z-index: 1; }

/* =============================== RESET CMS ================================ */
.services-auto h2, .services-auto h3, .services-auto p { margin: 0; padding: 0; }

.services-auto img { max-width: none; display: block; }

/* =============================== TITRE ================================ */
.services-auto-header { position: relative; max-width: 820px; margin: 0 auto 90px; }

.services-auto-bg-title { position: absolute; top: -60px; left: 50%; transform: translateX(-50%); font-size: 130px; font-weight: 800; font-family: Arvo; color: rgba(0, 0, 0, 0.08); line-height: 1; white-space: nowrap; pointer-events: none; }

.services-auto-header h2 { position: relative; font-size: 40px; font-weight: 700; margin-bottom: 18px; line-height: 1.2; }

.services-auto-header h2 span { color: #d73128; }

.services-auto-header p { font-size: 19px; color: #555; line-height: 1.75; max-width: 760px; margin: 0 auto; }

/* =============================== GRID ================================ */
.services-auto-grid { max-width: 1400px; margin: 0 auto; display: grid; grid-template-columns: repeat(4, 1fr); gap: 45px; }

/* =============================== ITEM ================================ */
.service-auto-item { text-align: left; }

/* IMAGE */
.service-auto-image img { width: 100%; height: 400px; object-fit: cover; }

/* =============================== RECTANGLE CTA ================================ */
.service-auto-link { display: block; width: 100%; text-decoration: none; color: inherit; }

.service-auto-rectangle { position: relative; background: #ffffff; padding: 10px 20px 16px 10px; margin-top: -45px; margin-left: -22px; width: calc(100% - 30px); box-shadow: 0 14px 36px rgba(0, 0, 0, 0.14); overflow: hidden; transition: background-color 0.3s ease, transform 0.25s ease, box-shadow 0.3s ease; }

/* Barre rouge */
.service-auto-rectangle::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3.5px; background: #d73128; }

.service-auto-rectangle h3 { font-size: 20px; font-weight: 700; line-height: 1.25; transition: color 0.3s ease; }

/* Hover CTA */
@media (hover: hover) { .service-auto-link:hover .service-auto-rectangle { background: #d73128; transform: translateY(-4px); box-shadow: 0 18px 40px rgba(215, 49, 40, 0.35); } .service-auto-link:hover h3 { color: #ffffff; } .service-auto-link:hover .service-auto-rectangle::before { background: #ffffff; } }

/* DESCRIPTION */
.service-auto-description { margin-top: 22px; font-size: 18px; line-height: 1.7; color: #555; padding-left: 10px; }

/* =============================== RESPONSIVE ================================ */
@media (max-width: 1200px) { .services-auto-bg-title { font-size: 110px; top: -50px; } .services-auto-header h2 { font-size: 36px; } .services-auto-grid { gap: 36px; } .service-auto-image img { height: 380px; } }

@media (max-width: 992px) { .services-auto { padding: 110px 20px; padding-top: 190px; } .services-auto-grid { grid-template-columns: repeat(2, 1fr); gap: 40px; } .service-auto-image img { height: 340px; } .service-auto-rectangle { margin-left: -16px; width: calc(100% - 20px); } }

@media (max-width: 600px) { .services-auto { padding: 90px 16px; padding-top: 130px; clip-path: polygon(0 0, 100% 40px, 100% calc(100% - 40px), 0 100%); margin-top: -40px; } .services-auto-bg-title { font-size: 70px; top: -35px; } .services-auto-header h2 { font-size: 26px; } .services-auto-grid { grid-template-columns: 1fr; gap: 46px; } .service-auto-item { text-align: center; } .service-auto-image img { height: 300px; } .service-auto-rectangle { margin-top: -30px; margin-left: -10px; width: calc(100% - 10px); padding: 14px 18px; } .service-auto-rectangle h3 { font-size: 18px; } .service-auto-description { font-size: 16px; padding-left: 0; margin-top: 18px; } }

@media (max-width: 400px) { .services-auto-bg-title { font-size: 58px; } .service-auto-image img { height: 260px; } .service-auto-rectangle { margin-left: -6px; width: calc(100% - 6px); } }

/*----------------------------------------------------------------------------------------------CONTACT-------------------------------------------------------------------------------------------------------*/
/* =============================== CONTACT DETAILS - VERSION MODERNE ================================ */
.contact-details { position: relative; background: #0a0a0a; color: #fff; overflow: hidden; padding: 120px 20px 140px; clip-path: polygon(0 100px, 100% 0, 100% calc(100% - 100px), 0 100%); margin-top: -100px; margin-bottom: -100px; z-index: 2; }

/* Image de fond avec parallax effect */
.contact-details { background-image: url("https://storage.googleapis.com/refpro-app-ca244.appspot.com/customers%2FkfuiW4UuewbUgbKrZ4j5XWu4Fk82%2Fimages%2FDesign_sans_titre_-_2026-02-06T102110374_4ut0.webp"); background-size: cover; background-position: center; background-attachment: fixed; }

/* Overlay avec gradient dynamique */
.contact-overlay { position: absolute; inset: 0; background: linear-gradient(135deg, rgba(225, 6, 0, 0.15) 0%, rgba(0, 0, 0, 0.85) 50%, rgba(0, 0, 0, 0.95) 100%); z-index: 0; }

/* Effet de grille animée en arrière-plan */
.contact-overlay::before { content: ""; position: absolute; inset: 0; background-image: linear-gradient(rgba(255, 255, 255, 0.03) 1px, transparent 1px), linear-gradient(90deg, rgba(255, 255, 255, 0.03) 1px, transparent 1px); background-size: 50px 50px; opacity: 0.3; }

/* Contenu */
.contact-inner { position: relative; z-index: 1; max-width: 1100px; margin: 0 auto; text-align: center; }

/* Titre avec effet moderne */
.contact-inner h2 { font-size: 48px; font-weight: 900; letter-spacing: -1px; margin-bottom: 70px; line-height: 1.1; background: linear-gradient(135deg, #fff 0%, rgba(255, 255, 255, 0.7) 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; position: relative; display: inline-block; }

.contact-inner h2::after { content: ""; position: absolute; bottom: -20px; left: 50%; transform: translateX(-50%); width: 80px; height: 4px; background: linear-gradient(90deg, transparent, #e10600, transparent); border-radius: 2px; }

.contact-grid { display: grid; grid-template-columns: repeat(4, 1fr); /* ✅ 4 cartes desktop */ gap: 50px; margin-bottom: 70px; }

/* Item avec effet de carte moderne */
.contact-item { position: relative; padding: 30px 20px; background: rgba(255, 255, 255, 0.04); backdrop-filter: blur(10px); border: 1px solid rgba(255, 255, 255, 0.1); border-radius: 24px; box-shadow: 0 8px 32px rgba(225, 6, 0, 0.1); }

.contact-item::before { content: ""; position: absolute; inset: 0; border-radius: 24px; padding: 2px; background: linear-gradient(135deg, rgba(225, 6, 0, 0.4), transparent 50%, rgba(255, 255, 255, 0.15)); -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0); -webkit-mask-composite: xor; mask-composite: exclude; opacity: 0.6; }

.contact-item h3 { font-size: 18px; font-weight: 700; line-height: 1.4; margin-bottom: 25px; color: #fff; }

.contact-item p { font-size: 15px; line-height: 1.7; color: rgba(255, 255, 255, 0.75); }

/* Icône avec effet moderne */
.contact-icon { margin: 25px auto 0; width: 110px; height: 110px; border: 2px solid rgba(255, 255, 255, 0.15); border-radius: 50%; display: flex; align-items: center; justify-content: center; position: relative; background: rgba(225, 6, 0, 0.08); }

.contact-icon::before { content: ""; position: absolute; inset: -10px; border-radius: 50%; background: conic-gradient(from 0deg, transparent, rgba(225, 6, 0, 0.25), transparent); opacity: 0.5; animation: rotate 8s linear infinite; }

@keyframes rotate { to { transform: rotate(360deg); } }

.contact-icon img { width: 55px; filter: brightness(1.1); position: relative; z-index: 1; }

/* CTA avec détails rouges */
.contact-cta { display: inline-block; background: #de2217; color: #ffffff; padding: 13px 34px; border-radius: 8px; font-weight: 600; font-size: 18px; text-decoration: none; transition: transform 0.25s ease, box-shadow 0.25s ease; }

.contact-cta:hover { transform: translateY(-2px); box-shadow: 0 12px 30px rgba(222, 34, 23, 0.4); }

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

@media (max-width: 768px) { .contact-details { padding: 100px 20px 120px; } .contact-inner h2 { font-size: 36px; margin-bottom: 60px; } .contact-item { padding: 30px 20px; } }

@media (max-width: 500px) { .contact-details { clip-path: polygon(0 50px, 100% 0, 100% calc(100% - 50px), 0 100%); margin-top: -50px; margin-bottom: -50px; padding: 100px 15px 120px; } .contact-inner h2 { font-size: 30px; margin-bottom: 50px; } .contact-grid { gap: 40px; } .contact-cta { padding: 13px 34px; font-size: 16px; } }

/*----------------------------------------------------------------------------------------------DIAGONALE ROUGE-------------------------------------------------------------------------------------------------------*/
/* =============================== SERVICES MOTO ================================ */
.services-moto { position: relative; background: linear-gradient(135deg, #c84a3f 0%, #b8382d 100%); padding: 100px 20px; overflow: hidden; clip-path: polygon(0 0, 100% 80px, 100% calc(100% - 80px), 0 100%); margin-top: -80px; padding-top: 180px; }

/* Image de fond moto */
.services-moto::before { content: ""; position: absolute; inset: 0; background-image: url("https://storage.googleapis.com/refpro-app-ca244.appspot.com/customers%2FkfuiW4UuewbUgbKrZ4j5XWu4Fk82%2Fimages%2FDesign_sans_titre_-_2026-02-06T120856546_fyq2.webp"); background-size: cover; background-position: center; opacity: 0.15; z-index: 0; }

.services-moto-inner { position: relative; z-index: 1; max-width: 1300px; margin: 0 auto; color: #ffffff; }

/* Header */
.services-moto-header { text-align: center; margin-bottom: 80px; }

.services-moto-subtitle { font-size: 17px; letter-spacing: 3px; text-transform: uppercase; opacity: 0.8; margin-bottom: 12px; }

.services-moto-header h2 { font-size: 38px; font-weight: 700; line-height: 1.3; letter-spacing: 1px; margin: 0; }

.services-moto-header h2 span { display: block; }

/* =============================== GRID WRAPPER ================================ */
.services-moto-grid-wrapper { position: relative; }

/* =============================== GRID DESKTOP → 3 x 2 ================================ */
.services-moto-grid { display: grid; grid-template-columns: repeat(3, 1fr); /* ✅ 3 par ligne */ gap: 0; transition: transform 0.4s ease; }

/* Item */
.service-moto-item { text-align: center; padding: 20px 30px; border-right: 1px solid rgba(255, 255, 255, 0.2); border-bottom: 1px solid rgba(255, 255, 255, 0.2); }

/* Fin de ligne (3 colonnes) */
.service-moto-item:nth-child(3n) { border-right: none; }

/* Dernière ligne */
.service-moto-item:nth-child(n+4) { border-bottom: none; }

/* =============================== ICÔNES / IMAGES ================================ */
.service-moto-icon { width: 150px; height: 150px; margin: 0 auto 18px; border-radius: 50%; overflow: hidden; display: flex; align-items: center; justify-content: center; background: rgba(255, 255, 255, 0.06); }

.service-moto-icon img { width: 70%; height: 70%; object-fit: contain; display: block; }

/* Texte */
.service-moto-item h3 { font-size: 20px; font-weight: 700; margin: 0 0 8px 0; letter-spacing: 0.5px; }

.service-moto-item p { font-size: 18px; line-height: 1.6; opacity: 0.85; margin: 0; }

/* =============================== NAVIGATION (inchangée) ================================ */
.services-nav-btn { display: none; position: absolute; top: 50%; transform: translateY(-50%); background: rgba(255, 255, 255, 0.2); border: none; color: #ffffff; width: 50px; height: 50px; border-radius: 50%; cursor: pointer; transition: background 0.3s ease; z-index: 10; }

.services-nav-btn:hover:not(:disabled) { background: rgba(255, 255, 255, 0.3); }

.services-nav-btn:disabled { opacity: 0.3; cursor: not-allowed; }

.services-nav-prev { left: -25px; }

.services-nav-next { right: -25px; }

/* =============================== RESPONSIVE ================================ */
/* Tablette */
@media (max-width: 1024px) { .services-moto-grid { grid-template-columns: repeat(2, 1fr); } .service-moto-item:nth-child(3n) { border-right: 1px solid rgba(255, 255, 255, 0.2); } .service-moto-item:nth-child(2n) { border-right: none; } .service-moto-item:nth-child(n+4) { border-bottom: 1px solid rgba(255, 255, 255, 0.2); } .service-moto-item:nth-child(n+5) { border-bottom: none; } .services-moto-header h2 { font-size: 32px; } }

/* Mobile / slider */
@media (max-width: 768px) { .services-moto { padding: 70px 20px; clip-path: polygon(0 0, 100% 40px, 100% calc(100% - 40px), 0 100%); margin-top: -40px; padding-top: 110px; } .services-moto-header { margin-bottom: 50px; } .services-moto-header h2 { font-size: 26px; } .services-moto-grid-wrapper { overflow: hidden; padding: 0 60px; } .services-moto-grid { grid-template-columns: repeat(8, calc(100vw - 160px)); gap: 40px; } .service-moto-item { border: none; padding: 40px 20px; } .services-nav-btn { display: flex; align-items: center; justify-content: center; } .services-nav-prev { left: 0; } .services-nav-next { right: 0; } /* ✅ Icônes PLUS GRANDES en responsive */ .service-moto-icon { width: 110px; height: 110px; } .service-moto-icon img { width: 80%; height: 80%; } }

/* Très petit mobile */
@media (max-width: 480px) { .services-moto-grid-wrapper { padding: 0 50px; } .services-moto-grid { grid-template-columns: repeat(8, calc(100vw - 140px)); } .services-nav-btn { width: 40px; height: 40px; } .services-nav-btn svg { width: 20px; height: 20px; } .service-moto-icon { width: 95px; height: 95px; } }

/*----------------------------------------------------------------------------------------------CARTES LOSANGE-------------------------------------------------------------------------------------------------------*/
/* =============================== CARTE AUTOG — VERSION CLEAN ================================ */
.carte-autog { position: relative; padding: 180px 20px 140px; background-color: #f5f5f5; background-image: url("https://storage.googleapis.com/refpro-app-ca244.appspot.com/customers%2FkfuiW4UuewbUgbKrZ4j5XWu4Fk82%2Fimages%2FDesign_sans_titre_-_2026-02-06T141427618_i6pw.webp"); background-size: cover; background-position: center; clip-path: polygon(0 80px, 100% 0, 100% 100%, 0 100%); margin-top: -80px; }

/* Sécurité z-index */
.carte-autog > * { position: relative; z-index: 1; }

/* =============================== TITRE ================================ */
.carte-autog-title { text-align: center; font-size: 42px; font-weight: 800; color: #1f2329; margin-bottom: 100px; line-height: 1.2; letter-spacing: -0.5px; }

/* =============================== GRID ================================ */
.carte-autog-inner { max-width: 1300px; margin: 0 auto; display: grid; grid-template-columns: repeat(4, 1fr); gap: 40px; }

/* =============================== CARTE ================================ */
.carte-autog-card { background: #ffffff; padding: 90px 40px 45px; text-align: center; border-radius: 16px; border: 1px solid rgba(0, 0, 0, 0.06); box-shadow: 0 10px 40px rgba(0, 0, 0, 0.08); }

/* =============================== LOSANGE (STRUCTURE SAINE) ================================ */
.carte-autog-icon { width: 130px; height: 130px; margin: -130px auto 40px; background: #ffffff; border-radius: 12px; transform: rotate(45deg); overflow: hidden; display: flex; align-items: center; justify-content: center; box-shadow: 0 15px 45px rgba(0, 0, 0, 0.12); }

/* ✅ IMAGE — REMPLISSAGE PARFAIT DU LOSANGE */
.carte-autog-icon img { width: 100%; height: 100%; object-fit: cover; transform-origin: center; transform: rotate(-45deg) scale(1.45); }

/* =============================== TEXTE ================================ */
.carte-autog-card h3 { font-size: 20px; font-weight: 700; margin-bottom: 14px; color: #1f2329; line-height: 1.3; }

.carte-autog-card p { font-size: 16px; line-height: 1.7; color: #666; margin: 0; }

/* =============================== RESPONSIVE ================================ */
@media (max-width: 1100px) { .carte-autog { padding: 150px 20px 120px; clip-path: polygon(0 60px, 100% 0, 100% 100%, 0 100%); margin-top: -60px; } .carte-autog-inner { grid-template-columns: repeat(2, 1fr); gap: 50px; } .carte-autog-title { font-size: 36px; } }

@media (max-width: 600px) { .carte-autog { padding: 120px 20px 80px; clip-path: polygon(0 40px, 100% 0, 100% 100%, 0 100%); margin-top: -40px; } .carte-autog-title { font-size: 28px; margin-bottom: 60px; } .carte-autog-inner { grid-template-columns: 1fr; gap: 60px; } .carte-autog-card { padding: 80px 30px 35px; } .carte-autog-icon { width: 100px; height: 100px; margin-top: -100px; } }

/*----------------------------------------------------------------------------------------------ENTRETIEN VOITURE-------------------------------------------------------------------------------------------------------*/
/* =============================== ENTRETIEN AUTO ================================ */
.entretien-auto { position: relative; background-color: #f5f5f5; padding: 120px 20px; overflow: hidden; }

/* Image de fond */
.entretien-auto::before { content: ""; position: absolute; inset: 0; background-image: url("https://storage.googleapis.com/refpro-app-ca244.appspot.com/customers%2FkfuiW4UuewbUgbKrZ4j5XWu4Fk82%2Fimages%2FDesign_sans_titre_-_2026-02-06T141427618_i6pw.webp"); background-size: cover; background-position: center; opacity: 0.12; z-index: 0; }

.entretien-auto-inner { position: relative; z-index: 1; max-width: 1300px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1.2fr; gap: 80px; align-items: center; }

/* IMAGE */
.entretien-auto-image { display: flex; justify-content: center; }

.entretien-auto-image img { width: 75%; max-width: 420px; height: auto; display: block; }

/* CONTENU */
.entretien-auto-content { max-width: 620px; }

.entretien-auto-subtitle { display: block; font-size: 12px; letter-spacing: 2px; text-transform: uppercase; color: #777; margin-bottom: 10px; }

.entretien-auto-content h2 { font-size: 44px; font-weight: 800; color: #de2217; margin-bottom: 18px; }

.entretien-auto-intro { font-size: 18px; line-height: 1.7; color: #555; margin-bottom: 40px; }

/* GRID TEXTE */
.entretien-auto-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 30px 40px; }

.entretien-auto-item h3 { font-size: 17px; font-weight: 700; text-transform: uppercase; color: #de2217 !important; margin-bottom: 8px; color: #000; }

.entretien-auto-item p { font-size: 17px; line-height: 1.6; color: #666; }

/* =============================== RESPONSIVE ================================ */
@media (max-width: 1024px) { .entretien-auto-inner { grid-template-columns: 1fr; gap: 60px; text-align: center; } .entretien-auto-content { max-width: 100%; margin: 0 auto; } .entretien-auto-image img { width: 65%; } }

@media (max-width: 600px) { .entretien-auto { padding: 80px 20px; } .entretien-auto-content h2 { font-size: 28px; } .entretien-auto-grid { grid-template-columns: 1fr; gap: 26px; } .entretien-auto-image img { width: 85%; max-width: 320px; } }

/*----------------------------------------------------------------------------------------------PNEU-------------------------------------------------------------------------------------------------------*/
/* =============================== PNEU AUTO ================================ */
.pneu-auto { position: relative; background: linear-gradient(135deg, #1a1e24 0%, #252a31 50%, #1f2329 100%); padding: 180px 20px 160px; color: #ffffff; overflow: hidden; clip-path: polygon(0 80px, 100% 0, 100% calc(100% - 80px), 0 100%); margin-top: -80px; margin-bottom: -80px; z-index: 3; }

/* Effet de texture subtile */
.pneu-auto::before { content: ""; position: absolute; inset: 0; background-image: radial-gradient(circle at 20% 30%, rgba(222, 34, 23, 0.08) 0%, transparent 50%), radial-gradient(circle at 80% 70%, rgba(222, 34, 23, 0.05) 0%, transparent 50%); pointer-events: none; z-index: 0; }

/* Motif géométrique discret */
.pneu-auto::after { content: ""; position: absolute; top: 0; right: -100px; width: 600px; height: 600px; background: radial-gradient(circle, rgba(255, 255, 255, 0.02) 1px, transparent 1px); background-size: 30px 30px; opacity: 0.3; z-index: 0; }

.pneu-auto-inner { position: relative; z-index: 1; max-width: 1300px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; align-items: center; gap: 80px; }

/* =============================== CONTENU TEXTE ================================ */
.pneu-auto-content { position: relative; }

.pneu-auto-content h2 { font-size: 52px; font-weight: 800; line-height: 1.1; margin-bottom: 28px; background: linear-gradient(135deg, #ffffff 0%, #e0e0e0 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; letter-spacing: -1px; }

.pneu-auto-text { font-size: 18px; line-height: 1.8; color: #b8bec5; margin-bottom: 45px; }

.pneu-auto-subtitle { font-size: 20px; font-weight: 700; margin-bottom: 24px; color: #ffffff; position: relative; display: inline-block; }

.pneu-auto-subtitle::after { content: ""; position: absolute; bottom: -8px; left: 0; width: 50px; height: 3px; background: linear-gradient(90deg, #de2217 0%, #ff4d42 100%); border-radius: 2px; }

/* =============================== LISTE EN GRILLE 2 COLONNES ================================ */
.pneu-auto-list { list-style: none; padding: 0; margin: 0 0 40px 0; display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px 30px; }

.pneu-auto-list li { position: relative; padding-left: 35px; font-size: 16px; color: #d1d5db; line-height: 1.6; }

/* Icône avec dégradé */
.pneu-auto-list li::before { content: "✓"; position: absolute; left: 0; top: 0; width: 24px; height: 24px; background: linear-gradient(135deg, #de2217 0%, #ff4d42 100%); border-radius: 6px; display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 700; color: #ffffff; box-shadow: 0 4px 12px rgba(222, 34, 23, 0.3); }

/* =============================== CTA ROUGE ================================ */
.pneu-auto-cta { display: inline-block; background: #de2217; color: #ffffff; padding: 13px 34px; border-radius: 8px; font-weight: 600; font-size: 15px; text-decoration: none; transition: transform 0.25s ease, box-shadow 0.25s ease; }

.pneu-auto-cta:hover { transform: translateY(-2px); box-shadow: 0 12px 30px rgba(222, 34, 23, 0.4); }

/* =============================== IMAGE ================================ */
.pneu-auto-image { display: flex; justify-content: center; align-items: center; position: relative; }

/* Cercle décoratif derrière l'image */
.pneu-auto-image::before { content: ""; position: absolute; width: 400px; height: 400px; background: radial-gradient(circle, rgba(222, 34, 23, 0.15) 0%, transparent 70%); border-radius: 50%; z-index: 0; }

.pneu-auto-image img { position: relative; z-index: 1; width: 100%; max-width: 500px; height: auto; display: block; filter: drop-shadow(0 20px 40px rgba(0, 0, 0, 0.4)); }

/* =============================== RESPONSIVE ================================ */
@media (max-width: 1024px) { .pneu-auto { padding: 150px 20px 140px; clip-path: polygon(0 60px, 100% 0, 100% calc(100% - 60px), 0 100%); margin-top: -60px; margin-bottom: -60px; } .pneu-auto-inner { grid-template-columns: 1fr; gap: 60px; } .pneu-auto-content { text-align: center; max-width: 700px; margin: 0 auto; } .pneu-auto-content h2 { font-size: 42px; } .pneu-auto-subtitle::after { left: 50%; transform: translateX(-50%); } .pneu-auto-list { text-align: left; max-width: 600px; margin: 0 auto 40px; } .pneu-auto-image { max-width: 500px; margin: 0 auto; } }

@media (max-width: 600px) { .pneu-auto { padding: 120px 20px 100px; clip-path: polygon(0 40px, 100% 0, 100% calc(100% - 40px), 0 100%); margin-top: -40px; margin-bottom: -40px; } .pneu-auto-inner { gap: 50px; } .pneu-auto-content h2 { font-size: 32px; } .pneu-auto-text { font-size: 15px; margin-bottom: 35px; } .pneu-auto-subtitle { font-size: 18px; margin-bottom: 20px; } /* Liste reste en 2 colonnes même sur mobile */ .pneu-auto-list { grid-template-columns: repeat(2, 1fr); gap: 16px 20px; max-width: 100%; margin-bottom: 35px; } .pneu-auto-list li { font-size: 14px; padding-left: 30px; } .pneu-auto-list li::before { width: 20px; height: 20px; font-size: 10px; } .pneu-auto-cta { padding: 14px 32px; font-size: 14px; } .pneu-auto-image::before { width: 280px; height: 280px; } .pneu-auto-image img { max-width: 320px; } }

/* Très petits écrans */
@media (max-width: 400px) { .pneu-auto-list { gap: 14px 15px; } .pneu-auto-list li { font-size: 13px; padding-left: 28px; } .pneu-auto-content h1 { font-size: 28px; } .pneu-auto-cta { padding: 12px 28px; font-size: 13px; } }

/* =============================== PRESENTATION GARAGE ================================ */
.presentation-garage { position: relative; padding: 110px 20px; background: linear-gradient(180deg, #1f2329, #191d22); color: #ffffff; overflow: hidden; clip-path: polygon(0 0, 100% 0, 100% calc(100% - 70px), 0 100%); }

/* IMAGE DE FOND (OVERLAY) */
.presentation-garage-bg { position: absolute; inset: 0; background-image: url("https://storage.googleapis.com/refpro-app-ca244.appspot.com/customers%2FkfuiW4UuewbUgbKrZ4j5XWu4Fk82%2Fimages%2FDesign_sans_titre_-_2026-02-06T091435204_4rmu.webp"); background-size: cover; background-position: center; opacity: 0.18; z-index: 0; }

/* CONTENU */
.presentation-garage-inner { position: relative; z-index: 1; max-width: 1320px; margin: 0 auto; display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 70px; align-items: center; }

/* ===== BLOC TEXTE ===== */
.presentation-garage-content { display: flex; flex-direction: column; align-items: flex-start; text-align: left; }

/* LOGO */
.presentation-garage-logo { width: 220px; margin-bottom: 20px; }

/* BADGE */
.presentation-garage-badge { display: inline-block; background: rgba(222, 34, 23, 0.15); color: #de2217; padding: 8px 14px; border-radius: 8px; font-size: 16px; font-weight: 600; margin-bottom: 26px; }

/* TITRE */
.presentation-garage-content h1 { font-size: 42px; line-height: 1.15; margin-bottom: 22px; font-weight: 800; }

/* TEXTE */
.presentation-garage-content p { font-size: 18px; line-height: 1.65; color: #d1d5db; max-width: 600px; margin-bottom: 34px; }

/* CTA */
.presentation-garage-cta { display: inline-block; background: #de2217; color: #ffffff; padding: 13px 34px; border-radius: 8px; font-weight: 600; font-size: 15px; text-decoration: none; transition: transform 0.25s ease, box-shadow 0.25s ease; }

.presentation-garage-cta:hover { transform: translateY(-2px); box-shadow: 0 12px 30px rgba(222, 34, 23, 0.4); }

/* IMAGE */
.presentation-garage-image-wrapper img { width: 85%; height: auto; border-radius: 42px; display: block; }

/* =============================== RESPONSIVE ================================ */
@media (max-width: 1024px) { .presentation-garage-inner { grid-template-columns: 1fr; gap: 55px; text-align: center; } .presentation-garage-content { align-items: center; text-align: center; } .presentation-garage-logo { margin-left: auto; margin-right: auto; } .presentation-garage-badge { margin-left: auto; margin-right: auto; } .presentation-garage-content p { margin-left: auto; margin-right: auto; } .presentation-garage-image-wrapper img { width: 70%; margin: 0 auto; border-radius: 34px; } }

@media (max-width: 600px) { .presentation-garage { padding: 90px 16px; clip-path: polygon(0 0, 100% 0, 100% calc(100% - 40px), 0 100%); } .presentation-garage-content h1 { font-size: 30px; } .presentation-garage-content p { font-size: 15px; } .presentation-garage-image-wrapper img { width: 85%; border-radius: 26px; } }

@media (max-width: 400px) { .presentation-garage-content h1 { font-size: 26px; } .presentation-garage-image-wrapper img { width: 100%; border-radius: 20px; } }

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