:root {
      --ics-navy: #071a35;
      --ics-navy-soft: #102847;
      --ics-navy-rgb: 7, 26, 53;
      --ics-gold: #92681d;
      --ics-gold-dark: #8f671c;
      --ics-gold-rgb: 184, 138, 46;
      --ics-ink: #263142;
      --ics-muted: #667085;
      --ics-line: #e5e7eb;
      --ics-light: #f7f7f5;
    }

    body {
      background:
        radial-gradient(circle at 12% 8%, rgba(var(--ics-gold-rgb), .16), transparent 28%),
        radial-gradient(circle at 88% 18%, rgba(var(--ics-navy-rgb), .08), transparent 30%),
        linear-gradient(180deg, #ffffff 0%, #fbfaf6 42%, #f7f7f5 100%);
      color: var(--ics-ink);
      font-family: "Segoe UI", Roboto, Arial, sans-serif;
      line-height: 1.65;
      overflow-x: hidden;
    }

    html {
      scroll-behavior: smooth;
    }

    body::before {
      background:
        linear-gradient(115deg, transparent 0%, rgba(255,255,255,.45) 42%, rgba(var(--ics-gold-rgb), .12) 50%, rgba(255,255,255,.45) 58%, transparent 100%);
      content: "";
      height: 100%;
      left: -75%;
      pointer-events: none;
      position: fixed;
      top: 0;
      transform: skewX(-18deg);
      width: 48%;
      z-index: -1;
      animation: pageShine 9s ease-in-out infinite;
    }

    a {
      text-decoration: none;
    }

    h1, .h1 {
      font-size: 40px;
      font-weight: 700;
    }

    h2, .h2 {
      font-size: 40px;
      font-weight: 700;
    }

    h3, .h3 {
      font-size: 20px;
      font-weight: 700;
    }

    h4, .h4 {
      font-size: 20px;
      font-weight: 700;
    }

    h5, .h5 {
      font-size: 20px;
      font-weight: 700;
    }

    h6, .h6 {
      font-size: 20px;
      font-weight: 700;
    }

    .display-6 {
      font-size: 40px;
      font-weight: 700;
    }
.bg-white {
    --bs-bg-opacity: 1;
    background-color: rgb(0 9 25) !important;
}
    .topbar {
      background: #92681d;
      border-bottom: 3px solid transparent;
      border-image: linear-gradient(90deg, var(--ics-gold), #1877f2, #e4405f, #0a66c2, var(--ics-gold)) 1;
      color: rgba(255, 255, 255, .86);
      font-size: 15px;
    }

    .topbar a {
      color: rgba(255, 255, 255, .9);
    }

    .topbar i {
      color: var(--ics-gold);
    }

    .topbar-contact span,
    .topbar-contact a {
      align-items: center;
      display: inline-flex;
      gap: 4px;
    }

    .topbar-contact span {
      color: #ffffff;
    }

    .topbar-contact a {
      color: #ffffff;
    }

    .topbar-contact span i {
      color: #ffffff;
    }

    .topbar-contact a i {
      color: #ffffff;
    }

    .topbar-social a {
      align-items: center;
      background: #fff;
      border-radius: 50%;
      display: inline-flex;
      height: 30px;
      justify-content: center;
      transition: transform .25s ease, box-shadow .25s ease;
      width: 30px;
    }

    .topbar-social a:hover {
      box-shadow: 0 8px 18px rgba(0,0,0,.22);
      transform: translateY(-3px);
    }

    .topbar-social .social-facebook i {
      color: #1877f2;
    }

    .topbar-social .social-instagram i {
      color: #e4405f;
    }

    .topbar-social .social-linkedin i {
      color: #0a66c2;
    }

    .navbar {
      --bs-navbar-padding-x: 0;
      --bs-navbar-padding-y: 0;
      border-bottom: 1px solid rgba(var(--ics-gold-rgb), .16);
      box-shadow: 0 14px 35px rgba(var(--ics-navy-rgb), .08);
    }

    .navbar > .container {
      align-items: center;
      min-height: 92px;
    }

    .navbar-brand {
      align-items: center;
      display: flex;
      margin: 0;
      padding: 0;
    }

    .navbar-brand img {
      max-height: 100px;
      width: auto;
      display: block;
    }

    .navbar-nav {
      gap: .2rem;
    }

    .nav-link {
      color: #ffffff;
      font-weight: 700;
      padding: .72rem .88rem !important;
      position: relative;
    }

    .nav-link:hover,
    .nav-link:focus {
      color: var(--ics-gold);
    }

    .nav-link::after {
      background: var(--ics-gold);
      border-radius: 99px;
      bottom: .35rem;
      content: "";
      height: 2px;
      left: .88rem;
      opacity: 0;
      position: absolute;
      right: .88rem;
      transform: scaleX(.35);
      transition: opacity .2s ease, transform .2s ease;
    }

    .nav-link:hover::after,
    .nav-link:focus::after {
      opacity: 1;
      transform: scaleX(1);
    }

    .navbar-collapse {
      align-items: center;
    }

    .navbar-toggler {
      border-color: var(--ics-line);
      box-shadow: none !important;
      height: 44px;
      padding: .4rem .65rem;
    }

    .dropdown-menu {
      border: 1px solid var(--ics-line);
      border-radius: 8px;
      box-shadow: 0 18px 45px rgba(var(--ics-navy-rgb), .12);
      min-width: 280px;
      padding: .55rem;
    }

    .dropdown-toggle::after {
      display: none;
    }

    .menu-arrow {
      color: var(--ics-gold);
      font-size: 12px;
      margin-left: .45rem;
      transition: transform .2s ease;
    }

    .dropdown:hover .menu-arrow,
    .dropdown .show .menu-arrow,
    .dropdown-toggle[aria-expanded="true"] .menu-arrow {
      transform: rotate(180deg);
    }

    @media (min-width: 992px) {
      .navbar .dropdown:hover > .dropdown-menu {
        display: block;
        margin-top: 0;
      }

      .navbar .dropdown:hover > .dropdown-toggle {
        color: var(--ics-gold);
      }
    }

    .dropdown-item {
      border-radius: 8px;
      color: var(--ics-ink);
      font-weight: 600;
      padding: .65rem .8rem;
    }

    .dropdown-item:hover,
    .dropdown-item:focus {
      background: var(--ics-light);
      color: var(--ics-gold);
    }

    .header-quote-btn {
      box-shadow: 0 12px 24px rgba(var(--ics-gold-rgb), .24);
      white-space: nowrap;
    }

    .btn-ics {
      --bs-btn-bg: var(--ics-gold);
      --bs-btn-border-color: var(--ics-gold);
      --bs-btn-hover-bg: var(--ics-gold-dark);
      --bs-btn-hover-border-color: var(--ics-gold-dark);
      --bs-btn-color: #fff;
      --bs-btn-hover-color: #fff;
      border-radius: 999px;
      font-weight: 700;
      padding: .78rem 1.35rem;
      overflow: hidden;
      position: relative;
      transition: transform .28s ease, box-shadow .28s ease;
    }

    .btn-ics::before {
      background: linear-gradient(120deg, transparent, rgba(255,255,255,.45), transparent);
      content: "";
      height: 160%;
      left: -120%;
      position: absolute;
      top: -30%;
      transform: skewX(-20deg);
      transition: left .65s ease;
      width: 55%;
    }

    .btn-ics:hover {
      box-shadow: 0 14px 30px rgba(var(--ics-gold-rgb), .28);
      transform: translateY(-2px);
    }

    .btn-ics:hover::before {
      left: 130%;
    }

    .btn-outline-ics {
      --bs-btn-color: #fff;
      --bs-btn-border-color: rgba(255, 255, 255, .65);
      --bs-btn-hover-bg: #fff;
      --bs-btn-hover-border-color: #fff;
      --bs-btn-hover-color: var(--ics-navy);
      border-radius: 999px;
      font-weight: 700;
      padding: .78rem 1.35rem;
    }

    .hero-video {
      background: var(--ics-navy);
      height: clamp(620px, 88vh, 940px);
      overflow: hidden;
      position: relative;
    }

    .hero-video::after {
      background: transparent;
      content: "";
      inset: 0;
      pointer-events: none;
      position: absolute;
    }

    .hero-video-media {
      backface-visibility: hidden;
      height: 100%;
      object-fit: cover;
      object-position: center;
      transform: translateZ(0);
      width: 100%;
      display: block;
      filter: none;
    }

    .eyebrow {
      color: var(--ics-gold);
      display: inline-flex;
      align-items: center;
      gap: .5rem;
      font-size: 13px;
      font-weight: 700;
      letter-spacing: .12em;
      text-transform: uppercase;
    }

    .hero h1 {
      max-width: 780px;
      font-size: 40px;
      font-weight: 700;
      letter-spacing: 0;
      line-height: 1.03;
      margin: 1rem 0 1.35rem;
    }

    .hero .lead {
      max-width: 650px;
      color: rgba(255, 255, 255, .84);
      font-size: 20px;
    }

    .hero-panel {
      background: rgba(255, 255, 255, .1);
      border: 1px solid rgba(255, 255, 255, .18);
      backdrop-filter: blur(16px);
      border-radius: 8px;
      padding: 1.35rem;
    }

    .stat-card {
      background: rgba(255, 255, 255, .9);
      border: 1px solid rgba(var(--ics-gold-rgb), .16);
      border-radius: 8px;
      box-shadow: 0 18px 45px rgba(var(--ics-navy-rgb), .08);
      padding: 1.3rem;
      height: 100%;
      transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease;
    }

    .stat-card:hover {
      border-color: rgba(var(--ics-gold-rgb), .5);
      box-shadow: 0 26px 65px rgba(var(--ics-navy-rgb), .14);
      transform: translateY(-8px);
    }

    .stat-card strong {
      color: var(--ics-gold);
      display: block;
      font-size: 36px;
      line-height: 1;
    }

    .section-pad {
      padding: 92px 0;
      position: relative;
      z-index: 1;
    }

    .section-pad::before {
      background: linear-gradient(90deg, transparent, rgba(var(--ics-gold-rgb), .08), transparent);
      content: "";
      height: 1px;
      left: 10%;
      position: absolute;
      right: 10%;
      top: 0;
    }

    .section-soft {
      background:
        linear-gradient(135deg, rgba(var(--ics-gold-rgb), .08), rgba(255,255,255,.76)),
        var(--ics-light);
    }

    .stats-section {
      padding: 42px 0;
    }

    .section-title {
      max-width: 760px;
      margin-bottom: 2.25rem;
    }

    .section-title h2 {
      color: var(--ics-navy);
      font-size: 40px;
      font-weight: 700;
      line-height: 1.08;
      margin-top: .55rem;
    }

    .muted {
      color: var(--ics-muted);
    }

    .feature-icon,
    .service-icon,
    .process-icon {
      align-items: center;
      border-radius: 8px;
      display: inline-flex;
      height: 48px;
      justify-content: center;
      width: 48px;
    }

    .feature-icon {
      background: rgba(var(--ics-gold-rgb), .14);
      color: var(--ics-gold);
    }

    .service-card {
      background:
        linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,255,255,.9)),
        #fff;
      border: 1px solid rgba(var(--ics-gold-rgb), .18);
      border-radius: 8px;
      box-shadow: 0 16px 38px rgba(var(--ics-navy-rgb), .08);
      display: flex;
      flex-direction: column;
      height: 100%;
      overflow: hidden;
      opacity: 0;
      position: relative;
      transform: translateY(28px) rotateX(0) rotateY(0);
      transform-style: preserve-3d;
      transition: transform .38s ease, box-shadow .38s ease, border-color .38s ease, opacity .65s ease;
      will-change: transform, opacity;
    }

    
    
    .service-card::before {
      background:
        linear-gradient(120deg, transparent 0%, rgba(255,255,255,.82) 42%, rgba(var(--ics-gold-rgb), .22) 50%, rgba(255,255,255,.82) 58%, transparent 100%);
      content: "";
      height: 140%;
      left: -130%;
      pointer-events: none;
      position: absolute;
      top: -20%;
      transform: skewX(-20deg);
      transition: left .7s ease;
      width: 58%;
      z-index: 4;
    }

    .service-card::after {
      border: 1px solid transparent;
      border-radius: 8px;
      content: "";
      inset: 0;
      pointer-events: none;
      position: absolute;
      transition: border-color .35s ease, box-shadow .35s ease;
      z-index: 5;
    }

    .service-card:hover {
      border-color: rgba(var(--ics-gold-rgb), .7);
      box-shadow: 0 30px 70px rgba(var(--ics-navy-rgb), .18), 0 0 0 4px rgba(var(--ics-gold-rgb), .08);
      transform: perspective(900px) rotateX(4deg) rotateY(-5deg) translateY(-12px);
    }

    .service-card:hover::before {
      left: 130%;
    }

    .service-card:hover::after {
      border-color: rgba(var(--ics-gold-rgb), .62);
      box-shadow: inset 0 0 28px rgba(var(--ics-gold-rgb), .12);
    }

    .service-card img {
      aspect-ratio: 16 / 10;
      object-fit: cover;
      transition: transform .55s ease, filter .55s ease;
      width: 100%;
    }

    .service-card:hover img {
      filter: saturate(1.08) contrast(1.04);
      transform: scale(1.08);
    }

    .service-icon {
      background: linear-gradient(145deg, var(--ics-navy), var(--ics-navy-soft));
      box-shadow: 0 12px 24px rgba(var(--ics-navy-rgb), .2);
      color: #fff;
      margin-top: -24px;
      position: relative;
      transition: background .35s ease, color .35s ease, transform .35s ease, box-shadow .35s ease;
      z-index: 6;
    }

    .service-card:hover .service-icon {
      background: var(--ics-gold);
      box-shadow: 0 14px 26px rgba(var(--ics-gold-rgb), .34);
      color: #fff;
      transform: translateZ(28px) rotateY(12deg);
    }

    .service-card h3,
    .service-card p {
      position: relative;
      z-index: 6;
    }

    .service-card h3 a {
      color: var(--ics-navy);
      transition: color .25s ease;
    }

    .service-card h3 a:hover,
    .service-card h3 a:focus {
      color: var(--ics-gold);
    }

    .service-card .p-4 {
      display: flex;
      flex: 1;
      flex-direction: column;
    }

    .service-card p {
      margin-top: auto;
    }

    #services.services-loaded .service-card {
      opacity: 1;
      transform: translateY(0);
    }

    #services.services-loaded .col-md-6:nth-child(2) .service-card {
      transition-delay: .08s;
    }

    #services.services-loaded .col-md-6:nth-child(3) .service-card {
      transition-delay: .16s;
    }

    #services.services-loaded .col-md-6:nth-child(4) .service-card {
      transition-delay: .24s;
    }

    #services.services-loaded .col-md-6:nth-child(5) .service-card {
      transition-delay: .32s;
    }

    #services.services-loaded .col-md-6:nth-child(6) .service-card {
      transition-delay: .4s;
    }

    #services.services-loaded .col-md-6:nth-child(7) .service-card {
      transition-delay: .48s;
    }

    #services.services-loaded .col-md-6:nth-child(8) .service-card {
      transition-delay: .56s;
    }

    .industries-section {
      background:
        radial-gradient(circle at 50% 15%, rgba(var(--ics-gold-rgb), .1), transparent 28%),
        linear-gradient(180deg, #fff 0%, #fbfaf7 100%);
      overflow: hidden;
    }

    .industries-title {
      margin: 0 auto 3rem;
      max-width: 980px;
      text-align: center;
    }

    .industries-title h2 {
      color: var(--ics-navy);
      font-size: 40px;
      font-weight: 700;
      letter-spacing: 0;
      line-height: 1.08;
      margin: .8rem 0 .7rem;
    }

    .industry-card {
      background:
        linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,255,255,.92)),
        #fff;
      border: 1px solid rgba(var(--ics-gold-rgb), .18);
      border-bottom: 4px solid var(--ics-gold);
      border-radius: 8px;
      box-shadow: 0 18px 45px rgba(var(--ics-navy-rgb), .08);
      height: 100%;
      min-height: 330px;
      opacity: 0;
      padding: 2.7rem 2rem 2.2rem;
      position: relative;
      text-align: center;
      transform: translateY(32px) scale(.98);
      transform-style: preserve-3d;
      transition: transform .45s ease, box-shadow .45s ease, border-color .45s ease, opacity .7s ease;
      will-change: transform, opacity;
    }

    .industry-card::before {
      background:
        radial-gradient(circle at 15% 18%, rgba(var(--ics-gold-rgb), .18), transparent 30%),
        radial-gradient(circle at 85% 12%, rgba(var(--ics-navy-rgb), .08), transparent 28%);
      content: "";
      inset: 0;
      opacity: .75;
      pointer-events: none;
      position: absolute;
      z-index: 0;
    }

    .industry-card::after {
      
      content: "";
      height: 130%;
      left: -120%;
      pointer-events: none;
      position: absolute;
      top: -15%;
      transform: skewX(-20deg);
      transition: left .75s ease;
      width: 55%;
      z-index: 3;
    }

    .industry-card:hover {
      border-color: rgba(var(--ics-gold-rgb), .75);
      box-shadow: 0 30px 80px rgba(var(--ics-navy-rgb), .18), 0 0 0 4px rgba(var(--ics-gold-rgb), .08);
      transform: perspective(900px) rotateX(5deg) rotateY(-6deg) translateY(-12px);
    }

    .industry-card:hover::after {
      left: 130%;
    }

    .industry-icon {
      align-items: center;
      background: rgba(255,255,255,.88);
      border: 1px dashed rgba(var(--ics-gold-rgb), .78);
      border-radius: 50%;
      color: var(--ics-navy);
      display: inline-flex;
      font-size: 48px;
      height: 118px;
      justify-content: center;
      margin-bottom: 2rem;
      position: relative;
      transition: transform .35s ease, color .35s ease, box-shadow .35s ease;
      width: 118px;
      z-index: 2;
    }

    .industry-icon::after {
      animation: iconDotSpin 9s linear infinite;
      background: var(--ics-gold);
      border: 4px solid #fff;
      border-radius: 50%;
      box-shadow: 0 0 0 1px rgba(var(--ics-gold-rgb), .35);
      content: "";
      height: 20px;
      position: absolute;
      
      width: 20px;
    }

    .industry-card h3 {
      color: var(--ics-navy);
      font-size: 20px;
      font-weight: 700;
      margin-bottom: 1rem;
      position: relative;
      z-index: 2;
    }

    .industry-card p {
      color: var(--ics-muted);
      font-size: 16px;
      margin: 0;
      position: relative;
      z-index: 2;
    }

    .industry-card:hover .industry-icon {
      box-shadow: 0 14px 35px rgba(var(--ics-gold-rgb), .18);
      color: var(--ics-gold);
      transform: translateZ(26px) scale(1.06);
    }

    .industries-section.is-visible .industry-card {
      opacity: 1;
      transform: translateY(0) scale(1);
    }

    .industries-section.is-visible .col-md-6:nth-child(2) .industry-card {
      transition-delay: .08s;
    }

    .industries-section.is-visible .col-md-6:nth-child(3) .industry-card {
      transition-delay: .16s;
    }

    .industries-section.is-visible .col-md-6:nth-child(4) .industry-card {
      transition-delay: .24s;
    }

    .industries-section.is-visible .col-md-6:nth-child(5) .industry-card {
      transition-delay: .32s;
    }

    .industries-section.is-visible .col-md-6:nth-child(6) .industry-card {
      transition-delay: .4s;
    }

    .industries-section.is-visible .col-md-6:nth-child(7) .industry-card {
      transition-delay: .48s;
    }

    .industries-section.is-visible .col-md-6:nth-child(8) .industry-card {
      transition-delay: .56s;
    }

    @keyframes iconDotSpin {
      from {
        transform: rotate(0deg) translateX(59px) rotate(0deg);
      }

      to {
        transform: rotate(360deg) translateX(59px) rotate(-360deg);
      }
    }

    .about-modern {
      background:
        linear-gradient(180deg, #fff 0%, var(--ics-light) 100%),
        #fff;
      overflow: hidden;
      position: relative;
    }

    .about-modern .container {
      overflow: hidden;
    }

    .about-modern::before {
      background: rgba(var(--ics-gold-rgb), .08);
      content: "";
      height: 1px;
      position: absolute;
      inset: 0 0 auto;
    }

    .about-visual {
      position: relative;
      perspective: 1200px;
    }

    .about-scroll-left,
    .about-scroll-right {
      opacity: 0;
      transition: opacity .8s ease, transform .8s cubic-bezier(.22, 1, .36, 1);
      will-change: opacity, transform;
    }

    .about-scroll-left {
      transform: translate3d(-42px, 0, 0);
    }

    .about-scroll-right {
      transform: translate3d(42px, 0, 0);
    }

    .about-modern.is-visible .about-scroll-left,
    .about-modern.is-visible .about-scroll-right {
      opacity: 1;
      transform: translate3d(0, 0, 0);
    }

    .about-image-frame {
      background: #fff;
      border: 1px solid rgba(var(--ics-gold-rgb), .32);
      border-radius: 8px;
      box-shadow: 0 24px 65px rgba(var(--ics-navy-rgb), .18);
      height: 540px;
      overflow: hidden;
      position: relative;
      transform: rotateX(0) rotateY(0) translateZ(0);
      transform-style: preserve-3d;
      transition: transform .45s ease, border-color .45s ease, box-shadow .45s ease;
    }

    .about-image-frame:hover {
      border-color: rgba(var(--ics-gold-rgb), .78);
      box-shadow: 0 34px 90px rgba(var(--ics-navy-rgb), .26);
      transform: rotateX(2deg) rotateY(-8deg) translateY(-8px);
    }

    .about-image-frame::before {
      animation: aboutBorderRun 2.8s linear infinite;
      animation-play-state: paused;
      background:
        linear-gradient(90deg, transparent, rgba(var(--ics-gold-rgb), .95), transparent) 0 0 / 220% 2px no-repeat,
        linear-gradient(180deg, transparent, rgba(var(--ics-gold-rgb), .95), transparent) 100% 0 / 2px 220% no-repeat,
        linear-gradient(270deg, transparent, rgba(var(--ics-gold-rgb), .95), transparent) 100% 100% / 220% 2px no-repeat,
        linear-gradient(0deg, transparent, rgba(var(--ics-gold-rgb), .95), transparent) 0 100% / 2px 220% no-repeat;
      content: "";
      inset: 0;
      pointer-events: none;
      position: absolute;
      z-index: 3;
    }

    .about-image-frame:hover::before {
      animation-play-state: running;
    }

    .about-image-frame::after {
      background: linear-gradient(180deg, rgba(var(--ics-navy-rgb), 0) 45%, rgba(var(--ics-navy-rgb), .72));
      content: "";
      inset: 0;
      position: absolute;
      z-index: 1;
    }

    .about-image-frame img {
      height: 100%;
      object-fit: cover;
      transition: transform .55s ease;
      width: 100%;
    }

    .about-image-frame:hover img {
      transform: scale(1.06);
    }

    .about-floating-card {
      background: #fff;
      border: 1px solid var(--ics-line);
      border-left: 4px solid var(--ics-gold);
      border-radius: 8px;
      bottom: 26px;
      box-shadow: 0 20px 45px rgba(var(--ics-navy-rgb), .16);
      left: 26px;
      padding: 1.15rem 1.25rem;
      position: absolute;
      width: min(280px, 82%);
      z-index: 2;
    }

    .about-floating-card strong {
      color: var(--ics-navy);
      display: block;
      font-size: 32px;
      line-height: 1;
    }

    .about-feature-card {
      background: #fff;
      border: 1px solid var(--ics-line);
      border-radius: 8px;
      box-shadow: 0 16px 38px rgba(var(--ics-navy-rgb), .06);
      height: 100%;
      padding: 1.05rem;
      transition: transform .25s ease, border-color .25s ease, box-shadow .25s ease;
    }

    .about-feature-card:hover {
      border-color: rgba(var(--ics-gold-rgb), .42);
      box-shadow: 0 24px 55px rgba(var(--ics-navy-rgb), .1);
      transform: perspective(800px) rotateX(3deg) rotateY(-3deg) translateY(-6px);
    }

    .about-feature-card .feature-icon {
      margin-bottom: .85rem;
    }

    .about-points {
      display: grid;
      gap: .8rem;
      margin: 1.25rem 0 0;
    }

    .about-point {
      align-items: center;
      display: flex;
      gap: .75rem;
    }

    .about-point i {
      color: var(--ics-gold);
    }

    @keyframes aboutBorderRun {
      0% {
        background-position: -220% 0, 100% -220%, 220% 100%, 0 220%;
      }

      100% {
        background-position: 220% 0, 100% 220%, -220% 100%, 0 -220%;
      }
    }

    @keyframes pageShine {
      0%, 35% {
        left: -75%;
        opacity: 0;
      }

      45% {
        opacity: .75;
      }

      70%, 100% {
        left: 130%;
        opacity: 0;
      }
    }

    .about-image-caption {
      bottom: 30px;
      color: #fff;
      left: 30px;
      max-width: 360px;
      position: absolute;
      z-index: 2;
    }

    .about-image-caption strong {
      display: block;
      font-size: 20px;
      margin-bottom: .35rem;
    }

    .about-metric {
      align-items: center;
      background: #fff;
      border: 1px solid var(--ics-line);
      border-radius: 8px;
      display: flex;
      gap: 1rem;
      padding: 1rem;
      transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease;
    }

    .about-metric:hover {
      border-color: rgba(var(--ics-gold-rgb), .42);
      box-shadow: 0 18px 42px rgba(var(--ics-navy-rgb), .1);
      transform: translateY(-5px);
    }

    .about-metric i {
      color: var(--ics-gold);
      font-size: 24px;
    }

    .process-step {
      background: rgba(255, 255, 255, .94);
      border: 1px solid rgba(var(--ics-gold-rgb), .14);
      border-radius: 8px;
      height: 100%;
      padding: 1.5rem;
      position: relative;
    }

    .process-number {
      color: rgba(var(--ics-navy-rgb), .08);
      font-size: 64px;
      font-weight: 700;
      line-height: 1;
      position: absolute;
      right: 1rem;
      top: 1rem;
    }

    .process-icon {
      background: rgba(var(--ics-gold-rgb), .18);
      color: var(--ics-gold-dark);
      margin-bottom: 1.25rem;
    }

    .portfolio-gallery {
      overflow: hidden;
    }

    .portfolio-gallery .carousel {
      padding: 0 3.5rem 3.2rem;
    }

    .portfolio-card {
      background: #fff;
      border: 1px solid rgba(var(--ics-gold-rgb), .18);
      border-radius: 8px;
      box-shadow: 0 18px 45px rgba(var(--ics-navy-rgb), .08);
      overflow: hidden;
      position: relative;
      transition: transform .35s ease, box-shadow .35s ease, border-color .35s ease;
    }

    .portfolio-card:hover {
      border-color: rgba(var(--ics-gold-rgb), .68);
      box-shadow: 0 30px 80px rgba(var(--ics-navy-rgb), .18), 0 0 0 4px rgba(var(--ics-gold-rgb), .08);
      transform: translateY(-10px);
    }

    .portfolio-card img {
      aspect-ratio: 16 / 11;
      object-fit: cover;
      transition: transform .55s ease, filter .55s ease;
      width: 100%;
    }

    .portfolio-card:hover img {
      filter: saturate(1.08) contrast(1.04);
      transform: scale(1.08);
    }

    .portfolio-content {
      background: linear-gradient(180deg, rgba(var(--ics-navy-rgb), 0), rgba(var(--ics-navy-rgb), .9));
      bottom: 0;
      color: #fff;
      left: 0;
      padding: 4.5rem 1.25rem 1.25rem;
      position: absolute;
      right: 0;
      z-index: 2;
    }

    .portfolio-content h3 {
      font-size: 20px;
      font-weight: 700;
      margin-bottom: .25rem;
    }

    .portfolio-content p {
      color: rgba(255,255,255,.78);
      margin: 0;
    }

    .portfolio-gallery .carousel-control-prev,
    .portfolio-gallery .carousel-control-next {
      opacity: 1;
      width: 3rem;
    }

    .portfolio-gallery .carousel-control-prev-icon,
    .portfolio-gallery .carousel-control-next-icon {
      background-color: var(--ics-navy);
      background-size: 52%;
      border: 1px solid rgba(var(--ics-gold-rgb), .48);
      border-radius: 50%;
      box-shadow: 0 12px 24px rgba(var(--ics-navy-rgb), .18);
      height: 46px;
      width: 46px;
    }

    .portfolio-gallery .carousel-indicators {
      bottom: 0;
      gap: .45rem;
      margin-bottom: 0;
    }

    .portfolio-gallery .carousel-indicators [data-bs-target] {
      background-color: rgba(var(--ics-navy-rgb), .28);
      border: 0;
      border-radius: 50%;
      height: 11px;
      opacity: 1;
      width: 11px;
    }

    .portfolio-gallery .carousel-indicators .active {
      background-color: var(--ics-gold);
      transform: scale(1.22);
    }

    .working-process {
      background:
        radial-gradient(circle at 20% 18%, rgba(var(--ics-gold-rgb), .1), transparent 26%),
        radial-gradient(circle at 80% 18%, rgba(var(--ics-navy-rgb), .06), transparent 28%),
        #fff;
      overflow: hidden;
    }

    .process-title {
      margin: 0 auto 4rem;
      max-width: 980px;
      text-align: center;
    }

    .process-title h2 {
      color: var(--ics-navy);
      font-size: 40px;
      font-weight: 700;
      letter-spacing: 0;
      line-height: 1.08;
      margin: .8rem 0 0;
    }

    .work-step {
      height: 100%;
      opacity: 0;
      text-align: center;
      transform: translateY(34px);
      transition: opacity .75s ease, transform .75s cubic-bezier(.22, 1, .36, 1);
    }

    .working-process.is-visible .work-step {
      opacity: 1;
      transform: translateY(0);
    }

    .working-process.is-visible .col-md-6:nth-child(2) .work-step {
      transition-delay: .12s;
    }

    .working-process.is-visible .col-md-6:nth-child(3) .work-step {
      transition-delay: .24s;
    }

    .working-process.is-visible .col-md-6:nth-child(4) .work-step {
      transition-delay: .36s;
    }

    .work-icon-wrap {
      align-items: center;
      background: rgba(255,255,255,.96);
      border-radius: 50%;
      box-shadow: 0 26px 70px rgba(var(--ics-navy-rgb), .08);
      display: inline-flex;
      height: 200px;
      justify-content: center;
      margin-bottom: 2.1rem;
      position: relative;
      transform-style: preserve-3d;
      transition: transform .35s ease, box-shadow .35s ease;
      width: 200px;
    }

    .work-icon-wrap::before {
      border: 1px dashed rgba(var(--ics-navy-rgb), .48);
      border-radius: 50%;
      content: "";
      inset: 28px;
      position: absolute;
    }

    .work-icon {
      align-items: center;
      color: var(--ics-navy);
      display: inline-flex;
      font-size: 51px;
      justify-content: center;
      position: relative;
      transition: color .35s ease, transform .35s ease;
      z-index: 2;
    }

    .work-number {
      align-items: center;
      background: var(--ics-gold);
      border: 5px solid #fff;
      border-radius: 50%;
      box-shadow: 0 14px 28px rgba(var(--ics-gold-rgb), .28);
      color: #fff;
      display: inline-flex;
      font-weight: 700;
      height: 48px;
      justify-content: center;
      position: absolute;
      right: 8px;
      top: 16px;
      width: 48px;
      z-index: 3;
    }

    .work-orbit-dot {
      animation: workDotSpin 9s linear infinite;
      border: 2px solid rgba(var(--ics-gold-rgb), .75);
      border-radius: 50%;
      bottom: 42px;
      height: 34px;
      position: absolute;
      width: 34px;
      z-index: 3;
    }

    .work-step:hover .work-icon-wrap {
      box-shadow: 0 34px 90px rgba(var(--ics-navy-rgb), .15);
      transform: perspective(900px) rotateX(5deg) rotateY(-8deg) translateY(-10px);
    }

    .work-step:hover .work-icon {
      color: var(--ics-gold);
      transform: translateZ(30px) scale(1.08);
    }

    .work-step h3 {
      color: var(--ics-navy);
      font-size: 20px;
      font-weight: 700;
      line-height: 1.32;
      margin-bottom: 1rem;
    }

    .work-step p {
      color: var(--ics-muted);
      font-size: 17px;
      line-height: 1.75;
      margin: 0 auto;
      max-width: 310px;
    }

    @keyframes workDotSpin {
      from {
        transform: rotate(0deg) translateX(76px) rotate(0deg);
      }

      to {
        transform: rotate(360deg) translateX(76px) rotate(-360deg);
      }
    }

    .testimonial {
      background: rgba(255, 255, 255, .94);
      border: 1px solid rgba(var(--ics-gold-rgb), .14);
      border-radius: 8px;
      height: 100%;
      padding: 1.5rem;
      position: relative;
      transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease;
    }

    .testimonial::before {
      background: var(--ics-gold);
      border-radius: 8px 8px 0 0;
      content: "";
      height: 4px;
      left: 0;
      position: absolute;
      right: 0;
      top: 0;
      transform: scaleX(0);
      transform-origin: left;
      transition: transform .35s ease;
    }

    .testimonial:hover {
      border-color: rgba(var(--ics-gold-rgb), .5);
      box-shadow: 0 24px 60px rgba(var(--ics-navy-rgb), .13);
      transform: translateY(-8px);
    }

    .testimonial:hover::before {
      transform: scaleX(1);
    }

    .testimonials-carousel {
      padding: 0 3.25rem 3.25rem;
    }

    .testimonials-carousel .carousel-inner {
      overflow: hidden;
      padding: .35rem 0 1.15rem;
    }

    .testimonials-carousel .carousel-item {
      backface-visibility: hidden;
      transform: translateZ(0);
      transition: transform 1.15s cubic-bezier(.22, 1, .36, 1), opacity 1.15s ease;
      will-change: transform;
    }

    .testimonials-carousel .carousel-control-prev,
    .testimonials-carousel .carousel-control-next {
      background: var(--ics-navy);
      border: 1px solid rgba(var(--ics-gold-rgb), .34);
      border-radius: 50%;
      box-shadow: 0 18px 38px rgba(var(--ics-navy-rgb), .16);
      height: 44px;
      opacity: 1;
      top: calc(50% - 1.75rem);
      transform: translateY(-50%);
      transition: background .25s ease, transform .25s ease, box-shadow .25s ease;
      width: 44px;
    }

    .testimonials-carousel .carousel-control-prev {
      left: 0;
    }

    .testimonials-carousel .carousel-control-next {
      right: 0;
    }

    .testimonials-carousel .carousel-control-prev:hover,
    .testimonials-carousel .carousel-control-next:hover {
      background: var(--ics-gold);
      box-shadow: 0 22px 48px rgba(var(--ics-gold-rgb), .26);
      transform: translateY(-50%) scale(1.05);
    }

    .testimonials-carousel .carousel-control-prev-icon,
    .testimonials-carousel .carousel-control-next-icon {
      height: 1.1rem;
      width: 1.1rem;
    }

    .testimonials-carousel .carousel-indicators {
      bottom: 0;
      gap: .45rem;
      margin-bottom: 0;
    }

    .testimonials-carousel .carousel-indicators [data-bs-target] {
      background-color: rgba(var(--ics-navy-rgb), .28);
      border: 0;
      border-radius: 999px;
      height: 9px;
      margin: 0;
      opacity: 1;
      transition: background-color .25s ease, width .25s ease;
      width: 9px;
    }

    .testimonials-carousel .carousel-indicators .active {
      background-color: var(--ics-gold);
      width: 28px;
    }

    .clients-section {
      overflow: hidden;
    }

    .clients-logo-shell {
      padding: .35rem 3.25rem .5rem;
      position: relative;
    }

    .clients-logo-viewport {
      -ms-overflow-style: none;
      mask-image: linear-gradient(90deg, transparent 0, #000 8%, #000 92%, transparent 100%);
      overflow: hidden;
      scroll-behavior: smooth;
      scrollbar-width: none;
      width: 100%;
    }

    .clients-logo-viewport::-webkit-scrollbar {
      display: none;
    }

    .clients-logo-track {
      animation: clientsLogoScroll 32s linear infinite;
      display: flex;
      gap: 1rem;
      width: max-content;
      will-change: transform;
    }

    .clients-logo-shell:hover .clients-logo-track {
      animation-play-state: paused;
    }

    .clients-logo-group {
      display: flex;
      flex: 0 0 auto;
      gap: 1rem;
    }

    @keyframes clientsLogoScroll {
      from {
        transform: translate3d(0, 0, 0);
      }

      to {
        transform: translate3d(calc(-50% - .5rem), 0, 0);
      }
    }

    .client-logo-card {
      align-items: center;
      background: #fff;
      border: 1px solid rgba(var(--ics-navy-rgb), .1);
      border-radius: 8px;
      box-shadow: 0 18px 42px rgba(var(--ics-navy-rgb), .08);
      color: var(--ics-navy);
      display: flex;
      font-size: clamp(1.05rem, 2vw, 1.55rem);
      font-weight: 800;
      height: 112px;
      justify-content: center;
      letter-spacing: 0;
      padding: 1rem;
      text-align: center;
      transition: border-color .25s ease, box-shadow .25s ease, transform .25s ease;
      width: 190px;
    }

    .client-logo-card:hover {
      border-color: rgba(var(--ics-gold-rgb), .45);
      box-shadow: 0 24px 54px rgba(var(--ics-navy-rgb), .13);
      transform: translateY(-5px);
    }

    .client-logo-card img {
      display: block;
      max-height: 74px;
      max-width: 145px;
      object-fit: contain;
      width: auto;
    }

    .clients-scroll-btn {
      align-items: center;
      background: var(--ics-navy);
      border: 1px solid rgba(var(--ics-gold-rgb), .34);
      border-radius: 50%;
      box-shadow: 0 18px 38px rgba(var(--ics-navy-rgb), .16);
      color: #fff;
      display: inline-flex;
      font-size: 1.1rem;
      height: 44px;
      justify-content: center;
      position: absolute;
      top: calc(50% - .15rem);
      transform: translateY(-50%);
      transition: background .25s ease, transform .25s ease, box-shadow .25s ease;
      width: 44px;
      z-index: 3;
    }

    .clients-scroll-prev {
      left: 0;
    }

    .clients-scroll-next {
      right: 0;
    }

    .clients-scroll-btn:hover {
      background: var(--ics-gold);
      box-shadow: 0 22px 48px rgba(var(--ics-gold-rgb), .26);
      transform: translateY(-50%) scale(1.05);
    }

    @media (prefers-reduced-motion: reduce) {
      .clients-logo-track {
        animation: none;
      }
    }

    .cta {
      background:
        linear-gradient(90deg, rgba(var(--ics-navy-rgb), .96), rgba(var(--ics-navy-rgb), .83)),
        url("https://images.unsplash.com/photo-1504384308090-c894fdcc538d?auto=format&fit=crop&w=1600&q=80") center/cover;
      color: #fff;
    }

    .form-control,
    .form-select {
      border-color: var(--ics-line);
      border-radius: 8px;
      min-height: 50px;
      transition: border-color .25s ease, box-shadow .25s ease;
    }

    .form-control:focus,
    .form-select:focus {
      border-color: var(--ics-gold);
      box-shadow: 0 0 0 4px rgba(var(--ics-gold-rgb), .14);
    }

    footer {
      background: rgb(0, 9, 25) !important;
      color: rgba(255, 255, 255, .74);
    }

    .footer-logo {
      display: block;
      margin-bottom: 1rem;
      max-height: 175pxpx;
      width: 220px;
    }

    footer a {
      color: rgba(255, 255, 255, .78);
      transition: color .25s ease, padding-left .25s ease;
    }

    footer a:hover {
      color: var(--ics-gold);
      padding-left: 4px;
    }

    .ui-reveal {
      opacity: 0;
      transform: translateY(28px);
      transition: opacity .7s ease, transform .7s cubic-bezier(.22, 1, .36, 1);
      will-change: opacity, transform;
    }

    .ui-reveal.is-visible {
      opacity: 1;
      transform: translateY(0);
    }

    .floating-whatsapp {
      align-items: center;
      background: var(--ics-gold);
      border-radius: 999px;
      bottom: 22px;
      box-shadow: 0 12px 25px rgba(var(--ics-gold-rgb), .32);
      color: #fff;
      display: inline-flex;
      font-size: 23px;
      height: 54px;
      justify-content: center;
      position: fixed;
      right: 22px;
      width: 54px;
      z-index: 1030;
    }

    .brand-gold {
      color: var(--ics-gold) !important;
    }

    @media (max-width: 991.98px) {
      .navbar > .container {
        min-height: 76px;
      }

      .navbar-brand img {
        max-height: 100px;
      }

      .navbar-collapse {
        border-top: 1px solid var(--ics-line);
        margin-top: 0;
        padding: .8rem 0 1rem;
      }

      .navbar-nav {
        align-items: stretch !important;
        gap: .15rem;
      }

      .nav-link {
        border-radius: 8px;
        padding: .72rem .85rem !important;
      }

      .nav-link:hover,
      .nav-link:focus {
        background: var(--ics-light);
      }

      .nav-link::after {
        display: none;
      }

      .dropdown-menu {
        border: 0;
        box-shadow: none;
        margin: 0 0 .35rem;
        min-width: 100%;
        padding: .25rem 0 .25rem .7rem;
      }

      .dropdown-toggle {
        align-items: center;
        display: flex;
        justify-content: space-between;
      }

      .dropdown-item {
        padding: .65rem .85rem;
      }

      .header-quote-btn {
        justify-content: center;
        width: 100%;
      }

      .hero-video {
        height: clamp(540px, 76vh, 760px);
      }

      .section-pad {
        padding: 68px 0;
      }

      .portfolio-gallery .carousel {
        padding: 0 0 3.1rem;
      }

      .portfolio-gallery .carousel-control-prev,
      .portfolio-gallery .carousel-control-next {
        display: none;
      }

      .testimonials-carousel {
        padding: 0 0 3.1rem;
      }

      .testimonials-carousel .carousel-control-prev,
      .testimonials-carousel .carousel-control-next {
        top: auto;
        bottom: .2rem;
        transform: none;
      }

      .testimonials-carousel .carousel-control-prev:hover,
      .testimonials-carousel .carousel-control-next:hover {
        transform: scale(1.05);
      }

      .testimonials-carousel .carousel-control-prev {
        left: calc(50% - 78px);
      }

      .testimonials-carousel .carousel-control-next {
        right: calc(50% - 78px);
      }

      .testimonials-carousel .carousel-indicators {
        bottom: 1rem;
      }

      .clients-logo-shell {
        padding: .15rem 0 3.2rem;
      }

      .client-logo-card {
        height: 96px;
        width: 165px;
      }

      .clients-scroll-btn {
        top: auto;
        bottom: .2rem;
        transform: none;
      }

      .clients-scroll-btn:hover {
        transform: scale(1.05);
      }

      .clients-scroll-prev {
        left: calc(50% - 58px);
      }

      .clients-scroll-next {
        right: calc(50% - 58px);
      }

      .work-icon-wrap {
        height: 180px;
        width: 180px;
      }

      .work-icon {
        font-size: 45px;
      }

      .work-number {
        height: 44px;
        width: 44px;
      }

      @keyframes workDotSpin {
        from {
          transform: rotate(0deg) translateX(68px) rotate(0deg);
        }

        to {
          transform: rotate(360deg) translateX(68px) rotate(-360deg);
        }
      }

      .about-visual {
        min-height: auto;
      }

      .about-scroll-left,
      .about-scroll-right {
        transform: translate3d(0, 34px, 0);
      }

      .about-modern.is-visible .about-scroll-left,
      .about-modern.is-visible .about-scroll-right {
        transform: translate3d(0, 0, 0);
      }

      .about-image-frame {
        height: 470px;
        transform: none;
      }
    }

    @media (max-width: 575.98px) {
      .navbar > .container {
        min-height: 66px;
      }

      .navbar-brand img {
        max-height: 66px;
      }

      .topbar .container {
        align-items: flex-start !important;
        flex-direction: column;
        gap: .35rem !important;
      }

      .hero-video {
        height: 190px;
      }

      .about-visual {
        min-height: 430px;
      }

      .about-image-frame {
        height: 390px;
      }

      .about-image-frame:hover {
        transform: translateY(-5px);
      }

      .service-card:hover {
        transform: translateY(-7px);
      }

      #services .col-md-6:nth-child(-n+4) .service-card,
      #services .col-md-6:nth-child(n+5) .service-card {
        transform: translateY(26px);
      }

      .industry-card {
        min-height: 310px;
        padding: 2.2rem 1.5rem 1.8rem;
      }

      .industry-card:hover {
        transform: translateY(-7px);
      }

      .industry-icon {
        font-size: 39px;
        height: 102px;
        width: 102px;
      }

      .work-icon-wrap {
        height: 160px;
        width: 160px;
      }

      .work-icon-wrap::before {
        inset: 22px;
      }

      .work-icon {
        font-size: 39px;
      }

      .work-number {
        height: 40px;
        right: 0;
        top: 10px;
        width: 40px;
      }

      @keyframes workDotSpin {
        from {
          transform: rotate(0deg) translateX(58px) rotate(0deg);
        }

        to {
          transform: rotate(360deg) translateX(58px) rotate(-360deg);
        }
      }

      @keyframes iconDotSpin {
        from {
          transform: rotate(0deg) translateX(51px) rotate(0deg);
        }

        to {
          transform: rotate(360deg) translateX(51px) rotate(-360deg);
        }
      }

      .about-floating-card {
        bottom: 18px;
        left: 12px;
      }

      .about-image-caption {
        bottom: 120px;
        left: 18px;
        right: 18px;
      }

      .btn-ics,
      .btn-outline-ics {
        justify-content: center;
        width: 100%;
      }
    }

/* ── About Us Hero ───────────────────────────────────────────── */
.hero-about-us {
  position: relative;
  background-image: url('https://images.unsplash.com/photo-1581568736305-49a04e012c13?auto=format&fit=crop&w=1920&q=80');
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  min-height: 380px;
  display: flex;
  align-items: center;
}

.hero-about-us::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(var(--ics-navy-rgb), 0.68);
  z-index: 0;
}

.hero-about-title {
  font-size: clamp(2rem, 5vw, 3.2rem);
  letter-spacing: 0.5px;
}

.hero-about-breadcrumb .breadcrumb-item + .breadcrumb-item::before {
  color: rgba(255, 255, 255, 0.75);
  font-weight: 600;
}

.hero-about-breadcrumb .breadcrumb-item a:hover {
  color: var(--ics-gold) !important;
}

.service-detail-hero {
  align-items: center;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  display: flex;
  min-height: 420px;
  overflow: hidden;
  position: relative;
}

.service-detail-hero::before {
  background:
    linear-gradient(90deg, rgb(7 26 53 / 34%), rgba(var(--ics-navy-rgb), .6)),
    rgba(var(--ics-navy-rgb), .28);
  content: "";
  inset: 0;
  position: absolute;
  z-index: 0;
}

.service-detail-hero .lead {
  color: rgba(255, 255, 255, .86);
  max-width: 760px;
}

.service-list-panel {
  background: #fff;
  border: 1px solid rgba(var(--ics-gold-rgb), .18);
  border-radius: 8px;
  box-shadow: 0 18px 44px rgba(var(--ics-navy-rgb), .08);
  padding: 1.25rem;
  position: sticky;
  top: 112px;
}

.service-list-panel h2 {
  color: var(--ics-navy);
}

.service-detail-list {
  border-radius: 8px;
  gap: .55rem;
}

.service-detail-list .list-group-item {
  align-items: center;
  border: 1px solid var(--ics-line);
  border-radius: 8px;
  color: var(--ics-ink);
  display: flex;
  font-weight: 600;
  gap: .7rem;
  padding: .85rem 1rem;
  transition: background .25s ease, border-color .25s ease, color .25s ease, transform .25s ease;
}

.service-detail-list .list-group-item i {
  color: var(--ics-gold);
}

.service-detail-list .list-group-item:hover,
.service-detail-list .list-group-item:focus {
  border-color: rgba(var(--ics-gold-rgb), .42);
  color: var(--ics-navy);
  transform: translateX(4px);
}

.service-detail-list .list-group-item.active {
  background: var(--ics-navy);
  border-color: var(--ics-navy);
  color: #fff;
}

.service-detail-list .list-group-item.active i {
  color: var(--ics-gold);
}

.service-detail-content {
  background: #fff;
  border: 1px solid rgba(var(--ics-gold-rgb), .14);
  border-radius: 8px;
  box-shadow: 0 18px 48px rgba(var(--ics-navy-rgb), .08);
  padding: 1.25rem;
}

.service-detail-image {
  aspect-ratio: 16 / 8;
  border-radius: 8px;
  margin-bottom: 1.5rem;
  object-fit: cover;
  width: 100%;
}

.service-detail-content h2 {
  color: var(--ics-navy);
  margin-bottom: 1rem;
}

.service-benefit {
  align-items: flex-start;
  background: var(--ics-light);
  border: 1px solid var(--ics-line);
  border-radius: 8px;
  display: flex;
  gap: .7rem;
  height: 100%;
  padding: .95rem 1rem;
}

.service-benefit i {
  color: var(--ics-gold);
  flex: 0 0 auto;
  margin-top: .15rem;
}

.service-faq {
  max-width: 900px;
}

.service-faq .accordion-item {
  background: #fff;
  border: 1px solid rgba(var(--ics-gold-rgb), .16);
  border-radius: 8px;
  box-shadow: 0 14px 34px rgba(var(--ics-navy-rgb), .06);
  margin-bottom: 1rem;
  overflow: hidden;
}

.service-faq .accordion-button {
  color: var(--ics-navy);
  font-weight: 700;
  min-height: 58px;
}

.service-faq .accordion-button:not(.collapsed) {
  background: rgba(var(--ics-gold-rgb), .1);
  box-shadow: none;
  color: var(--ics-navy);
}

.service-faq .accordion-button:focus {
  border-color: var(--ics-gold);
  box-shadow: 0 0 0 4px rgba(var(--ics-gold-rgb), .14);
}

@media (max-width: 767.98px) {
  .hero-about-us {
    min-height: 260px;
    background-position: 60% center;
  }

  .hero-about-us .row {
    min-height: 220px !important;
  }

  .service-detail-hero {
    min-height: 320px;
  }

  .service-list-panel {
    position: static;
  }

  .service-detail-image {
    aspect-ratio: 16 / 10;
  }
}

@media (max-width: 575.98px) {
  .hero-about-us {
    min-height: 220px;
  }

  .hero-about-us .row {
    min-height: 180px !important;
  }
}

/* Blog Section */
.blog-section .blog-post-card {
  border: 1px solid rgba(var(--ics-gold-rgb), .18);
  box-shadow: 0 18px 45px rgba(var(--ics-navy-rgb), .08);
  transform-style: preserve-3d;
  transition: transform .38s ease, box-shadow .38s ease, border-color .38s ease;
}

.blog-section .blog-post-card:hover {
  border-color: rgba(var(--ics-gold-rgb), .75);
  box-shadow: 0 30px 80px rgba(var(--ics-navy-rgb), .18), 0 0 0 4px rgba(var(--ics-gold-rgb), .08);
  transform: perspective(900px) rotateX(4deg) rotateY(-5deg) translateY(-12px);
}

.blog-section .blog-post-card img {
  height: 200px;
  object-fit: cover;
}

.blog-section .blog-post-card .card-title a {
  color: var(--ics-navy);
  transition: color .25s ease;
}

.blog-section .blog-post-card .card-title a:hover,
.blog-section .blog-post-card .card-title a:focus {
  color: var(--ics-gold);
}

.blog-section .blog-post-card .btn-outline-dark {
  --bs-btn-color: var(--ics-navy);
  --bs-btn-border-color: var(--ics-line);
  --bs-btn-hover-bg: var(--ics-navy);
  --bs-btn-hover-color: #fff;
}

/* Gallery Section */
.gallery-section .gallery-item {
  position: relative;
  overflow: hidden;
  border-radius: 8px;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.gallery-section .gallery-item:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 25px rgba(0, 0, 0, 0.2);
}

.gallery-section .gallery-item img {
  width: 100%;
  height: 250px; /* Fixed height for consistency */
  object-fit: cover;
  transition: transform 0.3s ease;
}

.gallery-section .gallery-item:hover img {
  transform: scale(1.05);
}

.gallery-section .gallery-caption {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.7), rgba(0, 0, 0, 0));
  color: #fff;
  padding: 15px;
  text-align: center;
  opacity: 0; /* Hidden by default */
  transition: opacity 0.3s ease;
}

.gallery-section .gallery-item:hover .gallery-caption {
  opacity: 1;
}

.gallery-section .gallery-caption h5 {
  margin-bottom: 0;
  color: #fff;
  font-size: 1.1rem;
}

/* Modal Carousel Styling */
#imageModal .modal-content {
  background-color: rgba(0, 0, 0, 0.8);
  border: none;
}

#imageModal .modal-header {
  border-bottom: none;
  padding: 1rem 1.5rem 0.5rem;
}

#imageModal .modal-title {
  color: #fff;
}

#imageModal .btn-close {
  filter: invert(1);
}

#imageModal .carousel-item img {
  max-height: 80vh; /* Limit image height in modal */
  width: auto;
  margin: auto;
  display: block;
  object-fit: contain;
}

#imageModal .carousel-caption {
  background-color: rgba(0, 0, 0, 0.5);
  padding: 10px 15px;
  border-radius: 5px;
  bottom: 20px;
}

#imageModal .carousel-caption h5 {
  font-size: 1.2rem;
}

/* Contact Section */
.map-responsive {
    overflow: hidden;
    padding-bottom: 56.25%; /* 16:9 aspect ratio */
    position: relative;
    height: 0;
}
.map-responsive iframe {
    left: 0;
    top: 0;
    height: 100%;
    width: 100%;
    position: absolute;
    border-radius: 8px;
}
.contact-section .card {
    border: 1px solid var(--ics-line);
    border-radius: 8px;
    box-shadow: 0 14px 35px rgba(var(--ics-navy-rgb), .06);
}
.contact-section .card i {
    font-size: 1.1rem;
}

#imageModal .carousel-control-prev-icon,
#imageModal .carousel-control-next-icon {
  background-color: rgba(255, 255, 255, 0.2);
  border-radius: 50%;
  padding: 15px;
}

/* ── Journey Section ─────────────────────────────────────────── */
.journey-text-col {
  border-right: 2px solid var(--ics-line);
  padding-right: 2.5rem;
}

.journey-list {
  list-style: none;
  padding: 0;
  margin: 0 0 1.25rem;
}

.journey-list li {
  position: relative;
  padding-left: 1.4rem;
  color: var(--ics-muted);
  font-size: 0.97rem;
  line-height: 1.7;
}

.journey-list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.62em;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--ics-ink);
}

@media (max-width: 991.98px) {
  .journey-text-col {
    border-right: none;
    border-bottom: 2px solid var(--ics-line);
    padding-right: 0;
    padding-bottom: 2rem;
  }
}

/* ── Housekeeping Services ───────────────────────────────────── */
.hk-card {
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 14px;
  padding: 2rem 2.2rem;
}

.hk-card-title {
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--ics-ink);
  margin-bottom: 1.5rem;
}

.hk-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.hk-list li {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  padding: 0.6rem 0;
  color: var(--ics-ink);
  font-size: 0.97rem;
  border-bottom: 1px solid #f3f4f6;
}

.hk-list li:last-child {
  border-bottom: none;
}

.hk-list li i {
  color: var(--ics-gold);
  font-size: 1.15rem;
  flex-shrink: 0;
  font-weight: 700;
}

.hk-tagline {
  color: var(--ics-muted);
  font-size: 0.9rem;
  margin-top: 1.25rem;
  margin-bottom: 0;
}

.hk-banner {
  background: linear-gradient(135deg, rgba(var(--ics-gold-rgb), .07) 0%, #fff 100%);
  border: 1.5px solid rgba(var(--ics-gold-rgb), .45);
  border-radius: 16px;
  padding: 2.5rem 2rem;
  text-align: center;
}

.hk-banner-title {
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--ics-ink);
  margin-bottom: 0.5rem;
}

.hk-banner-text {
  color: var(--ics-muted);
  font-size: 0.97rem;
  max-width: 560px;
  margin: 0 auto;
}

@media (max-width: 575.98px) {
  .hk-card {
    padding: 1.5rem;
  }

  .hk-banner {
    padding: 1.75rem 1.25rem;
  }
}

/* ── Mission Vision Values ───────────────────────────────────── */
.mvv-card {
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 14px;
  padding: 2rem;
}

.mvv-card--featured {
  border: 1.5px solid rgba(var(--ics-gold-rgb), .55);
}

.mvv-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  background: var(--ics-navy);
  border-radius: 10px;
  color: #fff;
  font-size: 1.35rem;
  margin-bottom: 1.2rem;
}

.mvv-heading {
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--ics-ink);
  margin-bottom: 0.75rem;
}

.mvv-text {
  color: var(--ics-muted);
  font-size: 0.97rem;
  line-height: 1.7;
  margin-bottom: 0;
}

.mvv-values {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.mvv-value-row {
  display: flex;
  align-items: baseline;
  gap: 0.75rem;
  padding: 0.75rem 1rem;
  background: rgba(var(--ics-gold-rgb), .07);
  border-left: 3px solid var(--ics-gold);
  border-radius: 0 8px 8px 0;
}

.mvv-value-row strong {
  color: var(--ics-ink);
  font-weight: 700;
  white-space: nowrap;
  min-width: 95px;
  flex-shrink: 0;
}

.mvv-value-row span {
  color: var(--ics-muted);
  font-size: 0.93rem;
}

@media (max-width: 575.98px) {
  .mvv-card {
    padding: 1.5rem;
  }

  .mvv-value-row {
    flex-wrap: wrap;
    gap: 0.25rem;
  }

  .mvv-value-row strong {
    min-width: unset;
  }
}
