/* =====================================================
   CONVERGENCE GAMING — umbrella landing layout
   Consumes brand tokens from brand.css (--cvg-*).
   Dark industrial base · teal umbrella · per-card accent.
   ===================================================== */

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }

body {
  min-height: 100vh;
  background: var(--cvg-bg);
  color: var(--cvg-text);
  font-family: var(--cvg-font-body);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  display: flex;
  position: relative;
  overflow-x: hidden;
}

a { color: var(--cvg-umbrella-text); text-decoration: none; transition: color .15s ease; }
a:hover { color: var(--cvg-text); }

/* --- background layers --- */
/* Network constellation backdrop — teal nodes/links suggesting the umbrella's
   web of servers converging. Sits behind the grid. */
.bg-network {
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background: url("assets/network-bg.svg?v=1") center/cover no-repeat;
  opacity: 0.9;
}
.bg-grid {
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background:
    linear-gradient(var(--cvg-border) 1px, transparent 1px) 0 0 / 100% 48px,
    linear-gradient(90deg, var(--cvg-border) 1px, transparent 1px) 0 0 / 48px 100%,
    radial-gradient(circle at 50% -10%, rgba(42,111,122,.18) 0%, transparent 55%);
  /* base intentionally transparent so .bg-network shows through; body is #141414 */
  opacity: .9;
  mask-image: radial-gradient(ellipse at 50% 30%, #000 0%, transparent 80%);
  -webkit-mask-image: radial-gradient(ellipse at 50% 30%, #000 0%, transparent 80%);
}
.bg-vignette {
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background: radial-gradient(ellipse at center, transparent 55%, rgba(0,0,0,.6) 100%);
}

/* --- layout --- */
.wrap {
  position: relative; z-index: 1;
  margin: auto;
  width: 100%;
  max-width: 1040px;
  padding: clamp(2rem, 6vw, 5rem) 1.25rem;
  text-align: center;
}

/* --- brand --- */
.brand { margin-bottom: clamp(2.5rem, 6vw, 4rem); }
.brand__mark { display: inline-block; filter: drop-shadow(0 0 22px rgba(42,111,122,.5)); }
.brand__name {
  font-family: var(--cvg-font-display);
  font-weight: 700;
  font-size: clamp(2.4rem, 8vw, 4.5rem);
  letter-spacing: .12em;
  line-height: 1;
  margin-top: .5rem;
  color: var(--cvg-text);
}
.brand__sub {
  display: block;
  font-size: .32em;
  letter-spacing: .55em;
  color: var(--cvg-umbrella-text);
  margin-top: .55rem;
  padding-left: .55em;
}
.brand__tag {
  margin-top: 1.1rem;
  color: var(--cvg-text-muted);
  font-size: clamp(.95rem, 2.5vw, 1.15rem);
}

/* --- picker --- */
.picker__label {
  font-family: var(--cvg-font-display);
  text-transform: uppercase;
  letter-spacing: .25em;
  font-size: .85rem;
  color: var(--cvg-text-muted);
  margin-bottom: 1.5rem;
}
.games {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 1.1rem;
}

/* --- game card --- */
.game {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  text-align: left;
  gap: .55rem;
  padding: 1.5rem 1.4rem;
  background: var(--cvg-surface-raised);
  border: 1px solid var(--cvg-border);
  border-radius: var(--cvg-radius-lg);
  min-height: 210px;
  position: relative;
  overflow: hidden;
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}
/* accent spine — uses each card's own --cvg-accent (set via data-cvg-server) */
.game::before {
  content: "";
  position: absolute; left: 0; top: 0; bottom: 0; width: 4px;
  background: var(--cvg-accent);
  opacity: .9;
}
.game--soon::before { background: var(--cvg-border-strong); }

.game--live { cursor: pointer; }
.game--live:hover {
  transform: translateY(-4px);
  border-color: var(--cvg-accent);
  box-shadow: 0 24px 60px -24px rgba(0,0,0,.8);
}
.game--soon { opacity: .6; }

.game__status {
  font-family: var(--cvg-font-mono);
  font-size: .7rem;
  letter-spacing: .12em;
  padding: .2rem .55rem;
  border-radius: 999px;
  border: 1px solid var(--cvg-border-strong);
  color: var(--cvg-text-muted);
}
.game--live .game__status { color: var(--cvg-accent); border-color: var(--cvg-accent); }

.game__lockup { font-size: 1.45rem; letter-spacing: .04em; margin-top: .35rem; }
.game__tbd { color: var(--cvg-text-faint) !important; }

.game__meta {
  font-family: var(--cvg-font-mono);
  font-size: .72rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--cvg-text-muted);
}
.game__desc { color: var(--cvg-text-muted); font-size: .9rem; flex: 1; }

.game__go { margin-top: .4rem; }
.game--live:hover .game__go { background: var(--cvg-accent-hover); }

/* --- footer --- */
.foot { margin-top: clamp(2.5rem, 6vw, 4rem); }
.foot__copy { margin-top: 1.2rem; color: var(--cvg-text-faint); font-size: .8rem; }

@media (prefers-reduced-motion: reduce) { * { transition: none !important; } }

/* ===== brand component classes (from brand system) ===== */
.cvg-wordmark {
  font-family: var(--cvg-font-display);
  font-weight: 600;
  letter-spacing: .08em;
  color: var(--cvg-text);
}
.cvg-wordmark i { color: var(--cvg-umbrella); font-style: normal; margin: 0 .4em; }
.cvg-wordmark b { color: var(--cvg-accent); font-weight: 600; }

.cvg-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 18px;
  border: none;
  border-radius: var(--cvg-radius-md);
  background: var(--cvg-accent);
  color: var(--cvg-accent-ink);
  font-family: var(--cvg-font-display);
  font-weight: 600;
  letter-spacing: .04em;
  cursor: pointer;
  transition: background .15s ease;
}
