@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap');

/*
 * hero-lp-v2.css
 * Styles for the two-column PPC landing page hero and stats bar.
 * Add to landing-page-mods.css or include as a separate file via $css_includes.
 *
 * All classes are prefixed lp2- to avoid any collision with existing site styles.
 */

body {
    font-family: 'Inter', sans-serif;
}


/* Tablet two-column — padding adjustment only */
@media (max-width: 1199px) {
    .lp2-hero-left {
        padding: 32px 20px 24px;
    }
}

/* Below lg — layout switches to stacked */
@media (max-width: 991px) {
    .lp2-hero-right {
        margin: 0 16px 32px;
        align-self: auto;
        padding: 24px 20px;
    }
    .lp2-features {
        max-width: 100%;
    }
    .lp2-hero-row {
        min-height: auto;
    }
}

/* Mobile — any additional small screen tweaks */
@media (max-width: 575px) {
    .lp2-hero-left {
        padding: 24px 16px 20px;
    }
    .lp2-hero-right {
        margin: 0 12px 24px;
    }
}

@media (max-width: 1199px) {
    .lp2-hero-left {
        padding: 32px 20px 24px;
    }
    .lp2-hero-right {
        padding: 24px 20px;
    }
}


header.fixed-top.fixed-header {
    background-color: #ffffff;
}


#alpha .ban-block.lp2-hero-outer,
.ban-block.lp2-hero-outer {
    background-color: #004677;
    background-image: linear-gradient(-15deg, #0270bd 0%, #004677 100%);
    padding-top: 85px !important;
    padding-bottom: 50px !important;
    padding-left: 20px;
    padding-right: 20px;
}

.trusted-companies-wrap {
    border-top: 1px solid #63676b;
}

/* =============================================================
   Hero outer wrapper
   Full-width white background, same role as .ban-block
   ============================================================= */

.lp2-hero-outer {
    background-color: #ffffff;
    width: 100%;
}

.lp2-hero-row {
    max-width: 1170px;
    margin-left: auto;
    margin-right: auto;
    min-height: 340px;
    align-items: stretch;
}


/* =============================================================
   Left column
   ============================================================= */

.lp2-hero-left {
    background-color: transparent;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 48px 40px 48px 60px;
}

.lp2-hero-gap {
    background-color: transparent;
}

/* Eyebrow label — shown only if $herotexttop is set */
.lp2-eyebrow {
    font-size: 12px;
    font-weight: 600;
    color: #B5D4F4; 
    letter-spacing: 0.06em;
    text-transform: uppercase;
    margin-bottom: 10px;
}

/* H1 */
.lp2-title {
    font-size: 38px;
    font-weight: 400;
    line-height: 1.2;
    color: #ffffff;
    margin-bottom: 16px;
}

.lp2-title-accent {
    color: #20bf55;
    font-weight: 400;
}

/* Subhead paragraph */
.lp2-description {
    font-size: 1.1rem;
    color: #C5DCF5; 
    line-height: 1.65;
    max-width: 440px;
    margin-bottom: 28px;
}

/* CTA button row */
.lp2-cta-row {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 16px;
}


.lp2-btn-primary {
    display: inline-block;
    padding: 0.85rem 1.6rem;
    background-color: #20bf55;
    color: #1a2e1a !important;
    font-size: 1.3rem;
    font-weight: 500;
    border-radius: 6px;
    text-decoration: none !important;
    white-space: nowrap;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
    transition: background-color 0.15s ease, box-shadow 0.15s ease, transform 0.15s ease;
}

.lp2-btn-primary:hover,
.lp2-btn-primary:focus {
    background-color: #1aab4d;
    color: #1a2e1a !important;
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.25);
    transform: translateY(-1px);
}

.lp2-btn-primary:active {
    transform: translateY(0);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}


/* Secondary button — ghost style */
.lp2-btn-secondary {
    display: inline-block;
    padding: 12px 20px;
    background-color: transparent;
    color: #B5D4F4 !important;
    border-color: #185FA5;
    font-size: 15px;
    font-weight: 600;
    border: 1px solid #185FA5;
    border-radius: 4px;
    text-decoration: none !important;
    white-space: nowrap;
    transition: background-color 0.15s ease;
}
.lp2-btn-secondary:hover,
.lp2-btn-secondary:focus {
    background-color: rgba(255, 255, 255, 0.08);
    color: #E6F1FB !important;
}

/* Small reassurance line below the CTAs */
.lp2-micro {
    font-size: 1rem;
    color: #C5DCF5;
    margin-bottom: 0;
    margin-top: 1rem;
}


/* =============================================================
   Right column — "How it works"
   Hidden on mobile via d-none d-lg-flex in the template
   ============================================================= */


.lp2-hero-right {
    background-color: #eeeeee;
    flex-direction: column;
    justify-content: flex-start;
    padding-top: 24px;
    padding-bottom: 24px;
    padding-left: 32px !important;
    padding-right: 32px !important;
    align-self: center;
    width: 100%;
    border-radius: 10px;
    box-shadow: 0 8px 64px rgba(0, 0, 0, 0.75);
}


.lp2-features {
    width: 100%;
    margin: 0 auto;
}


.lp2-features-header {
    font-size: 22px;
    font-weight: 400;
    color: #0C447C;
    margin-bottom: 18px;
    text-align: center;
}

.lp2-features-header::after {
    content: '';
    display: block;
    width: 90%;
    height: 3px;
    background: radial-gradient(ellipse at center, #20bf55  0%, transparent 100%);
    margin: 14px auto 0;
}

.lp2-feature-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.lp2-feature-icon {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background-color: #0C447C;
    color: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    margin-top: 2px;
    font-size: 16px;
    font-weight: 700;
    font-family: sans-serif;
    line-height: 1;
}

.lp2-feature-title {
    font-size: 1rem;
    font-weight: 700;
    color: #1a1a1a;
    line-height: 1.3;
}

.lp2-feature-description {
    font-size: 1rem;
    color: #555555;
    line-height: 1.5;
}

.lp2-feature {
    display: flex;
    align-items: flex-start;
    gap: 10px;
}

.lp2-feature-body {
    display: flex;
    flex-direction: column;
    gap: 2px;
}


/* =============================================================
   Stats / trust bar
   ============================================================= */

.lp2-stats-bar {
    background-color: #042C53;
    width: 100%;
}

.lp2-stats-inner {
    max-width: 1170px;
    margin: 0 auto;
}

.lp2-stat {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 20px 12px;
    border-right: 1px solid #185FA5;
}

.lp2-stat:last-child {
    border-right: none;
}

/* On mobile (2x2 grid): remove right border from the even columns
   and add a top border to the bottom row */
@media (max-width: 767px) {
    .lp2-stat:nth-child(2) {
        border-right: none;
    }
    .lp2-stat:nth-child(3),
    .lp2-stat:nth-child(4) {
        border-top: 1px solid #185FA5;
    }
}

.lp2-stat-val {
    display: block;
    font-size: 22px;
    font-weight: 700;
    color: #E6F1FB;
    line-height: 1.1;
}

.lp2-stat-label {
    display: block;
    font-size: 12px;
    color: #85B7EB;
    margin-top: 5px;
}




/* =============================================================
   Section wrapper — light blue background
   ============================================================= */

.lp-feature-section {
    padding: 60px 0;
    background-color: #E6F1FB;
}


/* =============================================================
   Intro — centered heading and subheading
   ============================================================= */

.lp-feature-intro {
    text-align: center;
    margin-bottom: 40px;
}

.lp-feature-heading {
    font-size: 1.75rem;
    font-weight: 600;
    color: #042C53;
    line-height: 1.25;
    margin-bottom: 12px;
}

.lp-feature-subheading {
    font-size: 1.125rem;
    color: #3f4f5e;
    line-height: 1.6;
    max-width: 700px;
    font-weight: 500;
    margin: 0 auto;
}

/* =============================================================
   Grid
   ============================================================= */

.lp-feature-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}


/* =============================================================
   Tile — white card, centered content
   ============================================================= */

.lp-feature-tile {
    background: #ffffff;
    border-radius: 12px;
    padding: 32px 24px;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 16px;
    border: 1px solid rgba(12, 68, 124, 0.12);
    box-shadow: 0 4px 20px rgba(12, 68, 124, 0.3);
}

.lp-feature-tile-title::after {
    content: '';
    display: block;
    width: 240px;
    height: 3px;
    background: radial-gradient(ellipse at center, #20bf55  0%, transparent 100%);
    margin: 14px auto 0;
}

/* Circular gradient icon */
.lp-feature-icon-wrap {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    background: linear-gradient(-15deg, #0270bd 0%, #004677 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #ffffff;
    flex-shrink: 0;
}

.lp-feature-tile-title {
    font-size: 16px;
    font-weight: 600;
    color: #1a1a1a;
    line-height: 1.3;
}

.lp-feature-tile-description {
    font-size: 1rem;
    color: #555555;
    line-height: 1.3;
    font-weight: 400;
}

.lp-feature-section .container {
    padding: 0 20px 20px 20px;
}


.lp-feature-cta {
    text-align: center;
    margin-top: 60px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
}

.lp-feature-cta-micro {
    font-size: 14px;
    color: #185FA5;
    margin: 0;
}




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

@media (max-width: 991px) {
    .lp-feature-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 575px) {
    .lp-feature-section {
        padding: 40px 0;
    }
    .lp-feature-heading {
        font-size: 22px;
    }
    .lp-feature-subheading {
        font-size: 15px;
    }
    .lp-feature-grid {
        grid-template-columns: 1fr;
        gap: 16px;
    }
}



/*
 * How it works + carrier registration — combined section
 * Gradient blue background, staggered white step cards,
 * animated message bubbles, frosted glass 10DLC card below.
 * All classes prefixed lp-hiw- to avoid collisions.
 */


/* =============================================================
   Section wrapper — full gradient background
   ============================================================= */

.lp-hiw-section {
    background: linear-gradient(-15deg, #0270bd 0%, #004677 100%);
    padding: 60px 0;
    position: relative;
    overflow: hidden;
}



/* =============================================================
   Steps wrapper — contains heading, cards and bubbles
   Overflow hidden clips bubbles to this area only
   ============================================================= */

.lp-hiw-steps-wrap {
    position: relative;
    overflow: hidden;
    padding-bottom: 8px; /* prevents clipping card shadows */
}


/* =============================================================
   Message bubbles — constrained within steps wrapper
   ============================================================= */

.lp-hiw-bubbles {
    position: absolute;
    z-index: 1;
    pointer-events: none;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.lp-hiw-bubbles-right { right: 0; top:  100px; }
.lp-hiw-bubbles-left  { left:  0; bottom: 40px; }

.lp-hiw-bubble-label {
    font-size: .75rem;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.4);
    letter-spacing: 0.05em;
    text-transform: uppercase;
    margin-bottom: 2px;
}

.lp-hiw-bubble {
    border-radius: 10px;
    padding: 7px 12px;
    font-size: 0.75rem;
    line-height: 1.45;
    opacity: 0;
    transform: translateY(10px);
    transition: opacity 0.5s ease, transform 0.5s ease;
}

.lp-hiw-bubble-out {
    background: #ffffff;
    color: #042C53;
    border-radius: 10px 10px 3px 10px;
}

.lp-hiw-bubble-in {
    background: rgba(255, 255, 255, 0.18);
    color: #ffffff;
    border: 1px solid rgba(255, 255, 255, 0.25);
    border-radius: 10px 10px 10px 3px;
}

/* Top bubbles — triggered by heading observer */
.lp-hiw-section.lp-hiw-visible-top .lp-hiw-b1 {
    opacity: 1;
    transform: translateY(0);
    transition-delay: 0.2s;
}

.lp-hiw-section.lp-hiw-visible-top .lp-hiw-b2 {
    opacity: 1;
    transform: translateY(0);
    transition-delay: 0.9s;
}

/* Bottom bubbles — triggered by card 3 observer */
.lp-hiw-section.lp-hiw-visible-bottom .lp-hiw-b3 {
    opacity: 1;
    transform: translateY(0);
    transition-delay: 0.2s;
}

.lp-hiw-section.lp-hiw-visible-bottom .lp-hiw-b4 {
    opacity: 1;
    transform: translateY(0);
    transition-delay: 0.9s;
}


/* =============================================================
   Section heading
   ============================================================= */

.lp-hiw-intro {
    text-align: center;
    margin-bottom: 60px;
    position: relative;
    z-index: 2;
}

.lp-hiw-heading {
    font-size: 1.75rem;
    font-weight: 600;
    color: #ffffff;
    line-height: 1.3;
    margin-bottom: 10px;
    letter-spacing: -0.01em;
}

.lp-hiw-head-accent {
    width: 50%;
    height: 2px;
    background: radial-gradient(ellipse at center, #20bf55 0%, transparent 100%);
    border-radius: 1px;
    margin: 0 auto;
}


/* =============================================================
   Step cards
   ============================================================= */

.lp-hiw-steps {
    display: flex;
    flex-direction: column;
    gap: 24px;
    position: relative;
    z-index: 2;
}

.lp-hiw-card {
    background: #ffffff;
    border: none;
    border-radius: 12px;
    padding: 30px 22px;
    display: flex;
    align-items: center;
    gap: 22px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
    width: 50%;
}

.lp-hiw-card-1 { margin-right: auto; }
.lp-hiw-card-2 { margin: 0 auto;     }
.lp-hiw-card-3 { margin-left: auto;  }

.lp-hiw-card-icon {
    width: 85px;
    height: 85px;
    border-radius: 50%;
    background: linear-gradient(-15deg, #0270bd 0%, #004677 100%);
    border: 2px solid rgba(255, 255, 255, 0.2);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #ffffff;
    flex-shrink: 0;
}

.lp-hiw-card-body {
    display: flex;
    flex-direction: column;
    gap: 6px;
    flex: 1;
}

.lp-hiw-card-step {
    font-size: 0.75rem;
    font-weight: 700;
    color: #20bf55;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.lp-hiw-card-title {
    font-size: 1.1rem;
    font-weight: 600;
    color: #042C53;
    line-height: 1.3;
    margin: 0;
}

.lp-hiw-card-divider {
    height: 2px;
    width: 100%;
    max-width: 160px;
    background: radial-gradient(ellipse at center, #20bf55 0%, transparent 100%);
    border-radius: 1px;
}

.lp-hiw-card-desc {
    font-size: 1rem;
    color: #444444;
    line-height: 1.65;
    margin: 0;
}


/* =============================================================
   Separator with centered label
   ============================================================= */

.lp-hiw-separator {
    display: flex;
    align-items: center;
    gap: 16px;
    margin: 52px 0 40px;
    position: relative;
    z-index: 2;
}

.lp-hiw-separator::before,
.lp-hiw-separator::after {
    content: '';
    flex: 1;
    height: 1px;
    background: rgba(255, 255, 255, 0.2);
}

.lp-hiw-separator-text {
    font-size: 0.8rem;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.9);
    letter-spacing: 0.06em;
    text-transform: uppercase;
    white-space: nowrap;
    background: rgba(255, 255, 255, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.22);
    padding: 6px 18px;
    border-radius: 20px;
}


/* =============================================================
   Registration (10DLC) card
   ============================================================= */

.lp-hiw-reg {
    position: relative;
    z-index: 2;
    max-width: 680px;
    margin: 0 auto;
    background: rgba(255, 255, 255, 0.13);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.22);
    border-radius: 12px;
    padding: 32px 36px;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 14px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
}

.lp-hiw-reg-icon {
    width: 52px;
    height: 52px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.18);
    border: 1px solid rgba(255, 255, 255, 0.28);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #ffffff;
}

.lp-hiw-reg-pill {
    display: inline-block;
    font-size: 11px;
    font-weight: 600;
    color: #85B7EB;
    background: rgba(255, 255, 255, 0.1);
    padding: 4px 14px;
    border-radius: 20px;
    letter-spacing: 0.03em;
}

.lp-hiw-reg-title {
    font-size: 20px;
    font-weight: 600;
    color: #ffffff;
    line-height: 1.3;
    margin: 0;
    padding-bottom: 10px;
}

.lp-hiw-reg-body {
    font-size: 1rem;
    color: #ecf6ff;
    line-height: 1.5;
    margin: 0;
    max-width: 560px;
    text-align: left;
    width: 100%;
}

.lp-hiw-reg-body + .lp-hiw-reg-body {
    margin-top: 12px;
}

.lp-hiw-reg-note {
    font-size: 1rem;
    font-weight: 600;
    color: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding-top: 16px;
    border-top: 1px solid rgba(255, 255, 255, 0.15);
    width: 100%;
}

.lp-hiw-reg-note svg {
    color: #20bf55;
    flex-shrink: 0;
}


.lp-hiw-cta {
    text-align: center;
    margin-top: 60px;
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
}

.lp-hiw-cta-micro {
    font-size: 1 rem;
    color: #d3e9ff;
    margin: 0;
    margin-top: 5px;
}


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

@media (max-width: 991px) {
    .lp-hiw-card {
        width: 75%;
    }

    .lp-hiw-bubbles {
        display: none; /* not enough room at tablet */
    }
}

@media (max-width: 767px) {
    .lp-hiw-card {
        width: 100%;
    }

    .lp-hiw-card-1,
    .lp-hiw-card-2,
    .lp-hiw-card-3 {
        margin: 0;
    }

    .lp-hiw-reg {
        padding: 24px 20px;
    }

    .lp-hiw-heading {
        font-size: 22px;
    }

    .lp-hiw-reg-title {
        font-size: 18px;
    }
}

@media (max-width: 575px) {
    .lp-hiw-section {
        padding: 40px 0;
    }
}