/* ============================================================
   ScrrySport — shared design system
   ============================================================ */

:root {
  /* surfaces */
  --bg:            #0a0f0a;
  --surface-1:     #0c150c;
  --surface-2:     #0e1a0e;
  --surface-3:     #101e10;

  /* greens — low to high */
  --green-line:    #1c3a1c;
  --green-border:  #1e3d1e;
  --green-rule:    #223d22;
  --green-dim:     #2d4a2d;
  --green-divider: #2d5c2d;
  --green-stroke:  #2e5c2e;
  --green-mid:     #3a6e3a;
  --green-peak:    #3d7a3d;
  --green-accent:  #4a7c4a;

  /* text */
  --text-faint:    #5a7a5a;
  --text-muted:    #7a9e7a;
  --text-soft:     #a8c4a8;
  --text:          #e8ede8;

  /* type */
  --font-display:  'Bebas Neue', 'Impact', sans-serif;
  --font-body:     'Inter', system-ui, sans-serif;

  /* tracking */
  --track-tight:   0.01em;
  --track-logo:    0.04em;
  --track-link:    0.15em;
  --track-label:   0.20em;
  --track-eyebrow: 0.35em;

  /* spacing */
  --space-1: 0.5rem;
  --space-2: 1rem;
  --space-3: 1.5rem;
  --space-4: 2rem;
  --space-5: 2.5rem;
  --space-6: 3rem;

  /* layout */
  --content-max:   640px;
  --reading-max:   420px;

  /* motion */
  --ease:          0.2s ease;
}

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

html, body { background: var(--bg); }

body {
  min-height: 100vh;
  font-family: var(--font-body);
  color: var(--text);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

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

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

::selection { background: var(--green-mid); color: var(--text); }

/* ---------- typography ---------- */
.logo {
  font-family: var(--font-display);
  font-size: clamp(64px, 14vw, 110px);
  color: var(--text);
  letter-spacing: var(--track-logo);
  line-height: 1;
}
.logo span { color: var(--green-mid); }

.eyebrow {
  font-size: 11px;
  font-weight: 500;
  letter-spacing: var(--track-eyebrow);
  color: var(--green-accent);
  text-transform: uppercase;
}

.label {
  font-size: clamp(12px, 2.5vw, 14px);
  font-weight: 300;
  color: var(--text-faint);
  letter-spacing: var(--track-label);
  text-transform: uppercase;
}

.body-text {
  font-size: 15px;
  font-weight: 300;
  color: var(--text-muted);
  line-height: 1.9;
  letter-spacing: var(--track-tight);
}
.body-text em { color: var(--text-soft); font-style: normal; }

.footer-text {
  font-size: 10px;
  font-weight: 400;
  letter-spacing: var(--track-label);
  color: var(--green-dim);
  text-transform: uppercase;
}

/* ---------- background layers ---------- */
.bg-grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(34,74,34,0.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(34,74,34,0.07) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
}

.bg-vignette {
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 50% 60%, transparent 25%, var(--bg) 75%);
  pointer-events: none;
  z-index: 1;
}

.bg-fade-left {
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, var(--bg) 0%, var(--bg) 8%, transparent 40%);
  pointer-events: none;
  z-index: 1;
}

.bg-fade-right {
  position: absolute;
  inset: 0;
  background: linear-gradient(to left, var(--bg) 0%, var(--bg) 8%, transparent 40%);
  pointer-events: none;
  z-index: 1;
}

/* ---------- corner brackets ---------- */
.corner {
  position: absolute;
  width: 20px;
  height: 20px;
  border-color: var(--green-border);
  border-style: solid;
  opacity: 0.6;
  z-index: 3;
}
.corner.tl { top: var(--space-4); left:  var(--space-4); border-width: 1px 0 0 1px; }
.corner.tr { top: var(--space-4); right: var(--space-4); border-width: 1px 1px 0 0; }
.corner.bl { bottom: var(--space-4); left:  var(--space-4); border-width: 0 0 1px 1px; }
.corner.br { bottom: var(--space-4); right: var(--space-4); border-width: 0 1px 1px 0; }

/* ---------- dividers ---------- */
.divider-h {
  width: 40px;
  height: 1px;
  background: var(--green-divider);
  margin: 0 auto;
}
.divider-v {
  width: 1px;
  height: 48px;
  background: linear-gradient(to bottom, var(--green-divider), transparent);
  margin: 0 auto;
}

/* ---------- links / buttons ---------- */
.link-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--green-accent);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: var(--track-link);
  text-transform: uppercase;
  border: 0.5px solid var(--green-border);
  padding: 10px 20px;
  border-radius: 2px;
  transition: color var(--ease), border-color var(--ease), background var(--ease);
}
.link-btn:hover {
  color: var(--text-soft);
  border-color: var(--green-mid);
  background: rgba(58, 110, 58, 0.08);
}

.link-btn.primary {
  background: var(--green-mid);
  color: var(--bg);
  border-color: var(--green-mid);
}
.link-btn.primary:hover {
  background: var(--green-peak);
  border-color: var(--green-peak);
  color: var(--bg);
}

/* ---------- top nav ---------- */
.nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 10;
  padding: 1.25rem 2rem;
  background: linear-gradient(to bottom, rgba(10, 15, 10, 0.85), rgba(10, 15, 10, 0));
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.nav-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: 1280px;
  margin: 0 auto;
}

.nav-brand {
  font-family: var(--font-display);
  font-size: 22px;
  letter-spacing: var(--track-logo);
  color: var(--text);
}
.nav-brand span { color: var(--green-mid); }

.nav-links {
  display: flex;
  align-items: center;
  gap: 1.75rem;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: var(--track-link);
  text-transform: uppercase;
}
.nav-links a {
  color: var(--text-muted);
  transition: color var(--ease);
}
.nav-links a:hover { color: var(--text); }

.nav-placeholder {
  color: var(--text-faint);
  cursor: default;
}

.nav-tag {
  font-size: 9px;
  color: var(--green-accent);
  margin-left: 5px;
  letter-spacing: var(--track-label);
}

/* ---------- scroll cue ---------- */
.scroll-cue {
  position: absolute;
  bottom: 3rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  font-size: 9px;
  letter-spacing: var(--track-label);
  color: var(--green-accent);
  text-transform: uppercase;
}
.scroll-cue::after {
  content: '';
  width: 1px;
  height: 32px;
  background: linear-gradient(to bottom, var(--green-divider), transparent);
}

.dot {
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background: var(--green-divider);
}

/* ---------- layout helper ---------- */
.page {
  min-height: 100vh;
  width: 100%;
  position: relative;
  overflow: hidden;
}

.stack-center {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.content {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: var(--content-max);
  text-align: center;
}
