/* Contact page hero */
.contact-hero { position: relative; padding: calc(var(--header-height) + 80px) 0 80px; color: #fff; background-size: cover; background-position: center; background-repeat: no-repeat; overflow: hidden; }
.contact-hero__overlay { position: absolute; inset: 0; background: rgba(8, 18, 30, 0.405); z-index: 1; }
.contact-hero__inner { position: relative; z-index: 2; display: flex; align-items: center; }
.contact-hero .common-title { color: #fff; max-width: 980px; }
.contact-hero .common-title__heading { color: #fff; font-size: clamp(30px, 4.6vw, 56px); line-height: 1.02; margin-bottom: 12px; }
.contact-hero .common-title__text { color: rgba(255,255,255,0.92); margin-bottom: 18px; max-width: 820px; font-size: 16px; line-height: 1.7; }
.contact-hero__actions { display: flex; gap: 12px; align-items: center; margin-top: 8px; }
@media (max-width: 992px) { .contact-hero__inner { padding: 0 20px; } .contact-hero { padding: calc(var(--header-height) + 60px) 0 60px; } }
@media (max-width: 640px) { .contact-hero { padding: calc(var(--header-height) + 40px) 0 40px; } .contact-hero .common-title__heading { font-size: clamp(22px, 6vw, 36px); } .contact-hero__inner { min-height: auto; } }

/* Services structured features */
.services-structured { padding: 72px 0;  color: #102233; }
.services-structured__inner { display: grid; grid-template-columns: 1fr 640px; gap: 40px; align-items: start; }
.services-structured .common-title__heading { color: #102233; font-size: clamp(28px, 3.6vw, 42px); margin-bottom: 14px; }
.services-structured .common-title__text { color: rgba(16,34,51,0.9); margin-bottom: 12px; font-size: 16px; line-height: 1.7; }
.features-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.feature { background: #fff; border: 1px solid rgba(16,34,51,0.06); padding: 18px; display: flex; gap: 12px; align-items: center; border-radius: 8px; }
.feature__icon { width: 56px; height: 56px; display: flex; align-items: center; justify-content: center; flex: 0 0 56px; }
.feature__icon svg { width: 36px; height: 36px; display: block; }
.feature__label { font-weight: 600; color: #102233; font-size: 15px; }
@media (max-width: 992px) {.services-structured__inner { grid-template-columns: 1fr 520px; padding: 0 20px; }}
@media (max-width: 768px) {.services-structured__inner { grid-template-columns: 1fr; }.features-grid { grid-template-columns: repeat(2, 1fr); margin-top: 18px; }}
@media (max-width: 420px) {.features-grid { grid-template-columns: 1fr; }	.feature { padding: 14px; }}

/* Flexible Engagement Models */
.flexible-engagement { padding: 56px 0;}
.flexible-engagement__heading { text-align: center; font-size: clamp(20px, 2.4vw, 26px); color: #102233; margin-bottom: 28px; }
.engage-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.engage-card { background: #fff; border: 1px solid rgba(16,34,51,0.06); padding: 22px;  border-radius: 4px; text-align: left; }
.engage-card__title { font-size: 18px; color: #102233; margin-bottom: 10px; font-weight: 600; position: relative; padding-bottom: 10px; }
.engage-card__title::after { content: ""; display: block; width: 100%; height: 1px; background: rgba(16,34,51,0.12); margin: 15px auto 0; }
.engage-card__text { color: rgba(16,34,51,0.85); line-height: 1.6; font-size: 16px; }
@media (max-width: 992px) { .engage-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .engage-grid { grid-template-columns: 1fr; } }

/* Representative Engagements */
.representative-engagements { padding: 48px 0; }
.rep-heading { text-align: center; font-size: clamp(18px, 2.2vw, 27px); margin-bottom: 25px; color: #102233; }
.rep-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 22px; align-items: start; }
.rep-cta { position: relative; border-radius: 6px; min-height: 220px; display:flex; align-items:center; overflow: hidden; }
.rep-cta__bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; z-index: 0; }
.rep-cta__inner { padding: 28px; color: #fff; position: relative; z-index: 1; }
.rep-list { min-width: 0; }
.rep-cta__title { font-size: 25px; margin-bottom: 20px; color: #fff;}
.rep-cta__btn { display: inline-block; background: #d9c38a; color: #082034; padding: 10px 16px; border-radius: 4px; text-decoration: none; font-weight: 600; }
.rep-list { background: #fff; border: 1px solid rgba(16,34,51,0.04); padding: 18px; border-radius: 6px; }
.rep-list__heading { font-size: clamp(18px, 2.2vw, 25px); color: #102233; margin: 0 0 12px; padding-bottom: 10px; position: relative; }
.rep-list__heading::after { content: ""; display: block; width: 100%; height: 1px; background: rgba(16,34,51,0.08); margin-top: 6px; }
.rep-list__cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.rep-list__cols ul { list-style: none; margin: 0; padding: 0; color: #102233; }
.rep-list__cols li { padding: 10px 0; border-bottom: 1px solid rgba(16,34,51,0.03); font-size: 14px; }

@media (max-width: 992px) { .rep-grid { grid-template-columns: 1fr; } .rep-list__cols { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .rep-list__cols { grid-template-columns: 1fr; } }


/* Services detail blocks */
.services-details { padding: 12px 0 70px; }
.service-item { display: flex; gap: 32px; align-items: center; margin-bottom: 56px; }
.service-item--reverse { flex-direction: row-reverse; }
.service-item__content { flex: 1 1 50%; min-width: 0; }
.service-item__content h3 { font-size: clamp(20px, 2.6vw, 28px); margin-bottom: 12px; color: #102233; }
.service-item__content p { color: rgba(16,34,51,0.9); margin-bottom: 12px; line-height: 1.6; }
.service-item__list { margin: 0 0 0 18px; padding: 0; color: rgba(16,34,51,0.9); }
.service-item__list li { margin-bottom: 8px; }
.service-item__media { flex: 1 1 50%; min-width: 0; }
.service-item__media img { width: 100%; height: 350px; display: block; }
@media (max-width: 992px) { .service-item__media { flex: 1 1 50%; } }
@media (max-width: 768px) { .service-item { flex-direction: column; } .service-item--reverse { flex-direction: column; } .service-item__media { width: 100%; } }

/* Services trigger section */
.services-trigger {  position: relative; overflow: hidden; padding: 14px 0 20px; color: #fff;
     background:
        linear-gradient(rgba(255,255,255,0.035) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.035) 1px, transparent 1px),
        radial-gradient(circle at 50% 0%, rgba(42,78,117,0.55), transparent 38%),
        linear-gradient(90deg, #081626 0%, #142842 50%, #081626 100%);}
.services-trigger::before { content: ""; position: absolute; inset: 0; pointer-events: none; opacity: 0.5;}
.services-trigger .container { position: relative; z-index: 1; }
.services-trigger__title { margin: 0 0 30px; color: #fff; text-align: center; font-size: clamp(18px, 2vw, 27px); font-weight: 400; line-height: 1.15; letter-spacing: -0.2px;}
.services-trigger__grid { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); align-items: stretch;}
.services-trigger__item { position: relative; display: flex; flex-direction: column; align-items: center; justify-content: flex-start; min-height: 76px; padding: 0 20px; text-align: center;}
.services-trigger__item:not(:last-child)::after { content: ""; position: absolute; top: 12px; right: 0; width: 1px; height: 52px;  background: rgba(255,255,255,0.13);}
.services-trigger__icon { width: 44px; height: 44px; color: rgba(255,255,255,0.72); display: flex; align-items: center; justify-content: center; margin-bottom: 7px;}
.services-trigger__icon svg { width: 100%; height: 100%; display: block;}
.services-trigger__item p { max-width: 150px; margin: 0;  color: rgba(255,255,255,0.92);}
@media (max-width: 992px) {
    .services-trigger { padding: 26px 0; }
    .services-trigger__grid { grid-template-columns: repeat(3, minmax(0, 1fr)); row-gap: 24px; }
    .services-trigger__item:nth-child(3)::after { display: none; }}
@media (max-width: 640px) {
    .services-trigger__grid { grid-template-columns: 1fr; gap: 18px; }
    .services-trigger__item { min-height: auto; padding: 0; }
    .services-trigger__item:not(:last-child)::after { display: none; }
    .services-trigger__item p { max-width: none; }}
