/* ==========================
          RESET / BASE
========================== */

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
    font-family:Arial, sans-serif;
}

html,
body{
    margin:0;
    padding:0;
}

body{
    background-color:#f5f5f5;
    color:#333;
}

a{
    text-decoration:none;
    color:inherit;
}

@keyframes fadeIn{
    to{ opacity:1; }
}

/* ==========================
            HEADER
========================== */

header{
    background-color:#1a1a1a;
    height:60px;
    width:100%;
    display:flex;
    align-items:center;
    justify-content:center;
    box-shadow:0 4px 8px rgba(0,0,0,0.3);
    position:relative;
    overflow:hidden;
}

.header-text{
    color:#cb2727;
    font-size:18px;
    font-weight:700;
    font-style:italic;
    text-align:center;
    opacity:0;
    animation:fadeIn 1.5s forwards;
}

/* ==========================
             HERO
========================== */

.hero{
    position:relative;
    background-image:url("images/IMG_4983.jpg");
    background-position:center 90%;
    background-size:cover;
    background-repeat:no-repeat;
    min-height:70vh;
    display:flex;
    justify-content:center;
    align-items:center;
    text-align:center;
    color:#fff;
    padding:60px 20px 100px 20px;
    flex-direction:column;
}

.hero::before{
    content:"";
    position:absolute;
    inset:0;
    background:rgba(0,0,0,0.4);
}

.hero-logo-container,
.hero > div{
    position:relative;
    z-index:2;
}

.hero-logo-container{
    margin-bottom:20px;
    opacity:0;
    animation:fadeIn 2s 0.4s forwards;
}

.hero-logo{
    max-width:280px;
    height:auto;
    display:block;
    margin:0 auto;
}

.hero h1{
    position:relative;
    z-index:2;
    font-size:2.5rem;
    font-weight:bold;
    margin-bottom:30px;
    padding:20px;
    border-radius:10px;
    opacity:0;
    animation:fadeIn 2s 0.8s forwards;
    font-style:italic;
}

.license-text{
    font-size:18px;
    font-weight:normal;
    display:block;
    margin-top:10px;
    font-style:italic;
}

/* ==========================
            BUTTONS
========================== */

.call-btn-big{
    background-color:#000;
    color:#fff;
    padding:15px 35px;
    font-size:20px;
    border-radius:5px;
    border:none;
    cursor:pointer;
    transition:0.3s;
}

.call-btn-big:hover{
    background-color:#a31f1f;
    transform:scale(1.05);
}

.hero-call-container{
    position:relative;
    z-index:2;
    margin-top:15px;
    text-align:center;
}

.learn-more-btn-white{
    display:inline-block;
    padding:14px 30px;
    background-color:#fff;
    color:#1a1a1a;
    font-weight:bold;
    border-radius:8px;
    transition:all 0.3s ease;
    box-shadow:0 4px 10px rgba(0,0,0,0.2);
    text-align:center;
    width:fit-content;
}

.learn-more-btn-white:hover{
    background-color:#f2f2f2;
    transform:translateY(-3px);
    box-shadow:0 6px 15px rgba(0,0,0,0.3);
}

#phoneNumber{
    display:none;
    margin-top:15px;
    font-size:24px;
    font-weight:bold;
    color:#fff;
    text-shadow:2px 2px 4px rgba(0,0,0,0.5);
}

/* ==========================
            ABOUT
========================== */

.about{
    background-color:#cb2727;
    color:#fff;
    padding:60px 20px 80px 20px;
}

.about-container{
    max-width:1100px;
    margin:0 auto;
}

.about h2{
    text-align:center;
    margin-bottom:50px;
    font-size:32px;
}

.about-flex{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:50px;
}

.about-text{
    flex:1.5;
    text-align:left;
}

.about-text p{
    font-size:18px;
    line-height:1.8;
    margin-bottom:20px;
}

.about-right{
    flex:1;
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:25px;
}

.gov-logo{
    max-width:220px;
    height:auto;
    border-radius:5px;
    filter:drop-shadow(0 0 10px rgba(255,255,255,0.2));
}

/* ==========================
     BUSINESS BG SECTION
========================== */

.bg-image-section{
    position:relative;
    background-image:
        linear-gradient(rgba(255,255,255,0.9), rgba(255,255,255,0.15)),
        url("images/ChesterHillAfterCopy.jpg");
    background-size:cover;
    background-position:center;
    background-repeat:no-repeat;
    padding:40px 0 80px 0;
    margin-top:0;
}

.bg-image-section > *{
    position:relative;
    z-index:1;
}

/* ==========================
         WORK SELECTION
========================== */

.work-title{
    text-align:center;
    padding:40px 20px 20px 20px;
}

.work-title h2{
    font-size:28px;
    color:#1a1a1a;
    font-weight:bold;
}

.work{
    display:grid;
    grid-template-columns:repeat(auto-fit, minmax(150px, 1fr));
    gap:15px;
    padding:40px 20px;
    max-width:900px;
    margin:0 auto;
}

.work-card{
    background-color:#fff;
    color:#1a1a1a;
    border:2px solid #cb2727;
    border-radius:10px;
    padding:20px;
    text-align:center;
    font-size:14px;
    font-weight:bold;
    cursor:pointer;
    transition:all 0.3s ease;
    box-shadow:0 2px 8px rgba(0,0,0,0.1);
    min-height:150px;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
}

.work-card:hover{
    background-color:#cb2727;
    color:#fff;
    transform:translateY(-3px);
    box-shadow:0 6px 15px rgba(0,0,0,0.2);
}

.work-card h2{
    margin-bottom:0;
    font-size:16px;
    line-height:1.3;
}

.work-card a{
    display:none;
}

/* ==========================
        OTHER SERVICES
========================== */

.other-title{
    text-align:center;
    padding:40px 20px 20px 20px;
}

.other-title h2{
    font-size:32px;
    color:#1a1a1a;
    font-weight:bold;
}

.other-services{
    display:grid;
    grid-template-columns:repeat(3, 1fr);
    gap:20px;
    max-width:1200px;
    margin:0 auto 40px auto;
    padding:20px 40px 60px 40px;
    box-sizing:border-box;
}

.other-card{
    background-color:#fff;
    border:2px solid #cb2727;
    border-radius:10px;
    text-align:center;
    padding:30px 15px;
    box-sizing:border-box;
}

.other-card h3{
    color:#1a1a1a;
    margin-bottom:15px;
    font-size:24px;
}

.other-card p{
    font-size:16px;
    color:#555;
    margin-bottom:10px;
}

.other-card a{
    display:inline-block;
    text-align:center;
    background-color:#cb2727;
    color:#000;
    padding:10px 20px;
    margin-top:15px;
    border-radius:5px;
    font-weight:bold;
}

/* ==========================
         AREAS SECTION
========================== */

.area-title h2{
    text-align:center;
    color:#000;
    font-size:2rem;
    margin-top:40px;
    margin-bottom:20px;
    text-transform:none;
}

.areas{
    display:grid;
    grid-template-columns:repeat(3, 1fr);
    gap:20px;
    padding:40px 20px;
    max-width:1100px;
    margin:0 auto;
    box-sizing:border-box;
}

.area-card{
    background-color:#fff;
    border:2px solid #cb2727;
    border-radius:10px;
    padding:20px;
    text-align:center;
    font-weight:bold;
    cursor:pointer;
    transition:transform 0.3s ease, box-shadow 0.3s ease;
    box-shadow:0 2px 8px rgba(0,0,0,0.1);
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    min-height:180px;
}

.area-card h2{
    margin:0 0 15px 0;
    font-size:16px;
    line-height:1.3;
    color:#1a1a1a;
}

.area-card:hover{
    transform:translateY(-5px);
    box-shadow:0 6px 15px rgba(0,0,0,0.15);
}

.area-card a{
    display:inline-block;
    background-color:#cb2727;
    color:#000;
    padding:12px 25px;
    border-radius:5px;
    font-weight:bold;
    box-shadow:0 4px 6px rgba(0,0,0,0.2);
    transition:background-color 0.3s ease, color 0.3s ease;
}

.area-card a:hover{
    background-color:#c41a1f;
    color:#fff;
}

/* ==========================
     CONTACT BG WRAPPER
========================== */

.contact-bg-wrap{
    background:
        linear-gradient(rgba(255,255,255,0.5), rgba(255,255,255,0.3)),
        url("images/IMG_6555copy.jpg");
    background-size:cover;
    background-position:center;
    background-repeat:no-repeat;
    padding:80px 20px;
}

/* ==========================
         CONTACT FORM
========================== */

.contact-form-section{
    padding:0 0 60px 0;
    margin-bottom:0;
    display:flex;
    justify-content:center;
    align-items:flex-start;
    background:transparent;
}

.contact-container{
    display:flex;
    flex-wrap:wrap;
    max-width:1200px;
    margin:0 auto;
    gap:150px;
    justify-content:center;
    align-items:flex-start;
}

.contact-form{
    flex:1 1 450px;
    max-width:520px;
    padding:30px 20px;
    margin-bottom:40px;
    background-color:#f5f5f5;
    border-radius:10px;
    border:3px solid #cb2727;
    box-shadow:0 4px 12px rgba(0,0,0,0.1);
}

.contact-form h2{
    font-size:26px;
    color:#1a1a1a;
    margin-bottom:20px;
    text-align:center;
}

.contact-form form{
    display:flex;
    flex-direction:column;
    gap:10px;
}

.contact-form .form-row{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
}

.contact-form input,
.contact-form textarea{
    padding:12px;
    font-size:15px;
    border-radius:6px;
    border:1px solid #ccc;
    width:100%;
    box-sizing:border-box;
}

.contact-form .form-row input{
    flex:1 1 45%;
    min-width:120px;
}

.contact-form textarea{
    min-height:150px;
}

.contact-form button{
    padding:15px 30px;
    font-size:16px;
    font-weight:bold;
    background-color:#cb2727;
    color:#000;
    border:none;
    border-radius:8px;
    cursor:pointer;
    transition:background 0.3s, transform 0.2s;
}

.contact-text{
    flex:1 1 0;
    max-width:450px;
    color:#1a1a1a;
    display:flex;
    flex-direction:column;
    justify-content:center;
    font-size:18px;
    line-height:1.6;
}

.contact-text h2{
    font-size:28px;
    margin-bottom:15px;
}

.contact-text p{
    font-size:16px;
}

.contact-form .role-selection{
    text-align:center;
    margin:10px 0;
}

.contact-form .role-selection label{
    display:inline-flex;
    flex-direction:column;
    align-items:center;
    gap:5px;
    margin:5px 10px;
    font-weight:normal;
    cursor:pointer;
}

.contact-form .role-selection input[type="radio"]{
    transform:scale(1.2);
    cursor:pointer;
}

.role-selection{
    display:flex;
    flex-wrap:wrap;
    justify-content:center;
    align-items:flex-start;
    gap:8px 6px;
    margin:15px 0;
}

.role-inline-label{
    font-weight:bold;
    font-size:15px;
    align-self:center;
}

.role-option{
    display:flex;
    flex-direction:column;
    align-items:center;
    font-weight:normal;
    cursor:pointer;
}

.role-option input[type="radio"]{
    transform:scale(1.2);
    margin-bottom:4px;
    cursor:pointer;
}

.services-list{
    list-style-type:disc;
    padding-left:20px;
    margin:10px 0;
    font-size:16px;
    font-weight:bold;
    line-height:1.6;
    color:#1a1a1a;
}

.services-list li{
    margin-bottom:5px;
}

.next-section{
    margin-top:40px;
}

/* ==========================
         PHOTO SLIDER
========================== */

.section-divider{
    width:70%;
    max-width:900px;
    height:3px;
    background:white;
    margin:60px auto;
    border-radius:2px;
    opacity:0.9;
	background:#cb2727;
}

.gallery-title{
    font-size:32px;
    font-weight:bold;
    color:#1a1a1a;
    margin-bottom:10px;
    letter-spacing:2px;
}

.photo-slider{
    padding:10px 0 30px 0;
    text-align:center;
    background:transparent !important;
    background:rgba(255,255,255,0.8);
    margin:20px auto;
    padding:40px;
    border-radius:10px;
    max-width:1000px;
}

.slider-container{
    position:relative;
    margin:10px auto;
    margin-top:0 !important;
    padding-top:0 !important;
    display:flex;
    justify-content:center;
    align-items:center;
    background:transparent !important;
    border:none !important;
    width:90%;
    max-width:1100px;
    overflow:visible;
    box-shadow:none !important;
}

.slider-image{
    display:none;
    width:auto;
    max-width:100%;
    height:auto;
    max-height:550px;
    object-fit:contain;
    margin:0 auto;
    border:3px solid #cb2727;
    box-shadow:0 4px 15px rgba(0,0,0,0.3);
}

.slider-image:first-of-type{
    display:block;
}

.slider-btn{
    position:absolute;
    top:50%;
    transform:translateY(-50%);
    background-color:#cb2727;
    border:none;
    color:#fff;
    cursor:pointer;
    border-radius:50%;
    width:45px;
    height:45px;
    transition:background 0.3s;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:20px;
    line-height:1;
    z-index:10;
}

.slider-btn:hover{
    background-color:rgba(203,39,39,1);
    transform:scale(1.1);
    transition:0.2s;
}

.slider-btn.prev{
    left:10px;
    transform:translate(-2%, -50%);
}

.slider-btn.next{
    right:10px;
    transform:translate(2%, -50%);
}

/* ==========================
            BRANDS
========================== */

.after-about-fullwidth{
    width:100% !important;
    background-color:#fff !important;
    padding:40px 0 !important;
    margin:0 !important;
    display:block !important;
}

.brands-inner-container{
    width:100%;
    margin:0 auto;
    text-align:center;
}

.brands-img{
    width:100% !important;
    max-width:750px !important;
    height:auto !important;
    display:block;
    margin:0 auto;
}

.brands-reveal{
    opacity:0;
    transform:translateX(-80px);
    transition:opacity 0.8s ease, transform 0.8s ease;
}

.brands-reveal.show{
    opacity:1;
    transform:translateX(0);
}

/* ==========================
       SAFETY PROTOCOLS
========================== */

.safety-section{
    position:relative;
    z-index:1;
    padding-top:60px;
}

.safety-container{
    display:flex;
    flex-wrap:wrap;
    max-width:1200px;
    margin:0 auto;
    gap:40px;
    align-items:center;
    justify-content:center;
}

.safety-text{
    flex:1 1 450px;
    color:#1a1a1a;
    display:flex;
    flex-direction:column;
    justify-content:center;
    padding:0 20px;
    box-sizing:border-box;
}

.safety-text h2{
    font-size:28px;
    margin-bottom:15px;
}

.safety-text p,
.safety-text ul{
    font-size:16px;
    line-height:1.6;
    margin-bottom:15px;
}

.safety-text ul{
    list-style-type:disc;
    padding-left:20px;
}

.safety-text li{
    margin-bottom:8px;
}

.safety-image{
    flex:1 1 450px;
    display:flex;
    justify-content:center;
    overflow:hidden;
    border-radius:12px;
    padding:0 15px;
    box-sizing:border-box;
}

.safety-image img{
    max-width:100%;
    height:auto;
    display:block;
    border-radius:12px;
    object-fit:cover;
}

/* ==========================
         USEFUL INFO
========================== */

.useful-info{
    background-color:#cb2727;
    padding:60px 20px 140px 20px;
    color:#fff;
    position:relative;
}

.useful-info::after{
    content:"";
    position:absolute;
    bottom:40px;
    left:50%;
    transform:translateX(-50%);
    width:70%;
    max-width:900px;
    height:3px;
    background:#fff;
    border-radius:2px;
    opacity:0.9;
}

.info-container{
    max-width:1100px;
    margin:0 auto;
}

.useful-info h2{
    text-align:center;
    font-size:32px;
    margin-bottom:40px;
    letter-spacing:1px;
}

.info-flex{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:40px;
}

.info-text{
    flex:1;
}

.info-list{
    list-style-type:none;
    padding:0;
}

.info-list li{
    font-size:18px;
    font-weight:bold;
    margin-bottom:20px;
    position:relative;
    padding-left:25px;
}

.info-list li::before{
    content:"•";
    position:absolute;
    left:0;
    color:#fff;
}

.info-photo{
    flex:1;
    text-align:center;
}

.info-photo img{
    width:100%;
    max-width:500px;
    height:auto;
    border:3px solid #fff;
    border-radius:8px;
    box-shadow:0 4px 15px rgba(0,0,0,0.2);
}

/* ==========================
        ASBESTOS BLOCK
========================== */

.reveal-left{
    opacity:0;
    transform:translateX(-30px);
    transition:opacity 0.6s ease, transform 0.6s ease;
}

.reveal-left.show{
    opacity:1;
    transform:translateX(0);
}

/* stagger effect */
.asbestos-signs .asbestos-card:nth-child(1){ transition-delay:0.1s; }
.asbestos-signs .asbestos-card:nth-child(2){ transition-delay:0.2s; }
.asbestos-signs .asbestos-card:nth-child(3){ transition-delay:0.3s; }
.asbestos-signs .asbestos-card:nth-child(4){ transition-delay:0.4s; }

.asbestos-block{
    background-color:#cb2727;
    color:#fff;
    padding:60px 20px;
}

.asbestos-container{
    display:flex;
    gap:40px;
    max-width:1200px;
    margin:0 auto;
    flex-wrap:wrap;
    padding:0 20px 140px 20px;
    box-sizing:border-box;
    position:relative;
}

.asbestos-container::after{
    content:"";
    position:absolute;
    bottom:40px;
    left:50%;
    transform:translateX(-50%);
    width:70%;
    max-width:900px;
    height:3px;
    background:#fff;
    border-radius:2px;
    opacity:0.9;
}

.asbestos-left{
    flex:1 1 400px;
    display:flex;
    flex-direction:column;
    align-items:center;
}

.asbestos-left h2{
    font-size:28px;
    margin-bottom:25px;
    color:#fff;
    text-align:center;
}

.asbestos-signs{
    display:flex;
    flex-direction:column;
    gap:25px;
    align-items:center;
}

.asbestos-card,
.asbestos-signs .work-card{
    background-color:#333;
    color:#fff;
    border:2px solid #fff;
    padding:25px;
    border-radius:12px;
    text-align:center;
    font-weight:bold;
    cursor:default;
    display:flex;
    align-items:center;
    justify-content:center;
    box-shadow:0 2px 8px rgba(0,0,0,0.15);
    position:relative;
    transition:all 0.25s ease;
    min-height:80px;
    width:280px;
}

.asbestos-card:hover,
.asbestos-signs .work-card:hover{
    background-color:#fff;
    color:#000;
    transform:translateY(-3px);
    box-shadow:0 6px 15px rgba(0,0,0,0.25);
}

.asbestos-card::after,
.asbestos-signs .work-card::after{
    content:attr(data-tooltip);
    position:absolute;
    bottom:130%;
    left:50%;
    transform:translateX(-50%);
    width:220px;
    background:#fff;
    color:#222;
    padding:10px;
    border-radius:6px;
    font-size:13px;
    line-height:1.4;
    opacity:0;
    pointer-events:none;
    box-shadow:0 4px 10px rgba(0,0,0,0.2);
    transition:opacity 0.25s ease;
    z-index:10;
}

.asbestos-card::before,
.asbestos-signs .work-card::before{
    content:"";
    position:absolute;
    bottom:120%;
    left:50%;
    transform:translateX(-50%);
    border-width:6px;
    border-style:solid;
    border-color:#fff transparent transparent transparent;
    opacity:0;
    transition:opacity 0.25s ease;
}

.asbestos-card:hover::after,
.asbestos-card:hover::before,
.asbestos-signs .work-card:hover::after,
.asbestos-signs .work-card:hover::before{
    opacity:1;
}

.asbestos-right{
    display:flex;
    flex-direction:column;
    justify-content:flex-start;
    flex:1 1 380px;
}

.asbestos-right h2{
    margin-bottom:20px;
    text-align:center;
    font-size:28px;
    line-height:1.2;
}

.asbestos-todo{
    list-style:disc inside;
    font-size:16px;
    line-height:1.8;
}

.asbestos-todo li{
    margin-bottom:15px;
}

/* ==========================
       GOVERNMENT VIDEOS
========================== */

.asbestos-video-title{
    text-align:center;
    margin-top:60px;
    margin-bottom:40px;
    font-size:30px;
    color:#fff;
}

.gov-video-container{
    display:flex;
    justify-content:center;
    align-items:stretch;
    gap:40px;
    flex-wrap:wrap;
}

.gov-video-card{
    background:#fff;
    padding:20px;
    border-radius:10px;
    box-shadow:0 6px 15px rgba(0,0,0,0.25);
    text-align:center;
}

.gov-video-card p{
    margin-top:12px;
    font-size:15px;
    color:#333;
    font-weight:bold;
}

.gov-video-youtube{
    max-width:500px;
    width:100%;
}

.gov-video-youtube iframe{
    width:100%;
    aspect-ratio:16 / 9;
    border:none;
    border-radius:6px;
}

.gov-learn-btn{
    margin-top:20px;
    align-self:center;
}

.video-fallback{
    width:100%;
    aspect-ratio:16 / 9;
    background:#2b2b2b;
    border-radius:6px;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    padding:20px;
    text-align:center;
    color:#fff;
}

.video-fallback p{
    color:#fff;
    margin-bottom:18px;
    font-size:16px;
    font-weight:600;
}

.gov-logos-image{
    margin-top:20px;
    display:flex;
    justify-content:center;
    align-items:center;
}

.gov-logos-image img{
    width:100%;
    max-width:180px;
    height:auto;
    display:block;
}

.gov-video-facebook{
    max-width:340px;
    width:100%;
}

.gov-video-facebook iframe{
    width:100%;
    height:500px;
    border:none;
    border-radius:6px;
}

/* ==========================
             FAQ
========================== */

.faq{
    position: relative;
    background-image: url("images/AsbestosMaterial.jpeg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    padding: 80px 20px;
}

/* white soft panel like the old site */
.faq::before{
    content:"";
    position:absolute;
    top:0;
    left:0;
    right:0;
    bottom:0;
    background: rgba(255,255,255,0.75);
}

/* keep FAQ content above overlay */
.faq > *{
    position:relative;
    z-index:2;
    max-width:1000px;
    margin:0 auto;
}

.faq-container{
    max-width:1100px;
    margin:0 auto;
    background:rgba(255,255,255,0.55);
    backdrop-filter:blur(2px);
    -webkit-backdrop-filter:blur(2px);
    padding:50px 40px;
    border-radius:12px;
}

.faq h2{
    font-size:32px;
    color:#1a1a1a;
    font-weight:bold;
    text-align:center;
    margin-bottom:50px;
}

.faq-item{
    margin-bottom:20px;
    border-radius:10px;
    background-color:#fff;
    box-shadow:0 4px 10px rgba(0,0,0,0.1);
    overflow:hidden;
	max-width: 1000px;
    margin: 0 auto 20px auto;
}

.faq-question{
    width:100%;
    text-align:left;
    padding:20px;
    font-size:17px;
    font-style:normal;
    font-weight:normal;
    color:#1a1a1a;
    background-color:#fff;
    border:none;
    outline:none;
    cursor:pointer;
    transition:background 0.3s, transform 0.2s;
    display:flex;
    justify-content:space-between;
    align-items:center;
}

.faq-question:hover{
    background-color:#cb2727;
    transform:translateY(-2px);
    box-shadow:0 6px 12px rgb(0 0 0 / 15%);
}

.faq-symbol{
    margin-left:10px;
    font-weight:bold;
    color:#cb2727;
    font-size:20px;
}

.faq-answer{
    display:none;
    padding:15px 20px;
    font-size:16px;
    font-style:normal;
    color:#1a1a1a;
    background-color:#fff;
    line-height:1.6;
}

.faq-item.active .faq-answer{
    display:block;
}

/* ==========================
           PAYMENT
========================== */

.payment-logos{
    margin:40px auto 0 auto;
    padding:0;
    text-align:center;
}

.payment-logos img{
    display:block;
    margin:0 auto;
    height:40px;
    width:auto;
}

/* ==========================
        COMPANY GROUP
========================== */

.company-group{
    background-color:#1a1a1a;
    width:100%;
    padding:0;
    margin:0 !important;
    display:flex;
    justify-content:center;
    align-items:center;
    line-height:0;
}

.company-group-container{
    max-width:1200px;
    margin:0 auto;
    display:flex;
    justify-content:center;
    align-items:center;
    gap:50px;
    flex-wrap:wrap;
}

.company-group-container img{
    max-height:70px;
    max-width:100%;
    width:auto;
    height:auto;
    object-fit:contain;
    opacity:0.9;
}

.company-group img{
    display:block;
    margin:0 auto;
    max-height:70px;
    width:auto;
    object-fit:contain;
}

.company-group::before{
    content:"";
    display:table;
}

/* ==========================
            FOOTER
========================== */

footer{
    background-color:#1a1a1a;
    color:#fff;
    text-align:center;
    padding:25px 20px;
    font-size:14px;
    line-height:1.5;
}

.footer-credit{
    color:#cccccc;
    font-size:13px;
}

/* ==========================
          RESPONSIVE
========================== */

@media (max-width: 900px){
    .contact-container{
        flex-direction:column;
        padding-left:15px;
        padding-right:15px;
        box-sizing:border-box;
        gap:50px;
    }

    .contact-form{
        width:100%;
        max-width:520px;
        margin:0 auto 40px auto;
    }

    .contact-text{
        margin-top:30px;
    }

    .contact-form-section{
        padding-left:15px;
        padding-right:15px;
        padding-bottom:80px;
    }

    .contact-form .form-row{
        flex-direction:column;
    }

    .areas{
        grid-template-columns:repeat(2, 1fr);
    }

    .asbestos-container{
        flex-direction:column;
    }

    .asbestos-left,
    .asbestos-right{
        flex:1 1 100%;
    }

    .safety-image{
        margin-top:30px;
        max-height:300px;
        padding:0 20px;
    }

    .safety-image img{
        width:100%;
        height:100%;
        object-fit:cover;
        border-radius:12px;
    }
}

@media (max-width: 768px){
    .about-flex{
        flex-direction:column;
        text-align:center;
    }

    .about-text{
        text-align:center;
    }

    .other-services{
        grid-template-columns:repeat(2, 1fr);
        padding:20px;
        gap:15px;
    }

    .info-flex{
        flex-direction:column;
        text-align:left;
    }

    .info-photo{
        margin-top:20px;
    }

    .company-group-container{
        padding:20px;
    }

    .company-group-container img{
        max-width:90%;
        max-height:none;
        height:auto;
    }
}

@media (max-width: 600px){
    .hero-logo{
        max-width:200px;
        margin-bottom:10px;
    }

    .hero h1{
        font-size:32px;
    }

    .work{
        grid-template-columns:repeat(auto-fit, minmax(130px, 1fr));
        gap:10px;
        padding:20px 10px;
    }

    .work-card{
        min-height:120px;
    }

    .work-card h2{
        font-size:14px;
    }

    .areas{
        grid-template-columns:1fr;
    }

    .asbestos-card,
    .asbestos-signs .work-card{
        padding:20px;
        font-size:14px;
        min-height:100px;
    }

    .slider-container{
        position:relative;
        display:flex;
        justify-content:center;
        align-items:center;
        width:100%;
    }

    .slider-image{
        max-height:400px;
        width:auto;
        max-width:90%;
        margin:0 auto;
        border:3px solid #cb2727;
    }

    .slider-btn{
        position:absolute;
        top:50%;
        transform:translateY(-50%);
        width:40px;
        height:40px;
        font-size:22px;
        padding:0;
        background-color:#cb2727;
        color:#fff;
        border-radius:50%;
        display:flex;
        align-items:center;
        justify-content:center;
        z-index:10;
    }

    .slider-btn.prev{
        left:calc((100% - 90%) / 2 - 50px);
    }

    .slider-btn.next{
        right:calc((100% - 90%) / 2 - 50px);
    }

    .brands-img{
        max-width:90% !important;
    }

    .after-about-fullwidth{
        padding:20px 0 !important;
    }

    .after-about-fullwidth img{
        max-height:100px;
        width:auto;
        height:auto;
    }

    footer{
        padding:20px;
    }

    .footer-credit{
        display:block;
        margin-top:8px;
    }
}