/* Kids browse components (games landing, hub, dashboard, achievements, placement) */
@import "kids-browse-components.css";

/* Kids game chrome — uses site-design-system.css tokens (load layout first) */

:root {
  --kids-browse-max-width: var(--sw-container, 1120px);
  --kids-radius-lg: var(--sw-radius-lg, 26px);
  --kids-radius-md: var(--sw-radius-md, 18px);
  --kids-shadow-card: var(--sw-shadow);
  --kids-shadow-card-hover: var(--sw-shadow-hover);
  /* Accents for game marketing surfaces */
  --kids-coral: var(--sw-accent-coral);
  --kids-coral-soft: #ff9494;
  --kids-teal: #4ecdc4;
  --kids-teal-deep: #38b2ac;
  --kids-gold: var(--sw-accent-yellow);
  --kids-gold-bright: #ffd700;
  --kids-purple: var(--sw-secondary);
  --kids-green: var(--sw-accent-green);
  --kids-slate: var(--sw-text);
  --kids-slate-mid: var(--sw-text-soft);
  --kids-page-bg: var(--sw-bg);
  --kids-page-bg-2: #f6fbff;
  --kids-text: var(--sw-text);
  --kids-text-muted: var(--sw-text-soft);
  --kids-mint: var(--kids-teal);
  --kids-mint-dark: var(--kids-teal-deep);
  --kids-mint-light: #b2f5ea;
  --kids-navy: var(--sw-text);
  --kids-navy-dark: #1a202c;
}

/* Header (kids-game-page) */
body.kids-game-page .site-header {
  background: var(--sw-surface);
  border-bottom: 1px solid var(--sw-border);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.8);
}

body.kids-game-page .site-logo {
  color: var(--sw-primary) !important;
  background: none !important;
  -webkit-text-fill-color: var(--sw-primary) !important;
  background-clip: unset !important;
  font-size: 1.25rem;
  font-weight: 700;
  font-family: var(--sw-font-display), var(--sw-font-body), sans-serif;
  letter-spacing: 0.02em;
}

body.kids-game-page .site-logo:hover {
  color: var(--sw-primary-hover) !important;
  -webkit-text-fill-color: var(--sw-primary-hover) !important;
}

/* Browse mode */
body.kids-game-browse {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  font-family: var(--sw-font-body), system-ui, sans-serif;
  color: var(--kids-text);
  -webkit-tap-highlight-color: transparent;
}

body.kids-game-browse .title {
  font-family: var(--sw-font-display), var(--sw-font-body), sans-serif;
  letter-spacing: 0.01em;
  color: var(--kids-slate);
}

body.kids-game-browse main {
  flex: 1 0 auto;
  display: block;
  overflow: visible;
  background: linear-gradient(180deg, var(--kids-page-bg) 0%, var(--kids-page-bg-2) 55%, #eef8ff 100%);
  padding: 0;
}

body.kids-game-browse main > .section {
  flex: none;
  overflow: visible;
  padding: 1.25rem 0 2.5rem;
  max-width: 100%;
  background: transparent;
}

body.kids-game-browse main > .section > .container {
  flex: none;
  display: block;
  overflow: visible;
  max-width: var(--kids-browse-max-width) !important;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding-left: 1.25rem;
  padding-right: 1.25rem;
}

body.kids-game-browse .section {
  background: transparent;
}

/* Embedded play — full-viewport flex (legacy / non-standard layout) */
body.kids-game-page:not(.kids-game-browse):not(.kids-game-play) main {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background: transparent !important;
  padding: 0;
}

body.kids-game-page:not(.kids-game-browse):not(.kids-game-play) main > .section {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  padding: 0 !important;
  max-width: 100%;
}

body.kids-game-page:not(.kids-game-browse):not(.kids-game-play) main > .section > .container {
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  padding: 0 !important;
  max-width: 100% !important;
  width: 100% !important;
}

@media (max-width: 768px) {
  body.kids-game-page:not(.kids-game-browse):not(.kids-game-play) {
    height: 100dvh !important;
  }
}

body.kids-game-page:not(.kids-game-browse):not(.kids-game-play) .section .container {
  max-width: 100%;
}

/* Embedded play — same shell as rest of site: scroll, gradient bg, container width */
body.kids-game-page.kids-game-play {
  overflow-x: hidden;
  min-height: 100vh;
  min-height: 100dvh;
}

body.kids-game-page.kids-game-play main {
  flex: none !important;
  min-height: 0 !important;
  display: block !important;
  overflow: visible !important;
  background: transparent !important;
}

body.kids-game-page.kids-game-play main > .section {
  flex: none !important;
  min-height: 0 !important;
  display: block !important;
  overflow: visible !important;
  padding: 1rem 0 2rem !important;
  max-width: 100%;
}

body.kids-game-page.kids-game-play main > .section > .container {
  flex: none !important;
  display: block !important;
  overflow: visible !important;
  padding-left: 1rem !important;
  padding-right: 1rem !important;
  max-width: var(--kids-browse-max-width) !important;
  width: 100% !important;
  margin-left: auto;
  margin-right: auto;
}

body.kids-game-page.kids-game-play #game-wrapper,
body.kids-game-page.kids-game-play .kids-game-wrapper {
  width: 100%;
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}

body.kids-game-page.kids-game-play #game-wrapper {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  margin-bottom: 0.5rem;
}

/* Explicit height so Phaser RESIZE + canvas fill the viewport band (header/footer scroll away) */
body.kids-game-page.kids-game-play #game-container {
  width: 100%;
  min-height: 320px;
  height: min(72vh, 720px);
  max-height: min(85vh, 900px);
}

/* Same chrome as .kids-game-container (spelling / jump) when #game-container carries the class */
body.kids-game-page.kids-game-play #game-container.kids-game-container {
  background: linear-gradient(180deg, #2d3e5c 0%, var(--sw-text) 100%) !important;
  border-radius: var(--kids-radius-lg);
  overflow: hidden;
  box-shadow: var(--kids-shadow-card);
  border: 2px solid rgba(55, 168, 255, 0.35);
}

body.kids-game-page.kids-game-play #game-container.kids-game-container[data-game-theme="woodland"] {
  background: linear-gradient(180deg, #4ecdc4 0%, #38b2ac 55%, #2c7a7b 100%) !important;
  border-color: rgba(255, 255, 255, 0.2);
}

body.kids-game-page.kids-game-play #game-container canvas {
  display: block;
}

/* Nav above canvas: stack on narrow screens, row on desktop */
body.kids-game-page.kids-game-play .kids-game-play-nav {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0.5rem;
  width: 100%;
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}

body.kids-game-page.kids-game-play .kids-game-play-nav .kids-back-link {
  display: inline-block;
  padding: 0.35rem 0;
  text-decoration: none !important;
  font-size: 0.9rem;
}

@media (min-width: 769px) {
  body.kids-game-page.kids-game-play .kids-game-play-nav {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.35rem 1.25rem;
  }
}

body.kids-game-page.kids-game-play .spg-page,
body.kids-game-page.kids-game-play .ka-page {
  width: 100%;
  max-width: 800px;
  margin: 0 auto;
}

.kids-back-link {
  font-family: var(--sw-font-body), sans-serif;
  font-weight: 600;
  color: var(--kids-slate-mid) !important;
  transition: color 0.2s ease, transform 0.2s ease;
}

.kids-back-link:hover {
  color: var(--sw-primary) !important;
}

.kids-game-wrapper {
  max-width: var(--kids-browse-max-width);
  margin: 0 auto;
  padding: 1rem 0;
  width: 100%;
}

@media (min-width: 769px) {
  .kids-game-wrapper {
    padding: 1.25rem 0 1.5rem;
  }
}

body.kids-game-page:not(.kids-game-browse):not(.kids-game-play) .kids-game-wrapper {
  max-width: 640px;
}

@media (min-width: 769px) {
  body.kids-game-page:not(.kids-game-browse):not(.kids-game-play) .kids-game-wrapper {
    max-width: 960px;
  }
}

body.kids-game-page.kids-game-play .kids-game-wrapper {
  max-width: 800px;
  padding-top: 0.25rem;
}

body.kids-game-page .kids-game-container {
  background: linear-gradient(180deg, #2d3e5c 0%, var(--sw-text) 100%) !important;
  border-radius: var(--kids-radius-lg);
  overflow: hidden;
  box-shadow: var(--kids-shadow-card);
  border: 2px solid rgba(55, 168, 255, 0.35);
}

body.kids-game-page .kids-game-container[data-game-theme="woodland"] {
  background: linear-gradient(180deg, #4ecdc4 0%, #38b2ac 55%, #2c7a7b 100%) !important;
  border-color: rgba(255, 255, 255, 0.2);
}

body.kids-game-page .kids-game-loading {
  color: rgba(255, 255, 255, 0.9) !important;
  font-family: var(--sw-font-body), sans-serif;
}

body.kids-game-page .kids-game-container[data-game-theme="woodland"] .kids-game-loading {
  color: var(--sw-text) !important;
}

body.kids-game-browse .button.is-kids-primary {
  background: linear-gradient(135deg, var(--sw-primary), var(--sw-primary-hover));
  border: none;
  color: #fff;
  font-weight: 800;
  border-radius: 999px;
  box-shadow: var(--sw-shadow);
  min-height: 48px;
}

body.kids-game-browse .button.is-kids-primary:hover {
  color: #fff;
  filter: brightness(1.05);
  box-shadow: var(--sw-shadow-hover);
}

body.kids-game-browse .button.is-kids-teal {
  background: linear-gradient(135deg, var(--kids-teal), var(--kids-teal-deep));
  border: none;
  color: #fff;
  font-weight: 800;
  border-radius: 999px;
}

body.kids-game-browse .button.is-kids-teal:hover {
  color: #fff;
  filter: brightness(1.05);
}
