.rev_slider_wrapper.fullscreen-container,.rev_slider.fullscreenbanner { height: 100vh !important; max-height: 100vh !important;}.rs-background-video-layer video { object-fit: cover !important; height: 100% !important; width: 100% !important; max-width: 100vw; max-height: 100vh;}#welcome_wrapper { height: 100vh !important; max-height: 100vh !important; overflow: hidden !important;}.tp-fullwidth-forcer { height: 100vh !important; pointer-events: none; visibility: hidden;}header.header.header-bottom { margin-top: -68px;}.list-box.applications {list-style: none !important;}.bg-aerial5 {background-image: url('images/background/bg-aerial5.jpg');background-repeat: no-repeat;background-position: right bottom;}
.sidebar-sticky {
    position: sticky;
    top: 100px;
    z-index: 10;
}
.sticky-sm-bottom {
    box-shadow: 5px 12px 20px 0 rgba(0,0,0,0.05);
}
#page_fr_historique p > strong.text-primary {
    float: left;
    display: inline;
    width: 50px;
}

body {
    font-family: 'Poppins', sans-serif;
    font-size: 15px;
    font-weight: 400;
    color:#6c6c6c;
    text-align: justify;
    cursor: default;
}

@media (max-width: 768px) {
    
    header.header.header-bottom {
        bottom: 0px;
        margin-top: -50px;
    }
    header.site-header {
        position: sticky;
        min-height: 50px !important;
    }
    .sidebar-sticky .ext-sidebar-menu {
        display: none;
    }
    .sticky-sm-bottom {
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        z-index: 1055;
        background: white;
        box-shadow: 0 -2px 8px rgba(0, 0, 0, 0.15) !important;
        padding: 0.75rem 1rem;
        border-radius: 0 !important;
        margin-bottom: 0 !important;
    }
    .footer-bottom {
        padding: 20px 20px 60px 20px !important;
    }
}
.testimonial-pic.radius img {
	width: 100%;
	height: 70px;
	border-radius: 100%;
	-webkit-border-radius: 100%;
}

html {
    scroll-padding-top: 80px; /* adapte à la hauteur de ton header */
}

.list-columns-2 {
    column-count: 2;
    column-gap: 2rem;
    padding-left: 1.2em;
}

.list-columns-2 li {
    break-inside: avoid;
    margin-bottom: 0.5rem;
}

ul.list-2 li a {
    display: inline-block;
    max-width: 140px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    vertical-align: middle;
}
@media (max-width: 768px) {
    ul.list-2 li a {
        max-width: 120px;
    }
}
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.plus span {
    color: #fff;
}
.plus:hover span {
    color: inherit;
}

.type::after {
  content: '_';
  animation: blink 1s step-start infinite;
}

@keyframes blink {
  50% {
    opacity: 0;
  }
}

.plaquette {
	background-image: url('/images/fours/plaquette.gif');
	background-repeat: no-repeat;
	padding: 20px;
	font-size: 0.75rem;
	font-family: consolas;
	height: 164px;
	width: 276px;
}
.plaquette p {
    margin: 0;
    line-height: normal;
    color: #888;
    text-shadow:
      inset 1px 1px 2px #000, /* cette ligne ne marche pas en CSS pur */
      1px 1px 2px rgba(255, 255, 255, 0.3),
     -1px -1px 2px rgba(0, 0, 0, 0.6);
}
.site-footer {
    position: relative;
}

.cookies_list {
  list-style: none;
  padding-left: 0;
}

.cookies_list li {
  position: relative;
  margin: 0 0 1em 0;
  padding-left: 1.8em;
}

.cookies_list li::before {
  font-family: "Font Awesome 6 Pro";
  font-weight: 300;
  content: "\f564";
  position: absolute;
  left: 0;
  top: 0;
}

.page-content p a:hover {
    text-decoration: underline;
    color: var(--color-primary);
}


.page-meta{display:inline-flex;align-items:center;gap:.6em}
.pm-cal{display:inline-flex;align-items:center;gap:.4em}
.pm-date{
  display:inline-block;
  white-space:nowrap;
  overflow:hidden;
  max-width:0;
  transform:scaleX(0);
  transform-origin:left center;
  opacity:0;
  transition:max-width .25s ease, transform .25s ease, opacity .25s ease;
}
.pm-cal:hover .pm-date,
.pm-cal:focus .pm-date{
  max-width:20rem;          /* assez large pour la date */
  transform:scaleX(1);
  opacity:1;
}

@media (max-width: 768px) {
  .page-meta i {
    font-size: 1.5rem;      /* icônes plus grandes */
    padding: 8px;           /* augmente la zone tactile */
  }
}


.marquee {
  height: 6em;
  overflow: hidden;
  position: relative;
}

.marquee-content {
  list-style: none;
  margin: 0;
  padding: 0;
  animation: zigzag 20s linear infinite alternate;
}

.marquee-content li {
  line-height: 2em;         /* hauteur d’un élément */
}

/* Animation zig-zag */
@keyframes zigzag {
  0%   { transform: translateY(0); }
  100% { transform: translateY(-12em); } /* décale pour montrer tout */
}

/* Pause au survol */
.marquee:hover .marquee-content {
  animation-play-state: paused;
}

/* Masonry 3 colonnes responsive */
.masonry{column-count:3;column-gap:1rem}
@media (max-width: 992px){.masonry{column-count:2}}
@media (max-width: 576px){.masonry{column-count:1}}


.masonry-item {
  break-inside: avoid;
  margin-bottom: 1rem;
  overflow: hidden;
  border-radius: .5rem;
}

.masonry-item img {
  width: 100%;
  height: auto;
  display: block;
  transition: transform .3s ease;
}

.masonry-item.zoom img:hover {
  transform: scale(1.05);
}


.search-result {
	margin: 20px 0;
	padding: 10px;
}

.search-result:hover {
	background-color: #f5f5f5;
	border-radius: 5px;
}






@media screen {
    
  .print-header, 
  .print-cover,
  .print { 
    display: none; 
  }
  
  .page-header {
    cursor: default;
	margin-bottom: 60px;
  }
  .page-header *,
  .breadcrumb-item + .breadcrumb-item::before {
	color: #aaa !important;
  }
  
}






@media print { header, footer, nav, aside, .navbar, .site-header, .site-footer, .hero, .hero-section, .masthead, .offcanvas, .sidebar, .cookie, .cookie-banner, .modal, .video-bg, 
    .parallax, .breadcrumbs, .page-title, .page-header, .topbar, .bottom-bar, .cta, .newsletter, .social, .footer-widgets, .floating-btn, .back-to-top, .alert, .toast, 
    .gallery-thumbs, .tabs, .accordion-controls, .pagination, .related, .comments, .btn, .badge, .carousel-control-prev, .carousel-control-next, 
    .carousel-indicators, .swiper-button-prev, .swiper-button-next, .swiper-pagination, .swiper-scrollbar, .slick-arrow, .slick-dots, .owl-nav, 
    .owl-dots, .noprint {
        display: none !important;
    }
    
    html, body { margin: 0 !important; padding: 0 !important; background: #fff !important; color: #fff !important; } 
    
    #print-root, main, body > * { position: relative; z-index: 1; background: transparent !important; } 
    
    @page { size: A4 portrait; margin: 10mm 20mm 15mm 20mm; } 
    
    .print-header{ position: fixed; top:0; left:0; right:0; height:16mm; padding:2mm 10mm; box-sizing:border-box; background:#fff; border-bottom:1px solid #ddd; z-index:9999; display:flex; align-items:center; gap:8mm; } 
    .print-header img{ max-height:12mm; position: absolute; left: 0; } 
    .print-header .print-title{ font-size:13pt; position: absolute; right: 0; } 
    .print-cover { display: block; page-break-after: always; text-align: center; padding-top: 50mm; } 
    
    .cover-title { font-size: 28pt; font-weight: normal; margin-bottom: 20mm; }
    .cover-desc { font-size: 16pt; margin-bottom: 20mm; } 
    .cover-image { max-width: 100%; max-height: 120mm; object-fit: contain; margin: 0 auto; display: block; } 
    .container, .container-fluid, .site-content, .page-content, .entry-content, main, #content, .content { max-width: none !important; width: auto !important; margin: 0 !important; padding: 0 !important; }
    
    .page-content, .entry-content, main, #content { padding-top: 22mm !important; /* hauteur header + marge */ box-sizing: border-box; -webkit-box-decoration-break: clone; box-decoration-break: clone; }
    
    /* Grilles : enlever gutters et colonnes multiples pour éviter les marges internes */ 
    .row { margin-left: 0 !important; margin-right: 0 !important; } [class*="col-"] { 
        padding-left: 0 !important; padding-right: 0 !important; width: 100% !important; max-width: 100% !important; 
        float: none !important; flex: 0 0 auto !important; 
        
    } /* Médias fluides plein cadre */ 
        
    img, svg, canvas { max-width: 100% !important; height: auto !important; page-break-inside: avoid; } video, iframe { display: none !important; } table { width: 100% !important; table-layout: auto !important; page-break-inside: auto; } /* Carousels : aplatir et empiler les slides */ .carousel, .carousel-inner, .carousel-item { position: static !important; } .carousel-item { display: block !important; opacity: 1 !important; visibility: visible !important; transform: none !important; page-break-inside: avoid; } .swiper, .swiper-wrapper { overflow: visible !important; } .swiper-wrapper { transform: none !important; display: block !important; } .swiper-slide { display: block !important; width: auto !important; page-break-inside: avoid; } .slick-track { transform: none !important; width: auto !important; } .slick-slide { display: block !important; float: none !important; page-break-inside: avoid; } .owl-carousel .owl-stage { transform: none !important; } .owl-carousel .owl-item { display: block !important; float: none !important; page-break-inside: avoid; } /* Coupures propres */ h1, h2, h3 { page-break-after: avoid; } p, li, blockquote { orphans: 3; widows: 3; } /* Balise de saut manuel */ .page-break { page-break-before: always; break-before: page; } .page-content { display: block !important; page-break-after: avoid !important; /* évite de forcer une nouvelle page */ break-after: avoid !important; /* syntaxe moderne */ margin-bottom: 0 !important; padding-bottom: 0 !important; } .page-content > *:last-child { page-break-after: avoid !important; break-after: avoid !important; margin-bottom: 0 !important; padding-bottom: 0 !important; } /* Coupe tout ce qui suit */ .page-content ~ * { display: none !important; visibility: hidden !important; height: 0 !important; overflow: hidden !important; } body::after { content: none !important; /* pas d’élément fantôme qui pousse une page */ display: none !important; } .section-full { padding-top: 0 !important; } h2 { margin-bottom: 1cm !important; } .page-content { page-break-after: always !important; break-after: page !important; } /* Et masquer ensuite pour éviter la page blanche */ .page-content ~ * { display: none !important; } .page-content { padding-bottom: 0 !important; margin-bottom: 0 !important; border-bottom: none !important; font-size: 10pt !important; line-height: 1.2; } .page-content p { text-align: justify; } .page-content p, .page-content li { font-size: 10pt !important; line-height: 1.2; } .page-content p.font-18 { font-size: 14pt !important; } 
        
  hr.dlab-divider {
    border: 0;
    border-top: 1px solid #000;
    margin: 5mm 0;
    page-break-after: avoid;
  }
  
}

.dz_error-404-area {
	height: calc(100vh - 190px) !important;
}
.page-404 .page-content.bg-white {
	background-image: url(images/error/404.jpg);
}



/* Variante paysage si nécessaire */
/*
@media print {
  @page { size: A4 landscape; margin: 10mm 12mm; }
}
*/
