:root{
  --bg:#0f172a;
  --panel:#111827;
  --panel2:#0b1220;
  --text:#e5e7eb;
  --muted:#9ca3af;
  --border:rgba(255,255,255,.08);
  --active:rgba(255,255,255,.12);
  --hover:rgba(255,255,255,.07);
  --pin: rgba(255,255,255,.10);
  --ok: rgba(34,197,94,.18);
  --warn: rgba(251,191,36,.18);
}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--text)}
a{color:inherit}
.app{display:grid;grid-template-rows:56px 1fr;height:100vh}
.header{display:flex;align-items:center;justify-content:space-between;padding:0 14px;background:var(--panel);border-bottom:1px solid var(--border)}
.header-left{display:flex;gap:8px;align-items:center}
.header-right{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.userbox{line-height:1.1;margin-left:6px}
.user-name{font-weight:600;font-size:14px}
.user-role{font-size:12px;color:var(--muted)}
.btn{padding:8px 10px;border:1px solid var(--border);border-radius:10px;background:rgba(255,255,255,.03);color:var(--text);cursor:pointer}
.btn:hover{background:rgba(255,255,255,.06)}
.btnSmall{padding:6px 10px;font-size:12px;border-radius:999px}
.btnActive{background:rgba(255,255,255,.10)}

.main{display:grid;grid-template-columns:92px 380px 1fr;min-height:0}
.dock{background:var(--panel2);border-right:1px solid var(--border);padding:10px 8px;overflow:auto}
.submenu{background:var(--panel);border-right:1px solid var(--border);padding:10px;overflow:auto}
.content{padding:16px;overflow:auto;position:relative}

.crumbs{color:var(--muted);font-size:12px;margin-bottom:6px}
.pageTitle{margin:0 0 8px 0;font-size:18px}
.pageMeta{color:var(--muted);font-size:13px;margin-bottom:12px}

/* Dock icons */
.iconItem{cursor:pointer;border-radius:12px;padding:8px;text-align:center;margin-bottom:8px}
.iconItem:hover{background:var(--hover)}
.iconItem--active{background:var(--active);outline:1px solid var(--border)}
.iconItem__ico{width:34px;height:34px;border-radius:10px;margin:0 auto 6px auto;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.06);font-size:18px}
.iconItem__label{font-size:12px}

/* Submenu */
.submenuGroup{margin-bottom:14px}
.submenuGroup__title{display:flex;align-items:center;justify-content:space-between;gap:10px;font-weight:800;font-size:14px;padding:8px 10px;border-radius:10px;background:rgba(255,255,255,.04);border:1px solid var(--border)}
.submenuGroup__actions{display:flex;gap:6px;align-items:center}
.subItem{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 10px;border-radius:10px;cursor:pointer;margin-top:8px}
.subItem:hover{background:var(--hover)}
.subItem--active{background:var(--active);outline:1px solid var(--border)}
.subItem__left{display:flex;flex-direction:column;gap:2px;min-width:0}
.subItem__label{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.subItem__note{color:var(--muted);font-size:12px}
.subItem__chev{color:var(--muted);min-width:18px;text-align:right}
.subItem__actions{display:flex;gap:6px;align-items:center;margin-left:10px}
.subSub{margin:8px 0 0 12px;padding-left:12px;border-left:1px dashed var(--border)}
.subSubItem{padding:8px 10px;border-radius:10px;cursor:pointer}
.subSubItem:hover{background:var(--hover)}
.subSubItem--active{background:var(--active);outline:1px solid var(--border)}
.subSubItem__note{color:var(--muted);font-size:12px;margin-top:2px}

/* Pins / comments */
.pinBtn{
  width:26px;height:26px;border-radius:999px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.03);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
}
.pinBtn:hover{background:rgba(255,255,255,.08)}
.pinDot{
  position:absolute;
  width:18px;height:18px;border-radius:999px;
  display:flex;align-items:center;justify-content:center;
  background:var(--pin);
  border:1px solid var(--border);
  cursor:pointer;
  user-select:none;
}
.pinDot:hover{background:rgba(255,255,255,.16)}
.commentModeOn{
  outline: 2px dashed rgba(255,255,255,.25);
  outline-offset: 4px;
}

/* Blocks layout */
.blkLayout{display:grid;grid-template-columns:1fr 360px;gap:12px;align-items:start}
.blkCol--bottom{grid-column:1 / span 2}
.blkAreaHead{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px;border:1px solid var(--border);border-radius:12px;background:rgba(255,255,255,.03)}
.blkAreaTitle{font-weight:700}
.blkItem{margin-top:10px;border:1px solid var(--border);border-radius:12px;background:rgba(255,255,255,.03);overflow:hidden}
.blkItem__top{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-bottom:1px solid var(--border)}
.blkItem__meta{color:var(--muted);font-size:12px}
.blkItem__body{padding:10px}
.blkToolbar{display:flex;gap:6px;align-items:center;flex-wrap:wrap}

.tag{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;border:1px solid var(--border);font-size:12px;color:var(--muted)}
.tag.ok{background:var(--ok)}
.tag.warn{background:var(--warn)}

.blkCard__title{font-weight:800;margin-bottom:6px}
.blkCard__text{color:var(--muted);font-size:13px;white-space:pre-wrap}

.blkPanel{border:1px solid var(--border);border-radius:12px;padding:10px;background:rgba(255,255,255,.02)}
.blkPanelHead{display:flex;justify-content:space-between;gap:10px;align-items:center;margin-bottom:8px}
.blkPanelTitle{font-weight:800}
.blkGrid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.input{width:100%;margin-top:6px}
.dropzone{border:1px dashed var(--border);border-radius:12px;padding:14px;color:var(--muted);text-align:center}
.dropzone.drag{background:rgba(255,255,255,.06);color:var(--text)}

.blkTableWrap{border:1px solid var(--border);border-radius:12px;overflow:hidden}
.blkTableHead{display:flex;justify-content:space-between;gap:10px;padding:10px;border-bottom:1px solid var(--border)}
.blkTableTitle{font-weight:800}
.blkTableActions{display:flex;gap:10px;flex-wrap:wrap}
.blkTable{width:100%;border-collapse:collapse}
.blkTable th,.blkTable td{padding:8px;border-bottom:1px solid var(--border);text-align:left}
.small{font-size:12px;color:var(--muted)}
