/* ASCII pane integration scoped to the hero canvas container. */
.ascii-pane {
  --ascii-pane-width: clamp(320px, 85vw, 960px);
  --ascii-viewport-height: var(--viewport-height, 100vh);
  --ascii-frame-width: 100%;
  --ascii-frame-height: 100%;
  --ascii-font-size: 7px;
  --ascii-scale: 1;
  --ascii-frame-shift-x: 0px;
  --ascii-frame-shift-y: 0px;
  pointer-events: none;
  z-index: 0;
}

.ascii-pane .ascii-column {
  position: absolute;
  inset: 0;
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  pointer-events: none;
}

.ascii-pane .ascii-wrapper {
  position: relative;
  display: flex;
  flex-direction: column;
  width: 100%;
  max-width: 100%;
  height: var(--ascii-viewport-height);
  max-height: var(--ascii-viewport-height);
  overflow: hidden;
  background: var(--ascii-pane-background, var(--lightColor));
  contain: layout paint;
}

.ascii-pane[data-ascii-mode="split"] .ascii-wrapper {
  width: 100%;
  max-width: 100%;
}

.ascii-pane .ascii-stage {
  position: relative;
  flex: 1 1 auto;
  min-height: 0;
  height: 100%;
  display: block;
  background: var(--ascii-pane-background, var(--lightColor));
  color: inherit;
  transform: translateZ(0);
}

.ascii-pane .ascii-bitmap-stage {
  position: absolute;
  inset: 0;
  width: var(--ascii-frame-width, 100%);
  height: var(--ascii-frame-height, 100%);
  transform: translate3d(var(--ascii-frame-shift-x, 0px), var(--ascii-frame-shift-y, 0px), 0)
    scale(var(--ascii-scale, 1));
  transform-origin: top left;
  display: none;
  z-index: 2;
  pointer-events: none;
  background: inherit;
  contain: strict;
}

.ascii-pane .ascii-bitmap-stage[data-active="true"] {
  display: block;
}

.ascii-pane .ascii-bitmap-canvas,
.ascii-pane .ascii-bitmap-image {
  display: block;
  width: 100%;
  height: 100%;
  image-rendering: pixelated;
  image-rendering: crisp-edges;
  pointer-events: none;
}

.ascii-pane .ascii-bitmap-image {
  object-fit: contain;
}

.ascii-pane .ascii-frame {
  margin: 0;
  width: var(--ascii-frame-width, 100%);
  font-family: "IBM Plex Mono", "SFMono", ui-monospace, Menlo, Monaco, Consolas, "Courier New", monospace;
  font-size: var(--ascii-font-size, 7px);
  line-height: 1;
  letter-spacing: 0;
  white-space: pre;
  transform: translate3d(var(--ascii-frame-shift-x, 0px), var(--ascii-frame-shift-y, 0px), 0)
    scale(var(--ascii-scale, 1));
  transform-origin: top left;
  will-change: transform;
  backface-visibility: hidden;
}

.ascii-pane .ascii-frame {
  position: relative;
  z-index: 1;
  color: var(--ascii-pane-foreground, var(--darkColor));
  overflow: hidden;
}

@supports (-webkit-touch-callout: none) {
  @media (min-resolution: 160dpi) {
    .ascii-pane .ascii-frame {
      -webkit-font-smoothing: antialiased;
    }
  }
}

.ascii-pane[data-ascii-mode="split"] .ascii-column {
  justify-content: flex-end;
}

@media (min-width: 1024px) {
  .ascii-pane:not([data-ascii-mode="split"]) .ascii-wrapper {
    width: min(var(--ascii-pane-width), 100%);
    max-width: min(var(--ascii-pane-width), 100%);
  }
}

html.wide-ascii .ascii-pane .ascii-wrapper {
  width: 100%;
  max-width: 100%;
}

html.wide-ascii .ascii-frame{
  color: #8B5011;
}
