﻿/* ===== FONT AWESOME SIZING ===== */
.rn-icon i   { font-size: 18px; }
.ic i        { font-size: 20px; }
.skull i     { font-size: 36px; }
.pill i      { font-size: 12px; line-height: 1; }
.hero-date i { font-size: 20px; }

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

:root {
  --bg:       #0d0d0f;
  --bg2:      #111118;
  --bg3:      #17171f;
  --purple:   #9B30FF;
  --purple-l: #C070FF;
  --purple-d: #6B1AB3;
  --gold:     #c9972a;
  --gold-l:   #f0b429;
  --border:   rgba(255,255,255,0.07);
  --border2:  rgba(155,48,255,0.3);
  --text:     #c8c0e0;
  --muted:    #c8c0e0;
  --font-mono:     'Share Tech Mono', monospace;
  --font-head:     'Rajdhani', sans-serif;
  --body:     'Barlow', sans-serif;
}

html { scroll-behavior: smooth; }
body { position: relative; }
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image: url('../img/bg.png');
  background-size: cover;
  background-position: center top;
  background-repeat: no-repeat;
  opacity: 0.3;
  z-index: -1;
  pointer-events: none;
}
body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-mono);
  font-size: 0.95rem;
  line-height: 1.75;
  min-height: 100vh;
}

p { margin-bottom: 1rem; }
p:last-child { margin-bottom: 0; }

/* ===== NAV ===== */
#navbar {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  height: 64px;
  border-bottom: 1px solid transparent;
  transition: background 0.3s, border-color 0.3s;
}
#navbar.scrolled {
  background: rgba(13,13,15,0.92);
  backdrop-filter: blur(12px);
  border-bottom-color: var(--border);
}
.nav-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 2rem;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.nav-logo {
  font-family: var(--font-head);
  font-size: 1rem;
  font-weight: 700;
  color: #fff;
  letter-spacing: 2px;
  text-transform: uppercase;
  text-decoration: none;
  white-space: nowrap;
}
.logo-bracket { color: var(--purple); }
.logo-accent {
  color: var(--purple);
  animation: blink 1.2s step-end infinite;
}
@keyframes blink {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0; }
}
.logo-sep  { color: var(--muted); opacity: 0.4; font-weight: 400; }
.logo-sub  { color: var(--purple-l); font-size: 0.78em; letter-spacing: 0.18em; }
.nav-links {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  list-style: none;
}
.nav-link {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  color: var(--muted);
  letter-spacing: 1px;
  text-transform: uppercase;
  text-decoration: none;
  padding: 0.4rem 0.8rem;
  border-radius: 4px;
  transition: color 0.2s;
  position: relative;
}
.nav-link::after {
  content: '';
  position: absolute;
  bottom: -2px; left: 50%;
  transform: translateX(-50%);
  width: 0; height: 1px;
  background: var(--purple);
  transition: width 0.3s;
}
.nav-link:hover { color: #fff; }
.nav-link:hover::after,
.nav-link.active::after { width: 60%; }
.nav-link.active { color: var(--purple-l); }
.nav-link.nav-hof { color: var(--gold-l); }
.nav-link.nav-hof:hover { color: #fff; }
.nav-link.nav-hof::after { background: var(--gold-l); }

.nav-lang-item {
  display: flex;
  align-items: center;
  gap: 4px;
  margin-left: 8px;
  border: 1px solid rgba(155,48,255,0.2);
  border-radius: 4px;
  padding: 0.3rem 0.6rem;
  transition: border-color 0.2s;
  list-style: none;
}
.nav-lang-item:hover { border-color: var(--purple); }
.nav-lang-opt {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 1px;
  color: var(--muted);
  cursor: pointer;
  transition: color 0.2s;
}
.nav-lang-opt.active { color: var(--purple); font-weight: bold; }
.nav-lang-opt:hover { color: #fff; }
.nav-lang-sep { color: var(--muted); opacity: 0.4; font-size: 0.7rem; }

.nav-toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px;
}
.nav-toggle span {
  display: block;
  width: 24px;
  height: 2px;
  background: var(--purple);
  transition: transform 0.3s;
}

@media (max-width: 768px) {
  .nav-toggle { display: flex; }
  .nav-links {
    display: none;
    position: fixed;
    top: 64px; left: 0; right: 0;
    flex-direction: column;
    background: rgba(13,13,15,0.97);
    backdrop-filter: blur(12px);
    padding: 20px;
    border-bottom: 1px solid var(--border);
    gap: 4px;
    z-index: 99;
  }
  .nav-links.open { display: flex; }
  .nav-link { width: 100%; padding: 10px 16px; }
  .nav-lang-item { align-self: flex-start; margin-left: 0; }
}

/* ===== HERO ===== */
.hero i { color: var(--purple-l); }
.hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  padding: 100px 8vw 60px;
  overflow: hidden;
}
.hero-watermark {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  overflow: hidden;
}
.hero-watermark span {
  font-family: var(--font-head);
  font-weight: 900;
  font-size: clamp(5rem, 14vw, 14rem);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: transparent;
  -webkit-text-stroke: 1px rgba(155,48,255,0.40);
  text-shadow: 0 0 40px rgba(155,48,255,0.08);
  white-space: nowrap;
  user-select: none;
}
.hero::before {
  content: '';
  position: absolute;
  top: 20%;
  left: 5%;
  width: 600px;
  height: 600px;
  background: radial-gradient(circle, rgba(155,48,255,0.15) 0%, transparent 70%);
  pointer-events: none;
}
.hero-badge {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  color: var(--purple-l);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: 14px;
}
.hero h1 {
  font-family: var(--font-head);
  font-size: clamp(4rem, 12vw, 11rem);
  font-weight: 900;
  line-height: 0.9;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  color: #fff;
  margin-top: 32px;
  margin-bottom: 18px;
  position: relative;
}
.hero h1 em {
  font-style: normal;
  color: var(--purple-l);
}
.hero-sub {
  font-family: var(--font-mono);
  font-size: 0.8rem;
  color: var(--muted);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 32px;
}
.hero-date {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: 1px solid var(--border2);
  padding: 8px 18px;
  border-radius: 3px;
  font-family: var(--font-head);
  font-size: 1.35rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  color: #fff;
  margin-bottom: 28px;
}
.hero-date svg { color: var(--purple-l); }
.hero-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  font-family: var(--font-mono);
  font-size: 0.92rem;
  color: var(--muted);
}
.hero-pills .pill {
  display: flex;
  align-items: center;
  gap: 6px;
}
.hero-pills .pill span { color: #fff; font-size: 1rem; }

/* ===== SECTION COMMON ===== */
section { padding: 80px 0; }
.container { max-width: 860px; margin: 0 auto; padding: 0 24px; }

.section-label {
  font-family: var(--font-mono);
  font-size: 0.68rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--purple-l);
  text-align: center;
  margin-bottom: 10px;
}
.section-title {
  font-family: var(--font-head);
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  text-align: center;
  color: #fff;
  margin-bottom: 10px;
}
.section-title em {
  font-style: normal;
  color: var(--purple-l);
}
.section-sep {
  display: block;
  width: 60px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--purple), transparent);
  margin: 10px auto 42px;
}
.section-sub {
  text-align: center;
  font-family: var(--font-mono);
  font-size: 0.8rem;
  color: var(--muted);
  letter-spacing: 0.06em;
  margin-top: -30px;
  margin-bottom: 42px;
}

/* ===== SCORING SECTION ===== */
.scoring-card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 36px;
  text-align: center;
  position: relative;
  overflow: hidden;
  margin-bottom: 20px;
}
.scoring-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(155,48,255,0.06) 0%, transparent 60%);
  pointer-events: none;
}
.scoring-formula {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  margin-bottom: 14px;
}
.scoring-formula .num {
  font-family: var(--font-head);
  font-size: 5rem;
  font-weight: 900;
  color: #fff;
  line-height: 1;
}
.scoring-formula .sep {
  font-family: var(--font-head);
  font-size: 3rem;
  font-weight: 300;
  color: var(--purple);
  line-height: 1;
}
.skull { display: flex; align-items: center; opacity: 0.45; color: var(--purple-l); }
.scoring-label {
  font-family: var(--font-head);
  font-size: 1.1rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--purple-l);
  margin-bottom: 14px;
}
.scoring-desc {
  font-family: var(--font-mono);
  font-size: 0.8rem;
  color: var(--muted);
  max-width: 460px;
  margin: 0 auto;
  line-height: 1.7;
}

.scoring-meta {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.meta-card {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 22px 24px;
  display: flex;
  gap: 14px;
  align-items: flex-start;
}
.meta-card .ic { flex-shrink: 0; margin-top: 2px; color: var(--purple-l); }
.meta-card h4 {
  font-family: var(--font-head);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #fff;
  margin-bottom: 5px;
}
.meta-card p {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  color: var(--muted);
  line-height: 1.5;
}

/* ===== RULES SECTION ===== */
.rules-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.rules-category {
  font-family: var(--font-head);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--purple-l);
  padding: 5px 0 5px 14px;
  border-left: 2px solid var(--purple);
  margin-top: 20px;
}
.rules-category:first-child { margin-top: 0; }
.legal-notice {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 24px 0 8px;
  padding: 12px 18px;
  background: rgba(155,48,255,.06);
  border: 1px solid rgba(155,48,255,.18);
  border-radius: 4px;
  font-family: var(--font-mono);
  font-size: 0.75rem;
  color: var(--muted);
}
.legal-notice i { color: var(--purple-l); font-size: 0.85rem; flex-shrink: 0; }
.legal-notice a {
  color: var(--purple-l);
  text-decoration: none;
  margin-left: auto;
  white-space: nowrap;
  transition: color .15s;
}
.legal-notice a:hover { color: #fff; }

.rules-section-header {
  font-family: var(--font-head);
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--purple-l);
  padding: 9px 0 9px 18px;
  border-left: 3px solid var(--purple);
  margin-top: 32px;
}
.rules-subcategory {
  font-family: var(--font-mono);
  font-size: 0.65rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--muted);
  padding-left: 4px;
  margin-top: 14px;
  margin-bottom: 2px;
}
.rules-subcategory::before {
  content: '› ';
  color: var(--purple-l);
}
.rule-item {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 4px;
  display: flex;
  align-items: flex-start;
  gap: 0;
  overflow: hidden;
  transition: border-color 0.2s;
}
.rule-item:hover { border-color: var(--border2); }
.rule-num {
  width: 56px;
  flex-shrink: 0;
  background: none;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 20px 0;
  color: var(--purple-l);
}
.rule-num .rn-icon { display: flex; }
.rule-num .rn-num { display: none; }
.rule-body { padding: 18px 22px; }
.rule-body h3 {
  font-family: var(--font-head);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #fff;
  margin-bottom: 5px;
}
.rule-body p {
  font-family: var(--font-mono);
  font-size: 0.8rem;
  color: var(--muted);
  line-height: 1.55;
}
.rule-body strong { color: var(--purple-l); }
.rule-body .tag-bad {
  display: inline-block;
  background: rgba(200,50,50,0.15);
  border: 1px solid rgba(200,50,50,0.3);
  color: #e07070;
  font-size: 0.65rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 1px 7px;
  border-radius: 2px;
  margin-left: 6px;
  vertical-align: middle;
}
.rule-body .tag-ok {
  display: inline-block;
  background: rgba(46,160,67,0.12);
  border: 1px solid rgba(46,160,67,0.28);
  color: #5dd879;
  font-size: 0.65rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 1px 7px;
  border-radius: 2px;
  margin-left: 6px;
  vertical-align: middle;
}

/* ===== OBLIGATIONS ===== */
.oblig-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.oblig-item {
  display: flex;
  align-items: flex-start;
  gap: 0;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 4px;
  overflow: hidden;
}
.oblig-icon {
  width: 56px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px 0;
  border-right: 1px solid var(--border);
  background: var(--bg3);
  color: var(--purple-l);
}
.oblig-body { padding: 18px 22px; }
.oblig-body h3 {
  font-family: var(--font-head);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #fff;
  margin-bottom: 5px;
}
.oblig-body p {
  font-family: var(--font-mono);
  font-size: 0.8rem;
  color: var(--muted);
  line-height: 1.55;
}
.oblig-body strong { color: var(--purple-l); }

/* ===== SANCTIONS ===== */
.sanction-wrap {
  background: var(--bg2);
  border: 1px solid rgba(200,50,50,0.2);
  border-top: 2px solid #c03030;
  border-radius: 4px;
  padding: 30px 32px;
}
.sanction-wrap h3 {
  font-family: var(--font-head);
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: #e07070;
  margin-bottom: 16px;
}
.sanction-wrap ul { list-style: none; display: flex; flex-direction: column; gap: 8px; }
.sanction-wrap li {
  font-family: var(--font-mono);
  font-size: 0.82rem;
  color: var(--muted);
  display: flex;
  align-items: flex-start;
  gap: 8px;
}
.sanction-wrap li::before { content: '//'; color: #c03030; font-weight: 700; flex-shrink: 0; }
.sanction-wrap .triggers {
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid var(--border);
  font-family: var(--font-mono);
  font-size: 0.78rem;
  color: var(--muted);
}
.sanction-wrap .triggers span { color: #e07070; }

/* ===== DANGER VARIANTS (sanctions) ===== */
.rules-subcategory.danger { color: rgba(200,70,70,0.85); }
.rules-subcategory.danger::before { color: rgba(200,70,70,0.85); }
.rule-item.danger { border-color: rgba(200,50,50,0.6); background: rgba(200,50,50,0.18); }
.rule-item.danger:hover { border-color: rgba(200,50,50,0.45); }
.rule-item.danger .rule-num { color: rgba(200,70,70,0.85); }
.rule-item.danger .rule-body h3 { color: rgba(200,70,70,0.9); }
.rule-body .sanction-sub {
  font-family: var(--font-head);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #fff;
  margin-top: 10px;
  margin-bottom: 8px;
}
.rule-body .sanction-list { list-style: none; display: flex; flex-direction: column; gap: 6px; margin-bottom: 14px; }
.rule-body .sanction-list li {
  font-family: var(--font-mono);
  font-size: 0.8rem;
  color: var(--muted);
  display: flex;
  align-items: flex-start;
  gap: 8px;
}
.rule-body .sanction-list li::before { content: '►'; color: #c03030; font-size: 0.6rem; margin-top: 3px; flex-shrink: 0; }
.rule-body .sanction-triggers-inline {
  padding-top: 12px;
  border-top: 1px solid var(--border);
  font-family: var(--font-mono);
  font-size: 0.75rem;
  color: var(--muted);
}
.rule-body .sanction-triggers-inline span { color: rgba(200,70,70,0.85); }

/* ===== DUOS TABLE ===== */
.duos-section {
  margin-top: 48px;
}
.duos-section-title {
  font-family: var(--font-head);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--purple-l);
  border-left: 3px solid var(--purple);
  padding-left: 10px;
  margin-bottom: 16px;
}
.duos-table-wrap {
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 4px;
  overflow: hidden;
}
.duos-table {
  width: 100%;
  border-collapse: collapse;
}
.duos-table th {
  font-family: var(--font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--purple-l);
  background: var(--bg3);
  padding: 10px 14px;
  text-align: left;
  border-bottom: 1px solid var(--border);
}
.duos-table th:first-child { width: 44px; text-align: center; }
.duos-table td {
  font-family: var(--font-mono);
  font-size: 0.8rem;
  color: var(--text);
  padding: 11px 14px;
  border-bottom: 1px solid var(--border);
}
.duos-table td:first-child { text-align: center; color: var(--purple-d); font-size: 0.72rem; }
.duos-table tr:last-child td { border-bottom: none; }
.duos-table tr:hover td { background: rgba(155,48,255,0.04); }
.duos-td-name { font-weight: 700; color: #fff !important; }
.duos-td-player { display: flex; flex-direction: column; gap: 2px; }
.duos-td-player .dp-discord { color: var(--text); font-size: 0.78rem; }
.duos-td-player .dp-tracker {
  font-size: 0.68rem;
  color: var(--purple-l);
  text-decoration: none;
  opacity: 0.8;
  transition: opacity 0.15s;
}
.duos-td-player .dp-tracker:hover { opacity: 1; text-decoration: underline; }
.duos-empty {
  padding: 28px 20px;
  text-align: center;
  font-family: var(--font-mono);
  font-size: 0.8rem;
  color: var(--muted);
}

/* ===== SCANLINES ===== */
.scanlines {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background: repeating-linear-gradient(
    0deg,
    transparent,
    transparent 2px,
    rgba(0, 0, 0, 0.08) 2px,
    rgba(0, 0, 0, 0.08) 4px
  );
}

/* Ensure all page content renders above scanlines */
.hero, section,
main, .page-header,
.reg-header, .reg-section,
.hof-header, .hof-section,
.footer {
  position: relative;
  z-index: 2;
}

/* ===== FOOTER ===== */
.footer {
  background: rgba(17,17,24,0.92);
  border-top: 1px solid var(--border);
  padding: 3rem 1.5rem;
  position: relative;
  z-index: 2;
}
.footer-inner {
  max-width: 900px;
  margin: 0 auto;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.75rem;
}
.footer-logo {
  font-family: var(--font-head);
  font-size: 1rem;
  font-weight: 700;
  color: #fff;
  letter-spacing: 2px;
}
.footer-tagline {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  color: var(--muted);
  letter-spacing: 3px;
  text-transform: uppercase;
}
.footer-links {
  display: flex;
  gap: 1.5rem;
  margin: 0.5rem 0;
}
.footer-links a {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  color: var(--muted);
  text-decoration: none;
  letter-spacing: 1px;
  display: flex;
  align-items: center;
  gap: 0.4rem;
  transition: color 0.2s;
}
.footer-links a:hover { color: var(--purple-l); }
.footer-copy {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  color: var(--muted);
  opacity: 0.6;
  letter-spacing: 1px;
}
.footer-visits {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  color: var(--purple-l);
  letter-spacing: 1px;
  margin-top: 4px;
  opacity: 0.75;
}
.footer-made {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  color: var(--muted);
  opacity: 0.6;
  letter-spacing: 1px;
}
.footer-heart {
  color: #ff4466;
  animation: heartbeat 1.4s ease-in-out infinite;
  display: inline-block;
}
@keyframes heartbeat {
  0%, 100% { transform: scale(1); }
  14%       { transform: scale(1.25); }
  28%       { transform: scale(1); }
  42%       { transform: scale(1.15); }
}
.footer-author { color: var(--purple-l); font-weight: bold; }

/* ===== RESPONSIVE ===== */
@media (max-width: 640px) {
  .scoring-meta { grid-template-columns: 1fr; }
  .hero { padding: 100px 6vw 50px; }
  nav { gap: 20px; padding: 12px 20px; }
  nav a { font-size: 0.65rem; }
}

