.button:hover {
    transform: translateY(-3px);
}

.button.primary:hover {
    transform: translateY(-3px) scale(1.01);
}

.section {
    margin-top: 88px;
}

.section:first-of-type {
    margin-top: 0;
}

.section-header {
    max-width: 720px;
    margin-bottom: 32px;
}

.section-kicker {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 12px;
    padding: 6px 12px;
    border-radius: 999px;
    color: var(--secondary);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0;
    text-transform: uppercase;
    background: color-mix(in srgb, var(--secondary) 12%, transparent);
    border: 1px solid color-mix(in srgb, var(--secondary) 28%, var(--line));
}

.section h2,
.page-hero h1 {
    font-size: clamp(2.1rem, 4.2vw, 3.6rem);
    line-height: 1.05;
    letter-spacing: 0;
}

.section-header p {
    margin-top: 16px;
    color: var(--muted);
    font-size: 1.05rem;
    line-height: 1.75;
}

.section-header p a,
.hero-content p a,
.page-hero p a,
.card p a,
.story-panel p a {
    color: var(--secondary);
    text-decoration: none;
    border-bottom: 1px solid color-mix(in srgb, var(--secondary) 50%, transparent);
    transition: border-color 0.2s ease, color 0.2s ease;
}

.section-header p a:hover,
.hero-content p a:hover,
.page-hero p a:hover,
.card p a:hover,
.story-panel p a:hover {
    color: var(--text);
    border-bottom-color: var(--secondary);
}

.grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 20px;
}

.grid.two {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.card {
    position: relative;
    overflow: hidden;
    min-height: 220px;
    padding: 28px;
    border: 1px solid var(--line);
    border-radius: var(--radius-lg);
    background:
        linear-gradient(160deg, color-mix(in srgb, var(--card) 95%, transparent), color-mix(in srgb, var(--bg) 40%, transparent)),
        var(--card);
    box-shadow: var(--shadow-soft);
    transition: transform 0.35s var(--ease-out), border-color 0.25s ease, box-shadow 0.35s var(--ease-out);
}

.card::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, color-mix(in srgb, var(--primary) 22%, transparent), transparent 50%);
    opacity: 0;
    transition: opacity 0.35s var(--ease-out);
}

.card::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.12), transparent);
    opacity: 0.6;
}

.card:hover {
    transform: translateY(-8px);
    border-color: color-mix(in srgb, var(--primary) 38%, white 8%);
    box-shadow: var(--shadow);
}

.card:hover::before {
    opacity: 1;
}

.card > * {
    position: relative;
    z-index: 1;
}

.card-meta {
    display: inline-flex;
    margin-bottom: 16px;
    padding: 6px 12px;
    border: 1px solid var(--line);
    border-radius: 999px;
    color: var(--secondary);
    background: var(--glass);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0;
    text-transform: uppercase;
}

.card h3 {
    font-family: var(--font-display);
    font-size: 1.22rem;
    font-weight: 700;
    margin-bottom: 10px;
    letter-spacing: 0;
}

.card p {
    color: color-mix(in srgb, var(--muted) 85%, var(--text));
    line-height: 1.7;
    font-size: 0.95rem;
}

.page-hero {
    position: relative;
    overflow: hidden;
    padding: clamp(36px, 5vw, 56px);
    border: 1px solid var(--line);
    border-radius: var(--radius-xl);
    background:
        linear-gradient(145deg, color-mix(in srgb, var(--primary) 16%, transparent), transparent 55%),
        linear-gradient(180deg, var(--glass-strong), var(--glass));
    box-shadow: var(--shadow);
}

.page-hero::after {
    content: "";
    position: absolute;
    right: -15%;
    bottom: -40%;
    width: 55%;
    height: 80%;
    border-radius: 50%;
    background: radial-gradient(circle, var(--glow-secondary), transparent 70%);
    opacity: 0.35;
    pointer-events: none;
}

.page-hero > * {
    position: relative;
    z-index: 1;
}
