:root {
  --omni-bg: #03070a;
  --omni-bg-2: #050b10;
  --omni-panel: #071119;
  --omni-panel-2: #0b1822;
  --omni-panel-3: #0e1f2b;
  --omni-border: rgba(96, 219, 255, .25);
  --omni-border-strong: rgba(96, 219, 255, .48);
  --omni-cyan: #22d7ff;
  --omni-cyan-soft: #69e7ff;
  --omni-blue: #238cff;
  --omni-violet: #7b4dff;
  --omni-rose: #e65bc1;
  --omni-amber: #f4b84a;
  --omni-text: #eef7ff;
  --omni-muted: #8ea3b5;
  --omni-dim: #526879;
  --omni-danger: #ff6b8a;
  --font-display: "Arial Narrow", "Avenir Next Condensed", sans-serif;
  --font-body: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* { box-sizing: border-box; }
[hidden] { display: none !important; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--omni-text);
  background:
    radial-gradient(circle at 75% -10%, rgba(35, 140, 255, .13), transparent 28rem),
    radial-gradient(circle at 2% 36%, rgba(123, 77, 255, .08), transparent 25rem),
    var(--omni-bg);
  font: 13px/1.45 var(--font-body);
  min-width: 320px;
}
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: .16;
  background-image: linear-gradient(rgba(34, 215, 255, .045) 1px, transparent 1px), linear-gradient(90deg, rgba(34, 215, 255, .045) 1px, transparent 1px);
  background-size: 42px 42px;
  mask-image: linear-gradient(to bottom, #000, transparent 75%);
}

button, input, textarea, select { font: inherit; }
button, select { cursor: pointer; }
button:focus-visible, input:focus-visible, textarea:focus-visible, select:focus-visible, summary:focus-visible { outline: 2px solid var(--omni-cyan); outline-offset: 2px; }
img { max-width: 100%; }

.app-shell { width: min(1920px, 100%); margin: 0 auto; padding: 12px; position: relative; }
.panel, .hero {
  background: linear-gradient(135deg, rgba(8, 19, 28, .96), rgba(3, 9, 14, .97));
  border: 1px solid var(--omni-border);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.025), 0 18px 60px rgba(0,0,0,.2);
}

.hero {
  min-height: 128px;
  display: grid;
  grid-template-columns: minmax(280px, .9fr) minmax(300px, 1fr) auto;
  align-items: center;
  gap: 22px;
  padding: 14px 18px;
  border-radius: 8px 8px 0 0;
  overflow: hidden;
  position: relative;
}
.hero::after { content:""; position:absolute; inset:auto 0 0; height:1px; background:linear-gradient(90deg, transparent, var(--omni-cyan), var(--omni-violet), transparent); opacity:.55; }
.brand-lockup { height: 98px; min-width: 0; display:flex; align-items:center; overflow:hidden; }
.brand-logo { width: 100%; max-width: 450px; height: 100%; object-fit: cover; object-position: center; mix-blend-mode: screen; }
.hero-copy { min-width: 0; padding-left: 22px; border-left: 1px solid var(--omni-border); }
.hero-copy p { margin: 0; color: var(--omni-muted); max-width: 600px; }
.hero-copy .eyebrow { margin-bottom: 8px; color: var(--omni-text); font: 600 20px/1.1 var(--font-display); letter-spacing: .1em; text-transform: uppercase; }
.hero-actions { display: flex; gap: 8px; justify-content: flex-end; flex-wrap: wrap; }

.button {
  min-height: 42px;
  border: 1px solid rgba(142, 163, 181, .34);
  border-radius: 4px;
  background: rgba(5, 12, 18, .88);
  color: var(--omni-text);
  padding: 0 15px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  font: 600 13px/1 var(--font-display);
  letter-spacing: .06em;
  text-transform: uppercase;
  transition: border-color .2s, transform .2s, background .2s, box-shadow .2s;
}
.button:hover { border-color: var(--omni-cyan); background: rgba(14, 31, 43, .9); transform: translateY(-1px); }
.button img { width: 17px; height: 17px; }
.button.primary { color: #00151c; background: linear-gradient(135deg, var(--omni-cyan), #1597ef); border-color: var(--omni-cyan-soft); box-shadow: 0 0 22px rgba(34, 215, 255, .14); }
.button.primary:hover { background: linear-gradient(135deg, #77ebff, #2eaeff); }
.button.violet { background: linear-gradient(135deg, #3a1590, #5820b4); border-color: rgba(165, 122, 255, .65); }

.mobile-tabs { display: none; }
.workspace { display: grid; grid-template-columns: minmax(390px, .68fr) minmax(650px, 1.32fr); gap: 10px; margin-top: 10px; }
.compiler, .output { min-width: 0; border-radius: 6px; overflow: hidden; }
.section-heading { display:flex; align-items:center; gap:10px; padding: 11px 14px; border-bottom: 1px solid rgba(96,219,255,.12); min-height: 59px; }
.section-heading h1, .section-heading h2, .action-title h2 { margin:0; color: var(--omni-cyan); font: 600 18px/1.1 var(--font-display); letter-spacing:.07em; text-transform:uppercase; }
.section-heading p, .action-title p { margin:3px 0 0; color: var(--omni-dim); font-size:11px; }
.heading-icon { width:27px; height:27px; display:grid; place-items:center; border:1px solid var(--omni-border); border-radius:50%; }
.heading-icon img { width:16px; height:16px; }
.sticky-heading { position:relative; z-index:2; background:rgba(5,13,19,.95); }
.output-heading .status-pill { margin-left:auto; }
.status-pill { color:var(--omni-muted); border:1px solid var(--omni-border); border-radius:999px; padding:5px 9px; font:600 10px var(--font-display); text-transform:uppercase; letter-spacing:.1em; }
.status-pill span { display:inline-block; width:6px; height:6px; margin-right:5px; border-radius:50%; background:var(--omni-cyan); box-shadow:0 0 9px var(--omni-cyan); }

.compiler { height: 664px; }
.compiler-scroll { height: calc(100% - 59px); overflow:auto; scrollbar-width:thin; scrollbar-color: var(--omni-border-strong) transparent; padding: 8px; }
.editor-section { border:1px solid rgba(96,219,255,.13); background:rgba(4,11,17,.66); margin-bottom:7px; border-radius:4px; overflow:hidden; }
.editor-section > summary { list-style:none; display:flex; align-items:center; gap:9px; color:var(--omni-cyan-soft); padding:10px 11px; cursor:pointer; font:600 13px/1 var(--font-display); text-transform:uppercase; letter-spacing:.08em; }
.editor-section > summary::-webkit-details-marker { display:none; }
.editor-section > summary::after { content:"+"; margin-left:auto; color:var(--omni-dim); font-size:17px; }
.editor-section[open] > summary::after { content:"−"; }
.editor-section > summary span { color:var(--omni-dim); font-size:10px; }
.editor-section > summary em { color:var(--omni-dim); font-style:normal; font-size:10px; }
.editor-section > :not(summary) { margin-left:10px; margin-right:10px; }
.editor-section > :last-child { margin-bottom:11px; }
.field-grid { display:grid; gap:8px; }
.field-grid.two-col, .two-col { display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.span-two { grid-column:1 / -1; }
label { display:flex; flex-direction:column; gap:4px; color:var(--omni-muted); font-size:10px; }
input, textarea, select {
  width:100%; color:var(--omni-text); background:#061019; border:1px solid rgba(96,219,255,.18); border-radius:4px; padding:8px 9px; min-height:34px; font-size:11px; transition:border-color .18s, background .18s;
}
textarea { resize:vertical; line-height:1.45; }
input:hover, textarea:hover, select:hover, input:focus, textarea:focus, select:focus { border-color:var(--omni-border-strong); background:#081722; }
select { appearance:auto; }
.microcopy { color:var(--omni-dim); font-size:9px; margin-top:6px; }
.preset-warning { color:var(--omni-amber); display:flex; align-items:center; gap:7px; font-size:10px; padding:8px; border:1px solid rgba(244,184,74,.25); background:rgba(244,184,74,.05); }
.preset-warning img { width:15px; }

.reference-editor { display:grid; grid-template-columns:1fr 1fr; gap:7px; }
.reference-card { min-width:0; display:grid; grid-template-columns:58px 1fr; gap:8px; align-items:center; padding:6px; border:1px solid rgba(96,219,255,.15); background:#061019; border-radius:4px; }
.reference-card .ref-thumb { width:58px; height:46px; border:1px dashed var(--omni-border); background:linear-gradient(135deg,#071822,#0b0d1e); display:grid; place-items:center; overflow:hidden; }
.reference-card .ref-thumb img { width:100%; height:100%; object-fit:cover; }
.reference-card .ref-thumb span { color:var(--omni-dim); font:700 16px var(--font-display); }
.reference-card strong { display:block; font:600 11px var(--font-display); color:var(--omni-text); text-transform:uppercase; letter-spacing:.03em; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ref-actions { display:flex; gap:5px; margin-top:5px; }
.mini-button { color:var(--omni-cyan); background:transparent; border:1px solid var(--omni-border); border-radius:3px; padding:4px 6px; font:600 9px var(--font-display); text-transform:uppercase; }
.mini-button.danger { color:var(--omni-muted); }
.file-input { display:none; }

.beat-editor { display:grid; gap:5px; }
.beat-row { display:grid; grid-template-columns:28px 72px 1fr 1fr 24px; gap:5px; align-items:center; }
.beat-row .beat-number { color:var(--omni-amber); text-align:center; font:700 16px var(--font-display); }
.beat-row input { padding:6px; min-height:30px; }
.icon-button { width:24px; height:28px; border:0; color:var(--omni-dim); background:transparent; padding:0; font-size:16px; }
.icon-button:hover { color:var(--omni-danger); }
.text-button { color:var(--omni-cyan); background:transparent; border:1px solid var(--omni-border); border-radius:3px; padding:7px 10px; font:600 10px var(--font-display); text-transform:uppercase; margin-top:7px; }
.palette { display:flex; gap:7px; }
.palette input[type="color"] { width:30px; height:27px; min-height:0; padding:2px; border-radius:3px; }

.output { min-height:664px; display:flex; flex-direction:column; }
.board-stage { flex:1; padding:10px; display:flex; align-items:flex-start; justify-content:center; min-height:0; background:radial-gradient(circle at 50% 35%, rgba(35,140,255,.07), transparent 52%); }
.output-board {
  width:100%; aspect-ratio:16 / 9; min-width:0; overflow:hidden; container-type:inline-size;
  display:grid; grid-template-rows: 10.5% 16.5% 11.5% 13% 1fr 5.5%; gap:.75cqw; padding:1cqw;
  color:#f1f8ff; background:linear-gradient(145deg,#07131d,#02070b 72%); border:1px solid rgba(121,212,255,.48); box-shadow:0 0 0 1px rgba(0,0,0,.9), 0 22px 55px rgba(0,0,0,.38); font-family:var(--font-body);
}
.output-board h3 { margin:0 0 .45cqw; color:var(--omni-cyan); font:600 1.15cqw/1 var(--font-display); letter-spacing:.09em; text-transform:uppercase; }
.output-board p { margin:0; color:#dceaf5; font-size:1.05cqw; line-height:1.35; overflow:hidden; }
.board-header { display:grid; grid-template-columns:24% 1fr auto; align-items:center; gap:1cqw; min-width:0; overflow:hidden; border-bottom:1px solid rgba(96,219,255,.2); }
.board-header > img { width:100%; height:78%; object-fit:cover; object-position:center; mix-blend-mode:screen; }
.board-title { min-width:0; padding-left:1cqw; border-left:1px solid var(--omni-border); }
.board-title strong { display:block; font:600 1.55cqw/1 var(--font-display); letter-spacing:.08em; text-transform:uppercase; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.board-title span { display:block; margin-top:.35cqw; color:var(--omni-muted); font:500 .75cqw/1 var(--font-display); letter-spacing:.1em; text-transform:uppercase; }
.board-header-note { color:#dceaf5; font:600 .86cqw var(--font-display); letter-spacing:.08em; text-transform:uppercase; text-align:right; }
.board-summary-row, .board-lock-row { display:grid; grid-template-columns:1fr 1fr 1.18fr; gap:.75cqw; min-height:0; }
.board-summary-row section, .board-lock-row section { min-width:0; padding:.8cqw; border:1px solid rgba(96,219,255,.22); background:rgba(6,16,25,.82); overflow:hidden; }
.prompt-panel { border-color:rgba(123,77,255,.5) !important; background:linear-gradient(135deg,rgba(41,17,91,.45),rgba(6,16,25,.85)) !important; }
.prompt-panel h3 { color:#b69aff; }
.prompt-panel p { font-size:.92cqw; }
.hard-no { border-color:rgba(244,184,74,.3) !important; }
.hard-no h3 { color:var(--omni-amber); }
.board-lock-row p { font-size:.92cqw; }
.board-reference-row { display:grid; grid-template-columns:repeat(4,1fr); gap:.75cqw; min-height:0; }
.board-ref { position:relative; min-width:0; overflow:hidden; border:1px solid rgba(96,219,255,.2); background:linear-gradient(135deg,#0a1d29,#11112b); }
.board-ref::after { content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 35%,rgba(1,5,8,.92)); pointer-events:none; }
.board-ref img { width:100%; height:100%; object-fit:cover; display:block; }
.board-ref .ref-placeholder { position:absolute; inset:0; display:grid; place-items:center; color:rgba(105,231,255,.22); font:700 3.2cqw var(--font-display); }
.board-ref strong { position:absolute; left:.65cqw; right:.65cqw; bottom:.5cqw; z-index:1; color:var(--omni-cyan-soft); font:600 .78cqw var(--font-display); letter-spacing:.08em; text-transform:uppercase; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.storyboard-section { min-height:0; display:flex; flex-direction:column; }
.storyboard-heading { display:flex; justify-content:space-between; align-items:center; height:2cqw; }
.storyboard-heading h3 { margin:0; }
.storyboard-heading span { color:var(--omni-dim); font:500 .72cqw var(--font-display); letter-spacing:.07em; text-transform:uppercase; }
.storyboard-grid { flex:1; min-height:0; display:grid; grid-template-columns:repeat(3,1fr); grid-template-rows:repeat(2,1fr); gap:.65cqw; }
.storyboard-grid.layout-3 { grid-template-columns:repeat(3,1fr); grid-template-rows:1fr; }
.storyboard-grid.layout-4 { grid-template-columns:repeat(4,1fr); grid-template-rows:1fr; }
.storyboard-grid.layout-8 { grid-template-columns:repeat(4,1fr); grid-template-rows:repeat(2,1fr); }
.story-card { position:relative; min-width:0; overflow:hidden; padding:.65cqw; border:1px solid rgba(96,219,255,.3); background:linear-gradient(145deg,rgba(12,33,46,.92),rgba(4,11,17,.94)); }
.story-card.has-image::after { content:""; position:absolute; inset:0; background:linear-gradient(90deg,rgba(2,7,11,.95),rgba(2,7,11,.55) 60%,rgba(2,7,11,.18)); }
.story-card .story-bg { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:.62; }
.story-card > :not(.story-bg) { position:relative; z-index:1; }
.story-top { display:flex; align-items:flex-start; justify-content:space-between; gap:.4cqw; }
.story-number { color:var(--omni-amber); font:700 2.1cqw/1 var(--font-display); }
.story-time { color:var(--omni-cyan-soft); font:600 .78cqw var(--font-display); letter-spacing:.08em; }
.story-group { display:inline-block; color:#c7b7ff; margin:.3cqw 0; font:600 .7cqw var(--font-display); letter-spacing:.08em; text-transform:uppercase; }
.story-action { font-size:.95cqw !important; line-height:1.25 !important; max-width:95%; }
.story-dialogue { margin-top:.28cqw !important; color:var(--omni-amber) !important; font-size:.75cqw !important; font-style:italic; }
.board-warning { display:flex; align-items:center; justify-content:center; gap:.6cqw; color:#f7d796; border:1px solid rgba(244,184,74,.2); background:rgba(244,184,74,.045); font:600 .78cqw/1 var(--font-display); letter-spacing:.06em; text-align:center; }
.board-warning img { width:1.2cqw; height:1.2cqw; }
.board-quick-actions { display:none; padding:0 10px 10px; gap:7px; }

.action-bar { margin-top:10px; border-radius:6px; display:grid; grid-template-columns:1.05fr .95fr; gap:0; min-height:98px; }
.export-console, .adapter-console { display:flex; align-items:center; gap:10px; padding:12px 14px; min-width:0; }
.adapter-console { border-left:1px solid var(--omni-border); }
.action-title { min-width:140px; }
.action-title h2 { font-size:15px; }
.export-console label { min-width:115px; }
.export-console select { min-width:105px; }
.adapter-console .action-title { min-width:105px; }
.adapter-text { min-width:0; flex:1; margin:0; color:var(--omni-muted); font-size:10px; line-height:1.4; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }
.site-footer { min-height:39px; display:flex; align-items:center; justify-content:center; gap:12px; color:var(--omni-dim); font:600 9px var(--font-display); letter-spacing:.09em; text-transform:uppercase; }
.site-footer i { width:20px; height:1px; background:var(--omni-border); }
.site-footer div { margin-left:auto; }
.toast { position:fixed; left:50%; bottom:24px; z-index:20; transform:translate(-50%,20px); opacity:0; pointer-events:none; color:#00151c; background:var(--omni-cyan-soft); border-radius:4px; padding:9px 14px; font:700 11px var(--font-display); letter-spacing:.08em; text-transform:uppercase; transition:.2s; box-shadow:0 8px 28px rgba(0,0,0,.4); }
.toast.show { opacity:1; transform:translate(-50%,0); }

@media (max-width: 1050px) {
  .hero { grid-template-columns:minmax(260px,.85fr) minmax(280px,1fr); }
  .hero-actions { grid-column:1 / -1; justify-content:center; margin-top:-5px; }
  .hero { padding-block:10px; }
  .brand-lockup { height:74px; }
  .workspace { grid-template-columns:minmax(355px,.7fr) minmax(570px,1.3fr); }
  .reference-editor { grid-template-columns:1fr; }
  .compiler, .output { height:650px; min-height:650px; }
  .export-console, .adapter-console { flex-wrap:wrap; }
  .action-title { min-width:100%; }
}

@media (max-width: 820px) {
  body { background:var(--omni-bg); }
  .app-shell { padding:8px; }
  .hero { min-height:0; display:flex; flex-direction:column; gap:10px; text-align:center; border-radius:6px; padding:12px; }
  .brand-lockup { width:min(100%,440px); height:92px; }
  .brand-logo { object-position:center; }
  .hero-copy { border:0; padding:0; }
  .hero-copy .eyebrow { font-size:17px; }
  .hero-copy p:not(.eyebrow) { font-size:11px; max-width:500px; }
  .hero-actions { width:100%; display:grid; grid-template-columns:1fr 1fr; gap:6px; margin:0; }
  .hero-actions .button:first-child { grid-column:1 / -1; }
  .mobile-tabs { position:sticky; top:0; z-index:10; display:grid; grid-template-columns:repeat(3,1fr); margin:8px 0; padding:4px; border:1px solid var(--omni-border); border-radius:5px; background:rgba(3,7,10,.96); backdrop-filter:blur(12px); }
  .mobile-tab { height:39px; color:var(--omni-muted); border:0; border-radius:3px; background:transparent; font:600 12px var(--font-display); letter-spacing:.08em; text-transform:uppercase; }
  .mobile-tab.active { color:#00151c; background:var(--omni-cyan); }
  .workspace { display:contents; }
  .mobile-pane { display:none; }
  .mobile-pane.active { display:flex; }
  .compiler.active { display:block; }
  .output, .compiler { height:auto; min-height:0; margin-bottom:8px; }
  .compiler-scroll { height:auto; max-height:none; overflow:visible; }
  .compiler .editor-section:not([open]) > :not(summary) { display:none; }
  .reference-editor { grid-template-columns:1fr 1fr; }
  .beat-row { grid-template-columns:26px 68px 1fr 24px; }
  .beat-row .beat-dialogue-input { grid-column:3 / 4; }
  .output-heading { min-height:52px; }
  .output-heading p { font-size:9px; }
  .status-pill { display:none; }
  .board-stage { padding:6px; }
  .board-quick-actions { display:grid; grid-template-columns:1fr 1fr; }
  .action-bar.active { display:block; }
  .export-console, .adapter-console { display:grid; grid-template-columns:1fr 1fr; border:0; padding:12px; }
  .adapter-console { border-top:1px solid var(--omni-border); }
  .action-title, .adapter-console .action-title, .adapter-text { grid-column:1 / -1; min-width:0; }
  .export-console label { min-width:0; }
  .export-console label:first-of-type { grid-column:1 / -1; }
  .adapter-console .button { grid-column:1 / -1; }
  .site-footer { display:none; }
}

@media (max-width: 480px) {
  .brand-lockup { height:72px; }
  .hero-actions { grid-template-columns:1fr; }
  .hero-actions .button:first-child { grid-column:auto; }
  .button { min-height:40px; padding-inline:10px; font-size:11px; }
  .section-heading h1, .section-heading h2 { font-size:16px; }
  .reference-editor { grid-template-columns:1fr; }
  .field-grid.two-col, .two-col { grid-template-columns:1fr; }
  .span-two { grid-column:auto; }
  .board-stage { padding:3px; }
  .output-board { border-radius:2px; }
  .board-quick-actions { padding:7px; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { scroll-behavior:auto !important; transition:none !important; }
}

/* Final pass: storyboard-panel image controls and tighter compiler behavior */
.beat-row {
  grid-template-columns: 46px 22px 70px 1fr 1fr 24px 24px;
}
.beat-thumb {
  width: 46px;
  height: 34px;
  display: grid;
  place-items: center;
  overflow: hidden;
  border: 1px solid rgba(96,219,255,.22);
  border-radius: 3px;
  background: linear-gradient(135deg,#081722,#11112b);
  color: rgba(105,231,255,.5);
  padding: 0;
  font: 700 13px var(--font-display);
}
.beat-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.beat-row .icon-button:disabled { opacity: .28; cursor: not-allowed; }
@media (max-width: 820px) {
  .beat-row { grid-template-columns: 44px 24px 68px 1fr 24px 24px; }
  .beat-row .beat-dialogue-input { grid-column: 4 / -1; }
}
@media (max-width: 480px) {
  .beat-row { grid-template-columns: 42px 22px 1fr 24px; }
  .beat-row input[aria-label*="time"] { grid-column: 3 / 4; }
  .beat-row input[aria-label*="action"], .beat-row .beat-dialogue-input { grid-column: 1 / -1; }
}
