:root{
    --primary:#3a559e;
    --primary-dark:#263f82;
    --navy:#172b5b;
    --secondary:#364b4e;
    --logo-slate:#31494e;
    --accent-blue:#5877c8;
    --soft:#f5f7fb;
    --text:#182338;
    --muted:#687386;
    --border:#e5eaf2;
    --shadow:0 22px 60px rgba(23,43,91,.12);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Montserrat',sans-serif;color:var(--text);background:#fff;line-height:1.7}
a{text-decoration:none}
img{max-width:100%;display:block}
.topbar{background:var(--primary);color:#fff;font-size:.82rem;padding:.65rem 0}
.topbar a,.topbar span{color:#fff}
.topbar-group,.topbar-socials{display:flex;align-items:center;gap:1rem}
.topbar-socials a{opacity:.9}.topbar-socials a:hover{opacity:1}
.main-nav{padding:1rem 0;box-shadow:0 4px 24px rgba(0,0,0,.05)}
.navbar-brand,.footer-brand{display:flex;align-items:center;gap:.7rem}
.brand-logo{display:block;width:190px;height:auto;max-height:74px;object-fit:contain;object-position:left center}
.footer-logo{display:block;width:210px;height:auto;max-height:84px;object-fit:contain;object-position:left center}
.navbar-nav .nav-link{font-weight:600;color:#202a38;padding:.85rem .8rem!important;font-size:.9rem}.navbar-nav .nav-link:hover,.navbar-nav .nav-link.active{color:var(--primary)}
.btn{font-weight:700;border-radius:.45rem;padding:.78rem 1.35rem;font-size:.88rem;letter-spacing:.01em}
.btn-brand{background:var(--primary);border-color:var(--primary);color:#fff}.btn-brand:hover{background:var(--primary-dark);border-color:var(--primary-dark);color:#fff;transform:translateY(-1px)}
.btn-outline-brand{border:1px solid var(--primary);color:var(--primary)}.btn-outline-brand:hover{background:var(--primary);color:#fff}
.hero-slide{min-height:790px;background-size:cover;background-position:center;position:relative}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(8,22,48,.78) 0%,rgba(8,22,48,.46) 45%,rgba(8,22,48,.16) 100%)}
.hero-content-wrap{position:relative;z-index:2;min-height:790px;display:flex;align-items:center}
.hero-content{max-width:720px;color:#fff}.hero-content h1{font-size:clamp(2rem,4.2vw,3.8rem);font-weight:800;line-height:1.02;margin:.7rem 0 1.25rem}.hero-content p{font-size:1.08rem;max-width:700px;color:rgba(255,255,255,.88);margin-bottom:2rem}
.eyebrow,.section-kicker{display:inline-flex;align-items:center;gap:.5rem;text-transform:uppercase;letter-spacing:.18em;font-size:.72rem;font-weight:800;color:#dce6ff}.section-kicker{color:var(--primary)}.section-kicker.light{color:#dce6ff}
.carousel-control-prev,.carousel-control-next{width:7%}.carousel-indicators{margin-bottom:2rem}.carousel-indicators [data-bs-target]{width:30px;height:4px;border:0;border-radius:99px}
.welcome-strip-wrap{margin-top:-74px;position:relative;z-index:5}.welcome-strip{background:linear-gradient(135deg,var(--primary),#273f7b);color:#fff;padding:2.5rem 2rem;border-radius:18px;box-shadow:var(--shadow)}.welcome-strip span{font-size:1.15rem}.welcome-strip h2{font-size:clamp(1.5rem,2.4vw,2.15rem);font-weight:800;margin:.25rem 0}.welcome-strip p{margin:0;color:rgba(255,255,255,.75)}
.section-space{padding:100px 0}.bg-soft{background:var(--soft)}
.section-heading{max-width:760px;margin-bottom:3rem}.section-title{font-weight:800;line-height:1.25;font-size:clamp(1.65rem,2.8vw,2.45rem);margin:.65rem 0 1rem}.section-lead{font-size:1.08rem;color:#4b5870}.section-heading p{color:var(--muted)}
.image-frame{position:relative}.image-frame img,.rounded-image{border-radius:22px;min-height:460px;width:100%;object-fit:cover}.experience-badge{position:absolute;right:-20px;bottom:30px;background:#fff;border-radius:16px;padding:1.2rem 1.4rem;box-shadow:var(--shadow);max-width:210px}.experience-badge strong{display:block;font-size:2rem;color:var(--primary)}.experience-badge span{font-size:.78rem;font-weight:700;color:var(--secondary)}
.feature-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.85rem;margin-top:1.5rem}.feature-list div{font-weight:600;font-size:.9rem}.feature-list i{color:var(--primary);margin-right:.45rem}
.direction-tabs{gap:.5rem;margin-bottom:1.5rem}.direction-tabs .nav-link{border:1px solid var(--border);color:var(--text);font-weight:700;background:#fff;padding:.8rem 1.2rem}.direction-tabs .nav-link.active{background:var(--primary);border-color:var(--primary)}
.direction-panel{max-width:900px;margin:auto}.direction-inner{background:#fff;padding:2.5rem;border-radius:20px;display:flex;gap:1.5rem;align-items:center;box-shadow:0 15px 40px rgba(23,43,91,.08)}.direction-icon{width:76px;height:76px;flex:0 0 76px;border-radius:20px;background:rgba(58,85,158,.1);color:var(--primary);display:grid;place-items:center;font-size:2rem}.direction-inner h3{font-weight:800}.direction-inner p{margin:0;color:var(--muted)}
.stats-section{background:linear-gradient(135deg,var(--navy),var(--primary));padding:60px 0;color:#fff}.stat-item strong{display:block;font-size:3rem;font-weight:800;line-height:1}.stat-item strong:after{content:'+';font-size:1.25rem}.stat-item span{font-size:.83rem;color:rgba(255,255,255,.72);font-weight:600}
.service-card{border:1px solid var(--border);border-radius:18px;padding:2rem;background:#fff;transition:.25s ease}.service-card:hover{transform:translateY(-7px);box-shadow:var(--shadow);border-color:transparent}.service-icon{width:62px;height:62px;border-radius:16px;background:rgba(58,85,158,.1);display:grid;place-items:center;color:var(--primary);font-size:1.7rem;margin-bottom:1.4rem}.service-card h3{font-size:1.08rem;font-weight:800}.service-card p{color:var(--muted)}.text-link{font-weight:800;color:var(--primary);font-size:.86rem}.text-link i{transition:.2s}.text-link:hover i{transform:translateX(4px)}
.why-section{background:linear-gradient(135deg,var(--navy),#243f81)}.why-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);padding:1.5rem;border-radius:18px;color:#fff;height:100%}.why-card i{font-size:1.6rem;color:#cbd8ff}.why-card h3{font-size:1.05rem;font-weight:800;margin:.8rem 0 .45rem}.why-card p{font-size:.86rem;color:rgba(255,255,255,.67);margin:0}
.portfolio-filters{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center}.filter-btn{border:1px solid var(--border);background:#fff;padding:.7rem 1rem;border-radius:99px;font-weight:700;font-size:.8rem}.filter-btn.active,.filter-btn:hover{background:var(--primary);border-color:var(--primary);color:#fff}.portfolio-item{transition:.25s}.portfolio-item.is-hidden{display:none}
.project-card{border:0;padding:0;width:100%;height:380px;position:relative;border-radius:18px;overflow:hidden;text-align:left;background:#ddd}.project-card img{width:100%;height:100%;object-fit:cover;transition:.5s}.project-card:hover img{transform:scale(1.06)}.project-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,22,48,0) 30%,rgba(8,22,48,.88) 100%)}.project-content{position:absolute;left:0;right:0;bottom:0;padding:1.5rem;color:#fff;display:flex;flex-direction:column}.project-content small{text-transform:uppercase;letter-spacing:.14em;font-size:.65rem}.project-content strong{font-size:1.08rem}.project-content span:last-child{font-size:.78rem;color:rgba(255,255,255,.72);display:flex;justify-content:space-between;align-items:center}
.mini-points{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;margin-top:1.5rem}.mini-points span{font-weight:600;font-size:.88rem}.mini-points i{color:var(--primary);margin-right:.4rem}
.client-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.client-logo{height:110px;border:1px solid var(--border);border-radius:16px;display:grid;place-items:center;background:#fff;color:#8390a4;font-weight:800;font-size:1.15rem;transition:.2s}.client-logo:hover{color:var(--primary);box-shadow:0 10px 30px rgba(23,43,91,.08);transform:translateY(-3px)}
.cta-section{padding:0 0 90px}.cta-box{background:linear-gradient(135deg,var(--primary),var(--navy));color:#fff;border-radius:24px;padding:3rem;display:flex;align-items:center;justify-content:space-between;gap:2rem}.cta-box h2{font-size:clamp(1.55rem,2.6vw,2.25rem);font-weight:800;margin:.5rem 0}.cta-box p{margin:0;color:rgba(255,255,255,.75)}
.site-footer{background:#0f1f43;color:rgba(255,255,255,.7)}.footer-main{padding:80px 0 55px}.footer-brand{display:inline-flex;background:#fff;border-radius:12px;padding:.45rem .7rem}.site-footer h3{font-size:.9rem;color:#fff;text-transform:uppercase;letter-spacing:.12em;font-weight:800;margin-bottom:1.25rem}.site-footer ul{list-style:none;padding:0;margin:0}.site-footer li{margin-bottom:.65rem}.site-footer a{color:rgba(255,255,255,.68)}.site-footer a:hover{color:#fff}.footer-socials{display:flex;gap:.65rem}.footer-socials a{width:38px;height:38px;border:1px solid rgba(255,255,255,.12);border-radius:50%;display:grid;place-items:center}.contact-list li{display:flex;gap:.7rem;align-items:flex-start}.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:1.25rem 0;display:flex;justify-content:space-between;gap:1rem;font-size:.76rem}.footer-bottom div{display:flex;gap:1rem}
.project-modal-content{border:0;border-radius:20px;overflow:hidden;position:relative}.project-modal-content>img{width:100%;height:340px;object-fit:cover}.modal-close{position:absolute;right:1rem;top:1rem;background-color:#fff;border-radius:50%;padding:.65rem;z-index:2}.project-modal-content h2{font-weight:800}.modal-location{color:var(--primary);font-weight:700;font-size:.85rem}
@media(max-width:991.98px){.main-nav .navbar-collapse{padding-top:1rem}.hero-slide,.hero-content-wrap{min-height:700px}.welcome-strip-wrap{margin-top:-45px}.section-space{padding:75px 0}.cta-box{flex-direction:column;align-items:flex-start}.client-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:767.98px){.container{padding-left:24px;padding-right:24px}.topbar{font-size:.72rem}.topbar-group{gap:.55rem}.topbar-socials{display:none}.hero-slide,.hero-content-wrap{min-height:650px}.hero-overlay{background:linear-gradient(90deg,rgba(8,22,48,.84),rgba(8,22,48,.48))}.hero-content h1{font-size:clamp(1.85rem,9vw,2.65rem);line-height:1.12}.hero-content p{font-size:.94rem}.welcome-strip{padding:2rem 1.5rem}.image-frame img,.rounded-image{min-height:340px}.experience-badge{right:12px}.feature-list,.mini-points{grid-template-columns:1fr}.direction-inner{align-items:flex-start;padding:1.5rem;flex-direction:column}.direction-tabs{overflow-x:auto;flex-wrap:nowrap;justify-content:flex-start!important;padding-bottom:.35rem}.direction-tabs .nav-link{white-space:nowrap}.stat-item strong{font-size:2.3rem}.client-grid{grid-template-columns:1fr 1fr}.cta-box{padding:2rem}.footer-bottom{flex-direction:column}.project-card{height:320px}}

@media(max-width:575.98px){.brand-logo{width:132px;height:50px}.main-nav{padding:.65rem 0}.hero-content-wrap{padding-top:2rem;padding-bottom:5rem}.hero-content{max-width:100%}.carousel-control-prev,.carousel-control-next{width:11%}.section-space{padding:68px 0}.section-heading{margin-bottom:2.25rem}.direction-inner,.service-card,.why-card{padding:1.35rem}.cta-section{padding-bottom:68px}.footer-main{padding:65px 0 45px}}

.footer-brand{
    display:inline-flex;
    align-items:center;
    padding:12px 16px;
    border-radius:14px;
    background:#ffffff;
    box-shadow:0 12px 28px rgba(0,0,0,.16);
}
.navbar-brand{
    display:flex;
    align-items:center;
    min-height:76px;
}
@media(max-width:575.98px){
    .brand-logo{width:158px;max-height:62px}
    .navbar-brand{min-height:64px}
    .footer-logo{width:185px}
}

:root{--logo-green:#3f5f61;--logo-green-deep:#2f4c4e;--logo-green-soft:#eaf0ef}
body{font-weight:300;line-height:1.24}
p,li,.section-lead,.hero-content p,.service-card p,.why-card p,.direction-inner p,.footer-description{font-weight:300;line-height:1.24}
h1,h2,h3,h4,h5,h6,.section-title,.hero-content h1,.cta-box h2,.footer-intro h2{line-height:1.12}
.section-title{font-size:clamp(1.65rem,2.7vw,2.45rem);font-weight:650}.section-heading p,.section-lead{font-size:.96rem}
.hero-content{max-width:690px}.hero-content h1{font-size:clamp(2rem,4.2vw,3.55rem);font-weight:650;letter-spacing:-.035em}.hero-content p{max-width:650px;font-size:1rem}
.eyebrow,.section-kicker{color:var(--logo-green)}.hero-content .eyebrow{color:#d8e8e4}
.btn-brand:hover{background:var(--logo-green-deep);border-color:var(--logo-green-deep)}.btn-outline-brand{color:var(--logo-green-deep);border-color:rgba(63,95,97,.42)}.btn-outline-brand:hover{background:var(--logo-green-deep);border-color:var(--logo-green-deep);color:#fff}
.service-icon,.direction-icon{background:var(--logo-green-soft);color:var(--logo-green-deep)}.feature-list i,.mini-points i{color:var(--logo-green)}.text-link{color:var(--logo-green-deep)}
.stats-section{background:linear-gradient(135deg,var(--navy) 0%,var(--primary) 66%,var(--logo-green-deep) 145%)}.why-section{background:radial-gradient(circle at 88% 14%,rgba(79,117,113,.26),transparent 27%),linear-gradient(135deg,var(--navy),#243f81)}
.filter-btn{transition:background-color .25s ease,color .25s ease,border-color .25s ease,transform .25s ease}.filter-btn.active,.filter-btn:hover{background:var(--logo-green-deep);border-color:var(--logo-green-deep)}.filter-btn:active{transform:scale(.96)}
.portfolio-item{opacity:1;transform:translateY(0) scale(1);transition:opacity .34s ease,transform .34s ease;transform-origin:center}.portfolio-item.is-filtering-out{opacity:0;transform:translateY(18px) scale(.965);pointer-events:none}.portfolio-item.is-filtering-in{animation:portfolioReveal .48s cubic-bezier(.2,.75,.2,1) both}.portfolio-item.is-hidden{display:none}@keyframes portfolioReveal{from{opacity:0;transform:translateY(22px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}
.project-card::after{content:"";position:absolute;left:0;bottom:0;width:4px;height:0;background:var(--logo-green);z-index:3;transition:height .35s ease}.project-card:hover::after{height:100%}
.client-more-link{min-width:190px}.client-more-link i{margin-left:.35rem;transition:transform .22s ease}.client-more-link:hover i{transform:translateX(4px)}
.site-footer{position:relative;overflow:hidden;background:radial-gradient(circle at 88% 16%,rgba(63,95,97,.24),transparent 28%),linear-gradient(145deg,#091a36 0%,#102a54 58%,#173b62 100%);color:rgba(255,255,255,.72)}.site-footer::before{content:"";position:absolute;width:420px;height:420px;border:1px solid rgba(255,255,255,.06);border-radius:50%;right:-220px;bottom:-240px}.footer-accent{height:5px;background:linear-gradient(90deg,var(--primary),#5273c4 58%,var(--logo-green))}
.footer-intro{display:flex;align-items:center;justify-content:space-between;gap:2rem;padding:3rem 0 2.6rem;border-bottom:1px solid rgba(255,255,255,.1)}.footer-kicker{display:block;margin-bottom:.75rem;color:#9ec0b7;font-size:.7rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase}.footer-intro h2{max-width:720px;margin:0;color:#fff;font-size:clamp(1.55rem,2.6vw,2.45rem);font-weight:550;letter-spacing:-.025em}.btn-footer-cta{flex:0 0 auto;padding:.9rem 1.2rem;border-radius:12px;background:var(--logo-green);border:1px solid var(--logo-green);color:#fff;font-weight:600}.btn-footer-cta:hover{background:#fff;border-color:#fff;color:var(--navy)}
.footer-main{padding:64px 0 52px}.footer-brand{padding:10px 14px;border:1px solid rgba(255,255,255,.15)}.footer-description{max-width:370px;margin:1.5rem 0 1.4rem;color:rgba(255,255,255,.68)}.site-footer h3{color:#fff;font-size:.75rem;font-weight:650;letter-spacing:.16em}.site-footer li{margin-bottom:.78rem}.site-footer ul:not(.contact-list) a:hover{color:#a9c8c1}.footer-socials a{width:41px;height:41px;border-color:rgba(255,255,255,.15);background:rgba(255,255,255,.045)}.footer-socials a:hover{color:#fff;background:var(--logo-green);border-color:var(--logo-green);transform:translateY(-2px)}.contact-list li{align-items:flex-start}.contact-icon{width:31px;height:31px;flex:0 0 31px;display:grid;place-items:center;border-radius:9px;background:rgba(88,127,122,.17);color:#a9c8c1}.footer-bottom{position:relative;z-index:1;padding:1.35rem 0 1.55rem;color:rgba(255,255,255,.54)}
@media(max-width:991.98px){.footer-intro{align-items:flex-start;flex-direction:column}}@media(max-width:767.98px){.container{padding-left:28px;padding-right:28px}.hero-content h1{font-size:clamp(1.8rem,8vw,2.55rem)}.hero-content p{font-size:.9rem}.section-title{font-size:clamp(1.5rem,7vw,2rem)}.footer-main{padding-top:52px}}@media(max-width:575.98px){.container{padding-left:26px;padding-right:26px}.hero-content h1{font-size:1.82rem}.hero-content p{font-size:.86rem}.section-title{font-size:1.55rem}.footer-intro{padding-top:2.5rem}.footer-bottom div{flex-wrap:wrap}}


/* =========================================================
   V5 typography and hero-position refinement
   ========================================================= */
html{
    -webkit-font-smoothing:antialiased;
    -moz-osx-font-smoothing:grayscale;
    text-rendering:optimizeLegibility;
}
body{
    color:#111111;
    font-weight:300;
    font-synthesis:none;
}
p,
li,
.section-lead,
.section-heading p,
.service-card p,
.direction-inner p,
.feature-list div,
.mini-points span{
    color:#111111;
    font-weight:300;
}
.hero-content-wrap{
    align-items:flex-end;
    padding-bottom:108px;
}
.hero-content h1{
    margin-top:0;
    font-weight:500;
}
.hero-content p{
    color:rgba(255,255,255,.96);
    font-weight:300;
}
.btn,
.filter-btn,
.direction-tabs .nav-link,
.navbar-nav .nav-link,
.text-link,
.btn-footer-cta{
    font-weight:300!important;
}
.section-title,
.welcome-strip h2,
.direction-inner h3,
.service-card h3,
.why-card h3,
.project-content strong,
.cta-box h2{
    font-weight:500;
}
.section-lead,
.section-heading p,
.service-card p,
.direction-inner p{
    color:#111111;
}
@media(max-width:991.98px){
    .hero-content-wrap{padding-bottom:92px}
}
@media(max-width:767.98px){
    .hero-content-wrap{padding-top:3rem;padding-bottom:82px}
}
@media(max-width:575.98px){
    .hero-content-wrap{padding-top:3rem;padding-bottom:74px}
}


/* =========================================================
   V6 readability and image-backed section refinement
   ========================================================= */
html{font-size:16px}
body{
    font-size:16px;
    font-weight:400;
    line-height:1.24;
    color:#111111;
}
p,
li,
.section-lead,
.section-heading p,
.service-card p,
.direction-inner p,
.feature-list div,
.mini-points span{
    font-size:1rem;
    font-weight:400;
    color:#111111;
}
.navbar-nav .nav-link{
    font-weight:700!important;
    letter-spacing:.015em;
}
/* Keep CTA typography understated while improving body readability. */
.btn,
.filter-btn,
.direction-tabs .nav-link,
.text-link,
.btn-footer-cta{
    font-weight:300!important;
}
/* Image-backed trust section with a controlled overlay for readability. */
.why-section{
    position:relative;
    isolation:isolate;
    background-image:
        linear-gradient(90deg,rgba(9,26,54,.93),rgba(20,52,88,.83)),
        url('https://images.unsplash.com/photo-1497366811353-6870744d04b2?auto=format&fit=crop&w=2000&q=88');
    background-size:cover;
    background-position:center;
    background-attachment:fixed;
}
.why-section::before{
    content:"";
    position:absolute;
    inset:0;
    z-index:-1;
    background:radial-gradient(circle at 85% 15%,rgba(63,95,97,.28),transparent 34%);
}
.why-section p,
.why-section .why-card p{
    color:rgba(255,255,255,.82)!important;
}
.why-card{
    backdrop-filter:blur(3px);
    -webkit-backdrop-filter:blur(3px);
    background:rgba(255,255,255,.09);
}
@media(max-width:991.98px){
    .why-section{background-attachment:scroll}
}

/* =========================================================
   V7 portfolio typography balance
   ========================================================= */
#portfolio .section-heading{
    max-width:860px;
    margin-left:auto;
    margin-right:auto;
    margin-bottom:2.2rem;
}

#portfolio .section-kicker{
    margin-bottom:.65rem;
    font-size:.72rem;
    font-weight:700;
    line-height:1;
    letter-spacing:.18em;
}

#portfolio .section-title{
    margin-bottom:.9rem;
    font-size:clamp(2rem,3.2vw,3.1rem);
    font-weight:500;
    line-height:1.08;
    letter-spacing:-.025em;
}

#portfolio .section-heading p{
    max-width:760px;
    margin:0 auto;
    font-size:1rem;
    font-weight:400;
    line-height:1.5;
    color:#1f2937;
}

#portfolio .portfolio-filters{
    margin-top:1.65rem;
    gap:.65rem;
}

#portfolio .filter-btn{
    min-height:44px;
    padding:.65rem 1.15rem;
    font-size:.92rem;
    font-weight:400;
    line-height:1;
}

#portfolio .project-card .project-meta{
    font-size:.72rem;
    font-weight:500;
    letter-spacing:.12em;
}

#portfolio .project-card h3{
    font-size:1.32rem;
    font-weight:500;
    line-height:1.15;
}

#portfolio .project-card .project-location{
    font-size:.95rem;
    font-weight:400;
    line-height:1.25;
}

@media(max-width:767.98px){
    #portfolio .section-heading{
        margin-bottom:1.7rem;
    }

    #portfolio .section-kicker{
        font-size:.68rem;
        letter-spacing:.15em;
    }

    #portfolio .section-title{
        font-size:2rem;
    }

    #portfolio .section-heading p{
        font-size:.95rem;
        line-height:1.45;
    }

    #portfolio .portfolio-filters{
        margin-top:1.3rem;
        gap:.55rem;
    }

    #portfolio .filter-btn{
        min-height:42px;
        padding:.62rem 1rem;
        font-size:.88rem;
    }
}


/* =========================================================
   V8 typography, visibility and accessibility updates
   ========================================================= */
:root{
    --user-font-scale:1;
    --body-font-size:0.875rem; /* 14px */
    --content-line-height:1.24;
}
html{
    font-size:calc(16px * var(--user-font-scale));
}
body{
    font-size:var(--body-font-size);
    line-height:var(--content-line-height);
    font-weight:400;
    color:#000;
    text-rendering:optimizeLegibility;
    -webkit-font-smoothing:antialiased;
    -moz-osx-font-smoothing:grayscale;
}
p, li, .section-lead, .hero-content p, .service-card p, .why-card p, .direction-inner p, .footer-description{
    font-size:1rem;
    line-height:1.24em;
    font-weight:400;
}
.section-heading p, .project-content span:last-child, .modal-location, .welcome-strip p, .stat-item span{
    line-height:1.24em;
}
.btn{
    font-weight:300;
}
.text-link,
.client-more-link,
.project-modal-content .btn{
    color:#000 !important;
    font-size:1rem;
}
.text-link{
    font-weight:500;
    display:inline-flex;
    align-items:center;
    gap:.45rem;
}
.text-link i{font-size:.95rem}
.text-link:hover{
    color:var(--logo-green-deep) !important;
}
.client-more-link{
    border-color:#000;
    font-weight:400;
}
.client-more-link:hover{
    color:#fff !important;
    border-color:#000;
    background:#000;
}
.project-modal-content .btn.btn-brand{
    background:#fff;
    border-color:#000;
}
.project-modal-content .btn.btn-brand:hover{
    background:#000;
    color:#fff !important;
}
.footer-description,
.site-footer li,
.site-footer span,
.site-footer p,
.site-footer a,
.footer-bottom,
.footer-bottom a{
    color:rgba(255,255,255,.9);
}
.site-footer a:hover,
.footer-bottom a:hover,
.site-footer ul:not(.contact-list) a:hover{
    color:#fff;
}
.footer-kicker{color:#cfe0db}
.contact-icon{color:#d8ebe5;background:rgba(255,255,255,.12)}
.footer-bottom{
    font-size:.88rem;
    color:rgba(255,255,255,.88);
}
.footer-bottom div{gap:1.25rem}
.footer-description{max-width:390px}

/* Accessibility widget */
.accessibility-widget{
    position:fixed;
    right:18px;
    bottom:18px;
    z-index:1080;
    display:flex;
    flex-direction:column;
    align-items:flex-end;
    gap:.75rem;
}
.accessibility-toggle{
    border:0;
    border-radius:999px;
    background:#000;
    color:#fff;
    padding:.85rem 1rem;
    display:inline-flex;
    align-items:center;
    gap:.55rem;
    box-shadow:0 18px 40px rgba(0,0,0,.18);
    font-size:.92rem;
    font-weight:500;
}
.accessibility-toggle i{font-size:1.08rem}
.accessibility-panel{
    width:min(320px, calc(100vw - 36px));
    background:#fff;
    border:1px solid #d9dee8;
    border-radius:18px;
    padding:1rem;
    box-shadow:0 20px 50px rgba(0,0,0,.14);
}
.accessibility-panel h3{
    margin:0 0 .35rem;
    font-size:1.02rem;
    font-weight:600;
    color:#000;
}
.accessibility-panel p{
    margin:0 0 .9rem;
    font-size:.92rem;
    line-height:1.35;
    color:#222;
}
.accessibility-actions{
    display:grid;
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:.65rem;
}
.a11y-btn{
    border:1px solid #cfd6e1;
    border-radius:12px;
    background:#fff;
    color:#000;
    min-height:44px;
    padding:.7rem .8rem;
    font-size:.92rem;
    font-weight:500;
    transition:.2s ease;
}
.a11y-btn:hover,
.a11y-btn:focus{
    background:#000;
    border-color:#000;
    color:#fff;
    outline:none;
}
.a11y-btn-wide{grid-column:span 2}

body.accessibility-contrast{
    background:#fff;
    color:#000;
}
body.accessibility-contrast .welcome-strip,
body.accessibility-contrast .stats-section,
body.accessibility-contrast .why-section,
body.accessibility-contrast .cta-box,
body.accessibility-contrast .site-footer,
body.accessibility-contrast .hero-overlay{
    filter:contrast(1.18);
}
body.accessibility-contrast .section-kicker,
body.accessibility-contrast .eyebrow,
body.accessibility-contrast .text-link,
body.accessibility-contrast .btn-outline-brand,
body.accessibility-contrast .filter-btn.active{
    color:#000 !important;
}
body.accessibility-contrast .btn-brand,
body.accessibility-contrast .btn-outline-brand,
body.accessibility-contrast .filter-btn.active,
body.accessibility-contrast .filter-btn:hover,
body.accessibility-contrast .accessibility-toggle,
body.accessibility-contrast .btn-footer-cta{
    background:#000 !important;
    border-color:#000 !important;
    color:#fff !important;
}
body.accessibility-contrast a{
    text-decoration:underline;
    text-underline-offset:2px;
}

@media (max-width: 575.98px){
    .accessibility-widget{right:14px;bottom:14px}
    .accessibility-toggle{padding:.78rem .9rem;font-size:.86rem}
    .accessibility-panel{width:min(300px, calc(100vw - 28px))}
}


/* =========================================================
   V9 expanded accessibility modes
   ========================================================= */
.a11y-btn i{margin-right:.35rem}
.a11y-btn.is-active{
    background:var(--logo-green-deep);
    border-color:var(--logo-green-deep);
    color:#fff;
}

body.accessibility-bright{
    background:#fffdf5;
    color:#000;
}
body.accessibility-bright main,
body.accessibility-bright .bg-soft,
body.accessibility-bright .section-space,
body.accessibility-bright .service-card,
body.accessibility-bright .direction-inner,
body.accessibility-bright .client-logo,
body.accessibility-bright .accessibility-panel{
    background:#fffdf5 !important;
}
body.accessibility-bright .section-heading p,
body.accessibility-bright .section-lead,
body.accessibility-bright .direction-inner p,
body.accessibility-bright .service-card p{
    color:#111 !important;
}

body.accessibility-dark{
    background:#0d1117;
    color:#f5f7fa;
}
body.accessibility-dark main,
body.accessibility-dark .section-space,
body.accessibility-dark .bg-soft{
    background:#0d1117 !important;
}
body.accessibility-dark .service-card,
body.accessibility-dark .direction-inner,
body.accessibility-dark .client-logo,
body.accessibility-dark .accessibility-panel,
body.accessibility-dark .project-modal-content{
    background:#161b22 !important;
    color:#f5f7fa !important;
    border-color:#30363d !important;
}
body.accessibility-dark .section-title,
body.accessibility-dark .section-heading p,
body.accessibility-dark .section-lead,
body.accessibility-dark .service-card h3,
body.accessibility-dark .service-card p,
body.accessibility-dark .direction-inner h3,
body.accessibility-dark .direction-inner p,
body.accessibility-dark .client-logo,
body.accessibility-dark .accessibility-panel h3,
body.accessibility-dark .accessibility-panel p,
body.accessibility-dark .project-modal-content h2,
body.accessibility-dark .project-modal-content p{
    color:#f5f7fa !important;
}
body.accessibility-dark .main-nav{
    background:#111827 !important;
}
body.accessibility-dark .navbar-nav .nav-link,
body.accessibility-dark .navbar-toggler{
    color:#fff !important;
}
body.accessibility-dark .filter-btn,
body.accessibility-dark .a11y-btn,
body.accessibility-dark .btn-outline-brand,
body.accessibility-dark .text-link,
body.accessibility-dark .client-more-link{
    background:#161b22;
    color:#fff !important;
    border-color:#4b5563;
}
body.accessibility-dark .filter-btn.active,
body.accessibility-dark .filter-btn:hover,
body.accessibility-dark .a11y-btn:hover,
body.accessibility-dark .a11y-btn:focus{
    background:#fff !important;
    color:#000 !important;
    border-color:#fff !important;
}
body.accessibility-dark .accessibility-toggle{
    background:#fff;
    color:#000;
}

body.accessibility-grayscale{
    filter:grayscale(1);
}

body.accessibility-highlight-links a:not(.btn):not(.navbar-brand):not(.footer-brand){
    text-decoration:underline !important;
    text-decoration-thickness:3px !important;
    text-underline-offset:3px !important;
    background:#fff36d !important;
    color:#000 !important;
    padding:0 .12em;
}
body.accessibility-dark.accessibility-highlight-links a:not(.btn):not(.navbar-brand):not(.footer-brand){
    background:#ffe066 !important;
    color:#000 !important;
}


/* V10 quote popup and official about image */
#about .image-frame img{object-position:center center}
.quote-popup-trigger{cursor:pointer}
.quote-modal .modal-dialog{max-width:980px}
.quote-modal-content{display:grid;grid-template-columns:minmax(300px,.88fr) minmax(420px,1.12fr);border:0;border-radius:24px;overflow:hidden;box-shadow:0 30px 90px rgba(7,22,48,.28)}
.quote-modal-visual{position:relative;min-height:100%;background:url('../images/about.webp') center/cover no-repeat;color:#fff}
.quote-modal-overlay{position:absolute;inset:0;background:linear-gradient(155deg,rgba(16,43,91,.9),rgba(47,76,78,.72))}
.quote-modal-copy{position:relative;z-index:1;height:100%;min-height:620px;padding:3rem 2.5rem;display:flex;flex-direction:column;justify-content:flex-end}
.quote-modal-kicker{font-size:.72rem;font-weight:600;letter-spacing:.17em;text-transform:uppercase;color:#cde2dc;margin-bottom:.8rem}
.quote-modal-copy h2{font-size:clamp(1.75rem,3vw,2.55rem);font-weight:500;line-height:1.1;margin-bottom:1rem}
.quote-modal-copy p{color:rgba(255,255,255,.9);font-size:.95rem;line-height:1.45}
.quote-modal-points{display:grid;gap:.65rem;margin-top:1rem}.quote-modal-points span{display:flex;gap:.55rem;align-items:center;color:#fff}.quote-modal-points i{color:#b9d7cf}
.quote-modal-form-wrap{position:relative;background:#fff;padding:3rem 2.6rem}
.quote-modal-close{position:absolute;top:1.15rem;right:1.15rem;z-index:2}
.quote-modal-form-wrap .form-label{font-size:.82rem;font-weight:500;color:#111;margin-bottom:.45rem}
.quote-modal-form-wrap .form-control,.quote-modal-form-wrap .form-select{min-height:48px;border:1px solid #d9dee7;border-radius:11px;font-size:.9rem;font-weight:400;color:#000;padding:.72rem .85rem;box-shadow:none}
.quote-modal-form-wrap textarea.form-control{min-height:118px;resize:vertical}
.quote-modal-form-wrap .form-control:focus,.quote-modal-form-wrap .form-select:focus{border-color:var(--primary);box-shadow:0 0 0 .2rem rgba(58,85,158,.12)}
.quote-submit-btn{min-height:50px;font-size:.95rem;font-weight:400}
.quote-privacy-note{margin:0;text-align:center;color:#5f6878;font-size:.76rem;line-height:1.35}.quote-privacy-note i{color:var(--logo-green)}
.quote-honeypot{position:absolute!important;left:-9999px!important;width:1px!important;height:1px!important;opacity:0!important}
.quote-progress{height:4px;background:#e8edf4;border-radius:99px;overflow:hidden;margin-bottom:1rem}.quote-progress span{display:block;width:38%;height:100%;background:linear-gradient(90deg,var(--primary),var(--logo-green));border-radius:99px;animation:quoteProgress 1.1s ease-in-out infinite}
@keyframes quoteProgress{0%{transform:translateX(-120%)}100%{transform:translateX(340%)}}
.quote-modal .alert{font-size:.84rem;line-height:1.35;border-radius:10px}
@media(max-width:767.98px){.quote-modal .modal-dialog{margin:.75rem}.quote-modal-content{display:block;border-radius:18px}.quote-modal-visual{min-height:210px}.quote-modal-copy{min-height:210px;padding:2rem 1.5rem}.quote-modal-copy h2{font-size:1.65rem}.quote-modal-points{display:none}.quote-modal-form-wrap{padding:2.7rem 1.35rem 1.5rem}.quote-modal-close{top:.9rem;right:.9rem}}


/* =========================================================
   V12 custom quote labels and premium success state
   ========================================================= */
.quote-modal-form-wrap .quote-field-label{
    display:block;
    margin:0 0 .48rem;
    color:#101828;
    font-size:.74rem;
    font-weight:600;
    line-height:1.2;
    letter-spacing:.055em;
    text-transform:uppercase;
}
.quote-modal-form-wrap .form-control,
.quote-modal-form-wrap .form-select{
    border:1px solid #d7dde7;
    border-radius:12px;
    background:#fff;
}
.quote-modal-form-wrap .form-control:hover,
.quote-modal-form-wrap .form-select:hover{
    border-color:#b6c0cf;
}
.quote-modal-form-wrap .form-control:focus,
.quote-modal-form-wrap .form-select:focus{
    border-color:var(--logo-green);
    box-shadow:0 0 0 3px rgba(63,95,97,.11);
}
.quote-inline-message{
    margin-bottom:1rem;
    padding:.8rem .95rem;
    border-radius:12px;
    font-size:.84rem;
    line-height:1.35;
}
.quote-inline-message.is-error{
    color:#8a1c1c;
    background:#fff2f2;
    border:1px solid #f1c9c9;
}
.quote-form-fields{
    transition:opacity .24s ease, transform .24s ease;
}
.quote-form-fields.is-hiding{
    opacity:0;
    transform:translateY(10px);
}
.quote-success-state{
    min-height:540px;
    padding:2rem .3rem;
    display:flex;
    flex-direction:column;
    align-items:flex-start;
    justify-content:center;
    animation:quoteSuccessIn .42s cubic-bezier(.2,.75,.2,1) both;
}
.quote-success-state.d-none{display:none!important}
.quote-success-icon{
    width:66px;
    height:66px;
    display:grid;
    place-items:center;
    border-radius:50%;
    margin-bottom:1.3rem;
    background:linear-gradient(135deg,var(--primary),var(--logo-green));
    color:#fff;
    box-shadow:0 16px 35px rgba(58,85,158,.2);
}
.quote-success-icon i{
    font-size:2rem;
    line-height:1;
}
.quote-success-kicker{
    margin-bottom:.65rem;
    color:var(--logo-green-deep);
    font-size:.72rem;
    font-weight:600;
    letter-spacing:.16em;
    text-transform:uppercase;
}
.quote-success-state h3{
    max-width:520px;
    margin:0 0 1rem;
    color:#101828;
    font-size:clamp(1.6rem,2.8vw,2.2rem);
    font-weight:500;
    line-height:1.12;
    letter-spacing:-.025em;
}
.quote-success-state p{
    max-width:560px;
    margin:0;
    color:#475467;
    font-size:.98rem;
    line-height:1.55;
}
.quote-success-actions{
    display:flex;
    align-items:center;
    flex-wrap:wrap;
    gap:1rem;
    margin-top:1.6rem;
}
.quote-again-btn{
    border:0;
    background:transparent;
    color:#101828;
    padding:.65rem .2rem;
    font-size:.88rem;
    font-weight:500;
    text-decoration:underline;
    text-underline-offset:4px;
}
.quote-again-btn:hover{color:var(--primary)}
@keyframes quoteSuccessIn{
    from{opacity:0;transform:translateY(16px)}
    to{opacity:1;transform:translateY(0)}
}
body.accessibility-dark .quote-success-state h3,
body.accessibility-dark .quote-field-label,
body.accessibility-dark .quote-again-btn{color:#fff}
body.accessibility-dark .quote-success-state p{color:rgba(255,255,255,.78)}
body.accessibility-dark .quote-modal-form-wrap .form-control,
body.accessibility-dark .quote-modal-form-wrap .form-select{background:#172033;color:#fff;border-color:#39445a}
@media(max-width:767.98px){
    .quote-success-state{min-height:390px;padding:1.25rem 0 .6rem}
    .quote-success-state h3{font-size:1.65rem}
    .quote-success-actions{align-items:flex-start;flex-direction:column}
}


/* ===== Multi-page system V15 ===== */
.dropdown-menu{border:0;border-radius:14px;padding:.7rem;box-shadow:0 18px 50px rgba(23,43,91,.14)}
.dropdown-item{border-radius:9px;padding:.7rem .9rem;font-size:.86rem}.dropdown-item:hover{background:var(--logo-green-soft);color:var(--logo-green-deep)}
.page-hero{min-height:470px;background-size:cover;background-position:center;display:flex;align-items:flex-end;color:#fff}
.page-hero-inner{padding-top:120px;padding-bottom:72px}.page-hero h1{max-width:850px;font-size:clamp(2.25rem,4vw,4rem);font-weight:600;line-height:1.05;letter-spacing:-.035em;margin:.8rem 0 1rem}.page-hero p{max-width:760px;font-size:1.05rem;line-height:1.5;color:rgba(255,255,255,.88)}
.breadcrumb{margin-bottom:1.5rem}.breadcrumb-item,.breadcrumb-item a{color:rgba(255,255,255,.76);font-size:.8rem}.breadcrumb-item.active{color:#fff}.breadcrumb-item+.breadcrumb-item::before{color:rgba(255,255,255,.45)}
.page-feature-image{min-height:520px}.content-card,.feature-box,.process-step,.download-card,.contact-form-card{height:100%;background:#fff;border:1px solid var(--border);border-radius:20px;padding:1.7rem;box-shadow:0 12px 36px rgba(23,43,91,.06)}
.content-card>i,.download-card>i{width:54px;height:54px;display:grid;place-items:center;border-radius:15px;background:var(--logo-green-soft);color:var(--logo-green-deep);font-size:1.45rem;margin-bottom:1.2rem}.content-card h3,.feature-box h3,.process-step h3,.download-card h3{font-size:1.08rem;font-weight:600}.content-card p,.feature-box p,.process-step p,.download-card p{color:#303846;margin-bottom:0}
.accent-panel{background:linear-gradient(145deg,var(--navy),#25447c);color:#fff;border-radius:24px;padding:2rem}.accent-panel>i{font-size:2rem;color:#b9d2ca}.accent-panel h3,.accent-panel h2{font-size:1.35rem;margin:1rem 0}.accent-panel p{color:rgba(255,255,255,.82)}
.image-band{background-size:cover;background-position:center;color:#fff}.image-band h2{font-size:clamp(2rem,3vw,3rem);font-weight:600}.image-band p{color:rgba(255,255,255,.84);max-width:720px}
.feature-box{display:flex;gap:1rem}.feature-box>i{color:var(--logo-green);font-size:1.35rem}.process-step span{display:inline-block;color:var(--logo-green);font-weight:700;font-size:.75rem;letter-spacing:.15em;margin-bottom:1rem}
.featured-project{position:relative;min-height:590px;border-radius:24px;overflow:hidden}.featured-project img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.featured-project:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 20%,rgba(5,18,42,.9))}.featured-project>div{position:absolute;z-index:2;left:0;right:0;bottom:0;padding:2rem;color:#fff}.featured-project span{font-size:.72rem;text-transform:uppercase;letter-spacing:.15em}.featured-project h2{font-size:2rem}.featured-project p{color:rgba(255,255,255,.82)}.featured-project a{color:#fff;text-decoration:underline}.project-summary-list{display:grid;gap:1rem;height:100%}.project-summary-list article{padding:1.7rem;border:1px solid var(--border);border-radius:18px;background:#fff}.project-summary-list span{font-size:.7rem;text-transform:uppercase;letter-spacing:.14em;color:var(--logo-green)}.project-summary-list h3{font-size:1.2rem;margin:.6rem 0}.sector-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:1rem}.sector-grid a{display:grid;place-items:center;gap:.8rem;min-height:140px;border-radius:18px;background:#fff;border:1px solid var(--border);color:#111}.sector-grid i{font-size:1.7rem;color:var(--logo-green)}.sector-grid span{font-weight:500}
.client-grid.expanded{grid-template-columns:repeat(4,1fr)}.policy-list{display:grid;gap:.9rem}.policy-list>div{display:flex;align-items:center;gap:.9rem;padding:1rem;border:1px solid var(--border);border-radius:14px;background:#fff}.policy-list i{color:var(--logo-green);font-size:1.2rem}.contact-cards{display:grid;gap:1rem;margin-top:2rem}.contact-cards>a,.contact-cards>div{display:flex;gap:1rem;align-items:center;padding:1rem 1.1rem;border:1px solid var(--border);border-radius:15px;color:#000}.contact-cards i{width:42px;height:42px;display:grid;place-items:center;border-radius:12px;background:var(--logo-green-soft);color:var(--logo-green)}.contact-cards small{display:block;color:#667085}.contact-cards strong{display:block;font-size:.9rem}.contact-form-card{padding:2rem}.contact-form-card h2{font-size:1.7rem;font-weight:600}.map-placeholder{min-height:380px;background:linear-gradient(135deg,#eaf0ef,#edf2fb);display:grid;place-items:center;text-align:center;padding:3rem}.map-placeholder>div{max-width:700px}.map-placeholder i{font-size:3rem;color:var(--logo-green)}
.download-card span{font-size:.7rem;text-transform:uppercase;letter-spacing:.14em;color:var(--logo-green)}.download-card a{display:inline-block;margin-top:1rem;color:#000;font-weight:500}.legal-content{max-width:900px;margin:auto}.legal-content h2{font-size:1.3rem;font-weight:600;margin-top:2.2rem}.legal-content p,.legal-content li{line-height:1.7}.team-card{overflow:hidden;border-radius:20px;border:1px solid var(--border);background:#fff;height:100%}.team-photo-placeholder,.profile-portrait{min-height:320px;background:linear-gradient(145deg,#e8edf6,#dce7e4);display:grid;place-items:center;color:#607080}.team-photo-placeholder i,.profile-portrait i{font-size:5rem}.team-card>div:last-child{padding:1.5rem}.team-card span{font-size:.7rem;text-transform:uppercase;letter-spacing:.13em;color:var(--logo-green)}.team-card h3{font-size:1.25rem;margin:.5rem 0}.team-card a{color:#000;font-weight:500}.profile-portrait{min-height:560px;border-radius:24px;align-content:center;gap:1rem}.profile-portrait span{font-size:.85rem}.leadership-quote{border-left:4px solid var(--logo-green);padding:1rem 1.3rem;background:var(--logo-green-soft);border-radius:0 14px 14px 0;font-size:1.05rem;line-height:1.6;margin:1.7rem 0}
@media(max-width:991.98px){.page-hero{min-height:420px}.sector-grid{grid-template-columns:repeat(3,1fr)}.client-grid.expanded{grid-template-columns:repeat(3,1fr)}}
@media(max-width:767.98px){.page-hero-inner{padding-top:90px;padding-bottom:55px}.page-hero h1{font-size:2.35rem}.page-hero p{font-size:.95rem}.sector-grid{grid-template-columns:repeat(2,1fr)}.client-grid.expanded{grid-template-columns:repeat(2,1fr)}.featured-project{min-height:480px}.page-feature-image{min-height:360px}}


/* V16 navigation and footer information architecture */
.main-nav .dropdown-menu{
    min-width:250px;
    margin-top:.7rem;
    border:1px solid rgba(23,43,91,.08);
}
.main-nav .dropdown-item{
    display:flex;
    align-items:center;
    gap:.75rem;
    min-height:44px;
    color:#172033;
    font-weight:500;
}
.main-nav .dropdown-item i{
    width:22px;
    color:var(--logo-green-deep);
    font-size:1rem;
}
.main-nav .dropdown-item:hover,
.main-nav .dropdown-item:focus{
    background:var(--logo-green-soft);
    color:var(--navy);
}
.main-nav .dropdown-toggle.active{
    color:var(--primary);
}
.footer-main{
    --bs-gutter-x:2rem;
}
.site-footer .contact-list{
    overflow-wrap:anywhere;
}
@media(min-width:992px){
    .main-nav .navbar-nav > .dropdown:hover > .dropdown-menu{
        display:block;
    }
    .main-nav .navbar-nav > .dropdown:hover > .dropdown-toggle::after{
        transform:rotate(180deg);
    }
    .main-nav .dropdown-toggle::after{
        transition:transform .2s ease;
    }
}
@media(max-width:1199.98px) and (min-width:992px){
    .navbar-nav .nav-link{
        padding-left:.55rem!important;
        padding-right:.55rem!important;
        font-size:.82rem;
    }
    .main-nav .btn{
        padding-left:1rem;
        padding-right:1rem;
    }
}
@media(max-width:991.98px){
    .main-nav .dropdown-menu{
        border:0;
        box-shadow:none;
        margin:.15rem 0 .55rem;
        padding:.35rem 0 .35rem 1rem;
        background:#f7f9fc;
    }
    .main-nav .dropdown-item{
        min-height:42px;
    }
}


/* V17 dropdown usability fix */
.main-nav .dropdown-menu{
    margin-top:0 !important;
}
.main-nav .dropdown-item{
    gap:0;
    padding-left:1rem;
    padding-right:1rem;
}
.main-nav .dropdown-item span{
    display:block;
    width:100%;
}
@media(min-width:992px){
    .main-nav .navbar-nav > .dropdown{
        position:relative;
    }
    .main-nav .navbar-nav > .dropdown > .dropdown-menu{
        top:100%;
        padding-top:.85rem;
    }
    .main-nav .navbar-nav > .dropdown > .dropdown-menu::before{
        content:"";
        position:absolute;
        left:0;
        right:0;
        top:-12px;
        height:14px;
        background:transparent;
    }
    .main-nav .navbar-nav > .dropdown:hover > .dropdown-menu,
    .main-nav .navbar-nav > .dropdown:focus-within > .dropdown-menu{
        display:block;
    }
}
@media(max-width:991.98px){
    .main-nav .dropdown-menu{
        padding-top:.35rem;
    }
}


/* =========================================================
   V18 embedded contact form and clients directory
   ========================================================= */
.contact-form-embedded{
    padding:2.25rem;
    border:1px solid var(--border);
    border-radius:24px;
    background:#fff;
    box-shadow:0 24px 65px rgba(23,43,91,.1);
}
.contact-form-embedded > h2{
    margin:.55rem 0 .85rem;
    font-size:clamp(1.7rem,2.7vw,2.35rem);
    font-weight:600;
}
.contact-form-embedded > p{
    margin-bottom:1.7rem;
    color:#344054;
}
.embedded-quote-form .form-control,
.embedded-quote-form .form-select{
    min-height:50px;
    border:1px solid #d7dde8;
    border-radius:12px;
    background:#fbfcfe;
    color:#111827;
    font-size:.95rem;
    box-shadow:none;
}
.embedded-quote-form textarea.form-control{
    min-height:150px;
    resize:vertical;
}
.embedded-quote-form .form-control:focus,
.embedded-quote-form .form-select:focus{
    border-color:var(--primary);
    background:#fff;
    box-shadow:0 0 0 4px rgba(58,85,158,.1);
}
.contact-assurance-card{
    display:flex;
    gap:1rem;
    align-items:flex-start;
    margin-top:1.5rem;
    padding:1.25rem;
    border-radius:18px;
    background:var(--logo-green-soft);
    border:1px solid rgba(63,95,97,.14);
}
.contact-assurance-icon{
    width:44px;
    height:44px;
    flex:0 0 44px;
    display:grid;
    place-items:center;
    border-radius:12px;
    background:var(--logo-green-deep);
    color:#fff;
    font-size:1.15rem;
}
.contact-assurance-card h3{
    margin:0 0 .4rem;
    font-size:1rem;
    font-weight:600;
}
.contact-assurance-card p{margin:0;color:#243238}

.clients-directory{
    border-radius:24px;
}
.clients-toolbar{
    display:flex;
    align-items:end;
    justify-content:space-between;
    gap:1rem;
    margin-bottom:1.25rem;
}
.clients-search-wrap{
    position:relative;
    flex:1 1 520px;
}
.clients-search-wrap i{
    position:absolute;
    left:1rem;
    top:50%;
    transform:translateY(-50%);
    color:#667085;
}
.clients-search-wrap input,
.clients-filter-wrap select{
    width:100%;
    min-height:50px;
    border:1px solid #d9dee8;
    border-radius:13px;
    background:#fff;
    color:#111827;
    font-size:.94rem;
    outline:none;
}
.clients-search-wrap input{padding:.75rem 1rem .75rem 2.75rem}
.clients-filter-wrap{flex:0 0 240px}
.clients-filter-wrap label{
    display:block;
    margin-bottom:.45rem;
    color:#344054;
    font-size:.76rem;
    font-weight:600;
    letter-spacing:.08em;
    text-transform:uppercase;
}
.clients-filter-wrap select{padding:.75rem 2.5rem .75rem 1rem}
.clients-search-wrap input:focus,
.clients-filter-wrap select:focus{
    border-color:var(--primary);
    box-shadow:0 0 0 4px rgba(58,85,158,.1);
}
.clients-table-card{
    overflow:hidden;
    border:1px solid #e1e6ef;
    border-radius:20px;
    background:#fff;
    box-shadow:0 20px 55px rgba(23,43,91,.08);
}
.clients-table{
    width:100%;
    border-collapse:collapse;
}
.clients-table th{
    padding:1rem 1.15rem;
    background:#102a54;
    color:#fff;
    font-size:.74rem;
    font-weight:600;
    letter-spacing:.08em;
    text-transform:uppercase;
    white-space:nowrap;
}
.clients-table td{
    padding:1.05rem 1.15rem;
    border-bottom:1px solid #edf0f5;
    color:#1f2937;
    font-size:.9rem;
    vertical-align:middle;
}
.clients-table tbody tr{
    transition:background-color .2s ease,transform .2s ease;
}
.clients-table tbody tr:hover{background:#f7f9fc}
.clients-table tbody tr:last-child td{border-bottom:0}
.clients-table td strong{font-weight:600;color:#111827}
.client-sector-badge{
    display:inline-flex;
    align-items:center;
    min-height:30px;
    padding:.35rem .7rem;
    border-radius:999px;
    background:var(--logo-green-soft);
    color:var(--logo-green-deep);
    font-size:.76rem;
    font-weight:500;
    white-space:nowrap;
}
.clients-table-footer{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:1rem;
    padding:1rem 1.15rem;
    border-top:1px solid #e9edf3;
    background:#fbfcfe;
}
.clients-table-footer p{margin:0;color:#526071;font-size:.86rem}
.clients-pagination{display:flex;align-items:center;gap:.4rem}
.clients-page-btn{
    width:38px;
    height:38px;
    display:grid;
    place-items:center;
    border:1px solid #d7dde8;
    border-radius:10px;
    background:#fff;
    color:#1f2937;
    font-size:.86rem;
    font-weight:500;
    transition:.2s ease;
}
.clients-page-btn:hover:not(:disabled),
.clients-page-btn.is-active{
    background:var(--primary);
    border-color:var(--primary);
    color:#fff;
}
.clients-page-btn:disabled{opacity:.38;cursor:not-allowed}
.clients-empty-state{
    padding:4rem 1.5rem;
    text-align:center;
}
.clients-empty-state i{font-size:2.2rem;color:#7a8799}
.clients-empty-state h3{margin:.8rem 0 .35rem;font-size:1.15rem;font-weight:600}
.clients-empty-state p{margin:0;color:#667085}

@media(max-width:767.98px){
    .contact-form-embedded{padding:1.5rem}
    .clients-toolbar{align-items:stretch;flex-direction:column}
    .clients-filter-wrap{flex:1 1 auto;width:100%}
    .clients-table thead{display:none}
    .clients-table,
    .clients-table tbody,
    .clients-table tr,
    .clients-table td{display:block;width:100%}
    .clients-table tr{padding:1rem 1rem .35rem;border-bottom:1px solid #e8edf4}
    .clients-table td{
        display:grid;
        grid-template-columns:minmax(120px,42%) 1fr;
        gap:.75rem;
        padding:.55rem 0;
        border:0;
        text-align:left;
    }
    .clients-table td::before{
        content:attr(data-label);
        color:#667085;
        font-size:.72rem;
        font-weight:600;
        letter-spacing:.05em;
        text-transform:uppercase;
    }
    .clients-table-footer{align-items:flex-start;flex-direction:column}
    .clients-pagination{flex-wrap:wrap}
}


/* =========================================================
   V21 progressive image loading and portfolio motion
   ========================================================= */
.image-loader-shell{
    position:relative;
    display:block;
    max-width:100%;
    overflow:hidden;
    background:#e9edf3;
    isolation:isolate;
}
.image-loader-shell::before{
    content:"";
    position:absolute;
    inset:0;
    z-index:1;
    background:
        linear-gradient(105deg,
            transparent 20%,
            rgba(255,255,255,.72) 42%,
            transparent 64%),
        linear-gradient(135deg,#e6ebf2,#f5f7fa 55%,#e8edf3);
    background-size:220% 100%,100% 100%;
    animation:imageShimmer 1.35s linear infinite;
    transition:opacity .35s ease,visibility .35s ease;
}
.image-loader-shell::after{
    content:"";
    position:absolute;
    left:50%;
    top:50%;
    z-index:2;
    width:30px;
    height:30px;
    margin:-15px 0 0 -15px;
    border:2px solid rgba(58,85,158,.2);
    border-top-color:var(--primary);
    border-radius:50%;
    animation:imageLoaderSpin .8s linear infinite;
    transition:opacity .25s ease;
}
.image-loader-shell img{
    opacity:0;
    filter:blur(8px);
    transform:scale(1.025);
    transition:opacity .55s ease,filter .65s ease,transform .65s cubic-bezier(.22,.7,.2,1);
}
.image-loader-shell.is-loaded::before,
.image-loader-shell.is-loaded::after{
    opacity:0;
    visibility:hidden;
}
.image-loader-shell.is-loaded img,
.image-loader-shell img.is-image-loaded{
    opacity:1;
    filter:blur(0);
    transform:scale(1);
}
.image-loader-shell.is-error::before,
.image-loader-shell.is-error::after{
    display:none;
}
.image-loader-shell.is-error{
    background:linear-gradient(135deg,#edf0f4,#dde3ea);
}
.image-loader-shell--rounded,
.image-loader-shell--rounded img{
    border-radius:22px;
}
.image-frame .image-loader-shell,
.image-frame .image-loader-shell img,
.image-loader-shell .page-feature-image,
.image-loader-shell .rounded-image{
    width:100%;
}
.project-card .image-loader-shell{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    border-radius:inherit;
}
.project-card .image-loader-shell img{
    width:100%;
    height:100%;
    object-fit:cover;
}
.project-card:hover .image-loader-shell.is-loaded img{
    transform:scale(1.075);
}
.project-modal-content > .image-loader-shell{
    width:100%;
    height:340px;
}
.project-modal-content > .image-loader-shell img{
    width:100%;
    height:100%;
    object-fit:cover;
}
@keyframes imageShimmer{
    from{background-position:180% 0,0 0}
    to{background-position:-40% 0,0 0}
}
@keyframes imageLoaderSpin{
    to{transform:rotate(360deg)}
}

/* New portfolio category transition: fold away, then alternate slide reveal */
#portfolioGrid{
    transition:opacity .22s ease,transform .22s ease;
}
#portfolioGrid.is-switching{
    pointer-events:none;
}
.portfolio-item{
    transform-origin:50% 70%;
    will-change:transform,opacity,filter;
}
.portfolio-item.portfolio-leaving{
    animation:portfolioFoldAway .26s cubic-bezier(.55,.05,.85,.35) both;
}
.portfolio-item.portfolio-enter-left{
    animation:portfolioSweepLeft .62s cubic-bezier(.16,1,.3,1) var(--portfolio-delay,0ms) both;
}
.portfolio-item.portfolio-enter-right{
    animation:portfolioSweepRight .62s cubic-bezier(.16,1,.3,1) var(--portfolio-delay,0ms) both;
}
@keyframes portfolioFoldAway{
    from{opacity:1;transform:perspective(900px) rotateX(0) translateY(0) scale(1);filter:blur(0)}
    to{opacity:0;transform:perspective(900px) rotateX(-9deg) translateY(-16px) scale(.965);filter:blur(4px)}
}
@keyframes portfolioSweepLeft{
    from{opacity:0;transform:translate3d(-42px,28px,0) rotate(-1.7deg) scale(.94);filter:blur(7px)}
    65%{opacity:1;filter:blur(0)}
    to{opacity:1;transform:translate3d(0,0,0) rotate(0) scale(1);filter:blur(0)}
}
@keyframes portfolioSweepRight{
    from{opacity:0;transform:translate3d(42px,28px,0) rotate(1.7deg) scale(.94);filter:blur(7px)}
    65%{opacity:1;filter:blur(0)}
    to{opacity:1;transform:translate3d(0,0,0) rotate(0) scale(1);filter:blur(0)}
}
.filter-btn.active{
    box-shadow:0 9px 22px rgba(47,76,78,.17);
    transform:translateY(-1px);
}

@media (prefers-reduced-motion: reduce){
    .image-loader-shell::before,
    .image-loader-shell::after,
    .portfolio-item.portfolio-leaving,
    .portfolio-item.portfolio-enter-left,
    .portfolio-item.portfolio-enter-right{
        animation:none!important;
    }
    .image-loader-shell img{
        transition:opacity .15s ease!important;
        filter:none!important;
        transform:none!important;
    }
}


/* V24 dynamic content */
.dynamic-content-card{height:100%;background:#fff;border:1px solid var(--border);border-radius:18px;overflow:hidden;box-shadow:0 14px 36px rgba(23,43,91,.08);transition:.3s ease}.dynamic-content-card:hover{transform:translateY(-6px);box-shadow:0 22px 50px rgba(23,43,91,.14)}.dynamic-content-card a{display:block;color:#000;height:100%}.dynamic-content-card img{width:100%;height:260px;object-fit:cover}.dynamic-content-card div{padding:1.35rem}.dynamic-content-card span{color:var(--logo-green);text-transform:uppercase;letter-spacing:.12em;font-size:.7rem;font-weight:600}.dynamic-content-card h3{font-size:1.25rem;margin:.55rem 0}.dynamic-content-card p{color:#1f2937}.dynamic-content-card small{color:#5e6878}.project-card-link{height:100%}.project-card-link .project-card{display:block}.detail-rich-content{font-size:1rem;line-height:1.7;color:#111827}.detail-rich-content h2,.detail-rich-content h3{margin-top:1.8rem}.detail-rich-content li{margin-bottom:.5rem}.detail-sidebar-card{position:sticky;top:110px;background:var(--soft);border:1px solid var(--border);padding:1.5rem;border-radius:18px}.detail-sidebar-card>div{padding:1rem 0;border-bottom:1px solid var(--border)}.detail-sidebar-card small{display:block;color:#687386;margin-bottom:.25rem}.detail-sidebar-card strong{display:block;color:#111827}.detail-gallery{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.detail-gallery img{width:100%;height:280px;object-fit:cover;border-radius:16px}.empty-content-state{padding:2rem;border:1px dashed #cbd5e1;border-radius:16px;background:#f8fafc;color:#334155;text-align:center}@media(max-width:767px){.detail-gallery{grid-template-columns:1fr}.detail-sidebar-card{position:static}.dynamic-content-card img{height:220px}}


/* V36 dynamic client empty states */
.empty-content-state{max-width:720px;margin:0 auto;padding:46px 28px;border:1px dashed #cfd8e5;border-radius:20px;background:#f8fafc;text-align:center}.empty-content-state i{display:inline-grid;place-items:center;width:58px;height:58px;margin-bottom:16px;border-radius:16px;background:var(--logo-green-soft);color:var(--logo-green-deep);font-size:1.5rem}.empty-content-state h3{font-size:1.25rem;font-weight:600;color:#111827}.empty-content-state p{margin:0;color:#4b5563}.compact-empty-state{padding:34px 24px}


/* V37 migration-readiness refinements */
.quote-form-heading{margin:0 0 1.35rem;padding-right:2.25rem}
.quote-form-heading>span{display:block;margin-bottom:.35rem;color:var(--logo-green);font-size:.68rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase}
.quote-form-heading h3{margin:0 0 .45rem;color:#111827;font-size:1.35rem;font-weight:600;line-height:1.2}
.quote-form-heading p{margin:0;color:#4b5563;font-size:.88rem;line-height:1.45}
.download-description{position:relative;overflow:hidden;transition:max-height .32s ease}
.download-description.is-collapsed:after{content:"";position:absolute;left:0;right:0;bottom:0;height:38px;background:linear-gradient(transparent,#fff)}
.download-description-toggle{margin:-.15rem 0 .9rem;padding:0;border:0;background:transparent;color:#000;font-size:.86rem;font-weight:600;text-decoration:underline;text-underline-offset:3px}
.download-description-toggle:hover{color:var(--logo-green-deep)}
.team-profile-photo{aspect-ratio:4/5;min-height:0;object-fit:cover}


/* =========================================================
   V39 homepage clients section normalization
   ========================================================= */
#clients{
    position:relative;
    overflow:hidden;
}
#clients .section-heading{
    position:relative;
    z-index:2;
    max-width:760px;
    margin-bottom:2.75rem;
}
#clients .section-heading p{
    max-width:680px;
    margin-left:auto;
    margin-right:auto;
}
#clients .client-grid{
    position:relative;
    z-index:1;
    display:grid;
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:1.15rem;
    align-items:stretch;
}
#clients .client-logo{
    position:relative;
    width:100%;
    height:132px;
    min-width:0;
    padding:20px 24px;
    overflow:hidden;
    display:flex;
    align-items:center;
    justify-content:center;
    border:1px solid #e1e7ef;
    border-radius:18px;
    background:#fff;
    box-shadow:0 10px 28px rgba(23,43,91,.055);
    transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;
}
#clients .client-logo:hover{
    transform:translateY(-4px);
    border-color:rgba(58,85,158,.24);
    box-shadow:0 18px 38px rgba(23,43,91,.1);
}
#clients .client-logo img{
    display:block;
    width:auto !important;
    height:auto !important;
    max-width:100% !important;
    max-height:82px !important;
    object-fit:contain !important;
    object-position:center !important;
    margin:auto;
    opacity:1 !important;
    filter:none !important;
    transform:none !important;
}
#clients .client-logo .image-loader-shell{
    width:100%;
    height:100%;
    display:flex;
    align-items:center;
    justify-content:center;
    background:transparent;
    overflow:visible;
}
#clients .client-logo .image-loader-shell::before,
#clients .client-logo .image-loader-shell::after{
    display:none !important;
}
#clients .client-logo span{
    display:block;
    max-width:100%;
    overflow:hidden;
    color:#536073;
    font-size:1rem;
    font-weight:600;
    line-height:1.25;
    text-align:center;
    text-overflow:ellipsis;
}
#clients .client-more-link{
    position:relative;
    z-index:2;
    min-width:190px;
}
@media(max-width:991.98px){
    #clients .client-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media(max-width:767.98px){
    #clients .section-heading{margin-bottom:2rem}
    #clients .client-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.85rem}
    #clients .client-logo{height:112px;padding:16px 18px;border-radius:15px}
    #clients .client-logo img{max-height:68px !important}
}
@media(max-width:420px){
    #clients .client-grid{grid-template-columns:1fr}
    #clients .client-logo{height:108px}
}


/* V40 Lighthouse/mobile performance refinements */
.hero-slide{background-image:none!important;contain:layout paint style}
.hero-media{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;z-index:0}
.hero-overlay,.hero-content-wrap{z-index:1}
.hero-overlay{will-change:opacity}
img{height:auto}
.project-card,.service-card,.client-logo,.why-card{contain:layout paint style}
.portfolio-item{will-change:transform,opacity}
.portfolio-item.portfolio-leaving,.portfolio-item.portfolio-enter-left,.portfolio-item.portfolio-enter-right{transition-property:transform,opacity!important}
.image-loader-shell::before{will-change:transform,opacity}
@media(max-width:767.98px){
  .hero-media{object-position:center center}
  .image-loader-shell::after{display:none}
  .project-card img{transition:transform .3s ease}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{scroll-behavior:auto!important;animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
}


/* =========================================================
   V43 larger homepage portfolio cards + direct detail links
   ========================================================= */
#portfolio .homepage-portfolio-card{
    display:block;
    height:500px;
    color:#fff;
    cursor:pointer;
    box-shadow:0 18px 44px rgba(23,43,91,.13);
}
#portfolio .homepage-portfolio-card img{
    width:100%;
    height:100%;
    object-fit:cover;
}
#portfolio .homepage-portfolio-card .project-content{
    padding:2rem;
}
#portfolio .homepage-portfolio-card .project-content strong{
    font-size:1.45rem;
    line-height:1.15;
    margin:.35rem 0 .45rem;
}
#portfolio .homepage-portfolio-card .project-content span:last-child{
    font-size:.92rem;
}
#portfolio .homepage-portfolio-card:focus-visible{
    outline:3px solid var(--logo-green);
    outline-offset:4px;
}
@media(max-width:991.98px){
    #portfolio .homepage-portfolio-card{height:430px}
}
@media(max-width:767.98px){
    #portfolio .homepage-portfolio-card{height:370px}
    #portfolio .homepage-portfolio-card .project-content{padding:1.5rem}
    #portfolio .homepage-portfolio-card .project-content strong{font-size:1.2rem}
}


/* =========================================================
   V45 homepage portfolio sizing + larger modal image
   ========================================================= */
#portfolio .homepage-portfolio-card{height:390px}
#portfolio .homepage-portfolio-card .project-content{padding:1.55rem}
#portfolio .homepage-portfolio-card .project-content strong{font-size:1.25rem}
#projectModal .modal-dialog{max-width:1080px}
#projectModal .project-modal-content>img{width:100%;height:560px;object-fit:cover;object-position:center}
#projectModal .modal-body{padding-top:2rem!important}
@media(max-width:991.98px){
  #portfolio .homepage-portfolio-card{height:350px}
  #projectModal .project-modal-content>img{height:470px}
}
@media(max-width:767.98px){
  #portfolio .homepage-portfolio-card{height:310px}
  #portfolio .homepage-portfolio-card .project-content{padding:1.25rem}
  #portfolio .homepage-portfolio-card .project-content strong{font-size:1.12rem}
  #projectModal .modal-dialog{margin:.75rem}
  #projectModal .project-modal-content>img{height:330px}
}


/* =========================================================
   V47 stable first-paint / no FOUC
   ========================================================= */
html.css-ready body{
    visibility:visible;
    animation:siteReadyReveal .16s ease-out both;
}
html.css-ready::before,
html.css-ready::after{
    content:none !important;
    display:none !important;
}
@keyframes siteReadyReveal{
    from{opacity:.985}
    to{opacity:1}
}
@media(prefers-reduced-motion:reduce){
    html.css-ready body{animation:none}
}


/* =========================================================
   V48 company direction and core values pages
   ========================================================= */
.direction-link-card{
    display:flex;
    flex-direction:column;
    height:100%;
}
.direction-link-card .text-link{
    margin-top:auto;
    padding-top:1rem;
}
.values-section{
    position:relative;
    overflow:hidden;
}
.value-card{
    height:100%;
    padding:2rem;
    border:1px solid #e3e8ef;
    border-radius:20px;
    background:#fff;
    box-shadow:0 14px 38px rgba(23,43,91,.07);
}
.value-icon{
    width:58px;
    height:58px;
    display:grid;
    place-items:center;
    margin-bottom:1.25rem;
    border-radius:16px;
    background:var(--logo-green-soft);
    color:var(--logo-green-deep);
    font-size:1.45rem;
}
.value-card h3{
    margin-bottom:.8rem;
    font-size:1.2rem;
    font-weight:600;
}
.value-card p{
    margin:0;
    color:#1f2937;
    line-height:1.5;
}
.policy-layout{
    display:grid;
    grid-template-columns:300px minmax(0,1fr);
    gap:4.5rem;
    align-items:start;
    max-width:1080px;
    margin:0 auto;
}
.policy-icon-panel{
    min-height:310px;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:1rem;
    border-radius:24px;
    color:#fff;
    background:
        radial-gradient(circle at 85% 15%,rgba(92,138,132,.42),transparent 32%),
        linear-gradient(145deg,var(--navy),var(--primary));
    box-shadow:0 24px 55px rgba(23,43,91,.18);
}
.policy-icon-panel i{
    font-size:4.2rem;
}
.policy-icon-panel span{
    font-size:.76rem;
    font-weight:700;
    letter-spacing:.18em;
    text-transform:uppercase;
}
.lead-copy{
    margin-bottom:1.35rem;
    color:#0f172a;
    font-size:1.15rem;
    font-weight:500;
    line-height:1.5;
}
.policy-points{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:1rem;
    margin-top:2rem;
}
.policy-points div{
    display:flex;
    align-items:flex-start;
    gap:.7rem;
    padding:1rem;
    border:1px solid #e4e9f0;
    border-radius:14px;
    background:#f8fafc;
}
.policy-points i{
    margin-top:.15rem;
    color:var(--logo-green);
}
.policy-points span{
    color:#172033;
    font-size:.92rem;
    font-weight:500;
    line-height:1.4;
}
@media(max-width:991.98px){
    .policy-layout{
        grid-template-columns:1fr;
        gap:2.5rem;
    }
    .policy-icon-panel{
        min-height:220px;
    }
}
@media(max-width:575.98px){
    .policy-points{
        grid-template-columns:1fr;
    }
    .value-card{
        padding:1.5rem;
    }
}

/* =========================================================
   V49 corporate signage page
   ========================================================= */
.signage-highlight-list{
    display:grid;
    gap:.8rem;
    margin-top:1.5rem;
}
.signage-highlight-list div{
    display:flex;
    align-items:flex-start;
    gap:.75rem;
    color:#172033;
    font-weight:500;
}
.signage-highlight-list i{
    margin-top:.12rem;
    color:var(--logo-green);
}
.signage-feature-visual{
    position:relative;
}
.signage-feature-visual img{
    min-height:520px;
}
.signage-visual-badge{
    position:absolute;
    left:28px;
    right:28px;
    bottom:28px;
    padding:1.2rem 1.4rem;
    border:1px solid rgba(255,255,255,.25);
    border-radius:16px;
    background:rgba(10,29,57,.88);
    color:#fff;
    backdrop-filter:blur(12px);
}
.signage-visual-badge strong{
    display:block;
    margin-bottom:.25rem;
    font-size:1.05rem;
    font-weight:600;
}
.signage-visual-badge span{
    color:rgba(255,255,255,.76);
    font-size:.82rem;
}
.signage-solution-grid{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:1.25rem;
}
.signage-solution-card{
    padding:1.7rem;
    border:1px solid #e1e7ef;
    border-radius:20px;
    background:#fff;
    box-shadow:0 12px 34px rgba(23,43,91,.06);
    transition:transform .25s ease,border-color .25s ease,box-shadow .25s ease;
}
.signage-solution-card:hover{
    transform:translateY(-4px);
    border-color:rgba(63,95,97,.3);
    box-shadow:0 20px 44px rgba(23,43,91,.1);
}
.signage-card-top{
    display:flex;
    align-items:center;
    justify-content:space-between;
    margin-bottom:1.2rem;
}
.signage-card-icon{
    width:52px;
    height:52px;
    display:grid;
    place-items:center;
    border-radius:15px;
    background:var(--logo-green-soft);
    color:var(--logo-green-deep);
    font-size:1.35rem;
}
.signage-card-number{
    color:#c4ccd8;
    font-size:.74rem;
    font-weight:700;
    letter-spacing:.14em;
}
.signage-solution-card h3{
    margin-bottom:.65rem;
    font-size:1.2rem;
    font-weight:600;
}
.signage-solution-card > p{
    min-height:48px;
    margin-bottom:1rem;
    color:#39465a;
    line-height:1.45;
}
.signage-card-toggle{
    display:inline-flex;
    align-items:center;
    gap:.55rem;
    padding:0;
    border:0;
    background:transparent;
    color:#000;
    font-size:.9rem;
    font-weight:600;
}
.signage-card-toggle i{
    transition:transform .25s ease;
}
.signage-card-toggle[aria-expanded="true"] i{
    transform:rotate(45deg);
}
.signage-capability-list{
    display:grid;
    gap:.65rem;
    margin:1.1rem 0 0;
    padding:1rem 0 0;
    border-top:1px solid #edf0f4;
    list-style:none;
}
.signage-capability-list li{
    display:flex;
    align-items:flex-start;
    gap:.35rem;
    color:#263348;
    font-size:.9rem;
    line-height:1.4;
}
.signage-capability-list i{
    margin-top:.05rem;
    color:var(--logo-green);
    font-size:1.15rem;
}
.signage-consultancy-panel{
    position:sticky;
    top:120px;
    padding:2.3rem;
    border-radius:24px;
    background:
        radial-gradient(circle at 90% 10%,rgba(80,123,118,.35),transparent 30%),
        linear-gradient(145deg,var(--navy),var(--primary));
    color:#fff;
    box-shadow:0 24px 58px rgba(23,43,91,.2);
}
.signage-consultancy-panel h2{
    margin:.75rem 0 1rem;
    font-size:clamp(1.65rem,3vw,2.35rem);
    font-weight:550;
}
.signage-consultancy-panel p{
    color:rgba(255,255,255,.78);
    line-height:1.55;
}
.signage-consultancy-stat{
    display:flex;
    align-items:center;
    gap:.7rem;
    margin-top:1.7rem;
    padding-top:1.2rem;
    border-top:1px solid rgba(255,255,255,.14);
    color:#d7e4f5;
    font-size:.82rem;
}
.signage-consultancy-stat strong{
    color:#fff;
}
.consultancy-process-list{
    display:grid;
    gap:1rem;
}
.consultancy-process-item{
    display:grid;
    grid-template-columns:48px minmax(0,1fr);
    gap:1rem;
    align-items:start;
    padding:1.35rem 1.5rem;
    border:1px solid #e2e7ee;
    border-radius:16px;
    background:#fff;
}
.consultancy-process-item > span{
    width:42px;
    height:42px;
    display:grid;
    place-items:center;
    border-radius:12px;
    background:var(--logo-green-soft);
    color:var(--logo-green-deep);
    font-size:.74rem;
    font-weight:700;
}
.consultancy-process-item p{
    margin:0;
    color:#1f2937;
    line-height:1.5;
}
.signage-process-card{
    height:100%;
}
.signage-maintenance-box{
    display:grid;
    grid-template-columns:92px minmax(0,1fr) auto;
    gap:2rem;
    align-items:center;
    padding:2.4rem;
    border:1px solid #dce5e3;
    border-radius:24px;
    background:linear-gradient(135deg,#f8fbfa,#edf4f2);
}
.signage-maintenance-icon{
    width:82px;
    height:82px;
    display:grid;
    place-items:center;
    border-radius:22px;
    background:var(--logo-green-deep);
    color:#fff;
    font-size:2rem;
}
.signage-maintenance-copy h2{
    margin:.55rem 0 .75rem;
    font-size:clamp(1.55rem,2.7vw,2.25rem);
    font-weight:550;
}
.signage-maintenance-copy p{
    max-width:760px;
    margin-bottom:1.2rem;
    color:#263348;
    line-height:1.5;
}
.signage-maintenance-points{
    display:flex;
    flex-wrap:wrap;
    gap:.7rem 1.1rem;
}
.signage-maintenance-points span{
    color:#253344;
    font-size:.85rem;
    font-weight:500;
}
.signage-maintenance-points i{
    margin-right:.3rem;
    color:var(--logo-green);
}
.signage-maintenance-action{
    white-space:nowrap;
}
@media(max-width:991.98px){
    .signage-solution-grid{
        grid-template-columns:1fr;
    }
    .signage-consultancy-panel{
        position:relative;
        top:auto;
    }
    .signage-maintenance-box{
        grid-template-columns:82px minmax(0,1fr);
    }
    .signage-maintenance-action{
        grid-column:1/-1;
        padding-left:0;
    }
}
@media(max-width:575.98px){
    .signage-feature-visual img{
        min-height:360px;
    }
    .signage-visual-badge{
        left:16px;
        right:16px;
        bottom:16px;
    }
    .signage-solution-card{
        padding:1.35rem;
    }
    .signage-solution-card > p{
        min-height:0;
    }
    .signage-consultancy-panel{
        padding:1.65rem;
    }
    .consultancy-process-item{
        grid-template-columns:40px minmax(0,1fr);
        padding:1.1rem;
    }
    .signage-maintenance-box{
        grid-template-columns:1fr;
        padding:1.5rem;
    }
    .signage-maintenance-icon{
        width:68px;
        height:68px;
    }
}


/* =========================================================
   V52 related signage projects / portfolio
   ========================================================= */
.signage-related-work-section .section-heading-row{margin-bottom:2.4rem}
.signage-related-work-section .section-heading{max-width:780px}
.signage-related-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1.4rem}
.signage-related-card{overflow:hidden;border:1px solid var(--border);border-radius:20px;background:#fff;box-shadow:0 14px 34px rgba(23,43,91,.08);transition:transform .28s ease,box-shadow .28s ease}
.signage-related-card:hover{transform:translateY(-6px);box-shadow:0 24px 48px rgba(23,43,91,.14)}
.signage-related-media{position:relative;display:block;height:270px;overflow:hidden;background:#e9eef5}
.signage-related-media img{width:100%;height:100%;object-fit:cover;transition:transform .45s ease}
.signage-related-card:hover .signage-related-media img{transform:scale(1.045)}
.signage-related-placeholder{width:100%;height:100%;display:grid;place-items:center;color:var(--primary);font-size:2.4rem;background:linear-gradient(135deg,#edf2fa,#dde6f2)}
.signage-related-type{position:absolute;top:16px;left:16px;padding:.45rem .7rem;border-radius:999px;background:rgba(8,22,48,.82);color:#fff;font-size:.66rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;backdrop-filter:blur(8px)}
.signage-related-copy{padding:1.45rem}
.signage-related-category{display:block;margin-bottom:.55rem;color:var(--logo-green-deep);font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase}
.signage-related-copy h3{margin:0 0 .65rem;font-size:1.18rem;line-height:1.22;font-weight:600}
.signage-related-copy h3 a{color:#101828}
.signage-related-copy h3 a:hover{color:var(--primary)}
.signage-related-meta{margin-bottom:.65rem;color:#5f6b7d;font-size:.78rem;font-weight:500}
.signage-related-copy > p:not(.signage-related-meta){display:-webkit-box;overflow:hidden;-webkit-line-clamp:3;-webkit-box-orient:vertical;margin-bottom:1rem;color:#303846;line-height:1.45}
@media(max-width:991.98px){.signage-related-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.signage-related-media{height:250px}}
@media(max-width:575.98px){.signage-related-grid{grid-template-columns:1fr}.signage-related-media{height:230px}.signage-related-copy{padding:1.25rem}}


/* =========================================================
   V54 portfolio/project gallery lightbox
   ========================================================= */
.detail-gallery figure{margin:0}
.gallery-lightbox-trigger{
    position:relative;
    display:block;
    width:100%;
    padding:0;
    border:0;
    border-radius:16px;
    overflow:hidden;
    background:#0b1730;
    cursor:zoom-in;
}
.gallery-lightbox-trigger img{
    display:block;
    width:100%;
    height:280px;
    object-fit:cover;
    transition:transform .32s ease,filter .32s ease;
}
.gallery-lightbox-trigger:hover img,
.gallery-lightbox-trigger:focus-visible img{
    transform:scale(1.035);
    filter:brightness(.78);
}
.gallery-lightbox-icon{
    position:absolute;
    right:14px;
    bottom:14px;
    width:42px;
    height:42px;
    display:grid;
    place-items:center;
    border-radius:50%;
    color:#fff;
    background:rgba(7,20,44,.78);
    backdrop-filter:blur(8px);
    opacity:0;
    transform:translateY(8px);
    transition:opacity .24s ease,transform .24s ease;
}
.gallery-lightbox-trigger:hover .gallery-lightbox-icon,
.gallery-lightbox-trigger:focus-visible .gallery-lightbox-icon{
    opacity:1;
    transform:translateY(0);
}
.gallery-lightbox-trigger:focus-visible{
    outline:3px solid rgba(88,119,200,.65);
    outline-offset:3px;
}
.gallery-lightbox-modal .modal-content{
    position:relative;
    min-height:100vh;
    border:0;
    border-radius:0;
    background:rgba(4,10,22,.97);
    color:#fff;
    overflow:hidden;
}
.gallery-lightbox-stage{
    width:100%;
    min-height:100vh;
    padding:72px 88px 58px;
    display:flex;
    align-items:center;
    justify-content:center;
    flex-direction:column;
    gap:18px;
}
.gallery-lightbox-stage img{
    display:block;
    width:auto;
    max-width:min(1500px,calc(100vw - 190px));
    height:auto;
    max-height:calc(100vh - 150px);
    object-fit:contain;
    border-radius:14px;
    box-shadow:0 30px 80px rgba(0,0,0,.42);
}
.gallery-lightbox-close,
.gallery-lightbox-nav{
    position:absolute;
    z-index:3;
    border:1px solid rgba(255,255,255,.18);
    background:rgba(255,255,255,.08);
    color:#fff;
    backdrop-filter:blur(10px);
    transition:background .2s ease,transform .2s ease,border-color .2s ease;
}
.gallery-lightbox-close{
    top:22px;
    right:24px;
    width:48px;
    height:48px;
    border-radius:50%;
    display:grid;
    place-items:center;
    font-size:1.15rem;
}
.gallery-lightbox-nav{
    top:50%;
    width:56px;
    height:72px;
    display:grid;
    place-items:center;
    border-radius:16px;
    transform:translateY(-50%);
    font-size:1.55rem;
}
.gallery-lightbox-prev{left:22px}
.gallery-lightbox-next{right:22px}
.gallery-lightbox-close:hover,
.gallery-lightbox-nav:hover,
.gallery-lightbox-close:focus-visible,
.gallery-lightbox-nav:focus-visible{
    background:var(--primary);
    border-color:var(--primary);
    color:#fff;
}
.gallery-lightbox-nav:hover{transform:translateY(-50%) scale(1.04)}
.gallery-lightbox-meta{
    min-height:28px;
    color:rgba(255,255,255,.78);
    font-size:.85rem;
    letter-spacing:.08em;
}
.gallery-lightbox-nav[disabled]{
    opacity:.28;
    pointer-events:none;
}
@media(max-width:767.98px){
    .gallery-lightbox-trigger img{height:250px}
    .gallery-lightbox-stage{padding:74px 16px 88px}
    .gallery-lightbox-stage img{
        max-width:100%;
        max-height:calc(100vh - 190px);
        border-radius:10px;
    }
    .gallery-lightbox-nav{
        top:auto;
        bottom:18px;
        width:52px;
        height:52px;
        border-radius:50%;
        transform:none;
    }
    .gallery-lightbox-nav:hover{transform:scale(1.04)}
    .gallery-lightbox-prev{left:calc(50% - 64px)}
    .gallery-lightbox-next{right:calc(50% - 64px)}
    .gallery-lightbox-close{top:16px;right:16px}
}
@media(prefers-reduced-motion:reduce){
    .gallery-lightbox-trigger img,
    .gallery-lightbox-icon,
    .gallery-lightbox-nav,
    .gallery-lightbox-close{transition:none!important}
}

/* =========================================================
   V56 Renewable energy page
   ========================================================= */
.renewable-feature-visual,
.renewable-mast-image-wrap,
.renewable-project-image-wrap,
.renewable-wind-image-wrap {
    position: relative;
}

.renewable-feature-visual img,
.renewable-project-image-wrap img,
.renewable-wind-image-wrap img,
.renewable-mast-image-wrap img {
    width: 100%;
    display: block;
}

.renewable-visual-badge {
    position: absolute;
    left: 1.5rem;
    bottom: 1.5rem;
    background: rgba(8, 22, 48, 0.92);
    color: #fff;
    padding: 1rem 1.15rem;
    border-radius: 18px;
    box-shadow: 0 18px 45px rgba(10, 28, 60, 0.22);
}

.renewable-visual-badge strong,
.renewable-visual-badge span {
    display: block;
}

.renewable-visual-badge strong {
    font-size: 1rem;
    font-weight: 700;
    margin-bottom: 0.2rem;
}

.renewable-visual-badge span {
    font-size: 0.92rem;
    color: rgba(255,255,255,0.78);
}

.renewable-point-grid {
    display: grid;
    gap: 1rem;
    margin-top: 1.75rem;
}

.renewable-point-card {
    display: flex;
    align-items: flex-start;
    gap: 0.95rem;
    background: #fff;
    border: 1px solid rgba(58, 85, 158, 0.12);
    border-radius: 20px;
    padding: 1rem 1.1rem;
    box-shadow: 0 12px 34px rgba(10, 28, 60, 0.06);
}

.renewable-point-card i {
    font-size: 1.35rem;
    color: #3a559e;
    margin-top: 0.1rem;
}

.renewable-point-card strong,
.renewable-point-card span {
    display: block;
}

.renewable-point-card strong {
    font-size: 1rem;
    color: #081630;
    margin-bottom: 0.18rem;
}

.renewable-point-card span {
    color: #5b6478;
    line-height: 1.5;
}

.renewable-project-card,
.renewable-wind-card,
.renewable-brand-card,
.renewable-location-card {
    background: #fff;
    border: 1px solid rgba(58, 85, 158, 0.12);
    border-radius: 26px;
    overflow: hidden;
    box-shadow: 0 14px 40px rgba(10, 28, 60, 0.08);
}

.renewable-project-card {
    height: 100%;
}

.renewable-project-image-wrap img {
    aspect-ratio: 2 / 1;
    object-fit: cover;
}

.renewable-capacity-badge {
    position: absolute;
    left: 1rem;
    bottom: 1rem;
    display: inline-flex;
    align-items: center;
    padding: 0.55rem 0.9rem;
    border-radius: 999px;
    background: rgba(8, 22, 48, 0.9);
    color: #fff;
    font-size: 0.92rem;
    font-weight: 700;
    letter-spacing: 0.02em;
}

.renewable-project-content {
    padding: 1.35rem 1.35rem 1.5rem;
}

.renewable-project-content h3,
.renewable-wind-content h3 {
    margin-bottom: 0.7rem;
    color: #081630;
    font-size: 1.5rem;
}

.renewable-project-content p,
.renewable-wind-content p,
.renewable-location-card p {
    margin-bottom: 0;
    color: #5b6478;
    line-height: 1.65;
}

.renewable-brand-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 1.1rem;
}

.renewable-brand-card {
    min-height: 160px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}

.renewable-brand-card img {
    max-width: 100%;
    height: auto;
}

.renewable-wind-stack {
    display: grid;
    gap: 1.5rem;
}

.renewable-wind-card .row {
    --bs-gutter-x: 0;
}

.renewable-wind-card.is-featured .renewable-wind-image-wrap img {
    aspect-ratio: 1 / 1;
    object-fit: cover;
}

.renewable-wind-card:not(.is-featured) .renewable-wind-image-wrap img {
    aspect-ratio: 16 / 9;
    object-fit: cover;
}

.renewable-wind-content {
    padding: 1.6rem 1.6rem 1.8rem;
}

.renewable-meta-pill {
    display: inline-flex;
    align-items: center;
    margin-bottom: 0.9rem;
    padding: 0.45rem 0.8rem;
    border-radius: 999px;
    background: rgba(58, 85, 158, 0.1);
    color: #2d4a8f;
    font-size: 0.88rem;
    font-weight: 700;
}

.renewable-detail-list {
    margin: 1.1rem 0 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 0.7rem;
}

.renewable-detail-list li {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    color: #3b465d;
    line-height: 1.55;
}

.renewable-detail-list i {
    color: #3a559e;
    margin-top: 0.2rem;
    flex-shrink: 0;
}

.renewable-location-list {
    display: grid;
    gap: 1rem;
    margin: 1.5rem 0 1.2rem;
}

.renewable-location-card {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1.1rem 1.2rem;
}

.renewable-location-number {
    width: 54px;
    height: 54px;
    border-radius: 18px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #3a559e, #314989);
    color: #fff;
    font-weight: 700;
    letter-spacing: 0.02em;
    flex-shrink: 0;
}

.renewable-location-card strong {
    display: block;
    margin-bottom: 0.2rem;
    color: #081630;
}

.renewable-mast-note {
    display: flex;
    align-items: flex-start;
    gap: 0.85rem;
    padding: 1rem 1.1rem;
    border-radius: 20px;
    background: rgba(54, 75, 78, 0.08);
    color: #364b4e;
}

.renewable-mast-note i {
    color: #3a559e;
    font-size: 1.15rem;
    margin-top: 0.1rem;
}

@media (max-width: 1199.98px) {
    .renewable-brand-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 991.98px) {
    .renewable-feature-visual,
    .renewable-mast-image-wrap {
        margin-top: 0.5rem;
    }

    .renewable-wind-card.is-featured .renewable-wind-image-wrap img,
    .renewable-wind-card:not(.is-featured) .renewable-wind-image-wrap img {
        aspect-ratio: 16 / 10;
    }
}

@media (max-width: 767.98px) {
    .renewable-brand-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .renewable-project-content h3,
    .renewable-wind-content h3 {
        font-size: 1.26rem;
    }

    .renewable-wind-content,
    .renewable-project-content {
        padding: 1.2rem 1.15rem 1.35rem;
    }

    .renewable-visual-badge {
        position: static;
        margin-top: 1rem;
    }
}

/* =========================================================
   V57 Renewable wind project image fit refinement
   ========================================================= */
.renewable-wind-card .row{
    align-items:stretch;
}

.renewable-wind-card .row > [class*="col-"]{
    display:flex;
}

.renewable-wind-image-wrap{
    width:100%;
    height:100%;
    min-height:440px;
    overflow:hidden;
    background:#dfe6ef;
}

.renewable-wind-image-wrap img,
.renewable-wind-card.is-featured .renewable-wind-image-wrap img,
.renewable-wind-card:not(.is-featured) .renewable-wind-image-wrap img{
    width:100%;
    height:100%;
    min-height:440px;
    aspect-ratio:auto;
    object-fit:cover;
    object-position:center;
}

.renewable-wind-card:nth-child(2) .renewable-wind-image-wrap img{
    object-position:center 46%;
}

.renewable-wind-content{
    width:100%;
    display:flex;
    flex-direction:column;
    justify-content:center;
}

@media(max-width:1199.98px){
    .renewable-wind-image-wrap,
    .renewable-wind-image-wrap img,
    .renewable-wind-card.is-featured .renewable-wind-image-wrap img,
    .renewable-wind-card:not(.is-featured) .renewable-wind-image-wrap img{
        min-height:400px;
    }
}

@media(max-width:991.98px){
    .renewable-wind-card .row > [class*="col-"]{
        display:block;
    }

    .renewable-wind-image-wrap,
    .renewable-wind-image-wrap img,
    .renewable-wind-card.is-featured .renewable-wind-image-wrap img,
    .renewable-wind-card:not(.is-featured) .renewable-wind-image-wrap img{
        height:auto;
        min-height:0;
        aspect-ratio:16 / 10;
    }
}

@media(max-width:575.98px){
    .renewable-wind-image-wrap,
    .renewable-wind-image-wrap img,
    .renewable-wind-card.is-featured .renewable-wind-image-wrap img,
    .renewable-wind-card:not(.is-featured) .renewable-wind-image-wrap img{
        aspect-ratio:4 / 3;
    }
}


/* =========================================================
   V58 remove residual gap below wind project images
   ========================================================= */
@media(min-width:992px){
    .renewable-wind-card .row > [class*="col-"]{
        position:relative;
    }

    .renewable-wind-image-wrap{
        position:absolute;
        inset:0;
        min-height:0;
        height:auto;
    }

    .renewable-wind-image-wrap img,
    .renewable-wind-card.is-featured .renewable-wind-image-wrap img,
    .renewable-wind-card:not(.is-featured) .renewable-wind-image-wrap img{
        position:absolute;
        inset:0;
        width:100%;
        height:100%;
        min-height:0;
        display:block;
        object-fit:cover;
    }
}

@media(max-width:991.98px){
    .renewable-wind-card .row > [class*="col-"]{
        position:static;
    }

    .renewable-wind-image-wrap,
    .renewable-wind-image-wrap img,
    .renewable-wind-card.is-featured .renewable-wind-image-wrap img,
    .renewable-wind-card:not(.is-featured) .renewable-wind-image-wrap img{
        position:static;
        inset:auto;
    }
}


/* =========================================================
   V59 wind image visibility hotfix
   ========================================================= */
.renewable-wind-image-wrap > img[data-no-loader]{
    opacity:1 !important;
    filter:none !important;
    transform:none !important;
}

/* Defensive support if an older cached loader script already wrapped the image. */
@media(min-width:992px){
    .renewable-wind-image-wrap > .image-loader-shell{
        position:absolute;
        inset:0;
        width:100%;
        height:100%;
        max-width:none;
    }

    .renewable-wind-image-wrap > .image-loader-shell > img{
        position:absolute;
        inset:0;
        width:100%;
        height:100%;
        min-height:0;
        object-fit:cover;
        opacity:1;
        filter:none;
        transform:none;
    }
}

/* =========================================================
   V60 simplified premium footer
   ========================================================= */
.site-footer .footer-main{
    display:grid;
    grid-template-columns:minmax(250px,1.05fr) minmax(430px,1.75fr) minmax(240px,.95fr);
    gap:clamp(2rem,4vw,4.5rem);
    align-items:start;
    padding:58px 0 48px;
}

.footer-brand-column,
.footer-contact-column,
.footer-link-groups{
    min-width:0;
}

.footer-link-groups{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:clamp(1.3rem,2.3vw,2.4rem);
}

.footer-link-group h3,
.footer-contact-column h3{
    margin-bottom:1.05rem;
}

.site-footer .footer-link-group li{
    margin-bottom:.62rem;
}

.site-footer .footer-link-group a{
    display:inline-block;
    font-size:.86rem;
    line-height:1.42;
}

.footer-brand-column .footer-description{
    margin:1.35rem 0 1.25rem;
    max-width:340px;
    line-height:1.6;
}

.footer-contact-column{
    padding:1.35rem;
    border:1px solid rgba(255,255,255,.1);
    border-radius:18px;
    background:rgba(255,255,255,.04);
}

.footer-contact-column .contact-list{
    margin-bottom:1.15rem;
}

.footer-contact-column .contact-list li{
    margin-bottom:.9rem;
}

.footer-contact-link{
    display:inline-flex;
    align-items:center;
    gap:.45rem;
    color:#fff!important;
    font-size:.82rem;
    font-weight:600;
}

.footer-contact-link i{
    transition:transform .2s ease;
}

.footer-contact-link:hover i{
    transform:translateX(4px);
}

.footer-bottom{
    align-items:center;
}

@media(max-width:1199.98px){
    .site-footer .footer-main{
        grid-template-columns:minmax(240px,.9fr) minmax(480px,1.6fr);
    }

    .footer-contact-column{
        grid-column:1 / -1;
        display:grid;
        grid-template-columns:auto 1fr auto;
        gap:1.5rem;
        align-items:start;
    }

    .footer-contact-column h3{
        margin:0;
        padding-top:.35rem;
    }

    .footer-contact-column .contact-list{
        display:grid;
        grid-template-columns:repeat(2,minmax(0,1fr));
        gap:.85rem 1.5rem;
        margin:0;
    }

    .footer-contact-column .contact-list li{
        margin:0;
    }
}

@media(max-width:991.98px){
    .site-footer .footer-main{
        grid-template-columns:1fr;
        gap:2.4rem;
        padding:50px 0 42px;
    }

    .footer-brand-column .footer-description{
        max-width:560px;
    }

    .footer-contact-column{
        grid-column:auto;
    }
}

@media(max-width:767.98px){
    .footer-link-groups{
        grid-template-columns:repeat(2,minmax(0,1fr));
        gap:2rem 1.5rem;
    }

    .footer-link-group:last-child{
        grid-column:1 / -1;
    }

    .footer-contact-column{
        display:block;
    }

    .footer-contact-column h3{
        margin-bottom:1rem;
        padding:0;
    }

    .footer-contact-column .contact-list{
        display:block;
        margin-bottom:1rem;
    }

    .footer-contact-column .contact-list li{
        margin-bottom:.85rem;
    }
}

@media(max-width:575.98px){
    .footer-intro{
        padding:2.3rem 0 2rem;
        gap:1.35rem;
    }

    .footer-intro h2{
        font-size:1.45rem;
    }

    .footer-link-groups{
        grid-template-columns:1fr 1fr;
        gap:1.8rem 1.1rem;
    }

    .site-footer .footer-link-group a{
        font-size:.82rem;
    }

    .footer-bottom{
        gap:.75rem;
    }
}


/* V62 About page final statistics and CTA transition */
.about-stats-section{
    padding:70px 0 105px;
}
.about-stats-section .stat-item strong.stat-no-suffix::after{
    content:none;
}
.about-stats-section .about-stat-item span{
    max-width:190px;
    margin:.45rem auto 0;
    display:block;
}
.about-cta-section{
    position:relative;
    margin-top:-58px;
    padding:0 0 58px;
    background:linear-gradient(to bottom,transparent 0 58px,#f7f9fc 58px 100%);
}
.about-cta-box{
    position:relative;
    z-index:2;
    box-shadow:0 22px 55px rgba(15,31,67,.18);
}
.about-cta-section + .site-footer{
    margin-top:0;
}
@media(max-width:767.98px){
    .about-stats-section{padding:55px 0 82px}
    .about-cta-section{margin-top:-42px;padding-bottom:42px;background:linear-gradient(to bottom,transparent 0 42px,#f7f9fc 42px 100%)}
    .about-cta-box{padding:1.75rem}
}


/* V63 Shared managed website statistics */
.stat-item .managed-stat-value::after{content:none!important}
.managed-stat-value{display:flex!important;align-items:flex-start;justify-content:center;gap:2px}
.managed-stat-value>span{font-size:inherit!important;color:inherit!important;font-weight:inherit!important;line-height:inherit!important;margin:0!important;max-width:none!important}
.managed-stat-value small{font-size:1.18rem;line-height:1;font-weight:700;margin-top:.15rem;color:#fff}
@media(max-width:767.98px){.managed-stat-value small{font-size:.95rem}}

/* V65 client project directory */
.clients-table{min-width:1120px}.client-table-subtext{display:block;margin-top:.25rem;color:#667085;font-size:.76rem}.client-work-summary{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3;overflow:hidden;max-width:360px;line-height:1.5}@media(max-width:767.98px){.clients-table{min-width:0}.client-work-summary{max-width:none}}


/* V66 Managing Director profile */
.profile-portrait-image{padding:0;overflow:hidden;background:#eef2f8}
.profile-portrait-image img{width:100%;height:100%;min-height:560px;object-fit:cover;display:block}
.managing-director-name{margin-bottom:.65rem}
.managing-director-headline{font-size:1.15rem;line-height:1.45;color:#3a559e;font-weight:600;margin-bottom:1.25rem}
.managing-director-bio{line-height:1.7;color:#1f2937;margin-bottom:1.25rem}
@media(max-width:767.98px){.profile-portrait-image img{min-height:420px}.managing-director-headline{font-size:1.05rem}}


/* =========================================================
   V68 image-led service cards and rich service content
   ========================================================= */
.services-listing-section .service-image-card,
.homepage-services-section .service-image-card{
    padding:0;
    overflow:hidden;
    display:flex;
    flex-direction:column;
}

.service-card-image{
    position:relative;
    display:block;
    width:100%;
    aspect-ratio:16 / 10;
    overflow:hidden;
    background:#e9eef5;
}

.service-card-image img{
    width:100%;
    height:100%;
    object-fit:cover;
    transition:transform .45s ease;
}

.service-image-card:hover .service-card-image img{
    transform:scale(1.045);
}

.service-card-body{
    display:flex;
    flex:1;
    flex-direction:column;
    padding:1.45rem 1.45rem 1.55rem;
}

.service-card-body h3{
    margin:0 0 .7rem;
    font-size:1.2rem;
    line-height:1.25;
}

.service-card-body p{
    margin:0 0 1.2rem;
    color:#4f5a6e;
    line-height:1.55;
}

.service-card-body .text-link{
    margin-top:auto;
}

.detail-rich-content > p{
    margin:0 0 1.15rem;
    line-height:1.7;
}

.detail-rich-content > p:last-child{
    margin-bottom:0;
}

.detail-rich-content ul,
.detail-rich-content ol{
    margin-bottom:1.25rem;
}

@media(max-width:767.98px){
    .service-card-image{aspect-ratio:16 / 9}
    .service-card-body{padding:1.2rem 1.15rem 1.3rem}
}


/* V70 homepage image-led services */
.homepage-services-section .service-image-card{
    min-height:100%;
}
.homepage-services-section .service-card-image{
    aspect-ratio:16 / 10;
}
.homepage-services-section .service-card-body p{
    display:-webkit-box;
    -webkit-box-orient:vertical;
    -webkit-line-clamp:3;
    overflow:hidden;
}

/* =========================================================
   V76 quotation popup scrolling fix
   ========================================================= */
.quote-modal .modal-dialog{
    width:min(980px, calc(100% - 2rem));
    max-height:calc(100dvh - 2rem);
    margin:1rem auto;
}

.quote-modal .quote-modal-content{
    max-height:calc(100dvh - 2rem);
    min-height:0;
    overflow:hidden;
}

.quote-modal .quote-modal-visual,
.quote-modal .quote-modal-form-wrap{
    min-height:0;
}

.quote-modal .quote-modal-form-wrap{
    max-height:calc(100dvh - 2rem);
    overflow-y:auto;
    overscroll-behavior:contain;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:thin;
    scrollbar-color:rgba(58,85,158,.45) transparent;
}

.quote-modal .quote-modal-form-wrap::-webkit-scrollbar{
    width:8px;
}

.quote-modal .quote-modal-form-wrap::-webkit-scrollbar-track{
    background:transparent;
}

.quote-modal .quote-modal-form-wrap::-webkit-scrollbar-thumb{
    background:rgba(58,85,158,.4);
    border-radius:999px;
}

.quote-modal .quote-modal-close{
    position:sticky;
    top:0;
    float:right;
    margin-top:-1.85rem;
    margin-right:-1.4rem;
    background-color:#fff;
    box-shadow:0 8px 24px rgba(8,22,48,.14);
}

@media(max-width:767.98px){
    .quote-modal .modal-dialog{
        width:auto;
        max-height:calc(100dvh - 1rem);
        margin:.5rem;
        align-items:flex-start;
    }

    .quote-modal .quote-modal-content{
        display:flex;
        flex-direction:column;
        max-height:calc(100dvh - 1rem);
        overflow-y:auto;
        overscroll-behavior:contain;
        -webkit-overflow-scrolling:touch;
    }

    .quote-modal .quote-modal-visual{
        flex:0 0 auto;
        min-height:180px;
    }

    .quote-modal .quote-modal-copy{
        min-height:180px;
        padding:1.6rem 1.35rem;
    }

    .quote-modal .quote-modal-form-wrap{
        max-height:none;
        overflow:visible;
        flex:0 0 auto;
        padding:2.4rem 1.2rem 1.35rem;
    }

    .quote-modal .quote-modal-close{
        position:sticky;
        top:.65rem;
        z-index:5;
        margin-top:-1.65rem;
        margin-right:-.45rem;
    }

    .quote-modal .quote-submit-btn{
        min-height:50px;
    }
}

@media(max-height:700px) and (min-width:768px){
    .quote-modal .quote-modal-copy{
        min-height:560px;
        padding:2.2rem 2rem;
    }

    .quote-modal .quote-modal-form-wrap{
        padding:2.3rem 2rem;
    }
}
