/* ============================================
 * CSS RESET
 * Mirror of konvoka-client/assets/styling/reset.css
 * ============================================ */

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

html {
  -moz-text-size-adjust: none;
  -webkit-text-size-adjust: none;
  text-size-adjust: none;
  scroll-behavior: smooth;
  background-color: var(--color-ink-950);
}

body,
h1, h2, h3, h4, h5, h6,
p,
figure, blockquote,
dl, dd {
  margin-block-end: 0;
}

ul[role='list'],
ol[role='list'] {
  list-style: none;
}

body {
  font-family: var(--font-primary);
  font-weight: var(--font-normal);
  font-size: var(--text-body);
  line-height: var(--leading-normal);
  color: var(--color-text-strong);
  background-color: var(--color-surface);
  min-height: 100vh;
  font-synthesis: none;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}

h1, h2, h3, h4,
button, input, label {
  line-height: var(--leading-tight);
}

h1, h2, h3, h4 {
  text-wrap: balance;
  font-family: var(--font-display);
  color: var(--color-text-heading);
}

p {
  text-wrap: pretty;
}

a:not([class]) {
  color: var(--color-primary);
  text-decoration-skip-ink: auto;
}

img, picture, video, canvas, svg {
  display: block;
  max-width: 100%;
}

input, button, textarea, select {
  font: inherit;
  color: inherit;
}

textarea:not([rows]) {
  min-height: 8em;
}

:target {
  scroll-margin-block: 6rem;
}

/* Accessible skip link — hidden until keyboard focus */
.skip-link {
  position: absolute;
  top: 0;
  left: 0;
  transform: translateY(-110%);
  background: var(--color-primary);
  color: #fff;
  padding: var(--space-3) var(--space-4);
  text-decoration: none;
  border-radius: 0 0 var(--radius-md) 0;
  z-index: var(--z-toast);
  font-weight: var(--font-semibold);
  transition: transform var(--transition-fast);
}

.skip-link:focus,
.skip-link:focus-visible {
  transform: translateY(0);
  outline: 3px solid #fff;
  outline-offset: -3px;
}

/* Screen-reader only */
.visually-hidden,
.sr-only {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}
