/* Theme overrides for landing page */
@layer theme {
    @scope (.hero) {
        :scope {
            padding-block: 6rem;
            max-inline-size: 900px;
            margin-inline: auto;
        }

        h1 {
            font-size: clamp(2rem, 5vw, 3rem);
            line-height: 1.2;
            margin-block-end: var(--space-md);
        }

        .tagline {
            font-size: var(--fs-large);
            max-inline-size: 45ch;
            color: var(--text-secondary);
            line-height: 1.6;
        }

        .cta-group {
            margin-block: var(--space-xl);
            gap: var(--space-md);
        }

        .stats {
            padding: var(--space-lg) var(--space-xl);
            background: var(--surface-elevated);
            border-radius: var(--wire-radius);
            border: 1px solid var(--border-color);
            margin-block: var(--space-xl);

            li {
                font-size: var(--fs-small);
            }
        }

        .portal-links {
            margin-block-start: var(--space-xl);

            a {
                color: var(--text-secondary);
                border-color: var(--border-color);
                padding-block-end: var(--space-3xs);
                font-size: var(--fs-small);

                &:hover {
                    color: var(--accent-primary);
                    border-color: var(--accent-primary);
                }
            }
        }
    }
}

@layer components {
    @scope (.hero) {
        :scope {
            display: flex;
            flex-direction: column;
            align-items: center;
            text-align: center;
            padding: var(--space-3xl) var(--wire-gap);
            gap: var(--space-xl);
        }

        h1 {
            font-size: var(--fs-xxl);
            font-weight: var(--fw-bold);
            line-height: 1.2;
        }

        .tagline {
            max-inline-size: var(--measure);
            font-size: var(--fs-large);
            color: var(--text-secondary);
        }

        .cta-group {
            display: flex;
            flex-wrap: wrap;
            justify-content: center;
            gap: var(--wire-gap);
        }

        .cta-button {
            padding: var(--space-sm) var(--space-xl);
            border: var(--wire-border);
            border-radius: var(--wire-radius);
            background: transparent;
            color: var(--text-primary);
            font-size: var(--fs-body);
            cursor: pointer;

            &.primary {
                background: var(--text-primary);
                color: var(--bg-primary);
            }
        }

        .stats {
            display: flex;
            flex-wrap: wrap;
            justify-content: center;
            gap: var(--space-xl);

            li {
                display: flex;
                gap: var(--space-xs);
                font-size: var(--fs-small);
                color: var(--text-secondary);
            }

            .stat-value {
                font-weight: var(--fw-semibold);
                color: var(--text-primary);
            }
        }

        .note {
            font-size: var(--fs-xsmall);
            color: var(--text-secondary);
        }

        .portal-links {
            display: flex;
            gap: var(--space-xl);

            a {
                font-size: var(--fs-small);
                border-block-end: 1px solid var(--text-secondary);
            }
        }
    }
}
