:root {
     /* Core Governance Palette */
  --primary-color: #1A202C;        /* Midnight Slate – governance, security */
  --secondary-color: #F7FAFC;      /* Slate Light – clean background */

  /* Sustainability & Responsibility */
  --emotive-green: #4A7C59;        /* Sage Green – Green IT, sustainability */
  --emotive-sky: #2E3A44;          /* Muted slate blue-grey */

  /* Legacy & Trust */
  --accent-color: #B7942E;         /* Burnished Gold – legacy value */
  --rating-color: #B7942E;

  /* Headings (Authoritative Ink) */
  --heading-color-1: #1A202C;      /* Primary heading */
  --heading-color-2: #2D3748;      /* Secondary heading */
  --heading-color-3: #EDF2F7;      /* Soft highlight panels */

  /* Text System */
  --text-color: #1F2933;           /* Primary readable text */
  --text-color-1: #FFFFFF;         /* Text on dark backgrounds */
  --text-color-2: #4A5568;         /* Muted paragraph text */

  /* Borders & Structure */
  --border-color: #CBD5E0;

  /* Transparency */
  --transparent-color-1: #00000000;

  /* Overlays (Authority + Depth) */
  --overlay-color: rgba(26, 32, 44, 0.65);
  --overlay-color-2: rgba(26, 32, 44, 0.35);

  /* Forms */
  --bg-form: #FFFFFF;
    --font: "Outfit", sans-serif;
    --button-icon-size: 62px;
    --md-button-icon-size: 45px;
    --btn-icon-arrow: 30px;
    --icon-qoute-size: 70px;
    --text-big: 30px;
    --text-huge: 200px;
    --text-small-huge: 150px;
    --text-5xl: 100px;
    --text-4xl: 56px;
    --text-3xl: 40px;
    --text-2xl: 26px;
    --text-xl: 20px;
    --text-base: 18px;
    --md-text-5xl: 80px;
    --md-text-4xl: 40px;
    --md-text-3xl: 28px;
    --md-text-2xl: 23px;
    --md-text-xl: 18px;
    --md-text-base: 16px;
    --sm-text-5xl: 61px;
    --sm-text-4xl: 27px;
    --sm-text-3xl: 23px;
    --sm-text-2xl: 20px;
    --sm-text-xl: 16px;
    --sm-text-base: 14px;
    --leading-short: 0.8em;
    --leading-small: 1em;
    --leading-medium: 1.35em;
    --leading-normal: 1.55em
}

.bg-section-1{
    background: linear-gradient(180deg, #EDF2F7, #F7FAFC);
  }
  
  .bg-section-2{
    background: linear-gradient(180deg, #F7FAFC, #edf2f6);
  }
  
  .bg-section-3{
    background: linear-gradient(180deg, #E6EBF1, #F7FAFC);
  }
  
  .page-heading{
    padding-top: 10vw !important;
    background: linear-gradient(180deg, #1a202c75, #f7fafc);
  }

  .bg-section-4{
    background: linear-gradient(180deg, #f1f7fb, #f3f7f9, #c9d3d7);
  }

  .bg-4{
    background-color: #eef2f6;
  }

  @media (max-width: 767px) {
    /* Target the slider wrapper */
    .hero-slider,
    .hero-slider .slides,
    .hero-slider .slide {
      width: 100% !important;
      max-width: 100% !important;
      margin: 0 auto !important;
      padding: 0 !important;
    }
  
    /* Optional: reduce padding so content aligns */
    .hero-slider .slide-content,
    .hero-slider .hero-text {
      padding-left: 15px !important;
      padding-right: 15px !important;
      text-align: center !important;
    }
  }

.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 80px 24px
}

.hero {
    background: var(--primary-color);
    color: #fff
}

.hero img {
    width: 100%;
    height: auto;
    object-fit: cover
}

h1 {
    font-size: clamp(2.6rem, 4vw, 3.6rem);
    font-weight: 600;
    letter-spacing: -.02em
}

h2 {
    font-size: 2.2rem;
    font-weight: 500;
    margin-bottom: 20px
}

h3 {
    font-size: 1.2rem;
    font-weight: 500
}

p {
    font-size: 1rem;
    line-height: 1.55;
    color: var(--text-color-1)
}

.section--research {
    background: #fff
}

.btn-primary {
    display: inline-block;
    margin-top: 24px;
    padding: 14px 32px;
    background: var(--accent-color);
    color: var(--primary-color);
    font-weight: 500;
    text-decoration: none;
    border-radius: 2px
}

.btn-primary:hover {
    background: #b79d46
}

h1 {
    font-size: 3.2rem
}

h2 {
    font-size: 2.4rem
}

h3 {
    font-size: 1.8rem
}

li,
p {
    font-size: 1rem;
    line-height: 1.55
}

body,
li,
p {
    line-height: 1.4;
    letter-spacing: .2px
}

body {
    background-color: var(--secondary-color);
    color: var(--text-color)
}

li,
p {
    color: var(--text-color-2)
}

a {
    color: var(--heading-color-1)
}

h1,
h2,
h3 {
    color: var(--heading-color-1)
}

h2,
h3 {
    color: var(--heading-color-2)
}

.btn-primary,
.cta-button {
    background-color: var(--accent-color);
    color: var(--primary-color);
    border: none
}

.btn-primary:hover {
    background-color: #b79d46
}

h1 {
    font-size: 100px;
    font-weight: 500;
    line-height: var(--text-5xl)
}

.heading-2,
h2 {
    font-size: 29px;
    font-weight: 300;
    line-height: var(--leading-medium);
}

h3 {
    font-size: 23px;
    font-weight: 300
}

h4 {
    font-size: 26px;
    font-weight: 300
}

h5 {
    font-size: 20px;
    font-weight: 300
}

h6 {
    font-size: 18px;
    font-weight: 400;
    line-height: 27px;
    letter-spacing: 1px
}

li,
p {
    font-size: 16px;
    font-weight: 300;
    letter-spacing: 1px
}

a {
    color: var(--heading-color-1);
    text-decoration: none
}

body {
    font-family: var(--font);
    font-size: var(--text-base);
    color: var(--text-color);
    background-color: var(--secondary-color)
}

.b-container {
    max-width: 1350px;
    margin-right: auto;
    margin-left: auto
}

.section {
    padding: 63px 20px 63px 20px;
    overflow: hidden;
    background-size: cover;
    background-position: center
}

.bg-heading-color-1 {
    background-color: #f6f4f2 !important;
    /*background:linear-gradient(183deg, #d0d3fcb5, #c7c2c569);
    backdrop-filter: blur(15px);*/
}

.bg-heading-color-2 {
    background-color: #f1efeb !important;
    /*background: linear-gradient(181deg, #d1e2f470, #b6bdd870);
    backdrop-filter: blur(15px);*/
}

.bg-heading-color-3 {
    background-color: rgb(237 242 247 / 35%);
    background: linear-gradient(178deg, #E3F2FD, #ffffff00);
}

.bg-secondary-color {
    background-color: var(--secondary-color) !important
}

.bg-accent-color {
    background-color: var(--accent-color) !important
}

.bg-heading{
    background: #edf2f7;
}

.text-primary-color {
    color: var(--primary-color) !important
}

.text-secondary-color {
    color: var(--secondary-color) !important
}

.text-heading-color-1 {
    color: var(--heading-color-1) !important
}

.text-heading-color-2 {
    color: var(--text-color-2) !important
}

.text-heading-color-3 {
    color: var(--heading-color-3) !important
}

.text-heading-color-4 {
    color: var(--emotive-green) !important
}

.text-color-1 {
    color: var(--text-color-1) !important
}

.header {
    position: relative;
    margin-bottom: -100px;
    z-index: 999;
    padding: 0 8px
}

.header-logo {
    max-width: 175px
}

.home-hero {
    height: 100vh;
    max-height: 890px;
    overflow: hidden
}

.home-hero h1 {
    max-width: 540px;
    font-size: 72px;
    line-height: 82px;
    letter-spacing: 2px;
}

.home-hero .spacer-bottom-right {
    position: relative;
    left: -12px;
    margin-left: -30px
}

.home-hero .spacer-bottom-left {
    position: relative;
    right: -12px
}

.hero-desc {
    max-width: 410px;
    margin-top: -45px;
    margin-bottom: 45px;
}

.hero-content {
    max-width: 630px;
    padding: 15px 15px 0 15px;
    background-color: var(--heading-color-3);
    border-radius: 25px 25px 0 0
}

.hero-content img {
    height: 210px
}

.hero-content h5 {
    padding: 0 10px 10px 0;
    border-bottom-right-radius: 10px
}

.kb-bg {
    z-index: 0
}

.kb-carousel {
    overflow: hidden;
    height: 100%;
    max-height: none
}

.kb-carousel .carousel-item {
    transition: transform .6s ease-in-out 0s, opacity ease-in-out .6s
}

.kb-carousel .carousel-item.active {
    transition: transform .6s ease-in-out 0s, opacity ease-in-out .6s
}

.kb-carousel>.carousel-inner>.carousel-item>a>img,
.kb-carousel>.carousel-inner>.carousel-item>img {
    opacity: .8;
    width: 100%;
    height: 100vh;
    object-fit: cover;
    animation: kenburns 20s linear 0s infinite alternate
}

.social-media {
    position: absolute;
    bottom: 180px;
    left: 50px;
    transform: rotateZ(90deg);
    width: 100%;
    min-width: 275px;
    gap: 20px
}

.border-top-color>.b-container {
    border-top: 1px solid #6d97c6;
}

.border-right-color {
    border-right: 1px solid var(--heading-color-1)
}

.desc-wrapper {
    border-top-left-radius: 25px;
    border-top-right-radius: 25px;
    background-color: var(--secondary-color);
    padding: 30px
}

.img-background {
    background-position: center center;
    background-size: cover
}

@keyframes kenburns {
    0% {
        transform: scale(1);
        transition: transform 20s linear 0s
    }
    100% {
        transform: scale(1.4);
        transition: transform 20s linear 0s
    }
}

@keyframes button-ripple {
    70% {
        -webkit-box-shadow: 0 0 0 var(--glow-size, 34px) var(--heading-color-1);
        box-shadow: 0 0 0 var(--glow-size, 34px) var(--heading-color-1);
        opacity: 0
    }
    100% {
        -webkit-box-shadow: 0 0 0 0 var(--heading-color-1);
        box-shadow: 0 0 0 0 var(--heading-color-1);
        opacity: 0
    }
}

.fade.fade-right {
    opacity: 0;
    transform: translateX(20vw);
    transition: opacity .3s ease, transform .8s ease
}

.fade.fade-right.show {
    opacity: 1;
    transform: translateX(0)
}

@media (prefers-reduced-motion:reduce) {
    .fade.fade-right {
        transition: none
    }
}

.nav-link {
    font-size: var(--text-base);
    font-weight: 500;
    color: var(--primary-color)
}

.nav-link:focus,
.nav-link:hover {
    color: var(--text-color) !important
}

.nav-link.active {
    color: var(--emotive-green) !important
}

.nav.nav-pills .nav-item {
    width: 100%;
    border-bottom: 1px solid var(--heading-color-2)
}

.navbar-toggler {
    border-radius: 10px;
    padding: 10px 10px
}

.navbar-toggler-icon {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3E%3Cpath stroke='%231A202C' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E") !important;
    width: 23px;
    height: 23px;
}

.btn-close:focus,
.navbar-toggler:focus {
    box-shadow: none
}

.nav-pills .nav-link {
    padding: 5px 0;
    font-size: var(--text-4xl);
    font-weight: 500;
    letter-spacing: 1px;
    text-align: end
}

.nav-pills .nav-link.active {
    background-color: #fff0;
    color: var(--secondary-color)
}

.tab-content>.active {
    display: flex;
    justify-content: flex-end
}

.tab-content .service-box img {
    max-height: 500px;
    min-height: 500px
}

.tab-content .service-box .bg-overlay-2 {
    border-radius: 16px
}

.service-box {
    position: relative;
    background-color: var(--secondary-color);
    width: 100%;
    height: 100%;
    min-height: 515px;
    border-radius: 25px;
    transition: all 0.3s ease
}

.service-box>img {
    border-radius: 25px;
    object-fit: cover;
    object-position: center
}

.service-box:hover .service-wrap {
    transform: translateY(0)
}

.service-box .bg-overlay-2 {
    border-radius: 25px
}

.service-content {
    display: flex;
    align-items: flex-end;
    position: absolute;
    bottom: 0;
    left: 0;
    overflow: hidden;
    padding: 27px;
    width: 100%;
    height: 100%;
    min-height: 440px;
    z-index: 2
}

.service-content h4 {
    color: var(--secondary-color)
}

.service-content p {
    color: var(--text-color-3)
}

.service-info {
    overflow: hidden
}

.service-wrap {
    transform: translateY(40px);
    transition: all 0.3s ease
}

.tab-content .service-box img {
    max-height: 500px;
    min-height: 500px
}

.tab-content .service-box .bg-overlay-2 {
    border-radius: 16px
}

.project.service-box {
    min-height: 270px;
    max-height: 270px;
}

.project.service-box .bg-overlay-3 {
    border-radius: 25px
}

.project.service-box .spacer-top-left,
.why-box.project .spacer-top-left {
    box-shadow: -10px -10px 0 0 var(--secondary-color)
}

.project.service-box h6,
.why-box.project h6 {
    border-bottom-right-radius: 10px;
    padding-right: 15px;
    padding-left: 10px
}

.project.service-box .service-content {
    min-height: 400px
}



.btn-cta-primary {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: #fff
}

.btn-icon {
    width: 1.1em;
    height: 1.1em;
    flex-shrink: 0;
    fill: currentColor;
    transition: transform 0.3s ease
}

.btn-cta-primary:hover .btn-icon {
    transform: translateX(6px)
}

.btn-cta-primary {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 40px;
    background-color: #f6f4f214;
    color: var(--text-color-2);
    border: 1px solid #ffffff45;
    padding: 5px;
    font-size: var(--text-base);
    line-height: var(--leading-normal);
    border-radius: 18px;
    font-weight: 300;
    transition: .3s
}

.btn-cta-primary:hover {
    color: var(--text-color-1);
    transform: scale(.95)
}

.btn-cta-primary:hover .btn-icon-primary {
    transform: rotate(360deg)
}

.btn-cta-primary .btn-text {
    padding: 20px
}

.btn-cta-primary .btn-icon-primary {
    transform: rotate(320deg);
    transition: .3s
}



.btn-cta-secondary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background-color: var(--transparent-1-color);
    color: var(--heading-color-1);
    border: none;
    font-weight: 500;
    transition: .3s
}

.btn-cta-secondary .bi-arrow-right-short::before {
    font-size: var(--btn-icon-arrow)
}

.btn-cta-secondary:hover {
    color: var(--accent-color)
}

.btn-cta-form {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background-color: var(--heading-color-1);
    color: var(--heading-color-3);
    border: none;
    border-radius: 100px;
    font-weight: 500;
    font-size: var(--text-base);
    padding: 19px 20px;
    transition: .3s
}

.btn-cta-form:hover {
    background-color: var(--heading-color-3);
    color: var(--accent-color)
}

.offcanvas-header .btn-close {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%231A202C'%3E%3Cpath d='M.293.293a1 1 0 0 1 1.414 0L8 6.586 14.293.293a1 1 0 1 1 1.414 1.414L9.414 8l6.293 6.293a1 1 0 0 1-1.414 1.414L8 9.414l-6.293 6.293a1 1 0 0 1-1.414-1.414L6.586 8 .293 1.707a1 1 0 0 1 0-1.414z'/%3E%3C/svg%3E") !important;
    opacity: 1;
    border-radius: 10px;
    padding: 14px;
    margin-right: 0
}

.btn-cta-primary .btn-icon-primary {
    
    fill: var(--heading-color-1)
}

.bg-tranparent {
    border: 1px solid var(--heading-color-1);
    background: #fff0
}

.bg-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgb(237 242 247 / 35%);
    background: linear-gradient(178deg, #E3F2FD, #ffffff00);
    opacity: 1;
    z-index: 1;
    transition: all .3s ease
}

.bg-overlay-2 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-image: linear-gradient(180deg, var(--transparent-color-1) 0, var(--overlay-color) 100%);
    z-index: 1;
    opacity: .8
}

.bg-overlay-3 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-image: linear-gradient(180deg, #f7fafcc9 0, var(--heading-color-3) 100%);
    z-index: 1;
    opacity: .9;
    backdrop-filter: blur(15px)
}

.bg-overlay-4 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: var(--heading-color-1);
    background: linear-gradient(180deg, #eef2f6, #E3F2FD);
    opacity: .8;
    transition: all .3s ease
}

.bg-overlay-5 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: var(--overlay-color);
    opacity: .6;
    transition: all .3s ease
}

.bg-overlay-6 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: var(--heading-color-3);
    opacity: .5;
    transition: all .3s ease
}

.object-cover {
    object-fit: cover;
    object-position: center
}

.spacer-top-left {
    width: 30px;
    height: 30px;
    border-radius: 10px 0 0 0;
    box-shadow: -10px -10px 0 0 var(--heading-color-3)
}

.spacer-top-left-25 {
    width: 50px;
    height: 50px;
    border-radius: 25px 0 0 0;
    box-shadow: -10px -10px 0 0 var(--secondary-color)
}

.spacer-top-right-25 {
    width: 50px;
    height: 50px;
    border-radius: 0 25px 0 0;
    box-shadow: 10px -10px 0 0 var(--secondary-color)
}

.spacer-special-left {
    margin-left: -12px;
    margin-top: 23px
}

.spacer-special-right {
    margin-right: -12px;
    margin-top: 23px
}

.spacer-top-left-25 {
    width: 50px;
    height: 50px;
    border-radius: 25px 0 0 0;
    box-shadow: -10px -10px 0 0 var(--secondary-color)
}

.spacer-bottom-right {
    width: 40px;
    height: 40px;
    border-radius: 0 0 25px 0;
    box-shadow: 10px 10px 0 0 var(--heading-color-3)
}

.spacer-bottom-left {
    width: 40px;
    height: 40px;
    border-radius: 0 0 0 25px;
    box-shadow: -10px 10px 0 0 var(--heading-color-3)
}

.spacer-bottom-left-50 {
    width: 50px;
    height: 50px;
    border-radius: 0 0 0 25px;
    box-shadow: -10px 10px 0 0 var(--heading-color-3)
}

.spacer-bottom-right-40 {
    width: 40px;
    height: 40px;
    border-radius: 0 0 25px 0;
    box-shadow: 10px 10px 0 0 var(--heading-color-3)
}

.spacer-bottom-left-30 {
    width: 30px;
    height: 30px;
    border-radius: 0 0 0 15px;
    box-shadow: -10px 10px 0 0 var(--secondary-color)
}

.spacer-bottom-right-30 {
    width: 30px;
    height: 30px;
    border-radius: 0 0 15px 0;
    box-shadow: 10px 10px 0 0 var(--secondary-color)
}

.spacer-bottom-right-50 {
    width: 50px;
    height: 50px;
    border-radius: 0 0 25px 0;
    box-shadow: 10px 10px 0 0 var(--secondary-color)
}

.spacer-80 {
    width: 100%;
    height: 80px
}

.from-right {
    transform: translate3d(50vw, 0, 0)
}

.from-left {
    transform: translate3d(-50vw, 0, 0)
}

.rounded-6 {
    border-radius: 25px
}

.rounded-100 {
    border-radius: 100px
}

.padding-10 {
    padding: 10px
}

.padding-20 {
    padding: 20px
}

.padding-30 {
    padding: 30px
}

.padding-50 {
    padding: 50px
}

.gap-100 {
    gap: 100px 0
}

.w-49 {
    width: 49%
}

.w-51 {
    width: 51% !important
}

.mb-n90 {
    margin-bottom: -90px
}

.border-color {
    border: 5px solid var(--heading-color-1)
}

.home-hero {
    padding: 170px 8px 0 8px
}

section.hero-banner {
    padding-top: 245px;
    padding-bottom: 0;
    background-position: center center
}

section.about-us .bg-overlay-6 {
    border-radius: 100px
}

section.about-us,
section.who {
    padding-bottom: 110px
}

.why-box {
    display: flex;
    flex-direction: column;
    gap: 30px;
    position: relative;
    width: 100%;
    height: 100%;
    padding: 30px;
    border: 1px solid var(--heading-color-1);
    border-radius: 25px;
    transition: all .3s ease
}

.value-box {
    display: flex;
    flex-direction: column;
    gap: 1px;
    position: relative;
    width: 100%;
    height: 100%;
    padding: 9px 9px;
    border: 1px solid #1a202c2e;
    border-radius: 25px;
    transition: all .3s ease;
}

.no-border{
    border: 0;
}

.why-box:hover .why-wrap {
    transform: translateY(0)
}

.why-box.special .why-wrap {
    transform: translateY(0)
}

.value-box:hover .value-wrap {
    transform: translateY(0)
}

.value-box.special .value-wrap {
    transform: translateY(0)
}

.why-box img {
    width: 50px;
    height: 50px
}

.why-content {
    overflow: hidden
}

.why-wrap {
    display: flex;
    flex-direction: column;
    gap: 20px;
    transform: translateY(60px);
    transition: .6s
}

.value-wrap {
    display: flex;
    flex-direction: column;
    gap: 9px;
    transform: translateY(60px);
    transition: .6s
}

.icon-wrapper {
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    width: 75px;
    height: 75px;
    border-radius: 50%;
    background-color: var(--heading-color-1)
}

.impact-box {
    position: relative;
    max-width: 430px
}

.impact-box img {
    min-height: 430px;
    object-fit: cover;
    object-position: center
}

.impact-wrapper {
    position: absolute;
    bottom: 0;
    left: 0
}

.impact-content {
    padding: 20px 20px 0 0;
    border-top-right-radius: 25px;
    width: 100%;
    background-color: var(--heading-color-3)
}

.border-primary-color {
    border: 1px solid var(--heading-color-2)
}

.border-secondary-color {
    border: 1px solid var(--heading-color-1)
}

.border-text-color {
    border: 1px solid var(--text-color-1)
}

.border-top-primary {
    border-top: 1px solid var(--text-color-1);
    opacity: 1
}

.border-top-secondary {
    border-top: 1px solid var(--heading-color-2);
    opacity: 1
}

.footer {
    background-color: var(--heading-color-1);
    padding: 0 20px;
    background: linear-gradient(181deg, #c4ccd0, #E3F2FD);
}

.footer a {
    transition: .3s
}

.footer a:hover {
    color: var(--secondary-color)
}

.footer>.b-container {
    padding: 120px 0
}

.footer-logo-box img {
    max-width: 226px
}

.icon-contact,
.icon-social {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    border-radius: 100px;
    background-color: var(--heading-color-2);
    color: var(--heading-color-1);
    transition: .3s
}

.icon-contact {
    width: 70px;
    height: 70px
}

.icon-social {
    width: 30px;
    height: 30px;
    font-size: 14px
}

.icon-social:hover {
    background-color: var(--heading-color-1)
}

.icon-social:hover {
    color: var(--heading-color-3)
}

.footer-rights {
    font-weight: 300
}

.footer-terms a {
    font-weight: 300;
    transition: .3s
}

.footer-terms a:hover {
    color: var(--text-color-2) !important
}

.form {
    margin-top: 40px;
    background-color: #ffffff0d;
    backdrop-filter: blur(5px);
    padding: 10px;
    border-radius: 35px
}

.form label {
    font-size: 18px;
    font-weight: 500;
    display: none
}

.form input,
.form textarea {
    background-color: #f6f4f221;
    color: var(--text-color-2);
    backdrop-filter: blur(15px);
    border-radius: 18px;
    outline: 0;
    padding: 20px;
    font-size: 16px;
    font-weight: 300;
    border: none
}

.form input div::placeholder {
    color: var(--text-color)
}

.form textarea {
    max-height: 207px;
    border-radius: 30px
}

.form input:focus,
.form textarea:focus {
    box-shadow: none;
    border: solid 2px var(--accent-color-2);
    background-color: var(--bg-form);
    color: var(--text-color);
    border: none
}

.form input::placeholder,
.form textarea::placeholder {
    color: var(--placeholder-color);
    font-size: 14px
}

@media only screen and (max-width:1199.98px) {
    h1 {
        font-size: 80px;
        line-height: var(--leading-small)
    }
    .heading-2,
    h2 {
        font-size: 40px
    }
    h3 {
        font-size: 28px
    }
    h4 {
        font-size: 23px
    }
    h5 {
        font-size: 18px
    }
    h6 {
        font-size: 16px
    }
    a,
    li,
    p {
        font-size: 16px
    }
    .btn-cta-primary {
        font-size: var(--md-text-base)
    }
    .btn-cta-primary .btn-text {
        padding: 14px
    }
    .btn-cta-primary .btn-icon-primary:before {
        font-size: var(--md-button-icon-size)
    }
    .home-hero .spacer-bottom-right {
        margin-left: 0;
        width: 0;
        height: 0;
    }
    
    .home-hero .spacer-bottom-left {
        margin-right: 0;
        width: 0;
        height: 0;
    }
    .hero-content {
        max-width: 89%
    }
    .nav-pills .nav-link {
        font-size: var(--text-3xl)
    }
    .impact-box img {
        min-height: 500px
    }
}

@media only screen and (min-width:991.98px) {
    .navbar-nav .nav-link {
        padding-top: 32px;
        padding-bottom: 32px
    }
}

@media only screen and (max-width:991.98px) {
    .navbar-nav {
        width: 100%
    }
}

@media only screen and (max-width:768.98px) {
    .page-heading {
        padding-top: 27vw !important;
    }

    

    .home-hero .h-100{
        height: auto !important;
    }

    .home-hero .w-100{
        width: auto;
    }

    .home-hero{
        height: 100% !important;
        padding: 108px 8px 0 8px;
    }

    

    h1 {
        font-size: 27px;
        letter-spacing: 2px;
        line-height: 36px
    }
    .header-logo {
        max-width: 72px
    }

    .section{
        padding: 18px;
    }

    .form input, .form textarea{
        font-size: 18px;
        line-height: 24px;
    }

    .form-msg{
        padding: 0;
    }

    .heading-2,
    h2 {
        font-size: 18px;
        letter-spacing: 1px;
        line-height: 1.5
    }
    h3 {
        font-size: 18px;
        letter-spacing: 1px;
        line-height: 1.5;
        font-weight: 300;
    }
    h4 {
        font-size: 18px;
        letter-spacing: 1px
    }
    h5 {
        font-size: 18px;
        letter-spacing: 1px
    }
    h6 {
        font-size: 18px;
        letter-spacing: 1px
    }
    a,
    li,
    p {
        font-size: 18px;
        line-height: 24px;
        
    }
    .btn-cta-primary {
        font-size: var(--sm-text-base)
    }
    .home-hero h1 {
        max-width: 100%;
        font-size: 24px;
        line-height: 37px;
        letter-spacing: 1px;
    }

    .home-hero{
        background: #edf2f7;
    }

    .home-hero .overflow-hidden{
        overflow: scroll !important;
    }

    .hero-desc {
        margin-top: 0;
        max-width: 100%;
        margin-bottom: 11px
    }
    .hero-content {
        max-width: 110%;
        padding: 9px 9px 9px 9px;
        margin-bottom: 18px;
        border-radius: 25px 25px 25px 25px;
    }
    .w-49 {
        width: 100%
    }
    .w-51 {
        width: 100% !important
    }
    .mb-n90 {
        margin-bottom: 0
    }
    .impact-box {
        max-width: 100%
    }
    .nav-pills .nav-item {
        padding: 20px 0
    }
    .nav-pills .nav-link,
    .nav.nav-pills {
        width: 100%
    }
    .nav-pills .nav-link {
        font-size: var(--sm-text-4xl)
    }
    .list-people {
        order: -9999;
        width: 100%
    }
    .section.hero-banner .border-right-color {
        border: none
    }
}

.cookie-banner {
    position: fixed;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    width: calc(100% - 40px);
    max-width: 1200px;
    padding: 18px;
    backdrop-filter: blur(90px);
    border-radius: 25px;
    border: 1px solid var(--heading-color-1);
    color: var(--text-color);
    z-index: 9999;
    animation: slideUp .4s ease-out;
    background: #f6f4f2;
}

.cookie-content {
    max-width: 100%
}

.cookie-content h5 {
    color: var(--heading-color-1);
    margin-bottom: 10px
}

.cookie-content p {
    color: var(--text-color);
    font-size: 18px;
    line-height: var(--leading-medium);
    font-weight: 200
}

.cookie-actions {
    display: flex;
    gap: 12px;
    margin-top: 20px;
    flex-wrap: wrap
}

.cookie-btn {
    padding: 5px 9px;
    border-radius: 25px;
    font-size: 14px;
    font-weight: 400;
    cursor: pointer;
    transition: .3s;
    border: none
}

.cookie-btn.accept {
    background-color: var(--heading-color-2);
    color: var(--heading-color-3)
}

.cookie-btn.accept:hover {
    transform: scale(.95)
}

.cookie-btn.reject {
    background-color: #fff0;
    border: 1px solid var(--heading-color-2);
    color: var(--heading-color)
}

.cookie-btn.manage {
    background-color: var(--heading-color-3);
    color: var(--heading-color-1)
}

/* ===============================
COOKIE MODAL WRAPPER (UTG FIX)
=============================== */

.cookie-modal {
    position: fixed;
    inset: 0;
    z-index: 10000;
  
    background: rgba(15, 23, 42, 0.35);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
  
    /* CENTERING + SAFE GUTTERS */
    display: none;
    align-items: flex-start;
    justify-content: center;
  
    padding: 20px; /* ← side spacing */
    overflow-y: auto;
  }
  
  .cookie-modal.active {
    display: flex;
  }
  

/* ===============================
MODAL BOX RESPONSIVE FIX
=============================== */

.modal-content {

    width: 100%;
    max-width: 560px;
  
    margin-top: 8vh;
  
    padding: 30px;
  
    background: rgba(255, 255, 255, 0.82);
    border-radius: 24px;
  
    border: 1px solid var(--heading-color-1);
  
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
  
    animation: modalScale .35s ease-out;
  }
  
  /* ===============================
MOBILE EDGE SAFETY
=============================== */

@media (max-width: 768px) {

    .cookie-modal {
      padding: 16px;
    }
  
    .modal-content {
      padding: 22px;
      margin-top: 6vh;
      border-radius: 18px;
    }
  
  }
  
  @media (max-width: 420px) {
  
    .cookie-modal {
      padding: 14px;
    }
  
    .modal-content {
      padding: 20px;
      border-radius: 16px;
    }
  
  }
  .cookie-modal {
    padding-left: max(20px, env(safe-area-inset-left));
    padding-right: max(20px, env(safe-area-inset-right));
  }
    

.modal-content h4 {
    color: var(--heading-color-1);
    margin-bottom: 15px;
    font-size: 18px;
}

.cookie-category {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 16px;
    align-items: center;
    padding: 15px 0;
    border-top: 1px solid rgb(255 255 255 / .1);
}


.cookie-category:first-child {
    border-top: none
}

.cookie-category strong {
    color: var(--primary-color);
    font-weight: 400;
    font-size: 16px;
}

.cookie-category p {
    font-size: var(--sm-text-base);
    color: var(--text-color-2);
    margin: 5px 0 0;
    max-width: 85%
}

.cookie-switch {
    position: relative;
    width: 44px;
    height: 24px
}

.cookie-switch input {
    opacity: 0;
    width: 0;
    height: 0
}

.cookie-slider {
    position: absolute;
    inset: 0;
    background-color: #444;
    border-radius: 50px;
    transition: .3s
}

.cookie-slider::before {
    content: "";
    position: absolute;
    height: 18px;
    width: 18px;
    left: 3px;
    bottom: 3px;
    background-color: #fff;
    border-radius: 50%;
    transition: .3s
}

.cookie-switch input:checked+.cookie-slider {
    background-color: var(--heading-color-1)
}

.cookie-switch input:checked+.cookie-slider::before {
    transform: translateX(20px)
}

.cookie-switch input:disabled+.cookie-slider {
    background-color: #666;
    cursor: not-allowed
}

.modal-actions {
    display: flex;
    justify-content: flex-end;
    gap: 12px;
    margin-top: 25px;
    flex-wrap: wrap
}

.modal-actions .cookie-btn {
    min-width: 150px;
    text-align: center
}

.btn {
    color: var(--heading-color-1)
}

@keyframes slideUp {
    from {
        transform: translate(-50%, 100%)
    }
    to {
        transform: translate(-50%, 0)
    }
}

@keyframes modalScale {
    from {
        opacity: 0;
        transform: scale(.95)
    }
    to {
        opacity: 1;
        transform: scale(1)
    }
}

@media (max-width:768px) {
    .footer p, .footer a{
        font-size: 14px;
    }
    .cookie-actions{
        display: grid;
    }
    .cookie-banner {
        padding: 9px;
        width: calc(100% - 27px);
    }

    .project.service-box{
        min-height: 370px;
        max-height: 370px;

    }

    .spacer-top-left{
        width: 0px;
        height: 0px;
    }
    .spacer-top-right{
        width: 0px;
        height: 0px;
    }
    
    .cookie-btn{
        font-size: 15px;
        padding: 5px 9px;
        font-weight: 300;
    }
    .modal-content {
        padding: 22px
    }
    .modal-actions {
        flex-direction: column
    }
    .modal-actions .cookie-btn {
        width: 100%
    }
    .spacer-bottom-right{
        width: 0px;
        height: 0px;
    }
}

.cookie-banner h4{
    font-size: 16px;
}
.cookie-banner p, .cookie-banner a{
    font-size: 14px;
}

