/* WS-E — Public games landing pages. Design System v1. */
:root {
  --gap-1: var(--ln-space-1, 4px);
  --gap-2: var(--ln-space-2, 8px);
  --gap-3: var(--ln-space-3, 12px);
  --gap-4: var(--ln-space-4, 16px);
  --gap-6: var(--ln-space-6, 32px);
}
* { box-sizing: border-box; }
body {
  background: var(--ln-bg-primary, #FAF7F2);
  color: var(--ln-text-primary, #0A0A0A);
  font-family: var(--ln-font-ui, system-ui, sans-serif);
  margin: 0;
  line-height: 1.5;
}
.page-header {
  display: flex; justify-content: space-between; align-items: center;
  padding: var(--gap-3) var(--gap-4);
  border-bottom: 1px solid var(--ln-border, #e5e1d8);
  background: var(--ln-bg-card, #fff);
}
.logo { font-weight: 900; color: var(--ln-mark, #9C8348); text-decoration: none; font-size: 18px; }
.primary-nav { display: flex; gap: var(--gap-4); align-items: center; }
.primary-nav a { color: var(--ln-text-primary); text-decoration: none; font-size: 14px; }
.primary-nav a[aria-current="page"] { font-weight: 700; color: var(--ln-accent, #0A0A0A); }
.cta-secondary { padding: 6px 14px; border: 1px solid var(--ln-accent, #0A0A0A); border-radius: var(--ln-radius-md, 12px); }
.breadcrumbs { padding: var(--gap-3) var(--gap-4); font-size: 13px; color: var(--ln-text-secondary, #6b6657); }
.breadcrumbs a { color: var(--ln-accent, #0A0A0A); text-decoration: none; }
main { max-width: 800px; margin: 0 auto; padding: var(--gap-4); }
.game-landing .hero, .catalog .hero, .category-landing { text-align: center; padding: var(--gap-6) var(--gap-4); }
.hero-icon { font-size: 64px; margin-bottom: var(--gap-3); }
h1 { font-size: clamp(28px, 6vw, 42px); margin: var(--gap-2) 0; color: var(--ln-text-primary); }
h2 { font-size: clamp(22px, 4vw, 28px); margin-top: var(--gap-6); }
.tagline, .subtitle { color: var(--ln-text-secondary, #6b6657); font-size: 17px; max-width: 600px; margin: 0 auto var(--gap-4); }
.meta-chips { display: flex; flex-wrap: wrap; gap: var(--gap-2); justify-content: center; margin: var(--gap-4) 0; }
.chip {
  display: inline-block; padding: 6px 12px; border-radius: var(--ln-radius-full, 9999px);
  background: var(--ln-bg-card, #fff); border: 1px solid var(--ln-border, #e5e1d8);
  font-size: 13px; color: var(--ln-text-secondary, #6b6657);
}
.cta-primary {
  display: inline-block; padding: 14px 32px; min-height: 48px;
  background: var(--ln-accent, #0A0A0A); color: var(--ln-accent-text, #FAF7F2);
  border-radius: var(--ln-radius-lg, 16px); text-decoration: none;
  font-weight: 700; font-size: 16px; margin: var(--gap-3) 0;
  transition: transform 0.1s ease;
}
.cta-primary:hover { transform: translateY(-1px); }
.cta-primary.cta-large { padding: 18px 48px; font-size: 18px; }
.cta-note { color: var(--ln-text-secondary, #6b6657); font-size: 13px; margin-top: var(--gap-2); }
.description, .how-it-works, .related, .cta-bottom { margin: var(--gap-6) 0; }
.skills, .description ol, .how-it-works ol { padding-left: 24px; }
.skills li, .how-it-works li { margin: var(--gap-2) 0; }
.game-card-row, .game-grid {
  display: grid; gap: var(--gap-4);
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  margin-top: var(--gap-4);
}
.game-card, .game-card-mini {
  display: block; padding: var(--gap-4); text-decoration: none;
  background: var(--ln-bg-card, #fff); border: 1px solid var(--ln-border, #e5e1d8);
  border-radius: var(--ln-radius-lg, 16px);
  color: var(--ln-text-primary); transition: transform 0.15s ease, box-shadow 0.15s ease;
  text-align: center;
}
.game-card:hover, .game-card-mini:hover {
  transform: translateY(-2px);
  box-shadow: var(--ln-shadow-md, 0 4px 12px rgba(0,0,0,0.08));
}
.game-card-icon { font-size: 36px; }
.game-card h3, .game-card-name { font-size: 15px; font-weight: 700; margin: var(--gap-2) 0; }
.game-card-ages, .game-card-desc { font-size: 12px; color: var(--ln-text-secondary, #6b6657); margin: 4px 0; }
.cta-bottom { text-align: center; background: var(--ln-bg-card, #fff); padding: var(--gap-6) var(--gap-4); border-radius: var(--ln-radius-lg, 16px); margin-top: var(--gap-6); }
.cat-section { margin: var(--gap-6) 0; }
.cat-section h2 { display: flex; justify-content: space-between; align-items: center; border-bottom: 1px solid var(--ln-border, #e5e1d8); padding-bottom: var(--gap-2); }
.cat-section h2 a { color: var(--ln-text-primary); text-decoration: none; }
.cat-count { font-size: 13px; color: var(--ln-text-secondary, #6b6657); font-weight: normal; }
.page-footer { padding: var(--gap-6) var(--gap-4); text-align: center; border-top: 1px solid var(--ln-border, #e5e1d8); margin-top: var(--gap-6); }
.footer-nav { display: flex; flex-wrap: wrap; gap: var(--gap-4); justify-content: center; margin-bottom: var(--gap-3); }
.footer-nav a { color: var(--ln-text-secondary, #6b6657); text-decoration: none; font-size: 14px; }
.copyright { color: var(--ln-text-secondary, #6b6657); font-size: 12px; }
/* Mobile-first: stack chips, full-width CTA */
@media (max-width: 480px) {
  .primary-nav { gap: var(--gap-2); font-size: 13px; }
  .cta-primary { width: 100%; padding: 16px; }
}
