/* ============================================
   Take Action Challenge — Section Styles
   Per-section layout, typography, and effects
   ============================================ */

/* ==========================================
   1. HERO
   ========================================== */
.hero {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: var(--space-3xl) 0 var(--space-2xl);
    overflow: hidden;
    background: var(--bg-gradient);
}

.hero__content {
    position: relative;
    z-index: var(--z-base);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-lg);
    max-width: 720px;
}

/* Hero inline video */
.hero__video-wrapper {
    width: 100%;
    max-width: 640px;
}

.hero__video-container {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9;
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow:
        0 8px 40px rgba(0, 0, 0, 0.4),
        0 0 60px rgba(56, 154, 244, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: #000;
}

.hero__video-container iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: 0;
}

.hero__video-poster {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    cursor: pointer;
    transition: transform 0.4s ease, filter 0.4s ease;
}

.hero__video-container:hover .hero__video-poster {
    transform: scale(1.03);
    filter: brightness(0.85);
}

.hero__video-play {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: none;
    border: none;
    cursor: pointer;
    z-index: 2;
    transition: transform 0.3s ease;
    filter: drop-shadow(0 4px 12px rgba(0, 0, 0, 0.4));
    animation: video-pulse 2s ease-in-out infinite;
}

.hero__video-play svg circle {
    transition: fill 0.3s ease;
}

.hero__video-container:hover .hero__video-play {
    transform: translate(-50%, -50%) scale(1.12);
}

.hero__video-container:hover .hero__video-play svg circle {
    fill: rgba(56, 154, 244, 0.85);
}

@media (max-width: 767px) {
    .hero__video-wrapper {
        max-width: 100%;
    }

    .hero__video-container {
        border-radius: var(--radius-md);
    }

    .hero__video-play svg {
        width: 52px;
        height: 52px;
    }
}

/* Countdown */
.countdown {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
}

.countdown__block {
    display: flex;
    flex-direction: column;
    align-items: center;
    min-width: 56px;
}

.countdown__digit {
    font-family: var(--font-mono);
    font-size: clamp(2rem, 6vw, 3rem);
    font-weight: var(--weight-bold);
    color: var(--text-primary);
    line-height: 1.1;
    letter-spacing: -0.02em;
    overflow: hidden;
}

.countdown__label {
    font-size: var(--text-xs);
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-top: var(--space-xs);
}

.countdown__separator {
    font-family: var(--font-mono);
    font-size: clamp(1.5rem, 4vw, 2rem);
    color: var(--text-muted);
    font-weight: var(--weight-bold);
    padding-bottom: 1.2em;
}

.countdown--sm .countdown__digit {
    font-size: clamp(1.5rem, 4vw, 2.25rem);
}

.countdown--sm .countdown__block {
    min-width: 44px;
}

/* Hero Title */
.hero__title {
    font-family: var(--font-display);
    font-size: var(--text-hero);
    font-weight: var(--weight-extrabold);
    line-height: 1.08;
    letter-spacing: -0.03em;
    color: var(--text-primary);
}

/* Hero Subtitle */
.hero__subtitle {
    font-size: var(--text-body-lg);
    color: var(--text-secondary);
    font-weight: var(--weight-medium);
}

/* Social proof */
.hero__social-proof {
    font-size: var(--text-body);
    color: var(--text-secondary);
}

.hero__social-proof strong {
    color: var(--accent);
    font-weight: var(--weight-bold);
}

/* Micro-testimonial */
.hero__testimonial {
    display: flex;
    align-items: baseline;
    gap: var(--space-sm);
    font-size: var(--text-sm);
    color: var(--text-muted);
    flex-wrap: wrap;
    justify-content: center;
}

.hero__testimonial-quote {
    font-style: italic;
    color: var(--text-secondary);
}

.hero__testimonial-author {
    white-space: nowrap;
}

/* Start date */
.hero__start-date {
    font-size: var(--text-sm);
    color: var(--text-muted);
    margin-top: var(--space-xs);
}

.hero__start-date strong {
    color: var(--text-secondary);
}

/* Background orb */
.hero__orb {
    position: absolute;
    width: 600px;
    height: 600px;
    border-radius: 50%;
    background: radial-gradient(circle,
            rgba(56, 154, 244, 0.12) 0%,
            rgba(56, 154, 244, 0.04) 40%,
            transparent 70%);
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    pointer-events: none;
    filter: blur(60px);
}


/* ==========================================
   2. COMMUNITY PROOF
   ========================================== */
.community-proof {
    background: var(--bg-secondary);
}

/* Section Title (shared) */
.section-title {
    font-family: var(--font-display);
    font-size: var(--text-h2);
    font-weight: var(--weight-bold);
    line-height: 1.15;
    letter-spacing: -0.02em;
    text-align: center;
    margin-bottom: var(--space-2xl);
    color: var(--text-primary);
}

/* Video Testimonial Carousel */
.testimonial-carousel {
    margin-bottom: var(--space-2xl);
    overflow: visible;
}

.testimonial-carousel__track {
    display: flex;
    gap: var(--space-md);
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding: var(--space-sm) var(--space-sm);
    scrollbar-width: none;
}

.testimonial-carousel__track::-webkit-scrollbar {
    display: none;
}

.testimonial-card {
    flex: 0 0 240px;
    scroll-snap-align: start;
    padding: var(--space-sm);
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
    transition: transform var(--transition-base);
    cursor: pointer;
}

.testimonial-card:hover {
    transform: translateY(-4px);
}

.testimonial-card__poster {
    position: relative;
    aspect-ratio: 4 / 5;
    border-radius: var(--radius-md);
    overflow: hidden;
    background: linear-gradient(135deg, rgba(56, 154, 244, 0.12), rgba(56, 154, 244, 0.04));
    display: flex;
    align-items: center;
    justify-content: center;
}

.testimonial-card__initials {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    background: var(--accent-subtle);
    color: var(--accent);
    font-weight: var(--weight-bold);
    font-size: var(--text-h3);
    display: flex;
    align-items: center;
    justify-content: center;
}

.testimonial-card__play {
    position: absolute;
    bottom: var(--space-sm);
    right: var(--space-sm);
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: var(--accent);
    color: var(--text-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: var(--shadow-md);
    border: none;
    cursor: pointer;
    transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}

.testimonial-card__play:hover {
    transform: scale(1.15);
    box-shadow: 0 0 20px rgba(56, 154, 244, 0.4);
}

.testimonial-card__info {
    display: flex;
    flex-direction: column;
    gap: var(--space-xs);
    padding: 0 var(--space-xs);
}

.testimonial-card__name {
    font-weight: var(--weight-semibold);
    font-size: var(--text-sm);
    color: var(--text-primary);
}

.testimonial-card__quote {
    font-size: var(--text-xs);
    color: var(--text-secondary);
    font-style: italic;
}


/* --- Video Modal --- */
.video-modal {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}

.video-modal.active {
    opacity: 1;
    visibility: visible;
}

.video-modal__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.85);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}

.video-modal__content {
    position: relative;
    width: 90%;
    max-width: 640px;
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
    transform: scale(0.95);
    transition: transform 0.3s ease;
}

.video-modal.active .video-modal__content {
    transform: scale(1);
}

.video-modal__close {
    position: absolute;
    top: calc(-1 * var(--space-xl));
    right: 0;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.1);
    color: var(--text-primary);
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background var(--transition-fast);
    z-index: 1;
}

.video-modal__close:hover {
    background: rgba(255, 255, 255, 0.2);
}

.video-modal__video {
    width: 100%;
    aspect-ratio: 9 / 16;
    max-height: 70vh;
    border-radius: var(--radius-lg);
    overflow: hidden;
    background: var(--surface);
    display: flex;
    align-items: center;
    justify-content: center;
}

.video-modal__placeholder {
    width: 100%;
    aspect-ratio: 9 / 16;
    max-height: 70vh;
    border-radius: var(--radius-lg);
    background: linear-gradient(135deg, rgba(56, 154, 244, 0.1), rgba(56, 154, 244, 0.03));
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--space-md);
    color: var(--text-muted);
}

.video-modal__placeholder-icon {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.05);
    display: flex;
    align-items: center;
    justify-content: center;
}

.video-modal__placeholder-text {
    font-size: var(--text-body);
    color: var(--text-muted);
}

.video-modal__meta {
    text-align: center;
}

.video-modal__name {
    font-weight: var(--weight-semibold);
    font-size: var(--text-body-lg);
    color: var(--text-primary);
    margin-bottom: var(--space-xs);
}

.video-modal__quote {
    font-size: var(--text-body);
    color: var(--text-secondary);
    font-style: italic;
}


/* Win Cards */
.win-cards {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
    margin-bottom: var(--space-2xl);
}

.win-card {
    padding: var(--space-lg);
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
}

.win-card__screenshot {
    width: 100%;
    aspect-ratio: 16 / 9;
    border-radius: var(--radius-md);
    overflow: hidden;
    margin-bottom: var(--space-xs);
    background: linear-gradient(135deg, rgba(56, 154, 244, 0.08), rgba(56, 154, 244, 0.02));
}

.win-card__screenshot-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--space-xs);
    color: var(--text-muted);
    font-size: var(--text-xs);
}

.win-card__badge {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
}

.win-card__badge-icon {
    font-size: 1.25rem;
}

.win-card__badge-text {
    font-size: var(--text-xs);
    font-weight: var(--weight-bold);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--success);
}

.win-card__goal {
    font-size: var(--text-body-lg);
    font-weight: var(--weight-semibold);
    color: var(--text-primary);
    font-style: italic;
}

.win-card__meta {
    display: flex;
    gap: var(--space-md);
    font-size: var(--text-sm);
    color: var(--text-muted);
}

.win-card__author {
    color: var(--accent);
    font-weight: var(--weight-medium);
}

.win-card__reactions {
    display: flex;
    gap: var(--space-md);
    font-size: var(--text-sm);
    color: var(--text-secondary);
    margin-top: var(--space-xs);
}

/* Section CTA */
.section-cta {
    max-width: 400px;
    margin: 0 auto;
}


/* ==========================================
   3. PROBLEM → SOLUTION
   ========================================== */
.problem-solution {
    background: var(--bg-gradient);
    text-align: center;
}

.problem-statements {
    max-width: 560px;
    margin: 0 auto var(--space-2xl);
    display: flex;
    flex-direction: column;
    gap: var(--space-lg);
}

.problem-statement {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    font-size: var(--text-body-lg);
    text-align: left;
}

.problem-x {
    color: var(--error);
    font-weight: var(--weight-bold);
    font-size: 1.25rem;
    flex-shrink: 0;
    width: 28px;
    text-align: center;
}

.problem-text {
    color: var(--text-secondary);
    text-decoration: line-through;
    text-decoration-color: rgba(248, 113, 113, 0.4);
}

.solution-bridge {
    margin-bottom: var(--space-lg);
}

.bridge-line {
    font-family: var(--font-display);
    font-size: var(--text-h3);
    font-weight: var(--weight-bold);
    color: var(--text-primary);
    line-height: 1.3;
}

.bridge-line--accent {
    color: var(--accent);
    font-size: var(--text-h2);
}

.solution-text {
    font-size: var(--text-body-lg);
    color: var(--text-secondary);
    max-width: 520px;
    margin: 0 auto;
    line-height: 1.7;
}

.solution-text strong {
    color: var(--text-primary);
}


/* ==========================================
   4. HOW IT WORKS
   ========================================== */
.how-it-works {
    background: var(--bg-secondary);
}

.steps {
    display: grid;
    gap: var(--space-md);
    max-width: 600px;
    margin: 0 auto;
}

@media (min-width: 768px) {
    .steps {
        grid-template-columns: 1fr 1fr;
        max-width: 800px;
    }
}

.step {
    padding: var(--space-xl);
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
    min-height: 220px;
}

.step__icon {
    width: 48px;
    height: 48px;
    border-radius: var(--radius-md);
    background: var(--accent-subtle);
    color: var(--accent);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: var(--space-xs);
    flex-shrink: 0;
}

.step__title {
    font-family: var(--font-display);
    font-size: var(--text-h3);
    font-weight: var(--weight-semibold);
    color: var(--text-primary);
}

.step__desc {
    font-size: var(--text-body);
    color: var(--text-secondary);
    line-height: 1.5;
}


/* ==========================================
   2.25 PROMO VIDEO
   ========================================== */
.promo-video {
    background: var(--bg-secondary);
    padding-top: var(--space-lg);
    padding-bottom: var(--space-xl);
}

.promo-video__wrapper {
    max-width: 720px;
    margin: 0 auto;
}

.promo-video__container {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9;
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow:
        0 8px 40px rgba(0, 0, 0, 0.4),
        0 0 80px rgba(56, 154, 244, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.06);
    background: #000;
}

.promo-video__container iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: 0;
}

/* CTA + social proof below video */
.promo-video__footer {
    max-width: 400px;
    margin: var(--space-xl) auto 0;
    text-align: center;
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
}

.promo-video__social-proof {
    font-size: var(--text-body);
    color: var(--text-secondary);
}

.promo-video__social-proof strong {
    color: var(--accent);
    font-weight: var(--weight-bold);
}

@media (max-width: 767px) {
    .promo-video__wrapper {
        max-width: 100%;
    }

    .promo-video__container {
        border-radius: var(--radius-md);
    }
}


/* ==========================================
   2.5 IDENTITY MIRROR
   ========================================== */
.identity-mirror {
    background: var(--bg-gradient);
    text-align: center;
    padding-bottom: var(--space-2xl);
}

.mirror-text {
    max-width: 560px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: var(--space-xl);
}

.mirror-line {
    font-size: var(--text-body-lg);
    color: var(--text-secondary);
    line-height: 1.7;
}

.mirror-line--bold {
    font-family: var(--font-display);
    font-size: var(--text-h3);
    font-weight: var(--weight-bold);
    color: var(--text-primary);
}

.mirror-line--highlight {
    font-family: var(--font-display);
    font-size: var(--text-h3);
    font-weight: var(--weight-bold);
    color: var(--accent);
}

.mirror-line--cta {
    color: var(--text-primary);
    font-weight: var(--weight-medium);
}


/* ==========================================
   2.75 VIDEO TESTIMONIALS
   ========================================== */
.video-testimonials {
    background: var(--bg-secondary);
}

.video-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-lg);
    max-width: 900px;
    margin: 0 auto;
}

@media (max-width: 767px) {
    .video-grid {
        grid-template-columns: 1fr;
        gap: var(--space-md);
        max-width: 400px;
    }
}

.video-card {
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.06);
    transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.video-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.3);
}

.video-card__poster {
    aspect-ratio: 9 / 12;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--space-md);
    cursor: pointer;
    position: relative;
    transition: filter var(--transition-base);
    overflow: hidden;
    background: #0a0e1a;
}

.video-card__thumb {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
    z-index: 0;
}

.video-card:hover .video-card__poster {
    filter: brightness(1.1);
}

/* Per-person gradient posters */
.video-card__poster--raul {
    background: linear-gradient(135deg, rgba(244, 63, 94, 0.2) 0%, rgba(244, 63, 94, 0.05) 100%);
    border-bottom: 1px solid rgba(244, 63, 94, 0.15);
}

.video-card__poster--gianna {
    background: linear-gradient(135deg, rgba(52, 211, 153, 0.2) 0%, rgba(52, 211, 153, 0.05) 100%);
    border-bottom: 1px solid rgba(52, 211, 153, 0.15);
}

.video-card__poster--aileen {
    background: linear-gradient(135deg, rgba(139, 92, 246, 0.2) 0%, rgba(139, 92, 246, 0.05) 100%);
    border-bottom: 1px solid rgba(139, 92, 246, 0.15);
}

.video-card__initial {
    font-size: 3rem;
    font-weight: var(--weight-bold);
    color: rgba(255, 255, 255, 0.12);
    line-height: 1;
}

.video-card__play {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    background: rgba(0, 0, 0, 0.45);
    border: 2px solid rgba(255, 255, 255, 0.5);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all var(--transition-base);
    animation: video-pulse 2s ease-in-out infinite;
    z-index: 1;
    backdrop-filter: blur(4px);
}

.video-card:hover .video-card__play {
    background: rgba(0, 0, 0, 0.6);
    border-color: rgba(255, 255, 255, 0.7);
    transform: scale(1.1);
}

.video-card__meta {
    padding: var(--space-md) var(--space-lg);
    display: flex;
    flex-direction: column;
    gap: var(--space-xs);
}

.video-card__name {
    font-weight: var(--weight-semibold);
    font-size: var(--text-body);
    color: var(--text-primary);
}

.video-card__result {
    font-size: var(--text-sm);
    color: var(--text-secondary);
}

@media (max-width: 767px) {
    .video-card__poster {
        aspect-ratio: 9 / 10;
    }

    .video-card__play {
        width: 56px;
        height: 56px;
    }

    .video-card__initial {
        font-size: 2.5rem;
    }
}


/* ==========================================
   4. FOUNDER CREDIBILITY
   ========================================== */
.founder {
    background: var(--bg-gradient);
}

.founder-card {
    max-width: 640px;
    margin: 0 auto;
    padding: var(--space-2xl);
}

.founder-card__header {
    display: flex;
    align-items: center;
    gap: var(--space-md);
    margin-bottom: var(--space-xl);
}

.founder-card__avatar {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: var(--accent-subtle);
    color: var(--accent);
    font-weight: var(--weight-bold);
    font-size: var(--text-body-lg);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    object-fit: cover;
}

.founder-card__name {
    font-family: var(--font-display);
    font-size: var(--text-body-lg);
    font-weight: var(--weight-bold);
    color: var(--text-primary);
}

.founder-card__role {
    font-size: var(--text-sm);
    color: var(--text-muted);
}

.founder-card__body {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
}

.founder-card__body p {
    font-size: var(--text-body);
    color: var(--text-secondary);
    line-height: 1.7;
}

.founder-card__quote {
    font-style: italic;
    color: var(--text-primary) !important;
    font-size: var(--text-lg) !important;
    border-left: 3px solid var(--accent);
    padding-left: var(--space-lg);
    margin: var(--space-md) 0;
    line-height: 1.6;
}

.founder-card__signoff {
    font-weight: var(--weight-semibold);
    color: var(--text-primary) !important;
    margin-top: var(--space-sm);
}


/* ==========================================
   5. PROBLEM → SOLUTION (updated)
   ========================================== */
.problem-aside {
    font-style: italic;
    color: var(--text-muted);
    font-size: var(--text-sm);
}


/* ==========================================
   7. WHAT'S INCLUDED (replaces Benefits)
   ========================================== */
.whats-included {
    background: var(--bg-gradient);
}

.included-layout {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-2xl);
    margin-bottom: var(--space-2xl);
}

@media (min-width: 1024px) {
    .included-layout {
        flex-direction: row;
        align-items: flex-start;
    }
}

.included-phone {
    flex-shrink: 0;
    width: 380px;
    padding-left: var(--space-md);
}

.included-phone__img {
    width: 100%;
    height: auto;
    filter: drop-shadow(0 20px 60px rgba(56, 154, 244, 0.2));
}

@media (max-width: 1023px) {
    .included-phone {
        width: 320px;
        margin: 0 auto;
        padding-left: 0;
    }
}

.included-grid {
    display: grid;
    gap: var(--space-md);
    flex: 1;
}

@media (min-width: 768px) {
    .included-grid {
        grid-template-columns: 1fr 1fr;
    }
}

.included-item {
    padding: var(--space-lg);
    display: flex;
    align-items: flex-start;
    gap: var(--space-md);
}

.included-item__icon {
    width: 40px;
    height: 40px;
    border-radius: var(--radius-sm);
    background: var(--accent-subtle);
    color: var(--accent);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.included-item__text {
    display: flex;
    flex-direction: column;
    gap: var(--space-xs);
}

.included-item__title {
    font-family: var(--font-display);
    font-size: var(--text-body);
    font-weight: var(--weight-semibold);
    color: var(--text-primary);
    line-height: 1.3;
}

.included-item__desc {
    font-size: var(--text-sm);
    color: var(--text-secondary);
    line-height: 1.5;
}


/* ==========================================
   8. STAKE EXPLAINER (updated)
   ========================================== */
.stake-explainer {
    background: var(--bg-secondary);
    text-align: center;
}

.stake-intro {
    font-size: var(--text-body-lg);
    color: var(--text-secondary);
    margin-bottom: var(--space-2xl);
    max-width: 540px;
    margin-left: auto;
    margin-right: auto;
    line-height: 1.7;
}

.stake-intro strong {
    color: var(--accent);
}

.stake-outcomes {
    display: grid;
    gap: var(--space-md);
    max-width: 500px;
    margin: 0 auto var(--space-xl);
}

@media (min-width: 600px) {
    .stake-outcomes {
        grid-template-columns: 1fr 1fr;
    }
}

.stake-card {
    padding: var(--space-xl);
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-sm);
}

.stake-card__icon {
    font-size: 2rem;
    line-height: 1;
}

.stake-card--success {
    border: 1px solid rgba(52, 211, 153, 0.2);
}

.stake-card--success .stake-card__icon {
    color: var(--success);
}

.stake-card--fail {
    border: 1px solid rgba(248, 113, 113, 0.2);
}

.stake-card--fail .stake-card__icon {
    color: var(--error);
    font-weight: var(--weight-bold);
    font-size: 1.75rem;
}

.stake-card__title {
    font-weight: var(--weight-semibold);
    font-size: var(--text-body);
    color: var(--text-primary);
}

.stake-card__desc {
    font-size: var(--text-sm);
    color: var(--text-secondary);
}

.stake-note {
    font-size: var(--text-sm);
    color: var(--text-muted);
    margin-bottom: var(--space-xl);
}

/* Bucket List Pot */
.bucket-list-pot {
    max-width: 480px;
    margin: 0 auto var(--space-xl);
    padding: var(--space-lg) var(--space-xl);
    text-align: center;
    background: rgba(233, 218, 197, 0.08);
    border: 1px solid rgba(233, 218, 197, 0.15);
}

.bucket-list-pot__title {
    font-family: var(--font-display);
    font-size: var(--text-body-lg);
    font-weight: var(--weight-semibold);
    color: #E9DAC5;
    margin-bottom: var(--space-sm);
}

.bucket-list-pot__desc {
    font-size: var(--text-sm);
    color: var(--text-secondary);
    line-height: 1.6;
}

.bucket-list-pot__desc strong {
    color: #E9DAC5;
}

.stake-trust {
    display: inline-flex;
    align-items: center;
    gap: var(--space-sm);
    font-size: var(--text-sm);
    color: var(--text-secondary);
    background: var(--surface);
    padding: var(--space-sm) var(--space-lg);
    border-radius: var(--radius-pill);
}


/* ==========================================
   9. WHO THIS IS FOR
   ========================================== */
.who-for {
    background: var(--bg-gradient);
}

.who-for__grid {
    display: grid;
    gap: var(--space-md);
    max-width: 700px;
    margin: 0 auto;
}

@media (min-width: 640px) {
    .who-for__grid {
        grid-template-columns: 1fr 1fr;
    }
}

.who-for__column {
    padding: var(--space-xl);
}

.who-for__heading {
    font-family: var(--font-display);
    font-size: var(--text-body-lg);
    font-weight: var(--weight-bold);
    margin-bottom: var(--space-lg);
    color: var(--text-primary);
}

.who-for__list {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
}

.who-for__list li {
    font-size: var(--text-sm);
    color: var(--text-secondary);
    line-height: 1.5;
    padding-left: var(--space-xs);
}

.who-for__column--yes {
    border: 1px solid rgba(52, 211, 153, 0.15);
}

.who-for__column--no {
    border: 1px solid rgba(248, 113, 113, 0.15);
}


/* ==========================================
   10. FAQ
   ========================================== */
.faq {
    background: var(--bg-secondary);
}

.faq-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
    max-width: 680px;
    margin: 0 auto;
}

.faq-item {
    overflow: hidden;
}

.faq-question {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-md);
    padding: var(--space-lg);
    font-size: var(--text-body);
    font-weight: var(--weight-medium);
    color: var(--text-primary);
    text-align: left;
    cursor: pointer;
    transition: color var(--transition-fast);
}

.faq-question:hover {
    color: var(--accent);
}

.faq-chevron {
    flex-shrink: 0;
    color: var(--text-muted);
}

.faq-answer {
    padding: 0 var(--space-lg) 0;
}

.faq-item.open .faq-answer {
    padding-bottom: var(--space-lg);
}

.faq-answer p {
    font-size: var(--text-body);
    color: var(--text-secondary);
    line-height: 1.6;
}


/* ==========================================
   11. FINAL CTA (updated with vision)
   ========================================== */
.final-cta {
    position: relative;
    text-align: center;
    overflow: hidden;
    background: var(--bg-gradient);
}

.final-cta__content {
    position: relative;
    z-index: var(--z-base);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-lg);
    max-width: 560px;
}

.final-cta__title {
    font-family: var(--font-display);
    font-size: var(--text-h2);
    font-weight: var(--weight-bold);
    line-height: 1.15;
    letter-spacing: -0.02em;
    color: var(--text-primary);
}

.final-cta__vision {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
    text-align: center;
}

.final-cta__vision p {
    font-size: var(--text-body-lg);
    color: var(--text-secondary);
    line-height: 1.7;
}

.final-cta__vision-highlight {
    font-family: var(--font-display);
    font-size: var(--text-h3) !important;
    font-weight: var(--weight-bold);
    color: var(--accent) !important;
    margin-top: var(--space-sm);
}

.final-cta__proof {
    font-size: var(--text-body);
    color: var(--text-secondary);
    margin-top: var(--space-md);
}

.final-cta__proof strong {
    color: var(--accent);
}

/* Background gradient glow */
.final-cta__glow {
    position: absolute;
    bottom: -200px;
    left: 50%;
    transform: translateX(-50%);
    width: 800px;
    height: 500px;
    border-radius: 50%;
    background: radial-gradient(ellipse,
            rgba(56, 154, 244, 0.15) 0%,
            rgba(56, 154, 244, 0.05) 40%,
            transparent 70%);
    pointer-events: none;
    filter: blur(60px);
}


/* ==========================================
   FOOTER
   ========================================== */
.site-footer {
    padding: var(--space-xl) 0;
    border-top: 1px solid var(--surface-border);
}

.site-footer__inner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-sm);
    text-align: center;
}

@media (min-width: 640px) {
    .site-footer__inner {
        flex-direction: row;
        justify-content: space-between;
    }
}

.site-footer__copy {
    font-size: var(--text-xs);
    color: var(--text-muted);
}

.site-footer__links {
    display: flex;
    gap: var(--space-lg);
}

.site-footer__links a {
    font-size: var(--text-xs);
    color: var(--text-muted);
    transition: color var(--transition-fast);
}

.site-footer__links a:hover {
    color: var(--text-secondary);
}


/* ==========================================
   WIN CARD — BEFORE/AFTER
   ========================================== */
.win-card__before {
    font-size: var(--text-sm);
    color: var(--text-muted);
    font-style: italic;
    text-decoration: line-through;
    text-decoration-color: rgba(248, 113, 113, 0.4);
}


/* ==========================================
   STICKY BOTTOM BAR
   ========================================== */
.sticky-bar {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: var(--z-sticky);
    background: rgba(10, 14, 26, 0.85);
    backdrop-filter: var(--glass-blur-heavy);
    -webkit-backdrop-filter: var(--glass-blur-heavy);
    border-top: 1px solid var(--surface-border);
    padding: var(--space-sm) var(--content-padding);
    transform: translateY(100%);
    opacity: 0;
    pointer-events: none;
    transition: none;
}

.sticky-bar.visible {
    pointer-events: auto;
}

.sticky-bar__inner {
    max-width: var(--max-width);
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-md);
    padding: 0 var(--space-sm);
}

.sticky-bar__info {
    display: flex;
    flex-direction: column;
    gap: 2px;
    font-size: var(--text-xs);
    color: var(--text-muted);
}

.sticky-bar__countdown {
    font-family: var(--font-mono);
    font-weight: var(--weight-semibold);
    color: var(--text-secondary);
    font-size: var(--text-sm);
}

.sticky-bar__participants {
    color: var(--text-muted);
}

.sticky-bar__btn {
    padding: 0.75rem 1.5rem;
    font-size: var(--text-sm);
    white-space: nowrap;
    flex-shrink: 0;
}

/* Add bottom padding to body when sticky bar is visible */
body.sticky-active {
    padding-bottom: calc(80px + env(safe-area-inset-bottom, 0px));
}


/* ==========================================
   RESPONSIVE OVERRIDES
   ========================================== */

/* Mobile-specific (< 768px) */
@media (max-width: 767px) {
    .hero__content {
        padding-top: var(--space-xl);
    }

    .hero__testimonial {
        flex-direction: column;
        text-align: center;
        gap: var(--space-xs);
    }

    .countdown__block {
        min-width: 48px;
    }

    .testimonial-card {
        flex: 0 0 180px;
    }

    .win-cards {
        gap: var(--space-sm);
    }

    .btn-full {
        max-width: 100%;
    }

    .founder-card {
        padding: var(--space-xl);
    }

    .who-for__column {
        padding: var(--space-lg);
    }
}

/* Tablet+ (≥ 768px) */
@media (min-width: 768px) {
    .hero__orb {
        width: 800px;
        height: 800px;
    }

    .win-cards {
        display: grid;
        grid-template-columns: 1fr 1fr;
    }

    .win-cards .win-card:last-child {
        grid-column: 1 / -1;
        max-width: 50%;
        justify-self: center;
    }

    .testimonial-card {
        flex: 0 0 240px;
    }
}

/* Desktop (≥ 1024px) */
@media (min-width: 1024px) {
    .win-cards {
        grid-template-columns: 1fr 1fr 1fr;
    }

    .win-cards .win-card:last-child {
        grid-column: auto;
        max-width: 100%;
    }

    .hero__content {
        max-width: 700px;
    }

    .final-cta__glow {
        width: 1200px;
        height: 700px;
    }

    .final-cta__content {
        max-width: 640px;
    }
}


/* ==========================================
   TEXT TESTIMONIAL CARDS
   ========================================== */
.testimonials-text {
    background: var(--bg-gradient);
}

.testimonial-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-md);
    max-width: 800px;
    margin: 0 auto var(--space-2xl);
}

/* Center the last odd card */
.testimonial-grid > .testimonial-text-card:last-child:nth-child(odd) {
    grid-column: 1 / -1;
    max-width: 50%;
    justify-self: center;
}

@media (max-width: 767px) {
    .testimonial-grid {
        grid-template-columns: 1fr;
    }

    .testimonial-grid > .testimonial-text-card:last-child:nth-child(odd) {
        max-width: 100%;
    }
}

.testimonial-text-card {
    padding: var(--space-lg);
    border: 1px solid rgba(255, 255, 255, 0.06);
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
}

.testimonial-text-card__header {
    display: flex;
    align-items: center;
    gap: var(--space-md);
}

img.testimonial-text-card__avatar {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
}

div.testimonial-text-card__avatar {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    font-weight: var(--weight-bold);
    font-size: var(--text-body);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.testimonial-text-card__avatar--fire {
    background: rgba(244, 63, 94, 0.15);
    color: #f43f5e;
}

.testimonial-text-card__avatar--money {
    background: rgba(234, 179, 8, 0.15);
    color: #eab308;
}

.testimonial-text-card__avatar--rocket {
    background: rgba(52, 211, 153, 0.15);
    color: #34d399;
}

.testimonial-text-card__avatar--target {
    background: rgba(139, 92, 246, 0.15);
    color: #8b5cf6;
}

.testimonial-text-card__avatar--thesis {
    background: rgba(56, 154, 244, 0.15);
    color: var(--accent);
}

.testimonial-text-card__info {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.testimonial-text-card__name {
    font-weight: var(--weight-semibold);
    font-size: var(--text-body);
    color: var(--text-primary);
}

.testimonial-text-card__tag {
    font-size: var(--text-xs);
    color: var(--text-secondary);
    font-weight: var(--weight-medium);
}

.testimonial-text-card__quote {
    font-size: var(--text-sm);
    color: var(--text-secondary);
    font-style: italic;
    line-height: 1.6;
}


/* ==========================================
   RESULT STORIES (legacy — unused)
   ========================================== */
.result-stories {
    background: var(--bg-gradient);
}

.result-story {
    display: grid;
    grid-template-columns: 1fr 280px;
    gap: var(--space-xl);
    align-items: center;
    padding: var(--space-2xl);
    margin-bottom: var(--space-xl);
    border: 1px solid rgba(255, 255, 255, 0.06);
    transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.result-story:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.3);
}

/* Cards without proof image — full width */
.result-story:not(:has(.result-story__proof)) {
    grid-template-columns: 1fr;
}

.result-story__tag {
    display: inline-block;
    padding: var(--space-xs) var(--space-md);
    border-radius: 100px;
    font-size: var(--text-sm);
    font-weight: var(--weight-bold);
    letter-spacing: 0.02em;
    margin-bottom: var(--space-md);
}

.result-story__tag--fire {
    background: rgba(244, 63, 94, 0.12);
    color: #f43f5e;
    border: 1px solid rgba(244, 63, 94, 0.2);
}

.result-story__tag--money {
    background: rgba(234, 179, 8, 0.12);
    color: #eab308;
    border: 1px solid rgba(234, 179, 8, 0.2);
}

.result-story__tag--rocket {
    background: rgba(52, 211, 153, 0.12);
    color: #34d399;
    border: 1px solid rgba(52, 211, 153, 0.2);
}

.result-story__tag--target {
    background: rgba(139, 92, 246, 0.12);
    color: #8b5cf6;
    border: 1px solid rgba(139, 92, 246, 0.2);
}

.result-story__tag--thesis {
    background: rgba(56, 154, 244, 0.12);
    color: var(--accent);
    border: 1px solid rgba(56, 154, 244, 0.2);
}

.result-story__quote {
    font-size: var(--text-lg);
    line-height: 1.7;
    color: var(--text-secondary);
    font-style: italic;
    margin: 0 0 var(--space-md);
    padding: 0;
    border: none;
}

.result-story__author {
    display: block;
    font-size: var(--text-body);
    font-style: normal;
    font-weight: var(--weight-semibold);
    color: var(--text-primary);
    margin-bottom: var(--space-lg);
}

.result-story__play {
    display: inline-flex;
    align-items: center;
    gap: var(--space-sm);
    padding: var(--space-sm) var(--space-lg);
    background: rgba(56, 154, 244, 0.1);
    border: 1px solid rgba(56, 154, 244, 0.25);
    border-radius: 100px;
    color: var(--accent);
    font-size: var(--text-sm);
    font-weight: var(--weight-semibold);
    cursor: pointer;
    transition: all var(--transition-base);
}

.result-story__play:hover {
    background: rgba(56, 154, 244, 0.2);
    border-color: rgba(56, 154, 244, 0.4);
    transform: scale(1.03);
}

.result-story__play svg {
    transition: transform var(--transition-base);
}

.result-story__play:hover svg {
    transform: scale(1.15);
}

.result-story__proof {
    border-radius: var(--radius-lg);
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
}

.result-story__proof img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}


/* ---- Video poster for cards with video ---- */
.result-story--has-video {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto;
}

.result-story__video-poster {
    grid-column: 1 / -1;
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 220px;
    border-radius: var(--radius-lg);
    cursor: pointer;
    overflow: hidden;
    transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.result-story__video-poster:hover {
    transform: scale(1.01);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.4);
}

/* Per-person gradient posters */
.result-story__video-poster--raul {
    background: linear-gradient(135deg, rgba(244, 63, 94, 0.2) 0%, rgba(244, 63, 94, 0.05) 100%);
    border: 1px solid rgba(244, 63, 94, 0.15);
}

.result-story__video-poster--gianna {
    background: linear-gradient(135deg, rgba(52, 211, 153, 0.2) 0%, rgba(52, 211, 153, 0.05) 100%);
    border: 1px solid rgba(52, 211, 153, 0.15);
}

.result-story__video-poster--aileen {
    background: linear-gradient(135deg, rgba(139, 92, 246, 0.2) 0%, rgba(139, 92, 246, 0.05) 100%);
    border: 1px solid rgba(139, 92, 246, 0.15);
}

.result-story__video-initial {
    font-size: 3rem;
    font-weight: var(--weight-bold);
    color: rgba(255, 255, 255, 0.15);
    margin-bottom: var(--space-md);
    line-height: 1;
}

.result-story__video-play {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    background: rgba(56, 154, 244, 0.15);
    border: 2px solid rgba(56, 154, 244, 0.4);
    color: var(--accent);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all var(--transition-base);
    animation: video-pulse 2s ease-in-out infinite;
}

@keyframes video-pulse {
    0%, 100% {
        box-shadow: 0 0 0 0 rgba(56, 154, 244, 0.2);
    }
    50% {
        box-shadow: 0 0 0 12px rgba(56, 154, 244, 0);
    }
}

.result-story__video-poster:hover .result-story__video-play {
    background: rgba(56, 154, 244, 0.25);
    border-color: rgba(56, 154, 244, 0.6);
    transform: scale(1.1);
}

.result-story__video-label {
    margin-top: var(--space-sm);
    font-size: var(--text-sm);
    font-weight: var(--weight-semibold);
    color: var(--accent);
    letter-spacing: 0.02em;
}

/* Video cards: content + proof sit side by side below poster on desktop */

@media (min-width: 768px) {
    .result-story--has-video {
        grid-template-columns: 1fr 240px;
        grid-template-rows: auto auto;
    }

    .result-story__video-poster {
        grid-column: 1 / -1;
    }
}

/* Mobile: stack vertically */
@media (max-width: 767px) {
    .result-story {
        grid-template-columns: 1fr;
        padding: var(--space-lg);
        gap: var(--space-md);
    }

    .result-story__proof {
        order: -1;
        max-width: 280px;
        margin: 0 auto;
    }

    .result-story__quote {
        font-size: var(--text-body);
    }

    .result-story__video-poster {
        min-height: 160px;
    }

    .result-story__video-play {
        width: 52px;
        height: 52px;
    }

    .result-story__video-initial {
        font-size: 2rem;
    }
}


/* ==========================================
   MICRO-TESTIMONIAL INLINE
   ========================================== */
.micro-testimonial-inline {
    padding: var(--space-lg) 0;
    text-align: center;
}

.micro-testimonial-inline__text {
    font-size: var(--text-lg);
    font-style: italic;
    color: var(--text-secondary);
    line-height: 1.6;
    max-width: 560px;
    margin: 0 auto var(--space-sm);
}

.micro-testimonial-inline__author {
    font-size: var(--text-sm);
    font-weight: var(--weight-semibold);
    color: var(--accent);
}

@media (max-width: 767px) {
    .micro-testimonial-inline__text {
        font-size: var(--text-body);
    }
}


/* ==========================================
   COMMUNITY QUOTES GRID
   ========================================== */
.community-voices {
    background: var(--bg-secondary);
    overflow: hidden;
}

.community-quotes {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-lg);
    margin-bottom: var(--space-2xl);
}

.community-quote {
    padding: var(--space-xl);
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
    border: 1px solid rgba(255, 255, 255, 0.06);
}

.community-quote p {
    font-size: var(--text-body);
    color: var(--text-secondary);
    font-style: italic;
    line-height: 1.7;
    flex: 1;
}

.community-quote cite {
    font-size: var(--text-sm);
    font-style: normal;
    font-weight: var(--weight-semibold);
    color: var(--accent);
}

@media (max-width: 767px) {
    .community-quotes {
        grid-template-columns: 1fr;
    }

    .community-quote {
        padding: var(--space-lg);
    }
}


/* ==========================================
   WHATSAPP SOCIAL PROOF STRIP
   ========================================== */
.whatsapp-strip {
    position: relative;
    width: 100%;
    overflow: hidden;
    margin-top: var(--space-xl);
    -webkit-mask-image: linear-gradient(
        to right,
        transparent 0%,
        black 8%,
        black 92%,
        transparent 100%
    );
    mask-image: linear-gradient(
        to right,
        transparent 0%,
        black 8%,
        black 92%,
        transparent 100%
    );
}

.whatsapp-strip__track {
    display: flex;
    gap: var(--space-lg);
    animation: whatsapp-scroll 40s linear infinite;
    width: max-content;
    padding: var(--space-md) 0;
}

@keyframes whatsapp-scroll {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(-50%);
    }
}

.whatsapp-strip:hover .whatsapp-strip__track {
    animation-play-state: paused;
}

.whatsapp-strip__card {
    flex-shrink: 0;
    width: 220px;
    border-radius: var(--radius-lg);
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.08);
    transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.whatsapp-strip__card:hover {
    transform: scale(1.05) rotate(0deg) !important;
    box-shadow: 0 8px 32px rgba(56, 154, 244, 0.15);
    z-index: 2;
}

.whatsapp-strip__card--tilt-left {
    transform: rotate(-1.5deg);
}

.whatsapp-strip__card--tilt-right {
    transform: rotate(1.5deg);
}

.whatsapp-strip__card img {
    width: 100%;
    height: auto;
    display: block;
}

@media (max-width: 767px) {
    .whatsapp-strip__card {
        width: 170px;
    }

    .whatsapp-strip__track {
        gap: var(--space-md);
    }
}