/* NetGameForge — single stylesheet. Brand palette lives in :root. */
:root {
  /* Brand palette — change brand in one place */
  --color-bg: #0d0f0e;
  --color-surface: #16181a;
  --color-surface-2: #22262a;
  --color-text: #f2f4f1;
  --color-text-muted: #9aa39a;
  --color-accent: #9be600;
  --color-accent-2: #ff4d6d;
  --color-border: #2a2e2c;
  --color-focus: #caff3d;

  /* Cover placeholder gradient (shown when image missing) */
  --cover-fallback: linear-gradient(135deg, #22262a 0%, #16181a 50%, #1c2a12 100%);

  /* Layout */
  --radius: 12px;
  --gap: 1rem;
  --maxw: 1200px;
  --font: system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

* { box-sizing: border-box; }

html { color-scheme: dark; }

body {
  margin: 0;
  font-family: var(--font);
  background: var(--color-bg);
  color: var(--color-text);
  line-height: 1.5;
  -webkit-text-size-adjust: 100%;
}

a { color: var(--color-accent); }

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

:focus-visible {
  outline: 3px solid var(--color-focus);
  outline-offset: 2px;
}

.container {
  max-width: var(--maxw);
  margin-inline: auto;
  padding-inline: 1rem;
}

.visually-hidden {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0 0 0 0);
  white-space: nowrap; border: 0;
}

/* ---------- Header ---------- */
.site-header {
  border-bottom: 1px solid var(--color-border);
  background: var(--color-surface);
  position: sticky; top: 0; z-index: 10;
}
.site-header .container {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding-block: 0.75rem;
}
.brand {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  text-decoration: none;
  color: var(--color-text);
  font-weight: 700;
  font-size: 1.15rem;
}
.brand img, .brand svg { height: 32px; width: auto; aspect-ratio: 1 / 1; }

/* ---------- Main / sections ---------- */
main { padding-block: 1.5rem 3rem; }

.page-intro { margin-bottom: 1.5rem; }
.page-intro h1 {
  font-size: clamp(1.5rem, 4vw, 2.25rem);
  margin: 0 0 0.5rem;
  line-height: 1.15;
}
.page-intro p { color: var(--color-text-muted); margin: 0; max-width: 60ch; }

section.shelf { margin-block: 2rem; }
section.shelf > h2 {
  font-size: 1.25rem;
  margin: 0 0 0.75rem;
}

/* ---------- Tag filter (horizontal scroll) ---------- */
.tag-filter {
  display: flex;
  gap: 0.5rem;
  overflow-x: auto;
  padding-bottom: 0.5rem;
  margin-bottom: 1.5rem;
  -webkit-overflow-scrolling: touch;
}
.tag-filter button {
  flex: 0 0 auto;
  background: var(--color-surface-2);
  color: var(--color-text);
  border: 1px solid var(--color-border);
  border-radius: 999px;
  padding: 0.4rem 0.9rem;
  font: inherit;
  font-size: 0.9rem;
  cursor: pointer;
  white-space: nowrap;
}
.tag-filter button[aria-pressed="true"] {
  background: var(--color-accent);
  color: #0d0f0e;
  border-color: var(--color-accent);
  font-weight: 600;
}

/* ---------- Grid ---------- */
.game-grid {
  display: grid;
  gap: var(--gap);
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
}
@media (min-width: 640px) {
  .game-grid { grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); }
}

/* ---------- Card ---------- */
.game-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform 0.12s ease, border-color 0.12s ease;
}
.game-card a {
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
  height: 100%;
}
.game-card:hover,
.game-card:focus-within {
  transform: translateY(-2px);
  border-color: var(--color-accent);
  box-shadow: 0 0 0 1px var(--color-accent), 0 8px 24px rgba(155, 230, 0, 0.12);
}
.game-card .cover {
  aspect-ratio: 1 / 1;
  background: var(--cover-fallback);
  background-size: cover;
  background-position: center;
  position: relative;
}
.game-card .cover img {
  width: 100%; height: 100%;
  object-fit: cover;
}
.game-card .badges {
  position: absolute; top: 0.5rem; left: 0.5rem; right: 0.5rem;
  display: flex; flex-wrap: wrap; gap: 0.35rem;
}
.badge {
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  padding: 0.2rem 0.5rem;
  border-radius: 999px;
}
.badge--new { background: var(--color-accent); color: #0d0f0e; }
.badge--popular { background: var(--color-accent-2); color: #2a0411; }

.game-card .body { padding: 0.75rem; display: flex; flex-direction: column; gap: 0.5rem; flex: 1; }
.game-card h2, .game-card h3 { margin: 0; font-size: 1rem; line-height: 1.25; }
.game-card .tags {
  display: flex; flex-wrap: wrap; gap: 0.3rem;
  margin-top: auto;
}
.game-card .tags span {
  font-size: 0.72rem;
  color: var(--color-text-muted);
  background: var(--color-surface-2);
  padding: 0.15rem 0.45rem;
  border-radius: 6px;
}

/* ---------- Empty state ---------- */
.empty-state {
  text-align: center;
  padding: 3rem 1rem;
  color: var(--color-text-muted);
  border: 1px dashed var(--color-border);
  border-radius: var(--radius);
}
.empty-state h2 { color: var(--color-text); margin-top: 0; }

/* ---------- Footer ---------- */
.site-footer {
  border-top: 1px solid var(--color-border);
  padding-block: 1.5rem;
  color: var(--color-text-muted);
  font-size: 0.9rem;
}

/* ---------- Game page ---------- */
.breadcrumbs { font-size: 0.9rem; margin-bottom: 1rem; color: var(--color-text-muted); }
.breadcrumbs a { color: var(--color-text-muted); }
.breadcrumbs [aria-current="page"] { color: var(--color-text); }

.game-hero h1 { font-size: clamp(1.5rem, 4vw, 2rem); margin: 0 0 0.5rem; }
.game-lead { font-size: 1.05rem; color: var(--color-text); margin: 0 0 1rem; max-width: 65ch; }

.game-frame {
  position: relative;
  width: 100%;
  background: #000;
  border-radius: var(--radius);
  overflow: hidden;
  border: 1px solid var(--color-border);
}
.game-frame.landscape { aspect-ratio: 16 / 9; }
.game-frame.portrait { aspect-ratio: 9 / 16; max-width: 420px; margin-inline: auto; }
.game-frame iframe {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  border: 0;
}

.game-meta { margin-block: 1.5rem; color: var(--color-text-muted); }
.game-meta .tags { display: flex; flex-wrap: wrap; gap: 0.4rem; margin-top: 0.5rem; }
.game-meta .tags span {
  font-size: 0.8rem; background: var(--color-surface-2);
  padding: 0.2rem 0.6rem; border-radius: 6px; color: var(--color-text-muted);
}

/* ---------- Cabinet (/my/, noindex) ---------- */
.cab { max-width: 760px; }
.cab-muted { color: var(--color-text-muted); }
.cab-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  padding: 1.25rem;
  margin-block: 1rem;
}
.cab-card h1 { margin-top: 0; }
.cab-toolbar {
  display: flex; align-items: center; gap: 0.75rem;
  flex-wrap: wrap; margin-block: 1rem;
}
.cab-toolbar h1 { margin: 0; flex: 1 1 auto; font-size: 1.4rem; }

.cab-btn {
  font: inherit; font-weight: 600;
  border-radius: var(--radius);
  padding: 0.6rem 1.1rem;
  border: 1px solid var(--color-border);
  cursor: pointer;
}
.cab-btn:disabled { opacity: 0.6; cursor: default; }
.cab-btn--primary { background: var(--color-accent); color: #0d0f0e; border-color: var(--color-accent); }
.cab-btn--ghost { background: var(--color-surface-2); color: var(--color-text); }

.cab-field { display: block; margin-block: 0.75rem; }
.cab-field > span { display: block; margin-bottom: 0.3rem; font-size: 0.9rem; color: var(--color-text-muted); }
.cab-field input, .cab-field textarea, .cab-field select {
  width: 100%; font: inherit;
  background: var(--color-bg); color: var(--color-text);
  border: 1px solid var(--color-border); border-radius: 8px;
  padding: 0.55rem 0.7rem;
}
.cab-field input[readonly] { opacity: 0.7; }

.cab-counter {
  display: block; text-align: right;
  font-size: 0.78rem; color: var(--color-text-muted); margin-top: 0.2rem;
}
.cab-counter--warn { color: var(--color-accent-2); font-weight: 600; }
.cab-hint { display: block; font-size: 0.8rem; color: var(--color-text-muted); margin-top: 0.2rem; }
.cab-slug { margin: 0.25rem 0; font-size: 0.85rem; word-break: break-all; }

.cab-chips { display: flex; flex-wrap: wrap; gap: 0.4rem; margin: 0.5rem 0 0.75rem; }
.cab-chip-btn {
  font: inherit; font-size: 0.82rem; min-height: 44px;
  background: var(--color-surface-2); color: var(--color-text);
  border: 1px solid var(--color-border); border-radius: 999px;
  padding: 0.35rem 0.8rem; cursor: pointer;
}
.cab-chip-btn:hover { border-color: var(--color-accent); }

.cab-cropper {
  display: flex; flex-wrap: wrap; gap: 0.9rem; align-items: center;
  margin-block: 0.75rem;
}
.cab-cropper canvas {
  width: 256px; max-width: 100%; height: auto; aspect-ratio: 1 / 1;
  border: 1px solid var(--color-border); border-radius: 8px;
  background: var(--color-bg); touch-action: none; cursor: grab;
}
#cover-canvas {
  width: 400px; aspect-ratio: 1200 / 630;
}
.cab-cropper-ctrl { flex: 1 1 200px; }
.cab-cropper-ctrl label { display: block; font-size: 0.85rem; color: var(--color-text-muted); }
.cab-cropper-ctrl input[type="range"] { width: 100%; margin-top: 0.3rem; }

.cab-flags {
  border: 1px solid var(--color-border); border-radius: 8px;
  margin-block: 0.75rem; padding: 0.6rem 0.9rem;
}
.cab-flags legend { color: var(--color-text-muted); font-size: 0.9rem; padding-inline: 0.3rem; }
.cab-flags label { display: inline-flex; align-items: center; gap: 0.4rem; margin-right: 1.2rem; }

.cab-error { color: var(--color-accent-2); margin: 0.5rem 0; }
.cab-status { color: var(--color-text-muted); margin: 0.5rem 0; }
.cab-warnings {
  border: 1px solid var(--color-accent-2); border-radius: 8px;
  padding: 0.5rem 0.9rem; margin-block: 0.5rem;
}
.cab-warnings p { margin: 0.25rem 0; }

.cab-games { display: grid; gap: 0.6rem; }
.cab-game {
  display: flex; align-items: center; gap: 0.75rem; flex-wrap: wrap;
  background: var(--color-surface); border: 1px solid var(--color-border);
  border-radius: var(--radius); padding: 0.75rem 1rem;
}
.cab-game > div:first-child { flex: 1 1 auto; min-width: 0; }
.cab-tags { display: flex; flex-wrap: wrap; gap: 0.35rem; margin-top: 0.4rem; }
.cab-tag {
  font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.02em;
  padding: 0.15rem 0.5rem; border-radius: 999px;
  background: var(--color-surface-2); color: var(--color-text-muted);
}
.cab-tag--new { background: var(--color-accent); color: #0d0f0e; }
.cab-tag--pop { background: var(--color-accent-2); color: #2a0411; }
.cab-tag--pub { background: #1c2a12; color: var(--color-accent); }
.cab-tag--draft { background: var(--color-surface-2); color: var(--color-text-muted); }

/* ---------- Ratings: action-bar (FE-13) ---------- */
.ngf-actionbar {
  display: flex; align-items: center; gap: 0.6rem; flex-wrap: wrap;
  margin-block: 1rem;
}
.ngf-vote {
  min-width: 44px; min-height: 44px;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 1.25rem; line-height: 1;
  background: var(--color-surface-2); color: var(--color-text);
  border: 1px solid var(--color-border); border-radius: var(--radius);
  cursor: pointer;
}
.ngf-vote.is-active {
  background: var(--color-accent); border-color: var(--color-accent);
}
.ngf-vote.is-active[aria-label="Не нравится"] {
  background: var(--color-accent-2); border-color: var(--color-accent-2);
}
.ngf-vote-summary { color: var(--color-text-muted); font-size: 0.95rem; }

/* ---------- Ratings: reviews accordion (FE-14) ---------- */
.ngf-reviews {
  border: 1px solid var(--color-border); border-radius: var(--radius);
  background: var(--color-surface); margin-block: 1rem;
}
.ngf-reviews-summary {
  cursor: pointer; list-style: none;
  display: flex; align-items: center; gap: 0.5rem;
  padding: 0.85rem 1rem; min-height: 44px;
  font-weight: 600;
}
.ngf-reviews-summary::-webkit-details-marker { display: none; }
.ngf-reviews-count { color: var(--color-text-muted); font-weight: 400; }
.ngf-reviews-panel { padding: 0 1rem 1rem; }

.ngf-review-form { display: flex; flex-direction: column; gap: 0.6rem; margin-bottom: 1rem; }
.ngf-field { display: block; }
.ngf-field > span { display: block; margin-bottom: 0.3rem; font-size: 0.9rem; color: var(--color-text-muted); }
.ngf-field input, .ngf-field textarea {
  width: 100%; font: inherit;
  background: var(--color-bg); color: var(--color-text);
  border: 1px solid var(--color-border); border-radius: 8px;
  padding: 0.55rem 0.7rem;
}
.ngf-counter { font-size: 0.8rem; color: var(--color-text-muted); align-self: flex-end; }
.ngf-btn {
  font: inherit; font-weight: 600; min-height: 44px;
  border-radius: var(--radius); padding: 0.6rem 1.1rem;
  border: 1px solid var(--color-border); cursor: pointer; align-self: flex-start;
}
.ngf-btn:disabled { opacity: 0.6; cursor: default; }
.ngf-btn--primary { background: var(--color-accent); color: #0d0f0e; border-color: var(--color-accent); }
.ngf-form-msg { color: var(--color-accent-2); margin: 0.25rem 0; }

.ngf-my-review { margin-bottom: 1rem; }
.ngf-reject-note {
  color: var(--color-text-muted); font-size: 0.9rem;
  border: 1px solid var(--color-border); border-radius: 8px; padding: 0.6rem 0.8rem; margin: 0;
}
.ngf-chip {
  font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.02em;
  padding: 0.15rem 0.5rem; border-radius: 999px;
}
.ngf-chip--pending { background: #3a3413; color: #e6cf00; }

.ngf-review-list { display: flex; flex-direction: column; gap: 0.85rem; }
.ngf-review { border-top: 1px solid var(--color-border); padding-top: 0.85rem; }
.ngf-review-head { display: flex; align-items: baseline; gap: 0.6rem; flex-wrap: wrap; }
.ngf-review-date { color: var(--color-text-muted); font-size: 0.82rem; }
.ngf-review-text { margin: 0.3rem 0 0; white-space: pre-wrap; }
.ngf-reviews-empty { color: var(--color-text-muted); }
