/* FRAMEZZ — SIGNATURE layer. The things that make it unforgettable:
   Prompt→Frame hero (latent denoise), scrubbing-trail cursor, NLE sequence
   strip on WORK, Director's-commentary mode, opt-in room sound, render-queue
   contact. All additive — no existing behaviour is touched. */

/* ============ 1 · PROMPT → FRAME (hero) ============ */
.promptline{margin-top:26px;display:flex;align-items:flex-start;gap:14px;max-width:60ch;
  font-family:var(--mono);font-size:clamp(12px,1.35vw,15px);line-height:1.5;color:var(--soft);min-height:2.2em}
.promptline .pl-tag{flex:none;color:var(--accent);letter-spacing:.12em;text-transform:uppercase;
  font-size:.82em;padding-top:.18em}
.promptline .pl-body{position:relative}
.promptline .pl-txt{color:var(--ink)}
.promptline .pl-caret{display:inline-block;width:.62em;height:1.06em;margin-left:1px;vertical-align:-2px;
  background:var(--accent);animation:plblink 1s steps(1) infinite}
.promptline.done .pl-caret{animation:none;opacity:.0}
.promptline .pl-status{display:block;margin-top:7px;font-size:.82em;letter-spacing:.14em;text-transform:uppercase;
  color:var(--dim);opacity:0;transition:opacity .5s}
.promptline.done .pl-status{opacity:1}
.promptline .pl-status b{color:var(--accent);font-weight:400}
@keyframes plblink{0%,50%{opacity:1}51%,100%{opacity:0}}

/* latent-noise denoise reveal over the hero video */
.slate .hero-bg{transition:opacity 3.4s cubic-bezier(.4,0,.2,1),filter 1.7s cubic-bezier(.4,0,.2,1)}
.slate:not(.denoised) .hero-bg{filter:blur(22px) saturate(.25) brightness(.5) contrast(1.7)}
.slate.denoised .hero-bg{filter:saturate(.9) contrast(1.04) brightness(.95)}
.hero-latent{position:absolute;inset:0;z-index:1;pointer-events:none;opacity:.9;transition:opacity 1.7s ease;
  mix-blend-mode:screen;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:240px 240px;animation:latentdrift 1.2s steps(4) infinite}
.slate.denoised .hero-latent{opacity:0;animation:none}
@keyframes latentdrift{0%{background-position:0 0}100%{background-position:240px 120px}}

/* ============ 2 · SCRUBBING-TRAIL CURSOR ============ */
.scrubframe{position:fixed;z-index:128;pointer-events:none;width:26px;height:15px;margin:-7px 0 0 -13px;
  border:1px solid var(--accent);background:rgba(255,67,38,.08);opacity:.0}
.scrubframe.live{opacity:.55;animation:sffade .6s ease-out forwards}
@keyframes sffade{0%{opacity:.5;transform:scale(1)}100%{opacity:0;transform:scale(.72)}}

/* ============ 3 · WORK AS A SEQUENCE ============ */
.seqstrip{display:flex;align-items:center;gap:0;margin:-10px 0 30px;border:1px solid var(--line);
  background:var(--bg2);font-family:var(--mono)}
.seqstrip .sq-tc{padding:11px 16px;font-size:12px;letter-spacing:.06em;color:var(--ink);
  font-variant-numeric:tabular-nums;border-right:1px solid var(--line);white-space:nowrap}
.seqstrip .sq-tc b{color:var(--accent);font-weight:400}
.seqstrip .sq-clips{flex:1;display:flex;align-items:stretch;height:30px;min-width:0;overflow:hidden}
.seqstrip .sq-c{position:relative;border-right:1px solid var(--bg2);background:#1b1e24;display:flex;align-items:center;
  padding:0 10px;font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--soft);white-space:nowrap;
  overflow:hidden;cursor:pointer;transition:background .2s,color .2s}
.seqstrip .sq-c::before{content:"";position:absolute;left:0;right:0;top:0;height:4px;
  background:repeating-linear-gradient(90deg,rgba(243,244,241,.18) 0 2px,transparent 2px 6px)}
.seqstrip .sq-c.wide{flex:2.0}
.seqstrip .sq-c.tall{flex:1.0}
.seqstrip .sq-c:hover,.seqstrip .sq-c.cued{background:var(--accent-dim);color:var(--ink)}
.seqstrip .sq-meta{padding:11px 16px;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--dim);
  border-left:1px solid var(--line);white-space:nowrap}
@media(max-width:640px){
  .seqstrip .sq-meta{display:none}
  .seqstrip .sq-tc{font-size:11px;padding:10px 12px}
  .seqstrip .sq-c{font-size:0;padding:0}
  .seqstrip .sq-c::after{content:"";position:absolute;left:6px;right:6px;bottom:7px;height:3px;background:var(--line2)}
}

/* ============ 4 · DIRECTOR'S COMMENTARY ============ */
.sigctl{display:flex;align-items:center;gap:2px;height:100%}
.sigbtn{display:inline-flex;align-items:center;gap:8px;height:100%;padding:0 13px;cursor:pointer;background:none;
  border:0;border-left:1px solid var(--line);color:var(--soft);font-family:var(--mono);font-size:10px;
  letter-spacing:.16em;text-transform:uppercase;transition:color .2s,background .2s}
.sigbtn:hover{color:var(--ink)}
.sigbtn.on{color:var(--accent)}
.sigbtn .dotled{width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.45}
.sigbtn.on .dotled{opacity:1;box-shadow:0 0 8px currentColor}
.sigbtn svg{width:14px;height:14px;fill:none;stroke:currentColor;stroke-width:1.6}
@media(max-width:880px){.sigbtn .sigbtn-l{display:none}.sigbtn{padding:0 12px}}

/* commentary annotation chips */
.anno{position:absolute;z-index:30;display:flex;flex-direction:column;gap:5px;padding:11px 13px;
  background:rgba(10,11,13,.86);backdrop-filter:blur(6px);border:1px solid var(--accent);
  font-family:var(--mono);max-width:230px;opacity:0;transform:translateY(6px);
  transition:opacity .4s ease,transform .4s ease;pointer-events:none}
.anno::before{content:"";position:absolute;left:-1px;top:13px;width:14px;height:1px;background:var(--accent);transform:translateX(-100%)}
.anno.show{opacity:1;transform:none}
.anno .a-h{font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent)}
.anno .a-r{display:flex;justify-content:space-between;gap:14px;font-size:10.5px;letter-spacing:.04em;color:var(--soft)}
.anno .a-r b{color:var(--ink);font-weight:400}
body.commentary .viewer{outline:1px solid rgba(255,67,38,.18);outline-offset:-1px}
.anno-host{position:relative}

/* ============ 5 · ROOM SOUND (opt-in) ============ */
/* purely a toggle state class on body; audio is WebAudio, no DOM needed */

/* ============ 6 · CONTACT AS A RENDER JOB ============ */
.renderjob{margin-top:40px;width:min(520px,92vw);border:1px solid var(--line2);background:var(--bg2);
  font-family:var(--mono);text-align:left;overflow:hidden}
.renderjob .rj-head{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:12px 16px;
  border-bottom:1px solid var(--line);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--dim)}
.renderjob .rj-head .rj-live{display:flex;align-items:center;gap:7px;color:var(--accent)}
.renderjob .rj-head .rj-live i{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:pulse 1.5s infinite}
.renderjob .rj-track{position:relative;height:5px;background:var(--panel)}
.renderjob .rj-fill{position:absolute;inset:0 100% 0 0;background:var(--accent);box-shadow:0 0 12px var(--accent);
  transition:right 2.2s cubic-bezier(.5,0,.2,1)}
.renderjob.run .rj-fill{right:0}
.renderjob .rj-rows{padding:6px 16px 14px}
.renderjob .rj-row{display:flex;justify-content:space-between;gap:16px;padding:7px 0;font-size:11px;
  letter-spacing:.05em;color:var(--soft);border-bottom:1px solid var(--line)}
.renderjob .rj-row:last-child{border-bottom:0}
.renderjob .rj-row b{color:var(--ink);font-weight:400}
.renderjob .rj-row .ok{color:var(--accent)}

@media(prefers-reduced-motion:reduce){
  .scrubframe{display:none!important}
  .hero-latent{display:none!important}
  .promptline .pl-caret{animation:none}
}
