:root{
  --bg:#15130F; --bg2:#1E1B16; --bg3:#272219; --line:#3A3327;
  --gold:#C9A86A; --gold-dim:#6E5C3C; --ink:#EFEAE0; --ink2:#A8A296;
  --edit:#7FB084; --roll:#E0703A; --done:#5B7A52; --danger:#C96B6B;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;background:var(--bg);color:var(--ink);
  font-family:-apple-system,'PingFang TC','Noto Sans TC',sans-serif;
  font-size:16px;line-height:1.5;-webkit-text-size-adjust:100%}
body{padding-bottom:env(safe-area-inset-bottom)}
.loading{padding:60px;text-align:center;color:var(--ink2)}
a{color:var(--gold);text-decoration:none}
button{font-family:inherit;cursor:pointer}

/* ---- 通用 ---- */
.wrap{max-width:680px;margin:0 auto;padding:0 14px}
.topbar{position:sticky;top:0;z-index:10;background:rgba(21,19,15,.94);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);padding:calc(env(safe-area-inset-top) + 10px) 14px 10px}
.topbar .pname{font-weight:800;font-size:18px;letter-spacing:.5px}
.topbar .sub{color:var(--ink2);font-size:12.5px;margin-top:2px}
.tabs{display:flex;gap:4px;margin-top:10px}
.tabs button{flex:1;background:var(--bg2);color:var(--ink2);border:1px solid var(--line);
  border-radius:10px;padding:9px 0;font-size:14px;font-weight:600}
.tabs button.on{background:var(--gold);color:#15130F;border-color:var(--gold);font-weight:800}
.muted{color:var(--ink2)}
.btn{display:inline-block;background:var(--gold);color:#15130F;border:none;border-radius:11px;
  padding:13px 18px;font-weight:800;font-size:16px;width:100%}
.btn.sec{background:var(--bg3);color:var(--ink);border:1px solid var(--line)}
.btn:active{transform:scale(.99)}
input,select,textarea{width:100%;background:var(--bg3);border:1px solid var(--line);border-radius:11px;
  color:var(--ink);padding:13px 12px;font-size:16px;font-family:inherit;outline:none}
input:focus,select:focus,textarea:focus{border-color:var(--gold-dim)}
label{display:block;font-size:13px;color:var(--ink2);margin:14px 2px 6px;font-weight:600}
.field{margin-bottom:4px}

/* ---- 進度條 ---- */
.prog{margin:12px 0 4px}
.prog .bar{height:10px;background:var(--bg3);border-radius:6px;overflow:hidden}
.prog .bar i{display:block;height:100%;background:linear-gradient(90deg,var(--gold-dim),var(--gold));border-radius:6px;transition:width .4s}
.prog .lbl{display:flex;justify-content:space-between;font-size:13px;margin-top:5px;color:var(--ink2)}
.prog .lbl b{color:var(--gold);font-weight:800}
.seg-prog{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}
.seg-prog span{font-size:11.5px;color:var(--ink2);background:var(--bg2);border:1px solid var(--line);border-radius:7px;padding:3px 8px}

/* ---- 正在 roll 橫幅 ---- */
.nowroll{margin:12px 0;background:linear-gradient(135deg,#2A1810,#3A2113);border:1.5px solid var(--roll);
  border-radius:14px;padding:14px;display:flex;align-items:center;gap:12px}
.nowroll .dot{width:12px;height:12px;border-radius:50%;background:var(--roll);box-shadow:0 0 0 0 var(--roll);
  animation:pulse 1.4s infinite;flex-shrink:0}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(224,112,58,.6)}70%{box-shadow:0 0 0 12px rgba(224,112,58,0)}100%{box-shadow:0 0 0 0 rgba(224,112,58,0)}}
.nowroll .no{font-weight:800;color:var(--roll);font-size:16px}
.nowroll .desc{color:var(--ink);font-size:14px;margin-top:2px;line-height:1.4}
.nowroll.idle{background:var(--bg2);border-color:var(--line)}
.nowroll.idle .dot{background:var(--ink2);animation:none}
.nowroll.idle .no{color:var(--ink2)}

/* ---- 分鏡卡 ---- */
.seg-head{font-weight:800;font-size:15px;color:var(--gold);margin:18px 4px 8px;letter-spacing:1px;
  display:flex;align-items:center;gap:8px}
.seg-head .c{font-size:12px;color:var(--ink2);font-weight:600}
.shot{background:var(--bg2);border:1px solid var(--line);border-radius:13px;padding:12px 13px;margin-bottom:9px;
  display:flex;gap:11px;align-items:flex-start;transition:border-color .2s}
.shot.done{opacity:.62}
.shot.cur{border-color:var(--roll);background:#221710}
.shot .chk{width:30px;height:30px;border-radius:9px;border:2px solid var(--gold-dim);background:transparent;
  flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:18px;color:#15130F;margin-top:1px}
.shot.done .chk{background:var(--done);border-color:var(--done)}
.shot .chk.ro{border-style:dashed;opacity:.5}
.shot .body{flex:1;min-width:0}
.shot .no{font-weight:800;font-size:15px;color:var(--gold)}
.shot.done .no{color:var(--ink2);text-decoration:line-through}
.shot .d{font-size:14px;line-height:1.45;margin-top:2px}
.shot .meta{font-size:12px;color:var(--ink2);margin-top:5px;line-height:1.5}
.shot .meta b{color:var(--ink);font-weight:600}
.shot .row{display:flex;align-items:center;gap:8px;margin-top:9px;flex-wrap:wrap}
.shot .take{font-size:12px;color:var(--ink2)}
.shot .mini{background:var(--bg3);border:1px solid var(--line);color:var(--ink);border-radius:8px;padding:5px 10px;font-size:12.5px;font-weight:600}
.shot .mini.roll{border-color:var(--roll);color:var(--roll)}
.shot .mini.roll.on{background:var(--roll);color:#15130F}
.shot .doneby{font-size:11px;color:var(--done)}
.shot .filerow{display:flex;align-items:center;gap:7px;margin-top:8px;font-size:12px;color:var(--ink2)}
.shot .filerow .fileno{flex:1;max-width:200px;background:var(--bg3);border:1px solid var(--line);border-radius:8px;color:var(--ink);padding:6px 9px;font-size:13px}
.shot .filerow .fileno:focus{border-color:var(--gold-dim)}
.shot .filerow .send{flex:0 0 auto}
.shot .take.fno{color:var(--gold)}
.shot .mini.rst{color:var(--ink2);font-size:14px}

/* ---- 通告 / 在線 ---- */
.card{background:var(--bg2);border:1px solid var(--line);border-radius:13px;padding:14px;margin-bottom:10px}
.kv{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--line);font-size:14.5px}
.kv:last-child{border:none}.kv .k{color:var(--ink2)}.kv .v{font-weight:600;text-align:right}
.roster{display:flex;flex-wrap:wrap;gap:7px}
.who{background:var(--bg2);border:1px solid var(--line);border-radius:9px;padding:6px 10px;font-size:13px}
.who .g{color:var(--gold);font-weight:700}.who.on{border-color:var(--edit)}
.who .liveon{color:var(--edit)}.who .liveoff{color:var(--ink2)}
.gp{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--line)}
.gp .n{flex:1;font-weight:600}
.seg-sel{display:flex;gap:6px}.seg-sel button{background:var(--bg3);border:1px solid var(--line);color:var(--ink2);border-radius:8px;padding:6px 11px;font-size:13px;font-weight:600}
.seg-sel button.on{background:var(--edit);color:#15130F;border-color:var(--edit)}
.seg-sel button.on.v{background:var(--ink2);color:#15130F}

/* ---- 置中卡(加入/建立/landing) ---- */
.center{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:24px 18px}
.brand{text-align:center;margin-bottom:26px}
.brand h1{font-size:22px;font-weight:800;letter-spacing:2px;margin:0}
.brand p{color:var(--ink2);font-size:13px;margin:6px 0 0}
.panel{background:var(--bg2);border:1px solid var(--line);border-radius:18px;padding:20px}
.share{background:var(--bg3);border:1px dashed var(--gold-dim);border-radius:11px;padding:11px 12px;font-size:13px;
  word-break:break-all;margin-top:6px;color:var(--gold)}
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:#000;color:#fff;
  padding:11px 18px;border-radius:11px;font-size:14px;z-index:100;max-width:90%;text-align:center;box-shadow:0 4px 16px #0009}
.pad{padding:14px 0 80px}
.ro-note{font-size:12px;color:var(--ink2);background:var(--bg2);border:1px solid var(--line);border-radius:9px;padding:7px 11px;margin:8px 0}

/* ===== 看板版型：直式(預設) / 橫式雙欄(電腦・平板手機轉橫) ===== */
.topbar .bar-in{max-width:1300px;margin:0 auto}
.stage{max-width:680px;margin:0 auto;padding:12px 14px 90px}
.tabbody{margin-top:6px}
.stage.wide{max-width:1300px;display:grid;grid-template-columns:minmax(0,1fr) 384px;gap:22px;align-items:start;padding:18px 22px 60px}
.stage.wide .col-main{min-width:0}
.stage.wide .col-side{min-width:0}
.stage.wide .col-main .seg-head:first-child,.stage.wide .col-side .seg-head:first-child{margin-top:2px}
.stage.wide .nowroll{margin-top:0}

/* 現場通告橫幅(topbar) */
.livebanner{margin-top:10px;border-radius:11px;padding:9px 13px;display:flex;align-items:center;gap:9px;font-size:14px;border:1.5px solid var(--gold-dim);background:var(--bg3)}
.livebanner .ic{font-size:18px}
.livebanner .m{font-weight:700;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.livebanner .by{font-size:11.5px;color:var(--ink2);flex-shrink:0}
.k-rest{border-color:#6E8FB0;background:#1A2230}
.k-meal{border-color:var(--gold);background:#2A2114}
.k-wrap{border-color:var(--danger);background:#2A1414}
.k-move{border-color:var(--edit);background:#16241A}
.reddot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--roll);vertical-align:middle;margin-left:2px}

/* 發通告 composer */
.composer .ctitle{font-weight:800;font-size:14px;color:var(--gold);margin-bottom:9px}
.composer.compact{margin-bottom:10px}
.quickbtns{display:flex;flex-wrap:wrap;gap:7px}
.qb{background:var(--bg3);border:1px solid var(--gold-dim);color:var(--ink);border-radius:10px;padding:10px 13px;font-size:14px;font-weight:700;flex:1;min-width:74px}
.qb:active{background:var(--gold);color:#15130F}
.qb.more{flex:0 0 auto;color:var(--ink2);border-style:dashed}
.field2{display:flex;gap:7px;margin-top:9px}
.field2 input{flex:1}
.btn.send{width:auto;padding:0 18px;flex-shrink:0;font-size:15px}

/* 通告 feed */
.feed{padding:4px 14px}
.annrow{display:flex;gap:10px;padding:11px 0 11px 8px;border-bottom:1px solid var(--line);border-left:3px solid transparent}
.annrow:last-child{border-bottom:none}
.annrow .ic{font-size:18px}
.annrow .m{font-weight:600;font-size:14.5px}
.annrow .by{font-size:11.5px;color:var(--ink2);margin-top:2px}
.annrow.k-rest{border-left-color:#6E8FB0}.annrow.k-meal{border-left-color:var(--gold)}
.annrow.k-wrap{border-left-color:var(--danger)}.annrow.k-move{border-left-color:var(--edit)}

/* 全螢幕醒目通告 toast */
.anntoast{position:fixed;left:50%;top:84px;transform:translateX(-50%);z-index:200;display:flex;align-items:center;gap:13px;min-width:280px;max-width:92%;background:#15130F;border:2px solid var(--gold);border-radius:16px;padding:16px 20px;box-shadow:0 12px 44px #000c;cursor:pointer;animation:annin .35s cubic-bezier(.2,1.4,.4,1)}
.anntoast .ic{font-size:34px;flex-shrink:0}
.anntoast .m{font-size:18px;font-weight:800;line-height:1.3}
.anntoast .by{font-size:12px;color:var(--ink2);margin-top:3px}
.anntoast.k-rest{border-color:#6E8FB0}.anntoast.k-meal{border-color:var(--gold)}
.anntoast.k-wrap{border-color:var(--danger)}.anntoast.k-move{border-color:var(--edit)}
.anntoast.out{animation:annout .3s forwards}
@keyframes annin{from{opacity:0;transform:translate(-50%,-18px)}to{opacity:1;transform:translate(-50%,0)}}
@keyframes annout{to{opacity:0;transform:translate(-50%,-18px)}}

/* admin 可發通告切換 */
.seg-sel button.on.a{background:var(--gold);color:#15130F;border-color:var(--gold)}

/* ===== 場 / 鏡頭層級 ===== */
.scene-strip{display:flex;gap:7px;overflow-x:auto;padding:2px 0 11px;-webkit-overflow-scrolling:touch}
.scene-strip::-webkit-scrollbar{height:0}
.scene-chip{flex:0 0 auto;background:var(--bg2);border:1px solid var(--line);color:var(--ink2);border-radius:10px;padding:7px 12px;font-size:13px;font-weight:700;white-space:nowrap}
.scene-chip b{color:var(--ink);margin-left:2px}
.scene-chip.full{opacity:.5}
.scene-chip.cur{background:#221710;border-color:var(--roll);color:var(--roll)}
.scene-chip.cur b{color:var(--roll)}
.scene{margin-bottom:8px}
.scene-head{display:flex;align-items:center;gap:9px;background:var(--bg2);border:1px solid var(--line);border-radius:12px;padding:11px 13px;cursor:pointer;user-select:none}
.scene-head.cur{border-color:var(--roll);background:#221710}
.scene-head .caret{color:var(--ink2);font-size:12px;width:13px;flex-shrink:0}
.scene-head .nm{font-weight:800;font-size:16px;color:var(--gold);letter-spacing:1px}
.scene-head.cur .nm{color:var(--roll)}
.scene-head .scene-badge{font-size:11.5px;font-weight:800;color:#15130F;background:var(--roll);border-radius:6px;padding:2px 7px}
.scene-head .cnt{margin-left:auto;font-size:13px;color:var(--ink2);font-weight:700}
.scene-head .scene-set{background:var(--bg3);border:1px solid var(--roll);color:var(--roll);border-radius:8px;padding:6px 11px;font-size:12.5px;font-weight:700;flex-shrink:0}
.scene-body{padding:9px 0 2px}
.scene-body[hidden]{display:none}
.scene-now{font-size:12.5px;color:var(--roll);margin-top:5px;font-weight:700}

/* 統一入口：管理者切換連結 */
.adminlink{text-align:center;color:var(--gold);font-size:14px;font-weight:600;margin-top:16px;padding:8px;cursor:pointer}
.adminlink:active{opacity:.6}

/* ===== 全螢幕現場通告警報 ===== */
.annalert{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px;
  background:rgba(8,6,4,.88);backdrop-filter:blur(4px);animation:aafade .22s}
.annalert .aa-card{background:#15130F;border:3px solid var(--gold);border-radius:26px;padding:40px 30px 30px;text-align:center;
  max-width:460px;width:100%;box-shadow:0 0 0 6px rgba(201,168,106,.16),0 28px 80px #000;animation:aapop .42s cubic-bezier(.2,1.5,.4,1)}
.annalert.k-rest .aa-card{border-color:#6E8FB0;box-shadow:0 0 0 6px rgba(110,143,176,.18),0 28px 80px #000}
.annalert.k-meal .aa-card{border-color:var(--gold)}
.annalert.k-wrap .aa-card{border-color:var(--danger);box-shadow:0 0 0 6px rgba(201,107,107,.18),0 28px 80px #000}
.annalert.k-move .aa-card{border-color:var(--edit);box-shadow:0 0 0 6px rgba(127,176,132,.18),0 28px 80px #000}
.aa-ic{font-size:76px;line-height:1;animation:aashake .55s ease-in-out 2}
.aa-msg{font-size:30px;font-weight:900;margin-top:16px;line-height:1.25;letter-spacing:1px}
.aa-by{font-size:14px;color:var(--ink2);margin-top:12px}
.aa-ok{margin-top:26px;background:var(--gold);color:#15130F;border:none;border-radius:14px;padding:15px 0;width:100%;font-size:18px;font-weight:800;cursor:pointer}
.aa-ok:active{transform:scale(.98)}
.annalert.out{animation:aafadeout .28s forwards}
@keyframes aafade{from{opacity:0}to{opacity:1}}
@keyframes aafadeout{to{opacity:0}}
@keyframes aapop{from{transform:scale(.82);opacity:0}to{transform:scale(1);opacity:1}}
@keyframes aashake{0%,100%{transform:rotate(0)}25%{transform:rotate(-10deg)}75%{transform:rotate(10deg)}}

/* ===== 專案列表 dashboard ===== */
.proj{background:var(--bg2);border:1px solid var(--line);border-radius:14px;padding:15px;margin-bottom:11px}
.proj-name{font-weight:800;font-size:17px}
.proj-name .arch{font-size:11px;color:var(--ink2);background:var(--bg3);border:1px solid var(--line);border-radius:6px;padding:1px 6px;font-weight:600;vertical-align:middle;margin-left:6px}
.proj-sub{color:var(--ink2);font-size:13px;margin-top:4px}
.proj-act{display:flex;gap:8px;margin-top:12px}
.proj-act .btn{width:auto;flex:1;padding:11px 0;font-size:15px}
.backlist{color:var(--gold);font-size:13px;font-weight:700;cursor:pointer;margin-bottom:6px}
.backlist:active{opacity:.6}
.proj-act .reset{flex:0 0 46px;color:var(--gold);font-size:18px}
.proj-act .del{flex:0 0 50px;color:var(--danger);border-color:#5a3a3a}
.srcgrid{display:flex;flex-wrap:wrap;gap:7px}
.srcgrid .btn{flex:1;min-width:108px;width:auto;padding:11px 8px;font-size:14px}
.filebtn{display:flex;align-items:center;justify-content:center;text-align:center;cursor:pointer}
.panel.drop{outline:2px dashed var(--gold);outline-offset:-5px;background:#241f16}
