:root {
  --bg:#eef2f7; --surface:#ffffff; --surface-alt:#f7f9fc; --text:#1f2937; --muted:#60718a;
  --primary:#0f766e; --primary-strong:#115e59; --danger:#b42318; --warn:#b54708; --ok:#067647;
  --orange:#c2410c; --blue:#2563eb; --border:#d6deea; --shadow:0 10px 30px rgba(15,23,42,.08); --radius:16px;
}
:root[data-theme="dark"] {
  --bg:#0b1220; --surface:#111827; --surface-alt:#172033; --text:#eef2ff; --muted:#a8b3c7;
  --primary:#2dd4bf; --primary-strong:#14b8a6; --danger:#f97066; --warn:#fdb022; --ok:#32d583;
  --orange:#fb923c; --blue:#60a5fa; --border:#293548; --shadow:0 16px 40px rgba(0,0,0,.35);
}
*{box-sizing:border-box} body{margin:0;font-family:"Segoe UI","Noto Sans",sans-serif;background:radial-gradient(circle at 20% 0%,rgba(45,212,191,.18),transparent 32%),radial-gradient(circle at 80% 10%,rgba(59,130,246,.16),transparent 28%),var(--bg);color:var(--text)}
#app{width:min(1700px,100%);margin:0 auto;padding:14px}.topbar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}h1,h2,h3,h4{margin:0}.subtitle{margin:4px 0 0;color:var(--muted)}
.panel,.team-card,.toolbar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px;margin-bottom:12px}.login-panel{max-width:520px;margin:6vh auto}.stack-form{display:grid;gap:10px;margin-top:12px}label{display:grid;gap:6px;font-size:14px}input,select,button{font:inherit}input,select{border:1px solid var(--border);border-radius:12px;padding:10px 12px;background:var(--surface);color:var(--text)}
.btn{border:1px solid var(--border);border-radius:12px;padding:9px 12px;background:var(--surface);color:var(--text);cursor:pointer}.btn.primary{background:var(--primary);color:#042f2e;border-color:var(--primary)}.btn.danger{background:#fef3f2;color:#b42318;border-color:#fecdca}.btn.ghost{background:var(--surface-alt)}.session-controls{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;padding:10px 12px}.toolbar-actions{display:flex;gap:6px;flex-wrap:wrap}.toolbar-actions.micro .btn{padding:6px 9px;font-size:12px;border-radius:999px}.toolbar-title{font-weight:850;white-space:nowrap;text-transform:capitalize}.month-strip{display:flex;align-items:center;gap:10px;min-width:0;flex:1}.month-buttons{display:flex;gap:5px;overflow-x:auto;padding:2px 0;max-width:100%}.month-pill{border:1px solid var(--border);border-radius:999px;background:var(--surface-alt);color:var(--text);padding:5px 9px;font-size:12px;white-space:nowrap;display:inline-flex;gap:3px;align-items:baseline}.month-pill small{color:var(--muted);font-size:10px}.month-pill.active{background:var(--primary);border-color:var(--primary);color:#042f2e}.month-pill.active small{color:#064e3b}.tabs{display:flex;gap:8px;overflow-x:auto;margin-bottom:8px;padding-bottom:2px}.tab{border-radius:999px;border:1px solid var(--border);padding:8px 14px;background:var(--surface);color:var(--text);white-space:nowrap}.tab.active{background:var(--primary);border-color:var(--primary);color:#042f2e}
.badge{display:inline-flex;align-items:center;border-radius:999px;padding:4px 10px;font-size:12px;font-weight:800;border:1px solid transparent}.badge.ontrack,.badge.ok{background:#ecfdf3;color:#067647}.badge.watch,.badge.warn{background:#fffaeb;color:#b54708}.badge.behind{background:#fff4ed;color:#c2410c}.badge.critical,.badge.danger{background:#fef3f2;color:#b42318}
.kpi-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.card{background:var(--surface-alt);border:1px solid var(--border);border-radius:14px;padding:12px}.main-kpis{margin-bottom:12px}.kpi-card{position:relative;overflow:hidden;padding:16px;border-width:0;box-shadow:var(--shadow)}.kpi-card:before{content:"";position:absolute;inset:0;opacity:.15}.kpi-card>*{position:relative}.kpi-heads:before{background:linear-gradient(135deg,#14b8a6,#22c55e)}.kpi-pace:before{background:linear-gradient(135deg,#3b82f6,#60a5fa)}.kpi-manips:before{background:linear-gradient(135deg,#8b5cf6,#ec4899)}.kpi-ok:before{background:linear-gradient(135deg,#22c55e,#86efac)}.kpi-alert:before{background:linear-gradient(135deg,#ef4444,#fb923c)}.kpi-value{margin-top:6px;font-size:22px;font-weight:850}.main-kpis .kpi-value{font-size:28px}.kpi-label{color:var(--muted);font-size:13px}.pos{color:var(--ok)}.neg{color:var(--danger)}
.dashboard-intro{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap}.legend{display:flex;gap:10px;align-items:center;flex-wrap:wrap;color:var(--muted);font-size:13px}.compact-legend{background:transparent;border:0;box-shadow:none;margin:0 0 10px;padding:0 2px}.dot{display:inline-block;width:11px;height:11px;border-radius:50%;margin-right:5px}.dot.good{background:#22c55e}.dot.warn{background:#facc15}.dot.orange{background:#fb923c}.dot.bad{background:#ef4444}.dot.weekend{background:#60a5fa}.dot.nodata{background:#cbd5e1}
.team-grid{display:grid;grid-template-columns:1fr;gap:12px}.team-card{position:relative;overflow:hidden;margin:0;min-height:210px}.team-card .fill{position:absolute;inset:0 auto 0 0;opacity:.18;transition:width .25s ease}.team-card.ontrack .fill{background:linear-gradient(90deg,#22c55e,#86efac)}.team-card.watch .fill{background:linear-gradient(90deg,#eab308,#fde68a)}.team-card.behind .fill{background:linear-gradient(90deg,#f97316,#fed7aa)}.team-card.critical .fill{background:linear-gradient(90deg,#ef4444,#fecaca)}.team-content{position:relative;z-index:1}.team-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.team-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:12px 0}.team-stats.two{grid-template-columns:repeat(2,1fr)}.team-stats span{background:rgba(255,255,255,.55);border:1px solid var(--border);border-radius:12px;padding:8px}:root[data-theme="dark"] .team-stats span{background:rgba(17,24,39,.72)}.team-stats b{display:block;font-size:21px}.team-stats small{display:block;color:var(--muted);margin-top:2px}.team-note{font-size:13px;color:var(--muted);margin-top:8px}.progress-line{margin-top:8px;background:#dde4ef;border-radius:999px;height:10px;overflow:hidden}.progress-line>span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--primary),#22c55e)}
.days-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-top:10px}.day{min-height:22px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:850;border:1px solid var(--border);background:var(--surface-alt);color:var(--muted)}.day.good{background:#dcfae6;color:#067647;border-color:#75e0a7}.day.warn{background:#fef9c3;color:#854d0e;border-color:#fde047}.day.orange{background:#ffedd5;color:#9a3412;border-color:#fdba74}.day.bad{background:#fee4e2;color:#b42318;border-color:#fda29b}.day.weekend{background:#dbeafe;color:#1d4ed8;border-color:#93c5fd}.day.nodata{background:#f1f5f9;color:#64748b;border-style:dashed}:root[data-theme="dark"] .day.nodata{background:#1e293b;color:#94a3b8}:root[data-theme="dark"] .day.weekend{background:#172554;color:#93c5fd}:root[data-theme="dark"] .day.warn{background:#422006;color:#facc15}:root[data-theme="dark"] .day.orange{background:#431407;color:#fb923c}
.entry-mode-panel{padding-bottom:10px}.entry-mode-tabs{display:flex;gap:8px;flex-wrap:wrap;margin:12px 0}.entry-mode{border:1px solid var(--border);border-radius:999px;padding:9px 13px;background:var(--surface-alt);color:var(--text);cursor:pointer}.entry-mode.active{background:var(--primary);border-color:var(--primary);color:#042f2e}.manip-help{background:var(--surface-alt);border:1px dashed var(--border);border-radius:12px;padding:10px;margin:8px 0 0}.entry-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:12px}.entry-grid .wide{grid-column:1/-1}.important-input input{font-size:24px;font-weight:850}.board-controls{display:flex;align-items:end;gap:10px;flex-wrap:wrap;margin-top:12px}.entry-board{display:grid;grid-template-columns:repeat(7,minmax(40px,1fr));gap:6px;margin-top:12px}.entry-cell{border:1px solid var(--border);border-radius:10px;padding:6px;background:var(--surface-alt);display:grid;gap:4px}.entry-cell b{font-size:12px}.entry-cell input[type="number"]{width:100%;padding:5px;border-radius:8px;font-weight:850;text-align:center}.manip-mini{display:grid;grid-template-columns:repeat(4,1fr);gap:3px}.manip-mini input{font-size:10px;padding:4px 2px}.entry-cell small{font-size:10px;color:var(--muted)}.entry-cell label{font-size:10px;display:flex;gap:3px;align-items:center;color:var(--muted)}.entry-cell.good{background:#ecfdf3}.entry-cell.warn{background:#fef9c3}.entry-cell.orange{background:#ffedd5}.entry-cell.bad{background:#fee4e2}.entry-cell.weekend{background:#dbeafe}.entry-cell.nodata{background:#f8fafc;border-style:dashed}.day-entry-grid{display:grid;grid-template-columns:1fr;gap:10px;margin-top:12px}.day-team-card{border:1px solid var(--border);border-radius:14px;padding:10px;background:var(--surface-alt);display:grid;gap:8px}.day-team-card.good{background:#ecfdf3}.day-team-card.warn{background:#fef9c3}.day-team-card.orange{background:#ffedd5}.day-team-card.bad{background:#fee4e2}.day-team-card.weekend{background:#dbeafe}.day-team-card.nodata{background:#f8fafc;border-style:dashed}
.finance-split{display:grid;grid-template-columns:1fr;gap:10px;margin:10px 0}.splitbar{height:18px;border-radius:999px;background:#c7d2fe;overflow:hidden;margin:12px 0}.splitbar span{display:block;height:100%;background:linear-gradient(90deg,#14b8a6,#22c55e)}
.table-wrap{overflow:auto;border:1px solid var(--border);border-radius:12px;background:var(--surface)}table{width:100%;border-collapse:collapse;min-width:760px}th,td{text-align:left;padding:10px;border-bottom:1px solid var(--border);font-size:14px;vertical-align:top}th{background:var(--surface-alt);color:var(--muted)}.error-text{color:var(--danger);min-height:18px;margin-top:8px}.success-text{color:var(--ok);min-height:18px;margin-top:8px}.muted{color:var(--muted)}.demo-logins{margin:8px 0;padding-left:18px}.hidden{display:none!important}.view{display:none}.view.active{display:block}
.status-Новый{background:#eff8ff;color:#175cd3;border-color:#b2ddff}.status-Ожидаем\ оплату{background:#eff8ff;color:#175cd3;border-color:#b2ddff}.status-Частично\ оплачен{background:#fffaeb;color:#b54708;border-color:#fedf89}.status-Просрочен{background:#fff4ed;color:#b93815;border-color:#fed7aa}.status-Проблемный{background:#fef3f2;color:#b42318;border-color:#fecdca}.status-Оплачен{background:#ecfdf3;color:#067647;border-color:#abefc6}
@media (min-width:760px){#app{padding:18px}.kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.team-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.entry-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.day-entry-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.finance-split{grid-template-columns:2fr 1fr}}
@media (min-width:1200px){.team-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.day-entry-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media (min-width:1500px){body{font-size:18px}h1{font-size:42px}.panel,.team-card,.card,.toolbar{padding:18px}.kpi-value{font-size:30px}.main-kpis .kpi-value{font-size:38px}th,td,.tab,.btn,input,select{font-size:17px}.team-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.day-entry-grid{grid-template-columns:repeat(5,minmax(0,1fr))}.day{min-height:26px}.entry-board{grid-template-columns:repeat(14,minmax(42px,1fr))}}


/* v7 mobile layout polish */
.day-team-card,.day-manips,.day-manips label,.entry-cell,.entry-cell label,.manip-mini input{min-width:0}.day-manips input,.day-team-card input,.entry-cell input{width:100%}.tabs,.month-buttons{max-width:100%;overflow-x:auto;overflow-y:hidden}
.btn.icon{width:38px;height:38px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;font-size:18px}.btn.mini{padding:7px 9px;font-size:12px;border-radius:999px}.role-badge{white-space:nowrap}.toolbar{align-items:stretch}.month-strip{width:100%;flex:1 1 100%;display:grid;grid-template-columns:auto minmax(0,1fr);gap:8px;align-items:center}.toolbar-title{text-transform:none;background:var(--surface-alt);border:1px solid var(--border);border-radius:999px;padding:7px 10px;font-size:13px}.month-buttons{width:100%;min-width:0;scrollbar-width:thin}.month-pill{min-width:54px;justify-content:center}.board-controls input[type="date"]{min-width:0;width:100%}.date-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:end}.entry-board-mobile-note{display:none}
@media (max-width:759px){
  #app{padding:10px 8px 88px}.topbar{display:grid;grid-template-columns:1fr;gap:8px}.topbar h1{font-size:24px}.subtitle{font-size:13px}.session-controls{gap:5px;justify-content:flex-start}.session-controls .badge{font-size:11px;padding:4px 8px}.tabs{margin-left:0;margin-right:0;padding:0 0 6px;scroll-snap-type:none;flex-wrap:wrap;overflow:visible}.tab{padding:7px 11px;font-size:13px;scroll-snap-align:start;flex:1 1 auto;text-align:center}.toolbar{padding:9px;margin-bottom:10px}.month-strip{grid-template-columns:1fr;gap:7px}.toolbar-title{width:max-content;max-width:100%;font-size:12px;padding:6px 9px}.month-buttons{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(54px,1fr);overflow-x:auto;gap:6px;padding-bottom:4px}.month-pill{padding:8px 7px;font-size:12px}.month-pill small{font-size:10px}.legend{gap:6px;font-size:11px}.kpi-grid{gap:8px}.kpi-card{padding:12px}.main-kpis .kpi-value{font-size:22px}.team-stats{grid-template-columns:repeat(2,1fr)}.team-stats span:last-child{grid-column:1/-1}.days-grid{gap:3px}.day{min-height:24px;font-size:9px}.entry-mode-panel h2,.panel h2{font-size:20px}.entry-mode-tabs{display:grid;grid-template-columns:1fr;gap:7px}.entry-mode{width:100%;padding:10px}.manip-help{font-size:12px}.board-controls{display:grid;grid-template-columns:1fr;gap:9px;align-items:stretch}.board-controls label,.board-controls button{width:100%}.board-controls .success-text{min-height:0}.entry-board{grid-template-columns:1fr;gap:8px}.entry-cell{grid-template-columns:36px 74px minmax(0,1fr);grid-template-areas:"day heads manips" "off off sum";align-items:center;padding:8px;border-radius:13px}.entry-cell b{grid-area:day;font-size:18px;text-align:center}.entry-cell input[data-field="heads"]{grid-area:heads;font-size:16px;padding:8px 6px}.entry-cell .manip-mini{grid-area:manips;grid-template-columns:repeat(4,minmax(0,1fr));gap:4px}.entry-cell .manip-mini input{font-size:12px;padding:7px 2px}.entry-cell small{grid-area:sum;font-size:11px}.entry-cell label{grid-area:off;justify-self:start;width:auto;font-size:10px;display:flex;gap:3px;align-items:center;color:var(--muted)}
}
@media (max-width:380px){.session-controls .role-badge{order:-1}.session-controls{gap:4px}.btn.mini{padding:6px 7px;font-size:11px}.month-buttons{grid-auto-columns:minmax(50px,1fr)}.entry-cell{grid-template-columns:32px 66px minmax(0,1fr);padding:7px}.entry-cell .manip-mini input{font-size:11px}.day-manips{gap:4px}}


/* v8 day tiles: weekday/date + centered heads */
.main-kpis{grid-template-columns:repeat(4,minmax(0,1fr));gap:6px}.main-kpis .kpi-card{padding:8px 9px;border-radius:12px}.main-kpis .kpi-value{font-size:18px;margin-top:2px}.main-kpis .kpi-label{font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.team-card{min-height:230px}.team-stats{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px;margin:8px 0}.team-stats span{padding:6px;border-radius:10px}.team-stats b{font-size:18px}.team-stats small{font-size:11px}.days-grid{grid-template-columns:repeat(7,minmax(34px,1fr));gap:5px}.day{position:relative;min-height:42px;padding:4px;display:flex;flex-direction:column;align-items:center;justify-content:center;line-height:1;border-radius:9px}.day small{position:absolute;top:4px;left:5px;font-size:8px;font-weight:850;opacity:.82}.day b{font-size:16px;font-weight:950;letter-spacing:-.03em}.day.weekend b,.day.nodata b{font-size:12px;letter-spacing:0}
@media (max-width:759px){.main-kpis{grid-template-columns:repeat(4,minmax(0,1fr));gap:5px}.main-kpis .kpi-card{padding:7px 5px}.main-kpis .kpi-value{font-size:14px}.main-kpis .kpi-label{font-size:9px}.team-stats{grid-template-columns:repeat(3,minmax(0,1fr))}.team-stats span:last-child{grid-column:auto}.team-stats b{font-size:15px}.team-stats small{font-size:9px}.days-grid{gap:4px}.day{min-height:40px;border-radius:8px}.day small{font-size:7px;top:4px;left:4px}.day b{font-size:15px}.day.weekend b,.day.nodata b{font-size:10px}}


/* v9 progress labels, dark status contrast, mobile entry cleanup */
.progress-line{position:relative;height:18px;margin-top:10px;background:rgba(148,163,184,.32);border:1px solid rgba(148,163,184,.38);border-radius:999px;overflow:hidden;box-shadow:inset 0 1px 2px rgba(15,23,42,.18)}
.progress-line>span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#14b8a6,#22c55e);min-width:1.5rem}
.progress-line>b{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:950;line-height:1;color:#052e2b;text-shadow:0 1px 0 rgba(255,255,255,.35);z-index:2}
:root[data-theme="dark"] .progress-line{background:rgba(15,23,42,.9);border-color:rgba(148,163,184,.38)}
:root[data-theme="dark"] .progress-line>b{color:#ecfeff;text-shadow:0 1px 2px rgba(0,0,0,.85)}
:root[data-theme="dark"] .team-card.watch .fill{background:linear-gradient(90deg,#ca8a04,#facc15)}
:root[data-theme="dark"] .team-card.behind .fill{background:linear-gradient(90deg,#ea580c,#fb923c)}
:root[data-theme="dark"] .team-card.critical .fill{background:linear-gradient(90deg,#dc2626,#f87171)}
:root[data-theme="dark"] .day.warn{background:#713f12;color:#fef3c7;border-color:#f59e0b}
:root[data-theme="dark"] .day.orange{background:#7c2d12;color:#ffedd5;border-color:#fb923c}
:root[data-theme="dark"] .day.bad{background:#7f1d1d;color:#fee2e2;border-color:#f87171}
:root[data-theme="dark"] .entry-cell.good,:root[data-theme="dark"] .day-team-card.good{background:#064e3b;color:#ecfdf5;border-color:#10b981}
:root[data-theme="dark"] .entry-cell.warn,:root[data-theme="dark"] .day-team-card.warn{background:#713f12;color:#fef3c7;border-color:#f59e0b}
:root[data-theme="dark"] .entry-cell.orange,:root[data-theme="dark"] .day-team-card.orange{background:#7c2d12;color:#ffedd5;border-color:#fb923c}
:root[data-theme="dark"] .entry-cell.bad,:root[data-theme="dark"] .day-team-card.bad{background:#7f1d1d;color:#fee2e2;border-color:#f87171}
:root[data-theme="dark"] .entry-cell.weekend,:root[data-theme="dark"] .day-team-card.weekend{background:#172554;color:#dbeafe;border-color:#60a5fa}
:root[data-theme="dark"] .entry-cell.nodata,:root[data-theme="dark"] .day-team-card.nodata{background:#111827;color:#cbd5e1;border-color:#475569}
:root[data-theme="dark"] .entry-cell input,:root[data-theme="dark"] .day-team-card input{background:#0f172a;color:#f8fafc;border-color:#334155}
.off-check{width:100%;min-width:0;justify-content:flex-start;white-space:nowrap;overflow:visible;color:var(--muted)}
.off-check input,.entry-cell label input{flex:0 0 auto;width:16px;height:16px}
@media (max-width:759px){
  .progress-line{height:20px}.progress-line>b{font-size:12px}
  .entry-cell{grid-template-columns:34px minmax(58px,.7fr) minmax(0,1.8fr);grid-template-areas:"day heads manips" "off off sum";gap:6px 7px;overflow:hidden}
  .entry-cell label{grid-area:off;justify-self:start;width:auto;font-size:10px;white-space:nowrap;opacity:.95;color:inherit}
  .entry-cell small{justify-self:end;white-space:nowrap;font-size:10px;opacity:.78;color:inherit}
  .entry-cell .manip-mini input{min-width:0;max-width:100%;font-size:11px;padding:7px 1px}
  .day-team-card{overflow:hidden;padding:11px;border-radius:14px;gap:7px}
  .day-team-card h3{font-size:17px;margin-bottom:0}
  .day-team-card .important-input{font-size:12px;color:var(--muted);gap:4px}
  .day-team-card .important-input input{font-size:22px;padding:8px 10px}
  .day-manips{grid-template-columns:repeat(4,minmax(0,1fr));gap:5px;width:100%}
  .day-manips label{font-size:10px;gap:3px;color:var(--muted)}
  .day-manips input{min-width:0;width:100%;padding:7px 2px;font-size:12px}
  .day-team-card .off-check{font-size:12px;justify-content:flex-start;padding-top:2px;color:var(--muted)}
}
@media (max-width:380px){.entry-cell{grid-template-columns:30px minmax(52px,.65fr) minmax(0,1.9fr);gap:5px}.entry-cell .manip-mini input{font-size:10px}.day-manips{gap:4px}.day-team-card{padding:10px}}


/* v10 logo, simplified status colors, KPI progress */
.brand-lockup{display:flex;align-items:center;gap:12px;min-width:0}
.project-logo{width:clamp(150px,22vw,250px);height:auto;display:block;object-fit:contain;filter:drop-shadow(0 8px 18px rgba(15,23,42,.12))}
.kpi-card .kpi-fill{position:absolute;inset:0 auto 0 0;width:0;opacity:.18;background:linear-gradient(90deg,#22c55e,#86efac);transition:width .25s ease}
.kpi-bar{position:relative;height:18px;margin-top:7px;border-radius:999px;background:rgba(148,163,184,.28);overflow:hidden;border:1px solid rgba(148,163,184,.32)}
.kpi-bar span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#16a34a,#84cc16);min-width:1.3rem}
.kpi-bar b{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:950;color:#052e16;text-shadow:0 1px 0 rgba(255,255,255,.35)}
.dot.orange,.day.orange{display:none}
.day.warn{background:#fef3c7;color:#92400e;border-color:#facc15}
.entry-cell.warn,.day-team-card.warn{background:#fef3c7;color:#92400e;border-color:#facc15}
:root[data-theme="dark"] .kpi-card .kpi-fill{opacity:.22}
:root[data-theme="dark"] .kpi-bar{background:rgba(15,23,42,.88);border-color:rgba(148,163,184,.38)}
:root[data-theme="dark"] .kpi-bar b{color:#ecfdf5;text-shadow:0 1px 2px rgba(0,0,0,.85)}
:root[data-theme="dark"] .day.warn{background:#713f12;color:#fef3c7;border-color:#facc15}
:root[data-theme="dark"] .entry-cell.warn,:root[data-theme="dark"] .day-team-card.warn{background:#713f12;color:#fef3c7;border-color:#facc15}
@media (max-width:759px){.brand-lockup{gap:9px}.project-logo{width:min(190px,58vw)}.topbar h1{font-size:20px}.subtitle{font-size:12px}.kpi-bar{height:16px}.kpi-bar b{font-size:9px}}
@media (max-width:430px){.brand-lockup{align-items:flex-start}.project-logo{width:min(165px,54vw)}}


/* v10 finance table sticky row/column */
.sticky-controls{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin:10px 0}
.sticky-controls label{display:flex;grid-template-columns:none;align-items:center;gap:6px;font-size:13px;color:var(--muted);background:var(--surface-alt);border:1px solid var(--border);border-radius:999px;padding:7px 10px}
.sticky-controls input{width:16px;height:16px;padding:0}
.finance-table-wrap{max-height:58vh;position:relative}
.finance-table-wrap table{border-collapse:separate;border-spacing:0}
.finance-table-wrap.sticky-top thead th{position:sticky;top:0;z-index:5;box-shadow:0 1px 0 var(--border),0 6px 14px rgba(15,23,42,.08)}
.finance-table-wrap.sticky-first th:first-child,.finance-table-wrap.sticky-first td:first-child{position:sticky;left:0;z-index:4;background:var(--surface-alt);box-shadow:1px 0 0 var(--border),8px 0 14px rgba(15,23,42,.06);font-weight:800}
.finance-table-wrap.sticky-top.sticky-first thead th:first-child{z-index:7}
:root[data-theme="dark"] .finance-table-wrap.sticky-first th:first-child,:root[data-theme="dark"] .finance-table-wrap.sticky-first td:first-child{box-shadow:1px 0 0 var(--border),8px 0 16px rgba(0,0,0,.28)}
@media (max-width:759px){.finance-table-wrap{max-height:64vh}.sticky-controls{gap:6px}.sticky-controls label{font-size:11px;padding:6px 8px}}


/* v11 header/logo and clearer progress */
.topbar{align-items:flex-start}
.brand-lockup{align-items:flex-start;padding-top:6px}
.project-logo{margin-top:8px;max-height:62px;width:clamp(132px,18vw,220px)}
.kpi-card{overflow:hidden;position:relative}
.kpi-card > *:not(.kpi-fill){position:relative;z-index:1}
.kpi-fill.manip{background:linear-gradient(90deg,#a855f7,#f472b6)}
.kpi-bar.manip span{background:linear-gradient(90deg,#9333ea,#f472b6)}
.splitbar{position:relative;display:flex;align-items:center}
.splitbar span{position:absolute;left:0;top:0;bottom:0}
.splitbar b{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;height:100%;font-size:11px;font-weight:950;white-space:nowrap;text-shadow:0 1px 0 rgba(255,255,255,.4)}
.split-heads{color:#064e3b;padding-left:12px;justify-content:flex-start!important;flex:1}
.split-manips{color:#3730a3;padding-right:12px;justify-content:flex-end!important;flex:1}
:root[data-theme="dark"] .splitbar b,:root[data-theme="dark"] .kpi-bar b{color:#ecfeff;text-shadow:0 1px 2px rgba(0,0,0,.55)}
@media (max-width:759px){.brand-lockup{padding-top:2px}.project-logo{margin-top:4px;max-height:54px;width:138px}.topbar h1{font-size:23px}}


/* v13 KPI summary: two large progress blocks + compact deviations */
.kpi-summary-v13{grid-template-columns:1.35fr 1.35fr .85fr;align-items:stretch}
.kpi-summary-v13 .kpi-primary{min-height:142px;padding:22px}
.kpi-summary-v13 .kpi-primary .kpi-label{font-size:13px;letter-spacing:.02em;text-transform:uppercase}
.kpi-summary-v13 .kpi-primary .kpi-value{font-size:42px;line-height:1;margin:10px 0 14px}
.kpi-summary-v13 .kpi-primary .kpi-bar{height:22px}
.kpi-delta-compact{padding:18px;min-height:142px;display:flex;flex-direction:column;justify-content:space-between}
.delta-stack{display:grid;gap:10px}
.delta-stack span{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;border-radius:16px;background:rgba(255,255,255,.48);border:1px solid rgba(255,255,255,.45)}
.delta-stack small{font-size:12px;color:var(--muted);font-weight:800;text-transform:uppercase;letter-spacing:.02em}
.delta-stack b{font-size:22px;line-height:1}
:root[data-theme="dark"] .delta-stack span{background:rgba(15,23,42,.42);border-color:rgba(148,163,184,.22)}
@media (max-width:900px){.kpi-summary-v13{grid-template-columns:1fr 1fr}.kpi-delta-compact{grid-column:1/-1;min-height:auto}.delta-stack{grid-template-columns:1fr 1fr}}
@media (max-width:759px){.kpi-summary-v13{grid-template-columns:1fr 1fr;gap:10px}.kpi-summary-v13 .kpi-primary{min-height:118px;padding:14px}.kpi-summary-v13 .kpi-primary .kpi-label{font-size:10.5px;line-height:1.2}.kpi-summary-v13 .kpi-primary .kpi-value{font-size:30px;margin:8px 0 10px}.kpi-summary-v13 .kpi-primary .kpi-bar{height:20px}.kpi-summary-v13 .kpi-primary .kpi-bar b{font-size:10px}.kpi-delta-compact{grid-column:1/-1;padding:12px}.delta-stack{grid-template-columns:1fr 1fr;gap:8px}.delta-stack span{padding:9px}.delta-stack small{font-size:10px}.delta-stack b{font-size:18px}}


/* v14: only two main KPI blocks; deltas inside cards; manip breakdown on click */
.kpi-summary-v14{grid-template-columns:1fr 1fr;align-items:stretch}
.kpi-summary-v14 .kpi-primary{min-height:170px;padding:22px;text-align:left;border:0}
.kpi-clickable{cursor:pointer;font:inherit;color:inherit;position:relative;overflow:hidden}
.kpi-clickable:hover{transform:translateY(-1px);box-shadow:0 16px 36px rgba(15,23,42,.12)}
.kpi-inline-delta{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:12px;padding:10px 12px;border-radius:16px;background:rgba(255,255,255,.52);border:1px solid rgba(255,255,255,.55)}
.kpi-inline-delta small{font-weight:900;color:var(--muted);text-transform:uppercase;letter-spacing:.03em;font-size:11px}.kpi-inline-delta b{font-size:22px}.tap-hint{margin-top:8px;font-size:12px;font-weight:800;color:var(--muted)}
.manip-breakdown{margin:-6px 0 18px;padding:16px;border-radius:22px;background:rgba(255,255,255,.68);border:1px solid rgba(148,163,184,.22);box-shadow:0 14px 32px rgba(15,23,42,.08)}
.breakdown-head{display:flex;justify-content:space-between;gap:12px;margin-bottom:12px}.breakdown-head span{color:var(--muted);font-weight:800}.breakdown-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.breakdown-item{padding:12px;border-radius:18px;background:linear-gradient(135deg,rgba(250,245,255,.95),rgba(236,253,245,.9));border:1px solid rgba(168,85,247,.16)}.breakdown-item div:first-child{display:flex;justify-content:space-between;gap:8px}.breakdown-item b{font-size:18px}.breakdown-item small{font-size:11px;color:var(--muted);font-weight:800}.breakdown-item strong{display:block;font-size:24px;margin:8px 0}.mini-progress{height:16px;border-radius:999px;overflow:hidden;background:rgba(148,163,184,.22);position:relative}.mini-progress span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#a855f7,#ec4899)}.mini-progress em{position:absolute;inset:0;text-align:center;font-style:normal;font-size:10px;font-weight:900;line-height:16px;color:#111827}
:root[data-theme="dark"] .kpi-inline-delta,:root[data-theme="dark"] .manip-breakdown{background:rgba(15,23,42,.58);border-color:rgba(148,163,184,.22)}:root[data-theme="dark"] .breakdown-item{background:linear-gradient(135deg,rgba(88,28,135,.45),rgba(20,83,45,.35))}:root[data-theme="dark"] .mini-progress em{color:#f8fafc}
@media (max-width:759px){.kpi-summary-v14{grid-template-columns:1fr 1fr;gap:10px}.kpi-summary-v14 .kpi-primary{min-height:168px;padding:13px}.kpi-summary-v14 .kpi-primary .kpi-label{font-size:10.5px;line-height:1.2}.kpi-summary-v14 .kpi-primary .kpi-value{font-size:30px}.kpi-inline-delta{padding:8px;display:block}.kpi-inline-delta b{display:block;font-size:18px;margin-top:3px}.tap-hint{font-size:10px}.breakdown-grid{grid-template-columns:1fr 1fr}.breakdown-item{padding:10px}.breakdown-item strong{font-size:20px}}


/* v15: compact KPI deltas and manipulation breakdown */
.kpi-inline-delta.compact{margin-top:8px;padding:0;border:0;background:transparent;display:flex;justify-content:flex-start;gap:7px;align-items:baseline;box-shadow:none}.kpi-inline-delta.compact span{font-size:12px;font-weight:900;color:var(--muted);text-transform:none;letter-spacing:0}.kpi-inline-delta.compact b{font-size:18px;line-height:1}.tap-hint{margin-top:5px}.manip-breakdown{padding:12px;margin:-8px 0 14px}.breakdown-head{margin-bottom:8px;font-size:13px}.breakdown-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.breakdown-row{display:grid;grid-template-columns:minmax(92px,1fr) 48px minmax(74px,1fr);align-items:center;gap:8px;padding:8px 10px;border-radius:14px;background:linear-gradient(135deg,rgba(250,245,255,.88),rgba(236,253,245,.78));border:1px solid rgba(168,85,247,.12)}.breakdown-row span{font-size:12px;font-weight:900;color:var(--text)}.breakdown-row b{text-align:right;font-size:16px}.breakdown-row .mini-progress{height:14px}.breakdown-item{display:none}
:root[data-theme="dark"] .kpi-inline-delta.compact{background:transparent;border:0}:root[data-theme="dark"] .breakdown-row{background:linear-gradient(135deg,rgba(88,28,135,.34),rgba(20,83,45,.24));border-color:rgba(168,85,247,.2)}
@media (max-width:759px){.kpi-inline-delta.compact{display:flex;padding:0}.kpi-inline-delta.compact b{font-size:16px}.manip-breakdown{padding:10px}.breakdown-grid{grid-template-columns:1fr;gap:6px}.breakdown-row{grid-template-columns:minmax(104px,1fr) 42px minmax(76px,1fr);padding:7px 8px}.breakdown-row span{font-size:11.5px}.breakdown-row b{font-size:15px}.breakdown-head{font-size:12px}.tap-hint{font-size:9.5px}}


/* v16: KPI deviation placement and renamed manipulation rows */
.kpi-percent{text-align:center}.kpi-meta-line{display:flex;justify-content:flex-end;align-items:center;margin:2px 0 6px;font-size:11px;font-weight:900;color:var(--muted);line-height:1.15}.kpi-meta-line b{font-size:14px;margin-left:4px}.kpi-meta-line .pos{color:var(--green-dark)}.kpi-meta-line .neg{color:var(--red)}.breakdown-row span{letter-spacing:-.01em}
@media (max-width:759px){.kpi-meta-line{font-size:9.5px;margin:0 0 5px;white-space:nowrap}.kpi-meta-line b{font-size:12px}.kpi-percent{text-align:center}.breakdown-row{grid-template-columns:minmax(116px,1fr) 38px minmax(70px,1fr);gap:6px}.breakdown-row span{font-size:10.8px}.breakdown-row b{font-size:14px}}

/* v17 cache-bust + center current KPI value class */
.kpi-value{text-align:center}


/* v18: straighten main KPI layout on desktop/mobile */
.kpi-summary-v14 .kpi-primary{
  display:grid;
  grid-template-rows:auto 1fr auto auto;
  gap:8px;
  min-width:0;
  text-align:left;
}
.kpi-summary-v14 .kpi-primary .kpi-fill{display:none}
.kpi-summary-v14 .kpi-primary .kpi-label{
  min-width:0;
  max-width:100%;
  white-space:normal;
  overflow:visible;
  text-overflow:clip;
  line-height:1.25;
  min-height:34px;
}
.kpi-summary-v14 .kpi-primary .kpi-value{
  align-self:center;
  justify-self:center;
  width:100%;
  text-align:center;
  margin:2px 0 0;
  line-height:1;
}
.kpi-summary-v14 .kpi-primary .kpi-meta-line{
  justify-content:flex-end;
  width:100%;
  margin:0;
  text-align:right;
  white-space:nowrap;
}
.kpi-summary-v14 .kpi-primary .kpi-bar{
  width:100%;
  margin-top:0;
}
.kpi-summary-v14 .kpi-primary .tap-hint{
  margin-top:0;
  text-align:right;
}
@media (min-width:760px){
  .kpi-summary-v14 .kpi-primary{min-height:178px;padding:22px 24px 18px}
  .kpi-summary-v14 .kpi-primary .kpi-value{font-size:44px}
  .kpi-summary-v14 .kpi-primary .kpi-bar{height:24px}
}
@media (max-width:759px){
  .kpi-summary-v14{grid-template-columns:1fr 1fr;gap:8px}
  .kpi-summary-v14 .kpi-primary{min-height:160px;padding:12px 10px;gap:6px}
  .kpi-summary-v14 .kpi-primary .kpi-label{font-size:10.5px;min-height:30px}
  .kpi-summary-v14 .kpi-primary .kpi-value{font-size:30px}
  .kpi-summary-v14 .kpi-primary .kpi-meta-line{font-size:9px;letter-spacing:-.02em}
  .kpi-summary-v14 .kpi-primary .kpi-meta-line b{font-size:11px}
  .kpi-summary-v14 .kpi-primary .tap-hint{font-size:9.5px;line-height:1.15}
}
@media (max-width:430px){
  .kpi-summary-v14{grid-template-columns:1fr;gap:9px}
  .kpi-summary-v14 .kpi-primary{min-height:138px;padding:14px 13px}
  .kpi-summary-v14 .kpi-primary .kpi-label{min-height:0;font-size:11px}
  .kpi-summary-v14 .kpi-primary .kpi-value{font-size:32px}
  .kpi-summary-v14 .kpi-primary .kpi-meta-line{font-size:10px}
  .kpi-summary-v14 .kpi-primary .kpi-meta-line b{font-size:12px}
}


/* v19: centered clean KPI cards after visual review */
.kpi-summary-v14 .kpi-primary{
  display:flex !important;
  flex-direction:column;
  justify-content:space-between;
  align-items:stretch;
  text-align:center !important;
  gap:10px;
}
.kpi-summary-v14 .kpi-primary .kpi-label{
  text-align:left;
  min-height:0;
  width:100%;
  font-weight:850;
}
.kpi-summary-v14 .kpi-primary .kpi-value{
  display:block;
  text-align:center !important;
  margin:0 auto;
  width:100%;
}
.kpi-summary-v14 .kpi-primary .kpi-meta-line{
  display:block;
  width:100%;
  text-align:center !important;
  margin:-2px 0 0;
  white-space:normal;
  color:var(--muted);
}
.kpi-summary-v14 .kpi-primary .kpi-meta-line span{
  display:inline-flex;
  align-items:baseline;
  justify-content:center;
  gap:4px;
  padding:3px 9px;
  border-radius:999px;
  background:rgba(255,255,255,.48);
}
.kpi-summary-v14 .kpi-primary .kpi-meta-line b{margin-left:0}
.kpi-summary-v14 .kpi-primary .kpi-bar{
  margin-top:0;
  width:100%;
  flex:0 0 auto;
}
.kpi-summary-v14 .kpi-primary .tap-hint{
  width:100%;
  text-align:center !important;
  margin-top:-2px;
}
@media (min-width:760px){
  .kpi-summary-v14 .kpi-primary{min-height:168px;padding:20px 22px 18px}
  .kpi-summary-v14 .kpi-primary .kpi-value{font-size:46px}
  .kpi-summary-v14 .kpi-primary .kpi-meta-line{font-size:12px}
  .kpi-summary-v14 .kpi-primary .kpi-meta-line b{font-size:15px}
}
@media (max-width:430px){
  .kpi-summary-v14 .kpi-primary{min-height:146px;padding:13px 12px;gap:7px}
  .kpi-summary-v14 .kpi-primary .kpi-label{text-align:center;font-size:11px}
  .kpi-summary-v14 .kpi-primary .kpi-value{font-size:34px}
  .kpi-summary-v14 .kpi-primary .kpi-meta-line span{padding:2px 8px}
}


/* v20: smaller KPI cards, aligned bars, hint in top-right */
.kpi-summary-v14 .kpi-primary{
  position:relative;
  min-height:142px !important;
  padding:16px 18px 14px !important;
  gap:7px !important;
  display:grid !important;
  grid-template-rows:32px 48px 26px 22px !important;
  align-items:center;
}
.kpi-summary-v14 .kpi-primary .kpi-label{
  align-self:start;
  padding-right:0;
}
.kpi-summary-v14 .kpi-primary .kpi-value{
  align-self:center;
  font-size:38px !important;
}
.kpi-summary-v14 .kpi-primary .kpi-meta-line{
  align-self:center;
}
.kpi-summary-v14 .kpi-primary .kpi-bar{
  align-self:end;
  height:22px !important;
}
.kpi-summary-v14 .kpi-primary .tap-hint{
  position:absolute;
  top:14px;
  right:16px;
  max-width:150px;
  margin:0 !important;
  text-align:right !important;
  font-size:10.5px;
  line-height:1.1;
}
.kpi-summary-v14 .kpi-manips .kpi-label{padding-right:150px}
@media (max-width:759px){
  .kpi-summary-v14 .kpi-primary{
    min-height:132px !important;
    padding:13px 12px 12px !important;
    grid-template-rows:28px 42px 24px 20px !important;
    gap:5px !important;
  }
  .kpi-summary-v14 .kpi-primary .kpi-value{font-size:32px !important}
  .kpi-summary-v14 .kpi-primary .kpi-bar{height:20px !important}
  .kpi-summary-v14 .kpi-primary .tap-hint{top:10px;right:12px;max-width:116px;font-size:9px}
  .kpi-summary-v14 .kpi-manips .kpi-label{padding-right:112px}
}
@media (max-width:430px){
  .kpi-summary-v14 .kpi-primary{
    min-height:128px !important;
    grid-template-rows:26px 40px 23px 20px !important;
  }
  .kpi-summary-v14 .kpi-primary .kpi-label{text-align:left;font-size:10.5px}
  .kpi-summary-v14 .kpi-primary .tap-hint{font-size:8.8px;max-width:108px}
  .kpi-summary-v14 .kpi-manips .kpi-label{padding-right:106px}
}


/* v21: restore v19 visual layout; only move hint top-right and reduce height */
.kpi-summary-v14 .kpi-primary{
  position:relative !important;
  display:flex !important;
  flex-direction:column !important;
  justify-content:space-between !important;
  align-items:stretch !important;
  text-align:center !important;
  min-height:142px !important;
  padding:16px 18px 14px !important;
  gap:7px !important;
}
.kpi-summary-v14 .kpi-primary .kpi-label{
  align-self:auto !important;
  text-align:left !important;
  min-height:0 !important;
  width:100% !important;
  padding-right:0 !important;
}
.kpi-summary-v14 .kpi-manips .kpi-label{padding-right:150px !important}
.kpi-summary-v14 .kpi-primary .kpi-value{
  display:block !important;
  align-self:auto !important;
  text-align:center !important;
  margin:0 auto !important;
  width:100% !important;
  font-size:40px !important;
  line-height:1 !important;
}
.kpi-summary-v14 .kpi-primary .kpi-meta-line{
  display:block !important;
  align-self:auto !important;
  width:100% !important;
  text-align:center !important;
  margin:-1px 0 0 !important;
  white-space:normal !important;
}
.kpi-summary-v14 .kpi-primary .kpi-meta-line span{
  display:inline-flex !important;
  align-items:baseline !important;
  justify-content:center !important;
  gap:4px !important;
  padding:3px 9px !important;
  border-radius:999px !important;
  background:rgba(255,255,255,.48) !important;
}
.kpi-summary-v14 .kpi-primary .kpi-bar{
  align-self:auto !important;
  width:100% !important;
  height:22px !important;
  margin-top:0 !important;
  flex:0 0 auto !important;
}
.kpi-summary-v14 .kpi-primary .tap-hint{
  position:absolute !important;
  top:12px !important;
  right:16px !important;
  max-width:150px !important;
  width:auto !important;
  margin:0 !important;
  text-align:right !important;
  font-size:10.5px !important;
  line-height:1.1 !important;
}
@media (max-width:759px){
  .kpi-summary-v14 .kpi-primary{min-height:126px !important;padding:12px 11px !important;gap:5px !important}
  .kpi-summary-v14 .kpi-primary .kpi-value{font-size:32px !important}
  .kpi-summary-v14 .kpi-primary .kpi-bar{height:20px !important}
  .kpi-summary-v14 .kpi-primary .tap-hint{top:9px !important;right:11px !important;max-width:112px !important;font-size:8.8px !important}
  .kpi-summary-v14 .kpi-manips .kpi-label{padding-right:108px !important}
}
@media (max-width:430px){
  .kpi-summary-v14{grid-template-columns:1fr !important}
  .kpi-summary-v14 .kpi-primary{min-height:122px !important}
  .kpi-summary-v14 .kpi-primary .kpi-label{text-align:left !important;font-size:10.5px !important}
}



/* v23: compact brigade totals table with draggable column borders */
.brigade-summary-panel{margin-top:14px;padding:12px;--team-col:150px;--heads-col:82px;--manips-col:86px}
.summary-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:8px}.summary-head h3{font-size:18px}.summary-head .muted{margin:3px 0 0;font-size:12px}
.brigade-summary-table{border:1px solid var(--border);border-radius:14px;overflow:hidden;background:var(--surface);max-width:100%}
.summary-row{display:grid;grid-template-columns:minmax(96px,var(--team-col)) minmax(64px,var(--heads-col)) minmax(64px,var(--manips-col));align-items:center;min-height:34px;border-bottom:1px solid var(--border);position:relative}
.summary-row:last-child{border-bottom:0}.summary-row>*{min-width:0;padding:8px 10px;border-right:1px solid var(--border);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.summary-row>*:last-child{border-right:0}.summary-row span:nth-child(n+2),.summary-row b+span,.summary-row b+span+span{text-align:right}.summary-header{background:var(--surface-alt);color:var(--muted);font-size:12px;font-weight:900;user-select:none}.summary-row b{font-size:13px}.summary-row span{font-size:13px}
.summary-header .col-drag{display:block;width:16px;height:100%;padding:0;border:0;position:absolute;top:0;cursor:col-resize;z-index:3;background:transparent;touch-action:none}.summary-header .col-drag::after{content:"";position:absolute;top:7px;bottom:7px;left:7px;width:2px;border-radius:2px;background:rgba(20,184,166,.35)}.summary-header .col-drag[data-left="team"]{left:calc(var(--team-col) - 8px)}.summary-header .col-drag[data-left="heads"]{left:calc(var(--team-col) + var(--heads-col) - 8px)}.summary-header .col-drag.dragging::after,.summary-header .col-drag:hover::after{background:var(--primary);width:3px}
.scroll-top-btn{display:block;margin:14px auto 4px;padding:10px 16px;border:0;border-radius:999px;background:linear-gradient(135deg,var(--primary),#22c55e);color:white;font-weight:900;box-shadow:0 10px 24px rgba(20,184,166,.25);cursor:pointer}.scroll-top-btn:active{transform:translateY(1px)}
@media (max-width:759px){.brigade-summary-panel{padding:10px;margin-top:10px;--team-col:154px;--heads-col:76px;--manips-col:78px}.summary-head h3{font-size:16px}.summary-head .muted{font-size:11px}.summary-row{min-height:31px}.summary-row>*{padding:7px 8px}.summary-row b,.summary-row span{font-size:12px}.summary-header{font-size:11px}.scroll-top-btn{width:100%;max-width:220px;margin-top:12px}}

.summary-row.summary-total{background:rgba(15,23,42,.06);font-weight:900;border-top:2px solid rgba(15,23,42,.16)}
.summary-row.summary-total b,.summary-row.summary-total span{font-weight:900;color:var(--text)}
.summary-row.is-off{opacity:.72;background:rgba(148,163,184,.08)}

.finance-kpis .finance-kpi{border:0;text-align:left;cursor:pointer;position:relative;overflow:hidden}.finance-kpi:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(22,163,74,.12),rgba(37,99,235,.12));opacity:.75}.finance-kpi>*{position:relative}.finance-kpi.active{outline:2px solid var(--accent);box-shadow:0 16px 34px rgba(37,99,235,.22);transform:translateY(-1px)}.finance-kpi small{display:block;margin-top:6px;color:var(--muted);font-weight:800}.finance-cell-hot{background:rgba(37,99,235,.12)!important;color:var(--text);font-weight:900}.resizable-finance{table-layout:fixed}.resizable-finance th{position:relative}.finance-col-drag{position:absolute;right:-5px;top:0;width:10px;height:100%;cursor:col-resize;z-index:5}.finance-col-drag:after{content:"";display:block;width:2px;height:60%;margin:10px auto;background:rgba(37,99,235,.45);border-radius:3px}.team-add{display:flex;gap:8px;margin-bottom:12px}.team-add input,.team-edit-row input{width:100%;padding:10px;border:1px solid var(--line);border-radius:12px;background:var(--card);color:var(--text)}.team-list{display:grid;gap:8px}.team-edit-row{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center}

.summary-head{gap:14px;align-items:flex-start}
.summary-date-controls{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end;align-items:center}
.summary-date-controls label{font-size:12px;color:var(--muted);font-weight:800;display:flex;gap:5px;align-items:center}
.summary-date-controls select{height:34px;border:1px solid var(--line);border-radius:10px;background:var(--panel);color:var(--text);font-weight:800;padding:0 8px}
@media (max-width:640px){.summary-head{display:block}.summary-date-controls{justify-content:flex-start;margin-top:10px}.summary-date-controls label{flex:1 1 95px}.summary-date-controls select{width:100%}}

/* v30 debts sticky row/column */
.debt-table-wrap{max-height:64vh;position:relative}
.debt-table-wrap table{border-collapse:separate;border-spacing:0}
.debt-table-wrap.sticky-top thead th{position:sticky;top:0;z-index:5;box-shadow:0 1px 0 var(--border),0 6px 14px rgba(15,23,42,.08)}
.debt-table-wrap.sticky-first th:first-child,.debt-table-wrap.sticky-first td:first-child{position:sticky;left:0;z-index:4;background:var(--surface-alt);box-shadow:1px 0 0 var(--border),8px 0 14px rgba(15,23,42,.06);font-weight:800}
.debt-table-wrap.sticky-top.sticky-first thead th:first-child{z-index:7}
:root[data-theme="dark"] .debt-table-wrap.sticky-first th:first-child,:root[data-theme="dark"] .debt-table-wrap.sticky-first td:first-child{box-shadow:1px 0 0 var(--border),8px 0 16px rgba(0,0,0,.28)}

/* v31 debt table column resizing */
.resizable-debts{table-layout:fixed;min-width:990px}
.debt-col-drag{position:absolute;right:-4px;top:0;width:8px;height:100%;cursor:col-resize;touch-action:none;z-index:8}
.resizable-debts th{position:relative}
.debt-col-drag:hover{background:rgba(14,165,233,.28)}


/* v34 finance/debt mobile layout polish */
.finance-main-kpis{grid-template-columns:1fr;margin:10px 0 12px}
.finance-main-kpis .kpi-card{min-width:0}
.finance-main-kpis .kpi-value{font-size:clamp(24px,7vw,34px);line-height:1.05}
.finance-main-kpis .kpi-meta-line{display:block;margin-top:6px;color:var(--muted);font-weight:800}
.finance-main-kpis .kpi-meta-line span{display:block;overflow-wrap:anywhere}
.finance-main-kpis .kpi-bar{margin-top:10px}
.summary-total-row td{background:var(--surface-alt);font-weight:850;border-top:2px solid var(--border);white-space:nowrap}
.finance-table-wrap.sticky-first tfoot td:first-child,.debt-table-wrap.sticky-first tfoot td:first-child{position:sticky;left:0;z-index:4;background:var(--surface-alt);box-shadow:1px 0 0 var(--border),8px 0 14px rgba(15,23,42,.06)}
.debt-total-row td:first-child{white-space:normal;min-width:0;line-height:1.2}
@media (max-width:759px){.finance-panel{padding:12px 10px}.finance-main-kpis{gap:9px}.finance-main-kpis .kpi-card{padding:13px}.finance-main-kpis .kpi-value{font-size:25px}.finance-main-kpis .kpi-bar b{font-size:11px}.finance-table-wrap,.debt-table-wrap{max-height:58vh}.summary-total-row td{font-size:13px;padding:9px 8px}.resizable-finance{min-width:720px}.resizable-debts{min-width:900px}}


/* v36 accounting/debts/tv summary polish */
.brigade-summary-table{overflow:visible}
.brigade-summary-panel{padding-bottom:16px}
.debt-status-legend{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0 8px;color:var(--muted);font-size:12px}
.debt-status-legend span{display:inline-flex;align-items:center;gap:6px;background:var(--surface-alt);border:1px solid var(--border);border-radius:999px;padding:6px 9px}
.debt-dot{display:inline-block;width:12px;height:12px;border-radius:50%;border:1px solid var(--border)}
.debt-row.status-Новый td,.debt-row.status-Ожидаем\ оплату td{background:rgba(239,248,255,.72)}
.debt-row.status-Частично\ оплачен td{background:rgba(255,250,235,.82)}
.debt-row.status-Просрочен td{background:rgba(255,244,237,.86)}
.debt-row.status-Проблемный td{background:rgba(254,243,242,.9)}
.resizable-debts{min-width:870px}
.tv-summary-panel{min-height:calc(100vh - 190px)}
.tv-total-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin:12px 0}
.tv-team-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.tv-team-card{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px 12px;align-items:center;border:1px solid var(--border);border-radius:16px;padding:12px;background:var(--surface-alt)}
.tv-team-card h3{margin:0;font-size:17px}.tv-team-card p{margin:3px 0 0;color:var(--muted);font-size:13px}.tv-team-card strong{font-size:22px}.tv-team-card .mini-progress{grid-column:1/-1;height:12px;border-radius:999px;background:rgba(15,23,42,.08);overflow:hidden}.tv-team-card .mini-progress span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#14b8a6,#22c55e)}
@media (min-width:1100px){.tv-team-grid{grid-template-columns:repeat(5,minmax(0,1fr))}.tv-summary-panel .kpi-card{padding:18px}.tv-summary-panel .kpi-value{font-size:38px}}
@media (max-width:759px){.brigade-summary-table{font-size:12px}.resizable-debts{min-width:820px}.tv-total-grid,.tv-team-grid{grid-template-columns:1fr}.tv-summary-panel{min-height:auto}}

/* v38: owner finance collapsed into one expandable summary card */
.finance-summary-single{display:grid;grid-template-columns:1fr;gap:10px;margin:10px 0 12px}
.finance-total-card{width:100%;border:0;text-align:left;cursor:pointer;position:relative;display:grid;grid-template-rows:auto auto auto auto;gap:8px;padding:18px 20px;background:linear-gradient(135deg,#ecfeff,#f0fdf4);box-shadow:0 16px 34px rgba(15,23,42,.10)}
.finance-total-card .tap-hint{position:absolute;right:14px;top:10px;margin:0;font-size:10px;text-transform:uppercase;letter-spacing:.03em;color:var(--muted)}
.finance-total-card .kpi-label{font-size:13px;text-transform:uppercase;letter-spacing:.03em;color:var(--muted);font-weight:900;padding-right:92px}
.finance-total-card .kpi-value{font-size:36px;line-height:1;text-align:center;margin:3px 0 0}
.finance-plan-inline{justify-content:center;gap:12px;flex-wrap:wrap;font-size:12px;margin:0 0 2px;text-align:center}
.finance-total-card .kpi-bar{height:24px}
.finance-detail-panel{padding:12px;border-radius:18px;background:rgba(255,255,255,.72);border:1px solid rgba(148,163,184,.22);box-shadow:0 12px 28px rgba(15,23,42,.07)}
.finance-detail-panel.hidden{display:none}
.finance-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px}
.finance-detail-grid div,.manip-breakdown.compact div{padding:10px 12px;border-radius:14px;background:var(--surface);border:1px solid var(--border)}
.finance-detail-grid b,.manip-breakdown.compact b{display:block;font-size:12px;color:var(--muted);margin-bottom:4px}.finance-detail-grid span,.manip-breakdown.compact span{font-weight:900}
.finance-share-bar{height:20px;margin:8px 0 10px}.manip-breakdown.compact{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:0;padding:0;background:transparent;border:0;box-shadow:none}
@media (max-width:759px){.finance-total-card{padding:15px 12px 13px}.finance-total-card .kpi-label{font-size:11px;padding-right:74px}.finance-total-card .tap-hint{font-size:8.5px;right:10px;top:9px}.finance-total-card .kpi-value{font-size:31px}.finance-plan-inline{font-size:10px;gap:7px}.finance-total-card .kpi-bar{height:22px}.finance-detail-grid,.manip-breakdown.compact{grid-template-columns:1fr}.finance-detail-grid div,.manip-breakdown.compact div{padding:8px 10px}.finance-table-wrap{max-height:none;overflow-x:auto;overflow-y:visible}.finance-table-wrap table{min-width:610px}.finance-table-wrap th,.finance-table-wrap td{padding:8px 7px;font-size:12px}.finance-col-drag{display:none}}
:root[data-theme="dark"] .finance-total-card{background:linear-gradient(135deg,rgba(20,83,45,.58),rgba(15,23,42,.92))}:root[data-theme="dark"] .finance-detail-panel{background:rgba(15,23,42,.58);border-color:rgba(148,163,184,.22)}

/* v40: draggable column widths for all data tables */
.resizable-finance,.resizable-debts,.resizable-audit{table-layout:fixed}
.resizable-finance th,.resizable-debts th,.resizable-audit th{position:relative;user-select:none}
.finance-col-drag,.debt-col-drag,.table-col-drag{position:absolute;right:-4px;top:0;width:12px;height:100%;cursor:col-resize;touch-action:none;z-index:12;background:transparent}
.finance-col-drag::after,.debt-col-drag::after,.table-col-drag::after{content:"";position:absolute;top:7px;bottom:7px;left:5px;width:2px;border-radius:2px;background:rgba(20,184,166,.32)}
.finance-col-drag:hover,.debt-col-drag:hover,.table-col-drag:hover{background:rgba(20,184,166,.16)}
.resizable-audit{min-width:840px}
.audit-table-wrap{max-height:62vh}
@media (max-width:759px){.resizable-audit{min-width:760px}.finance-col-drag,.debt-col-drag,.table-col-drag{width:16px;right:-7px}}

/* v48 TV clean header */
body.role-tv .brand-lockup h1,
body.role-tv .brand-lockup .subtitle{display:none}
body.role-tv .topbar{justify-content:space-between;align-items:center;margin-bottom:6px;gap:10px;flex-wrap:nowrap}
body.role-tv .brand-lockup{justify-content:flex-start;padding-top:0;min-width:0;flex:0 1 auto}
body.role-tv .project-logo{margin-top:0;max-height:58px;width:min(220px,42vw);object-fit:contain}
body.role-tv .session-controls{display:flex;justify-content:flex-end;align-items:center;gap:8px;margin-left:auto;flex:0 0 auto;flex-wrap:nowrap}
body.role-tv .session-controls .role-badge{display:none}
body.role-tv #tabs{display:none}
body.role-tv .tv-top-tabs{display:flex;gap:8px;align-items:center;flex-wrap:nowrap}
body.role-tv .tv-top-tabs .tab{margin:0;padding:9px 16px;white-space:nowrap}
body.role-tv .toolbar{margin-top:4px}
body.role-tv .month-strip{grid-template-columns:minmax(0,1fr)}
body.role-tv .toolbar-title{display:none}
body.role-tv .month-buttons{justify-content:flex-start}
@media (max-width:759px){body.role-tv .topbar{display:flex} body.role-tv .project-logo{width:min(180px,38vw)} body.role-tv .session-controls{gap:5px} body.role-tv .tv-top-tabs .tab{padding:7px 10px;font-size:13px}}

/* v49 TV summary logo + dark logo asset */
.project-logo-dark{display:none}
:root[data-theme="dark"] .project-logo-light{display:none}
:root[data-theme="dark"] .project-logo-dark{display:block}
body.role-tv.tab-tvsummary .project-logo{max-height:116px;width:min(440px,48vw)}
body.role-tv.tab-tvsummary .topbar{align-items:flex-start}
@media (max-width:759px){body.role-tv.tab-tvsummary .project-logo{max-height:92px;width:min(330px,52vw)}}


/* v60 mobile header: controls on the same row as logo */
.topbar{align-items:center;flex-wrap:nowrap}
.session-controls{margin-left:auto;justify-content:flex-end;flex-wrap:nowrap;min-width:0}
.brand-lockup{flex:0 1 auto;min-width:0}
@media (max-width:759px){
  .topbar{display:flex;grid-template-columns:none;align-items:center;justify-content:space-between;gap:6px;margin-bottom:8px;flex-wrap:nowrap}
  .brand-lockup{padding-top:0;align-items:center;flex:1 1 auto;min-width:96px}
  .project-logo{margin-top:0;width:clamp(112px,34vw,138px);max-height:46px}
  .session-controls{margin-left:auto;gap:4px;justify-content:flex-end;flex:0 0 auto;flex-wrap:nowrap}
  .session-controls .btn.icon{width:32px;height:32px;font-size:15px}
  .session-controls .btn.mini{padding:6px 8px;font-size:11px;line-height:1;border-radius:999px}
  .session-controls .badge{font-size:10.5px;line-height:1;padding:6px 7px;max-width:82px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
}
@media (max-width:380px){
  .session-controls .role-badge{order:0}
  .topbar{gap:4px}
  .project-logo{width:108px;max-height:42px}
  .session-controls{gap:3px}
  .session-controls .btn.icon{width:30px;height:30px}
  .session-controls .btn.mini{padding:6px 7px;font-size:10.5px}
  .session-controls .badge{font-size:10px;padding:6px 6px;max-width:72px}
}

/* v66: finance table fits the phone width without horizontal inner scroll */
@media (max-width:759px){
  .finance-panel{padding:10px 6px}
  .finance-panel .sticky-controls{display:none}
  .finance-table-wrap{max-height:none!important;overflow:visible!important;border-radius:10px}
  .finance-table-wrap table{width:100%!important;min-width:0!important;table-layout:fixed}
  .finance-table-wrap col:nth-child(1){width:24%!important}
  .finance-table-wrap col:nth-child(2){width:13%!important}
  .finance-table-wrap col:nth-child(3){width:13%!important}
  .finance-table-wrap col:nth-child(4){width:17%!important}
  .finance-table-wrap col:nth-child(5){width:16%!important}
  .finance-table-wrap col:nth-child(6){width:17%!important}
  .finance-table-wrap th,.finance-table-wrap td{padding:5px 2px!important;font-size:10px!important;line-height:1.12!important;white-space:normal!important;overflow-wrap:anywhere!important}
  .finance-table-wrap th{font-size:9px!important}
  .finance-table-wrap.sticky-top thead th,.finance-table-wrap.sticky-first th:first-child,.finance-table-wrap.sticky-first td:first-child,.finance-table-wrap.sticky-first tfoot td:first-child{position:static!important;box-shadow:none!important}
  .finance-table-wrap tfoot td{font-size:9px!important;font-weight:850}
  .finance-col-drag{display:none!important}
}

@media (max-width:380px){
  .finance-table-wrap th,.finance-table-wrap td{font-size:9px!important;padding:4px 1px!important}
  .finance-table-wrap th{font-size:8px!important}
}

/* v67: synced entry UI and mobile debt table overlap fix */
.compact-entry-panel{padding:10px 12px}
.entry-mode-head{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.compact-entry-panel .entry-mode-tabs{margin:8px 0 0}
.entry-manip-legend{color:var(--muted);font-size:12px;font-weight:750}
.entry-section-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px;flex-wrap:wrap}
.entry-work-panel h2{font-size:20px}
.entry-save-row{display:flex;justify-content:flex-end;margin-top:12px}
.entry-save-row .btn{min-width:190px}
.plan-settings-panel{margin-bottom:0}
.debt-table-wrap thead th{background:var(--surface-alt)}
.debt-table-wrap tfoot td{background:var(--surface-alt)}
.debt-table-wrap.sticky-first .debt-row td:first-child{background:var(--surface)!important}

@media (max-width:759px){
  .compact-entry-panel{padding:9px 10px}
  .entry-mode-head{display:grid;gap:5px}
  .entry-mode-head h2{font-size:18px}
  .entry-manip-legend{font-size:11px;line-height:1.25}
  .compact-entry-panel .entry-mode-tabs{grid-template-columns:1fr 1fr;gap:6px;margin-top:7px}
  .compact-entry-panel .entry-mode{padding:8px 7px;font-size:12px}
  .entry-work-panel{padding:11px 9px}
  .entry-work-panel h2{font-size:18px}
  .entry-section-head .muted{font-size:12px}
  .entry-save-row{display:grid}
  .entry-save-row .btn{width:100%;min-width:0}
  .team-manager h3,.plan-settings-panel h3{font-size:17px}
  .debt-table-wrap{overflow:auto;max-height:58vh}
  .debt-table-wrap .debt-col-drag,.debt-table-wrap + .debt-col-drag{display:none!important}
  .debt-table-wrap.sticky-first th:first-child,
  .debt-table-wrap.sticky-first td:first-child,
  .debt-table-wrap.sticky-first tfoot td:first-child{
    position:static!important;
    left:auto!important;
    z-index:auto!important;
    box-shadow:none!important;
  }
  .debt-table-wrap th,.debt-table-wrap td{white-space:normal;overflow-wrap:anywhere}
  .debt-table-wrap thead th,.debt-table-wrap tfoot td{background:var(--surface-alt)!important}
}
