/* ============================================================
   U-DYRECT v2 — stylesheet
   ------------------------------------------------------------
   Same dark cinematic identity, rebuilt around the wizard:
     Upload → Lock → Scene → Add/Remove → Hero → Light+Look → Render.

   - Keeps IBM Plex, the void/panel/cyan palette, the full-bleed Stage,
     PWA insets, the scoped site header.
   - Removes the old "Direction stack" + shot textarea visuals.
   - Adds: stage tracker, lock pill + tap-to-place, reference grids,
     pass plan, render progress.
   ============================================================ */

:root {
  --udy-void:      #070809;
  --udy-panel:     #0e1013;
  --udy-panel-2:   #14171b;
  --udy-panel-3:   #1a1e23;
  --udy-line:      rgba(255,255,255,0.07);
  --udy-line-lit:  rgba(255,255,255,0.16);
  --udy-line-hot:  rgba(45,212,232,0.55);
  --udy-ink:       #f3f5f7;
  --udy-ink-soft:  rgba(243,245,247,0.62);
  --udy-ink-mute:  rgba(243,245,247,0.38);
  --udy-cyan:      #2dd4e8;
  --udy-cyan-deep: rgba(45,212,232,0.14);
  --udy-amber:     #e8a33d;
  --udy-rose:      #e8553d;
  --udy-radius:    14px;
}

* { box-sizing: border-box; margin: 0; padding: 0; -webkit-tap-highlight-color: transparent; }

html, body {
  background: var(--udy-void);
  color: var(--udy-ink);
  font-family: 'IBM Plex Sans', -apple-system, BlinkMacSystemFont, sans-serif;
  font-size: 16px; line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}
body {
  min-height: 100vh; min-height: 100dvh;
  background:
    radial-gradient(120% 60% at 50% -10%, rgba(45,212,232,0.07), transparent 60%),
    var(--udy-void);
  padding-bottom: max(40px, env(safe-area-inset-bottom));
}

/* ===== Scoped site header (unchanged) ===== */
.ord-site-header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 22px;
  padding-top: max(16px, env(safe-area-inset-top));
  background: rgba(7,8,9,0.86);
  backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--udy-line);
}
.ord-site-header__brand { display: flex; align-items: center; gap: 11px; text-decoration: none; }
.ord-site-header__logo { width: 40px; height: auto; display: block; filter: invert(1) brightness(1.4); }
.ord-site-header__wordmark { font-size: 0.86rem; font-weight: 600; letter-spacing: 0.2rem; color: var(--udy-ink); }
.ord-site-header__back {
  font-size: 0.78rem; font-weight: 500; letter-spacing: 0.06rem;
  color: var(--udy-ink-soft); text-decoration: none;
  border: 1px solid var(--udy-line-lit); border-radius: 8px;
  padding: 8px 14px; transition: color .2s, border-color .2s;
}
.ord-site-header__back:hover { color: var(--udy-cyan); border-color: var(--udy-cyan); }
body.has-ord-header { padding-top: 92px; }

/* ===== Layout ===== */
.udy { max-width: 760px; margin: 0 auto; padding: 0 18px; }

/* ===== Intro ===== */
.udy-intro { padding: 26px 0 24px; }
.udy-intro__eyebrow {
  font-family: 'IBM Plex Mono', monospace; font-size: 0.68rem;
  letter-spacing: 0.26rem; text-transform: uppercase; color: var(--udy-cyan);
  margin-bottom: 14px;
}
.udy-intro__title { font-size: 2.85rem; font-weight: 600; letter-spacing: 0.02em; line-height: 1; margin-bottom: 14px; }
.udy-intro__deck { color: var(--udy-ink-soft); font-size: 0.98rem; max-width: 50ch; }
.udy-intro__narrow {
  margin-top: 14px; padding: 12px 14px;
  border: 1px solid var(--udy-line); border-radius: 10px;
  background: var(--udy-panel-2);
  font-size: 0.86rem; color: var(--udy-ink-soft);
  max-width: 56ch;
}
.udy-intro__narrow strong { color: var(--udy-ink); font-weight: 600; }

.udy-status {
  display: inline-flex; align-items: center; gap: 9px;
  margin-top: 18px; padding: 8px 14px;
  background: var(--udy-panel-2); border: 1px solid var(--udy-line);
  border-radius: 999px;
  font-family: 'IBM Plex Mono', monospace; font-size: 0.72rem;
  color: var(--udy-ink-soft);
}
.udy-status__dot { width: 7px; height: 7px; border-radius: 50%; background: var(--udy-amber); box-shadow: 0 0 9px var(--udy-amber); }

/* ===== Panels (shared chrome) ===== */
.udy-panel {
  background: var(--udy-panel); border: 1px solid var(--udy-line);
  border-radius: var(--udy-radius); padding: 22px 20px; margin-bottom: 14px;
}
.udy-panel__head { margin-bottom: 16px; }
.udy-panel__num { font-family: 'IBM Plex Mono', monospace; font-size: 0.7rem; color: var(--udy-cyan); letter-spacing: 0.1rem; }
.udy-panel__title { font-size: 1.28rem; font-weight: 600; margin: 4px 0 5px; }
.udy-panel__hint { font-size: 0.86rem; color: var(--udy-ink-mute); }
.udy-note { font-size: 0.78rem; color: var(--udy-ink-mute); margin-top: 10px; }

/* ===== Drop zone (unchanged from v1) ===== */
.udy-drop {
  border: 1.5px dashed var(--udy-line-lit); border-radius: var(--udy-radius);
  background: var(--udy-panel-2); padding: 38px 20px; text-align: center;
  cursor: pointer; transition: border-color .2s, background .2s;
}
.udy-drop:hover, .udy-drop:focus-visible, .udy-drop.is-drag {
  border-color: var(--udy-cyan); background: var(--udy-cyan-deep); outline: none;
}
.udy-drop__icon { font-size: 2rem; color: var(--udy-cyan); margin-bottom: 10px; }
.udy-drop__primary { font-weight: 500; margin-bottom: 5px; }
.udy-drop__secondary { font-size: 0.8rem; color: var(--udy-ink-mute); }
.udy-drop.is-loaded { border-style: solid; border-color: var(--udy-cyan); }

/* ===== Stage (full-bleed, unchanged) ===== */
.udy-stage {
  position: relative; width: 100%;
  background: repeating-linear-gradient(45deg, #0c0e10 0 10px, #0a0c0e 10px 20px);
  border-top: 1px solid var(--udy-line); border-bottom: 1px solid var(--udy-line);
  overflow: hidden; display: flex; align-items: center; justify-content: center;
}
.udy-stage--bleed { aspect-ratio: 9 / 16; max-height: 88vh; }
.udy-stage__empty { text-align: center; color: var(--udy-ink-mute); padding: 20px; }
.udy-stage__empty-icon { font-size: 2.4rem; margin-bottom: 8px; color: var(--udy-line-lit); }
.udy-stage__empty p { font-size: 0.84rem; }
.udy-stage__canvas, .udy-stage__video, .udy-stage__result {
  position: absolute; inset: 0; width: 100%; height: 100%;
  display: block; object-fit: cover;
}
/* Lock marker shown on the Stage when a target is locked */
.udy-stage__lock-pin {
  position: absolute; z-index: 5;
  width: 28px; height: 28px; border-radius: 50%;
  background: rgba(7,8,9,0.65); border: 2px solid var(--udy-cyan);
  display: flex; align-items: center; justify-content: center;
  color: var(--udy-cyan); font-size: 0.78rem;
  transform: translate(-50%, -50%);
  pointer-events: none;
  box-shadow: 0 0 0 4px rgba(45,212,232,0.12), 0 0 18px rgba(45,212,232,0.4);
}

/* ===== Link / reset buttons (unchanged) ===== */
.udy-link-btn {
  background: transparent; border: none; padding: 8px 0 0;
  color: var(--udy-ink-soft); font-family: 'IBM Plex Mono', monospace;
  font-size: 0.74rem; letter-spacing: 0.04rem; cursor: pointer;
  text-decoration: underline; text-underline-offset: 3px;
  transition: color .15s;
}
.udy-link-btn:hover { color: var(--udy-cyan); }
.udy-link-btn--inline { margin-top: 8px; display: inline-block; }

.udy-reset {
  display: block; margin-top: 14px;
  background: transparent; border: 1px solid var(--udy-line-lit);
  border-radius: 8px; padding: 9px 16px; cursor: pointer;
  color: var(--udy-ink-soft); font-family: 'IBM Plex Mono', monospace;
  font-size: 0.72rem; letter-spacing: 0.08rem; text-transform: uppercase;
  transition: border-color .2s, color .2s;
}
.udy-reset:hover { border-color: var(--udy-cyan); color: var(--udy-cyan); }

/* ===== Auth gate (unchanged) ===== */
.udy-gate { text-align: center; padding: 40px 24px; }
.udy-gate__eyebrow {
  font-family: 'IBM Plex Mono', monospace; font-size: 0.68rem;
  letter-spacing: 0.26rem; text-transform: uppercase; color: var(--udy-cyan);
  margin-bottom: 14px;
}
.udy-gate__title { font-size: 1.6rem; font-weight: 600; margin-bottom: 10px; }
.udy-gate__deck { color: var(--udy-ink-soft); font-size: 0.92rem; margin: 0 auto 22px; max-width: 38ch; }
.udy-gate .udy-render { max-width: 280px; margin: 0 auto; }

/* ===== Lock — the tentpole ===== */
.udy-lock { /* lives inside its own panel */ }
.udy-lock__q { font-size: 0.96rem; color: var(--udy-ink); margin-bottom: 14px; }
.udy-lock__choices {
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px;
}
.udy-lock__choice {
  background: var(--udy-panel-2); border: 1px solid var(--udy-line-lit);
  border-radius: 10px; padding: 14px 12px; cursor: pointer;
  font-family: inherit; text-align: left;
  transition: border-color .2s, background .2s;
}
.udy-lock__choice:hover { border-color: var(--udy-cyan); background: var(--udy-cyan-deep); }
.udy-lock__choice-name { display: block; font-weight: 600; font-size: 0.9rem; color: var(--udy-ink); }
.udy-lock__choice-desc { display: block; font-size: 0.74rem; color: var(--udy-ink-mute); margin-top: 3px; }
.udy-lock__skip {
  margin-top: 10px;
  background: transparent; border: 1px solid var(--udy-line);
  border-radius: 8px; padding: 10px 14px; cursor: pointer;
  color: var(--udy-ink-mute); font-family: 'IBM Plex Mono', monospace;
  font-size: 0.72rem; letter-spacing: 0.06rem;
  width: 100%; transition: color .2s, border-color .2s;
}
.udy-lock__skip:hover { color: var(--udy-ink-soft); border-color: var(--udy-line-lit); }

/* Tap-to-place frame (used by Lock target picker + Add element placement) */
.udy-tapframe {
  position: relative; width: 100%;
  aspect-ratio: 9 / 16;
  background: var(--udy-panel-2);
  border: 1px solid var(--udy-line-lit); border-radius: 12px;
  overflow: hidden; cursor: crosshair;
  margin-top: 14px;
}
.udy-tapframe__img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.udy-tapframe__pin {
  position: absolute; width: 32px; height: 32px; border-radius: 50%;
  background: rgba(7,8,9,0.65); border: 2px solid var(--udy-cyan);
  transform: translate(-50%, -50%); pointer-events: none;
  display: flex; align-items: center; justify-content: center;
  color: var(--udy-cyan); font-size: 0.78rem; font-weight: 600;
  box-shadow: 0 0 0 4px rgba(45,212,232,0.12), 0 0 18px rgba(45,212,232,0.4);
}
.udy-tapframe__hint {
  position: absolute; left: 50%; bottom: 12px; transform: translateX(-50%);
  background: rgba(7,8,9,0.78); border: 1px solid var(--udy-line);
  border-radius: 999px; padding: 6px 12px;
  font-family: 'IBM Plex Mono', monospace; font-size: 0.7rem;
  color: var(--udy-ink-soft); pointer-events: none;
}

/* Lock summary pill — persistent once lock is set */
.udy-lock-pill {
  display: inline-flex; align-items: center; gap: 8px;
  margin-top: 14px; padding: 8px 12px;
  background: var(--udy-cyan-deep); border: 1px solid var(--udy-line-hot);
  border-radius: 999px;
  font-family: 'IBM Plex Mono', monospace; font-size: 0.74rem;
  color: var(--udy-cyan);
}
.udy-lock-pill__glyph { font-size: 0.9rem; }
.udy-lock-pill__remove {
  background: transparent; border: none; color: var(--udy-cyan);
  cursor: pointer; padding: 0 0 0 4px; font-size: 1rem; line-height: 1;
  opacity: 0.7; transition: opacity .15s;
}
.udy-lock-pill__remove:hover { opacity: 1; }

/* ===== Wizard stages ===== */
.udy-wiz__tracker {
  display: flex; gap: 6px; margin-bottom: 14px; flex-wrap: wrap;
}
.udy-wiz__step {
  flex: 1; min-width: 110px;
  padding: 9px 11px;
  background: var(--udy-panel-2);
  border: 1px solid var(--udy-line);
  border-radius: 8px;
  font-family: 'IBM Plex Mono', monospace; font-size: 0.7rem;
  letter-spacing: 0.06rem;
  color: var(--udy-ink-mute);
  display: flex; align-items: center; gap: 7px;
  transition: border-color .2s, color .2s;
}
.udy-wiz__step.is-active { border-color: var(--udy-cyan); color: var(--udy-cyan); background: var(--udy-cyan-deep); }
.udy-wiz__step.is-done { color: var(--udy-ink-soft); border-color: var(--udy-line-lit); }
.udy-wiz__step.is-done .udy-wiz__step-mark { color: var(--udy-cyan); }
.udy-wiz__step-mark {
  display: inline-block; width: 14px; text-align: center;
  font-size: 0.74rem;
}

.udy-stage-card { /* one stage of the wizard */ }
.udy-stage-card__q { font-size: 1rem; color: var(--udy-ink); margin-bottom: 14px; line-height: 1.4; }
.udy-stage-card__yn {
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 10px;
}
.udy-yn-btn {
  background: var(--udy-panel-2); border: 1px solid var(--udy-line-lit);
  border-radius: 10px; padding: 14px; cursor: pointer;
  font-family: inherit; text-align: center;
  transition: border-color .2s, background .2s, color .2s;
}
.udy-yn-btn__name { display: block; font-weight: 600; font-size: 0.96rem; color: var(--udy-ink); }
.udy-yn-btn__desc { display: block; font-size: 0.74rem; color: var(--udy-ink-mute); margin-top: 4px; }
.udy-yn-btn:hover { border-color: var(--udy-cyan); background: var(--udy-cyan-deep); }
.udy-yn-btn.is-selected { border-color: var(--udy-cyan); background: var(--udy-cyan-deep); }
.udy-yn-btn.is-selected .udy-yn-btn__name { color: var(--udy-cyan); }

.udy-stage-card__body { margin-top: 16px; padding-top: 16px; border-top: 1px solid var(--udy-line); }
.udy-stage-card__sub-q { font-size: 0.88rem; color: var(--udy-ink-soft); margin-bottom: 10px; }

/* Stage navigation row */
.udy-stage-nav {
  display: flex; gap: 8px; margin-top: 16px;
}
.udy-stage-nav__back, .udy-stage-nav__next {
  flex: 1; padding: 12px; border-radius: 10px;
  font-family: inherit; font-weight: 500; font-size: 0.88rem;
  cursor: pointer; transition: border-color .2s, color .2s, background .2s, opacity .2s;
}
.udy-stage-nav__back {
  background: transparent; border: 1px solid var(--udy-line-lit);
  color: var(--udy-ink-soft);
}
.udy-stage-nav__back:hover { border-color: var(--udy-cyan); color: var(--udy-cyan); }
.udy-stage-nav__next {
  background: var(--udy-panel-2); border: 1px solid var(--udy-line-hot);
  color: var(--udy-cyan);
}
.udy-stage-nav__next:hover:not(:disabled) { background: var(--udy-cyan-deep); }
.udy-stage-nav__next:disabled { opacity: 0.45; cursor: not-allowed; }

/* Collapsed completed stage summary */
.udy-stage-summary {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 14px; margin-bottom: 10px;
  background: var(--udy-panel); border: 1px solid var(--udy-line);
  border-radius: 10px; cursor: pointer;
  transition: border-color .2s;
}
.udy-stage-summary:hover { border-color: var(--udy-line-lit); }
.udy-stage-summary__num { font-family: 'IBM Plex Mono', monospace; font-size: 0.68rem; color: var(--udy-cyan); letter-spacing: 0.08rem; min-width: 24px; }
.udy-stage-summary__name { font-weight: 600; font-size: 0.92rem; color: var(--udy-ink); }
.udy-stage-summary__value { flex: 1; font-size: 0.82rem; color: var(--udy-ink-soft); margin-left: 10px; }
.udy-stage-summary__edit {
  font-family: 'IBM Plex Mono', monospace; font-size: 0.68rem;
  color: var(--udy-ink-mute); letter-spacing: 0.06rem;
}

/* ===== Reference grids ===== */
.udy-refgrid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px;
  margin-top: 8px;
}
@media (min-width: 540px) { .udy-refgrid { grid-template-columns: 1fr 1fr 1fr; } }
.udy-ref {
  position: relative; aspect-ratio: 4 / 5;
  background: var(--udy-panel-3);
  border: 1px solid var(--udy-line-lit);
  border-radius: 10px; cursor: pointer; overflow: hidden;
  transition: border-color .2s, transform .12s;
}
.udy-ref:hover { border-color: var(--udy-cyan); }
.udy-ref:active { transform: scale(0.98); }
.udy-ref.is-selected { border-color: var(--udy-cyan); box-shadow: 0 0 0 1px var(--udy-cyan); }
.udy-ref__thumb {
  position: absolute; inset: 0;
  /* Placeholder treatment until real thumbs ship.
     A subtle moody gradient hints at the vibe. */
  background:
    radial-gradient(80% 60% at 50% 30%, rgba(45,212,232,0.06), transparent 70%),
    linear-gradient(180deg, rgba(255,255,255,0.02), rgba(0,0,0,0.4)),
    var(--udy-panel-3);
}
.udy-ref__label {
  position: absolute; left: 8px; right: 8px; bottom: 8px;
  font-size: 0.74rem; color: var(--udy-ink);
  background: linear-gradient(180deg, transparent, rgba(7,8,9,0.85));
  padding: 18px 6px 4px;
  border-radius: 0 0 8px 8px;
  line-height: 1.3;
}
.udy-ref.is-selected .udy-ref__label { color: var(--udy-cyan); }

/* Free-text escape hatch under a grid */
.udy-freetext {
  width: 100%; margin-top: 10px;
  background: var(--udy-void); color: var(--udy-ink);
  border: 1px solid var(--udy-line-lit); border-radius: 10px;
  padding: 11px 13px; font-family: inherit; font-size: 0.86rem;
}
.udy-freetext:focus { outline: none; border-color: var(--udy-cyan); }
.udy-freetext-label {
  display: block; font-size: 0.76rem; color: var(--udy-ink-mute);
  margin-top: 14px; margin-bottom: 4px;
}

/* Hero (subject) mode picker */
.udy-modepick {
  display: flex; flex-direction: column; gap: 8px; margin-top: 8px;
}
.udy-modepick__btn {
  background: var(--udy-panel-2); border: 1px solid var(--udy-line-lit);
  border-radius: 10px; padding: 13px 14px; cursor: pointer;
  font-family: inherit; text-align: left;
  transition: border-color .2s, background .2s;
}
.udy-modepick__btn:hover { border-color: var(--udy-cyan); background: var(--udy-cyan-deep); }
.udy-modepick__btn.is-selected { border-color: var(--udy-cyan); background: var(--udy-cyan-deep); }
.udy-modepick__name { display: block; font-weight: 600; font-size: 0.92rem; color: var(--udy-ink); }
.udy-modepick__desc { display: block; font-size: 0.76rem; color: var(--udy-ink-mute); margin-top: 3px; }

/* Material chip set (used inside Hero / Material mode) */
.udy-chipset { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px; }
.udy-chip {
  background: var(--udy-void); border: 1px solid var(--udy-line-lit);
  border-radius: 7px; padding: 8px 12px; cursor: pointer;
  color: var(--udy-ink-soft); font-size: 0.8rem; font-family: inherit;
  transition: border-color .15s, color .15s, background .15s;
}
.udy-chip.is-on { border-color: var(--udy-cyan); color: var(--udy-cyan); background: var(--udy-cyan-deep); }

/* Add/Remove dual section */
.udy-dual { display: flex; flex-direction: column; gap: 18px; }
.udy-dual__section { padding-top: 14px; border-top: 1px dashed var(--udy-line); }
.udy-dual__section:first-child { padding-top: 0; border-top: none; }
.udy-dual__toggle { display: flex; align-items: center; gap: 10px; }
.udy-dual__toggle-label { flex: 1; font-weight: 600; font-size: 0.92rem; color: var(--udy-ink); }

/* ===== Pass plan (shown before render) ===== */
.udy-plan { padding: 18px 16px; background: var(--udy-panel-2); border: 1px solid var(--udy-line-lit); border-radius: 12px; margin-bottom: 14px; }
.udy-plan__title {
  font-family: 'IBM Plex Mono', monospace; font-size: 0.7rem;
  letter-spacing: 0.14rem; text-transform: uppercase;
  color: var(--udy-cyan); margin-bottom: 12px;
}
.udy-plan__list { list-style: none; display: flex; flex-direction: column; gap: 8px; }
.udy-plan__item {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 12px;
  background: var(--udy-panel); border: 1px solid var(--udy-line);
  border-radius: 8px;
  font-size: 0.86rem;
}
.udy-plan__num {
  font-family: 'IBM Plex Mono', monospace; font-size: 0.7rem;
  color: var(--udy-cyan); min-width: 24px;
}
.udy-plan__label { flex: 1; color: var(--udy-ink); }
.udy-plan__status {
  font-family: 'IBM Plex Mono', monospace; font-size: 0.66rem;
  letter-spacing: 0.08rem; text-transform: uppercase;
  color: var(--udy-ink-mute);
  min-width: 80px; text-align: right;
}
.udy-plan__item.is-running { border-color: var(--udy-line-hot); background: var(--udy-cyan-deep); }
.udy-plan__item.is-running .udy-plan__status { color: var(--udy-cyan); }
.udy-plan__item.is-succeeded .udy-plan__status { color: var(--udy-cyan); }
.udy-plan__item.is-failed { border-color: rgba(232,85,61,0.5); }
.udy-plan__item.is-failed .udy-plan__status { color: var(--udy-rose); }
.udy-plan__time {
  font-family: 'IBM Plex Mono', monospace; font-size: 0.7rem;
  color: var(--udy-ink-mute); margin-top: 10px; text-align: right;
}

/* ===== Render ===== */
.udy-render {
  width: 100%; padding: 15px; border-radius: 11px; border: none;
  background: var(--udy-cyan); color: var(--udy-void);
  font-family: inherit; font-weight: 600; font-size: 0.96rem; cursor: pointer;
  transition: opacity .2s, transform .1s;
}
.udy-render:hover:not(:disabled) { transform: translateY(-1px); }
.udy-render:disabled { background: var(--udy-panel-2); color: var(--udy-ink-mute); cursor: not-allowed; }
.udy-render__note {
  text-align: center; font-family: 'IBM Plex Mono', monospace;
  font-size: 0.68rem; color: var(--udy-ink-mute); margin-top: 10px;
}

/* Tweak controls (post-render) */
.udy-tweak {
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-top: 14px;
}
.udy-tweak__btn {
  background: var(--udy-panel-2); border: 1px solid var(--udy-line-lit);
  border-radius: 10px; padding: 12px; cursor: pointer;
  font-family: inherit; font-size: 0.86rem; color: var(--udy-ink-soft);
  transition: border-color .2s, color .2s, background .2s;
}
.udy-tweak__btn:hover { border-color: var(--udy-cyan); color: var(--udy-cyan); background: var(--udy-cyan-deep); }

/* ===== Footer ===== */
.udy-foot {
  display: flex; justify-content: space-between;
  padding: 26px 4px 10px; margin-top: 8px;
  border-top: 1px solid var(--udy-line);
  font-family: 'IBM Plex Mono', monospace; font-size: 0.68rem;
  color: var(--udy-ink-mute); letter-spacing: 0.06rem;
}

/* ===== Image-source simplified path ===== */
.udy-image-simple textarea {
  width: 100%; min-height: 110px;
  background: var(--udy-void); color: var(--udy-ink);
  border: 1px solid var(--udy-line-lit); border-radius: 10px;
  padding: 12px; font-family: inherit; font-size: 0.9rem;
}
.udy-image-simple textarea:focus { outline: none; border-color: var(--udy-cyan); }

/* ===== Responsive ===== */
@media (min-width: 680px) {
  .udy-intro__title { font-size: 3.6rem; }
  .udy-panel { padding: 26px 24px; }
}
@media (max-width: 440px) {
  .udy-wiz__step { min-width: 88px; font-size: 0.66rem; }
  .udy-lock__choices { grid-template-columns: 1fr; }
  .udy-tweak { grid-template-columns: 1fr; }
}
