/* =========================================================
   Brijesh Kumar Engineering — Custom Styles
   Theme: Industrial Cobalt Blue + Safety Orange
   ========================================================= */

:root{
    --blue:        #0b46d9;   /* vibrant cobalt */
    --blue-dark:   #082f93;
    --orange:      #ff6a13;   /* safety / welding orange */
    --orange-dark: #e0540a;
    --ink:         #0e2f77;   /* steel charcoal */
    --ink-soft:    #2a3240;
    --grey:        #5b6573;
    --light:       #f4f7fc;   /* steel light */
    --line:        #e3e8f0;
    --white:       #ffffff;
    --shadow:      0 14px 40px rgba(11,22,54,.10);
    --shadow-sm:   0 6px 18px rgba(11,22,54,.08);
    --radius:      14px;
}

*{ box-sizing:border-box; }

html{ scroll-behavior:smooth; }

body{
    font-family:'Inter', sans-serif;
    color:var(--ink-soft);
    line-height:1.7;
    overflow-x:hidden;
    background:var(--white);
}

h1,h2,h3,h4,h5,h6{
    font-family:'Saira', sans-serif;
    font-weight:800;
    color:var(--ink);
    letter-spacing:-.01em;
}

a{ text-decoration:none; transition:.3s ease; }
img{ max-width:100%; }

.text-accent{ color:var(--orange); }

/* ---------- Section base ---------- */
.section{ padding:90px 0; }
.section-head{ max-width:720px; margin:0 auto 55px; }

.section-eyebrow{
    display:inline-block;
    font-family:'Saira',sans-serif;
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:2px;
    font-size:.82rem;
    color:var(--orange);
    padding:6px 16px;
    background:rgba(255,106,19,.10);
    border-radius:50px;
    margin-bottom:16px;
}
.section-eyebrow.light{ color:#fff; background:rgba(255,255,255,.15); }

.section-title{
    font-size:clamp(1.8rem, 3vw, 2.7rem);
    line-height:1.15;
    margin-bottom:16px;
}
.section-lead{
    color:var(--grey);
    font-size:1.05rem;
    max-width:680px;
}

/* ---------- Buttons ---------- */
.btn{
    font-family:'Saira',sans-serif;
    font-weight:700;
    letter-spacing:.4px;
    padding:12px 28px;
    border-radius:10px;
    transition:.3s ease;
    border:none;
}
.btn i{ margin-right:6px; }

.btn-cta{
    background:var(--orange);
    color:#fff;
    box-shadow:0 8px 20px rgba(255,106,19,.30);
}
.btn-cta:hover{
    background:var(--orange-dark);
    color:#fff;
    transform:translateY(-3px);
    box-shadow:0 12px 26px rgba(255,106,19,.42);
}
.btn-outline-light-cta{
    background:transparent;
    color:#fff;
    border:2px solid rgba(255,255,255,.7);
}
.btn-outline-light-cta:hover{
    background:#fff;
    color:var(--blue);
    transform:translateY(-3px);
}
.btn-service{
    background:var(--blue);
    color:#fff;
    padding:10px 22px;
    font-size:.92rem;
}
.btn-service:hover{
    background:var(--blue-dark);
    color:#fff;
    transform:translateY(-2px);
}

/* =========================================================
   TOP BAR
   ========================================================= */
.top-bar{
    background:var(--ink);
    color:#cfd6e2;
    font-size:.88rem;
    padding:9px 0;
}
.top-bar-info{ display:flex; gap:24px; flex-wrap:wrap; }
.top-bar-info li i{ color:var(--orange); margin-right:6px; }
.top-bar-info a{ color:#cfd6e2; }
.top-bar-info a:hover{ color:#fff; }
.top-bar-social a{
    color:#cfd6e2;
    margin-left:12px;
    font-size:1rem;
}
.top-bar-social a:hover{ color:var(--orange); }

/* =========================================================
   HEADER
   ========================================================= */
.main-header{
    background:#fff;
    position:sticky;
    top:0;
    z-index:1000;
    box-shadow:0 2px 16px rgba(11,22,54,.07);
    transition:.3s ease;
}
.main-header.scrolled{ box-shadow:0 4px 22px rgba(11,22,54,.13); }
.navbar{ padding:14px 0; transition:.3s ease; }
.main-header.scrolled .navbar{ padding:9px 0; }

.navbar-brand{ display:flex; align-items:center; gap:12px; }
.brand-logo{ width:290px; }
.brand-text{ display:flex; flex-direction:column; line-height:1; }
.brand-name{
    font-family:'Saira',sans-serif;
    font-weight:900;
    font-size:1.35rem;
    color:var(--ink);
    text-transform:uppercase;
    letter-spacing:.5px;
}
.brand-sub{
    font-family:'Saira',sans-serif;
    font-weight:700;
    font-size:.85rem;
    color:var(--orange);
    text-transform:uppercase;
    letter-spacing:3px;
}

.navbar-nav .nav-link{
    font-family:'Saira',sans-serif;
    font-weight:600;
    color:var(--ink-soft);
    padding:8px 16px;
    position:relative;
}
.navbar-nav .nav-link::after{
    content:'';
    position:absolute;
    left:16px; bottom:2px;
    width:0; height:2px;
    background:var(--orange);
    transition:.3s ease;
}
.navbar-nav .nav-link:hover,
.navbar-nav .nav-link.active{ color:var(--blue); }
.navbar-nav .nav-link:hover::after,
.navbar-nav .nav-link.active::after{ width:calc(100% - 32px); }

.navbar-toggler{ border:none; font-size:1.8rem; color:var(--blue); padding:0; }
.navbar-toggler:focus{ box-shadow:none; }

/* =========================================================
   HERO CAROUSEL
   ========================================================= */
.hero-section{ position:relative; }
.hero-img{ height:88vh; min-height:560px; object-fit:cover; }
.hero-overlay{
    position:absolute; inset:0;
    background:linear-gradient(100deg, rgba(8,20,40,.90) 0%, rgba(11,70,217,.55) 55%, rgba(11,22,40,.30) 100%);
}
.carousel-item .container{
    position:absolute; inset:0;
    display:flex; align-items:center;
    z-index:3;
}
.hero-caption{
    position:static;
    max-width:660px;
    padding:0;
    text-align:left;
}
.hero-eyebrow{
    display:inline-block;
    font-family:'Saira',sans-serif;
    font-weight:700;
    text-transform:uppercase;
    letter-spacing:2px;
    font-size:.85rem;
    color:#fff;
    border-left:4px solid var(--orange);
    padding-left:12px;
    margin-bottom:18px;
}
.hero-caption h1{
    color:#fff;
    font-size:clamp(2rem, 5vw, 3.8rem);
    font-weight:900;
    line-height:1.08;
    margin-bottom:18px;
    text-shadow:0 2px 18px rgba(0,0,0,.3);
}
.hero-caption p{
    color:#e7ecf6;
    font-size:1.12rem;
    margin-bottom:30px;
    max-width:540px;
}
.hero-btns{ display:flex; gap:14px; flex-wrap:wrap; }

.carousel-indicators{ z-index:4; margin-bottom:1.5rem; }
.carousel-indicators [data-bs-target]{
    width:13px; height:13px; border-radius:50%;
    border:2px solid #fff; background:transparent; opacity:.8;
}
.carousel-indicators .active{ background:var(--orange); border-color:var(--orange); }
.carousel-control-prev, .carousel-control-next{ width:6%; z-index:4; opacity:.7; }
.carousel-control-prev:hover, .carousel-control-next:hover{ opacity:1; }

/* =========================================================
   INFO STRIP
   ========================================================= */
.info-strip{
    background:var(--blue);
    position:relative;
    z-index:5;
    margin-top:-1px;
}
.info-strip-item{
    display:flex; align-items:center; gap:16px;
    padding:26px 24px;
    color:#fff;
    border-right:1px solid rgba(255,255,255,.15);
}
.info-strip .col-md-4:last-child .info-strip-item{ border-right:none; }
.info-strip-item i{ font-size:2rem; color:var(--orange); }
.info-strip-item span{ display:block; font-size:.82rem; color:#cdd8f5; text-transform:uppercase; letter-spacing:1px; }
.info-strip-item strong{ font-family:'Saira',sans-serif; font-size:1.05rem; }

/* =========================================================
   ABOUT
   ========================================================= */
.about-section{ background:#fff; }
.about-img-wrap{ position:relative; }
.about-img{
    border-radius:var(--radius);
    box-shadow:var(--shadow);
    width:100%;
    object-fit:cover;
    border:6px solid #fff;
}
.about-img-wrap::before{
    content:'';
    position:absolute;
    top:-18px; left:-18px;
    width:120px; height:120px;
    border-top:6px solid var(--orange);
    border-left:6px solid var(--orange);
    border-radius:8px 0 0 0;
    z-index:-1;
}
.about-exp-badge{
    position:absolute;
    right:-12px; bottom:-22px;
    background:var(--blue);
    color:#fff;
    padding:20px 26px;
    border-radius:12px;
    box-shadow:0 12px 30px rgba(11,70,217,.4);
    text-align:center;
}
.exp-num{ font-family:'Saira',sans-serif; font-weight:900; font-size:2.6rem; line-height:1; display:block; }
.exp-num span{ color:var(--orange); }
.exp-label{ font-size:.8rem; display:block; max-width:130px; margin-top:4px; }

.about-points{ margin-top:24px; }
.about-point{
    font-family:'Saira',sans-serif;
    font-weight:600;
    color:var(--ink);
    display:flex; align-items:center; gap:10px;
}
.about-point i{ color:var(--orange); font-size:1.2rem; }

/* =========================================================
   SERVICES
   ========================================================= */
.services-section{ background:var(--light); }
.service-card{
    background:#fff;
    border-radius:var(--radius);
    overflow:hidden;
    box-shadow:var(--shadow-sm);
    height:100%;
    transition:.35s ease;
    border:1px solid var(--line);
}
.service-card:hover{
    transform:translateY(-8px);
    box-shadow:var(--shadow);
}
.service-img{ overflow:hidden; height:220px; position:relative; }
.service-img img{ width:100%; height:100%; object-fit:cover; transition:.5s ease; }
.service-card:hover .service-img img{ transform:scale(1.08); }
.service-body{ padding:26px 24px 28px; }
.service-title{
    font-size:1.4rem;
    margin-bottom:12px;
    position:relative;
    padding-bottom:12px;
}
.service-title::after{
    content:''; position:absolute; left:0; bottom:0;
    width:46px; height:3px; background:var(--orange); border-radius:3px;
}
.service-body p{ color:var(--grey); font-size:.97rem; margin-bottom:20px; }

/* CTA service card */
.service-cta-card{
    background:linear-gradient(135deg, var(--blue) 0%, var(--blue-dark) 100%);
    display:flex; align-items:center; justify-content:center;
    text-align:center;
    border:none;
}
.service-cta-inner{ padding:36px 28px; }
.service-cta-inner i{ font-size:3.2rem; color:var(--orange); margin-bottom:14px; }
.service-cta-inner p{ color:#dbe3f7; margin-bottom:22px; }

/* =========================================================
   WHY CHOOSE US
   ========================================================= */
.why-section{ background:#fff; }
.why-card{
    background:#fff;
    border:1px solid var(--line);
    border-radius:var(--radius);
    padding:36px 26px;
    height:100%;
    text-align:center;
    transition:.35s ease;
    position:relative;
    overflow:hidden;
}
.why-card::before{
    content:''; position:absolute; left:0; top:0;
    width:100%; height:4px; background:var(--orange);
    transform:scaleX(0); transform-origin:left; transition:.35s ease;
}
.why-card:hover{ transform:translateY(-8px); box-shadow:var(--shadow); }
.why-card:hover::before{ transform:scaleX(1); }
.why-icon{
    width:78px; height:78px;
    margin:0 auto 20px;
    display:flex; align-items:center; justify-content:center;
    background:rgba(11,70,217,.08);
    color:var(--blue);
    border-radius:50%;
    font-size:2rem;
    transition:.35s ease;
}
.why-card:hover .why-icon{ background:var(--blue); color:#fff; transform:rotateY(360deg); }
.why-card h3{ font-size:1.25rem; margin-bottom:10px; }
.why-card p{ color:var(--grey); font-size:.95rem; margin:0; }

/* =========================================================
   COUNTER
   ========================================================= */
.counter-section{
    position:relative;
    background:var(--ink);
    padding:75px 0;
    overflow:hidden;
}
.counter-section::before{
    content:'';
    position:absolute; inset:0;
    background:linear-gradient(120deg, var(--blue-dark) 0%, transparent 60%);
    opacity:.55;
}
.counter-box{ position:relative; z-index:2; color:#fff; }
.counter, .counter-plus{
    font-family:'Saira',sans-serif;
    font-weight:900;
    font-size:clamp(2.4rem,5vw,3.4rem);
    color:#fff;
    line-height:1;
}
.counter-plus{ color:var(--orange); }
.counter-box p{
    margin:10px 0 0;
    color:#c4cde0;
    font-family:'Saira',sans-serif;
    font-weight:600;
    text-transform:uppercase;
    letter-spacing:1px;
    font-size:.95rem;
}

/* =========================================================
   SPECIALIZED IN (CALL ONLY)
   ========================================================= */
.specialized-section{
    position:relative;
    background:linear-gradient(120deg, var(--blue) 0%, var(--blue-dark) 100%);
    padding:60px 0;
    overflow:hidden;
}
.specialized-section::after{
    content:'\F4D9';
    font-family:'bootstrap-icons';
    position:absolute;
    right:-20px; top:50%; transform:translateY(-50%);
    font-size:16rem;
    color:rgba(255,255,255,.06);
    z-index:1;
}
.specialized-section .container{ position:relative; z-index:2; }
.specialized-title{
    color:#fff;
    font-size:clamp(2rem,4vw,3rem);
    margin:8px 0 14px;
}
.specialized-text{ color:#e3eaff; max-width:600px; margin:0; }
.specialized-btn{ margin-top:8px; }

/* =========================================================
   HOW IT WORKS
   ========================================================= */
.works-section{ background:var(--light); }
.works-row{ position:relative; }
.work-step{
    background:#fff;
    border-radius:var(--radius);
    padding:42px 26px 30px;
    text-align:center;
    height:100%;
    position:relative;
    border:1px solid var(--line);
    transition:.35s ease;
}
.work-step:hover{ transform:translateY(-8px); box-shadow:var(--shadow); }
.step-num{
    position:absolute;
    top:-22px; left:50%; transform:translateX(-50%);
    font-family:'Saira',sans-serif;
    font-weight:900;
    font-size:1.1rem;
    width:46px; height:46px;
    background:var(--orange);
    color:#fff;
    border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    box-shadow:0 6px 16px rgba(255,106,19,.4);
}
.work-icon{ font-size:2.6rem; color:var(--blue); margin:10px 0 16px; }
.work-step h3{ font-size:1.25rem; margin-bottom:10px; }
.work-step p{ color:var(--grey); font-size:.93rem; margin:0; }

/* =========================================================
   GALLERY
   ========================================================= */
.gallery-section{ background:#fff; }
.gallery-item{
    position:relative;
    border-radius:12px;
    overflow:hidden;
    cursor:pointer;
    box-shadow:var(--shadow-sm);
    aspect-ratio:4/3;
}
.gallery-item img{
    width:100%; height:100%;
    object-fit:cover;
    transition:.5s ease;
}
.gallery-item:hover img{ transform:scale(1.1); }
.gallery-zoom{
    position:absolute; inset:0;
    background:rgba(11,70,217,.65);
    color:#fff;
    display:flex; align-items:center; justify-content:center;
    font-size:2rem;
    opacity:0;
    transition:.35s ease;
}
.gallery-item:hover .gallery-zoom{ opacity:1; }

/* Lightbox */
.lightbox{
    display:none;
    position:fixed; inset:0;
    background:rgba(8,12,20,.92);
    z-index:2000;
    align-items:center; justify-content:center;
    padding:20px;
}
.lightbox.open{ display:flex; }
.lightbox img{ max-width:90%; max-height:85vh; border-radius:8px; box-shadow:0 20px 60px rgba(0,0,0,.6); }
.lightbox-close{
    position:absolute; top:24px; right:34px;
    color:#fff; font-size:2.6rem; cursor:pointer; line-height:1;
    transition:.3s;
}
.lightbox-close:hover{ color:var(--orange); transform:rotate(90deg); }

/* =========================================================
   TESTIMONIALS
   ========================================================= */
.testimonial-section{ background:var(--light); }
.testimonial-card{
    background:#fff;
    border-radius:var(--radius);
    padding:46px 40px 40px;
    text-align:center;
    box-shadow:var(--shadow-sm);
    position:relative;
    margin-bottom:30px;
    border:1px solid var(--line);
}
.testimonial-quote{
    font-size:3rem;
    color:var(--orange);
    opacity:.3;
    line-height:1;
}
.testimonial-card p{
    font-size:1.12rem;
    color:var(--ink-soft);
    font-style:italic;
    margin:10px 0 26px;
}
.testimonial-author{ display:flex; align-items:center; justify-content:center; gap:14px; }
.t-avatar{
    width:54px; height:54px;
    background:var(--blue);
    color:#fff;
    border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    font-family:'Saira',sans-serif; font-weight:800; font-size:1.1rem;
}
.testimonial-author strong{ display:block; font-family:'Saira',sans-serif; color:var(--ink); }
.testimonial-author small{ color:var(--grey); }
.testimonial-indicators{ position:static; margin-top:6px; }
.testimonial-indicators [data-bs-target]{
    width:12px; height:12px; border-radius:50%;
    background:#c4ccda; border:none;
}
.testimonial-indicators .active{ background:var(--orange); }

/* =========================================================
   FAQ
   ========================================================= */
.faq-section{ background:#fff; }
.faq-accordion .accordion-item{
    border:1px solid var(--line);
    border-radius:12px !important;
    margin-bottom:14px;
    overflow:hidden;
    box-shadow:var(--shadow-sm);
}
.faq-accordion .accordion-button{
    font-family:'Saira',sans-serif;
    font-weight:700;
    font-size:1.08rem;
    color:var(--ink);
    padding:20px 24px;
    background:#fff;
}
.faq-accordion .accordion-button:not(.collapsed){
    color:var(--blue);
    background:rgba(11,70,217,.05);
    box-shadow:none;
}
.faq-accordion .accordion-button:focus{ box-shadow:none; border:none; }
.faq-accordion .accordion-button::after{
    background-size:1rem;
    filter:hue-rotate(200deg);
}
.faq-accordion .accordion-body{ color:var(--grey); padding:6px 24px 22px; }

/* =========================================================
   CONTACT
   ========================================================= */
.contact-section{ background:var(--light); }
.contact-card{
    background:#fff;
    border-radius:var(--radius);
    padding:36px 26px;
    text-align:center;
    height:100%;
    box-shadow:var(--shadow-sm);
    border:1px solid var(--line);
    transition:.35s ease;
}
.contact-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.contact-icon{
    width:70px; height:70px;
    margin:0 auto 18px;
    background:var(--blue);
    color:#fff;
    border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    font-size:1.8rem;
}
.contact-card h3{ font-size:1.25rem; margin-bottom:8px; }
.contact-card p{ margin-bottom:18px; word-break:break-word; }
.contact-card a{ color:var(--ink-soft); }
.contact-card a:hover{ color:var(--blue); }

.contact-detail-box{
    background:#fff;
    border-radius:var(--radius);
    padding:32px 30px;
    height:100%;
    box-shadow:var(--shadow-sm);
    border:1px solid var(--line);
    border-left:5px solid var(--orange);
}
.contact-detail-box h3{ font-size:1.3rem; margin-bottom:14px; display:flex; align-items:center; gap:10px; }
.contact-detail-box h3 i{ color:var(--orange); }
.contact-detail-box p{ color:var(--grey); margin-bottom:18px; }
.gst-tag{
    display:inline-flex; align-items:center; gap:8px;
    background:rgba(11,70,217,.08);
    color:var(--blue);
    font-family:'Saira',sans-serif; font-weight:700;
    padding:8px 16px; border-radius:8px; font-size:.95rem;
}
.map-wrap{
    border-radius:var(--radius);
    overflow:hidden;
    height:100%;
    min-height:300px;
    box-shadow:var(--shadow-sm);
    border:1px solid var(--line);
}
.map-wrap iframe{ display:block; min-height:300px; height:100%; }

/* =========================================================
   FOOTER
   ========================================================= */
.footer{
    background:var(--ink);
    color:#aeb8c9;
    padding:70px 0 0;
}
.footer-brand{ display:flex; align-items:center; gap:12px; margin-bottom:18px; }
.footer-logo{ height:48px; }
.footer-brand .brand-name{ color:#fff; font-size:1.25rem; }
.footer-brand span span{ display:block; line-height:1; }
.footer-about{ font-size:.95rem; margin-bottom:20px; }
.footer-social a{
    width:38px; height:38px;
    display:inline-flex; align-items:center; justify-content:center;
    background:rgba(255,255,255,.08);
    color:#fff; border-radius:8px; margin-right:8px;
}
.footer-social a:hover{ background:var(--orange); transform:translateY(-3px); }
.footer-title{
    color:#fff; font-size:1.15rem; margin-bottom:20px;
    position:relative; padding-bottom:10px;
}
.footer-title::after{
    content:''; position:absolute; left:0; bottom:0;
    width:36px; height:3px; background:var(--orange);
}
.footer-links li, .footer-contact li{ margin-bottom:11px; }
.footer-links a{ color:#aeb8c9; }
.footer-links a:hover{ color:var(--orange); padding-left:6px; }
.footer-contact li{ display:flex; gap:10px; font-size:.93rem; }
.footer-contact i{ color:var(--orange); margin-top:4px; }
.footer-contact a{ color:#aeb8c9; }
.footer-contact a:hover{ color:#fff; }
.footer-bottom{
    border-top:1px solid rgba(255,255,255,.1);
    margin-top:50px;
    padding:20px 0;
    text-align:center;
    font-size:.9rem;
}

/* =========================================================
   FLOATING ICONS + BACK TO TOP
   ========================================================= */
.floating-btns{
    position:fixed; right:20px; bottom:24px;
    display:flex; flex-direction:column; gap:14px;
    z-index:1500;
}
.float-btn{
    width:56px; height:56px;
    border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    color:#fff; font-size:1.5rem;
    box-shadow:0 8px 22px rgba(0,0,0,.25);
    animation:floatPulse 2.2s infinite;
}
.float-whatsapp{ background:#25d366; }
.float-call{ background:var(--orange); animation-delay:.6s; }
.float-btn:hover{ transform:scale(1.12); color:#fff; }

@keyframes floatPulse{
    0%,100%{ box-shadow:0 0 0 0 rgba(37,211,102,.5); }
    50%{ box-shadow:0 0 0 12px rgba(37,211,102,0); }
}
.float-call{ animation-name:floatPulseOrange; }
@keyframes floatPulseOrange{
    0%,100%{ box-shadow:0 0 0 0 rgba(255,106,19,.5); }
    50%{ box-shadow:0 0 0 12px rgba(255,106,19,0); }
}

.back-to-top{
    position:fixed; right:22px; bottom:92px;
    width:46px; height:46px;
    background:var(--blue);
    color:#fff; border:none; border-radius:10px;
    font-size:1.2rem;
    opacity:0; visibility:hidden;
    transition:.3s ease;
    z-index:1400;
}
.back-to-top.show{ opacity:1; visibility:visible; }
.back-to-top:hover{ background:var(--blue-dark); transform:translateY(-3px); }

/* =========================================================
   REVEAL ANIMATION
   ========================================================= */
.reveal{ opacity:0; transform:translateY(34px); transition:.7s cubic-bezier(.2,.7,.2,1); }
.reveal.visible{ opacity:1; transform:translateY(0); }

@media (prefers-reduced-motion: reduce){
    .reveal{ opacity:1; transform:none; transition:none; }
    html{ scroll-behavior:auto; }
    .float-btn{ animation:none; }
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 991.98px){
    .navbar-collapse{
        background:#fff;
        margin-top:14px;
        padding:16px;
        border-radius:12px;
        box-shadow:var(--shadow-sm);
    }
    .navbar-nav .nav-link{ padding:10px 8px; }
    .navbar-nav .nav-link::after{ display:none; }
    .btn-cta{ display:inline-block; margin-top:8px; }
    .hero-img{ height:78vh; }
    .info-strip-item{ border-right:none; border-bottom:1px solid rgba(255,255,255,.15); justify-content:center; }
    .info-strip .col-md-4:last-child .info-strip-item{ border-bottom:none; }
    .about-exp-badge{ right:10px; bottom:-22px; padding:16px 20px; }
    .specialized-section{ text-align:center; }
    .specialized-text{ margin:0 auto 22px; }
}

@media (max-width: 767.98px){
	.cu-ds-nn{
		display:none!important
	}
	.cu-jf-cntr{
		justify-content:center!important
	}
    .section{ padding:60px 0; overflow-x: hidden;}
    .section-head{ margin-bottom:40px; }
    .hero-img{ height:auto; min-height:480px; }
    .hero-caption{ text-align:center; }
    .hero-eyebrow{ border-left:none; padding-left:0; }
    .hero-btns{ justify-content:center; }
    .hero-caption p{ margin-left:auto; margin-right:auto; }
    .about-img-wrap{ margin-bottom:40px; }
    .about-img-wrap::before{ display:none; }
    .work-step{ margin-top:24px; }
    .float-btn{ width:50px; height:50px; font-size:1.3rem; }
    .map-wrap{ margin-top:0; min-height:280px; }
}
.contact-form-box {
  background: var(--white);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 40px 36px;
  box-shadow: var(--shadow-md);
}

.contact-form-title {
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--text-dark);
  margin-bottom: 28px;
  padding-bottom: 18px;
  border-bottom: 2px solid var(--border);
}



.btn-submit {
  padding: 14px;
  font-size: 0.95rem;
  font-weight: 700;
  letter-spacing: 0.03em;
}


@media (max-width: 575.98px){
    .section-title{ font-size:1.65rem; }
    .hero-caption h1{ font-size:1.9rem; }
    .hero-btns .btn{ width:100%; }
    .counter-box p{ font-size:.8rem; }
    .testimonial-card{ padding:36px 24px; }
    .testimonial-card p{ font-size:1rem; }
}
@media(max-width:374px)
{
	.brand-logo{ width:250px; }
}