:root{
  --bg:#0e1320; --bg2:#161d2e; --bg3:#1c2640; --line:#26304a;
  --fg:#e8edf7; --mut:#8a96b0; --acc:#3d7bff; --acc2:#1f9d6b;
  --warn:#d8863a; --err:#d8554a; --radius:14px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--bg); color:var(--fg);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","Apple SD Gothic Neo",Roboto,"Noto Sans KR",sans-serif;
  -webkit-text-size-adjust:100%; min-height:100vh;
  padding-bottom:env(safe-area-inset-bottom);
}

/* header */
.topbar{
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 18px;padding-top:calc(14px + env(safe-area-inset-top));
  border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--bg);z-index:10;
}
.brand{font-weight:700;font-size:18px;letter-spacing:-.3px}
.brand span{color:var(--acc);font-weight:600}
.status{font-size:13px;color:var(--mut);padding:5px 12px;border:1px solid var(--line);border-radius:20px;white-space:nowrap}
.status.ok{color:#fff;background:var(--acc2);border-color:var(--acc2)}
.status.off{color:var(--warn);border-color:var(--warn)}
.subtitle{margin:0;padding:8px 18px 0;color:var(--mut);font-size:13px;max-width:880px}

.wrap{max-width:880px;margin:0 auto;padding:16px;display:flex;flex-direction:column;gap:16px}

.card{background:var(--bg2);border:1px solid var(--line);border-radius:var(--radius);padding:16px}
.card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;gap:10px}
.card-head h2{margin:0;font-size:16px;font-weight:700;letter-spacing:-.2px}

.ghost{background:transparent;border:1px solid var(--line);color:var(--mut);border-radius:10px;padding:7px 12px;font-size:13px;cursor:pointer}
.ghost:hover{color:var(--fg);border-color:var(--acc)}
.primary{background:var(--acc);border:1px solid var(--acc);color:#fff;border-radius:10px;padding:12px 16px;font-size:15px;font-weight:700;cursor:pointer}
.primary:disabled{opacity:.5;cursor:wait}
.primary:active{transform:scale(.99)}

/* kanban */
.kanban{display:flex;gap:10px;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch}
.kstage{flex:0 0 auto;min-width:96px;background:var(--bg3);border:1px solid var(--line);border-radius:12px;padding:11px 12px;text-align:center}
.kstage .knum{font-size:24px;font-weight:800;line-height:1.1}
.kstage .klabel{font-size:11px;color:var(--mut);margin-top:5px;white-space:nowrap}
.kstage .kdot{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:4px;vertical-align:middle}

/* form */
.form{display:flex;flex-direction:column;gap:12px}
.form label{font-size:12px;color:var(--mut);display:flex;flex-direction:column;gap:5px}
.req{color:var(--warn)}
.form input[type=text],.form select{
  background:var(--bg);color:var(--fg);border:1px solid var(--line);border-radius:10px;
  padding:11px 12px;font-size:15px;width:100%;font-family:inherit
}
.form-row{display:flex;gap:12px;flex-wrap:wrap}
.form-row>label{flex:1;min-width:160px}
.langs{flex:1;min-width:160px;border:1px solid var(--line);border-radius:10px;padding:8px 12px 10px;margin:0}
.langs legend{font-size:12px;color:var(--mut);padding:0 4px}
.chk{flex-direction:row !important;align-items:center;gap:6px !important;font-size:13px !important;color:var(--fg) !important;display:inline-flex !important;margin:5px 12px 0 0}
.chk input{accent-color:var(--acc)}
.inline-msg{font-size:13px;min-height:18px}
.inline-msg.err{color:var(--err)}
.inline-msg.ok{color:var(--acc2)}

/* project list */
.proj-list{display:flex;flex-direction:column;gap:10px}
.proj{background:var(--bg3);border:1px solid var(--line);border-radius:12px;padding:13px 15px;cursor:pointer;transition:.12s}
.proj:hover{border-color:var(--acc)}
.proj-top{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}
.proj-title{font-weight:700;font-size:15px;line-height:1.35}
.proj-topic{font-size:13px;color:var(--mut);margin-top:4px;line-height:1.4}
.proj-meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:9px;align-items:center}
.chip{font-size:11px;padding:3px 8px;border-radius:20px;border:1px solid var(--line);color:var(--mut)}
.chip.prod{color:var(--acc);border-color:var(--acc)}
.time{font-size:11px;color:var(--mut);margin-left:auto}
.empty{color:var(--mut);font-size:14px;padding:16px 4px;text-align:center}

/* status badge */
.badge{font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px;white-space:nowrap;border:1px solid}
.badge.concept{color:#8a96b0;border-color:#3a435e}
.badge.scripted{color:#6fa8ff;border-color:#2f5290}
.badge.localized{color:#46c39a;border-color:#1f6e54}
.badge.spec_ready{color:#c9a25a;border-color:#7a5e2c}
.badge.rendered{color:#b58dff;border-color:#5a3f8a}
.badge.reviewing{color:#e0a64c;border-color:#8a5e22}
.badge.published{color:#fff;background:var(--acc2);border-color:var(--acc2)}
.badge.pending,.badge.queued{color:#8a96b0;border-color:#3a435e}
.badge.approved{color:#fff;background:var(--acc2);border-color:var(--acc2)}
.badge.rejected{color:#fff;background:var(--err);border-color:var(--err)}
.badge.failed,.badge.needs_auth{color:var(--err);border-color:var(--err)}

/* modal */
.modal{position:fixed;inset:0;z-index:50;display:flex;align-items:flex-end;justify-content:center}
.modal[hidden]{display:none}
.modal-back{position:absolute;inset:0;background:rgba(0,0,0,.6)}
.modal-box{position:relative;background:var(--bg2);border:1px solid var(--line);border-radius:18px 18px 0 0;
  width:100%;max-width:880px;max-height:92vh;overflow-y:auto;padding:0}
.modal-head{position:sticky;top:0;background:var(--bg2);display:flex;justify-content:space-between;align-items:center;
  padding:16px 18px;border-bottom:1px solid var(--line);z-index:2}
.modal-head h2{margin:0;font-size:17px;font-weight:700;line-height:1.3}
.modal-body{padding:16px 18px 32px}

.section{border-top:1px solid var(--line);margin-top:16px;padding-top:14px}
.section:first-child{border-top:none;margin-top:0;padding-top:0}
.section h3{font-size:13px;color:var(--mut);margin:0 0 10px;text-transform:uppercase;letter-spacing:.5px;font-weight:700}
.actions{display:flex;flex-wrap:wrap;gap:8px}
.btn{border:1px solid var(--line);background:var(--bg3);color:var(--fg);border-radius:10px;padding:10px 14px;font-size:14px;font-weight:600;cursor:pointer}
.btn:hover{border-color:var(--acc)}
.btn:disabled{opacity:.5;cursor:wait}
.btn.danger{border-color:var(--err);color:var(--err)}
.btn.go{background:var(--acc);border-color:var(--acc);color:#fff}
.btn.dl{background:var(--bg3);border-color:var(--acc2);color:#46c39a;text-decoration:none;display:inline-block}

/* lang tabs */
.ltabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}
.ltab{background:transparent;border:1px solid var(--line);color:var(--mut);border-radius:8px;padding:6px 12px;font-size:13px;font-weight:600;cursor:pointer}
.ltab.active{background:var(--bg3);color:var(--fg);border-color:var(--acc)}

.kv{font-size:14px;line-height:1.55;margin:0 0 10px}
.kv b{color:var(--mut);font-weight:600;display:block;font-size:12px;margin-bottom:2px}
.scenes{width:100%;border-collapse:collapse;font-size:13px;margin-top:6px}
.scenes th,.scenes td{border:1px solid var(--line);padding:8px 9px;text-align:left;vertical-align:top}
.scenes th{background:var(--bg3);color:var(--mut);font-size:12px;font-weight:700}
.scenes td.idx,.scenes td.dur{text-align:center;white-space:nowrap;color:var(--mut)}
.scenes .vp{color:#9fb0d0;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px}
.tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:5px}

.row-item{display:flex;align-items:center;gap:10px;flex-wrap:wrap;border:1px solid var(--line);border-radius:10px;padding:10px 12px;margin-bottom:8px;background:var(--bg3)}
.row-item .fname{font-size:13px;word-break:break-all;flex:1;min-width:120px}
.row-item a{color:var(--acc);text-decoration:none;font-size:13px}
.uploadbar{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-top:8px}
.uploadbar select{background:var(--bg);color:var(--fg);border:1px solid var(--line);border-radius:8px;padding:8px 10px;font-size:13px}
.uploadbar input[type=file]{font-size:13px;color:var(--mut);flex:1;min-width:140px}

.loading{color:var(--mut);font-size:13px;padding:8px 0}
.spin{display:inline-block;width:13px;height:13px;border:2px solid var(--line);border-top-color:var(--acc);border-radius:50%;animation:spin .7s linear infinite;vertical-align:middle;margin-right:6px}
@keyframes spin{to{transform:rotate(360deg)}}

/* toast */
.toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%);z-index:99;
  background:var(--bg3);border:1px solid var(--line);color:var(--fg);padding:12px 18px;border-radius:12px;
  font-size:14px;max-width:90vw;box-shadow:0 8px 28px rgba(0,0,0,.5);line-height:1.45}
.toast[hidden]{display:none}
.toast.err{border-color:var(--err)}
.toast.warn{border-color:var(--warn)}
.toast.ok{border-color:var(--acc2)}

@media(min-width:640px){
  .modal{align-items:center}
  .modal-box{border-radius:18px;max-height:88vh}
}
@media(max-width:560px){
  .form-row{flex-direction:column;gap:12px}
}
