/* common.css — Estil compartit per les 4 webs */
:root{
  --bg:#f5f1ea;
  --paper:#fffdf9;
  --ink:#1a1a17;
  --ink-soft:#3d3d38;
  --muted:#7a766e;
  --line:#d8d2c5;
  --line-soft:#e8e2d4;
  --accent:#ff6a1f;
  --accent-soft:#fff0e3;
  --red:#cc1f1f;
  --red-soft:#fbe7e7;
  --yellow:#c49010;
  --green:#3a7a40;
  --blue:#1f6fb2;
  --shadow: 0 1px 2px rgba(0,0,0,.04), 0 4px 12px rgba(0,0,0,.04);
  --r: 6px;
  --lane-label-w: 240px;
  --row-h: 52px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:"Inter","IBM Plex Sans",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--bg);
  color:var(--ink);
  font-size:13px;
  line-height:1.4;
  overflow:hidden;
}

button,input,select,textarea{font:inherit;color:inherit}
button{cursor:pointer;border:none;background:none}
input,select,textarea{
  border:1px solid var(--line);
  border-radius:var(--r);
  padding:6px 9px;
  background:#fff;
  color:var(--ink);
}
input:focus,select:focus,textarea:focus{
  outline:2px solid var(--accent);
  outline-offset:-1px;
  border-color:transparent;
}

/* TOPBAR */
.topbar{
  background:var(--ink);
  color:#fff;
  height:52px;
  display:flex;
  align-items:center;
  padding:0 16px;
  gap:16px;
  border-bottom:2px solid var(--accent);
  flex-shrink:0;
}
.topbar .brand{display:flex;align-items:center;gap:10px;font-weight:600;letter-spacing:.04em}
.topbar .brand .bombers-logo{
  display:grid;grid-template-columns:1fr 1fr;gap:2px;
}
.topbar .brand .bombers-logo span{
  display:block;width:9px;height:9px;background:#cc1f1f;
}
.topbar .brand .brand-text{display:flex;flex-direction:column;line-height:1;}
.topbar .brand .brand-title{font-size:13px;font-weight:700;letter-spacing:.1em;color:#fff}
.topbar .brand .brand-sub{font-size:9px;font-weight:500;letter-spacing:.15em;color:#a9a59c;margin-top:2px}
.topbar .brand .mode-tag{
  font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  padding:3px 8px;border-radius:3px;background:rgba(255,255,255,.1);color:#fff;
}
.topbar .brand .mode-tag.viewer{background:#1f6fb2;color:#fff}
.topbar .brand .mode-tag.editor{background:var(--accent);color:#fff}

.topbar-meta{display:flex;align-items:center;gap:12px;flex:1;min-width:0;flex-wrap:wrap}
.topbar-meta .field{display:flex;align-items:center;gap:6px;font-size:11px;color:#bdb9b0}
.topbar-meta .field label{font-weight:600;letter-spacing:.05em;text-transform:uppercase;font-size:10px;color:#a9a59c}
.topbar-meta input[type="text"],.topbar-meta input[type="datetime-local"]{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.15);
  color:#fff;
  font-size:12px;
  padding:5px 8px;
  border-radius:4px;
}
.topbar-meta input::placeholder{color:#85807a}
.topbar-meta .read-pill{
  background:rgba(255,255,255,.1);
  padding:5px 10px;
  border-radius:4px;
  font-size:12px;
  color:#fff;
}

.topbar-actions{display:flex;align-items:center;gap:8px}
.btn{
  display:inline-flex;align-items:center;gap:5px;
  padding:6px 11px;
  font-size:12px;font-weight:500;
  border:1px solid var(--line);
  border-radius:var(--r);
  background:#fff;color:var(--ink-soft);
  transition:all .12s;
  white-space:nowrap;
}
.btn:hover{background:var(--bg);border-color:var(--muted)}
.btn.primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn.primary:hover{background:#e85f12}
.btn.dark{background:rgba(255,255,255,.1);color:#fff;border-color:rgba(255,255,255,.18)}
.btn.dark:hover{background:rgba(255,255,255,.18)}
.btn.danger{background:#fff;color:var(--red);border-color:var(--red-soft)}
.btn.danger:hover{background:var(--red-soft)}
.btn.ghost{background:transparent;border-color:transparent;color:var(--muted)}
.btn.ghost:hover{color:var(--ink)}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* AUTOSAVE */
.autosave-chip{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 10px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.15);
  border-radius:4px;
  font-size:11px;
  color:#dfdcd4;
}
.autosave-chip.saved .autosave-dot{background:#3a7a40}
.autosave-chip.saving .autosave-dot{background:#c49010;animation:pulse 1s infinite}
.autosave-chip.error .autosave-dot{background:var(--red)}
.autosave-chip.unlinked .autosave-dot{background:#85807a}
.autosave-chip.connected .autosave-dot{background:#3a7a40}
.autosave-dot{width:7px;height:7px;border-radius:50%}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

/* PERIOD SELECTOR */
.po-bar{
  background:var(--paper);
  border-bottom:1px solid var(--line);
  padding:8px 16px;
  display:flex;align-items:center;gap:10px;
  flex-shrink:0;
  flex-wrap:wrap;
}
.po-bar > .btn{flex-shrink:0}
.po-pills{display:flex;gap:4px;overflow-x:auto;flex:1;min-width:0;padding-bottom:2px}
.po-pill{
  padding:4px 10px;
  font-size:11px;font-weight:600;
  border:1px solid var(--line);
  border-radius:14px;
  background:#fff;color:var(--ink-soft);
  white-space:nowrap;
  flex-shrink:0;
  display:flex;align-items:center;gap:6px;
}
.po-pill .po-num{font-family:"IBM Plex Mono",monospace;font-size:10px}
.po-pill .po-time{color:var(--muted);font-weight:400;font-size:10px}
.po-pill:hover{background:var(--bg)}
.po-pill.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.po-pill.active .po-time{color:rgba(255,255,255,.85)}
.po-pill.current{box-shadow:0 0 0 2px var(--accent-soft);}
.po-pill.current::before{
  content:"●";color:var(--accent);font-size:10px;
}
.po-pill.active.current::before{color:#fff}

.po-info{
  font-size:11px;color:var(--muted);
  display:flex;align-items:center;gap:10px;
  font-family:"IBM Plex Mono",monospace;
}
.po-info b{color:var(--ink);font-weight:600}

/* MAIN LAYOUT */
.main{
  flex:1;
  display:flex;
  min-height:0;
  position:relative;
  overflow:hidden;
}
.gantt-area{flex:1;overflow:auto;background:var(--bg);position:relative}
.side{
  width:340px;
  background:var(--paper);
  border-left:1px solid var(--line);
  display:flex;
  flex-direction:column;
  flex-shrink:0;
}

/* GANTT */
.gantt{position:relative;min-height:100%}
.gantt-header{
  position:sticky;top:0;z-index:30;
  background:var(--paper);
  border-bottom:1px solid var(--line);
}
.header-row{display:flex;align-items:stretch}
.lane-head{
  width:var(--lane-label-w);
  flex-shrink:0;
  padding:10px 14px;
  border-right:2px solid var(--line);
  background:var(--paper);
  position:sticky;left:0;z-index:35;
  box-shadow:2px 0 4px rgba(0,0,0,.04);
}
.lane-head .title{font-weight:600;font-size:13px}
.lane-head .sub{font-size:10px;color:var(--muted);margin-top:2px}

.time-rail{
  position:relative;
  height:36px;
  border-bottom:1px solid var(--line-soft);
}
.time-tick{position:absolute;top:0;height:36px;border-left:1px solid var(--line-soft)}
.time-tick.major{border-left-color:var(--line);height:36px}
.time-tick.day-change{border-left-color:var(--ink);border-left-width:2px}
.tick-label{
  position:absolute;left:3px;top:18px;
  font-size:10px;font-family:"IBM Plex Mono",monospace;
  color:var(--muted);
}
.day-label{
  position:absolute;left:3px;top:2px;
  font-size:10px;font-weight:700;color:var(--ink);
  background:var(--paper);padding:1px 4px;border-radius:2px;
}

/* PO band overlay (mostra els límits dels PO sobre el rail temporal) */
.po-band{
  position:absolute;top:0;height:36px;
  background:rgba(255,106,31,.06);
  border-left:2px solid var(--accent);
  pointer-events:none;
}
.po-band-label{
  position:absolute;top:2px;left:4px;
  font-size:9px;font-weight:700;
  color:var(--accent);
  font-family:"IBM Plex Mono",monospace;
}

/* INDICATORS RAIL */
.ind-rail{
  position:relative;
  height:32px;
  background:linear-gradient(180deg,var(--paper) 0%,var(--bg) 100%);
  border-bottom:1px solid var(--line);
}
.ind-pill{
  position:absolute;top:5px;
  height:22px;
  display:flex;align-items:center;gap:5px;
  padding:0 8px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:11px;
  font-size:11px;
  cursor:pointer;
  transform:translateX(-50%);
  white-space:nowrap;
  box-shadow:0 1px 2px rgba(0,0,0,.05);
  user-select:none;
}
.ind-pill:hover{border-color:var(--accent)}
.ind-pill.selected{border-color:var(--accent);background:var(--accent-soft)}
.ind-pill .dot{width:6px;height:6px;background:var(--accent);border-radius:50%}
.ind-pill .time{color:var(--muted);font-family:"IBM Plex Mono",monospace;font-size:10px}

/* GANTT BODY */
.gantt-body{position:relative}
.ot-row{
  display:flex;align-items:stretch;
  border-bottom:1px solid var(--line-soft);
  background:var(--paper);
  min-height: var(--row-h);
}
.ot-row.dim{opacity:.35}
.ot-label{
  width:var(--lane-label-w);
  flex-shrink:0;
  padding:8px 12px;
  border-right:2px solid var(--line);
  position:sticky;left:0;z-index:15;
  background:var(--paper);
  display:flex;flex-direction:column;gap:4px;
  justify-content:center;
  box-shadow:2px 0 4px rgba(0,0,0,.04);
}
.ot-label .tag{
  display:flex;align-items:center;gap:6px;
  font-size:10px;font-family:"IBM Plex Mono",monospace;
  color:var(--muted);
}
.ot-label .num{
  background:var(--ink);color:#fff;
  padding:1px 6px;border-radius:3px;
  font-weight:700;
}
.ot-label .sector-pill{
  background:var(--bg);
  padding:1px 6px;border-radius:8px;
  color:var(--ink-soft);
}
.ot-label .name{
  font-size:12px;font-weight:600;
  line-height:1.25;
}
.ot-label .name-input{
  border:none;background:transparent;padding:0;
  font-size:12px;font-weight:600;
}
.ot-label .name-input:focus{background:#fff;border:1px solid var(--accent);padding:2px 4px;outline:none}
.ot-label .meta{font-size:10px;color:var(--muted);display:flex;gap:8px;align-items:center}
.ot-label .meta .actions{margin-left:auto;display:flex;gap:4px}
.ot-label .meta button.icon{
  padding:2px 4px;border-radius:3px;color:var(--muted);
  display:inline-flex;
}
.ot-label .meta button.icon:hover{background:var(--bg);color:var(--ink)}
.ot-label .meta button.icon.linking{background:var(--accent);color:#fff}

.ot-track{
  flex:1;position:relative;
  background:
    linear-gradient(90deg, transparent 49.5%, var(--line-soft) 49.5%, var(--line-soft) 50.5%, transparent 50.5%);
  background-size:60px 100%;
  background-position:0 0;
}
.ot-track.linking-target{background-color:var(--accent-soft)}

/* LANES (carrils dins l'OT) */
.ot-lane{
  position:relative;
  height:48px;
  border-bottom:1px dashed var(--line-soft);
}
.ot-lane:last-child{border-bottom:none}
.ot-lane-num{
  position:absolute;left:4px;top:2px;
  font-size:9px;color:var(--muted);
  font-family:"IBM Plex Mono",monospace;
  pointer-events:none;
  z-index:1;
}

/* BARS */
.bar{
  position:absolute;
  top:4px;height:40px;
  border-radius:5px;
  padding:4px 8px;
  display:flex;flex-direction:column;justify-content:center;gap:2px;
  color:#fff;
  font-size:11px;font-weight:500;
  cursor:grab;
  overflow:hidden;
  user-select:none;
  box-shadow:0 1px 2px rgba(0,0,0,.15);
  line-height:1.2;
}
.bar:active{cursor:grabbing}
.bar.selected{outline:2px solid var(--accent);outline-offset:1px;z-index:5}
.bar.link-src{outline:2px solid var(--red);outline-offset:1px;animation:linkPulse 1.2s infinite;z-index:6}
.bar.link-target{cursor:crosshair;outline:1px dashed rgba(255,255,255,.7);outline-offset:1px}
.bar.link-target:hover{outline:2px solid var(--accent);outline-offset:1px}
@keyframes linkPulse{0%,100%{box-shadow:0 0 0 0 rgba(204,31,31,.5)}50%{box-shadow:0 0 0 4px rgba(204,31,31,0)}}
.bar.status-done{opacity:.75}
.bar.status-pending{background-image:repeating-linear-gradient(135deg,rgba(0,0,0,0) 0 6px,rgba(0,0,0,.12) 6px 12px)}

/* Línia 1: nom (fins a 2 línies) i pastilla de dependències */
.bar-row1{
  display:flex;align-items:flex-start;gap:6px;
  min-width:0;
}
.bar-deps{
  font-size:9px;font-weight:700;
  background:rgba(0,0,0,.25);padding:0 4px;border-radius:2px;
  flex-shrink:0;white-space:nowrap;
  margin-top:1px;
}
.bar-label{
  font-weight:600;
  flex:1;min-width:0;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  word-break:break-word;
  font-size:11px;
  line-height:1.2;
}

/* Línia 2: recursos i hora */
.bar-row2{
  display:flex;align-items:center;gap:6px;
  font-size:10px;opacity:.9;
  min-width:0;
  margin-top:auto;
}
.bar-resource{background:rgba(255,255,255,.18);padding:0 4px;border-radius:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;flex-shrink:1}
.bar-sub{font-family:"IBM Plex Mono",monospace;white-space:nowrap;margin-left:auto;flex-shrink:0}

/* Quan la barra és estreta el contingut s'oculta progressivament */
.bar.narrow .bar-row2{display:none}

.bar .handle{position:absolute;top:0;width:5px;height:100%;cursor:ew-resize;opacity:0}
.bar .handle.l{left:0}
.bar .handle.r{right:0}
.bar:hover .handle{opacity:1;background:rgba(255,255,255,.3)}

.bar-draft{
  position:absolute;
  top:3px;height:24px;
  background:rgba(255,106,31,.4);
  border:2px dashed var(--accent);
  border-radius:4px;
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:10px;font-weight:600;
  pointer-events:none;
}

/* OVERLAY (now line, indicator vertical lines, dependency arrows) */
.overlay-layer{position:absolute;pointer-events:none;z-index:8}
.ind-line{position:absolute;top:0;bottom:0;width:1px;border-left:1px dashed var(--accent);opacity:.35;pointer-events:none}
.now-line{position:absolute;top:0;bottom:0;width:2px;background:var(--red);box-shadow:0 0 6px rgba(204,31,31,.4);pointer-events:none;z-index:10}
.now-line::before{
  content:"";position:absolute;top:-4px;left:-4px;
  width:10px;height:10px;background:var(--red);border-radius:50%;
}
.po-active-band{
  position:absolute;top:0;bottom:0;
  background:rgba(255,106,31,.04);
  border-left:1px solid var(--accent);
  border-right:1px solid var(--accent);
  pointer-events:none;
}
.dep-svg{position:absolute;inset:0;width:100%;height:100%;overflow:visible;pointer-events:none}

/* CONTEXT MENU */
.ctx-menu{
  position:fixed;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--r);
  box-shadow:var(--shadow), 0 8px 24px rgba(0,0,0,.12);
  padding:4px;
  min-width:200px;
  z-index:1000;
  font-size:12px;
}
.ctx-menu .ctx-header{
  padding:6px 10px;
  font-size:10px;
  text-transform:uppercase;
  color:var(--muted);
  letter-spacing:.05em;
  font-weight:600;
}
.ctx-menu .ctx-item{
  padding:7px 10px;
  border-radius:4px;
  display:flex;align-items:center;gap:8px;
  cursor:pointer;
  user-select:none;
}
.ctx-menu .ctx-item:hover{background:var(--bg)}
.ctx-menu .ctx-item.danger{color:var(--red)}
.ctx-menu .ctx-divider{height:1px;background:var(--line);margin:4px 0}
.ctx-menu .ctx-sub{font-size:10px;color:var(--muted);margin-left:auto;font-family:"IBM Plex Mono",monospace}

/* SIDE PANEL */
.side-tabs{display:flex;border-bottom:1px solid var(--line);background:var(--bg)}
.side-tabs button{
  flex:1;padding:10px;
  background:none;border:none;
  font-size:12px;font-weight:500;
  color:var(--muted);
  border-bottom:2px solid transparent;
}
.side-tabs button.active{color:var(--ink);background:var(--paper);border-bottom-color:var(--accent)}

.side-body-wrap{flex:1;display:flex;flex-direction:column;min-height:0}
.side-head{padding:14px 16px;border-bottom:1px solid var(--line-soft);display:flex;align-items:flex-start;justify-content:space-between;gap:8px}
.side-head h3{font-size:13px;font-weight:600}
.side-sub{font-size:11px;color:var(--muted);margin-top:2px}
.side-body{flex:1;overflow:auto;padding:14px 16px;display:flex;flex-direction:column;gap:12px}

.field-grp{display:flex;flex-direction:column;gap:4px}
.field-grp label{font-size:10px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.field-grp input,.field-grp select,.field-grp textarea{font-size:12px}
.field-grp textarea{min-height:60px;resize:vertical;font-family:inherit}
.field-row{display:flex;gap:8px}
.field-row .field-grp{flex:1}

.chip-row{display:flex;flex-wrap:wrap;gap:5px}
.chip{
  display:inline-flex;align-items:center;gap:5px;
  padding:4px 9px;font-size:11px;
  border:1px solid var(--line);
  border-radius:14px;
  background:#fff;color:var(--ink-soft);
}
.chip:hover{border-color:var(--muted)}
.chip.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.chip .swatch{width:8px;height:8px;border-radius:2px}

.status-seg{display:flex;border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.status-seg button{flex:1;padding:6px 8px;background:#fff;font-size:11px;color:var(--ink-soft);border-right:1px solid var(--line)}
.status-seg button:last-child{border-right:none}
.status-seg button:hover{background:var(--bg)}
.status-seg button.active{background:var(--ink);color:#fff}
.status-seg button.active.done{background:var(--green)}
.status-seg button.active.inprogress{background:var(--yellow)}

.dep-list{display:flex;flex-direction:column;gap:4px}
.dep-item{
  display:flex;align-items:center;gap:6px;
  padding:5px 8px;background:var(--bg);
  border-radius:var(--r);
  font-size:11px;
}
.dep-item .dep-info{display:flex;align-items:center;gap:6px;flex:1;min-width:0}
.dep-item .dep-tag{background:var(--ink);color:#fff;padding:1px 5px;border-radius:3px;font-size:10px;font-family:"IBM Plex Mono",monospace}
.dep-item button{padding:2px 4px;color:var(--muted);border-radius:3px}
.dep-item button:hover{color:var(--red);background:var(--red-soft)}

.empty-hint{
  font-size:11px;color:var(--muted);
  background:var(--bg);
  padding:10px 12px;
  border-radius:var(--r);
  border:1px dashed var(--line);
  line-height:1.5;
}

/* INDICATOR LIST */
.ind-list{display:flex;flex-direction:column;gap:6px}
.ind-card{
  background:#fff;border:1px solid var(--line);
  border-radius:var(--r);padding:10px;
  cursor:pointer;
}
.ind-card:hover{border-color:var(--muted)}
.ind-card.selected{border-color:var(--accent);background:var(--accent-soft)}
.ind-top{display:flex;align-items:center;justify-content:space-between;gap:6px}
.ind-name{font-size:12px;font-weight:600}
.ind-time{font-family:"IBM Plex Mono",monospace;font-size:11px;color:var(--muted)}
.ind-watcher{font-size:11px;color:var(--ink-soft);margin-top:3px}
.ind-notes{font-size:11px;color:var(--muted);margin-top:3px;line-height:1.4}

/* FOOTER */
.bottombar{
  background:var(--paper);
  border-top:1px solid var(--line);
  padding:6px 16px;
  display:flex;align-items:center;gap:14px;
  flex-shrink:0;
  font-size:11px;
}
.stats{display:flex;gap:12px}
.stat{color:var(--muted)}
.stat b{color:var(--ink);font-weight:700;margin-right:3px}
.legend{display:flex;gap:10px;flex-wrap:wrap;margin-left:auto}
.legend .item{display:flex;align-items:center;gap:5px;color:var(--ink-soft)}
.legend .sw{width:10px;height:10px;border-radius:2px;display:inline-block}

/* ZOOM FAB */
.zoom-fab{position:fixed;bottom:16px;right:354px;display:flex;flex-direction:column;gap:4px;z-index:50}
.fab-btn{
  width:36px;height:36px;
  border-radius:50%;background:#fff;
  border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow);
}
.fab-btn:hover{border-color:var(--muted)}

.no-side .zoom-fab{right:16px}

/* FLOATING ADD */
.floating-add-wrap{
  position:fixed;
  bottom:50px;left:16px;
  z-index:20;
}
.floating-add-ot{
  background:var(--accent);color:#fff;
  padding:9px 14px;
  border-radius:20px;
  font-size:12px;font-weight:600;
  box-shadow:0 4px 12px rgba(255,106,31,.3);
  display:inline-flex;align-items:center;gap:6px;
}
.floating-add-ot:hover{background:#e85f12}
.floating-add-menu{
  position:absolute;
  bottom:calc(100% + 6px);left:0;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--r);
  box-shadow:var(--shadow), 0 8px 24px rgba(0,0,0,.12);
  padding:4px;
  min-width:220px;
  font-size:12px;
}
.floating-add-menu .ctx-item{
  padding:8px 10px;
  border-radius:4px;
  display:flex;align-items:center;gap:8px;
  cursor:pointer;user-select:none;
}
.floating-add-menu .ctx-item:hover{background:var(--bg)}
.floating-add-menu .ctx-item.disabled{opacity:.4;cursor:not-allowed}
.floating-add-menu .ctx-item.disabled:hover{background:transparent}

/* DROPDOWN GENÈRIC */
.dropdown{position:relative;display:inline-block}
.dropdown-menu{
  display:none;
  position:absolute;top:100%;right:0;margin-top:4px;
  background:#fff;border:1px solid var(--line);border-radius:var(--r);
  box-shadow:var(--shadow);
  min-width:180px;z-index:100;
  padding:4px;
}
.dropdown.open .dropdown-menu{display:block}
.dropdown-menu .item{
  padding:7px 10px;font-size:12px;border-radius:4px;cursor:pointer;
  display:flex;align-items:center;gap:6px;
}
.dropdown-menu .item:hover{background:var(--bg)}

/* MODE BANNER */
.mode-banner{
  position:fixed;bottom:80px;left:50%;transform:translateX(-50%);
  background:var(--ink);color:#fff;
  padding:8px 14px;border-radius:20px;
  display:flex;align-items:center;gap:10px;
  box-shadow:var(--shadow);
  z-index:30;font-size:12px;
}
.mode-banner button{
  background:rgba(255,255,255,.15);
  color:#fff;
  padding:3px 8px;border-radius:4px;
  font-size:11px;
}
.mode-banner button:hover{background:rgba(255,255,255,.25)}

/* PRINT */
@media print{
  .topbar,.po-bar,.side,.zoom-fab,.floating-add-ot,.floating-add-wrap,.bottombar{display:none!important}
  body{background:#fff}
  .gantt-area{overflow:visible}
}

/* SCROLLBARS subtils */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:#cdc7b8;border-radius:5px;border:2px solid var(--bg)}
::-webkit-scrollbar-thumb:hover{background:var(--muted)}
::-webkit-scrollbar-track{background:transparent}
