/* Hard Hat Sports — Base layer
   Element defaults + a few brand primitives (eyebrow, rule, hazard bar).
   Components reference tokens directly; this just sets sane page defaults. */

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

body {
  margin: 0;
  background: var(--canvas);
  color: var(--text-primary);
  font: var(--type-body);
  letter-spacing: var(--body-tracking);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

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

a { color: var(--link); text-decoration: none; }
a:hover { color: var(--link-hover); }

h1, h2, h3, h4 { margin: 0; }

/* --- Brand primitives usable as plain classes --- */

.hhs-eyebrow {
  font: var(--type-eyebrow);
  letter-spacing: var(--eyebrow-tracking);
  text-transform: uppercase;
  color: var(--accent);
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
}
.hhs-eyebrow::before {
  content: "";
  width: 22px;
  height: 2px;
  background: var(--accent);
}

.hhs-display {
  font: var(--type-display-md);
  letter-spacing: var(--display-tracking);
  text-transform: uppercase;
  color: var(--text-primary);
}

/* Hazard / caution-tape bar — jobsite motif */
.hhs-hazard {
  height: 6px;
  background: var(--hazard-stripes);
}

/* Hairline divider */
.hhs-rule { height: 1px; background: var(--hairline); border: 0; }

/* Focus visibility for keyboard users on interactive brand elements */
:where(button, a, input, select, [tabindex]):focus-visible {
  outline: none;
  box-shadow: var(--ring);
}
