/* ============================================
   CRUST PIZZA CO. - RESPONSIVE STYLESHEET
   ============================================
   Breakpoints:
   - Desktop XL: 1400px - 1919px
   - Desktop: 1200px - 1399px
   - Laptop: 992px - 1199px
   - Tablet: 768px - 991px
   - Mobile: < 767px
   - Small Mobile: < 576px
   ============================================ */

/* ============================================
   DESKTOP XL (1400px - 1919px)
   Keep hero section same as 1920px specs
   ============================================ */
@media (max-width: 1919.98px) and (min-width: 1400px) {
    /*
     * Hero — fluid 1400px → 1920px
     * Fixed 730 + 712 + gap exceeds container width near 1400px; use proportional flex
     * + interpolated type so columns stay balanced, not edge-to-edge.
     */
    .hero {
        --hero-gap: clamp(24px, calc(24px + (100vw - 1400px) * 94 / 520), 118px);
        --hero-sum: 1442; /* 730 + 712 */
        aspect-ratio: unset;
        height: auto;
        min-height: calc(1280px + (100vw - 1400px) * 252 / 520);
        margin-top: 144px;
    }

    .hero > .container {
        padding-top: 127px;
        padding-bottom: 80px;
        max-width: min(1560px, 100%);
    }

    .hero__row {
        gap: var(--hero-gap);
        justify-content: center;
        align-items: flex-start;
        flex-wrap: nowrap;
        width: 100%;
        max-width: 100%;
    }

    /* Override Bootstrap col-lg-auto (flex: 0 0 auto) so columns share row width */
    .hero__row .hero__left-col,
    .hero__row .hero__right-col {
        flex-grow: 1;
        flex-shrink: 1;
    }

    .hero__left-col {
        flex-basis: calc(
            (100% - var(--hero-gap)) * 730 / var(--hero-sum)
        );
        min-width: 0;
        max-width: 730px;
        width: auto;
    }

    .hero__right-col {
        flex-basis: calc(
            (100% - var(--hero-gap)) * 712 / var(--hero-sum)
        );
        min-width: 0;
        max-width: 712px;
        width: auto;
    }

    .hero__content {
        padding-left: clamp(24px, calc(24px + (100vw - 1400px) * 11 / 520), 35px);
    }

    .hero__accent-bar {
        height: calc(480px + (100vw - 1400px) * 89 / 520);
        width: 7px;
    }

    .hero__tagline {
        font-size: calc(64px + (100vw - 1400px) * 12 / 520);
        line-height: calc(48px + (100vw - 1400px) * 7 / 520);
    }

    .hero__title {
        font-size: calc(110px + (100vw - 1400px) * 23 / 520);
        line-height: calc(92px + (100vw - 1400px) * 20 / 520);
    }

    .hero__text {
        font-size: calc(20px + (100vw - 1400px) * 4 / 520);
        line-height: calc(34px + (100vw - 1400px) * 6 / 520);
        max-width: calc(480px + (100vw - 1400px) * 105 / 520);
    }

    .hero__form-card {
        padding: calc(32px + (100vw - 1400px) * 8 / 520)
            calc(36px + (100vw - 1400px) * 14 / 520)
            calc(40px + (100vw - 1400px) * 10 / 520);
    }

    .hero__form-title {
        font-size: calc(42px + (100vw - 1400px) * 10 / 520);
    }

    .form-stepper__circle {
        width: calc(44px + (100vw - 1400px) * 6 / 520);
        height: calc(44px + (100vw - 1400px) * 6 / 520);
        font-size: calc(22px + (100vw - 1400px) * 4 / 520);
    }

    .hero__form .form-control {
        height: calc(48px + (100vw - 1400px) * 4 / 520);
    }

    .btn-hero {
        height: calc(54px + (100vw - 1400px) * 4 / 520);
        font-size: calc(18px + (100vw - 1400px) * 2 / 520);
    }

    /* Earnings Section - Keep same as 1920px */

    /* Americans Love — ~1920 spec; scales slightly in this band */
    .americans-love {
        min-height: 1700px;
    }

    .americans-love__col--images {
        padding-top: 160px;
        padding-bottom: 180px;
    }

    .americans-love__col--content {
        padding-top: 170px;
    }

    .americans-love__title {
        font-size: 96px;
        line-height: 82px;
        margin-bottom: 56px;
    }

    .americans-love__quote {
        font-size: 30px;
        line-height: 42px;
        margin-bottom: 32px;
    }

    .americans-love__quote-card {
        height: 240px;
        padding: 18px 28px 16px;
    }
}

/* ============================================
   DESKTOP SMALL (1200px - 1399px)
   ============================================ */
@media (max-width: 1399.98px) {
    .header {
        height: auto;
        padding: 16px 0;
    }

    .navbar-nav {
        gap: 24px;
        padding-top: 0;
        padding-bottom: 0;
    }

    .nav-link {
        font-size: 15px;
    }

    .btn-nav {
        padding: 12px 24px;
        font-size: 16px;
        margin-top: 0;
        margin-bottom: 0;
    }

    .header__logo {
        width: 130px;
    }

    /* Hero */
    .hero {
        aspect-ratio: unset;
        height: 1532px;
    }

    .hero > .container {
        padding-top: 160px;
        padding-bottom: 60px;
    }

    .hero__row {
        gap: 150px;
    }

    .hero__left-col {
        width: 480px;
    }

    .hero__right-col {
        width: 460px;
    }

    .hero__content {
        padding-left: 30px;
    }

    .hero__accent-bar {
        height: 360px;
        width: 5px;
    }

    .hero__tagline {
        font-size: 48px;
        line-height: 60px;
    }

    .hero__title {
        font-size: 76px;
        line-height: 70px;
    }

    .hero__text {
        font-size: 17px;
        line-height: 28px;
        max-width: 400px;
    }

    .hero__form-card {
        padding: 26px 32px 34px;
    }

    .hero__form-title {
        font-size: 38px;
        margin-bottom: 20px;
    }

    .form-stepper {
        margin-bottom: 24px;
    }

    .form-stepper__circle {
        width: 42px;
        height: 42px;
        font-size: 22px;
    }

    .hero__form .form-control {
        height: 46px;
    }

    .btn-hero {
        height: 52px;
        font-size: 17px;
    }

    /* Earnings Section */
    .earnings {
        padding-top: 140px;
        padding-bottom: 120px;
    }
    .earnings .section-header {
        margin-bottom: 80px;
    }
    .earnings__industry-value {
        font-size: 110px;
    }
    .earnings__industry-label {
        font-size: 32px;
    }
    .earnings__stat-value {
        font-size: 56px;
    }
    .earnings__industry-inner {
        padding: 44px 28px;
    }

    /* CEO Welcome Section */
    .ceo-welcome {
        height: 550px;
    }
    .ceo-welcome__title {
        font-size: 80px;
        margin-bottom: 28px;
    }
    .ceo-welcome__subtitle {
        font-size: 20px;
        margin-bottom: 40px;
        max-width: 750px;
    }
    .ceo-welcome__play-btn img {
        width: 106px;
        height: 106px;
    }

    /* Americans Love — narrower artboard */
    .americans-love {
        min-height: auto;
        padding-bottom: 400px;
    }

    .americans-love__col--images {
        padding-top: 100px;
        padding-bottom: 140px;
    }

    .americans-love__col--content {
        padding-top: 80px;
        padding-bottom: 80px;
    }

    .americans-love__title {
        font-size: clamp(48px, 6vw, 88px);
        line-height: clamp(42px, 5vw, 76px);
        margin-bottom: 40px;
    }

    .americans-love__quote {
        font-size: clamp(20px, 2.2vw, 30px);
        line-height: clamp(28px, 3vw, 42px);
    }

    .americans-love__quote-cite {
        font-size: 17px;
    }

    .americans-love__text-card {
        height: auto;
        margin-top: 24px;
    }

}

/* ============================================
   LAPTOP (992px - 1199px)
   ============================================ */
@media (max-width: 1199.98px) {
    .navbar-nav {
        gap: 20px;
    }

    .nav-link {
        font-size: 14px;
    }

    .btn-nav {
        padding: 10px 20px;
        font-size: 14px;
    }

    .header__logo {
        width: 120px;
    }

    /* Hero */
    .hero {
        aspect-ratio: unset;
        height: 1532px;
        margin-top: 106px;
    }

    .hero > .container {
        padding-top: 130px;
        padding-bottom: 50px;
    }

    .hero__row {
        gap: 100px;
    }

    .hero__left-col {
        width: 400px;
    }

    

    .hero__content {
        padding-left: 26px;
    }

    .hero__accent-bar {
        height: 300px;
        width: 5px;
    }

    .hero__tagline {
        font-size: 38px;
        line-height: 48px;
    }

    .hero__title {
        font-size: 60px;
        line-height: 56px;
    }

    .hero__text {
        font-size: 15px;
        line-height: 24px;
        max-width: 340px;
    }

    .hero__form-card {
        padding: 22px 26px 30px;
    }

    .hero__form-title {
        font-size: 32px;
        margin-bottom: 16px;
    }

    .form-stepper {
        margin-bottom: 20px;
    }

    .form-stepper__circle {
        width: 38px;
        height: 38px;
        font-size: 20px;
    }

    .hero__form .form-control {
        height: 44px;
        border-radius: 8px;
    }

    .btn-hero {
        height: 48px;
        font-size: 16px;
        margin-top: 16px;
    }

    /* Spacing adjustments */
    .py-100 {
        padding-top: 80px;
        padding-bottom: 80px;
    }

    .py-120 {
        padding-top: 80px;
        padding-bottom: 80px;
    }

    /* Earnings Section */
    .earnings {
        padding-top: 100px;
        padding-bottom: 80px;
    }
    .earnings .section-header {
        margin-bottom: 60px;
    }
    .earnings__industry-value {
        font-size: 96px;
    }
    .earnings__industry-label {
        font-size: 28px;
    }
    .earnings__stat-value {
        font-size: 48px;
    }
    .earnings__industry-inner {
        padding: 40px 24px;
    }
    .earnings__stat-icon {
        width: 52px;
        height: 52px;
    }

    /* CEO Welcome Section */
    .ceo-welcome {
        height: 500px;
    }
    .ceo-welcome__title {
        font-size: 64px;
        margin-bottom: 24px;
    }
    .ceo-welcome__subtitle {
        font-size: 18px;
        margin-bottom: 36px;
        max-width: 600px;
    }
    .ceo-welcome__play-btn img {
        width: 93px;
        height: 93px;
    }
}

/* ============================================
   TABLET (768px - 991px)
   ============================================ */
@media (max-width: 991.98px) {
    /* Navbar - Mobile Style */
    .header {
        position: fixed;
        height: auto;
        padding: 16px 0;
        box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
    }

    .navbar-collapse {
        position: absolute;
        top: 100%;
        left: 0;
        right: 0;
        background-color: var(--clr-white);
        padding: var(--space-3);
        box-shadow: var(--shadow-md);
    }

    .navbar-nav {
        flex-direction: column;
        gap: 0;
        padding: 0;
    }

    .nav-link {
        padding: var(--space-2) 0 !important;
        border-bottom: 1px solid var(--clr-gray-200);
        font-size: 16px;
    }

    .btn-nav {
        margin-top: var(--space-3);
        margin-bottom: 0;
        width: 100%;
    }

    /* Hero - Stacked Layout */
    .hero {
        aspect-ratio: unset;
        height: auto;
        min-height: auto;
        /* Base style uses margin-top: 144px for absolute header; margin is outside the
           background — with a fixed header it becomes a white strip above the hero image */
        margin-top: 0;
        padding-top: 80px; /* Clear fixed navbar; background fills from top behind it */
        padding-bottom: var(--space-8);
    }

    .hero > .container {
        padding-top: 40px;
    }

    .hero__row {
        flex-direction: column;
        gap: 40px;
        align-items: center;
    }

    .hero__left-col,
    .hero__right-col {
        width: 100%;
        max-width: 600px;
    }

    .hero__content {
        text-align: center;
        padding-left: 0;
    }

    .hero__accent-bar {
        display: none;
    }

    .hero__tagline {
        font-size: 50px;
        line-height: 1.05;
        margin-bottom: 0;
        padding-bottom: 0;
    }

    .hero__title {
        font-size: 62px;
        line-height: 0.92;
        margin-top: -0.12em;
    }

    .hero__text {
        max-width: 500px;
        margin-left: auto;
        margin-right: auto;
        font-size: 16px;
        line-height: 26px;
    }

    .hero__form-card {
        padding: 28px 32px 36px;
    }

    .hero__form-title {
        font-size: 36px;
    }

    .form-stepper__circle {
        width: 44px;
        height: 44px;
        font-size: 22px;
    }

    .form-stepper__number {
        font-size: 28px;
    }

    .hero__form .form-control {
        height: 46px;
    }

    .btn-hero {
        height: 52px;
        font-size: 16px;
    }

    /* Section headers */
    .section-header {
        margin-bottom: var(--space-6);
    }

    /* Earnings Section */
    .earnings {
        padding-top: 80px;
        padding-bottom: 60px;
    }
    .earnings .section-header {
        margin-bottom: 48px;
    }
    .earnings__industry-card {
        max-width: 380px;
        margin: 0 auto var(--space-6);
    }
    .earnings__industry-value {
        font-size: 100px;
    }
    .earnings__industry-label {
        font-size: 30px;
    }
    .earnings__stat-value {
        font-size: 44px;
    }

    /* CEO Welcome Section */
    .ceo-welcome {
        height: 450px;
    }
    .ceo-welcome__title {
        font-size: 48px;
        margin-top: 80px;
        margin-bottom: 20px;
    }
    .ceo-welcome__subtitle {
        font-size: 16px;
        margin-bottom: 32px;
        max-width: 500px;
        padding: 0 20px;
    }
    .ceo-welcome__play-btn img {
        width: 80px;
        height: 80px;
    }

    /* Americans Love — stack, center */
    .americans-love {
        min-height: auto;
        padding-bottom: 200px;
    }

    .americans-love__row {
        --bs-gutter-y: 48px;
    }

    .americans-love__col--images {
        padding-top: 64px;
        padding-bottom: 120px;
        padding-right: clamp(12px, 4vw, 48px);
        padding-left: clamp(12px, 4vw, 48px);
        order: 1;
        min-width: 0;
    }

    .americans-love__col--content {
        padding-top: 48px;
        padding-bottom: 64px;
        padding-left: clamp(20px, 5vw, 48px);
        padding-right: clamp(20px, 5vw, 48px);
        order: 2;
        text-align: center;
    }

    .americans-love__photo-stack {
        margin-left: auto;
        margin-right: auto;
        width: 100%;
        max-width: min(696px, 100%);
    }

    /* Shrink with viewport (tablet / mobile stacked) */
    .americans-love__img-primary {
        width: 100%;
        max-width: min(696px, calc(100vw - 48px));
        height: auto;
    }

    .americans-love__img-secondary {
        width: min(458px, 65.8%, calc((100vw - 48px) * 0.48));
        height: auto;
        /* Pull left vs desktop (-16.95%): less hang-off on stacked layout */
        right: -5%;
    }

    .americans-love__title {
        font-size: clamp(40px, 10vw, 64px);
        line-height: clamp(36px, 9vw, 56px);
        margin-bottom: 32px;
    }

    .americans-love__quote-card {
        text-align: left;
        max-width: 520px;
        height: auto;
        min-height: 164px;
        margin-left: auto;
        margin-right: auto;
    }

    .americans-love__text {
        margin-left: auto;
        margin-right: auto;
        text-align: start;

    }

    .americans-love__text-card {
        width: 90%;
        height: auto;
        margin-left: auto;
        margin-right: auto;
        margin-top: 12px;
    }
}

/* ============================================
   MOBILE (576px - 767px)
   ============================================ */
@media (max-width: 767.98px) {
    /* Spacing adjustments */
    .py-80 {
        padding-top: var(--space-6);
        padding-bottom: var(--space-6);
    }

    .py-100 {
        padding-top: var(--space-8);
        padding-bottom: var(--space-8);
    }

    /* Hero */
    .hero {
        padding-top: 80px;
        padding-bottom: var(--space-6);
    }

    .hero > .container {
        padding-top: 32px;
    }

    .hero__tagline {
        font-size: 44px;
        line-height: 1;
        margin-bottom: 0;
    }

    .hero__title {
        font-size: 52px;
        line-height: 0.9;
        margin-top: -0.1em;
    }

    .hero__form-card {
        padding: 24px 24px 32px;
    }

    .hero__form-title {
        font-size: 36px;
        margin-bottom: 16px;
    }

    .form-stepper {
        margin-bottom: 24px;
    }

    .form-stepper__circle {
        width: 42px;
        height: 42px;
        font-size: 22px;
    }

    .form-stepper__number {
        font-size: 28px;
    }

    .hero__form .col-md-6 {
        width: 100%;
    }

    .hero__form .form-control {
        height: 52px;
    }

    .hero__form .hero-paired-field .form-label {
        min-height: 0;
        display: block;
    }

    .btn-hero {
        height: 56px;
        font-size: 18px;
    }

    /* Buttons */
    .btn {
        padding: 14px 24px;
        font-size: 16px;
    }

    .btn-lg {
        padding: 16px 32px;
        font-size: 18px;
    }

    /* Earnings Section */
    .earnings {
        padding-top: 60px;
        padding-bottom: 48px;
    }
    .earnings .section-header {
        margin-bottom: 40px;
    }
    .earnings__industry-card {
        max-width: 320px;
    }
    .earnings__industry-value {
        font-size: 80px;
    }
    .earnings__industry-label {
        font-size: 26px;
    }
    .earnings__industry-inner {
        padding: 36px 20px;
    }
    .earnings__stat-value {
        font-size: 38px;
    }
    .earnings__stat-icon {
        width: 48px;
        height: 48px;
    }
    .earnings__stat-label {
        font-size: 13px;
    }

    /* CEO Welcome Section */
    .ceo-welcome {
        height: 400px;
    }
    .ceo-welcome__title {
        font-size: 36px;
        margin-top: 60px;
        margin-bottom: 16px;
    }
    .ceo-welcome__subtitle {
        font-size: 14px;
        margin-bottom: 28px;
        max-width: 90%;
    }
    .ceo-welcome__play-btn img {
        width: 74px;
        height: 74px;
    }
}

/* ============================================
   SMALL MOBILE (< 576px)
   ============================================ */
@media (max-width: 575.98px) {
    /* Container padding */
    .container {
        padding-left: var(--space-2);
        padding-right: var(--space-2);
    }

    /* Header */
    .header {
        padding: 12px 0;
    }

    .header__logo {
        width: 110px;
    }

    /* Hero */
    .hero {
        padding-top: 70px;
    }

    .hero > .container {
        padding-top: 24px;
    }

    .hero__tagline {
        font-size: 48px;
        line-height: 0.95;
        margin-bottom: 0;
        margin-top: 24px;
    }

    .hero__title {
        font-size: 64px;
        line-height: 0.88;
        margin-top: -0.08em;
        margin-bottom: 20px;
    }

    .hero__text {
        font-size: 15px;
    }

    .hero__form-card {
        padding: 20px 20px 28px;
        border-radius: 16px;
    }

    .hero__form-title {
        font-size: 30px;
    }

    .form-stepper__circle {
        width: 38px;
        height: 38px;
        font-size: 20px;
    }

    .form-stepper__number {
        font-size: 24px;
    }

    .hero__form .form-control {
        height: 48px;
        padding: 12px 16px;
        border-radius: 10px;
    }

    .btn-hero {
        height: 52px;
        font-size: 16px;
        margin-top: 8px;
    }

    /* Americans Love — photo scales down on narrow viewports (e.g. ~475px) */
    .americans-love__col--images {
        padding-left: clamp(8px, 2.5vw, 16px);
        padding-right: clamp(8px, 2.5vw, 16px);
    }

    .americans-love__img-primary {
        width: 100%;
        max-width: min(696px, calc(100vw - 28px));
        height: auto;
        margin-left: auto;
        margin-right: auto;
    }

    .americans-love__img-secondary {
        width: 300px;
        height: auto;
        /* Much further left on narrow phones (inset from stack’s right edge) */
        right: 10%;
        bottom: -150px;
    }

    /* Earnings Section */
    .earnings {
        padding-top: 48px;
        padding-bottom: 40px;
    }
    .earnings .section-header {
        margin-bottom: 32px;
    }
    .earnings__industry-value {
        font-size: 64px;
    }
    .earnings__industry-label {
        font-size: 22px;
    }
    .earnings__stat-value {
        font-size: 32px;
    }

    /* CEO Welcome Section */
    .ceo-welcome {
        height: 350px;
    }
    .ceo-welcome__title {
        font-size: 28px;
        margin-top: 50px;
        margin-bottom: 14px;
    }
    .ceo-welcome__subtitle {
        font-size: 13px;
        margin-bottom: 24px;
    }
    .ceo-welcome__play-btn img {
        width: 67px;
        height: 67px;
    }
}

/* ============================================
   LARGE DESKTOP (> 1920px)
   Keep hero section same as 1920px specs
   ============================================ */
@media (min-width: 1921px) {
    .container {
        max-width: 1560px;
    }

    /* Hero - Same aspect ratio as Figma 1920×1532 so cover matches 1920 crop on ultrawide */
    .hero {
        aspect-ratio: 1920 / 1532;
        height: auto;
        min-height: 0;
        margin-top: 144px;
    }

    .hero > .container {
        padding-top: 127px;
        padding-bottom: 80px;
    }

    .hero__row {
        gap: 118px;
        justify-content: center;
    }

    .hero__left-col {
        width: 730px;
    }

    .hero__right-col {
        width: 712px;
    }

    .hero__content {
        padding-left: 35px;
    }

    .hero__accent-bar {
        height: 569px;
        width: 7px;
    }

    .hero__tagline {
        font-size: 76px;
        line-height: 55px;
    }

    .hero__title {
        font-size: 133px;
        line-height: 112px;
    }

    .hero__text {
        font-size: 24px;
        line-height: 40px;
        max-width: 585px;
    }

    .hero__form-card {
        padding: 40px 50px 50px;
    }

    .hero__form-title {
        font-size: 52px;
    }

    .form-stepper__circle {
        width: 50px;
        height: 50px;
        font-size: 26px;
    }

    .hero__form .form-control {
        height: 52px;
    }

    .btn-hero {
        height: 58px;
        font-size: 20px;
    }

    /* Earnings - Lock to 1920px specs */
    .earnings {
        padding-top: 247px;
        padding-bottom: 229px;
    }
    .earnings .section-header {
        margin-bottom: 146px;
    }
    .earnings__stats-row {
        gap: 96px;
    }

    /* CEO Welcome - Lock to 1920px specs */
    .ceo-welcome {
        height: 675px;
    }
    .ceo-welcome__title {
        font-size: 106px;
        margin-bottom: 36px;
    }
    .ceo-welcome__subtitle {
        font-size: 25px;
        margin-bottom: 56px;
        max-width: 900px;
    }
    .ceo-welcome__play-btn img {
        width: 133px;
        height: 133px;
    }

    /* Americans Love — 1920px artboard (pixel match with base styles) */
    .americans-love {
        min-height: 1888px;
    }

    .americans-love__col--images {
        padding-top: 178px;
        padding-bottom: 200px;
    }

    .americans-love__col--content {
        padding-top: 190px;
    }

    .americans-love__title {
        font-size: 106px;
        line-height: 90px;
        margin-bottom: 67px;
    }

    .americans-love__quote {
        font-size: 33px;
        line-height: 46px;
        margin-bottom: 38px;
    }

    .americans-love__quote-cite {
        font-size: 19px;
    }

    /* Don't Take Our Word */
    .dont-take-word {
        margin-top: -527px;
    }
    .dont-take-word__title {
        font-size: 96px;
        line-height: 82px;
    }
    .dont-take-word__play-btn img {
        width: 120px;
        height: 120px;
    }

    /* Why Now */
    .why-now__title {
        font-size: 96px;
        line-height: 82px;
    }
}

/* ============================================
   NEW SECTIONS - DESKTOP (1400px - 1919px)
   ============================================ */
@media (max-width: 1919.98px) and (min-width: 1400px) {
    .what-is-crust {
        height: auto;
        --wic-overlap: 460px;
    }
    .what-is-crust__title {
        margin-top: 280px;
        font-size: 90px;
    }

    .what-is-crust__deco-left {
        width: 412px;
        height: 448px;
        top: 300px;
    }

   
}

/* ============================================
   NEW SECTIONS - DESKTOP SMALL (1200px - 1399px)
   ============================================ */
@media (max-width: 1399.98px) {
    /* Don't Take Our Word */
    .dont-take-word {
        margin-top: -400px;
    }
    .dont-take-word__card {
        padding: 60px 48px 56px;
        border-radius: 24px;
    }
    .dont-take-word__title {
        font-size: 72px;
        line-height: 64px;
    }
    .dont-take-word__subtitle {
        font-size: 20px;
        margin-bottom: 36px;
    }
    .dont-take-word__play-btn img {
        width: 100px;
        height: 100px;
    }

    /* What is Crust */
    .what-is-crust {
        --wic-overlap: 420px;
        height: auto;
        padding-top: calc(var(--wic-overlap) + 80px);
        padding-bottom: 80px;
    }

    .what-is-crust__deco-left {
        width: 412px;
        height: 448px;
        top: 300px;
    }

    .what-is-crust__title {
        margin-top: 280px;
        font-size: 80px;
    }

    .what-is-crust__text {
        font-size: 18px;
        line-height: 36px;
    }
    .what-is-crust__cards {
        height: auto;
        flex-wrap: wrap;
        gap: 40px;
        max-width: 100%;
    }
    .crust-card-wrapper {
        width: 408px;
    }
    

    .crust-story__pizza-box {
        width: 300px;
    }
   


    /* Why Now */
    .why-now {
        padding-top: 120px;
        padding-bottom: 120px;
    }
    .why-now__title {
        font-size: 72px;
        line-height: 64px;
        margin-bottom: 56px;
    }
    .why-now__feature-title {
        font-size: 26px;
    }

    .investment-snapshot__title {
        font-size: 74px;
        line-height: 58px;
        margin-bottom: 48px;
    }

    investment-snapshot__col-img {
        padding: 0;
    }

    .investment-snapshot__photo  {
        height: 250px;
    }

    /* Easy Steps */
    .easy-steps {
        padding-top: 100px;
        padding-bottom: 100px;
    }
    .easy-steps .section-header {
        margin-bottom: 64px;
    }
    .easy-steps__timeline {
        padding-top: 72px;
    }
    .easy-steps__card {
        height: auto;
        min-height: 300px;
        padding: 120px 16px 56px;
    }
    .easy-steps__badge {
        width: 150px;
        height: 150px;
    }
    .easy-steps__badge-inner {
        width: 126px;
        height: 126px;
    }
    .easy-steps__icon {
        max-width: 60px;
        max-height: 60px;
    }
    .easy-steps__label {
        font-size: 36px;
    }

    /* Territories */
    .territories {
        padding-top: 100px;
        padding-bottom: 100px;
    }

    /* News Blog */
    .news-blog {
        padding-top: 100px;
        padding-bottom: 100px;
    }

    /* Footer */
    .footer-form__title {
        font-size: 64px;
        line-height: 1.2;
    }
    .footer-order__title {
        font-size: 64px;
        line-height: 1.2;
    }
}

/* ============================================
   NEW SECTIONS - LAPTOP (992px - 1199px)
   ============================================ */
@media (max-width: 1199.98px) {
    .dont-take-word {
        margin-top: -300px;
    }
    .dont-take-word__card {
        padding: 48px 36px 48px;
        border-radius: 24px;
    }
    .dont-take-word__title {
        font-size: 56px;
        line-height: 52px;
    }

    .what-is-crust {
        --wic-overlap: 360px;
        height: auto;
        padding-top: calc(var(--wic-overlap) + 60px);
        padding-bottom: 60px;
    }
    .what-is-crust__title {
        margin-top: 210px;
        font-size: 64px;
    }
    .what-is-crust__text {
        font-size: 17px;
        line-height: 34px;
    }
    .what-is-crust__cards {
        flex-direction: column;
        align-items: center;
    }
    .what-is-crust__deco-left {
        width: 320px;
        height: auto;
        aspect-ratio: 471 / 487;
        
    }
    .what-is-crust__deco-right {
        width: 320px;
        height: auto;
        aspect-ratio: 518 / 414;
        right: -140px;
    }
   

    .why-now {
        padding-top: 100px;
        padding-bottom: 100px;
    }
    .why-now__title {
        font-size: 56px;
        line-height: 52px;
        margin-bottom: 48px;
    }
    .why-now__feature-title {
        font-size: 22px;
    }

    .investment-snapshot {
        margin-top: 120px;
        margin-bottom: 120px;
        padding: 80px 48px 64px;
    }
    .investment-snapshot__title {
        font-size: 64px;
        line-height: 58px;
        margin-bottom: 48px;
    }
    .investment-snapshot__row-2 {
        --bs-gutter-x: 40px;
        margin-bottom: 48px;
    }
    .investment-snapshot__list-text {
        font-size: 20px;
        line-height: 28px;
    }
    .investment-snapshot__row-3 {
        margin-bottom: 56px;
    }

    .easy-steps__timeline {
        padding-top: 72px;
    }
    .easy-steps__card {
        padding: 120px 16px 56px;
    }
    .easy-steps__badge {
        width: 150px;
        height: 150px;
    }
    .easy-steps__badge-inner {
        width: 126px;
        height: 126px;
    }
    .easy-steps__icon {
        max-width: 56px;
        max-height: 56px;
    }
    .easy-steps__label {
        font-size: 32px;
    }
    .easy-steps__desc {
        font-size: 15px;
    }
}

/* ============================================
   NEW SECTIONS - TABLET (768px - 991px)
   ============================================ */
@media (max-width: 991.98px) {
    .dont-take-word {
        margin-top: -200px;
    }
    .dont-take-word__card {
        padding: 40px 28px 44px;
        border-radius: 20px;
    }
    .dont-take-word__title {
        font-size: 42px;
        line-height: 40px;
    }
    .dont-take-word__subtitle {
        font-size: 18px;
        margin-bottom: 28px;
    }
    .dont-take-word__play-btn img {
        width: 80px;
        height: 80px;
    }

    .investment-snapshot {
        margin-top: 80px;
        margin-bottom: 80px;
        padding: 56px 28px 48px;
    }
    .investment-snapshot__title {
        font-size: 40px;
        line-height: 38px;
        margin-bottom: 36px;
    }
    .investment-snapshot__row-2 {
        margin-bottom: 40px;
    }
    .investment-snapshot__col-invest {
        margin-top: 40px;
    }
    .investment-snapshot__list-text {
        font-size: 18px;
        line-height: 26px;
    }
    .investment-snapshot__col-heading,
    .investment-snapshot__invest-label {
        font-size: 20px;
    }
    .investment-snapshot__row-3 .col-md-4 {
        margin-bottom: 40px;
    }
    .investment-snapshot__row-3 .col-md-4:last-child {
        margin-bottom: 0;
    }
    .investment-snapshot__row-3 {
        margin-bottom: 48px;
    }

    /* Ticks align to first line when list text wraps (matches row-2 list behavior) */
    .investment-snapshot__list li {
        align-items: flex-start;
    }

    .what-is-crust {
        --wic-overlap: 320px;
        height: auto;
        padding-top: calc(var(--wic-overlap) + 60px);
        padding-bottom: 60px;
    }
    .what-is-crust__title {
        margin-top: 210px;
        font-size: 52px;
    }
    .what-is-crust__text {
        font-size: 16px;
        line-height: 32px;
    }
    .what-is-crust__deco-left {
        width: 280px;
        height: auto;
        aspect-ratio: 471 / 487;
        /* Pull above section title (horizontal left unchanged) */
        top: clamp(131px, calc(12vw + 83px), 303px);
    }
    .what-is-crust__deco-right {
        width: 300px;
        height: auto;
        aspect-ratio: 518 / 414;
        right: -80px;
        top: clamp(139px, calc(14vw + 83px), 343px);
    }
    .crust-card-wrapper {
        width: 340px;
    }
    .crust-card {
        width: 340px;
        height: 540px;
    }
    .crust-card__img-wrap {
        width: 300px;
        height: 300px;
    }
    .crust-card__heading {
        font-size: 36px;
        line-height: 36px;
    }

    .crust-story__col--media {
        text-align: center;
        margin-bottom: 48px;
        justify-content: center;
    }
    .crust-story__media-wrap {
        transform: none;
    }
    .crust-story__title {
        text-align: center;
    }
    .crust-story__text {
        text-align: center;
        margin-left: auto;
        margin-right: auto;
    }
    .crust-story__cta {
        justify-content: center;
        margin: 0 auto;
    }
    .crust-story__cup {
        left: max(-48px, calc(-100 * var(--crust-d) / 580));
    }
    .crust-story__sauce {
        top: clamp(0px, 2vw, 12px);
        right: clamp(4px, 1.5vw, 12px);
        width: min(100%, calc(193 * var(--crust-d) / 580));
    }
    .crust-story__pizza-box {
        width: min(100%, calc(445 * var(--crust-d) / 580));
        height: auto;
        aspect-ratio: 445 / 523;
    }

    .why-now {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .why-now__title {
        font-size: 42px;
        line-height: 40px;
        margin-bottom: 40px;
    }
    .why-now__feature-title {
        font-size: 20px;
    }

    .easy-steps {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .easy-steps .section-header {
        margin-bottom: 48px;
    }
    .easy-steps__timeline {
        padding-top: 72px;
        row-gap: clamp(96px, 10vw, 132px);
    }

    .territories {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    /* Tighter column gap than default g-4 (24px) on <lg — more room for text */
    .territories__grid {
        --bs-gutter-x: 0.75rem;
        --bs-gutter-y: 1rem;
    }
    .territories__banner-text {
        font-size: 36px;
        line-height: 40px;
    }

    .news-blog {
        padding-top: 80px;
        padding-bottom: 80px;
    }

    .footer-form {
        padding-top: 80px;
        padding-bottom: 80px;
    }
    .footer-form__title {
        font-size: 48px;
        line-height: 1.2;
        margin-bottom: 36px;
    }
    .footer-form__label {
        font-size: 18px;
    }
    .footer-form__input {
        height: 52px;
        font-size: 16px;
    }
    .footer-form__textarea {
        min-height: 140px;
    }
    .footer-order__title {
        font-size: 48px;
        line-height: 1.2;
    }
    .footer-order__btn {
        width: 220px;
    }
    .footer-nav__grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 32px 24px;
    }

    /* Bottom strip: black bg, legal text first, badges stacked vertically */
    .footer-end {
        background-color: #000;
    }

    .footer-end__card {
        padding-top: clamp(16px, 4vw, 28px);
        padding-bottom: clamp(28px, 6vw, 40px);
    }

    .footer-divider__line {
        border-top-color: rgba(255, 255, 255, 0.12);
    }

    .footer-bottom {
        padding-top: 0;
        margin-top: 18px;
        padding-bottom: 0;
    }

    .footer-order__last {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: flex-start;
        gap: 28px;
        width: 100%;
    }

    .footer-bottom__center {
        order: 1;
        gap: 10px;
        width: 100%;
        max-width: 360px;
    }

    .footer-bottom__copy {
        font-size: 14px;
        line-height: 1.45;
    }

    .footer-bottom__legal {
        font-size: 13px;
        line-height: 1.45;
    }

    .footer-bottom__social {
        margin-top: 4px;
    }

    .footer-bottom__badge--ifa {
        order: 2;
    }

    .footer-bottom__badge--ifa img {
        width: min(240px, 78vw);
        max-width: 100%;
        height: auto;
    }

    .footer-bottom__badges-right {
        order: 3;
        display: flex;
        flex-direction: column;
        flex-wrap: nowrap;
        align-items: center;
        justify-content: flex-start;
        gap: 22px;
        width: 100%;
        max-width: min(280px, 88vw);
    }

    .footer-bottom__badges-right img {
        display: block;
        width: 100%;
        max-width: 100%;
        height: auto;
    }

    .footer-bottom__badges-right img:nth-child(1) {
        width: min(200px, 72vw);
        max-width: 100%;
    }

    .footer-bottom__badges-right img:nth-child(2) {
        width: min(120px, 38vw);
        max-width: 100%;
    }

    .footer-bottom__badges-right img:nth-child(3) {
        width: min(220px, 85vw);
        max-width: 100%;
    }

    .ebrochure-card {
        width: 260px;
        height: auto;
        padding: 24px 20px 16px;
    }
    .ebrochure-card__img {
        width: 160px;
        height: auto;
    }
}

/* ============================================
   NEW SECTIONS - MOBILE (576px - 767px)
   ============================================ */
@media (max-width: 767.98px) {
    .dont-take-word {
        margin-top: -150px;
    }
    .dont-take-word__card {
        padding: 32px 20px 36px;
        border-radius: 20px;
    }
    .dont-take-word__title {
        font-size: 32px;
        line-height: 30px;
    }
    .dont-take-word__subtitle {
        font-size: 16px;
        margin-bottom: 24px;
    }
    .dont-take-word__play-btn img {
        width: 60px;
        height: 60px;
    }

    .what-is-crust {
        --wic-overlap: 220px;
        height: auto;
        padding-top: calc(var(--wic-overlap) + 48px);
        padding-bottom: 48px;
    }
    .what-is-crust__title {
        margin-top: 200px;
        font-size: 40px;
    }
    .what-is-crust__text {
        font-size: 15px;
        line-height: 28px;
    }
    .what-is-crust__deco-left {
        width: 200px;
        height: auto;
        aspect-ratio: 471 / 487;
    }
    .what-is-crust__deco-right {
        width: 220px;
        height: auto;
        aspect-ratio: 518 / 414;
        right: -48px;
    }
    .crust-card-wrapper {
        width: 320px;
    }
    .crust-card {
        width: 320px;
        height: 500px;
    }
    .crust-card__img-wrap {
        width: 280px;
        height: 280px;
    }
    .crust-card__heading {
        font-size: 30px;
        line-height: 30px;
    }
    .crust-card__desc {
        font-size: 16px;
    }

    .crust-story__cup {
        left: max(-36px, calc(-100 * var(--crust-d) / 580));
    }

    .why-now {
        padding-top: 60px;
        padding-bottom: 60px;
    }
    .why-now__title {
        font-size: 32px;
        line-height: 30px;
        margin-bottom: 32px;
    }
    .why-now__feature-title {
        font-size: 18px;
    }

    .easy-steps {
        padding-top: 60px;
        padding-bottom: 60px;
    }
    .easy-steps__timeline {
        padding-top: 64px;
        row-gap: clamp(88px, 10vw, 136px);
    }
    .easy-steps__card {
        max-width: 360px;
        padding: 120px 16px 56px;
    }
    .easy-steps__badge {
        width: 140px;
        height: 140px;
    }
    .easy-steps__badge-inner {
        width: 118px;
        height: 118px;
    }
    .easy-steps__icon {
        max-width: 52px;
        max-height: 52px;
    }
    .easy-steps__label {
        font-size: 32px;
    }

    .territories {
        padding-top: 60px;
        padding-bottom: 60px;
    }
    .territories__subtitle {
        margin-bottom: 40px;
    }
    .territories__search {
        height: auto;
        min-height: 72px;
        padding-left: 24px;
        padding-right: 12px;
    }
    .territories__select {
        font-size: 16px;
    }
    .territories__search-trigger {
        width: 52px;
        height: 52px;
    }
    .territories__search-chevron {
        width: 16px;
        height: 10px;
    }
    .territories__map-wrap {
        margin-bottom: 40px;
    }
    .territories__grid-card {
        margin-bottom: 80px;
    }
    .territories__banner {
        min-height: 0;
        padding: 24px 16px;
        border-radius: 16px;
    }
    .territories__banner-text {
        font-size: 28px;
        line-height: 32px;
    }

    .news-blog {
        padding-top: 60px;
        padding-bottom: 60px;
    }

    .footer-form {
        padding-top: 64px;
        padding-bottom: 64px;
    }
    .footer-form__title {
        font-size: 36px;
        line-height: 1.2;
        margin-bottom: 32px;
    }
    .footer-form__label {
        font-size: 16px;
    }
    .footer-form__input {
        height: 48px;
        font-size: 15px;
        padding: 0 16px;
    }
    .footer-form__textarea {
        min-height: 120px;
        padding-top: 14px;
        padding-bottom: 14px;
    }
    .footer-form__btn {
        width: 100%;
        font-size: 15px;
    }
    .footer-order {
        padding-top: 40px;
        padding-bottom: 40px;
    }
    .footer-order__inner {
        flex-direction: column;
        text-align: center;
    }
    .footer-order__title {
        font-size: 36px;
        line-height: 1.2;
    }
    .footer-order__btn {
        width: 220px;
    }
    .footer-nav__grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 32px 24px;
    }
    .footer-nav__heading {
        font-size: 18px;
    }
    .footer-nav__links a {
        font-size: 16px;
        line-height: 32px;
    }
}

/* ============================================
   NEW SECTIONS - SMALL MOBILE (< 576px)
   ============================================ */
@media (max-width: 575.98px) {
    .dont-take-word {
        margin-top: -120px;
        padding-bottom: 0;
    }
    .dont-take-word__card {
        padding: 24px 16px 32px;
        border-radius: 16px;
    }
    .dont-take-word__title {
        font-size: 42px;
        line-height: 26px;
    }
    .dont-take-word__subtitle {
        font-size: 21px;
    }
    .dont-take-word__play-btn img {
        width: 48px;
        height: 48px;
    }

    .what-is-crust {
        --wic-overlap: 140px;
        height: auto;
        padding-top: calc(var(--wic-overlap) + 40px);
        padding-bottom: 40px;
    }
    .what-is-crust__title {
        margin-top: 120px;
        font-size: 32px;
    }
    .what-is-crust__text {
        font-size: 14px;
        line-height: 26px;
    }
    .what-is-crust__deco-left {
        width: 140px;
        height: auto;
        aspect-ratio: 471 / 487;
        left: -56px;
        top: 96px;
    }
    .what-is-crust__deco-right {
        width: 150px;
        height: auto;
        aspect-ratio: 518 / 414;
        right: -42px;
    }
    .crust-card-wrapper {
        width: 280px;
    }
    .crust-card {
        width: 296px;
        height: 478px;
    }
    .crust-card__img-wrap {
        width: 250px;
        height: 250px;
    }
    .crust-card__heading {
        font-size: 26px;
        line-height: 26px;
    }
    .crust-card__desc {
        font-size: 15px;
        line-height: 22px;
    }

    .crust-story__cup {
        left: max(-24px, calc(-100 * var(--crust-d) / 580));
    }
    .crust-story__sauce {
        width: min(100%, calc(160 * var(--crust-d) / 580));
        right: 0;
    }
    .crust-story__pizza-box {
        width: min(100%, calc(360 * var(--crust-d) / 580));
        height: auto;
        aspect-ratio: 445 / 523;
        right: max(-24px, calc(-60 * var(--crust-d) / 580));
    }

    .why-now__title {
        font-size: 26px;
        line-height: 26px;
    }
    .why-now__feature-title {
        font-size: 16px;
    }
    .why-now__feature-icon {
        max-width: 96px;
        height: 80px;
        margin-bottom: 16px;
    }

    .why-now__feature-icon--explode {
        width: 85px;
        height: 81px;
        max-width: 85px;
    }

    .why-now__feature-icon--prime {
        width: 61px;
        height: 81px;
        max-width: 61px;
    }

    .why-now__feature-icon--shop {
        width: 75px;
        height: 81px;
        max-width: 75px;
    }

    .why-now__feature-icon--badge {
        width: 92px;
        height: 82px;
        max-width: 92px;
    }

    .easy-steps__timeline {
        padding-top: 56px;
        row-gap: clamp(80px, 11vw, 112px);
    }
    .easy-steps__card {
        padding: 100px 14px 48px;
        min-height: 280px;
    }
    .easy-steps__badge {
        width: 120px;
        height: 120px;
    }
    .easy-steps__badge-inner {
        width: 100px;
        height: 100px;
    }
    .easy-steps__icon {
        max-width: 44px;
        max-height: 44px;
    }
    .easy-steps__label {
        font-size: 26px;
    }
    .easy-steps__desc {
        font-size: 15px;
    }

    .territories__grid {
        --bs-gutter-x: 0.5rem;
        --bs-gutter-y: 0.75rem;
    }
    .territories__state-name {
        font-size: 16px;
    }
    .territories__cities li {
        font-size: 14px;
    }

    .footer-form__title {
        font-size: 28px;
        margin-bottom: 24px;
    }
    .footer-form__label {
        font-size: 15px;
    }
    .footer-order__title {
        font-size: 28px;
    }
    .footer-nav__grid {
        grid-template-columns: 1fr;
        gap: 28px;
    }
    .footer-bottom__copy {
        font-size: 13px;
        line-height: 1.4;
    }

    .footer-bottom__legal {
        font-size: 12px;
    }

    .ebrochure-card {
        width: 220px;
        padding: 20px 16px 12px;
        bottom: 10px;
        right: 10px;
    }
    .ebrochure-card__title {
        font-size: 15px;
    }
    .ebrochure-card__img {
        width: 140px;
        height: auto;
    }

    .ebrochure-modal {
        padding: 16px;
    }

    .ebrochure-modal__dialog {
        padding: 24px 20px 24px;
    }

    .ebrochure-modal__preview {
        width: 130px;
        max-height: 115px;
        margin-bottom: 16px;
    }

    .ebrochure-modal__download {
        font-size: 15px;
        min-height: 48px;
        padding: 12px 16px;
        margin-top: 16px;
    }
}

/* ============================================
   Mobile — unified heading & body copy
   CEO welcome, Why Franchise section title, pizza card titles;
   CEO subtitle & pizza card descriptions
   ============================================ */
@media (max-width: 767.98px) {
    .ceo-welcome__title,
    .why-franchise__title,
    .pizza-card__heading {
        font-size: 30px;
        line-height: 1.15;
    }

    .ceo-welcome__subtitle,
    .pizza-card__desc {
        font-size: 16px;
        line-height: 1.55;
        font-weight: 300;
    }

    .pizza-card__heading {
        min-height: 0;
    }

    .americans-love__text br {
        display: none;
    }

    /* Don't take our word / What is Crust — larger titles; matching body copy */
    .dont-take-word__title {
        font-size: 42px;
        line-height: 1.18;
    }

    .what-is-crust__title {
        font-size: 44px;
        line-height: 1.12;
    }

    .dont-take-word__subtitle,
    .what-is-crust__text {
        font-size: 21px;
        line-height: 1.6;
        font-weight: 400;
    }

    .what-is-crust__text-line {
        display: inline;
    }
}
