.hero {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg,
        var(--sera-warm-cream) 0%,
        rgba(245, 222, 230, 0.4) 25%,
        rgba(250, 214, 227, 0.3) 50%,
        rgba(253, 248, 240, 0.8) 100%
    );
    background-size: 400% 400%;
    animation: gradientShift 12s ease infinite;
    text-align: center;
    padding: var(--sera-spacing-2xl) var(--sera-spacing-lg);
}

@keyframes gradientShift {
    0% { background-position: 0% 50%; }
    50% { background-position: 100% 50%; }
    100% { background-position: 0% 50%; }
}

.hero-content {
    max-width: 700px;
    position: relative;
    z-index: 1;
}

.hero-icon {
    width: 180px;
    height: 180px;
    margin: 0 auto var(--sera-spacing-xl);
    border-radius: var(--sera-radius-xl);
    box-shadow: var(--sera-shadow-lg);
}

.hero-title {
    font-size: var(--sera-display-large);
    font-weight: 300;
    background: linear-gradient(135deg, var(--sera-pink-40), var(--sera-blush-pink));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    margin-bottom: var(--sera-spacing-md);
}

.hero-tagline {
    font-size: var(--sera-headline-small);
    font-weight: 500;
    color: var(--sera-on-surface);
    margin-bottom: var(--sera-spacing-md);
}

.hero-description {
    font-size: var(--sera-body-large);
    color: var(--sera-on-surface-variant);
    line-height: 1.8;
}

.features {
    padding: var(--sera-spacing-3xl) 0;
    background: var(--sera-warm-cream);
}

.features-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--sera-spacing-lg);
}

.feature-card {
    padding: var(--sera-spacing-xl);
    background: white;
    border-radius: var(--sera-radius-md);
    box-shadow: var(--sera-shadow-sm);
    border-top: 4px solid var(--sera-primary);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}


.feature-card[data-color="menstruation"] {
    border-top-color: var(--sera-cycle-menstruation);
}

.feature-card[data-color="follicular"] {
    border-top-color: var(--sera-cycle-follicular);
}

.feature-card[data-color="ovulation"] {
    border-top-color: var(--sera-cycle-ovulation);
}

.feature-card[data-color="luteal"] {
    border-top-color: var(--sera-cycle-luteal);
}

.feature-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--sera-shadow-md);
}

.feature-title {
    font-size: var(--sera-title-large);
    font-weight: 600;
    color: var(--sera-on-surface);
    margin-bottom: var(--sera-spacing-sm);
}

.feature-desc {
    font-size: var(--sera-body-medium);
    color: var(--sera-on-surface-variant);
    line-height: 1.7;
}

.privacy-section {
    padding: var(--sera-spacing-3xl) 0;
    background: var(--sera-blush-pink);
}


.privacy-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--sera-spacing-lg);
}

.privacy-card {
    padding: var(--sera-spacing-lg);
    background: var(--sera-warm-cream);
    border-radius: var(--sera-radius-md);
    border-left: 4px solid var(--sera-rose-gold);
}

.privacy-heading {
    font-size: var(--sera-title-medium);
    font-weight: 600;
    color: var(--sera-primary);
    margin-bottom: var(--sera-spacing-xs);
}

.privacy-text {
    font-size: var(--sera-body-medium);
    color: var(--sera-on-surface-variant);
    line-height: 1.7;
}

.passion-section {
    padding: var(--sera-spacing-3xl) 0;
}

.passion-card {
    max-width: var(--sera-content-width);
    margin: 0 auto;
    padding: var(--sera-spacing-2xl);
    background: linear-gradient(135deg, var(--sera-warm-cream), var(--sera-tertiary));
    border-radius: var(--sera-radius-lg);
    box-shadow: var(--sera-shadow-md);
    text-align: center;
    border: 2px solid var(--sera-secondary);
}

.passion-title {
    font-size: var(--sera-headline-medium);
    font-weight: 600;
    color: var(--sera-primary);
    margin-bottom: var(--sera-spacing-lg);
}

.passion-description {
    font-size: var(--sera-body-large);
    color: var(--sera-on-surface);
    line-height: 1.8;
    margin-bottom: var(--sera-spacing-md);
}

.passion-support {
    font-size: var(--sera-body-medium);
    color: var(--sera-on-surface-variant);
    font-style: italic;
}

.languages-section {
    padding: var(--sera-spacing-2xl) 0;
    background: var(--sera-warm-cream);
}

.languages-badges {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--sera-spacing-sm);
}

.lang-badge {
    padding: var(--sera-spacing-xs) var(--sera-spacing-md);
    background: var(--sera-blush-pink);
    color: var(--sera-primary);
    border-radius: var(--sera-radius-xl);
    font-size: var(--sera-body-small);
    font-weight: 600;
}

.download-section {
    padding: var(--sera-spacing-3xl) 0;
    text-align: center;
}

.download-title {
    font-size: var(--sera-headline-large);
    font-weight: 600;
    color: var(--sera-primary);
    margin-bottom: var(--sera-spacing-md);
}

.download-subtitle {
    font-size: var(--sera-headline-small);
    color: var(--sera-primary);
    margin-bottom: var(--sera-spacing-md);
    font-family: var(--sera-font-display);
    font-weight: 600;
}


.download-buttons {
    display: flex;
    gap: var(--sera-spacing-lg);
    justify-content: center;
    flex-wrap: wrap;
}

.download-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--sera-spacing-sm);
    padding: var(--sera-spacing-md) var(--sera-spacing-xl);
    border-radius: var(--sera-radius-md);
    font-size: var(--sera-body-large);
    font-weight: 600;
    box-shadow: var(--sera-shadow-sm);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.download-btn:hover {
    transform: translateY(-2px);
    box-shadow: var(--sera-shadow-md);
}

.download-btn-ios {
    background: var(--sera-primary);
    color: white;
}

.download-btn-android {
    background: var(--sera-secondary);
    color: var(--sera-on-surface);
}

@media (max-width: 768px) {
    .hero {
        min-height: 80vh;
        padding: var(--sera-spacing-xl) var(--sera-spacing-md);
    }

    .hero-icon {
        width: 120px;
        height: 120px;
    }

    .hero-title {
        font-size: var(--sera-display-small);
    }

    .hero-tagline {
        font-size: var(--sera-title-large);
    }

    .features-grid {
        grid-template-columns: 1fr;
    }

    .privacy-grid {
        grid-template-columns: 1fr;
    }

    .download-buttons {
        flex-direction: column;
        align-items: stretch;
    }

    .download-btn {
        width: 100%;
        max-width: 300px;
        margin: 0 auto;
    }
}
