/* ========================================
   COMMVIO — Base Styles
   Global element defaults
   ======================================== */

body {
    font-family: var(--font-family);
    font-size: var(--text-base);
    font-weight: var(--weight-regular);
    line-height: var(--leading-normal);
    color: var(--color-body);
    background-color: var(--color-off-white);
    overflow-x: hidden;
}

/* Prevent scroll when mobile nav is open */
body.nav-open {
    overflow: hidden;
}

/* ── Headings ── */

h1,
.h1 {
    font-size: var(--text-hero);
    font-weight: var(--weight-bold);
    line-height: var(--leading-tight);
    letter-spacing: var(--tracking-tight);
    color: var(--color-heading);
}

h2,
.h2 {
    font-size: clamp(1.75rem, 3.5vw + 0.5rem, var(--text-4xl));
    font-weight: var(--weight-bold);
    line-height: var(--leading-tight);
    letter-spacing: var(--tracking-tight);
    color: var(--color-heading);
}

h3,
.h3 {
    font-size: clamp(1.25rem, 2vw + 0.25rem, var(--text-2xl));
    font-weight: var(--weight-semibold);
    line-height: var(--leading-snug);
    color: var(--color-heading);
}

h4,
.h4 {
    font-size: var(--text-xl);
    font-weight: var(--weight-semibold);
    line-height: var(--leading-snug);
    color: var(--color-heading);
}

h5,
.h5 {
    font-size: var(--text-lg);
    font-weight: var(--weight-medium);
    line-height: var(--leading-snug);
    color: var(--color-heading);
}

h6,
.h6 {
    font-size: var(--text-md);
    font-weight: var(--weight-medium);
    line-height: var(--leading-snug);
    color: var(--color-heading);
}

/* ── Body Text ── */

p {
    max-width: 68ch;
    color: var(--color-body);
}

p+p {
    margin-top: var(--space-4);
}

.lead {
    font-size: clamp(var(--text-md), 1.5vw + 0.25rem, var(--text-xl));
    line-height: var(--leading-relaxed);
    color: var(--color-subtle);
    max-width: 56ch;
}

/* ── Links ── */

a {
    transition: color var(--duration-fast) var(--ease-out);
}

a:hover {
    color: var(--color-accent);
}

/* ── Selection ── */

::selection {
    background-color: var(--color-accent);
    color: var(--color-white);
}

/* ── Label / Eyebrow ── */

.eyebrow {
    display: inline-block;
    font-size: var(--text-xs);
    font-weight: var(--weight-semibold);
    letter-spacing: var(--tracking-wider);
    text-transform: uppercase;
    color: var(--color-accent);
    margin-bottom: var(--space-4);
}

/* ── Horizontal Rule ── */

hr {
    border: none;
    border-top: 1px solid var(--color-border-light);
    margin: var(--space-12) 0;
}

/* ── Strong / Em ── */

strong,
b {
    font-weight: var(--weight-semibold);
    color: var(--color-heading);
}

em,
i {
    font-style: italic;
}

/* ── Code ── */

code {
    font-family: var(--font-mono);
    font-size: 0.9em;
    background: var(--color-surface);
    padding: 0.15em 0.4em;
    border-radius: var(--radius-sm);
}

/* ── Main Content ── */

main {
    position: relative;
}

/* Page enter transition */
.page-enter {
    opacity: 0;
    transform: translateY(8px);
}

.page-enter.is-visible {
    opacity: 1;
    transform: translateY(0);
    transition: opacity var(--duration-slow) var(--ease-out),
        transform var(--duration-slow) var(--ease-out);
}