@charset "UTF-8";

/* ============================================================================
   Special Offers — base styles (used on Special Offers page + homepage)
   ============================================================================ */

.offers {
    position: relative;
    padding: var( --secPadding );
    margin: 0;
    overflow: visible;
    color: var( --black );
    background-color: var( --white );
    z-index: 1;
}

.offers .container {
    padding: 0;
}

.offers .heading {
    position: relative;
    line-height: 1.4em;
    color: inherit;
    width: 100%;
    margin: 0;
    text-align: center;
}

.offers .heading p {
    font-size: clamp( 16px, 0.938vw, 18px );
    margin: 0 auto 8px;
    color: inherit;
    max-width: 812px;
}

.offers .expires strong {
    font-weight: 400;
    color: inherit;
    display: block;
    text-align: center;
    font-size: 14px;
}

p.expires {
    margin: 100px 0 24px;
    text-align: center;
    color: var( --white );
    font-size: 14px;
}

ul.offers-list a:hover,
.offers-list li:hover .box-offers .box-holder .specWrap a {
    text-decoration: none;
    color: inherit;
    opacity: 1;
}

ul.offers-list {
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    justify-content: center;
    margin: 0;
    overflow: visible;
    flex: 1 1 0;
    padding-left: 0;
    gap: clamp( 20px, 2.344vw, 45px );
}

.offers-list li {
    width: 30%;
    padding: 0;
    margin: 0;
    transition: all .3s ease;
}

.offers-list li:hover {
    transform: translateY( -20px );
}

/* --- Box: outer wrapper for each offer card --- */

.box-offers {
    position: relative;
    font-size: clamp( 14px, 0.833vw, 16px );
    padding: 0;
    float: left;
    transition: padding-top .3s cubic-bezier( 0.4, 0, 1, 1 );
    width: 100%;
    height: 100%;
    text-align: left;
}

.box-offers .box-holder {
    position: relative;
    background-color: var( --white );
    color: inherit;
    margin: 0 auto;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 40px;
    box-sizing: border-box;
    border-radius: 0;
    overflow: hidden;
    transition: all .75s ease;
    box-shadow: var( --shadyMid );
}

.box-offers img {
    display: block;
    width: 80px;
    border-radius: 50%;
    transition: all .75s ease;
}

.box-offers.image-center img,
.box-offers.content-center img {
    display: inline-block;
    vertical-align: middle;
}

.box-offers.content-right img {
    width: 100%;
    display: inline-block;
    vertical-align: middle;
}

.box-offers.image-center .alpha-match,
.box-offers.content-center .alpha-match {
    margin-top: 10px;
}

.spcImg {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 32px;
}

/* --- Title (h4) inside the box --- */

.box-offers .h4 {
    font-family: var( --heading-font );
    font-size: clamp( 20px, 1.15vw, 22px );
    font-weight: 400;
    line-height: clamp( 28px, 1.563vw, 30px );
    color: inherit;
    text-transform: unset;
    letter-spacing: normal;
    margin: 0 0 16px;
}

.box-offers .h4 sup {
    font-size: 75%;
}

/* --- Description + body --- */

.box-offers .description {
    position: relative;
    margin: 0;
    padding: 0;
    overflow: hidden;
}

.box-offers .description p {
    font-size: clamp( 14px, 0.938vw, 18px );
    font-weight: 400;
    color: inherit;
}

.box-offers .description p:last-of-type {
    margin-bottom: 0;
}

.box-offers .offers-info {
    position: relative;
    margin: 0;
    padding: 0;
    color: inherit;
    font-weight: normal;
}

.box-offers .offers-info p {
    font-size: 16px;
    font-weight: 400;
    line-height: 24px;
    color: inherit;
    margin: 0;
}

/* --- Per-row CTA link (the "Learn More") --- */

.specWrap {
    position: relative;
    width: 100%;
    text-align: center;
    height: auto;
    display: block;
    overflow: visible;
    padding: 32px 20px 0;
}

.specWrap a {
    font-family: var( --body-font );
    font-weight: 600;
    color: inherit;
    text-transform: uppercase;
    font-size: clamp( 14px, 0.833vw, 16px );
    letter-spacing: clamp( .52px, 0.080vw, 1.54px );
    margin: 0 auto;
    display: block;
    position: relative;
    width: fit-content;
}

.specWrap a::after {
    content: '';
    display: block;
    opacity: 0;
    margin: 6px auto;
    height: 2px;
    width: 0;
    background-color: var( --secondary-color );
    transition: all .75s ease;
}

.specWrap a:hover::after,
.offers-list li:hover .box-offers .box-holder .specWrap a::after {
    width: 100%;
    opacity: 1;
}

/* --- Bottom-of-section "More Offers" CTA (used on Special Offers page) --- */

.btn.btn-orange.moreOff {
    display: block;
    position: relative;
    background-color: var( --primary-color );
    width: fit-content;
    font-weight: 600;
    letter-spacing: clamp( 0.52px, 0.080vw, 1.54px );
    margin: 56px auto 0;
}

a.btn.btn-orange.moreOff:hover {
    background-color: var( --primary-hover );
    text-decoration: none;
    transition: all .75s ease;
}

/* ============================================================================
   Broadwing homepage Special Offers Block (Figma 5598:2448)
   Two-column: big La Orleans headline left, stacked offer rows right
   ============================================================================ */

.home .offers {
    background-color: rgba( 234, 234, 234, 0.5 );
    padding: 80px 0;
    color: var( --black );
}

.home .offers .container {
    width: min( 100%, 1920px );
    max-width: unset;
    padding: 0;
}

.home .offers .offers-holder {
    display: grid;
    grid-template-columns: minmax( 0, 813fr ) minmax( 0, 1107fr );
    width: 100%;
    max-width: unset;
    margin: 0;
    padding: 0;
    align-items: stretch;
}

/* Block 1 (left) — La Orleans headline */
.home .offers .offers-holder > .heading {
    grid-column: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    border-top: 2px solid rgba( 30, 59, 71, 0.15 );
    border-bottom: 2px solid rgba( 30, 59, 71, 0.15 );
    padding: clamp( 60px, 6.25vw, 120px ) clamp( 20px, 7.29vw, 140px );
    min-height: clamp( 400px, 35.16vw, 675px );
    margin: 0;
    text-align: left;
    width: 100%;
    box-sizing: border-box;
}

.home .offers .offers-holder > .heading h2 {
    font-family: var( --heading-font );
    font-size: clamp( 36px, 4.167vw, 80px );
    line-height: 1;
    letter-spacing: -3.2px;
    font-weight: var( --heading-font-weight );
    color: var( --black );
    max-width: 535px;
    text-transform: none;
    margin: 0;
    text-align: left;
    display: block;
}

.home .offers .offers-holder > .heading p {
    display: none;
}

/* Block 2 (right) — vertical list of offer rows */
.home .offers ul.offers-list {
    grid-column: 2;
    display: flex;
    flex-direction: column;
    gap: clamp( 32px, 4.167vw, 80px );
    justify-content: center;
    border-top: 2px solid rgba( 30, 59, 71, 0.15 );
    border-bottom: 2px solid rgba( 30, 59, 71, 0.15 );
    border-left: 2px solid rgba( 30, 59, 71, 0.15 );
    padding: clamp( 40px, 5.208vw, 100px ) clamp( 20px, 8.073vw, 155px );
    min-height: clamp( 400px, 35.16vw, 675px );
    margin: 0;
    list-style: none;
    width: 100%;
    box-sizing: border-box;
    overflow: visible;
}

.home .offers .offers-list li {
    width: 100%;
    max-width: none;
    padding: 0;
    margin: 0;
    transition: none;
}

.home .offers .offers-list li:hover {
    transform: none;
}

/* Strip the default white card chrome — homepage uses inline rows, not cards */
.home .offers .offers-list li .box-offers,
.home .offers .offers-list li .box-offers .box-holder {
    background: transparent;
    box-shadow: none;
    padding: 0;
    height: auto;
    width: 100%;
}

/* Each offer row: title + body on left, CTA on right (aligned to row baseline) */
.home .offers .offers-list li .box-offers .box-holder {
    display: grid;
    grid-template-columns: minmax( 0, 1fr ) auto;
    grid-template-areas:
        "title cta"
        "body  cta";
    align-items: end;
    column-gap: clamp( 24px, 3.13vw, 60px );
    row-gap: 16px;
}

.home .offers .box-offers .spcImg {
    display: none;
}

.home .offers .box-offers .description {
    grid-area: title;
    width: 100%;
    max-width: 535px;
    text-align: left;
    padding: 0;
    margin: 0;
}

.home .offers .box-offers .description .h4 {
    font-family: var( --body-font );
    font-size: clamp( 18px, 1.458vw, 28px );
    font-weight: 500;
    line-height: 1.25;
    letter-spacing: 2.8px;
    text-transform: uppercase;
    color: var( --black );
    margin: 0;
}

.home .offers .box-offers .offers-info {
    grid-area: body;
    width: 100%;
    max-width: 535px;
    text-align: left;
    padding: 0;
    margin: 0;
}

.home .offers .box-offers .offers-info p {
    font-family: var( --body-font );
    font-size: var( --body-font-size );
    line-height: 1.5;
    color: var( --black );
    margin: 0;
    font-weight: 400;
    display: -webkit-box;
    -webkit-line-clamp: 4;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.home .offers .box-offers .specFormWrapper.specWrap {
    grid-area: cta;
    align-self: end;
    padding: 0;
    width: auto;
    bottom: auto;
    position: static;
    text-align: left;
    flex: 0 0 auto;
}

.home .offers .box-offers .specWrap a {
    font-family: var( --body-font );
    font-size: var( --overline-font-size );
    font-weight: 600;
    line-height: var( --overline-line-height );
    letter-spacing: var( --overline-letter-spc );
    text-transform: uppercase;
    color: var( --black );
    text-decoration: none;
    margin: 0;
    padding: 0;
    width: auto;
    display: inline-flex;
    align-items: center;
    gap: 16px;
}

.home .offers .box-offers .specWrap a::before {
    content: '';
    display: inline-block;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background-color: var( --primary-color );
    flex: 0 0 auto;
    margin: 0;
    transition: transform .2s ease;
}

.home .offers .box-offers .specWrap a::after {
    display: none;
}

.home .offers .box-offers .specWrap a:hover::before {
    transform: scale( 1.2 );
}

/* Hide bottom CTA + expires (not in Figma) */
.home .offers .moreOff,
.home .offers .expires {
    display: none;
}

/* ============================================================================
   Responsive
   ============================================================================ */

@media ( max-width: 1440px ) {
    .offers-list li {
        padding: 0 10px 22px;
    }
}

@media ( max-width: 1024px ) {
    .offers {
        clear: both;
        margin-top: 0;
        padding-top: 80px;
    }

    .offers-list {
        overflow: hidden;
        margin: 0 auto;
        clear: both;
        gap: 20px;
    }

    .offers-list li {
        padding: 0 10px 22px;
        width: 100%;
        max-width: 700px;
    }

    .box-offers .box-holder {
        width: 100%;
    }

    .specWrap {
        bottom: 20px;
    }

    /* Homepage overrides */
    .home .offers {
        background-color: var( --gray );
        padding: 40px 0;          /* outer vertical space; 0 horizontal so the lines reach the screen edges */
    }

    /* Full-width subtle lines (same value as the .diff bar): border on the
       container, vertical padding = inner space, horizontal padding insets content */
    .home .offers .container {
        border-top: 2px solid rgb( 33 33 33 / 5% );
        border-bottom: 2px solid rgb( 33 33 33 / 5% );
        padding: 40px 32px;
    }

    .home .offers .offers-holder {
        grid-template-columns: 1fr;
        gap: 56px;
    }

    /* Reset desktop's explicit grid-column placements so the grid stays 1-track */
    .home .offers .offers-holder > .heading,
    .home .offers ul.offers-list {
        grid-column: auto;
    }

    .home .offers .offers-holder > .heading {
        min-height: 0;
        border: none;
        padding: 0;
        max-width: none;
        align-items: center;
    }

    .home .offers .offers-holder > .heading h2 {
        font-size: var( --h1-font-size );
        line-height: var( --h1-line-height );
        max-width: none;
        letter-spacing: 0;
        text-align: center;
    }

    .home .offers ul.offers-list {
        min-height: 0;
        border: none;
        padding: 0;
        gap: 60px;
    }

    .home .offers .box-offers .offers-info p {
        -webkit-line-clamp: 6;
    }

    /* Stack + center each offer: title, body, then Learn More */
    .home .offers .offers-list li .box-offers .box-holder {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 0;
    }

    /* Title + body full width, centered text */
    .home .offers .box-offers .description,
    .home .offers .box-offers .offers-info {
        max-width: none;
        width: 100%;
        text-align: center;
    }

    .home .offers .box-offers .description {
        margin-bottom: 32px;          /* gap between title and body */
    }

    /* Learn More centered, 32px below the body */
    .home .offers .box-offers .specFormWrapper.specWrap {
        align-self: center;           /* resets desktop's align-self: end */
        margin-top: 32px;
    }
}

@media ( max-width: 768px ) {
    .offers .heading {
        display: block;
        width: 100%;
        overflow: hidden;
        padding: 0 20px;
        margin-bottom: 0;
    }

    .offers .heading p {
        padding: 0;
    }
}

@media ( max-width: 479px ) {
    .offers-list li {
        width: 95%;
    }

    .box-offers .box-holder {
        width: 100%;
    }

    .specWrap {
        bottom: 24px;
    }

    .specWrap a,
    .btn.btn-orange.moreOff {
        font-size: 16px;
    }
}
