/* ==============================
   BASE
================================ */

* {
    box-sizing: border-box;
    -webkit-font-smoothing: antialiased;
}

body {
    margin: 0;
    background: var(--color-bg-900);
    color: var(--color-text-100);
    font-family: var(--font-body);
    line-height: 1.7;
}

h1,
h2,
h3,
h4,
.heading,
label,
button,
.nav-link {
    font-family: var(--font-heading);
    text-transform: uppercase;
    letter-spacing: 0.08rem;
    font-weight: 500;
}

h1 {
    font-size: 2rem;
    color: var(--color-accent-600);
}

h2 {
    font-size: 1.5rem;
    border-bottom: 2px solid var(--color-accent-600);
    padding-bottom: var(--space-2);
}

p,
li {
    font-family: var(--font-body);
    letter-spacing: normal;
}

a {
    color: var(--color-accent-500);
    text-decoration: none;
}

a:hover {
    color: var(--color-accent-600);
}

:focus-visible {
    outline: 2px solid var(--color-accent-500);
    outline-offset: 2px;
}

/* Critical visibility — loaded early to prevent FOUC on slow connections (mobile Firefox) */
.hidden {
    display: none !important;
}

.wl-section-panel {
    display: block;
}

.wl-section-panel.hidden {
    display: none !important;
}