﻿/* ============================================================
   PAGE WRAPPER
============================================================ */
main.campus-page {
    display: grid;
    align-content: flex-start;
}

/* ============================================================
   NAV GRADIENT OVERLAY
============================================================ */
.ap-nav-gradient {
    top: 0;
    left: 0;
    width: 100%;
    height: 176px;
    background: linear-gradient(180deg, rgba(0, 0, 0, 0.40) 0%, rgba(0, 0, 0, 0.30) 100%);
    pointer-events: none;
    z-index: 999;
}

/* ============================================================
   SECTION 1 — HERO
============================================================ */
.campus-hero {
    background: url('/Files/templates/main-2026/images/big_v.svg') center top no-repeat;
    background-size: 100% auto;
    position: relative;
    max-width: 1440px;
    margin: 0 auto;
}

.campus-hero__inner {
    padding-top: 48px;
    padding-bottom: 48px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 72px;
    align-items: start;
}

.campus-hero__title {
    color: var(--vcc-midnight-violet, #2C1224);
    margin-bottom: 8px;
}

.campus-hero__tagline {
    font-family: "Outfit-Light";
    font-size: var(--font-lead, 20px);
    line-height: var(--lh-lead, 150%);
    color: var(--vcc-shadow-grey, #272932);
    margin: 0 0 24px;
}

.campus-hero__body,
.campus-hero__body p {
    font-family: "Outfit-Regular";
    font-size: var(--font-p, 18px);
    line-height: var(--lh-p, 130%);
    color: var(--vcc-shadow-grey, #272932);
    margin: 0 0 16px;
}

    .campus-hero__body p:last-child {
        margin-bottom: 0;
    }

.campus-hero__media {
    position: relative;
}

.campus-hero__photo {
    display: block;
    width: 100%;
    height: auto;
    object-fit: cover;
}

/* ============================================================
   960px — HERO MOBILE
============================================================ */
@media only screen and (max-width: 960px) {

    .ap-nav-gradient {
        display: none;
    }

    .campus-hero__inner {
        display: flex;
        flex-direction: column;
        gap: 0px;
        padding-top: 32px;
        padding-bottom: 40px;
    }

    .campus-hero__content {
        display: contents;
    }

    .campus-hero__title {
        order: 1;
    }

    .campus-hero__tagline {
        order: 2;
    }

    .campus-hero__media {
        order: 3;
        margin-bottom: 24px;
    }

    .campus-hero__body {
        order: 4;
    }
}

/* Hide default Google Maps InfoWindow close button */
.gm-ui-hover-effect {
    display: none !important;
}

/* ============================================================
   SECTION 2 — PROGRAMS
============================================================ */
.campus-programs {
    background: linear-gradient(0deg, rgba(44, 18, 36, 0.10) 0%, rgba(44, 18, 36, 0.10) 100%), #FBF9FF;
    max-width: 1440px;
    margin: 0 auto;
}

.campus-programs__inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    min-height: 560px;
}

.campus-programs__image {
    width: 100%;
    height: 100%;
    overflow: hidden;
}

    .campus-programs__image img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: center top;
        display: block;
    }

.campus-programs__content {
    padding: 64px 48px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 16px;
}

.campus-programs__eyebrow {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 32px;
    padding: 0 22px 0 15px;
    font-family: "Outfit-Medium";
    font-size: 15px;
    font-weight: 500;
    line-height: 100%;
    letter-spacing: 0.9px;
    text-transform: uppercase;
    color: var(--vcc-shadow-grey, #272932);
    background: #C5CACF;
    clip-path: polygon(0% 0%, 100% 0%, calc(100% - 10px) 100%, 0% 100%);
    align-self: flex-start;
}

.campus-programs__content h2 {
    color: var(--vcc-midnight-violet, #2C1224);
    margin: 0;
}

.campus-programs__text,
.campus-programs__text p {
    font-family: "Outfit-Light";
    font-size: var(--font-lead, 24px);
    line-height: var(--lh-lead, 150%);
    color: var(--vcc-shadow-grey, #272932);
    margin: 0;
}

.campus-programs__list {
    list-style: none;
    padding: 0;
    margin: 8px 0;
    display: flex;
    flex-direction: column;
    gap: 0;
}

.campus-programs__item {
    border-bottom: 4px solid rgba(116, 131, 134, 0.20);
    background: #FBF9FF;
}

    .campus-programs__item:first-child {
        border-top: 1px solid rgba(116, 131, 134, 0.20);
    }

    .campus-programs__item a {
        display: grid;
        grid-template-columns: 24px 1fr 16px;
        gap: 16px;
        align-items: center;
        padding: 16px;
        color: var(--Midnight-Violet, #2C1224);
        text-decoration: none;
        transition: color 0.2s;
    }

        .campus-programs__item a:hover {
            color: var(--vcc-carmine, #BE1E2D);
        }

        .campus-programs__item a span {
            font-family: "Outfit-Regular";
            font-size: var(--font-p, 18px);
            line-height: var(--lh-p, 130%);
            text-decoration: underline;
        }

        .campus-programs__item a i[data-lucide="graduation-cap"] {
            width: 24px;
            height: 24px;
            color: var(--vcc-midnight-violet, #2C1224);
            flex-shrink: 0;
        }

        .campus-programs__item a i[data-lucide="chevron-right"] {
            width: 16px;
            height: 16px;
            color: var(--vcc-state-grey, #748386);
            flex-shrink: 0;
            justify-self: end;
        }

.campus-programs__all {
    font-family: "Outfit-Regular";
    font-size: var(--font-sm, 15px);
    color: var(--vcc-shadow-grey, #272932);
    margin: 0;
}

    .campus-programs__all a {
        color: var(--vcc-shadow-grey, #272932);
        text-decoration: underline;
    }

        .campus-programs__all a:hover {
            color: var(--vcc-carmine, #BE1E2D);
        }

/* ============================================================
   SECTION 3 — CONTACT + MAP
============================================================ */
.campus-contact {
    background: #FBF9FF;
    max-width: 1440px;
    margin: 0 auto;
}

.campus-contact__inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    min-height: 500px;
}

.campus-contact__info {
    padding-top: 64px;
    padding-bottom: 64px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.campus-contact__eyebrow {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 32px;
    padding: 0 22px 0 15px;
    font-family: "Outfit-Medium";
    font-size: 15px;
    font-weight: 500;
    line-height: 100%;
    letter-spacing: 0.9px;
    text-transform: uppercase;
    color: var(--vcc-shadow-grey, #272932);
    background: #C5CACF;
    clip-path: polygon(0% 0%, 100% 0%, calc(100% - 10px) 100%, 0% 100%);
    align-self: flex-start;
    margin-bottom: 16px;
    margin-left: 0;
}

.campus-contact__info h2 {
    color: var(--vcc-midnight-violet, #2C1224);
    margin: 0;
}

.campus-contact__body,
.campus-contact__body p {
    font-family: "Outfit-Regular";
    font-size: var(--font-p, 18px);
    line-height: var(--lh-p, 130%);
    color: var(--vcc-shadow-grey, #272932);
}

.campus-contact__body {
    margin: 24px 0;
}

.campus-contact__address {
    font-family: "Outfit-Regular";
    font-size: var(--font-p, 18px);
    line-height: 1.8;
    color: var(--vcc-shadow-grey, #272932);
}

    .campus-contact__address strong {
        display: block;
        font-family: "Outfit-SemiBold";
        color: var(--vcc-midnight-violet, #2C1224);
        margin-bottom: 16px;
    }

    .campus-contact__address p {
        margin: 0;
        font-weight: 400;
    }

.campus-contact__phone {
    color: var(--vcc-shadow-grey, #272932);
    font-weight: 700;
    text-decoration: underline;
}

    .campus-contact__phone:hover {
        color: var(--vcc-carmine, #BE1E2D);
    }

.campus-contact__map {
    width: 100%;
    height: 100%;
    min-height: 500px;
}

#campusMap {
    width: 100%;
    height: 100%;
    min-height: 500px;
    display: block;
}

/* ============================================================
   SECTION 4 — OTHER CAMPUSES
   Dark midnight violet background, text-only cards
============================================================ */
.campus-others {
    background: var(--vcc-midnight-violet, #2C1224);
    max-width: 1440px;
    margin: 0 auto;
}

.campus-others__inner {
    padding-top: 48px;
    padding-bottom: 48px;
}

.campus-others__heading {
    color: #fff;
    margin: 0 0 8px;
}

.campus-others__sub {
    font-family: "Outfit-Light";
    font-size: var(--font-lead, 24px);
    line-height: var(--lh-lead, 150%);
    color: var(--White, #FFF);
    margin: 0 0 24px;
}

.campus-others__grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 4px;
}

.campus-others__card {
    display: flex;
    align-items: center;
    padding: 16px;
    background: rgba(251, 249, 255, 0.15);
    text-decoration: none;
    color: var(--Snow, #FBF9FF);
    font-family: "Outfit-Light";
    font-size: var(--font-p);
    font-style: normal;
    line-height: var(--lh-p);
    transition: background 0.2s;
}

    .campus-others__card:hover {
        background: rgba(251, 249, 255, 0.30);
        text-decoration: none;
    }

.campus-others__pin {
    width: 24px;
    height: 24px;
    flex-shrink: 0;
    margin-top: 2px;
    color: #fff;
    margin-right: 16px;
}

/* ============================================================
   SECTION 5 — CTA
============================================================ */
.campus-cta {
    max-width: 1440px;
    margin: 0 auto;
}
section.pw-cta .cta-container:before {
    background-image: url('../images/general-cta-bg-d.webp');
    background-position: unset;
}

/* =============================================================
   Tablet  ≤ 1024px  
   ============================================================= */
@media only screen and (max-width: 1024px) {
    .ap-nav-gradient {
        display: none;
    }

    main.campus-page {
        margin-top: var(--nav-h);
    }
}

/* ============================================================
   960px — MOBILE (non-hero sections)
============================================================ */
@media only screen and (max-width: 960px) {
    /* programs */
    .campus-programs__inner {
        display: flex;
        flex-direction: column;
        min-height: unset;
    }

    .campus-programs__content {
        display: contents;
    }

    .campus-programs__eyebrow {
        order: 1;
        margin-top: 24px;
        margin-bottom: 0;
       
        padding: 0 22px 0 24px
    }

    .campus-programs__content h2 {
        order: 2;
        padding: 16px 24px 0;
    }

    .campus-programs__text {
        order: 3;
        padding: 12px 24px 0;
    }

    .campus-programs__image {
        order: 4;
        padding: 24px;
    }

    .campus-programs__list {
        order: 5;
        padding: 0 24px;
    }

    .campus-programs__all {
        order: 6;
        padding: 16px 24px 48px;
    }

    .campus-programs__image img {
        height: auto;
    }
    /* contact */
    .campus-contact__inner {
        display: flex;
        flex-direction: column;
        min-height: unset;
    }

    .campus-contact__info {
        padding-top: 40px;
        padding-bottom: 32px;
    }

    .campus-contact__eyebrow {
        align-self: flex-start;
        margin-left: calc(-1 * var(--wrapper-padding));
        padding: 0 22px 0 24px
    }

    .campus-contact__map,
    #campusMap {
        min-height: 320px;
    }
    .campus-others{
        margin:0;
    }
    /* other campuses — 2 col on tablet */
    .campus-others__grid {
        grid-template-columns: repeat(2, 1fr);
    }
    section.pw-cta .cta-container:before {
       /* background-image: url('../images/General-CTA-bg-m.webp');*/
        
    }
}

@media only screen and (max-width: 480px) {

    /* other campuses — 1 col on mobile */
    .campus-others__grid {
        grid-template-columns: 1fr;
    }
    section.pw-cta .cta-container:before {
         background-image: url('../images/General-CTA-bg-m.webp');
    }
}
