/* Final tutorial layer. Loaded after styles.css on purpose. */
body.tutorial-active,
body[data-page="learn"] {
  background: #050505 !important;
}

body.tutorial-story-active .app,
body.tutorial-story-active #pageLearn,
body[data-page="learn"] #pageLearn.tutorial-page {
  background: #050505 !important;
  color: #f5f5f5;
}

body.tutorial-story-active .app {
  width: 100vw !important;
  max-width: none !important;
  padding: 0 !important;
}

.tutorial-page {
  --tutorial-gap: var(--scroll-gap, 16px);
  --tutorial-story-width: min(calc(100vw - var(--tutorial-gap) * 2), 560px);
  position: relative !important;
  width: 100% !important;
  min-height: var(--app-stable-height, 100vh) !important;
  padding: calc(var(--tutorial-gap) * 1.4) 0 calc(var(--tutorial-gap) * 2) !important;
  overflow: hidden !important;
  box-sizing: border-box !important;
  isolation: isolate;
}

.tutorial-spark-canvas {
  position: absolute !important;
  inset: 0 !important;
  z-index: 0 !important;
  width: 100% !important;
  height: 100% !important;
  pointer-events: none !important;
}

.tutorial-view {
  position: relative !important;
  z-index: 1 !important;
  display: none !important;
  width: var(--tutorial-story-width) !important;
  min-height: calc(var(--app-stable-height, 100vh) - var(--tutorial-gap) * 4) !important;
  margin: 0 auto !important;
  box-sizing: border-box !important;
  opacity: 0 !important;
  transition: opacity 520ms ease !important;
}

.tutorial-view.active {
  display: grid !important;
  opacity: 1 !important;
}

.tutorial-view.is-fading {
  opacity: 0 !important;
  pointer-events: none !important;
}

.tutorial-view.is-preparing {
  opacity: 0 !important;
  pointer-events: none !important;
  visibility: hidden !important;
  transition: none !important;
}

.tutorial-lore-view.is-staging .tutorial-lore-image,
.tutorial-lore-view.is-staging .tutorial-lore-text,
.tutorial-lore-view.is-staging .tutorial-lore-button {
  opacity: 0 !important;
  pointer-events: none !important;
  transition: none !important;
}

.tutorial-lore-view.is-changing .tutorial-lore-button {
  pointer-events: none !important;
}

.tutorial-intro-view,
.tutorial-lore-view,
.tutorial-modes-view {
  align-content: center !important;
  justify-items: center !important;
  gap: calc(var(--tutorial-gap) * 1.45) !important;
}

.tutorial-intro-view,
.tutorial-lore-view {
  grid-template-columns: minmax(0, 1fr) !important;
  grid-template-rows: auto auto auto !important;
  justify-content: stretch !important;
}

#tutorialIntroView .tutorial-intro-image,
#tutorialLoreView .tutorial-lore-image {
  width: 100% !important;
  max-width: 100% !important;
  justify-self: stretch !important;
}

.tutorial-image-slot {
  width: 100% !important;
  aspect-ratio: 1 / 1 !important;
  border: var(--game-line-width, 1px) solid rgba(255, 255, 255, 0.5) !important;
  background: rgba(255, 255, 255, 0.06) !important;
  display: grid !important;
  place-items: center !important;
  box-sizing: border-box !important;
  opacity: 0.88 !important;
  contain: layout paint !important;
}

.tutorial-image-slot::before {
  content: attr(data-image-label);
  color: rgba(255, 255, 255, 0.48) !important;
  font: 400 clamp(18px, 4vw, 28px)/1.2 var(--font-vcr, monospace) !important;
  text-shadow: none !important;
}

.tutorial-image-slot::after {
  content: none !important;
  display: none !important;
}

.tutorial-lore-image,
.tutorial-lore-text,
.tutorial-lore-button {
  opacity: 0 !important;
  pointer-events: none !important;
  transition: opacity 1040ms ease !important;
}

.tutorial-lore-image {
  transition-duration: 720ms !important;
}

.tutorial-lore-image.visible,
.tutorial-lore-text.visible,
.tutorial-lore-button.visible {
  opacity: 1 !important;
}

.tutorial-lore-button.visible {
  pointer-events: auto !important;
}

.tutorial-pixel-text {
  width: 100% !important;
  margin: 0 !important;
  color: #f7f7f7 !important;
  text-align: center !important;
  font: 400 clamp(18px, 4.2vw, 28px)/1.48 var(--font-vcr, monospace) !important;
  letter-spacing: 0.02em !important;
  text-shadow: 0 2px 0 rgba(0, 0, 0, 0.8) !important;
  box-sizing: border-box !important;
}

.tutorial-intro-text {
  display: grid !important;
  gap: 0.62em !important;
}

.tutorial-text-line {
  display: block !important;
  opacity: 0 !important;
}

.tutorial-text-line.visible {
  opacity: 1 !important;
  transition: opacity 1040ms ease !important;
}

.tutorial-lore-text {
  min-height: 3.8em !important;
  display: grid !important;
  place-items: center !important;
}

.tutorial-actions,
.tutorial-intro-actions {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: calc(var(--tutorial-gap) * 1.1) !important;
  width: min(100%, 440px) !important;
  justify-self: center !important;
}

.tutorial-intro-actions {
  width: min(100%, 380px) !important;
}

.tutorial-action-button {
  min-height: clamp(48px, 6.5vh, 64px) !important;
  width: 100% !important;
  border: var(--game-line-width, 1px) solid rgba(255, 255, 255, 0.55) !important;
  background: rgba(255, 255, 255, 0.045) !important;
  color: #f5f5f5 !important;
  font: 400 clamp(13px, 3vw, 18px)/1.2 var(--font-vcr, monospace) !important;
  letter-spacing: 0.02em !important;
  text-transform: none !important;
  text-shadow: 0 2px 0 rgba(0, 0, 0, 0.8) !important;
  display: grid !important;
  place-items: center !important;
  padding: calc(var(--tutorial-gap) * 0.7) !important;
  box-sizing: border-box !important;
  cursor: pointer !important;
  touch-action: manipulation !important;
  user-select: none !important;
  -webkit-user-select: none !important;
  pointer-events: auto !important;
  opacity: 0 !important;
  transition: opacity 840ms ease, background 160ms ease, border-color 160ms ease !important;
}

.tutorial-action-button:not(.visible),
.tutorial-lore-button:not(.visible),
.tutorial-finish-button:not(.visible),
.tutorial-interface-next:not(.visible) {
  pointer-events: none !important;
}

.tutorial-action-button.visible,
.tutorial-lore-button.visible,
.tutorial-finish-button.visible,
.tutorial-interface-next.visible {
  opacity: 1 !important;
  pointer-events: auto !important;
}

.tutorial-action-button:active {
  background: rgba(255, 255, 255, 0.14) !important;
  border-color: rgba(255, 255, 255, 0.82) !important;
}

.tutorial-close-button,
.tutorial-engine-close-button {
  position: absolute !important;
  top: var(--tutorial-gap, 16px) !important;
  right: var(--tutorial-gap, 16px) !important;
  z-index: 80 !important;
  width: clamp(32px, 7vw, 44px) !important;
  height: clamp(32px, 7vw, 44px) !important;
  display: grid !important;
  place-items: center !important;
  border: var(--game-line-width, 1px) solid rgba(255, 255, 255, 0.7) !important;
  background: rgba(18, 28, 42, 0.35) !important;
  padding: 0 !important;
  box-sizing: border-box !important;
  touch-action: manipulation !important;
  pointer-events: auto !important;
}

.tutorial-close-button.hidden,
.tutorial-engine-close-button.hidden {
  display: none !important;
}

body.tutorial-runtime-active.tutorial-mechanics-active .tutorial-engine-close-button {
  display: grid !important;
  visibility: visible !important;
  opacity: 1 !important;
  pointer-events: auto !important;
  z-index: 120 !important;
  width: clamp(28px, 6vw, 36px) !important;
  height: clamp(28px, 6vw, 36px) !important;
}

body.tutorial-runtime-active.tutorial-mechanics-active .tutorial-engine-close-button::before,
body.tutorial-runtime-active.tutorial-mechanics-active .tutorial-engine-close-button::after {
  left: 50% !important;
  top: 50% !important;
  width: 62% !important;
  height: 12% !important;
  transform-origin: center !important;
}

body.tutorial-runtime-active.tutorial-mechanics-active .tutorial-engine-close-button::before {
  transform: translate(-50%, -50%) rotate(45deg) !important;
}

body.tutorial-runtime-active.tutorial-mechanics-active .tutorial-engine-close-button::after {
  transform: translate(-50%, -50%) rotate(-45deg) !important;
}

.tutorial-close-button::before,
.tutorial-close-button::after,
.tutorial-engine-close-button::before,
.tutorial-engine-close-button::after {
  content: "" !important;
  position: absolute !important;
  left: 19% !important;
  top: calc(50% - 2px) !important;
  width: 62% !important;
  height: 4px !important;
  background: #fff !important;
  box-shadow: 0 2px 0 rgba(0, 0, 0, 0.65) !important;
  transform-origin: center !important;
}

.tutorial-close-button::before,
.tutorial-engine-close-button::before {
  transform: rotate(45deg) !important;
}

.tutorial-close-button::after,
.tutorial-engine-close-button::after {
  transform: rotate(-45deg) !important;
}

.tutorial-modes-card {
  width: 100% !important;
  display: grid !important;
  gap: calc(var(--tutorial-gap) * 0.9) !important;
  border: var(--game-line-width, 1px) solid rgba(255, 255, 255, 0.48) !important;
  background: rgba(255, 255, 255, 0.045) !important;
  padding: calc(var(--tutorial-gap) * 1.2) !important;
  box-sizing: border-box !important;
}

.tutorial-modes-card p {
  margin: 0 !important;
  font: 400 clamp(14px, 3.3vw, 19px)/1.45 var(--font-vcr, monospace) !important;
  text-shadow: 0 2px 0 rgba(0, 0, 0, 0.75) !important;
}

.tutorial-exit-dialog {
  position: fixed !important;
  inset: 0 !important;
  z-index: 160 !important;
  display: grid !important;
  place-items: center !important;
  padding: calc(var(--tutorial-gap, 16px) * 2) !important;
  background: rgba(0, 0, 0, 0.5) !important;
  backdrop-filter: blur(8px) !important;
  box-sizing: border-box !important;
}

.tutorial-exit-dialog.hidden,
.tutorial-engine-dialog.hidden {
  display: none !important;
}

.tutorial-exit-dialog-card {
  width: min(calc(100vw - var(--tutorial-gap, 16px) * 4), 520px) !important;
  display: grid !important;
  gap: calc(var(--tutorial-gap, 16px) * 1.2) !important;
  border: var(--game-line-width, 1px) solid rgba(255, 255, 255, 0.65) !important;
  background: rgba(58, 91, 137, 0.82) !important;
  padding: calc(var(--tutorial-gap, 16px) * 1.6) !important;
  box-sizing: border-box !important;
}

.tutorial-exit-dialog-card p {
  margin: 0 !important;
  color: #fff !important;
  text-align: center !important;
  font: 400 clamp(16px, 3.8vw, 23px)/1.25 var(--font-vcr, monospace) !important;
  text-shadow: 0 2px 0 rgba(0, 0, 0, 0.8) !important;
}

.tutorial-exit-dialog-actions {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: calc(var(--tutorial-gap, 16px) * 1.1) !important;
}

body.tutorial-runtime-active.tutorial-mechanics-active .status-panel,
body.tutorial-runtime-active.tutorial-mechanics-active .game-meta,
body.tutorial-runtime-active.tutorial-mechanics-active .game-divider:not(.skill-divider) {
  opacity: 0 !important;
  pointer-events: none !important;
}

body.tutorial-runtime-active.tutorial-mechanics-active .game-top-plate {
  position: relative !important;
  min-height: 0 !important;
  opacity: 1 !important;
  transition:
    opacity 410ms cubic-bezier(0.22, 0.72, 0.2, 1),
    filter 410ms cubic-bezier(0.22, 0.72, 0.2, 1) !important;
  transition-delay: 30ms !important;
}

body.tutorial-runtime-active.tutorial-mechanics-active .game-top-plate > :not(.tutorial-engine-text):not(.tutorial-engine-close-button) {
  opacity: 0 !important;
  pointer-events: none !important;
}

.tutorial-engine-text {
  position: absolute !important;
  inset: 8px !important;
  z-index: 50 !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  align-content: center !important;
  align-items: stretch !important;
  justify-content: stretch !important;
  overflow: hidden !important;
  padding: 7px 8px !important;
  border: 0 !important;
  background: transparent !important;
  color: #fff !important;
  text-align: left !important;
  font: 400 clamp(12px, 2.45vw, 16px)/1.22 var(--font-vcr, monospace) !important;
  letter-spacing: 0.01em !important;
  text-shadow: none !important;
  -webkit-text-stroke: 1px rgba(0, 0, 0, 0.88) !important;
  paint-order: stroke fill !important;
  box-sizing: border-box !important;
  transform: none !important;
  transition: opacity 380ms cubic-bezier(0.22, 0.72, 0.2, 1) !important;
  transition-delay: 45ms !important;
  pointer-events: none !important;
  opacity: 0 !important;
}

.tutorial-engine-text.visible {
  opacity: 1 !important;
  transform: none !important;
}

.tutorial-engine-text.tutorial-text-fresh {
  animation: tutorialTextFade 420ms ease both;
}

@keyframes tutorialTextFade {
  from { opacity: 0; }
  to { opacity: 1; }
}

body.tutorial-runtime-active.tutorial-mechanics-active .game-board-plate,
body.tutorial-runtime-active.tutorial-mechanics-active .game-skills-plate {
  transition:
    opacity 410ms cubic-bezier(0.22, 0.72, 0.2, 1),
    filter 410ms cubic-bezier(0.22, 0.72, 0.2, 1) !important;
}

body.tutorial-runtime-active.tutorial-mechanics-active .game-board-plate {
  transition-delay: 70ms !important;
}

body.tutorial-runtime-active.tutorial-mechanics-active .game-skills-plate {
  transition-delay: 105ms !important;
}

body.tutorial-runtime-active.tutorial-engine-transitioning .game-top-plate {
  opacity: 0 !important;
  pointer-events: none !important;
  transition-delay: 0ms !important;
}

body.tutorial-runtime-active.tutorial-engine-transitioning .tutorial-engine-text {
  transition-delay: 0ms !important;
}

body.tutorial-runtime-active.tutorial-engine-transitioning .game-board-plate {
  transition-delay: 35ms !important;
}

body.tutorial-runtime-active.tutorial-engine-transitioning .game-skills-plate {
  transition-delay: 65ms !important;
}

body.tutorial-runtime-active.tutorial-engine-transitioning .game-board-plate,
body.tutorial-runtime-active.tutorial-engine-transitioning .game-skills-plate,
body.tutorial-runtime-active.tutorial-engine-transitioning .tutorial-engine-text {
  opacity: 0 !important;
  pointer-events: none !important;
}

body.tutorial-runtime-active.tutorial-mechanics-active .game-skills-plate {
  position: relative !important;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.10), rgba(255, 255, 255, 0.035)) !important;
}

body.tutorial-runtime-active.tutorial-mechanics-active .skill-button {
  filter: blur(7px) saturate(0.55) !important;
  opacity: 0.23 !important;
  pointer-events: none !important;
  transition: filter 220ms ease, opacity 220ms ease, border-color 220ms ease, background 220ms ease !important;
}

body.tutorial-runtime-active.tutorial-mechanics-active .skill-button.tutorial-skill-focus,
body.tutorial-runtime-active.tutorial-mechanics-active .skill-button.tutorial-engine-skill-focus {
  filter: none !important;
  opacity: 1 !important;
  pointer-events: auto !important;
  border-color: rgba(255, 228, 68, 0.95) !important;
  background: rgba(255, 228, 68, 0.12) !important;
  z-index: 30 !important;
}

body.tutorial-runtime-active.tutorial-mechanics-active .skill-button.tutorial-skill-armed {
  box-shadow: 0 0 0 2px rgba(255, 228, 68, 0.55), 0 0 18px rgba(255, 228, 68, 0.3) !important;
}

.tutorial-engine-skill-gate {
  position: absolute !important;
  inset: 0 !important;
  z-index: 24 !important;
  background: rgba(255, 255, 255, 0.045) !important;
  -webkit-backdrop-filter: blur(18px) saturate(145%) brightness(0.92) !important;
  backdrop-filter: blur(18px) saturate(145%) brightness(0.92) !important;
  pointer-events: none !important;
}

.tutorial-engine-skill-gate.is-hidden {
  display: none !important;
}

.tutorial-engine-interface-card {
  position: fixed !important;
  left: 50% !important;
  top: 50% !important;
  z-index: 120 !important;
  width: min(calc(100vw - var(--scroll-gap, 16px) * 4), 520px) !important;
  max-height: calc(var(--app-stable-height, 100vh) - var(--scroll-gap, 16px) * 4) !important;
  overflow: auto !important;
  transform: translate(-50%, -50%) !important;
  border: var(--game-line-width, 1px) solid rgba(255, 255, 255, 0.62) !important;
  background: rgba(48, 80, 122, 0.86) !important;
  backdrop-filter: blur(10px) !important;
  padding: calc(var(--scroll-gap, 16px) * 1.2) !important;
  display: grid !important;
  gap: calc(var(--scroll-gap, 16px) * 0.85) !important;
  box-sizing: border-box !important;
}

.tutorial-engine-interface-card.is-hidden {
  display: none !important;
}

.tutorial-engine-interface-card h2,
.tutorial-engine-interface-card p {
  margin: 0 !important;
  color: #fff !important;
  font-family: var(--font-vcr, monospace) !important;
  text-shadow: 0 2px 0 rgba(0, 0, 0, 0.76) !important;
}

.tutorial-engine-interface-card h2 {
  text-align: center !important;
  font-size: clamp(18px, 4.2vw, 26px) !important;
  line-height: 1.2 !important;
}

.tutorial-engine-interface-card p {
  font-size: clamp(12px, 3vw, 16px) !important;
  line-height: 1.45 !important;
}

@media (max-width: 640px) {
  .tutorial-page {
    --tutorial-story-width: min(calc(100vw - var(--tutorial-gap) * 2), 460px);
  }

  .tutorial-actions,
  .tutorial-exit-dialog-actions {
    grid-template-columns: 1fr !important;
    width: min(100%, 360px) !important;
  }

  .tutorial-intro-actions {
    grid-template-columns: 1fr !important;
    width: min(100%, 320px) !important;
  }

  .tutorial-action-button {
    min-height: 52px !important;
  }

  .tutorial-engine-text {
    font-size: clamp(11px, 3.05vw, 15px) !important;
    line-height: 1.22 !important;
  }
}

.tutorial-demo-canvas {
  position: absolute !important;
  inset: 0 !important;
  z-index: 9999 !important;
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  pointer-events: none !important;
  image-rendering: pixelated !important;
  mix-blend-mode: normal !important;
}

/* Final tutorial mechanics cascade guard: stronger than the legacy tutorial blocks in styles.css. */
body.tutorial-runtime-active.tutorial-mechanics-active #pageGame .game-top-plate #tutorialEngineText.tutorial-engine-text {
  inset: 8px !important;
  z-index: 90 !important;
  max-height: calc(100% - 16px) !important;
  padding: 10px 12px !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  align-content: center !important;
  align-items: stretch !important;
  justify-content: stretch !important;
  font: 400 clamp(13px, 3.35vw, 19px)/1.22 var(--font-vcr, monospace) !important;
  text-shadow: none !important;
  -webkit-text-stroke: 1px rgba(0, 0, 0, 0.92) !important;
  paint-order: stroke fill !important;
  overflow: hidden !important;
}

body.tutorial-runtime-active.tutorial-mechanics-active #pageGame .game-top-plate #tutorialEngineText.tutorial-engine-text.visible {
  pointer-events: auto !important;
}

body.tutorial-runtime-active.tutorial-mechanics-active #pageGame .game-top-plate #tutorialEngineText .tutorial-engine-text-reserve,
body.tutorial-runtime-active.tutorial-mechanics-active #pageGame .game-top-plate #tutorialEngineText .tutorial-engine-text-visible {
  grid-area: 1 / 1 !important;
  display: block !important;
  width: 100% !important;
  min-width: 0 !important;
  align-self: stretch !important;
  justify-self: stretch !important;
  white-space: pre-wrap !important;
  overflow-wrap: anywhere !important;
}

body.tutorial-runtime-active.tutorial-mechanics-active #pageGame .game-top-plate #tutorialEngineText .tutorial-engine-text-reserve {
  visibility: hidden !important;
  pointer-events: none !important;
}

body.tutorial-runtime-active.tutorial-mechanics-active #pageGame .game-top-plate #tutorialEngineText .tutorial-engine-text-visible {
  pointer-events: none !important;
}

body.tutorial-runtime-active.tutorial-mechanics-active #pageGame .game-top-plate {
  overflow: visible !important;
}

body.tutorial-runtime-active.tutorial-mechanics-active #pageGame .game-top-plate,
body.tutorial-runtime-active.tutorial-mechanics-active #pageGame .game-board-plate,
body.tutorial-runtime-active.tutorial-mechanics-active #pageGame .game-skills-plate,
body.tutorial-runtime-active.tutorial-mechanics-active #pageGame .game-top-plate #tutorialEngineText.tutorial-engine-text {
  transition-duration: 620ms !important;
  transition-timing-function: cubic-bezier(0.22, 0.72, 0.2, 1) !important;
}

body.tutorial-runtime-active.tutorial-engine-transitioning #pageGame .game-top-plate,
body.tutorial-runtime-active.tutorial-engine-transitioning #pageGame .game-board-plate,
body.tutorial-runtime-active.tutorial-engine-transitioning #pageGame .game-skills-plate,
body.tutorial-runtime-active.tutorial-engine-transitioning #pageGame .game-top-plate #tutorialEngineText.tutorial-engine-text {
  transition-duration: 620ms !important;
}

body.tutorial-runtime-active.tutorial-mechanics-active #pageGame .game-top-plate #tutorialEngineText.tutorial-engine-text.visible {
  opacity: 1 !important;
}

body.tutorial-runtime-active.tutorial-mechanics-active #pageGame .game-top-plate #tutorialEngineCloseButton.tutorial-engine-close-button {
  --tutorial-close-size: clamp(28px, 6vw, 36px);
  top: calc((var(--tutorial-close-size) + var(--scroll-gap, 12px)) * -1) !important;
  right: 0 !important;
  width: var(--tutorial-close-size) !important;
  height: var(--tutorial-close-size) !important;
  z-index: 130 !important;
  opacity: 0.10 !important;
  background: rgba(0, 0, 0, 0.10) !important;
  border-color: rgba(255, 255, 255, 0.42) !important;
  box-shadow: none !important;
}

body.tutorial-runtime-active.tutorial-mechanics-active #pageGame .game-top-plate #tutorialEngineCloseButton.tutorial-engine-close-button::before,
body.tutorial-runtime-active.tutorial-mechanics-active #pageGame .game-top-plate #tutorialEngineCloseButton.tutorial-engine-close-button::after {
  left: 50% !important;
  top: 50% !important;
  width: 58% !important;
  height: 12% !important;
  background: rgba(255, 255, 255, 0.92) !important;
  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.45) !important;
  transform-origin: center !important;
}

body.tutorial-runtime-active.tutorial-mechanics-active #pageGame .game-top-plate #tutorialEngineCloseButton.tutorial-engine-close-button::before {
  transform: translate(-50%, -50%) rotate(45deg) !important;
}

body.tutorial-runtime-active.tutorial-mechanics-active #pageGame .game-top-plate #tutorialEngineCloseButton.tutorial-engine-close-button::after {
  transform: translate(-50%, -50%) rotate(-45deg) !important;
}

body.tutorial-runtime-active.tutorial-mechanics-active #pageGame .board-shell {
  position: relative !important;
}

@media (max-width: 640px) {
  body.tutorial-runtime-active.tutorial-mechanics-active #pageGame .game-top-plate #tutorialEngineText.tutorial-engine-text {
    font: 400 clamp(13px, 3.6vw, 18px)/1.22 var(--font-vcr, monospace) !important;
    padding: 10px 11px !important;
  }
}

/* Final tutorial story button guard. Legacy menu-button rules used to keep these at opacity: 0. */
body.tutorial-story-active #pageLearn .tutorial-action-button.visible,
body.tutorial-story-active #pageLearn .tutorial-lore-button.visible,
body.tutorial-story-active #pageLearn #tutorialLoreNextButton.visible,
body.tutorial-story-active #pageLearn .tutorial-finish-button.visible {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
}

/* Production lore tutorial. Fullscreen image story, independent from the old placeholder layout. */
body.tutorial-story-active #pageLearn.tutorial-page[data-tutorial-mode="lore"] {
  --lore-viewport-w: 100vw;
  --lore-viewport-h: var(--app-stable-height, 100vh);
  --lore-edge-gap: clamp(20px, 5.2vw, 32px);
  --lore-side-gap: var(--lore-edge-gap);
  --lore-bottom-gap: calc(var(--lore-edge-gap) + env(safe-area-inset-bottom, 0px));
  --lore-button-h: clamp(54px, 7vh, 70px);
  --lore-copy-h: 34%;
  position: fixed !important;
  inset: 0 !important;
  z-index: 35 !important;
  width: var(--lore-viewport-w) !important;
  max-width: none !important;
  min-height: var(--lore-viewport-h) !important;
  height: var(--lore-viewport-h) !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
  background: #000 !important;
}

body.tutorial-story-active #pageLearn.tutorial-page[data-tutorial-mode="lore"] #tutorialSparkCanvas {
  display: none !important;
}

body.tutorial-story-active #pageLearn.tutorial-page[data-tutorial-mode="lore"] .tutorial-lore-view {
  position: absolute !important;
  inset: 0 !important;
  z-index: 1 !important;
  width: 100% !important;
  min-height: var(--lore-viewport-h) !important;
  height: var(--lore-viewport-h) !important;
  margin: 0 !important;
  display: none !important;
  opacity: 0 !important;
  transition: opacity 520ms ease !important;
}

body.tutorial-story-active #pageLearn.tutorial-page[data-tutorial-mode="lore"] .tutorial-lore-view.active {
  display: block !important;
  opacity: 1 !important;
}

body.tutorial-story-active #pageLearn.tutorial-page[data-tutorial-mode="lore"] .tutorial-lore-view.is-preparing {
  visibility: visible !important;
  opacity: 1 !important;
  pointer-events: auto !important;
  transition: none !important;
}

body.tutorial-story-active #pageLearn.tutorial-page[data-tutorial-mode="lore"] .tutorial-lore-stage {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: var(--lore-viewport-h) !important;
  overflow: hidden !important;
  background: #000 !important;
  contain: layout paint style !important;
}

body.tutorial-story-active #pageLearn.tutorial-page[data-tutorial-mode="lore"] .tutorial-lore-bg {
  position: absolute !important;
  inset: 0 !important;
  z-index: 1 !important;
  width: 100% !important;
  height: 100% !important;
  min-width: 100% !important;
  min-height: 100% !important;
  max-width: none !important;
  max-height: none !important;
  transform: none !important;
  object-fit: cover !important;
  object-position: center center !important;
  opacity: 0 !important;
  transition-property: opacity !important;
  transition-timing-function: ease !important;
  transition-duration: 2500ms;
  will-change: opacity;
  pointer-events: none !important;
  user-select: none !important;
  -webkit-user-drag: none !important;
}

body.tutorial-story-active #pageLearn.tutorial-page[data-tutorial-mode="lore"] .tutorial-lore-bg.is-visible {
  opacity: 1 !important;
}

body.tutorial-story-active #pageLearn.tutorial-page[data-tutorial-mode="lore"] .tutorial-lore-bottom-gradient {
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  z-index: 3 !important;
  height: var(--lore-copy-h) !important;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.96) 0%, rgba(0, 0, 0, 0.82) 42%, rgba(0, 0, 0, 0) 100%) !important;
  pointer-events: none !important;
}

body.tutorial-story-active #pageLearn.tutorial-page[data-tutorial-mode="lore"] .tutorial-lore-copy {
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  z-index: 4 !important;
  min-height: var(--lore-copy-h) !important;
  padding: clamp(18px, 3.5vh, 28px) var(--lore-side-gap) var(--lore-bottom-gap) !important;
  display: grid !important;
  grid-template-rows: minmax(0, 1fr) auto !important;
  gap: clamp(12px, 2.4vh, 20px) !important;
  box-sizing: border-box !important;
  pointer-events: none !important;
}

body.tutorial-story-active #pageLearn.tutorial-page[data-tutorial-mode="lore"] .tutorial-lore-text {
  width: 100% !important;
  min-height: 0 !important;
  align-self: center !important;
  justify-self: stretch !important;
  display: block !important;
  place-items: normal !important;
  margin: 0 !important;
  color: #fff !important;
  text-align: left !important;
  font: 400 clamp(16px, 3.75vw, 22px)/1.22 var(--font-vcr, monospace) !important;
  letter-spacing: 0 !important;
  text-shadow:
    -1px 0 #000,
    1px 0 #000,
    0 -1px #000,
    0 1px #000,
    0 2px 0 rgba(0, 0, 0, 0.85) !important;
  opacity: 1 !important;
  pointer-events: none !important;
  transition: none !important;
  box-sizing: border-box !important;
}

body.tutorial-story-active #pageLearn.tutorial-page[data-tutorial-mode="lore"] .tutorial-lore-word {
  opacity: 0;
  transition: opacity 220ms linear;
}

body.tutorial-story-active #pageLearn.tutorial-page[data-tutorial-mode="lore"] .tutorial-lore-word.is-visible {
  opacity: 1;
}

body.tutorial-story-active #pageLearn.tutorial-page[data-tutorial-mode="lore"] .tutorial-lore-button {
  position: relative !important;
  z-index: 1 !important;
  width: 100% !important;
  min-height: var(--lore-button-h) !important;
  justify-self: stretch !important;
  align-self: end !important;
  padding: 0 clamp(12px, 3vw, 22px) !important;
  border-color: transparent !important;
  box-shadow: inset 0 0 0 var(--game-line-width, 1px) rgba(255, 255, 255, 0.56) !important;
  background: rgba(0, 0, 0, 0.30) !important;
  background-clip: padding-box !important;
  color: #fff !important;
  font: 400 clamp(13px, 3vw, 18px)/1.16 var(--font-vcr, monospace) !important;
  text-shadow:
    -1px 0 #000,
    1px 0 #000,
    0 -1px #000,
    0 1px #000 !important;
  opacity: 0 !important;
  pointer-events: none !important;
  backface-visibility: hidden !important;
  contain: paint !important;
  transform: translateZ(0) !important;
  will-change: opacity !important;
  transition: opacity 760ms ease, background 160ms ease, box-shadow 160ms ease !important;
}

body.tutorial-story-active #pageLearn.tutorial-page[data-tutorial-mode="lore"] .tutorial-lore-button.is-arrow {
  font-size: clamp(24px, 8vw, 40px) !important;
  line-height: 1 !important;
}

body.tutorial-story-active #pageLearn.tutorial-page[data-tutorial-mode="lore"] .tutorial-lore-button.visible {
  opacity: 1 !important;
  pointer-events: auto !important;
}
