/* =========================================================
   ELEVATE — lead-magnet landing page (v12 — design-match pass)
   All selectors page-scoped under .elv-* per the no-cross-section rule.
   Reference: https://www.ohyescommunications.com/elevate/
   ========================================================= */

.elevate-page main { overflow-x: clip; }

/* Dark CTA variant (only used in the Inside section — black pill) */
.elv-cta-dark {
    background: #1d1d1b;
    color: #fff;
    border-color: #1d1d1b;
}
.elv-cta-dark:hover { background: #000; border-color: #000; color: #fff; }

/* =========================================================
   01. HERO — centered title (3 lines), enlarged video, sublede, CTA
   ========================================================= */
.elv-hero {
    background: #edf3ff;
    padding: 140px 24px 90px;
    text-align: center;
}

.elv-hero-container {
    max-width: 960px;
    margin: 0 auto;
}

.elv-hero-title {
    font-family: var(--font-display);
    font-weight: 500;
    font-size: clamp(1.8rem, 3.2vw, 2.8rem);
    line-height: 1.18;
    letter-spacing: 0.01em;
    text-transform: uppercase;
    color: var(--clr-navy);
    margin: 0 0 40px;
}
.elv-hero-line { display: block; }
.elv-hero-hl {
    display: inline-block;
    background-image: url('../assets/images/elevate/hero-line.webp');
    background-size: 100% 100%;
    background-position: 50% 50%;
    background-repeat: no-repeat;
    padding: 4px 24px 8px;
    color: var(--clr-navy);
    font-weight: 600;
    margin-top: 8px;
    white-space: nowrap;
}

.elv-hero-video {
    max-width: 720px;
    margin: 0 auto 36px;
    border-radius: 24px;
    overflow: hidden;
    background: #000;
    aspect-ratio: 16 / 9;
    box-shadow: 0 18px 48px rgba(0, 0, 0, 0.08);
}
.elv-hero-video video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* Sublede uses .section-sublede utility; tighten max-width here */
.elv-hero-sub {
    max-width: 640px;
    margin: 0 auto 32px;
    text-align: center;
}
.elv-hero-sub strong { font-weight: 500; }

/* =========================================================
   02. ATTENTION — split white-left / lavender-right
   ========================================================= */
.elv-attention {
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-items: stretch;
    background: #fff;
}

/* LEFT — white side */
.elv-attention-left {
    padding: 100px clamp(40px, 6vw, 90px) 100px clamp(40px, 8vw, 130px);
    display: flex;
    flex-direction: column;
    justify-content: center;
    max-width: 720px;
    margin-left: auto;
}

.elv-attention-title {
    font-family: var(--font-display);
    font-weight: 500;
    font-size: clamp(1.8rem, 2.6vw, 2.5rem);
    line-height: 1.15;
    letter-spacing: 0.005em;
    text-transform: uppercase;
    color: var(--clr-navy);
    margin: 0 0 28px;
}
.elv-attention-line { display: block; }
.elv-attention-fx {
    display: inline-block;
    background-image: url('../assets/images/elevate/red-line.webp');
    background-size: 100% 14px;
    background-repeat: no-repeat;
    background-position: left bottom;
    padding-bottom: 12px;
    margin-top: 4px;
}
.elv-attention-fx strong { font-weight: 600; }

.elv-attention-callout {
    font-family: var(--font-body);
    font-size: clamp(1.05rem, 1.3vw, 1.2rem);
    line-height: 1.5;
    color: #8089ff;
    font-weight: 500;
    margin: 0 0 28px;
    letter-spacing: 0.3px;
}
.elv-attention-callout strong { font-weight: 600; color: #8089ff; }

.elv-attention-body p {
    font-family: var(--font-body);
    font-size: 0.95rem;
    line-height: 1.7;
    color: var(--clr-navy);
    margin: 0 0 18px;
    letter-spacing: 0.4px;
}
.elv-attention-closer {
    font-weight: 500 !important;
    margin-top: 22px !important;
}

.elv-attention-left .btn {
    align-self: flex-start;
    margin-top: 12px;
}

/* RIGHT — lavender side with photo + decor */
.elv-attention-right {
    position: relative;
    background: #8089ff;
    padding: 60px clamp(24px, 3vw, 48px);
    overflow: hidden;
    min-height: 600px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.elv-attention-photo {
    position: relative;
    z-index: 2;
    max-width: 520px;
    width: 100%;
    aspect-ratio: 4 / 5;
    overflow: hidden;
    transform: rotate(-1deg);
}
.elv-attention-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.elv-att-decor {
    position: absolute;
    z-index: 3;
    pointer-events: none;
}
.elv-att-decor--yellow-circle {
    top: 6%;
    right: 8%;
    width: 48px;
    height: auto;
}
.elv-att-decor--yellow-tri {
    top: 40%;
    left: 6%;
    width: 56px;
    height: auto;
}
.elv-att-decor--blue-half {
    bottom: 10%;
    left: 10%;
    width: 56px;
    height: auto;
}

/* =========================================================
   03. BENEFITS — grey bg, 3-up white cards with overlapping checks
   ========================================================= */
.elv-benefits {
    background: #f0f0f0;
    padding: clamp(72px, 9vw, 130px) 24px clamp(96px, 11vw, 150px);
}

.elv-benefits-title {
    font-family: var(--font-display);
    font-weight: 500;
    font-size: clamp(1.7rem, 2.8vw, 2.5rem);
    line-height: 1.2;
    text-transform: uppercase;
    color: var(--clr-navy);
    text-align: center;
    margin: 0 auto 80px;
    max-width: 820px;
}
.elv-benefits-line { display: block; }
.elv-benefits-fx { display: block; margin-top: 4px; }
.elv-benefits-fx strong { font-weight: 600; }

.elv-benefits-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 28px;
    max-width: 1180px;
    margin: 0 auto;
}

.elv-benefit-card {
    position: relative;
    background: #fff;
    border: 1px solid var(--clr-navy);
    border-radius: 18px;
    padding: 68px 32px 36px;
    text-align: left;
    display: flex;
    flex-direction: column;
    gap: 0;
    min-height: 240px;
}
.elv-benefit-check {
    position: absolute;
    top: -60px;
    left: 50%;
    transform: translateX(-50%);
    width: 120px;
    height: 120px;
    flex-shrink: 0;
}
.elv-benefit-card p {
    font-family: var(--font-body);
    font-size: clamp(1.25rem, 1.45vw, 1.4rem);
    line-height: 1.45;
    color: var(--clr-navy);
    margin: 0;
    letter-spacing: 0.3px;
}
.elv-benefit-card p strong { font-weight: 500; }

/* Underline strokes on bold keywords */
.elv-u {
    background-repeat: no-repeat;
    background-position: left bottom;
    background-size: 100% 8px;
    padding-bottom: 6px;
}
.elv-u--red    { background-image: url('../assets/images/elevate/red-underline-01.webp'); }
.elv-u--yellow { background-image: url('../assets/images/elevate/yellow-underline-01.webp'); }
.elv-u--blue   { background-image: url('../assets/images/elevate/blue-underline-01.webp'); }

/* =========================================================
   04. WHAT'S INSIDE — light lavender bg, iPad + 2x2 cards + CTA
   ========================================================= */
.elv-inside {
    background: #e2eafd;
    padding: clamp(72px, 9vw, 130px) 24px;
}

.elv-inside-grid {
    display: grid;
    grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
    gap: clamp(40px, 5vw, 80px);
    align-items: center;
    max-width: 1200px;
    margin: 0 auto;
}

.elv-inside-graphic {
    display: flex;
    align-items: center;
    justify-content: center;
}
.elv-inside-graphic img {
    width: 100%;
    max-width: 460px;
    height: auto;
    display: block;
}

.elv-inside-content { width: 100%; }

.elv-inside-title {
    font-family: var(--font-display);
    font-weight: 500;
    font-size: clamp(1.8rem, 2.8vw, 2.6rem);
    line-height: 1.15;
    text-transform: uppercase;
    color: var(--clr-navy);
    margin: 0 0 36px;
}
.elv-inside-fx strong { font-weight: 600; }

.elv-inside-grid-cards {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 32px 36px;
    margin-bottom: 40px;
}

.elv-inside-card {
    display: grid;
    grid-template-columns: 76px 1fr;
    gap: 4px 18px;
    grid-template-areas:
        "num title"
        "num body";
    align-items: start;
}
.elv-inside-num {
    grid-area: num;
    width: 68px;
    height: auto;
    margin-top: 2px;
}

/* Multi-line underline: each <span> is a block, each gets underline */
.elv-inside-card-title {
    grid-area: title;
    font-family: var(--font-display);
    font-weight: 500;
    font-size: clamp(1.1rem, 1.3vw, 1.25rem);
    line-height: 1.35;
    text-transform: uppercase;
    margin: 0 0 12px;
    letter-spacing: 0.01em;
}
.elv-inside-card-title span {
    display: block;
    padding-bottom: 4px;
    margin-bottom: 1px;
    background-repeat: no-repeat;
    background-position: left bottom;
    background-size: 100% 5px;
    width: fit-content;
    max-width: 100%;
}
.elv-inside-card-title--lavender { color: #8089ff; }
.elv-inside-card-title--lavender span { background-image: url('../assets/images/elevate/blue-underline-02.webp'); }
.elv-inside-card-title--red { color: var(--clr-red); }
.elv-inside-card-title--red span { background-image: url('../assets/images/elevate/red-underline-02.webp'); }
.elv-inside-card-title--blue { color: #0152ed; }
.elv-inside-card-title--blue span { background-image: url('../assets/images/elevate/blue-underline-01.webp'); }
.elv-inside-card-title--yellow { color: #c79100; }
.elv-inside-card-title--yellow span { background-image: url('../assets/images/elevate/yellow-underline-02.webp'); }

.elv-inside-card p {
    grid-area: body;
    font-family: var(--font-body);
    font-size: 0.92rem;
    line-height: 1.55;
    color: var(--clr-navy);
    margin: 6px 0 0;
    letter-spacing: 0.3px;
}
.elv-inside-card p strong { font-weight: 500; }

.elv-inside-content .btn { display: inline-flex; }

/* =========================================================
   05. BONUS — red bg w/ vertical-bar pattern, 2-col headline + body
   ========================================================= */
.elv-bonus {
    background-color: var(--clr-red);
    background-repeat: no-repeat;
    background-position: center center;
    background-size: 100% 100%;
    padding: clamp(60px, 7vw, 110px) clamp(32px, 6vw, 110px);
    color: #fff;
}

.elv-bonus-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: clamp(32px, 5vw, 80px);
    max-width: 1200px;
    margin: 0 auto;
    align-items: start;
}

.elv-bonus-flag {
    font-family: var(--font-display);
    font-size: clamp(1.4rem, 2vw, 1.9rem);
    line-height: 1;
    color: #fff;
    margin: 0 0 8px;
    font-weight: 400;
    text-transform: capitalize;
}
.elv-bonus-flag strong { font-weight: 500; }

.elv-bonus-title {
    font-family: var(--font-display);
    font-weight: 400;
    font-size: clamp(1.8rem, 3.2vw, 2.9rem);
    line-height: 1.15;
    text-transform: uppercase;
    color: #fff;
    margin: 0;
    letter-spacing: 0.005em;
}
.elv-bonus-line { display: block; }
.elv-bonus-title strong { font-weight: 500; font-style: italic; font-family: var(--font-display); }

/* Weight hierarchy on the bonus body — first line is bold, body has
   light-weight base with bold accents on "Oh Yes team member" + closer */
.elv-bonus-body {
    font-family: var(--font-body);
    font-weight: 300;
    font-size: clamp(0.95rem, 1.1vw, 1.05rem);
    line-height: 1.65;
    color: #fff;
    margin: 0 0 16px;
    letter-spacing: 0.3px;
}
.elv-bonus-body:first-child {
    font-weight: 500;
}
.elv-bonus-body strong { font-weight: 500; }

/* =========================================================
   06. HI, I'M KATHY — greige bg, 2-col with framed KATHY!
   ========================================================= */
.elv-kathy {
    background: #ddd4c6;
    padding: clamp(72px, 8vw, 120px) 24px;
}

.elv-kathy-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
    gap: clamp(40px, 5vw, 80px);
    max-width: 1180px;
    margin: 0 auto;
    align-items: start;
}

.elv-kathy-title {
    font-family: var(--font-display);
    font-weight: 500;
    font-size: clamp(2.4rem, 4.4vw, 4rem);
    line-height: 1;
    text-transform: uppercase;
    color: var(--clr-navy);
    margin: 0 0 32px;
    display: flex;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
}
.elv-kathy-greet { display: inline-block; }
.elv-kathy-frame {
    display: inline-block;
    background-image: url('../assets/images/elevate/kathy-bg.webp');
    background-size: 100% 100%;
    background-repeat: no-repeat;
    background-position: 50% 50%;
    padding: 12px 26px 14px;
    color: var(--clr-navy);
}

.elv-kathy-lede {
    font-family: var(--font-body);
    font-weight: 500;
    font-size: clamp(1.1rem, 1.4vw, 1.3rem);
    line-height: 1.5;
    color: var(--clr-red);
    margin: 0 0 28px;
    letter-spacing: 0.3px;
}

.elv-kathy-body p {
    font-family: var(--font-body);
    font-size: 1.02rem;
    line-height: 1.7;
    color: var(--clr-navy);
    margin: 0 0 18px;
    letter-spacing: 0.4px;
}
.elv-kathy-body p strong { font-weight: 500; }
.elv-kathy-signoff {
    font-weight: 500;
    margin-top: 24px !important;
    line-height: 1.4 !important;
}

.elv-kathy-photo {
    width: 100%;
    aspect-ratio: 4 / 5;
    overflow: hidden;
    border: 2px solid #000;
}
.elv-kathy-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 50% 15%;
    display: block;
}

/* =========================================================
   RESPONSIVE — tablet (≤1024)
   ========================================================= */
@media (max-width: 1024px) {
    .elv-hero { padding: 110px 24px 64px; }
    .elv-hero-title { font-size: clamp(1.6rem, 4.2vw, 2.4rem); }
    .elv-hero-hl { white-space: normal; }

    .elv-attention { grid-template-columns: 1fr; }
    .elv-attention-left {
        padding: 72px 32px;
        max-width: 100%;
        margin: 0 auto;
        text-align: left;
    }
    .elv-attention-right {
        padding: 60px 32px;
        min-height: 0;
    }
    .elv-attention-photo { max-width: 460px; }

    .elv-benefits { padding: 72px 24px 96px; }
    .elv-benefits-grid {
        grid-template-columns: 1fr;
        gap: 80px;
        max-width: 540px;
    }

    .elv-inside-grid {
        grid-template-columns: 1fr;
        gap: 48px;
    }
    .elv-inside-graphic img { max-width: 320px; }
    .elv-inside-grid-cards { gap: 28px; }

    .elv-bonus-grid {
        grid-template-columns: 1fr;
        gap: 24px;
    }

    .elv-kathy-grid {
        grid-template-columns: 1fr;
        gap: 40px;
    }
    .elv-kathy-photo {
        max-width: 480px;
        margin: 0 auto;
    }
}

/* =========================================================
   RESPONSIVE — phone (≤768)
   ========================================================= */
@media (max-width: 768px) {
    .elv-hero { padding: 100px 20px 56px; }
    .elv-hero-title { font-size: clamp(1.4rem, 5.4vw, 2rem); margin-bottom: 28px; }
    .elv-hero-video { margin-bottom: 24px; border-radius: 18px; }

    .elv-attention-left { padding: 56px 24px; }
    .elv-attention-title { font-size: clamp(1.5rem, 6vw, 2rem); }
    .elv-attention-right { padding: 60px 24px; }
    .elv-attention-photo { max-width: 360px; }

    .elv-benefits { padding: 56px 20px 80px; }
    .elv-benefits-title { font-size: clamp(1.4rem, 5.6vw, 1.9rem); margin-bottom: 60px; }
    .elv-benefit-check { width: 100px; height: 100px; top: -50px; }
    .elv-benefit-card { padding: 64px 26px 30px; }

    .elv-inside { padding: 56px 20px; }
    .elv-inside-title { font-size: clamp(1.5rem, 5.8vw, 2rem); }
    .elv-inside-grid-cards {
        grid-template-columns: 1fr;
        gap: 24px;
    }

    .elv-bonus { padding: 60px 24px; }
    .elv-bonus-title { font-size: clamp(1.5rem, 6vw, 2rem); }
    .elv-bonus-flag { font-size: 1.3rem; }

    .elv-kathy { padding: 60px 20px; }
    .elv-kathy-title { font-size: clamp(1.8rem, 6.8vw, 2.4rem); gap: 10px; }
    .elv-kathy-lede { font-size: 1.05rem; }
}

/* =========================================================
   RESPONSIVE — small phone (≤480)
   ========================================================= */
@media (max-width: 480px) {
    .elv-hero { padding: 90px 18px 48px; }
    .elv-hero-title { font-size: clamp(1.25rem, 6.2vw, 1.7rem); }

    .elv-attention-left, .elv-attention-right { padding-left: 20px; padding-right: 20px; }
    .elv-att-decor--yellow-circle { width: 36px; right: 6%; top: 4%; }
    .elv-att-decor--yellow-tri { width: 44px; left: 6%; top: 32%; }
    .elv-att-decor--blue-half { width: 44px; left: 6%; bottom: 6%; }

    .elv-bonus-title { font-size: clamp(1.3rem, 7vw, 1.7rem); }
    .elv-kathy-title { font-size: clamp(1.6rem, 8vw, 2.1rem); }
}
