.game {
  position: relative;
  display: flex;
  flex-direction: column;
  width: 100%;
  height: 100%;
  background: var(--app-color-bg);
  overflow: hidden;
}

.game--intro {
  position: relative;
  width: 100%;
  height: 100%;
}

.game-intro__skip {
  position: absolute;
  bottom: var(--app-spacing-lg);
  right: var(--app-spacing-md);
  z-index: var(--app-z-sticky);
  background: rgba(255, 255, 255, 0.92);
}

.game__stage {
  flex: 1 1 auto;
  position: relative;
  display: flex;
  flex-direction: column;
  padding-top: calc(var(--app-touch-target) + env(safe-area-inset-top, 0) + var(--app-spacing-md));
  padding-left: var(--app-spacing-md);
  padding-right: var(--app-spacing-md);
  padding-bottom: calc(var(--app-spacing-md) + env(safe-area-inset-bottom, 0));
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  gap: var(--app-spacing-md);
}

.game__modal-slot { position: relative; z-index: var(--app-z-modal); }

.puzzle-card {
  background: var(--app-color-surface);
  border: 1px solid var(--app-color-border);
  border-radius: var(--app-radius-md);
  box-shadow: var(--app-shadow-sm);
  padding: var(--app-spacing-lg);
  display: flex;
  flex-direction: column;
  gap: var(--app-spacing-md);
  animation: app-slide-up var(--app-transition-base);
}

.puzzle-card__type {
  display: inline-block;
  align-self: flex-start;
  background: var(--app-color-primary);
  color: var(--app-color-text-inverse);
  padding: 4px var(--app-spacing-sm);
  border-radius: var(--app-radius-full);
  font-size: var(--app-font-size-xs);
  font-weight: 700;
  letter-spacing: 0.5px;
  text-transform: uppercase;
}

.puzzle-card__prompt {
  margin: 0;
  font-size: var(--app-font-size-lg);
  line-height: var(--app-line-height-relaxed);
  color: var(--app-color-text);
}

.puzzle-card__hint {
  margin: 0;
  font-size: var(--app-font-size-sm);
  color: var(--app-color-text-muted);
  font-style: italic;
}

.puzzle-card__actions {
  display: flex;
  flex-direction: column;
  gap: var(--app-spacing-sm);
  margin-top: auto;
}

.puzzle-marker {
  position: absolute;
  inset: 0;
  background: #000;
}

.puzzle-marker__prompt {
  position: absolute;
  bottom: calc(var(--app-spacing-xl) + 60px);
  left: var(--app-spacing-md);
  right: var(--app-spacing-md);
  background: rgba(0, 0, 0, 0.65);
  color: #fff;
  padding: var(--app-spacing-md);
  border-radius: var(--app-radius-md);
  font-size: var(--app-font-size-sm);
  text-align: center;
  backdrop-filter: blur(4px);
  z-index: var(--app-z-sticky);
}

.puzzle-marker__fallback {
  position: absolute;
  bottom: calc(var(--app-spacing-xl) + 120px);
  left: 50%;
  transform: translateX(-50%);
  background: rgba(255, 255, 255, 0.95);
  padding: var(--app-spacing-md);
  border-radius: var(--app-radius-md);
  display: flex;
  flex-direction: column;
  gap: var(--app-spacing-sm);
  align-items: center;
  text-align: center;
  z-index: var(--app-z-sticky);
}

.puzzle-marker__fallback p { margin: 0; font-size: var(--app-font-size-sm); }
