/* ── Hero — global (component-level CSS) ── */

.hero {
    padding: var(--space-12) 0 var(--space-16);
    background-color: var(--color-white);
}

.hero-container {
    padding: 0 var(--container-padding-x);
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-8);
    align-items: center;
}

.hero-content {
    text-align: left;
}

.hero-headline {
    margin-bottom: var(--space-4);
}

.hero-subheadline {
    font-size: var(--font-size-h2);
    font-weight: var(--font-weight-light);
    line-height: var(--line-height-normal);
    color: var(--color-gray-900);
    margin-bottom: var(--space-6);
}

.hero-actions {
    display: flex;
    gap: var(--space-2);
    flex-direction: column;
}

.hero-entry-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
}

.hero-entry-button:disabled {
    cursor: wait;
    opacity: 0.85;
}

.entry-button-progress {
    width: 1rem;
    height: 1rem;
}

.hero-visual {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
}

.dashboard-image {
    width: 100%;
    height: auto;
    border-radius: var(--border-radius-sm);
    box-shadow: var(--shadow-md);
}

/* Tablet: 768px - 1023px */
@media (min-width: 768px) {
    .hero-actions {
        flex-direction: row;
    }
}

/* Desktop: >= 1024px */
@media (min-width: 1024px) {
    .hero-container {
        grid-template-columns: 60% 40%;
        width: calc(100% - 2 * var(--container-padding-x));
    }

    .hero-visual {
        order: 2;
    }

    .hero-content {
        order: 1;
    }
}

/* Mobile: reduce padding */
@media (max-width: 767px) {
    .hero {
        padding: var(--space-6) 0 var(--space-8);
    }
}

