/* ============================================================
   Home V3 — Global Tokens & Shared Utilities
   ============================================================ */

/* Google Fonts */
@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&family=Inter:wght@300;400;500;600;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@20..48,100..700,0..1,-50..200');

/* ── Page shell ── */
body {
    background-color: var(--color-surface-primary);
    color: var(--color-text-primary);
    font-family: var(--font-family-body);
    margin: 0;
}

.hv3-main {
    padding-top: 80px; /* offset for fixed nav */
}

/* ── Shared gradient button ── */
.hv3-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-2) var(--space-5);
    border-radius: var(--radius-md);
    font-family: var(--font-family-heading);
    font-weight: var(--font-weight-bold);
    font-size: var(--font-size-sm);
    cursor: pointer;
    text-decoration: none;
    border: none;
    transition: transform var(--transition-fast), filter var(--transition-fast);
    color: var(--color-text-inverse);
}

.hv3-btn--gradient {
    background: linear-gradient(135deg, var(--color-brand-primary) 0%, var(--color-brand-secondary) 100%);
}

.hv3-btn--gradient:hover {
    filter: brightness(1.1);
    transform: scale(1.03);
}

.hv3-btn--gradient:active {
    transform: scale(0.96);
}

.hv3-btn--lg {
    padding: var(--space-4) var(--space-7);
    font-size: var(--font-size-lg);
    border-radius: var(--radius-md);
}

/* ── Material Symbols base ── */
.material-symbols-outlined {
    font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
    vertical-align: middle;
    line-height: 1;
}
