/* Baja Collective — main site shell (design system tokens) */

:root {
    --ink: #0c0c0c;
    --ink-soft: #2a2928;
    --paper: #f6f4f0;
    --paper-warm: #ebe8e2;
    --stone: #9c9893;
    --stone-light: #c4c0ba;
    --rule: rgba(12, 12, 12, 0.12);
    --accent: #6b2c22;
    --accent-soft: #b8a898;
    --void: #111111;
    --space-xs: 0.5rem;
    --space-sm: 1rem;
    --space-md: 1.75rem;
    --space-lg: 3rem;
    --space-xl: 5rem;
    --font-sans: "Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    --font-serif: "Cormorant Garamond", "Iowan Old Style", "Palatino Linotype", Palatino, Georgia, serif;
    --text-body: 1.0625rem;
    --text-lead: 1.25rem;
    --lh: 1.55;
    --max-read: 38rem;
    --max-wide: 72rem;
    --color-text: var(--ink);
    --color-text-muted: var(--ink-soft);
    --color-surface: var(--paper);
}

*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    font-family: var(--font-sans);
    font-size: var(--text-body);
    line-height: var(--lh);
    color: var(--color-text);
    background: var(--color-surface);
    -webkit-font-smoothing: antialiased;
}

.site-header {
    border-bottom: 1px solid var(--rule);
    background: var(--paper);
}

.site-header__inner {
    max-width: var(--max-wide);
    margin: 0 auto;
    padding: var(--space-sm) var(--space-md);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-md);
    flex-wrap: wrap;
}

.site-logo {
    font-family: var(--font-serif);
    font-size: 1.35rem;
    font-weight: 400;
    letter-spacing: 0.02em;
    color: var(--ink);
    text-decoration: none;
}

.site-logo:hover {
    color: var(--accent);
}

.site-nav {
    display: flex;
    gap: var(--space-md);
    flex-wrap: wrap;
}

.site-nav a {
    font-size: 0.875rem;
    font-weight: 500;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--ink-soft);
    text-decoration: none;
    border-bottom: 1px solid transparent;
    padding-bottom: 2px;
}

.site-nav a:hover {
    color: var(--accent);
    border-bottom-color: var(--accent);
}

.site-nav a.is-active {
    color: var(--ink);
    border-bottom-color: var(--accent);
}

.site-main {
    max-width: var(--max-wide);
    margin: 0 auto;
    padding: var(--space-xl) var(--space-md);
}

.hero {
    max-width: var(--max-read);
}

.eyebrow {
    margin: 0 0 var(--space-sm);
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--stone);
}

.hero__title {
    margin: 0 0 var(--space-md);
    font-family: var(--font-serif);
    font-size: clamp(2rem, 6vw, 3.25rem);
    font-weight: 300;
    line-height: 1.08;
    letter-spacing: -0.02em;
    color: var(--ink);
}

.hero__lead {
    margin: 0 0 var(--space-lg);
    font-size: var(--text-lead);
    color: var(--ink-soft);
    max-width: 32rem;
}

.hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-sm);
}

.button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.75rem 1.25rem;
    font-family: var(--font-sans);
    font-size: 0.8125rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    text-decoration: none;
    border-radius: 0;
    border: 1px solid var(--ink);
    cursor: pointer;
    transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.button--primary {
    background: var(--ink);
    color: var(--paper);
    border-color: var(--ink);
}

.button--primary:hover {
    background: var(--accent);
    border-color: var(--accent);
    color: var(--paper);
}

.button--ghost {
    background: transparent;
    color: var(--ink);
    border-color: var(--rule);
}

.button--ghost:hover {
    border-color: var(--ink);
    color: var(--accent);
}

.site-footer {
    margin-top: auto;
    border-top: 1px solid var(--rule);
    padding: var(--space-lg) var(--space-md);
    background: var(--paper-warm);
}

.site-footer__note {
    margin: 0;
    max-width: var(--max-wide);
    margin-inline: auto;
    font-size: 0.875rem;
    color: var(--stone);
    text-align: center;
}
