/* waar.today — dark production-timeline theme */
:root{
  --bg:#0b0d12; --panel:#13161f; --panel2:#191d28; --panel3:#1f2431;
  --line:#252a37; --line2:#323848;
  --text:#e7e9f0; --muted:#9aa3b6; --muted2:#6c7488;
  --accent:#f59e0b; --accent2:#fbbf24;
  --radius:14px; --radius-sm:10px;
  --shadow:0 8px 30px rgba(0,0,0,.35);
  --st-todo:#64748b; --st-progress:#3b82f6; --st-review:#a855f7; --st-done:#22c55e; --st-overdue:#ef4444;
}
.st-todo{--c:var(--st-todo)} .st-progress{--c:var(--st-progress)} .st-review{--c:var(--st-review)}
.st-done{--c:var(--st-done)} .st-overdue{--c:var(--st-overdue)}

*{box-sizing:border-box}
html,body{margin:0}
body{
  background:
    radial-gradient(1200px 600px at 85% -10%, rgba(245,158,11,.06), transparent 60%),
    radial-gradient(900px 500px at -10% 110%, rgba(59,130,246,.06), transparent 55%),
    var(--bg);
  color:var(--text);
  font-family:Inter,system-ui,Segoe UI,Roboto,Arial,sans-serif;
  font-size:14px; line-height:1.45; -webkit-font-smoothing:antialiased; min-height:100vh;
}
a{color:inherit;text-decoration:none}
h1{font-size:21px;font-weight:800;margin:0;letter-spacing:-.01em}
h3{font-size:16px;font-weight:700;margin:0 0 4px}
.muted{color:var(--muted)} .sm{font-size:12px} .center{text-align:center}
.mono{font-family:"JetBrains Mono",ui-monospace,monospace;font-size:12.5px}
.nowrap{white-space:nowrap}
.lead{margin:-6px 0 14px;color:var(--muted)}
.clamp2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.ic{width:18px;height:18px;flex:none}

/* ---------- top bar ---------- */
.topbar{
  display:flex;align-items:center;gap:14px;padding:11px 18px;
  background:rgba(13,16,23,.85);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);position:sticky;top:0;z-index:30;
}
.brand{display:flex;align-items:center;gap:7px;font-size:16px;font-weight:700}
.brand .logo{display:grid;place-items:center;width:26px;height:26px;border-radius:8px;
  background:linear-gradient(135deg,var(--accent),#b45309);color:#1a1205;font-weight:800;font-size:13px}
.brand .tld{color:var(--accent2)}
.nav{display:flex;gap:4px;margin-left:8px}
.navlink{display:flex;align-items:center;gap:7px;padding:8px 12px;border-radius:10px;color:var(--muted);font-weight:600;font-size:13px}
.navlink:hover{background:var(--panel2);color:var(--text)}
.navlink.active{background:var(--panel3);color:var(--text)}
.navlink.active .ic{color:var(--accent2)}
.spacer{flex:1}
.langtoggle{display:flex;gap:2px;background:var(--panel2);border:1px solid var(--line);border-radius:9px;padding:2px}
.langtoggle a{padding:4px 9px;border-radius:7px;font-size:12px;font-weight:700;color:var(--muted)}
.langtoggle a.on{background:var(--accent);color:#1a1205}
.me{display:flex;align-items:center;gap:9px}
.me-name{display:flex;flex-direction:column;line-height:1.15;font-weight:600;font-size:12.5px}
.me-name small{color:var(--muted2);font-weight:500;font-size:10.5px}
.avatar{display:grid;place-items:center;width:30px;height:30px;border-radius:9px;flex:none;
  background:color-mix(in srgb,var(--c,#f59e0b) 30%,#0b0d12);color:#fff;font-weight:700;font-size:13px;
  border:1px solid color-mix(in srgb,var(--c,#f59e0b) 55%,transparent)}
.avatar.sm{width:22px;height:22px;border-radius:7px;font-size:11px}
.iconbtn{display:inline-grid;place-items:center;width:32px;height:32px;border-radius:9px;border:1px solid transparent;
  background:transparent;color:var(--muted);cursor:pointer}
.iconbtn:hover{background:var(--panel2);color:var(--text)}
.iconbtn.danger:hover{color:var(--st-overdue)}

/* ---------- layout ---------- */
.wrap{max-width:1240px;margin:0 auto;padding:22px 18px 60px}
.page-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:16px}
.page-head h1{display:flex;align-items:center;gap:10px}
.row-actions{display:flex;gap:8px}
.crumbs{margin-bottom:10px}
.crumbs a{display:inline-flex;align-items:center;gap:5px;color:var(--muted);font-size:12.5px;font-weight:600}
.crumbs a:hover{color:var(--text)}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 14px;border-radius:10px;border:1px solid var(--line2);
  background:var(--panel2);color:var(--text);font:inherit;font-weight:600;font-size:13px;cursor:pointer;transition:.12s}
.btn:hover{background:var(--panel3)}
.btn.primary{background:linear-gradient(135deg,var(--accent),#d97706);border-color:transparent;color:#1a1205}
.btn.primary:hover{filter:brightness(1.07)}
.btn.ghost{background:transparent}
.btn.block{width:100%;justify-content:center;padding:11px}
.btn.sm{padding:7px 11px;font-size:12px}
.btn.danger-ghost{background:transparent;border-color:transparent;color:var(--st-overdue)}
.btn.danger-ghost:hover{background:color-mix(in srgb,var(--st-overdue) 14%,transparent)}
.iconbtn-lg{width:44px;height:44px;border-radius:11px;display:grid;place-items:center;padding:0}

/* ---------- panels / cards ---------- */
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px;margin-bottom:18px;box-shadow:var(--shadow)}
.panel-h{display:flex;align-items:center;gap:8px;font-weight:700;font-size:14px;margin-bottom:12px}
.panel-h .ic{color:var(--accent2)}
.panel-h .count{margin-left:4px;background:var(--panel3);color:var(--muted);border-radius:20px;padding:1px 9px;font-size:12px;font-weight:600}
.empty-big{text-align:center;color:var(--muted);padding:42px}
.dotc{width:11px;height:11px;border-radius:50%;flex:none;background:var(--c,#888);box-shadow:0 0 0 3px color-mix(in srgb,var(--c,#888) 22%,transparent)}
.dotc.lg{width:14px;height:14px}

.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:15px;transition:.14s;display:block}
.card:hover{border-color:var(--line2);transform:translateY(-2px)}
.card-top{display:flex;align-items:center;gap:9px;font-size:15px;margin-bottom:7px}
.card .bar{height:7px;border-radius:6px;background:var(--panel3);overflow:hidden;margin:12px 0 9px}
.card .bar i{display:block;height:100%;background:var(--c,#3b82f6);border-radius:6px}
.card-meta{display:flex;gap:10px;align-items:center;flex-wrap:wrap;color:var(--muted);font-size:12px}
.pill{padding:2px 8px;border-radius:20px;font-size:11px;font-weight:700;
  background:color-mix(in srgb,var(--c) 18%,transparent);color:color-mix(in srgb,var(--c) 75%,#fff)}

/* ---------- KPIs ---------- */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;margin-bottom:16px}
.kpi{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-sm);padding:13px 15px;display:flex;flex-direction:column;gap:2px;position:relative;overflow:hidden}
.kpi::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--c,var(--accent))}
.kpi-n{font-size:26px;font-weight:800;color:var(--c,var(--text));line-height:1}
.kpi-l{font-size:12px;color:var(--muted)}

/* ---------- toolbar / tabs / legend ---------- */
.toolbar{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:12px}
.tabs{display:flex;gap:4px;background:var(--panel);border:1px solid var(--line);border-radius:11px;padding:3px}
.tab{display:flex;align-items:center;gap:7px;padding:8px 13px;border-radius:8px;color:var(--muted);font-weight:600;font-size:13px;cursor:pointer}
.tab .ic{width:16px;height:16px}
.tab.on{background:var(--panel3);color:var(--text)}
.tab.on .ic{color:var(--accent2)}
.legend{display:flex;gap:14px;flex-wrap:wrap;color:var(--muted);font-size:12px}
.legend span{display:flex;align-items:center;gap:6px}
.sw{width:11px;height:11px;border-radius:3px;background:var(--c)}

/* ---------- tables ---------- */
.tbl-scroll{overflow-x:auto}
.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl th{text-align:left;color:var(--muted2);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.04em;padding:8px 10px;border-bottom:1px solid var(--line)}
.tbl td{padding:9px 10px;border-bottom:1px solid var(--line)}
.tbl tr:last-child td{border-bottom:none}
.tbl tr:hover td{background:var(--panel2)}
.tbl tr.dim{opacity:.5}
.lk{font-weight:600}.lk:hover{color:var(--accent2)}
.who{display:inline-flex;align-items:center;gap:7px}
.badge{display:inline-flex;align-items:center;padding:3px 9px;border-radius:7px;font-size:11.5px;font-weight:700;
  background:color-mix(in srgb,var(--c) 16%,transparent);color:color-mix(in srgb,var(--c) 78%,#fff);
  border:1px solid color-mix(in srgb,var(--c) 35%,transparent)}
.rtag{font-size:10.5px;font-weight:700;color:var(--muted2)}
.rtag.role-admin{color:var(--accent2)} .rtag.role-head{color:var(--st-progress)} .rtag.role-editor{color:var(--muted)}
form.inline{display:inline}

/* ---------- TIMELINE (gantt) ---------- */
.tl-panel{padding:14px 16px 18px}
.tl{--lh:188px;--rowh:34px;font-size:12px;width:100%}
.tl-axis{display:flex;align-items:flex-end;height:24px;margin-bottom:4px}
.tl-axis-head{width:var(--lh);flex:none}
.tl-axis-track{position:relative;flex:1;height:100%}
.tl-tick{position:absolute;top:0;bottom:0}
.tl-tick.lbl span{position:absolute;bottom:0;left:3px;color:var(--muted2);font-size:10.5px;white-space:nowrap}
.tl-now-lbl{position:absolute;bottom:0;transform:translateX(-50%);color:var(--accent2);font-size:10px;font-weight:800;white-space:nowrap}
.tl-group{display:flex;align-items:center;gap:9px;padding:11px 4px 5px;font-weight:700;border-top:1px solid var(--line);margin-top:5px}
.tl-group:first-of-type{border-top:none;margin-top:0;padding-top:2px}
.tl-group small{color:var(--muted2);font-weight:500;font-size:11px}
.tl-lane{display:flex;align-items:stretch;min-height:var(--rowh)}
.tl-lane:hover .tl-track{background:rgba(255,255,255,.012)}
.tl-lane-head{width:var(--lh);flex:none;display:flex;align-items:center;gap:8px;padding:3px 12px 3px 6px;overflow:hidden}
.tl-lane-head .ll{min-width:0}
.ll b{display:block;font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ll small{display:block;color:var(--muted2);font-size:10.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tl-track{position:relative;flex:1;border-left:1px solid var(--line)}
.tl-gl{position:absolute;top:0;bottom:0;border-left:1px solid rgba(255,255,255,.035)}
.tl-glnow{position:absolute;top:0;bottom:0;border-left:1.5px solid color-mix(in srgb,var(--accent) 60%,transparent);z-index:1}
.tl-bar{position:absolute;top:50%;transform:translateY(-50%);height:23px;border-radius:7px;display:flex;align-items:center;
  padding:0 9px;overflow:hidden;cursor:pointer;z-index:2;text-decoration:none;
  background:color-mix(in srgb,var(--c) 24%,#0b0d12);border:1px solid color-mix(in srgb,var(--c) 55%,transparent);
  box-shadow:inset 3px 0 0 var(--c);transition:.12s}
.tl-bar:hover{filter:brightness(1.18);box-shadow:inset 3px 0 0 var(--c),0 4px 14px rgba(0,0,0,.4);z-index:3}
.tl-bar-t{font-size:11px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#eef2f9}
.tl-empty{text-align:center;color:var(--muted2);padding:30px}

/* ---------- job list (editor) ---------- */
.joblist{display:flex;flex-direction:column;gap:9px}
.job-card{display:flex;align-items:center;gap:12px;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:0;overflow:hidden;transition:.12s}
.job-card:hover{border-color:var(--line2);transform:translateX(2px)}
.job-card .ic{color:var(--muted2);margin-right:14px;flex:none}
.bar-side{width:5px;align-self:stretch;background:var(--c);flex:none}
.job-main{flex:1;min-width:0;padding:12px 0}
.job-top{display:flex;align-items:center;gap:8px;font-size:14px}
.job-top b{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.job-sub{font-size:12px;margin-top:2px}

/* ---------- job detail + chat ---------- */
.job-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.25fr);gap:18px;align-items:start}
.job-detail .jd-head{display:flex;gap:11px;align-items:flex-start;margin-bottom:14px}
.jd-head h1{font-size:19px}
.status-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:16px}
.seg{display:flex;gap:3px;background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:3px}
.seg-b{padding:6px 11px;border-radius:7px;border:none;background:transparent;color:var(--muted);font:inherit;font-weight:600;font-size:12px;cursor:pointer}
.seg-b:hover{color:var(--text)}
.seg-b.on{background:color-mix(in srgb,var(--c) 26%,#0b0d12);color:#fff;box-shadow:inset 2px 0 0 var(--c)}
.kv{display:grid;grid-template-columns:1fr 1fr;gap:13px 18px;margin:0}
.kv>div{display:flex;flex-direction:column;gap:3px}
.kv dt{color:var(--muted2);font-size:11px;text-transform:uppercase;letter-spacing:.03em}
.kv dd{margin:0;font-weight:600}
.notes{margin-top:16px;padding-top:14px;border-top:1px solid var(--line)}
.notes p{margin:5px 0 0;color:var(--text)}

.chat{display:flex;flex-direction:column;height:min(72vh,640px);padding:0;overflow:hidden}
.chat .panel-h{padding:14px 16px;margin:0;border-bottom:1px solid var(--line)}
.chat-log{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}
.chat-empty{margin:auto;color:var(--muted2)}
.msg{display:flex;gap:8px;max-width:82%}
.msg.mine{align-self:flex-end;flex-direction:row-reverse}
.bubble{background:var(--panel2);border:1px solid var(--line);border-radius:13px;padding:8px 12px;border-top-left-radius:4px}
.msg.mine .bubble{background:color-mix(in srgb,var(--accent) 18%,var(--panel2));border-color:color-mix(in srgb,var(--accent) 30%,transparent);border-radius:13px;border-top-right-radius:4px}
.msg-who{font-size:11px;font-weight:700;color:var(--accent2);margin-bottom:2px}
.msg-who .rtag{margin-left:4px}
.msg-body{font-size:13.5px;word-wrap:break-word;overflow-wrap:anywhere}
.bubble time{display:block;font-size:10px;color:var(--muted2);margin-top:3px;text-align:right}
.chat-input{display:flex;gap:9px;padding:12px;border-top:1px solid var(--line);align-items:flex-end}
.chat-input textarea{flex:1;resize:none;max-height:120px;background:var(--panel2);border:1px solid var(--line2);border-radius:11px;
  color:var(--text);font:inherit;font-size:13.5px;padding:11px 13px;outline:none}
.chat-input textarea:focus{border-color:var(--accent)}

/* ---------- forms / dialogs ---------- */
.field{display:flex;flex-direction:column;gap:5px;margin-bottom:13px}
.field>span{font-size:12px;font-weight:600;color:var(--muted)}
input,select,textarea{background:var(--panel2);border:1px solid var(--line2);border-radius:10px;color:var(--text);
  font:inherit;font-size:14px;padding:10px 12px;outline:none;width:100%}
input:focus,select:focus,textarea:focus{border-color:var(--accent)}
select{cursor:pointer}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.chk{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);cursor:pointer}
.chk input{width:auto}
.swatches{display:flex;gap:7px;flex-wrap:wrap}
.swatch{cursor:pointer}.swatch input{display:none}
.swatch i{display:block;width:26px;height:26px;border-radius:8px;background:var(--c);border:2px solid transparent;transition:.1s}
.swatch input:checked + i{border-color:#fff;transform:scale(1.08)}
.err{background:color-mix(in srgb,var(--st-overdue) 16%,transparent);border:1px solid color-mix(in srgb,var(--st-overdue) 40%,transparent);
  color:#fecaca;padding:9px 12px;border-radius:10px;font-size:13px;margin-bottom:12px;text-align:center}

dialog.dlg{border:1px solid var(--line2);background:var(--panel);color:var(--text);border-radius:16px;padding:0;
  width:min(520px,94vw);box-shadow:0 24px 70px rgba(0,0,0,.6)}
dialog.dlg::backdrop{background:rgba(5,7,11,.62);backdrop-filter:blur(3px)}
.dlg-body{padding:20px}
.dlg-body h3{margin-bottom:14px}
.dlg-foot{display:flex;justify-content:flex-end;gap:9px;margin-top:6px}
.dlg-foot.spread{justify-content:space-between}

/* ---------- login ---------- */
.loginwrap{min-height:100vh;display:grid;place-items:center;padding:20px}
.login-card{width:min(380px,94vw);background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:30px 26px;box-shadow:var(--shadow)}
.login-brand{display:flex;align-items:center;justify-content:center;gap:8px;font-size:22px;font-weight:800}
.login-brand .logo{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--accent),#b45309);color:#1a1205;font-size:16px}
.login-brand .tld{color:var(--accent2)}
.login-card .sub{margin:6px 0 20px}
.langtoggle.center{justify-content:center;display:inline-flex;width:auto;margin-inline:auto}
.loginwrap .langtoggle{background:transparent;border:none}
.loginwrap .langtoggle a{color:var(--muted2)} .loginwrap .langtoggle a.on{background:var(--panel3);color:var(--accent2)}

/* ---------- responsive ---------- */
@media (max-width:860px){
  .job-grid{grid-template-columns:1fr}
  .tl{--lh:128px}
  .me-name{display:none}
  .nav .navlink span{display:none}
  .legend{display:none}
}
@media (max-width:560px){
  .kv{grid-template-columns:1fr}
  .grid2{grid-template-columns:1fr}
  .wrap{padding:16px 12px 50px}
}
