:root {
    --bg: #e9e9e9;
    --card: #ffffff;
    --text: #0f0f0f;
    --muted: #6a6a6a;
    --line: #dddddd;
    --shadow: 0 2px 10px rgba(0, 0, 0, .06);
    --r: 6px;
    --green: #c9cf2e;
    --teal: #25b8b6;
    --yellow: #c9cf2e;
    --brand: #2aa86c;
}

/* Basic */
.cu {
    font-family: "Manrope", sans-serif;
}

.cu img {
    max-width: 100%;
    display: block;
}

.cu a {
    color: inherit;
    text-decoration: none;
}

.cu a:hover {
    text-decoration: underline;
}

/* Page heading */
.cu-title {
    font-size: 48px;
    color: #0F6464;
    margin: 28px 0 20px;
}

/* Breadcrumb */
.breadcrumb li {
    font-size: 14px;
    color: #8b8989;
    margin-right: 6px;
    list-style-type: none;
}

.breadcrumb li a {
    color: #000000;
    transition: all .3s ease;
}

.breadcrumb li a:hover {
    color: #0f6464;
}

/* HERO */
.cu-hero__grid {
    display: grid;
    grid-template-columns: 0.8fr 1.15fr;
    gap: 0;
}

.cu-hero__photo {
    overflow: hidden;
    border-radius: 10px 0 0 10px;
}

.cu-hero__photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.cu-hero__panel {
    position: relative;
    background: var(--green);
    border-radius: 0 10px 10px 0;
    overflow: hidden;
}

.cu-hero__panel-inner {
    position: relative;
    padding: 36px 51px 22px 34px;
    min-height: 100%;
}

.cu-hero__panel-title {
    font-size: 34px;
    font-weight: 800;
    margin: 0 0 20px;
    color: #0a7a5b;
}

.cu-hero__panel-text {
    margin: 0;
    max-width: 530px;
    color: #1a1a1a;
    position: relative;
    z-index: 10;
}

.cu-hero__panel-brand {
    position: absolute;
    left: 34px;
    bottom: 40px;
}

.cu-hero__panel-brand img {
    max-width: 170px;
}

.cu-hero__map {
    position: absolute;
    right: 50px;
    bottom: 22px;
    max-width: 380px;
    height: auto;
}

/* FEATURES */
.cu-features {
    display: flex;
    gap: 30px;
    align-items: center;
    padding: 25px 0 28px;
    flex-wrap: nowrap;
}

.cu-feature {
    display: flex;
    gap: 7px;
    align-items: center;
}

.cu-feature__icon img {
    display: block;
}

.cu-feature__txt {
    color: #0F6464;
    font-size: 16px;
    line-height: 120%;
    font-weight: 700;
}

.cu-feature-img {
    display: flex;
    align-items: center;
    column-gap: 43px;
    padding-left: 10px;
}

.cu-feature-img img {
    height: 34px;
    width: auto;
}

/* SUPPORT SECTION */
.cu-support {
    background: var(--bg);
    padding: 48px 0 70px;
}

.cu-h2 {
    font-size: 24px;
    font-weight: 800;
    line-height: 120%;
    color: #0a7a5b;
    margin: 0 0 30px;
}

/* IMPORTANT: tumhare HTML me ask + cards direct children hain,
     isliye grid 4-col (desktop) theek rahega */
.cu-support__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 14px;
    align-items: stretch;
}

.cu-support__ask {
    background: var(--teal);
    border-radius: var(--r);
    padding: 18px;
    display: flex;
    align-items: center;
    box-shadow: var(--shadow);
    min-height: 212px;
    /* cards ke barabar feel */
}

.cu-support__ask p {
    margin: 0;
    color: #fff;
    font-size: 34px;
    font-weight: 800;
    line-height: 120%;
}

/* Card */
.cu-card {
    background: #fff;
    border-radius: var(--r);
    box-shadow: var(--shadow);
    padding: 12px 12px 10px;
    min-height: 212px;
    display: flex;
    flex-direction: column;
}

.cu-card__title {
    font-size: 20px;
    line-height: 120%;
    font-weight: 800;
    color: #0a7a5b;
    margin: 0 0 27px;
    min-height: 48px;
    /* title height match */
}

.cu-card__line {
    display: flex;
    gap: 10px;
    align-items: flex-start;
    font-size: 16px;
    color: #3a3a3a;
    padding: 11px 0;
    border-top: 1px solid #efefef;
}

.cu-card__line:first-of-type {
    border-top: 0;
}

.img-icon {
    width: 22px;
    min-width: 22px;
    height: 22px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.img-icon img {
    width: 18px;
    height: 18px;
    object-fit: contain;
}

/* multiline links */
.call-link,
.mail-call {
    display: block;
    line-height: 1.25;
}

.cu-card__line a {
    font-size: 16px;
    line-height: 120%;
    color: #2b2b2b;
    font-weight: 500;
}

/* LOCATION SECTION */
.location-sec {
    padding: 60px 0 40px;
}

.location-sec .row {
	all: unset;
    display: flex;
    gap: 18px;
}

.row>* {
all: unset;
}

.location-sec .col-left {
    width: 75%;
}

.location-sec .col-right {
    width: 25%;
    padding-top: 50px;
}

.location-sec .col-left h2 {
    color: #0F6464;
    font-size: 34px;
    font-weight: 800;
    line-height: 120%;
    margin: 0;
}

.location-sec .col-left p {
    display: flex;
    align-items: center;
    column-gap: 6px;
    margin: 10px 0 21px;
    flex-wrap: wrap;
}

.location-sec .col-left p span {
    color: #0a7a5b;
    font-weight: 800;
}

/* collage part (same system tumhare HTML ke hisaab se) */
.location-sec .inner-row,
.location-sec .inner-row2 {
    display: flex;
    gap: 8px;
}

.location-sec .inner-row2 {
    margin-top: 8px;
}

.location-sec .inner-col img,
.location-sec .inner_col img {
    border-radius: 6px;
    width: 100%;
    height: auto;
}

.location-sec .inner-col {
    flex: 1;
}

.location-sec .inner_col {
    flex: 1;
}

.location-sec .img-box {
    display: flex;
    gap: 8px;
    max-height: 132px;
}

.location-sec .img-box img {
    flex: 1;
}

/* map + yellow box */
.map-row {
    display: flex;
    gap: 8px;
    margin-top: 8px;
}

.map-row .map-box {
    width: 58%;
    height: 250px;
    overflow: hidden;
    border-radius: 6px;
}

.map-row .map-box img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 10px;
}

.map-row .text-right {
    width: 42%;
    background-color: #D5CB2C;
    border-radius: 10px;
    padding: 20px 28px 16px;
}

.map-row span {
    color: #0a7a5b;
    font-weight: 800;
}

.map-row h3 {
    font-size: 24px;
    font-weight: 800;
    margin: 10px 0;
}

.map-row .email {
    line-height: 1.4;
    display: block;
}

.map-row .text-right span a {
    color: #0B57D0;
}

.contact-text {
    margin-top: 8px;
    padding-top: 8px;
    border-top: 1px solid #fff;
}

.map-row .text-right h4 {
    font-weight: 800;
    margin: 6px 0;
}

.map-row .text-right p {
    margin: 0;
    font-size: 14px;
}

.map-row .text-right p strong {
    color: #0a7a5b;
}

/* Right cards */
.location-sec .col-right .title {
    font-size: 24px;
    font-weight: 800;
    line-height: 120%;
    color: #0a7a5b;
    margin-bottom: 16px;
}

.location-sec .box {
    padding: 8px;
    border: 1px solid #ddd;
    border-radius: 6px;
    margin-bottom: 8px;
}

.location-sec .box:last-child {
    margin-bottom: 0;
}

.location-sec .box .sub-title {
    font-weight: 800;
}

.location-sec .box .location-text {
    display: flex;
    align-items: flex-start;
    column-gap: 6px;
    font-size: 14px;
    color: #000000;
    margin: 4px 0 6px;
}

.location-text img {
    margin-top: 4px;
}

.small-map {
    border-radius: 6px;
    overflow: hidden;
    flex: 1;
}

.team-img-wrapper {
    flex: 1;
}

.location-sec .box .img-box img {
    width: 100%;
    border-radius: 6px;
    height: 100%;
    object-fit: cover;
}

.location-sec .box .office-number {
    margin: 6px 0 6px;
    padding-bottom: 6px;
    border-bottom: 1px solid #D9D9D9;
    font-size: 14px;
}

.location-sec .box .office-number span {
    font-weight: 800;
    color: #0a7a5b;
    display: block;
    margin-bottom: 4px;
}

.location-sec .box .office-number a {
    color: #000000;
}

.location-sec .box .office-address {
    line-height: 130%;
    font-size: 14px;
}

.location-sec .box .office-address strong {
    display: block;
    color: #0a7a5b;
    font-weight: 800;
}

/* =========================
   1) DESKTOP (>= 1200 / 1440)
   ========================= */
@media (min-width: 1200px) {

    /* HERO */
    .cu-hero__grid {
        grid-template-columns: 0.8fr 1.15fr;
    }

    .cu-hero__photo {
        border-radius: 10px 0 0 10px;
    }

    .cu-hero__panel {
        border-radius: 0 10px 10px 0;
    }

    .cu-hero__panel-inner {
        padding: 36px 51px 22px 34px;
    }

    .cu-hero__panel-title {
        font-size: 34px;
        margin-bottom: 15px;
    }

    .cu-hero__panel-brand {
        position: absolute;
        left: 34px;
        bottom: 40px;
    }

    .cu-hero__map {
        position: absolute;
        right: 50px;
        bottom: 22px;
        max-width: 420px;
    }

    /* FEATURES row same line */
    .cu-features {
        flex-wrap: nowrap;
        gap: 30px;
    }

    .cu-feature-img {
        margin-left: auto;
        padding-left: 10px;
        column-gap: 16px;
    }

    /* SUPPORT (4 columns like PDF) */
    .cu-support__grid {
        grid-template-columns: repeat(4, 1fr);
    }

    .cu-support__ask {
        min-height: 212px;
    }

    .cu-support__ask p {
        font-size: 34px;
    }

    .cu-support__ask p br {
        display: none;
    }

    .location-sec .row {
        flex-direction: row;
        gap: 18px;
    }

    .location-sec .col-left {
        width: 75%;
    }

    .location-sec .col-right {
        width: 25%;
        padding-top: 50px;
    }

    /* Map row side-by-side */
    .map-row {
        flex-direction: row;
    }

    .map-row .map-box {
        width: 58%;
    }

    .map-row .text-right {
        width: 42%;
        padding: 20px 28px 16px;
    }

    .cu-feature-img {
        column-gap: 18px;
    }
}


/* =========================
   2) TABLET (768 - 1199)
   ========================= */
@media (max-width: 1200px) and (min-width: 768px) {

    /* HERO: keep 2 columns till 992, but safe stacking if narrow */
    .cu-hero__grid {
        grid-template-columns: 1fr 1fr;
    }

    .cu-hero__panel-inner {
        padding: 28px 24px 18px 20px;
    }

    .cu-hero__panel-title {
        font-size: 28px;
        margin-bottom: 14px;
    }

    .cu-hero__panel-brand {
        position: absolute;
        left: 20px;
        bottom: 18px;
    }

    .cu-hero__panel-brand img {
        max-width: 150px;
    }

    .cu-hero__map {
        position: absolute;
        right: 16px;
        bottom: 12px;
        max-width: 320px;
    }

    /* FEATURES: wrap properly */
    .cu-features {
        flex-wrap: wrap;
        gap: 18px;
    }

    .cu-feature-img {
        padding-left: 0;
        column-gap: 18px;
    }

    /* SUPPORT: 2 columns, ASK full width on top */
    .cu-support__grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .cu-support__ask {
        grid-column: 1 / -1;
        min-height: auto;
    }

    .cu-support__ask p {
        font-size: 28px;
    }

    /* LOCATION: stack columns (better tablet UX) */
    .location-sec .row {
        flex-direction: column;
    }

    .location-sec .col-left,
    .location-sec .col-right {
        width: 100%;
    }

    .location-sec .col-right {
        padding-top: 14px;
    }

    /* Collage: 2 columns */
    .location-sec .inner-row,
    .location-sec .inner-row2 {
        flex-wrap: nowrap;
    }

    .location-sec .inner-col,
    .location-sec .inner_col {
        width: 50%;
        flex: 0 0 50%;
    }

    /* Map row stack */
    .map-row {
        flex-direction: column;
    }

    .map-row .map-box,
    .map-row .text-right {
        width: 100%;
    }

    .map-row .text-right {
        padding: 16px;
    }

    /* Wrapping */
    .call-link,
    .mail-call {
        word-break: break-word;
    }

    .location-sec .inner-box {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 10px;
    }
}


/* =========================
   3) MOBILE (<= 767) (includes 414)
   ========================= */
@media (max-width: 767px) {

    /* HERO stack */
    .cu-title {
        font-size: 34px;
    }

    .cu-hero__grid {
        grid-template-columns: 1fr;
    }

    .cu-hero__photo {
        border-radius: 10px;
    }

    .cu-hero__panel {
        border-radius: 10px;
    }

    .cu-hero__panel-inner {
        padding: 22px 18px 18px;
    }

    /* make brand + map non-overlap */
    .cu-hero__panel-brand {
        position: static;
        margin-top: 12px;
    }

    .cu-hero__map {
        position: static;
        margin-top: 10px;
        max-width: 100%;
    }

    .cu-hero__panel-title {
        font-size: 26px;
        margin-bottom: 12px;
    }

    /* FEATURES wrap */
    .cu-features {
        flex-wrap: wrap;
        gap: 14px;
        padding: 18px 0 22px;
    }

    .cu-feature-img {
        width: 100%;
        padding-left: 0;
        column-gap: 18px;
    }

    /* SUPPORT: 1 column */
    .cu-support__grid {
        grid-template-columns: 1fr;
    }

    .cu-support__ask {
        min-height: auto;
    }

    .cu-support__ask p {
        font-size: 20px;
    }

    .cu-support__ask p br {
        display: none;
    }

    .cu-card__title {
        font-size: 18px;
        margin-bottom: 16px;
        min-height: auto;
    }

    .cu-card__line {
        font-size: 14px;
        align-items: flex-start;
    }

    .cu-card__line a {
        font-size: 14px;
    }

    .call-link,
    .mail-call {
        word-break: break-word;
    }

    .location-sec .row {
        flex-direction: column;
    }

    .location-sec .col-left,
    .location-sec .col-right {
        width: 100%;
    }

    .location-sec .col-right {
        padding-top: 12px;
    }

    .location-sec .inner-row,
    .location-sec .inner-row2 {
        flex-direction: column;
    }

    .map-row {
        flex-direction: column;
    }

    .map-row .map-box,
    .map-row .text-right {
        width: 100%;
    }

    .map-row .text-right {
        padding: 16px;
    }

    .cu-title {
        font-size: 29px;
        margin: 10px 0;
    }

    .img-row {
        display: flex;
        align-items: center;
        flex-direction: column-reverse;
    }

    .cu-support {
        padding: 30px 0;
    }

    .cu-h2 {
        font-size: 22px;
        margin: 0 0 20px;
    }

    .location-sec {
        padding: 30px 0 30px;
    }

    .location-sec .col-left h2 {
        font-size: 24px;
    }

    .location-sec .col-left p {
        line-height: 1.8;
        font-size: 14px;
    }

    .map-row h3 {
        font-size: 20px;
        margin: 8px 0;
    }

    .location-sec .col-right .title {
        font-size: 22px;
    }
}

@media (max-width:400px) {
    .cu-feature-img {
        column-gap: 4px;
    }
}
