@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500;700&family=Roboto+Mono:wght@400;500&display=swap');

:root {
  --bg:        #1c1c1c;
  --bg2:       #292929;
  --bg3:       #313131;
  --bg4:       #383838;
  --bg5:       #404040;
  --border:    #3a3a3a;
  --border2:   #484848;
  --text:      #e8e8e8;
  --text2:     #a0a0a0;
  --text3:     #606060;
  --green:     #7ebf00;
  --green2:    #6aaa00;
  --green-bg:  rgba(126,191,0,0.12);
  --green-dim: rgba(126,191,0,0.06);
  --danger:    #e05252;
  --danger-bg: rgba(224,82,82,0.12);
  --warn:      #e09000;
  --sidebar-w: 224px;
  --radius:    5px;
  --radius2:   8px;

  --ss-wait-bg:              #1f1900; --ss-wait-fg:              #c49a00;
  --ss-ready_to_start-bg:    #0d1f0d; --ss-ready_to_start-fg:    #7ebf00;
  --ss-in_progress-bg:       #0d1830; --ss-in_progress-fg:       #5b9bd5;
  --ss-review-bg:            #2a1800; --ss-review-fg:            #e09000;
  --ss-internal_approved-bg: #052a14; --ss-internal_approved-fg: #2ecc71;
  --ss-client_reviewing-bg:  #1a0a2e; --ss-client_reviewing-fg:  #b57bee;
  --ss-client_final-bg:      #001f3a; --ss-client_final-fg:      #0ea5e9;
  --ss-omit-bg:              #2a0d0d; --ss-omit-fg:              #e05252;

  --ts-wait-bg:           #1f1900;  --ts-wait-fg:           #c49a00;
  --ts-ready_to_start-bg: #0d1f0d;  --ts-ready_to_start-fg: #7ebf00;
  --ts-in_progress-bg:    #0d1830;  --ts-in_progress-fg:    #5b9bd5;
  --ts-review-bg:         #2a1800;  --ts-review-fg:         #e09000;
  --ts-feedback-bg:       #2a0a1f;  --ts-feedback-fg:       #e85aa6;
  --ts-approved-bg:       #052a14;  --ts-approved-fg:       #2ecc71;
  --ts-complete-bg:       #001f3a;  --ts-complete-fg:       #0ea5e9;
  --ts-omit-bg:           #2a0d0d;  --ts-omit-fg:           #e05252;

  --p-high:   #e05252;
  --p-medium: #e09000;
  --p-low:    #5b9bd5;
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { font-size:14px; }
body { font-family:'Roboto',sans-serif; background:var(--bg); color:var(--text); min-height:100vh; overflow-y:scroll; }
a { color:var(--green); text-decoration:none; }
a:hover { color:var(--green2); }

input,textarea,select {
  font-family:'Roboto',sans-serif; font-size:13px;
  background:var(--bg4); border:1px solid var(--border2);
  color:var(--text); border-radius:var(--radius); padding:7px 10px;
  outline:none; width:100%; transition:border-color .15s;
}
input:focus,textarea:focus,select:focus { border-color:var(--green); }
textarea { resize:vertical; min-height:70px; }
label { display:block; font-size:11px; color:var(--text2); margin-bottom:4px; font-weight:500;
        letter-spacing:.03em; text-transform:uppercase; }
button,.btn {
  font-family:'Roboto',sans-serif; font-size:13px; font-weight:500;
  padding:7px 14px; border-radius:var(--radius); border:none; cursor:pointer;
  display:inline-flex; align-items:center; gap:6px;
  transition:background .15s,opacity .15s; text-decoration:none;
}
.btn-primary { background:var(--green); color:#000; font-weight:700; }
.btn-primary:hover { background:var(--green2); color:#000; }
.btn-ghost  { background:var(--bg4); color:var(--text2); border:1px solid var(--border2); }
.btn-ghost:hover { background:var(--bg5); color:var(--text); }
.btn-danger { background:var(--danger-bg); color:var(--danger); border:1px solid rgba(224,82,82,.25); }
.btn-danger:hover { background:var(--danger); color:#fff; }
.btn-sm  { padding:4px 10px; font-size:12px; }
.btn-xs  { padding:3px 8px; font-size:11px; }
.btn-icon { padding:5px; width:28px; height:28px; justify-content:center; }
button:disabled,.btn:disabled,.btn[disabled],button[disabled] {
  opacity:.4; cursor:not-allowed; filter:grayscale(.65);
}
button:disabled:hover,.btn:disabled:hover,.btn[disabled]:hover,button[disabled]:hover {
  background:inherit; color:inherit;
}

/* ── Sidebar ── */
.sidebar {
  width:var(--sidebar-w); min-height:100vh; background:var(--bg2);
  border-right:1px solid var(--border); display:flex; flex-direction:column;
  position:fixed; top:0; left:0; bottom:0; z-index:100; overflow-y:auto;
}
.sidebar-logo { padding:14px 16px; border-bottom:1px solid var(--border); display:flex; align-items:center; gap:10px; }
.sidebar-logo img { height:56px; display:block; }
.sidebar-logo .sub { font-size:9px; color:var(--text3); letter-spacing:.12em; text-transform:uppercase; font-family:'Roboto Mono',monospace; }
.nav-section { padding:6px 0; border-bottom:1px solid var(--border); }
.nav-label { font-size:9px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--text3); padding:8px 16px 4px; }
.nav-link { display:flex; align-items:center; gap:8px; padding:7px 16px; color:var(--text2); font-size:13px; transition:background .1s,color .1s; }
.nav-link:hover { background:var(--bg3); color:var(--text); }
.nav-link.active { color:var(--green); background:var(--green-dim); border-left:2px solid var(--green); padding-left:14px; }
.nav-link .dot { width:7px; height:7px; border-radius:50%; flex-shrink:0; }
.sidebar-footer { margin-top:auto; padding:12px 16px; border-top:1px solid var(--border); }
.user-avatar { width:26px; height:26px; border-radius:50%; background:var(--green-bg); border:1px solid var(--green); display:flex; align-items:center; justify-content:center; font-size:11px; font-weight:700; color:var(--green); flex-shrink:0; }
.user-chip { display:flex; align-items:center; gap:8px; }
.user-info .name { font-size:12px; font-weight:500; }
.user-info .role { font-size:10px; color:var(--text3); text-transform:capitalize; }

/* Notification bell — top-right topbar */
.notif-bell-top {
  position:relative; display:inline-flex; align-items:center; justify-content:center;
  width:36px; height:36px; border-radius:var(--radius2);
  color:var(--text2); border:1px solid var(--border); background:var(--bg3);
  transition:color .15s, border-color .15s, background .15s; flex-shrink:0;
}
.notif-bell-top:hover { color:var(--text); border-color:var(--border2); background:var(--bg4); }
.notif-bell-top.has-unread {
  color:var(--green); border-color:var(--green);
  background:var(--green-dim);
  animation:bell-pulse 2s ease-in-out infinite;
}
@keyframes bell-pulse {
  0%,100% { box-shadow:0 0 0 0 rgba(126,191,0,.4); }
  50%      { box-shadow:0 0 0 5px rgba(126,191,0,0); }
}
.notif-badge-top {
  position:absolute; top:-6px; right:-6px;
  background:var(--danger); color:#fff; border-radius:10px;
  font-size:10px; font-weight:800; padding:1px 5px; min-width:18px;
  text-align:center; border:2px solid var(--bg);
  font-family:'Roboto Mono',monospace;
}

/* Unread alert on item */
.unread-dot { width:8px; height:8px; border-radius:50%; background:var(--green); flex-shrink:0; animation:pulse 2s infinite; }
@keyframes pulse { 0%,100%{opacity:1;} 50%{opacity:.4;} }

/* ── Top navigation ── */
.topnav { display:flex; align-items:center; gap:14px; height:52px; background:var(--bg2); border-bottom:1px solid var(--border); padding:0 14px; position:sticky; top:0; z-index:100; }
.topnav-logo img { height:30px; display:block; }
.topnav-left { display:flex; align-items:center; gap:10px; flex:1; min-width:0; }
.topnav-right { display:flex; align-items:center; gap:8px; flex-shrink:0; }
.proj-select { background:var(--bg3); color:var(--text); border:1px solid var(--border2); border-radius:var(--radius2); padding:6px 10px; font-size:13px; font-weight:500; max-width:220px; cursor:pointer; }
.new-show-btn { display:inline-flex; align-items:center; justify-content:center; width:30px; height:30px; color:var(--green); font-size:18px; line-height:1; border:1px solid var(--border2); border-radius:var(--radius2); background:var(--bg3); flex-shrink:0; }
.new-show-btn:hover { background:var(--bg4); }
.tab-group { display:flex; align-items:center; gap:2px; }
.tab { display:inline-flex; align-items:center; gap:6px; padding:6px 12px; border-radius:var(--radius2); color:var(--text2); font-size:13px; white-space:nowrap; transition:background .1s,color .1s; }
.tab:hover { background:var(--bg3); color:var(--text); }
.tab.active { color:var(--green); background:var(--green-dim); }
.tab-divider { width:1px; height:26px; background:var(--border); margin:0 2px; }

/* User menu (native <details> dropdown) */
.user-menu { position:relative; }
.user-menu > summary { list-style:none; cursor:pointer; }
.user-menu > summary::-webkit-details-marker { display:none; }
.user-menu-pop { position:absolute; right:0; top:38px; background:var(--bg2); border:1px solid var(--border); border-radius:var(--radius2); min-width:175px; box-shadow:0 8px 24px rgba(0,0,0,.45); z-index:200; padding:6px; }
.user-menu-pop .user-menu-id { padding:8px 10px; border-bottom:1px solid var(--border); margin-bottom:4px; }
.user-menu-pop .user-menu-id .name { font-size:13px; font-weight:600; }
.user-menu-pop .user-menu-id .role { font-size:11px; color:var(--text3); text-transform:capitalize; }
.user-menu-pop a { display:block; padding:7px 10px; font-size:13px; color:var(--text2); border-radius:var(--radius); }
.user-menu-pop a:hover { background:var(--bg3); color:var(--text); }
.user-menu-sep { height:1px; background:var(--border); margin:5px 4px; }

/* ── Sub bar (breadcrumb + page actions) ── */
.subbar { display:flex; align-items:center; gap:8px; min-height:46px; padding:7px 20px; background:var(--bg); border-bottom:1px solid var(--border); position:sticky; top:52px; z-index:40; }
.subbar-actions { display:flex; align-items:center; gap:8px; margin-left:auto; }
.lens-header { display:flex; align-items:center; gap:14px; margin-bottom:14px; flex-wrap:wrap; }
.lens-header .stat-chips { margin-bottom:0; }
.lens-header-actions { display:flex; align-items:center; gap:8px; flex-shrink:0; margin-left:auto; }
.me-btn { padding:5px 12px; font-size:12px; color:var(--text2); background:var(--bg2); border:1px solid var(--border2); border-radius:var(--radius2); cursor:pointer; flex-shrink:0; font-family:inherit; transition:background .12s, color .12s, border-color .12s; }
.me-btn:hover { background:var(--bg3); color:var(--text); }
.me-btn.active { background:var(--green-dim); color:var(--green); border-color:var(--green); font-weight:600; }
.btn-reset-filters { display:inline-flex; align-items:center; gap:4px; padding:5px 12px; font-size:12px; border:1px solid var(--border); border-radius:var(--radius2); background:transparent; color:var(--text3); text-decoration:none; transition:color .12s, border-color .12s, background .12s; cursor:default; pointer-events:none; }
.btn-reset-filters.active { color:var(--warn); border-color:var(--warn); cursor:pointer; pointer-events:auto; }
.btn-reset-filters.active:hover { background:rgba(255,170,0,.08); }
.breadcrumb { display:flex; align-items:center; gap:6px; font-size:13px; color:var(--text3); flex:1; overflow:hidden; }
.breadcrumb a { color:var(--text2); white-space:nowrap; }
.breadcrumb a:hover { color:var(--text); }
.breadcrumb .sep { color:var(--text3); }
.breadcrumb .current { color:var(--text); font-weight:500; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.content { padding:24px; }

/* ── Flashes ── */
.flash-wrap { padding:0 24px; margin-top:10px; }
.flash { padding:10px 14px; border-radius:var(--radius); font-size:13px; margin-bottom:8px; border-left:3px solid; }
.flash.error   { background:var(--danger-bg); border-color:var(--danger); color:#fca5a5; }
.flash.success { background:rgba(126,191,0,.1); border-color:var(--green); color:#b8e05a; }

/* ── Page header ── */
.page-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:20px; flex-wrap:wrap; gap:12px; }
.page-title  { font-size:20px; font-weight:700; }

/* ── Cards ── */
.card { background:var(--bg2); border:1px solid var(--border); border-radius:var(--radius2); padding:18px; }
.card-title { font-size:11px; font-weight:700; color:var(--text3); margin-bottom:14px; display:flex; align-items:center; gap:8px; text-transform:uppercase; letter-spacing:.08em; }

/* ── Status pills ── */
.pill { display:inline-flex; align-items:center; padding:2px 8px; border-radius:3px; font-size:11px; font-weight:500; white-space:nowrap; }
.pill.wait              { background:var(--ss-wait-bg);              color:var(--ss-wait-fg); }
.pill.ready_to_start    { background:var(--ss-ready_to_start-bg);    color:var(--ss-ready_to_start-fg); }
.pill.in_progress       { background:var(--ss-in_progress-bg);       color:var(--ss-in_progress-fg); }
.pill.review            { background:var(--ss-review-bg);            color:var(--ss-review-fg); }
.pill.internal_approved { background:var(--ss-internal_approved-bg); color:var(--ss-internal_approved-fg); }
.pill.client_reviewing  { background:var(--ss-client_reviewing-bg);  color:var(--ss-client_reviewing-fg); }
.pill.client_final      { background:var(--ss-client_final-bg);      color:var(--ss-client_final-fg); }
.pill.omit              { background:var(--ss-omit-bg);              color:var(--ss-omit-fg); }
.pill.feedback          { background:var(--ts-feedback-bg);          color:var(--ts-feedback-fg); }
.pill.approved          { background:var(--ts-approved-bg);          color:var(--ts-approved-fg); }
.pill.complete          { background:var(--ts-complete-bg);          color:var(--ts-complete-fg); }

/* Priority badges */
.pbadge { font-size:10px; font-weight:700; padding:1px 5px; border-radius:3px; text-transform:uppercase; letter-spacing:.04em; }
.pbadge.high   { background:rgba(224,82,82,.15);  color:var(--p-high); }
.pbadge.medium { background:rgba(224,144,0,.12);  color:var(--p-medium); }
.pbadge.low    { background:rgba(91,155,213,.12); color:var(--p-low); }
.pbadge.none   { display:none; }

/* ── Status strip (item detail) ── */
.status-strip { display:flex; gap:4px; flex-wrap:wrap; align-items:center; padding:10px 14px; background:var(--bg2); border:1px solid var(--border); border-radius:var(--radius2); margin-bottom:14px; }
.status-btn { padding:3px 10px; border-radius:3px; font-size:11px; font-weight:500; border:1px solid transparent; cursor:pointer; font-family:'Roboto',sans-serif; transition:opacity .15s; }
.status-btn.active { outline:2px solid var(--green); outline-offset:2px; }
.status-btn.blocked { opacity:.3; cursor:not-allowed; pointer-events:none; }
.status-btn.s-omit  { background:var(--ss-omit-bg); color:var(--ss-omit-fg); border-color:rgba(224,82,82,.2); }
.status-btn.s-omit.active { outline-color:var(--danger); }

/* ── Tables ── */
.tbl-wrap { overflow-x:auto; }
table { width:100%; border-collapse:collapse; }
th { text-align:left; font-size:10px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--text3); padding:8px 12px; border-bottom:1px solid var(--border); white-space:nowrap; }
td { padding:8px 12px; border-bottom:1px solid var(--border); vertical-align:middle; font-size:13px; }
tr:last-child td { border-bottom:none; }
.mono { font-family:'Roboto Mono',monospace; font-size:12px; }

/* ── Thumbnails ── */
.shot-row td   { height:72px; }
.thumb-td      { padding:4px 0 4px 10px !important; vertical-align:top; }
.shot-thumb    { height:64px; width:114px; object-fit:cover; display:block; border-radius:3px; }
.shot-thumb-ph { height:64px; width:114px; background:var(--bg4); border:1px dashed var(--border2); display:flex; align-items:center; justify-content:center; font-size:9px; color:var(--text3); border-radius:3px; }

/* ── Progress bar ── */
.pbar  { height:3px; background:var(--bg5); border-radius:2px; overflow:hidden; }
.pfill { height:100%; background:var(--green); border-radius:2px; }
.pfill.full { background:#2ecc71; }

/* ── Subtask dots ── */
.sub-dots { display:flex; gap:3px; flex-wrap:wrap; }
.sdot { width:7px; height:7px; border-radius:50%; flex-shrink:0; }
.sdot.wait           { background:var(--ts-wait-fg); opacity:.5; }
.sdot.ready_to_start { background:var(--ts-ready_to_start-fg); }
.sdot.in_progress    { background:var(--ts-in_progress-fg); }
.sdot.review         { background:var(--ts-review-fg); }
.sdot.feedback       { background:var(--ts-feedback-fg); }
.sdot.approved       { background:var(--ts-approved-fg); }
.sdot.complete       { background:var(--ts-complete-fg); }
.sdot.omit           { background:var(--ts-omit-fg); }
/* Task name badges in My Tasks */
.task-badge { display:inline-block; border-radius:3px; padding:1px 5px; font-size:10px; font-weight:600; letter-spacing:.03em; }
.ts-wait            { background:var(--ts-wait-fg);           color:#000; opacity:.7; }
.ts-ready_to_start  { background:var(--ts-ready_to_start-fg); color:#000; }
.ts-in_progress     { background:var(--ts-in_progress-fg);    color:#fff; }
.ts-review          { background:var(--ts-review-fg);         color:#000; }
.ts-feedback        { background:var(--ts-feedback-fg);       color:#fff; }
.ts-approved        { background:var(--ts-approved-fg);       color:#000; }
.ts-complete        { background:var(--ts-complete-fg);       color:#fff; }
.ts-omit            { background:var(--ts-omit-fg);           color:#fff; opacity:.5; }

/* ── Job page filters ── */
.job-filters { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:16px; align-items:center; }
.job-filters input,.job-filters select { width:auto; font-size:12px; padding:5px 8px; }
.job-filters select.filter-modified,
.job-filters input[type="text"].filter-modified { border-color:var(--green); color:var(--green); background:var(--green-dim); }
.stat-chips { display:flex; gap:6px; flex-wrap:wrap; margin-bottom:14px; }
.schip { display:flex; align-items:center; gap:5px; padding:4px 10px; background:var(--bg3); border:1px solid var(--border); border-radius:3px; font-size:11px; cursor:pointer; text-decoration:none; color:var(--text2); transition:border-color .12s; }
.schip:hover,.schip.active { border-color:var(--green); color:var(--text); background:var(--green-dim); }
.schip .n { font-weight:700; color:var(--text); }

/* Type toggle */
.type-tabs { display:flex; gap:2px; background:var(--bg3); border:1px solid var(--border); border-radius:var(--radius); padding:3px; }
.type-tab { padding:4px 12px; border-radius:3px; font-size:11px; font-weight:500; color:var(--text3); cursor:pointer; text-decoration:none; transition:background .12s,color .12s; }
.type-tab:hover { color:var(--text); }
.type-tab.active { background:var(--green); color:#000; font-weight:700; }

/* ── Shot rows ── */
.shot-row { cursor:pointer; }
.shot-row:hover td { background:rgba(126,191,0,.07); }
.shot-row.omit-row td { opacity:.4; }
.shot-row.omit-row td:first-child { opacity:1; }
.asset-row td:nth-child(3) { color:var(--text3); }
.expand-row td { padding:0; background:var(--bg); }
.subtask-inline { padding:10px 16px 14px 88px; }
.subtask-inline table { background:var(--bg2); border-radius:var(--radius); }

/* ── Bulk bar ── */
.bulk-bar {
  position:fixed; bottom:24px; left:50%; transform:translateX(-50%) translateY(80px);
  background:var(--bg2); border:1px solid var(--green); border-radius:var(--radius2);
  padding:10px 16px; display:flex; align-items:center; gap:12px;
  box-shadow:0 8px 32px rgba(0,0,0,.5); z-index:200;
  transition:transform .2s ease; min-width:520px;
}
.bulk-bar.visible { transform:translateX(-50%) translateY(0); }
.bulk-count { font-size:12px; color:var(--text2); white-space:nowrap; }
.bulk-count strong { color:var(--green); }
.bulk-bar select { width:auto; min-width:110px; font-size:12px; padding:5px 8px; }

/* ── Item detail ── */
.item-header { display:flex; gap:18px; margin-bottom:20px; flex-wrap:wrap; }
.shot-thumb-lg { width:192px; height:108px; object-fit:cover; border-radius:var(--radius); border:1px solid var(--border2); flex-shrink:0; }
.shot-thumb-upload { width:192px; height:108px; border-radius:var(--radius); background:var(--bg4); border:1px dashed var(--border2); display:flex; flex-direction:column; align-items:center; justify-content:center; gap:6px; color:var(--text3); font-size:12px; cursor:pointer; flex-shrink:0; transition:border-color .15s; }
.shot-thumb-upload:hover { border-color:var(--green); color:var(--green); }
.item-title { font-family:'Roboto Mono',monospace; font-size:24px; font-weight:500; }
.meta-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(150px,1fr)); gap:10px; margin-top:14px; }
.meta-item .ml { font-size:10px; color:var(--text3); text-transform:uppercase; letter-spacing:.07em; margin-bottom:2px; }
.meta-item .mv { font-family:'Roboto Mono',monospace; font-size:12px; }
.vfx-desc { font-size:13px; color:var(--text2); line-height:1.7; }
.shot-link { color:var(--green); font-family:'Roboto Mono',monospace; font-size:12px; padding:0 3px; background:var(--green-bg); border-radius:3px; }
.shot-link:hover { background:var(--green); color:#000; }
.asset-link { background:rgba(181,123,238,.15); color:#b57bee; }
.asset-link:hover { background:#b57bee; color:#fff; }

/* ── Subtask table ── */
.st-status-sel,.st-assign-sel,.st-prio-sel {
  background:var(--bg3); border:1px solid transparent; color:var(--text);
  border-radius:var(--radius); padding:4px 6px; font-size:11px;
  font-family:'Roboto',sans-serif; cursor:pointer; width:auto;
}
.st-status-sel:hover,.st-assign-sel:hover,.st-prio-sel:hover { border-color:var(--border2); }
.st-status-sel:focus,.st-assign-sel:focus,.st-prio-sel:focus { border-color:var(--green); outline:none; }
.st-status-sel { min-width:120px; font-weight:500; }
/* Task status colour-coding (matches .pill.{status}) */
.st-status-sel.wait           { background:var(--ts-wait-bg);           color:var(--ts-wait-fg); }
.st-status-sel.ready_to_start { background:var(--ts-ready_to_start-bg); color:var(--ts-ready_to_start-fg); }
.st-status-sel.in_progress    { background:var(--ts-in_progress-bg);    color:var(--ts-in_progress-fg); }
.st-status-sel.review         { background:var(--ts-review-bg);         color:var(--ts-review-fg); }
.st-status-sel.feedback       { background:var(--ts-feedback-bg);       color:var(--ts-feedback-fg); }
.st-status-sel.approved       { background:var(--ts-approved-bg);       color:var(--ts-approved-fg); }
.st-status-sel.complete       { background:var(--ts-complete-bg);       color:var(--ts-complete-fg); }
.st-status-sel.omit           { background:var(--ts-omit-bg);           color:var(--ts-omit-fg); }
.st-status-sel option { background:var(--bg3); color:var(--text); }
.st-assign-sel { min-width:110px; }
.st-prio-sel   { min-width:80px; }
tr.omit-task td { opacity:.3; }
tr.omit-task td:first-child { opacity:1; }
.time-btn { background:none; border:none; font-family:'Roboto Mono',monospace; font-size:11px; color:var(--text3); cursor:pointer; padding:2px 4px; }
.time-btn.has-t { color:var(--green); }

/* Time expand */
.time-row td { padding:0; }
.time-inner { padding:10px 14px 14px; background:var(--bg3); border-bottom:1px solid var(--border); }
.time-entry { display:flex; justify-content:space-between; align-items:center; padding:4px 0; border-bottom:1px solid var(--border); font-size:12px; }
.time-entry:last-child { border-bottom:none; }
.time-add { display:flex; gap:8px; flex-wrap:wrap; align-items:flex-end; margin-top:10px; }
.time-add .fg { display:flex; flex-direction:column; gap:3px; }
.time-add .fg label { margin-bottom:0; }

/* ── Notes ── */
.note-card { background:var(--bg3); border:1px solid var(--border); border-radius:var(--radius); padding:8px 12px; margin-bottom:6px; }
.note-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:4px; gap:8px; }
.note-meta { font-size:11px; color:var(--text3); line-height:1.3; }
.note-meta strong { color:var(--green); }
.note-meta .note-date { display:block; font-size:10px; color:var(--text3); margin-top:1px; font-family:'Roboto Mono',monospace; }
.note-body { font-size:13px; color:var(--text2); line-height:1.3; white-space:pre-wrap; }
.note-actions-list { margin-top:6px; display:flex; flex-direction:column; gap:4px; padding-top:6px; border-top:1px solid var(--border); }
.action-item { display:flex; align-items:flex-start; gap:8px; font-size:12px; }
.action-item input[type=checkbox] { accent-color:var(--green); cursor:pointer; width:auto; flex-shrink:0; margin-top:2px; }
.action-item.done .action-text { text-decoration:line-through; color:var(--text3); }
.action-done-by { font-size:10px; color:var(--text3); margin-left:auto; white-space:nowrap; }
.note-add-form { background:var(--bg3); border:1px solid var(--border); border-radius:var(--radius); padding:14px 16px; }
.note-add-title { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--text3); margin-bottom:12px; }

/* subtask note panel */
.st-notes-panel { padding:8px 14px; background:var(--bg4); border-top:1px solid var(--border); }
.st-notes-panel .note-card { background:var(--bg3); }

/* ── Client log ── */
.cl-entry { background:var(--bg3); border:1px solid var(--border); border-radius:var(--radius); padding:12px 14px; margin-bottom:8px; }
.cl-header { display:flex; align-items:center; gap:10px; margin-bottom:8px; flex-wrap:wrap; }
.cl-date { font-family:'Roboto Mono',monospace; font-size:12px; color:var(--green); font-weight:500; }
.cl-version { background:var(--bg5); border-radius:3px; padding:2px 7px; font-size:11px; font-weight:700; color:var(--text2); }
.cl-items { font-size:13px; color:var(--text); line-height:1.6; }
.cl-feedback { margin-top:8px; padding:8px 10px; background:var(--bg4); border-radius:var(--radius); border-left:2px solid var(--warn); font-size:12px; color:var(--text2); }
.cl-feedback.empty { color:var(--text3); font-style:italic; }

/* ── Linked items ── */
.linked-item { display:flex; align-items:center; gap:8px; padding:6px 10px; background:var(--bg3); border:1px solid var(--border); border-radius:var(--radius); margin-bottom:6px; }
.linked-item .li-type { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:var(--text3); }

/* ── Dashboard ── */
.dash-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:14px; }
.jcard { background:var(--bg2); border:1px solid var(--border); border-radius:var(--radius2); padding:16px 18px; transition:border-color .15s; display:block; text-decoration:none; }
.jcard:hover { border-color:var(--border2); }
.jcard-name { font-size:16px; font-weight:700; color:var(--text); }
.jcard-client { font-size:12px; color:var(--text3); margin-top:1px; }
.jcard-meta { display:flex; gap:14px; margin:10px 0 8px; font-size:12px; color:var(--text2); }
.jcard-meta strong { color:var(--text); }
.sbar { display:flex; height:5px; border-radius:3px; overflow:hidden; gap:1px; margin-top:8px; }
.sbar-seg { height:100%; }
.sbar-seg.wait              { background:var(--ss-wait-fg); }
.sbar-seg.ready_to_start    { background:var(--ss-ready_to_start-fg); opacity:.5; }
.sbar-seg.in_progress       { background:var(--ss-in_progress-fg); }
.sbar-seg.review            { background:var(--ss-review-fg); }
.sbar-seg.internal_approved { background:var(--ss-internal_approved-fg); }
.sbar-seg.client_reviewing  { background:var(--ss-client_reviewing-fg); }
.sbar-seg.client_final      { background:var(--ss-client_final-fg); }
.sbar-seg.omit              { background:var(--ss-omit-fg); opacity:.4; }

/* ── Login ── */
.login-wrap { min-height:100vh; width:100%; display:flex; align-items:center; justify-content:center; background:var(--bg); background-image:radial-gradient(ellipse at 20% 50%, rgba(126,191,0,.04) 0%, transparent 60%); }
.login-card { width:360px; background:var(--bg2); border:1px solid var(--border2); border-radius:10px; padding:32px; }
.login-logo { margin-bottom:6px; }
.login-logo img { height:36px; }
.login-sub { font-size:11px; color:var(--text3); margin-bottom:24px; font-family:'Roboto Mono',monospace; letter-spacing:.06em; }

/* ── Forms ── */
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.form-grid.g3 { grid-template-columns:1fr 1fr 1fr; }
.fg { display:flex; flex-direction:column; gap:4px; margin-bottom:14px; }
.full { grid-column:1/-1; }
.form-title { font-size:18px; font-weight:700; margin-bottom:20px; }
.form-section { margin-bottom:20px; }
.form-section-title { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--text3); margin-bottom:12px; padding-bottom:8px; border-bottom:1px solid var(--border); }
.form-actions { display:flex; gap:8px; margin-top:8px; align-items:center; }
.tt-grid { display:flex; flex-wrap:wrap; gap:8px; }
.tt-pill { display:flex; align-items:center; gap:6px; padding:6px 12px; background:var(--bg4); border:1px solid var(--border2); border-radius:var(--radius); cursor:pointer; font-size:13px; user-select:none; transition:border-color .12s,background .12s; }
.tt-pill:hover { border-color:var(--green); }
.tt-pill.on { border-color:var(--green); background:var(--green-bg); }
.tt-pill input { width:auto; accent-color:var(--green); cursor:pointer; }

/* ── Admin user table ── */
.user-edit-panel { display:none; background:var(--bg3); border:1px solid var(--border2); border-radius:var(--radius2); padding:18px; margin-top:8px; }
.user-edit-panel.open { display:block; }

/* ── My tasks ── */
.mt-job { margin-bottom:24px; }
.mt-job-hdr { display:flex; align-items:center; gap:8px; margin-bottom:10px; padding-bottom:8px; border-bottom:1px solid var(--border); }
.mt-job-name { font-size:15px; font-weight:700; color:var(--text); }
.mt-shot { background:var(--bg2); border:1px solid var(--border); border-radius:var(--radius2); margin-bottom:8px; overflow:hidden; }
.mt-shot-hdr { display:flex; align-items:center; gap:10px; padding:8px 12px; background:var(--bg3); border-bottom:1px solid var(--border); }
.mt-thumb-sm { width:44px; height:25px; object-fit:cover; border-radius:3px; flex-shrink:0; }
.mt-shot-name { font-family:'Roboto Mono',monospace; font-size:13px; font-weight:500; }
.mt-latest-note { padding:8px 12px; background:var(--bg3); border-bottom:1px solid var(--border); font-size:12px; color:var(--text2); display:flex; gap:8px; }
.mt-latest-note .nl { color:var(--text3); font-size:11px; white-space:nowrap; }
.my-task-row { background:rgba(126,191,0,.04); }
.my-task-row > td:first-child { border-left:3px solid var(--green); }

/* ── Notifications page ── */
.notif-item { display:flex; gap:14px; padding:14px 16px; border-bottom:1px solid var(--border); align-items:flex-start; }
.notif-item:last-child { border-bottom:none; }
.notif-item.unread { background:rgba(126,191,0,.05); border-left:3px solid var(--green); padding-left:13px; }
.notif-indicator { width:8px; height:8px; border-radius:50%; margin-top:6px; flex-shrink:0; }
.notif-item.unread .notif-indicator { background:var(--green); animation:pulse 2s infinite; }
.notif-item:not(.unread) .notif-indicator { background:var(--bg4); }
.notif-content { font-size:13px; color:var(--text2); line-height:1.5; }
.notif-item.unread .notif-content { color:var(--text); }
.notif-body { margin-top:5px; padding:6px 10px; background:var(--bg3); border-radius:var(--radius); font-size:12px; color:var(--text2); border-left:2px solid var(--border2); }
.notif-meta { font-size:11px; color:var(--text3); font-family:'Roboto Mono',monospace; }
.notif-ack-btn { background:rgba(200,50,50,.15)!important; border:1px solid #c43333!important; color:#e05555!important; font-size:10px; font-weight:600; }
.notif-ack-btn:hover { background:#c43333!important; color:#fff!important; }

/* ── CSV mapping ── */
.mapping-table td,.mapping-table th { padding:8px 10px; }
.mapping-table select { font-size:12px; padding:4px 6px; }

/* ── Role badges ── */
.role-badge { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.06em; padding:2px 7px; border-radius:3px; background:var(--bg4); color:var(--text3); }
.role-badge.admin    { background:rgba(126,191,0,.15); color:var(--green); }
.role-badge.producer { background:rgba(99,102,241,.15); color:#a5b4fc; }
.role-badge.lead     { background:rgba(16,185,129,.15); color:#6ee7b7; }

/* ── Utilities ── */
.flex { display:flex; }
.items-center { align-items:center; }
.gap-2 { gap:8px; }
.gap-3 { gap:12px; }
.ml-auto { margin-left:auto; }
.text-dim { color:var(--text3); }
.text-sm { font-size:12px; }
.text-xs { font-size:11px; }
.hidden { display:none !important; }
.w-full { width:100%; }
.truncate { overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.divider { border:none; border-top:1px solid var(--border); margin:18px 0; }
.mt-1{margin-top:4px;}.mt-2{margin-top:8px;}.mt-3{margin-top:14px;}.mt-4{margin-top:20px;}
.mb-2{margin-bottom:8px;}.mb-3{margin-bottom:14px;}.mb-4{margin-bottom:20px;}

/* Instance banner (staging / dev) — shown when VFXT_INSTANCE env var is set */
body[class*="vfxt-"] { padding-top:24px; }
body[class*="vfxt-"] { padding-top:24px; }
body[class*="vfxt-"] .topnav { top:24px; }
body[class*="vfxt-"] .subbar { top:76px; }
.instance-banner { position:fixed; top:0; left:0; right:0; z-index:9999; height:24px; line-height:24px; text-align:center; font-size:11px; font-weight:700; letter-spacing:.12em; color:#fff; font-family:'Roboto Mono',monospace; user-select:none; }
.instance-banner-staging { background:repeating-linear-gradient(45deg,#d97706 0,#d97706 18px,#b45309 18px,#b45309 36px); border-bottom:1px solid #92400e; }
body.vfxt-staging .topnav { border-top:2px solid #f59e0b; }

/* ── Mobile (≤720px) ──
   The top nav and sub-bar are single non-wrapping flex rows, so on a phone the
   tabs and action buttons overflow off the right edge. Let both bars grow and
   wrap so everything stays visible, and drop sticky positioning so they scroll
   away with the page instead of overlapping the content below. */
@media (max-width:720px){
  .topnav{ position:static; height:auto; flex-wrap:wrap; gap:8px; padding:6px 10px; }
  .topnav-left{ flex-wrap:wrap; gap:6px 8px; min-width:0; overflow:visible; }
  .proj-select{ max-width:150px; }
  #agent-status{ display:none; }
  .subbar{ position:static; flex-wrap:wrap; padding:7px 12px; }
  .subbar-actions{ flex-wrap:wrap; }
}
