/* =========================================================
   YZ Content — "The Edit Bay" (guided)
   Director-led NLE. No page scroll. Real footage. Branded sizzle.
   ========================================================= */
:root {
  --bg:#f4f1ec; --panel:#ffffff; --panel-2:#efebe3;
  --fg:#18171b; --muted:#6c6b72; --dim:#a6a39c;
  --accent:#ff4d2e; --gfx:#5b8cff; --snd:#19b87e;
  --line:rgba(22,20,18,0.12); --line-2:rgba(22,20,18,0.06);
  --fd:"Space Grotesk",system-ui,sans-serif; --fm:"Space Mono",ui-monospace,monospace; --fb:"Inter",system-ui,sans-serif;
  --mb-h:44px; --tl-h:210px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body.app{background:var(--bg);color:var(--fg);font-family:var(--fb);display:grid;grid-template-rows:var(--mb-h) 1fr;height:100dvh;overflow:hidden;-webkit-font-smoothing:antialiased}
button{font-family:inherit;cursor:pointer}
input{font-family:inherit}
[hidden]{display:none!important}   /* author display rules must not defeat hidden */
::-webkit-scrollbar{width:9px;height:9px}::-webkit-scrollbar-thumb{background:#cfcabf;border-radius:6px}::-webkit-scrollbar-track{background:transparent}

.grain{position:fixed;inset:-120%;z-index:9000;pointer-events:none;opacity:.045;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:220px 220px;animation:grain .5s steps(5) infinite}
@keyframes grain{0%{transform:translate(0,0)}20%{transform:translate(-5%,3%)}40%{transform:translate(3%,-5%)}60%{transform:translate(-3%,5%)}80%{transform:translate(5%,-3%)}100%{transform:translate(0,0)}}
.vignette{position:fixed;inset:0;z-index:8999;pointer-events:none;background:radial-gradient(130% 120% at 50% 45%,transparent 70%,rgba(20,18,16,.05) 100%)}
.rec{width:8px;height:8px;border-radius:50%;background:var(--accent);display:inline-block;animation:tally 1.6s ease-out infinite}
@keyframes tally{0%{box-shadow:0 0 0 0 rgba(255,77,46,.6)}70%{box-shadow:0 0 0 6px rgba(255,77,46,0)}100%{box-shadow:0 0 0 0 rgba(255,77,46,0)}}
.kicker{font-family:var(--fm);text-transform:uppercase;letter-spacing:.14em;font-size:.7rem;color:var(--accent)}
.accent{color:var(--accent)}

.btn{display:inline-flex;align-items:center;justify-content:center;font-family:var(--fd);font-weight:500;font-size:.9rem;padding:9px 18px;border-radius:100px;border:0;transition:transform .15s,background .2s,border-color .2s}
.btn:hover{transform:translateY(-1px)}
.btn--primary{background:var(--accent);color:#fff}.btn--primary:hover{background:#ff674c}
.btn--ghost{border:1px solid var(--line);color:var(--fg);background:none}.btn--ghost:hover{border-color:var(--fg)}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}
.btn--sm{font-size:.78rem;padding:8px 14px}

/* ---------- menubar ---------- */
.menubar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:0 14px;background:var(--panel);border-bottom:1px solid var(--line);z-index:50}
.mb__group{display:flex;align-items:center;gap:12px}


.mb__app{font-family:var(--fd);font-weight:700;font-size:1.02rem}
.mb__tag{font-family:var(--fm);font-size:.7rem;color:var(--dim)}

/* ---------- editor grid (client-first: Settings | Monitor | Footage) ---------- */
.main{display:grid;grid-template-columns:304px 1fr 288px;grid-template-rows:1fr var(--tl-h);grid-template-areas:"settings monitor footage" "timeline timeline footage";overflow:hidden}
.panel{background:var(--panel);overflow:hidden;display:flex;flex-direction:column;border-right:1px solid var(--line)}
.settings{grid-area:settings;border-left:0;border-right:1px solid var(--line)}.monitor{grid-area:monitor}.bin{grid-area:footage;border-right:0;border-left:0}
.panel__head{display:flex;align-items:baseline;justify-content:space-between;padding:11px 16px 9px;border-bottom:1px solid var(--line-2)}
.panel__title{font-family:var(--fd);font-weight:600;font-size:.92rem}

/* "Our Work" — an inviting reel, not a file list */
.bin__head{align-items:center;gap:8px}
.bin__filter{flex:1;min-width:0;background:var(--panel-2);border:1px solid var(--line);color:var(--muted);border-radius:7px;padding:5px 8px;font-family:var(--fm);font-size:.7rem;cursor:pointer;appearance:none}
.bin__filter:focus{outline:none;border-color:var(--accent)}
.bin__list{flex:1;overflow-y:auto;padding:6px}
.bin__row{display:grid;grid-template-columns:92px 1fr;gap:11px;padding:6px;border-radius:9px;cursor:pointer;align-items:center;transition:background .15s}
.bin__row:hover{background:var(--panel-2)}
.bin__row:active{cursor:grabbing}
.bin__row.is-picked{opacity:.45}
.bin__thumbwrap{position:relative;width:92px;aspect-ratio:16/9;border-radius:7px;overflow:hidden;background:#000;flex:none}
.bin__thumb{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease}
.bin__row:hover .bin__thumb{transform:scale(1.06)}
.bin__dur{position:absolute;right:4px;bottom:4px;background:rgba(0,0,0,.8);color:#fff;font-family:var(--fm);font-size:.58rem;padding:1px 5px;border-radius:4px;letter-spacing:.02em}
.bin__play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.95rem;opacity:0;background:rgba(0,0,0,.34);transition:opacity .15s}
.bin__row:hover .bin__play{opacity:1}
.bin__row:hover .bin__thumbwrap{box-shadow:0 0 0 2px var(--accent)}
.bin__info{min-width:0}
.bin__name{font-size:.82rem;font-weight:500;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bin__sub{font-family:var(--fm);font-size:.62rem;color:var(--muted);margin-top:3px;text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bin__none{padding:24px 14px;color:var(--dim);font-family:var(--fm);font-size:.78rem}

/* monitor */
.monitor{background:#0a0a0c}
.monitor__screen{position:relative;flex:1;margin:12px;background:#000;border:1px solid var(--line);border-radius:8px;overflow:hidden;display:flex;align-items:center;justify-content:center;min-height:0;color:#f5f2ec}
.screen__empty{text-align:center;padding:24px;max-width:760px}
.screen__big{font-family:var(--fd);font-weight:600;font-size:clamp(1.2rem,2.6vw,1.9rem);line-height:1.15}
.screen__hint{font-family:var(--fm);font-size:.76rem;color:var(--dim);margin-top:14px;line-height:1.5}
.screen__poster{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;background:#000;z-index:1}
.screen__poster.kb{animation:kenburns 6s ease-out forwards}
@keyframes kenburns{from{transform:scale(1.08)}to{transform:scale(1)}}
.screen__player{position:absolute;inset:0;z-index:2}.screen__player iframe{width:100%;height:100%;border:0;display:block}
.screen__stage{position:absolute;inset:0;z-index:2;background:#000;filter:saturate(1.07) contrast(1.03)}
.vclip{position:absolute;inset:0;opacity:0;transition:opacity .5s ease}
/* cinematic vignette so disparate footage feels graded & unified */
.screen__grade{position:absolute;inset:0;z-index:2;pointer-events:none;opacity:0;transition:opacity .6s ease;background:radial-gradient(125% 115% at 50% 42%,transparent 55%,rgba(6,5,4,.5) 100%)}
.screen__grade.on{opacity:1}
/* film-leader countdown — buffers the clips + sets a cinematic tone before the cut plays */
.leader{position:absolute;inset:0;z-index:5;display:flex;align-items:center;justify-content:center;background:#08080b;color:#f5f2ec}
.leader[hidden]{display:none}
.leader__ring{position:absolute;width:min(44%,240px);aspect-ratio:1;border-radius:50%;border:2px solid rgba(245,242,236,.22)}
.leader__ring::before,.leader__ring::after{content:"";position:absolute;background:rgba(245,242,236,.18)}
.leader__ring::before{left:50%;top:-2px;width:1px;height:calc(100% + 4px);transform:translateX(-.5px)}
.leader__ring::after{top:50%;left:-2px;height:1px;width:calc(100% + 4px);transform:translateY(-.5px)}
.leader__sweep{position:absolute;width:min(44%,240px);aspect-ratio:1;border-radius:50%;background:conic-gradient(rgba(245,242,236,.14) 0 25%,transparent 25% 100%);animation:sweep .8s linear infinite}
@keyframes sweep{to{transform:rotate(360deg)}}
.leader__num{position:relative;z-index:1;font-family:var(--fd);font-weight:700;font-size:clamp(3.4rem,11vw,7rem);line-height:1}
.leader.beat .leader__num{animation:leadPop .76s ease}
@keyframes leadPop{0%{transform:scale(1.3);opacity:.35}22%{opacity:1}100%{transform:scale(1);opacity:1}}
.vclip.is-live{opacity:1}
.vclip iframe,.vclip>div{position:absolute;inset:0;width:100%;height:100%;border:0}
/* intertitle sizing by kind */
.screen__brandcard[data-kind="open"] .bc__name{font-size:clamp(2rem,5.4vw,4rem)}
.screen__brandcard[data-kind="mid"] .bc__name{font-size:clamp(1.7rem,4.6vw,3.1rem);text-transform:uppercase;letter-spacing:-.01em}
.screen__brandcard[data-kind="close"] .bc__name{font-size:clamp(1.8rem,4.8vw,3.3rem)}
.screen__brandcard .bc__kick{font-family:var(--fm);font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;color:var(--bc-accent,var(--accent))}
/* KINETIC entrance — organic per-word reveal + a gentle breath that keeps the card alive */
@keyframes barGrow{from{width:0;opacity:0}to{width:64px;opacity:1}}
@keyframes upFade{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
@keyframes wordIn{0%{opacity:0;transform:translateY(9px) scale(.99);filter:blur(2px)}55%{filter:blur(0)}100%{opacity:1;transform:none;filter:blur(0)}}
/* slow Ken-Burns zoom on the whole title — alternates in/out per title for variety */
@keyframes kbIn{from{transform:scale(1)}to{transform:scale(1.13)}}
@keyframes kbOut{from{transform:scale(1.13)}to{transform:scale(1)}}
.screen__brandcard.kbin{animation:kbIn 6.5s ease-out both}
.screen__brandcard.kbout{animation:kbOut 6.5s ease-out both}
.screen__brandcard .bc__name{animation:upFade .35s both}
/* layout variety per title — center / left-editorial / tight-uppercase, with a tinted backdrop on one */
.screen__brandcard[data-layout="1"]{align-items:flex-start;text-align:left;padding:0 9%}
.screen__brandcard[data-layout="1"] .bc__name{font-size:clamp(2.2rem,6vw,4.4rem)}
.screen__brandcard[data-layout="2"] .bc__name{text-transform:uppercase;letter-spacing:-.01em}
.bc__name .w{display:inline-block;animation:wordIn .62s cubic-bezier(.22,.61,.36,1) both;will-change:transform,opacity,filter}
/* per-generation title fonts */
.monitor__screen[data-font="serif"] .bc__name{font-family:"Fraunces",Georgia,serif;font-weight:600;letter-spacing:0}
.monitor__screen[data-font="condensed"] .bc__name{font-family:"Anton","Arial Narrow",sans-serif;text-transform:uppercase;letter-spacing:.015em;font-weight:400}
/* per-generation reveal animations (words = default per-word; rise/pop reveal the whole line) */
.monitor__screen[data-anim="rise"] .bc__name .w,.monitor__screen[data-anim="pop"] .bc__name .w{animation:none}
.monitor__screen[data-anim="rise"] .bc__name{animation:riseIn .72s cubic-bezier(.2,.7,.3,1) both}
.monitor__screen[data-anim="pop"] .bc__name{animation:popIn .6s cubic-bezier(.2,.8,.3,1) both}
@keyframes riseIn{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}
@keyframes popIn{from{opacity:0;transform:scale(.9)}to{opacity:1;transform:none}}
.screen__brandcard .bc__bar{animation:barGrow .5s .06s both}
.screen__brandcard .bc__by,.screen__brandcard .bc__kick,.screen__brandcard img,.screen__brandcard .bc__clients,.screen__brandcard .clientwall__lab{animation:upFade .55s .12s both}
/* per-flow rhythm — each story breathes at its own pace */
.monitor__screen[data-flow="org"] .bc__name .w,.monitor__screen[data-flow="corp"] .bc__name .w{animation-duration:.8s}
.monitor__screen[data-flow="marketing"] .bc__name .w{animation-duration:.42s}
.monitor__screen[data-flow="tech"] .bc__name .w,.monitor__screen[data-flow="commercial"] .bc__name .w{animation-duration:.52s}
.monitor__screen[data-look="bold"] .bc__name .w,.monitor__screen[data-look="social"] .bc__name .w{animation-duration:.4s}
/* editable title */
.bc__name[contenteditable]{outline:none;cursor:text;border-bottom:2px dashed var(--bc-accent,var(--accent));padding-bottom:3px}
.bc__name[contenteditable]:focus{border-bottom-style:solid}
.bc__name[contenteditable]::after{content:" ✎";font-size:.5em;opacity:.5;-webkit-text-fill-color:var(--bc-accent,var(--accent))}
/* transition fx overlay */
.fx{position:absolute;inset:0;z-index:6;pointer-events:none;opacity:0;background:#000}
.fx.dissolve{animation:fxdis .42s ease}
.fx.flash{background:#fff;animation:fxflash .22s ease}
.fx.wipe{background:var(--bc-accent,#ff4d2e);animation:fxwipe .36s ease}
@keyframes fxdis{0%{opacity:0}50%{opacity:.5}100%{opacity:0}}
@keyframes fxflash{0%{opacity:0}30%{opacity:.5}100%{opacity:0}}
@keyframes fxwipe{0%{opacity:.95;transform:translateX(-100%)}55%{opacity:.95;transform:translateX(0)}100%{opacity:.95;transform:translateX(100%)}}

/* ---- YZ logo in menubar ---- */
.mb__eye{height:22px;width:auto;display:block}

/* ---- HERO (idle program window) — feels like a global agency ---- */
.hero-mon{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:0;padding:24px;width:100%;height:100%;
  background:radial-gradient(70% 70% at 50% 35%,rgba(255,77,46,.16),transparent 70%),radial-gradient(60% 60% at 50% 100%,rgba(70,120,255,.12),transparent 70%)}
.hero-mon__lockup{display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap;animation:upFade .6s .05s both}
.hero-mon__eye{height:clamp(46px,6.5vw,68px);width:auto;filter:drop-shadow(0 6px 24px rgba(0,0,0,.5));animation:float 5.5s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
.hero-mon__h{font-family:var(--fd);font-weight:700;font-size:clamp(1.4rem,3.3vw,2.3rem);line-height:1.02;letter-spacing:-.02em;text-align:left;white-space:nowrap}
.hero-mon__h .accent{color:var(--accent)}
.hero-mon__sub{font-family:var(--fm);font-size:clamp(.74rem,1.6vw,.92rem);letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-top:16px;animation:upFade .6s .15s both}
.clientwall{margin-top:28px;width:100%;max-width:560px;animation:upFade .7s .28s both}
.clientwall__lab{font-family:var(--fm);font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--dim);margin-bottom:14px}
/* 15 logos · 3 rows of 5 · clean white marks, no background */
.clientwall__row{display:grid;grid-template-columns:repeat(5,1fr);gap:16px 18px;align-items:center}
.clientwall__row img{height:30px;width:auto;max-width:108px;object-fit:contain;justify-self:center;filter:brightness(0) invert(1);opacity:.82;transition:opacity .2s}
.clientwall__row img:hover{opacity:1}

/* client strip on the end card */
.bc__clients{display:flex;flex-wrap:wrap;gap:14px 20px;align-items:center;justify-content:center;margin-top:14px;max-width:86%}
.bc__clients img{height:22px;width:auto;max-width:78px;object-fit:contain;filter:brightness(0) invert(1);opacity:.7}

/* ---- drag-and-drop affordance ---- */
.tl__body.dropok::after{content:"drop to add a shot ▾";position:absolute;top:6px;right:14px;font-family:var(--fm);font-size:.66rem;color:var(--accent)}

/* ---- SETTINGS drawer (left panel) ---- */
.settings .panel__head{position:relative}
.set__min{position:absolute;right:12px;top:9px;background:none;border:0;color:var(--muted);font-size:.9rem;cursor:pointer}
.set__min:hover{color:var(--fg)}
.set__reopen{display:none}
.set__body{flex:1;overflow-y:auto;padding:14px 16px;display:flex;flex-direction:column;gap:12px}
.set__intro{padding-bottom:10px;border-bottom:1px solid var(--line-2)}
.set__hi{font-family:var(--fd);font-weight:600;font-size:1.08rem;line-height:1.2}
.set__say{font-family:var(--fb);font-size:.78rem;color:var(--muted);margin-top:6px;line-height:1.45}
.chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:2px}
.chip{font-family:var(--fb);font-size:.72rem;padding:5px 10px;border-radius:100px;border:1px solid var(--line);background:var(--panel);color:var(--fg);cursor:pointer;transition:background .15s,border-color .15s,color .15s}
.chip:hover{border-color:var(--fg)}
.chip.is-on{background:var(--accent);border-color:var(--accent);color:#fff}
.f{display:block;min-width:0}
.f>span{display:block;font-size:.72rem;color:var(--muted);margin-bottom:5px;line-height:1.25}
.set__body select,.set__body input[type=text]{width:100%;background:var(--panel-2);border:1px solid var(--line);color:var(--fg);border-radius:7px;padding:7px 9px;font-size:.8rem;font-family:var(--fb)}
.set__body select{font-family:var(--fm);font-size:.76rem;cursor:pointer;appearance:none;padding-right:26px;background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%);background-position:calc(100% - 14px) 13px,calc(100% - 9px) 13px;background-size:5px 5px;background-repeat:no-repeat}
.set__body select:focus,.set__body input:focus{outline:none;border-color:var(--accent)}
.set__body input[type=file]{width:100%;font-family:var(--fm);font-size:.66rem;color:var(--muted)}
.set__body input[type=file]::file-selector-button{background:var(--panel-2);border:1px solid var(--line);color:var(--fg);border-radius:6px;padding:5px 8px;margin-right:6px;cursor:pointer;font-size:.66rem}
.set__more{margin-top:2px;border-top:1px solid var(--line-2);padding-top:8px}
.set__more summary{font-family:var(--fm);font-size:.74rem;color:var(--muted);cursor:pointer;list-style:none;padding:3px 0}
.set__more summary::-webkit-details-marker{display:none}
.set__more summary::before{content:"+ ";color:var(--accent);font-weight:700}
.set__more[open] summary::before{content:"– "}
.set__more summary small{color:var(--dim)}
.set__more summary:hover{color:var(--fg)}
.set__more-body{display:flex;flex-direction:column;gap:12px;margin-top:12px}
.f>span small{color:var(--dim)}
.inline{display:flex;gap:6px}.inline input{flex:1}.inline .btn{padding:7px 12px}
.swatches{display:flex;gap:6px;flex-wrap:wrap}
.swatch{width:22px;height:22px;border-radius:50%;border:2px solid var(--line);cursor:pointer}
.swatch.is-on{border-color:var(--fg);box-shadow:0 0 0 2px var(--panel),0 0 0 4px var(--fg)}
/* footage view toggle + grid + footer */
.bin__views{display:flex;gap:3px}
.vbtn{background:var(--panel-2);border:1px solid var(--line);color:var(--muted);border-radius:5px;width:24px;height:22px;font-size:.8rem;line-height:1;cursor:pointer}
.vbtn.is-on{background:var(--accent);border-color:var(--accent);color:#fff}
.bin__list.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;align-content:start;padding:7px}
.bin__list.grid .bin__row{display:block;padding:0;border-radius:7px;overflow:hidden;border:1px solid var(--line-2)}
.bin__list.grid .bin__row:hover{border-color:var(--accent)}
.bin__list.grid .bin__thumbwrap{width:100%;aspect-ratio:16/9;border-radius:0}
.bin__list.grid .bin__row:hover .bin__thumbwrap{box-shadow:none}
.bin__list.grid .bin__info{display:none}
.bin__pager{display:flex;align-items:center;justify-content:center;gap:14px;padding:7px;border-top:1px solid var(--line-2);font-family:var(--fm);font-size:.72rem;color:var(--muted)}
.bin__pager[hidden]{display:none}
.pgbtn{background:var(--panel-2);border:1px solid var(--line);color:var(--fg);width:30px;height:24px;border-radius:6px;cursor:pointer;font-size:.9rem;line-height:1}
.pgbtn:hover:not(:disabled){border-color:var(--accent)}
.pgbtn:disabled{opacity:.35;cursor:not-allowed}
.set__foot{padding:12px 16px;border-top:1px solid var(--line-2)}
.set__foot .btn{width:100%;padding:15px;font-size:1.02rem;font-weight:600;border-radius:12px;animation:autopulse 2.6s ease-in-out infinite}
.set__foot .btn:hover{animation:none}
@keyframes autopulse{0%,100%{box-shadow:0 0 0 0 rgba(255,77,46,0)}50%{box-shadow:0 0 0 6px rgba(255,77,46,.16)}}
/* bottom = timeline (left) + Output panel (right, under settings) */
.cut__restart{background:none;border:0;color:var(--dim);font-family:var(--fm);font-size:.7rem;cursor:pointer;padding:4px}
.cut__restart:hover{color:var(--fg)}
/* minimized state */
body.settings-min .main{grid-template-columns:42px 1fr 288px}
body.settings-min .settings .panel__head,body.settings-min .settings .set__body,body.settings-min .settings .set__foot{display:none}
body.settings-min .settings .set__reopen{display:block;width:100%;height:100%;background:none;border:0;color:var(--muted);font-size:1.2rem;cursor:pointer}
body.settings-min .settings .set__reopen:hover{color:var(--fg)}

/* ---- look & feel treatments applied to the program window ---- */
.monitor__screen[data-look="cinematic"]::before,.monitor__screen[data-look="cinematic"]::after,
.monitor__screen[data-look="minimal"]::before,.monitor__screen[data-look="minimal"]::after{content:"";position:absolute;left:0;right:0;height:8%;background:#000;z-index:7;pointer-events:none}
.monitor__screen[data-look="cinematic"]::before,.monitor__screen[data-look="minimal"]::before{top:0}
.monitor__screen[data-look="cinematic"]::after,.monitor__screen[data-look="minimal"]::after{bottom:0}
.monitor__screen[data-look="bold"] .bc__name,.monitor__screen[data-look="social"] .bc__name{text-transform:uppercase;letter-spacing:.02em}
.monitor__screen[data-look="minimal"] .bc__bar,.monitor__screen[data-look="cinematic"] .bc__bar{display:none}
.screen__overlay{position:absolute;top:10px;left:12px;right:12px;z-index:4;display:flex;justify-content:space-between;font-family:var(--fm);font-size:.72rem;pointer-events:none;text-shadow:0 1px 3px #000}
.screen__rec{display:inline-flex;align-items:center;gap:6px;color:var(--accent)}
.screen__play{display:none!important}
/* brand title card overlay */
/* title cards are OPAQUE — a clean, separate beat (no live video bleeding through) */
.screen__brandcard{position:absolute;inset:0;z-index:3;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;text-align:center;background:#0a0a0d;opacity:0;pointer-events:none;transition:opacity .42s ease}
.screen__brandcard.show{opacity:1;pointer-events:auto}
/* rotating, opaque title backgrounds so titles don't all look the same */
.screen__brandcard[data-bg="0"]{background:radial-gradient(circle at 50% 36%,#1b1b22,#08080b)}
.screen__brandcard[data-bg="1"]{background:radial-gradient(circle at 24% 24%,var(--bc-accent),#0a0a0d 62%)}
.screen__brandcard[data-bg="2"]{background:#0a0a0d}
.screen__brandcard img{max-width:42%;max-height:38%;object-fit:contain}
.bc__name{font-family:var(--fd);font-weight:700;font-size:clamp(1.4rem,4vw,2.6rem);letter-spacing:-.01em;max-width:90%;line-height:1.04}
.bc__by{font-family:var(--fm);font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(245,242,236,.6)}
.bc__by b{color:var(--bc-accent,var(--accent))}
.bc__bar{width:60px;height:3px;background:var(--bc-accent,var(--accent));border-radius:2px}
/* personal brand bug — sits on the film throughout */
.brandbug{position:absolute;right:14px;bottom:14px;z-index:4;pointer-events:none;opacity:.72}
.brandbug img{height:24px;width:auto;max-width:120px;object-fit:contain;filter:drop-shadow(0 1px 5px rgba(0,0,0,.8))}
.brandbug span{font-family:var(--fd);font-weight:600;font-size:.92rem;color:#fff;text-shadow:0 1px 5px rgba(0,0,0,.9)}

.monitor__transport{display:flex;align-items:center;gap:12px;padding:0 14px 12px}
.tbtn{background:var(--panel-2);border:1px solid var(--line);color:var(--fg);width:34px;height:34px;border-radius:7px}
.tbar{flex:1;height:5px;background:var(--panel-2);border-radius:3px;position:relative;overflow:hidden}
.tbar__fill{position:absolute;inset:0 auto 0 0;width:0;background:var(--accent);border-radius:3px;transition:width .2s linear}
.ttime{font-family:var(--fm);font-size:.72rem;color:var(--muted);min-width:92px;text-align:right}

/* timeline */
.timeline{grid-area:timeline;background:var(--panel);display:flex;flex-direction:column;overflow:hidden;border-top:1px solid var(--line);border-right:1px solid var(--line)}
.tl__head{display:flex;align-items:center;gap:12px;padding:6px 14px;border-bottom:1px solid var(--line-2)}
.tl__title{font-family:var(--fd);font-weight:600;font-size:.88rem}.tl__title b{color:var(--accent)}
.tl__runtime{font-family:var(--fm);font-size:.72rem;color:var(--muted);margin-left:auto}
.tl__body{position:relative;flex:1;padding:8px 16px;overflow-x:auto;overflow-y:hidden;cursor:default}
.tl__ruler{height:12px;border-bottom:1px solid var(--line-2);background-image:repeating-linear-gradient(90deg,var(--line-2) 0 1px,transparent 1px 48px);margin-bottom:6px}
.tl__track{display:grid;grid-template-columns:28px 1fr;align-items:center;gap:8px;height:44px}
.tl__track--t{height:28px}
.tl__lab{font-family:var(--fm);font-size:.66rem;color:var(--dim)}
.tl__lane{position:relative;height:40px;background:var(--panel-2);border:1px solid var(--line-2);border-radius:6px;overflow:hidden;cursor:pointer}
#laneT1{height:22px}
.tl__clip{position:absolute;top:3px;bottom:3px;border-radius:4px;overflow:hidden;cursor:pointer;border:1px solid rgba(0,0,0,.3);display:flex;align-items:center;animation:drop .3s ease}
@keyframes drop{from{transform:translateY(-8px);opacity:0}to{transform:none;opacity:1}}
.tl__clip--v{background:#1a1a1c center/cover no-repeat}
.tl__clip--v::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.12),rgba(0,0,0,.62))}
.tl__clip--v span,.tl__clip--v .x{position:relative;z-index:1}
.tl__clip--t{top:2px;bottom:2px;background:linear-gradient(180deg,rgba(255,77,46,.28),rgba(255,77,46,.12));border-color:rgba(255,77,46,.5)}
.tl__clip--t span{color:#ffe2da;font-size:.58rem}
.tl__clip span{font-family:var(--fm);font-size:.6rem;color:rgba(255,255,255,.92);padding:0 6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tl__clip:hover{filter:brightness(1.15)}
.tl__playhead{position:absolute;top:8px;bottom:8px;left:44px;width:2px;background:var(--fg);pointer-events:none;transition:left .3s}
.tl__playhead::before{content:"";position:absolute;top:-2px;left:-4px;border:5px solid transparent;border-top-color:var(--fg)}
.tl__empty{position:absolute;left:52px;top:42px;font-family:var(--fm);font-size:.8rem;color:var(--dim);pointer-events:none}

/* modal + toast */
.modal{position:fixed;inset:0;z-index:9600;display:grid;place-items:center}
.modal[hidden]{display:none}
.modal__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(6px)}
.modal__card{position:relative;z-index:1;width:min(92vw,500px);background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:40px;text-align:center;animation:pop .3s ease}
@keyframes pop{from{opacity:0;transform:scale(.96) translateY(10px)}to{opacity:1;transform:none}}
.modal__close{position:absolute;top:16px;right:16px;background:none;border:0;color:var(--muted);font-size:1rem}.modal__close:hover{color:var(--fg)}
.modal__title{font-family:var(--fd);font-weight:700;font-size:clamp(1.8rem,5vw,2.6rem);margin:12px 0 14px}
.modal__sub{color:var(--muted);margin-bottom:24px;font-size:.92rem;line-height:1.5}
.modal__email{font-family:var(--fd);font-weight:600;font-size:clamp(1.3rem,4vw,1.8rem);color:var(--fg);border-bottom:2px solid transparent}.modal__email:hover{color:var(--accent);border-color:var(--accent)}
.modal__row{margin-top:22px;display:flex;gap:22px;justify-content:center;color:var(--muted);font-family:var(--fm);font-size:.85rem}.modal__row a:hover{color:var(--fg)}
.modal__credits{margin-top:26px;font-family:var(--fm);font-size:.64rem;letter-spacing:.15em;color:var(--dim)}
.modal__music{margin-top:6px;font-size:.56rem;letter-spacing:.06em;opacity:.7}
.toast{position:fixed;bottom:calc(var(--tl-h) + 16px);left:50%;transform:translateX(-50%);z-index:9700;background:var(--snd);color:#04130c;font-family:var(--fm);font-size:.8rem;font-weight:700;padding:10px 18px;border-radius:100px;animation:pop .2s ease}
.toast[hidden]{display:none}

/* ---------- arrival: black → film fills → settles → workspace builds window by window ---------- */
body.booting{background:#000;animation:bootBg 3.4s ease forwards}
@keyframes bootBg{0%{background:#000}55%{background:#000}100%{background:var(--bg)}}
/* the film starts large and cinematic, then eases down into its frame */
body.booting .monitor{opacity:0;transform-origin:center;animation:monIn 3.4s cubic-bezier(.38,.7,.22,1) forwards}
@keyframes monIn{0%{opacity:0;transform:scale(1.35)}14%{opacity:1}100%{opacity:1;transform:scale(1)}}
/* then each window slides + fades in, one at a time — unhurried */
body.booting .menubar{opacity:0;animation:revealD 1.1s ease 1.7s forwards}
body.booting .settings{opacity:0;animation:revealL 1.2s ease 2.1s forwards}
body.booting .bin{opacity:0;animation:revealR 1.2s ease 3.0s forwards}
body.booting .timeline{opacity:0;animation:revealU 1.2s ease 3.9s forwards}
@keyframes revealD{from{opacity:0;transform:translateY(-14px)}to{opacity:1;transform:none}}
@keyframes revealL{from{opacity:0;transform:translateX(-28px)}to{opacity:1;transform:none}}
@keyframes revealR{from{opacity:0;transform:translateX(28px)}to{opacity:1;transform:none}}
@keyframes revealU{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:none}}

/* responsive */
@media(max-width:920px){
  html{overflow-x:hidden}
  body.app{height:auto;min-height:100dvh;display:block;overflow-y:auto;overflow-x:hidden}
  .menubar{position:sticky;top:0}
  .mb__tag{display:none}   /* keep the bar tight on phones */
  .main{display:flex;flex-direction:column}
  .panel{border:0;border-bottom:1px solid var(--line)}
  .monitor{order:-1}.monitor__screen{aspect-ratio:4/3;flex:none}
  .settings{order:1}.bin{order:2}.timeline{order:3}
  .bin__list{max-height:42vh}
  .timeline{height:auto;border-right:0;border-top:1px solid var(--line)}.tl__body{min-height:130px}
  /* hero must wrap & fit on phones */
  .hero-mon__lockup{flex-direction:column;gap:10px}
  .hero-mon__h{white-space:normal;font-size:clamp(1.5rem,7vw,2.1rem)}
  .screen__empty{max-width:100%}
  .clientwall{max-width:100%}
  .clientwall__row{grid-template-columns:repeat(3,1fr);gap:12px 14px}
}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation:none!important}.grain{display:none}}
