/* =========================================================
   02-base.css
   Base styles + accessibility
========================================================= */

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

html, body {
  height: 100%;
  margin: 0;
  font-family: var(--font-sans);
  color: var(--text);
  background: var(--bg);
}

body{
  margin: 0;
  min-height: 100vh;
  font-family: var(--font-sans);
  color: var(--text);

  /* Match website background language */
  background:
    radial-gradient(circle at 14% 10%, rgba(94, 203, 255, 0.22), transparent 42%),
    radial-gradient(circle at 78% 18%, rgba(162, 117, 255, 0.18), transparent 40%),
    linear-gradient(180deg, var(--surface-2) 0%, var(--bg) 100%);

  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  position: relative;
}

img { max-width: 100%; display: block; }
button, input, select { font: inherit; }

a { color: inherit; text-decoration: none; }
a:hover { text-decoration: none; }

:focus-visible {
  outline: none;
  box-shadow: var(--ring);
  border-radius: 10px;
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
}

/* Skip link */
.saas-skip-link {
  position: absolute;
  left: 10px;
  top: 10px;
  transform: translateY(-160%);
  background: var(--surface);
  border: 1px solid var(--border);
  padding: 10px 12px;
  border-radius: 12px;
  box-shadow: var(--shadow-sm);
  z-index: 99999;
}
.saas-skip-link:focus { transform: translateY(0); }
