/* ═══════════════════════════════════════════════════════════════
   QUTRIT TRIDEX — Temiz 3 Bölge Layout
   Header:  52px  (fixed, top:0)
   Nav:     43px  (sticky, top:52px)  → alt kenar: 95px
   ① Ribbon:    ~33px  → top:95px   → alt: 128px
   ② Listband:  filtre~32 + thead~28 + scroll~160 = ~220px  → top:128px → alt:348px
   ③ Detayband: top:348px  → kalan: 100vh-348px
   NOT (TUR22): Eskiden burada ayrı bir Cmdbar (33px) vardı; "Yenile / Tanımlar /
   Raporlar / Yazılım Kontrol / Karar Destek" düğmeleri <nav class="nav"> içindeki
   <div class="nav-right">'a taşındı. Bu yüzden ribbon artık 128 değil 95'ten
   başlıyor. Aşağıdaki değişkenler JS (qtrCalcLayout) tarafından güncellenir;
   buradaki sayılar sadece ilk boyama için fallback'tir.
   ═══════════════════════════════════════════════════════════════ */

/* CSS değişkenleri — JS tarafından güncellenir */
:root {
  --qtr-ribbon-h:   42px;
  --qtr-ribbon-top: 99px;         /* hdr(52) + nav(43) + gap(4) */
  --qtr-list-top:   141px;        /* ribbon alt kenarı + gap */
  --qtr-list-h:     240px;        /* filtre+thead+scroll */
  --qtr-detay-top:  385px;        /* list alt kenarı + gap */
}

/* ── Sayfa container ─────────────────────────────────────────── */
#pg-qutritis {
  padding: 0 !important;
  background: var(--bg,#e7edf4);
}

/* ══════════════════════════════════════════════════════════════
   ① RİBBON
   ══════════════════════════════════════════════════════════════ */
.qtr-ribbon {
  position: fixed;
  top: var(--qtr-ribbon-top);
  left: 6px; right: 6px;
  z-index: 98;
  background: linear-gradient(180deg,#f4f7fb,#edf2f8);
  border: 3px solid #8ea7bd;
  border-radius: 0 0 4px 4px;
  box-shadow: 0 4px 12px rgba(142,167,189,.3);
}
.qtr-ribbon-inner {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: nowrap;
  justify-content: flex-start;
  padding: 5px clamp(260px, 24vw, 390px) 5px 12px;
  min-height: 38px;
  box-sizing: border-box;
}
.qtr-ribbon-title {
  font-size: 13px; font-weight: 700; color: var(--t,#233042);
  white-space: nowrap; letter-spacing: .01em; flex-shrink: 0;
  padding-right: 8px; border-right: 1px solid rgba(200,211,223,.6);
}

.qtr-ribbon-file-ref {
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  min-height: 22px;
  padding: 2px 7px;
  overflow: hidden;
  border: 1px solid #b7c7d8;
  border-radius: 5px;
  background: linear-gradient(180deg,#fffdf7,#eef5fc);
  color: #445a72;
  font: 700 10px/1.1 var(--sans);
  white-space: nowrap;
  box-shadow: 0 1px 4px rgba(40,72,102,.10);
  pointer-events: auto;
  user-select: text;
  max-width: 460px;
  min-width: 0;
}
.qtr-ribbon-file-ref-top {
  position: absolute;
  top: 50%;
  right: 12px;
  transform: translateY(-50%);
}
.qtr-ribbon-file-ref-pin { flex: 0 0 auto; }
.qtr-ribbon-file-ref-input {
  width: clamp(220px, 20vw, 330px);
  min-width: 0;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  appearance: none;
  -webkit-appearance: none;
  color: #445a72;
  font: 700 10px/1 var(--sans);
  height: 16px;
  line-height: 16px;
  margin: 0;
  padding: 0;
  vertical-align: middle;
  position: relative;
  top: -1px;
  outline: none;
}
.qtr-ribbon-file-ref-input:focus {
  background: transparent !important;
  box-shadow: none !important;
}
.qtr-ribbon-copy-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 18px;
  border: 1px solid #b7c7d8;
  border-radius: 5px;
  background: linear-gradient(180deg,#ffffff,#eef5fc);
  color: #445a72;
  font: 700 11px/1 var(--sans);
  cursor: pointer;
  flex: 0 0 auto;
  position: relative;
  top: -1px;
}
.qtr-ribbon-copy-btn:hover { background: #f7fbff; border-color: #96b0c8; }
.qtr-ribbon-copy-btn:active { transform: translateY(1px); }
/* ribbon renkleri — mevcut qtr-rbn stilleri korunuyor */
.qtr-ribbon-actions {
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
  min-width:0;
  justify-content:flex-start;
  align-content:center;
}
.qtr-ribbon-actions .btn,
.qtr-ribbon-actions .qtr-rbn,
.qtr-rbn {
  min-height:31px;
  height:31px;
  padding:0 13px;
  border-radius:6px;
  font-size:12px;
  font-weight:800;
  letter-spacing:.01em;
  line-height:1;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:5px;
  box-sizing:border-box;
  flex:0 0 auto;
  cursor:pointer;
  white-space:nowrap;
  transition:all .1s ease;
  border:1px solid var(--border,#c8d3df);
  background:#fff;
  color:var(--t,#233042);
}
.qtr-rbn:hover   { background: #edf2f8; border-color: #a8bfd4; transform: translateY(-1px); box-shadow: 0 2px 5px rgba(15,23,42,.06); }
.qtr-rbn:active  { transform: translateY(0); box-shadow: none; }
.qtr-rbn:disabled{ opacity: .42; cursor: not-allowed; transform: none !important; }
.qtr-rbn.primary { background: linear-gradient(180deg,#f0f6fc,#e6eef7); border-color: #b0cde5; color: #234560; }
.qtr-rbn.primary:hover { background: linear-gradient(180deg,#e8f2fb,#dce8f4); border-color: #8ab0cc; }
.qtr-rbn.ok      { background: linear-gradient(180deg,#eef8f2,#e3f3e8); border-color: #a8d4b6; color: #25573a; }
.qtr-rbn.ok:hover{ border-color: #7ab896; }
.qtr-rbn.pur     { background: linear-gradient(180deg,#f3f0fd,#ebe5fb); border-color: #c0aee8; color: #4a2f8a; }
.qtr-rbn.pur:hover{ border-color: #9b7dd4; }
.qtr-rbn.pink    { background: linear-gradient(180deg,#fdf1f8,#f8e3f0); border-color: #e7b3cf; color: #9f1d5c; }
.qtr-rbn.pink:hover{ background: linear-gradient(180deg,#fbe8f3,#f4d9ea); border-color: #d78ab7; }
.qtr-rbn.warn    { background: linear-gradient(180deg,#fdf7ea,#f9edd6); border-color: #dfc285; color: #7a5010; }
.qtr-rbn.danger  { background: linear-gradient(180deg,#fdf1f0,#f8e4e2); border-color: #e0b0ac; color: #7a3030; }

/* ══════════════════════════════════════════════════════════════
   ② LİSTE BANTI
   ══════════════════════════════════════════════════════════════ */
.qtr-listband {
  position: fixed;
  top: var(--qtr-list-top);
  left: 6px; right: 6px;
  z-index: 97;
  background: #f2f6fb;
  border: 3px solid #7aacc8;
  border-radius: 4px;
  box-shadow: 0 4px 12px rgba(122,172,200,.25);
}

/* Filtre satırı */
.qtr-listband-filters {
  display: flex; align-items: center; gap: 7px; flex-wrap: nowrap;
  padding: 5px 8px; overflow-x: auto;
  background: linear-gradient(180deg,#eef3f9,#e8eef6);
  border-bottom: 1px solid var(--border,#c8d3df);
}
.qtr-life-filters-inline {
  display: flex; gap: 6px; flex-shrink: 0; align-items: center;
}
.qtr-flt-inp {
  height: 24px; padding: 0 7px; font: 11px/1 var(--sans);
  border: 1px solid var(--border,#c8d3df); border-radius: 3px;
  background: #fff; color: var(--t); outline: none;
  min-width: 90px; max-width: 150px; flex-shrink: 0;
}
.qtr-flt-inp:focus { border-color: var(--acc); box-shadow: 0 0 0 2px rgba(142,167,189,.18); }
.qtr-flt-sel {
  height: 24px; padding: 0 5px; font: 11px/1 var(--sans);
  border: 1px solid var(--border,#c8d3df); border-radius: 3px;
  background: #fff; color: var(--t); outline: none; cursor: pointer; flex-shrink: 0;
}

/* Life chip'ler */
.qtr-life-chip {
  border: 1px solid rgba(200,211,223,.8);
  background: rgba(255,255,255,.7); border-radius: 3px;
  padding: 3px 6px; cursor: pointer;
  font: 600 10px/1 var(--sans); color: var(--t2,#5f6f82);
  display: inline-flex; gap: 3px; align-items: center;
  white-space: nowrap; transition: all .1s;
}
.qtr-life-chip span {
  min-width: 14px; text-align: center; padding: 1px 3px;
  border-radius: 2px; background: rgba(200,211,223,.4);
  color: var(--t3); font-size: 9px;
}
.qtr-life-chip:hover { background: rgba(255,255,255,.95); border-color: var(--acc); color: var(--t); }
.qtr-life-chip.active {
  background: var(--acc,#8ea7bd); border-color: var(--acc2,#a2b8cb); color: #fff;
  box-shadow: 0 2px 5px rgba(142,167,189,.25);
}
.qtr-life-chip.active span { background: rgba(255,255,255,.2); color: #fff; }

/* Tablo başlığı */
.qtr-listtable-head {
  background: linear-gradient(180deg,#eaf0f7,#e3ecf5);
  border-bottom: 1px solid var(--border,#c8d3df);
  overflow: hidden;
}
.qtr-listtable {
  width: 100%; border-collapse: collapse; table-layout: fixed; font-size: 11px;
}
.qtr-listtable th {
  background: linear-gradient(180deg,#eaf0f7,#e3ecf5);
  color: var(--t2,#5f6f82); font-weight: 700; font-size: 10px;
  text-transform: uppercase; letter-spacing: .04em;
  padding: 5px 8px;
  border-right: 1px solid rgba(200,211,223,.5);
  text-align: left; white-space: nowrap; user-select: none;
}
.qtr-listtable th:last-child { border-right: none; }
.qtr-th-sort { cursor: pointer; }
.qtr-th-sort:hover { background: linear-gradient(180deg,#dde6f0,#d5e0ec) !important; color: var(--t); }
.qtr-th-active { color: var(--acc,#5b7fa6) !important; }
.qtr-sort-icon { font-size: 10px; opacity: .6; margin-left: 3px; }
.qtr-th-active .qtr-sort-icon { opacity: 1; color: var(--acc,#5b7fa6); }

/* Scroll alanı */
.qtr-listband-scroll {
  overflow-y: auto; overflow-x: hidden;
  background: #fff;
  height: 160px;           /* JS tarafından güncellenir */
}
.qtr-listband-scroll::-webkit-scrollbar { width: 6px; }
.qtr-listband-scroll::-webkit-scrollbar-track { background: #edf2f8; }
.qtr-listband-scroll::-webkit-scrollbar-thumb { background: #c8d3df; border-radius: 3px; }

/* Satırlar */
.qtr-listband-scroll .qtr-listtable { width: 100%; border-collapse: collapse; table-layout: fixed; }
.qtr-list-row td {
  padding: 5px 8px; border-bottom: 1px solid #edf2f8;
  border-right: 1px solid rgba(200,211,223,.25);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  vertical-align: middle; font-size: 11px;
}
.qtr-list-row td:last-child { border-right: none; }
.qtr-list-row:hover td { background: #f3f7fc; cursor: pointer; }
.qtr-list-row.qtr-row-selected td { background: #ddeaf7 !important; }
.qtr-list-row:last-child td { border-bottom: none; }
.qtr-list-row.tone-root      td:first-child { box-shadow: inset 3px 0 0 #2563eb; }
.qtr-list-row.tone-extension td:first-child { box-shadow: inset 3px 0 0 #d97706; }
.qtr-list-row.tone-return    td:first-child { box-shadow: inset 3px 0 0 #0f766e; }
.qtr-list-row.tone-decision  td:first-child { box-shadow: inset 3px 0 0 #7c3aed; }
.qtr-cell-mono { font-family: var(--mono,'IBM Plex Mono',monospace); font-size: 10px; color: var(--t2); }
.qtr-cell-date { font-size: 10px; color: var(--t2); font-family: var(--mono,'IBM Plex Mono',monospace); }

/* ══════════════════════════════════════════════════════════════
   ③ DETAY BANTI
   ══════════════════════════════════════════════════════════════ */
.qtr-detayband {
  position: fixed;
  top: var(--qtr-detay-top);
  left: 6px; right: 6px; bottom: 6px;
  z-index: 96;
  display: flex; flex-direction: column;
  background: var(--bg2,#f2f5f9);
  overflow: hidden;
  border: 3px solid #a8b8cb;
  border-radius: 4px;
  box-shadow: 0 4px 12px rgba(168,184,203,.2);
}

/* 3a: Özet başlık — sabit */
.qtr-detay-ozet {
  flex-shrink: 0;
  background: #fff;
  margin: 6px 6px 0 6px;
  border-radius: 4px 4px 0 0;
  border: 4px solid #6b8fa8;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(107,143,168,.2);
}
.qtr-empty-state-bar {
  padding: 10px 16px; font-size: 12px; color: var(--t3);
}
.qtr-detail-head {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0,1fr) auto;
  align-items: start;
  gap: 10px;
  padding: 8px 330px 6px 14px;
  background: linear-gradient(180deg,#fdfefe,#f7faff);
}

.qtr-detail-main {
  min-width: 0;
  flex: 1 1 auto;
}
.qtr-detail-title-ref {
  position: absolute;
  top: 8px;
  right: 12px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  min-height: 22px;
  padding: 2px 7px;
  overflow: hidden;
  border: 1px solid #b7c7d8;
  border-radius: 5px;
  background: linear-gradient(180deg,#fffdf7,#eef5fc);
  color: #445a72;
  font: 700 10px/1.1 var(--sans);
  white-space: nowrap;
  box-shadow: 0 1px 4px rgba(40,72,102,.10);
  pointer-events: auto;
  user-select: text;
  max-width: 460px;
  min-width: 0;
}
.qtr-detail-kickers {
  display: flex; gap: 5px; flex-wrap: wrap; margin-bottom: 3px;
  align-items: center; font-size: 11px; color: var(--t3);
}
.qtr-detail-title {
  margin: 0; font-size: 14px !important; font-weight: 800 !important;
  color: var(--t,#233042); line-height: 1.25;
}
.qtr-detail-badges { display: flex; gap: 5px; flex-wrap: wrap; align-items: center; justify-content: flex-end; }
.qtr-detail-summary {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
  gap: 4px; padding: 5px 14px;
  background: #edf2f8; border-top: 1px solid var(--border,#c8d3df);
}
.qtr-summary-card {
  background: #fff; border: 1px solid var(--border,#c8d3df);
  border-radius: 4px; padding: 5px 8px; box-shadow: 0 1px 3px rgba(15,23,42,.04);
}
.qtr-summary-label { font-size: 9px; font-weight: 800; letter-spacing: .05em; text-transform: uppercase; color: var(--t3); }
.qtr-summary-value { margin-top: 2px; font-size: 14px; font-weight: 800; color: var(--t); line-height: 1.1; }
.qtr-summary-sub   { margin-top: 1px; font-size: 10px; color: var(--t3); }

/* 3b: Sekmeler — sabit */
.qtr-detay-tabs {
  flex-shrink: 0;
  margin: 4px 6px 0 6px;
  border: 4px solid #6b8fa8;
  border-radius: 4px 4px 0 0;
  overflow: hidden;
  background: #e8eef6;
  box-shadow: 0 -2px 8px rgba(107,143,168,.2);
}

.qtr-tabs-bar {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  gap: 8px;
  padding-right: 8px;
  background: #e8eef6;
}

.qtr-detail-file-ref {
  margin: 4px 0 4px auto;
  pointer-events: auto;
  user-select: text;
  max-width: 460px;
  min-width: 0;
  align-self: center;
  display: inline-flex;
  flex: 0 0 auto;
  align-items: center;
  gap: 5px;
  min-height: 22px;
  padding: 2px 7px;
  overflow: hidden;
  border: 1px solid #b7c7d8;
  border-radius: 5px;
  background: linear-gradient(180deg,#fffdf7,#eef5fc);
  color: #445a72;
  font: 700 10px/1.1 var(--sans);
  white-space: nowrap;
  box-shadow: 0 1px 4px rgba(40,72,102,.10);
}
.qtr-loading-note {
  padding: 14px 16px;
  color: var(--t3);
  font: 700 11px/1.35 var(--sans);
}

.qtr-tabs {
  display: flex; gap: 1px; flex-wrap: nowrap;
  flex: 1 1 auto;
  min-width: 0;
  padding: 0 0 0 8px;
  border-bottom: 2px solid var(--border,#c8d3df);
  background: #e8eef6;
  overflow-x: auto;
}
.qtr-tab {
  border: 1px solid transparent; border-bottom: none;
  background: rgba(255,255,255,.45); border-radius: 4px 4px 0 0;
  padding: 6px 11px; cursor: pointer;
  font: 600 11px/1 var(--sans); color: var(--t2);
  white-space: nowrap; transition: all .1s;
  margin-bottom: -2px; position: relative;
}
.qtr-tab:hover { background: rgba(255,255,255,.75); color: var(--t); }
.qtr-tab.active {
  background: #fff; border-color: var(--border,#c8d3df);
  border-bottom-color: #fff; color: var(--t); font-weight: 700;
  box-shadow: 0 -2px 0 var(--acc,#8ea7bd); z-index: 1;
}
.qtr-context-band {
  display: flex; gap: 5px; flex-wrap: wrap; align-items: center;
  padding: 4px 14px; border-bottom: 1px solid var(--border,#c8d3df);
  background: linear-gradient(180deg,#f7fafd,#f2f7fb);
}
.qtr-context-band:empty { display: none; }
.qtr-context-chip {
  border: 1px solid var(--border,#c8d3df); background: #fff;
  border-radius: 4px; padding: 4px 9px;
  font: 600 11px/1 var(--sans); color: var(--t); cursor: pointer; transition: all .1s;
}
.qtr-context-chip:hover { border-color: var(--acc); background: #f4f8fc; }
.qtr-context-chip.primary { background: linear-gradient(180deg,#edf4fa,#e6eef7); border-color: #b0cde5; color: #234560; }
.qtr-context-spacer { font-size: 11px; color: var(--t3); padding: 2px 0; }

/* 3c: İçerik — scroll */
.qtr-detay-content {
  flex: 1; overflow-y: auto; overflow-x: hidden;
  background: var(--bg2,#f2f5f9);
  margin: 0 6px 6px 6px;
  border: 4px solid #6b8fa8;
  border-top: none;
  border-radius: 0 0 4px 4px;
}
.qtr-detay-content::-webkit-scrollbar { width: 6px; }
.qtr-detay-content::-webkit-scrollbar-track { background: #edf2f8; }
.qtr-detay-content::-webkit-scrollbar-thumb { background: #c8d3df; border-radius: 3px; }
.qtr-tab-panel { display: none; padding: 10px 14px; }
.qtr-tab-panel.active { display: block; }

/* ══════════════════════════════════════════════════════════════
   DETAY İÇİ — form, tablo, kpi stilleri
   ══════════════════════════════════════════════════════════════ */
.qtr-badge {
  display: inline-flex; align-items: center; gap: 3px;
  border-radius: 2px; padding: 2px 5px;
  font-size: 10px; font-weight: 700; line-height: 1; border: 1px solid transparent;
}
.qtr-badge.phase-0 { background:#eef4ff; color:#3555c8; border-color:#c7d8f8; }
.qtr-badge.phase-1 { background:#fff6df; color:#8a6200; border-color:#f5d98a; }
.qtr-badge.phase-2 { background:#ebfff0; color:#1c7f3e; border-color:#a7edbe; }
.qtr-badge.status  { background:#eef2f7; color:#516074; border-color:#d5dde8; }
.qtr-badge.root-kind { background:#f5f8fc; color:#334155; border-color:#dde5ef; }
.qtr-root-tone-badge {
  display: inline-flex; align-items: center; border-radius: 2px;
  padding: 1px 5px; font-size: 9px; font-weight: 800; line-height: 1; border: 1px solid transparent;
}
.tone-root     .qtr-root-tone-badge,.qtr-list-row.tone-root     .qtr-root-tone-badge { background:#dbeafe; color:#1d4ed8; border-color:#93c5fd; }
.tone-extension .qtr-root-tone-badge,.qtr-list-row.tone-extension .qtr-root-tone-badge { background:#fef3c7; color:#b45309; border-color:#fcd34d; }
.tone-return   .qtr-root-tone-badge,.qtr-list-row.tone-return   .qtr-root-tone-badge { background:#ccfbf1; color:#0f766e; border-color:#5eead4; }
.tone-decision .qtr-root-tone-badge,.qtr-list-row.tone-decision .qtr-root-tone-badge { background:#ede9fe; color:#6d28d9; border-color:#c4b5fd; }
.qtr-detail-origin.tone-root     { background:#dbeafe; color:#1d4ed8; border-color:#93c5fd; }
.qtr-detail-origin.tone-extension{ background:#fef3c7; color:#b45309; border-color:#fcd34d; }
.qtr-detail-origin.tone-return   { background:#ccfbf1; color:#0f766e; border-color:#5eead4; }
.qtr-detail-origin.tone-decision { background:#ede9fe; color:#6d28d9; border-color:#c4b5fd; }

.qtr-section-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 8px; flex-wrap: wrap; margin-bottom: 7px; }
.qtr-section-title    { font-size: 12px; font-weight: 800; color: var(--t); }
.qtr-section-subtitle { font-size: 11px; color: var(--t3); margin-top: 2px; line-height: 1.4; }
.qtr-kpi-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px,1fr)); gap: 5px; margin-bottom: 9px; }
.qtr-kpi { background: #fff; border: 1px solid var(--border,#c8d3df); border-radius: 4px; padding: 7px 9px; box-shadow: 0 1px 3px rgba(15,23,42,.04); }
.qtr-kpi-label { font-size: 9px; text-transform: uppercase; letter-spacing: .05em; color: var(--t3); font-weight: 700; }
.qtr-kpi-value { margin-top: 3px; font-size: 18px; font-weight: 800; color: var(--t); line-height: 1.1; }

.qtr-table-wrap { overflow: auto; border: 1px solid var(--border,#c8d3df); border-radius: 4px; background: #fff; }
.qtr-table { width: 100%; border-collapse: collapse; font-size: 12px; }
.qtr-table th {
  background: linear-gradient(180deg,#f2f6fb,#eaf0f7); color: var(--t2);
  font-weight: 700; padding: 6px 9px; border-bottom: 2px solid var(--border,#c8d3df);
  text-align: left; font-size: 10px; text-transform: uppercase; letter-spacing: .04em;
  position: sticky; top: 0; z-index: 1; white-space: nowrap;
}
.qtr-table td { padding: 6px 9px; border-bottom: 1px solid #edf2f8; vertical-align: top; }
.qtr-table tr:last-child td { border-bottom: none; }
.qtr-table tr:hover td { background: #f8fbff; }
.qtr-table.compact th,.qtr-table.compact td { padding: 5px 7px; font-size: 11px; }
.qtr-cell-title { font-weight: 700; color: var(--t); font-size: 11px; }
.qtr-sor-table-wrap {
  overflow-x: auto;
  overflow-y: hidden;
  border: 1px solid var(--border,#c8d3df);
  border-radius: 4px;
  background: #fff;
}
.qtr-sor-table {
  width: 100%;
  min-width: 1220px;
  table-layout: fixed;
  border-collapse: collapse;
}
.qtr-sor-table col.qtr-sor-col-check-width { width: 40px; }
.qtr-sor-table col.qtr-sor-col-code-width { width: 120px; }
.qtr-sor-table col.qtr-sor-col-name-width { width: 310px; }
.qtr-sor-table col.qtr-sor-col-role-width { width: 140px; }
.qtr-sor-table col.qtr-sor-col-context-width { width: 220px; }
.qtr-sor-table col.qtr-sor-col-email-width { width: 250px; }
.qtr-sor-table col.qtr-sor-col-phone-width { width: 140px; }
.qtr-sor-table col.qtr-sor-col-action-width { width: 56px; }
.qtr-sor-table th,
.qtr-sor-table td {
  box-sizing: border-box;
  vertical-align: middle;
  overflow: hidden;
}
.qtr-sor-table th {
  white-space: nowrap;
}
.qtr-sor-table td {
  padding-top: 6px;
  padding-bottom: 6px;
  background-clip: padding-box;
}
.qtr-sor-col-check,
.qtr-sor-col-action {
  text-align: center;
  white-space: nowrap;
}
.qtr-sor-col-check {
  padding-left: 6px !important;
  padding-right: 6px !important;
}
.qtr-sor-col-code {
  padding-right: 10px !important;
}
.qtr-sor-col-name {
  padding-left: 10px !important;
  padding-right: 12px !important;
}
.qtr-sor-col-role,
.qtr-sor-col-context,
.qtr-sor-col-email,
.qtr-sor-col-phone {
  font-size: 10px;
}
.qtr-sor-col-context,
.qtr-sor-col-phone {
  color: var(--t2);
}
.qtr-sor-code-text,
.qtr-sor-name-text,
.qtr-sor-cell-clip,
.qtr-sor-mail-link,
.qtr-sor-empty {
  display: block;
  width: 100%;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.qtr-sor-code-text {
  font-size: 10px;
  line-height: 1.2;
  color: var(--t2);
}
.qtr-sor-name-text {
  font-size: 11px;
  line-height: 1.25;
  font-weight: 700;
  color: var(--t);
}
.qtr-sor-role-badge {
  font-size: 9px;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  vertical-align: middle;
}
.qtr-sor-mail-link {
  color: var(--acc);
}
.qtr-sor-empty {
  color: var(--t3);
}
.qtr-sor-del-btn {
  font-size: 10px;
  padding: 2px 6px;
}
.qtr-sor-empty-row {
  text-align: center;
  padding: 12px !important;
  color: var(--t3);
}
.qtr-cell-sub   { font-size: 10px; color: var(--t3); margin-top: 1px; }
.qtr-row-critical { background: #fff9ef !important; }
.qtr-row-closed   { opacity: .65; }

.qtr-edit-form { background: #fff; border: 1px solid var(--border,#c8d3df); border-radius: 5px; padding: 11px 13px; }
.qtr-edit-grid,.qtr-form-grid { display: grid; grid-template-columns: repeat(2, minmax(180px,1fr)); gap: 9px 11px; }
.qtr-form-field { display: flex; flex-direction: column; gap: 3px; }
.qtr-form-field label,.qtr-edit-form label { font-size: 11px; font-weight: 700; color: var(--t2); }
.qtr-span-2,.qtr-edit-form .full { grid-column: 1/-1; }
.qtr-form-field .inp,.qtr-edit-form input,.qtr-edit-form textarea,.qtr-edit-form select {
  width: 100%; background: #fff; border: 1px solid var(--border,#c8d3df);
  border-radius: 3px; padding: 5px 8px; font: 12px/1.3 var(--sans); color: var(--t); outline: none;
}
.qtr-form-field .inp:focus,.qtr-edit-form input:focus,.qtr-edit-form textarea:focus,.qtr-edit-form select:focus {
  border-color: var(--acc); box-shadow: 0 0 0 2px rgba(142,167,189,.18);
}
.qtr-edit-form input[readonly],.qtr-edit-form textarea[readonly],.qtr-edit-form select:disabled {
  background: #f5f8fc; color: var(--t2); cursor: not-allowed;
}
.qtr-edit-form textarea { min-height: 68px; resize: vertical; }

.qtr-toolbar { display: flex; gap: 4px; flex-wrap: wrap; margin-bottom: 7px; }
.qtr-mini-btn {
  border: 1px solid var(--border,#c8d3df); background: #fff; border-radius: 4px;
  padding: 4px 9px; cursor: pointer; font: 600 11px/1 var(--sans); color: var(--t);
  transition: all .1s; white-space: nowrap;
}
.qtr-mini-btn:hover { border-color: var(--acc); background: #f4f8fc; }
.qtr-primary { background: linear-gradient(180deg,#edf4fa,#e6eef7) !important; border-color: #b0cde5 !important; color: #234560 !important; font-weight: 700 !important; }
.qtr-primary:hover { border-color: #7aacc8 !important; }
.qtr-create-actions { display: flex; gap: 4px; flex-wrap: wrap; margin-top: 9px; }
.qtr-note-box { background: #f7f9fc; border: 1px dashed var(--border,#c8d3df); border-radius: 4px; padding: 9px 11px; color: var(--t2); font-size: 11px; line-height: 1.5; }
.qtr-stack { display: flex; flex-direction: column; gap: 7px; }
.qtr-empty-state { padding: 40px 24px; text-align: center; color: var(--t3); }
.qtr-empty-title { font-size: 15px; font-weight: 700; color: var(--t2); margin-bottom: 6px; }
.qtr-empty-text  { font-size: 12px; line-height: 1.5; }
.qtr-mono { font-family: var(--mono,'IBM Plex Mono',monospace); }
.qtr-grid-note { font-size: 11px; color: var(--t3); margin-bottom: 5px; }
.qtr-form-help  { font-size: 11px; color: var(--t3); line-height: 1.5; }
.qtr-planlama-ozet { display: grid; grid-template-columns: repeat(auto-fit,minmax(130px,1fr)); gap: 5px; margin-bottom: 7px; }
.qtr-form-band { background: linear-gradient(180deg,#f7fafd 88%,rgba(247,250,253,.92)); padding: 7px 12px; border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.qtr-panel-title { font-size: 12px; font-weight: 700; color: var(--t,#233042); }
.qtr-inline-actions { display: flex; gap: 4px; align-items: center; }
.qtr-form-band-actions { display: flex; gap: 4px; flex-wrap: wrap; align-items: center; }
.qtr-form-band-actions .qtr-mini-btn { min-height: 26px; padding: 0 9px; border-radius: 3px; font-weight: 700; }
#qtr-part-form-wrap .qtr-panel-head,#qtr-move-form-wrap .qtr-panel-head { margin: -11px -13px 9px; padding: 8px 13px; border-radius: 0; border-bottom: 1px solid var(--border); }

/* SOY AĞACI */
.qtr-tree-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  gap: 12px;
  align-items: start;
}
.qtr-tree-main { min-width: 0; }
  position: sticky;
  top: 10px;
  min-height: 220px;
}
.qtr-tree-sidecard {
  background: #fff;
  border: 1px solid var(--border,#c8d3df);
  border-radius: 12px;
  box-shadow: 0 10px 26px rgba(15,23,42,.08);
  padding: 12px;
}
.qtr-tree-sidehead {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
}
.qtr-tree-sidekicker {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #64748b;
  margin-bottom: 4px;
}
.qtr-tree-sidetitle {
  font-size: 14px;
  font-weight: 800;
  color: #0f172a;
  line-height: 1.35;
}
.qtr-tree-sidesub {
  font-size: 11px;
  color: #64748b;
  margin-top: 4px;
  line-height: 1.45;
}
.qtr-tree-chipbar {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin: 0 0 12px;
}
.qtr-tree-side-divider{height:1px;background:linear-gradient(90deg,rgba(15,23,42,.12),rgba(15,23,42,.04));margin:0 0 12px;border-radius:999px}
.qtr-tree-panel-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  border: 1px solid #dbe5f0;
  background: #f8fafc;
  color: #334155;
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
}
.qtr-tree-panel-chip span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 20px;
  padding: 0 6px;
  border-radius: 999px;
  background: #e2e8f0;
  color: #0f172a;
  font-size: 10px;
}
.qtr-tree-panel-chip:hover { border-color: #94a3b8; background: #f1f5f9; }
.qtr-tree-panel-chip.is-flow{border-color:#dbe5f0;background:#f8fafc;color:#334155}
.qtr-tree-panel-chip.is-history{border-color:#f3c8c8;background:#fef2f2;color:#b91c1c}
.qtr-tree-panel-chip.is-history span{background:#fecaca;color:#991b1b}
.qtr-tree-panel-chip.is-active{background:#0f2d5c;border-color:#0f2d5c;color:#fff;box-shadow:0 8px 18px rgba(15,45,92,.12)}
.qtr-tree-panel-chip.is-active span{background:rgba(255,255,255,.16);color:#fff}
.qtr-tree-panel-chip.is-history.is-active{background:#b91c1c;border-color:#b91c1c;color:#fff;box-shadow:0 8px 18px rgba(185,28,28,.14)}
.qtr-tree-panel-chip.is-history.is-active span{background:rgba(255,255,255,.18);color:#fff}
.qtr-tree-side-section-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin:2px 0 10px}
.qtr-tree-side-section-title{font-size:12px;font-weight:800;color:#334155;letter-spacing:.02em}
.qtr-tree-side-section-count{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 7px;border-radius:999px;background:#e2e8f0;color:#0f172a;font-size:11px;font-weight:800}
.qtr-tree-sidegrid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
}
.qtr-tree-sidekv {
  display: grid;
  gap: 3px;
  padding: 8px 9px;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
  background: linear-gradient(180deg,#fff 0%,#f8fafc 100%);
}
.qtr-tree-sidekv span {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #64748b;
}
.qtr-tree-sidekv strong {
  font-size: 12px;
  color: #0f172a;
  line-height: 1.45;
  word-break: break-word;
}
.qtr-tree-flow-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.qtr-tree-flow-card {
  border: 1px solid #dbe5f0;
  border-radius: 10px;
  padding: 10px;
  background: linear-gradient(180deg,#fff 0%,#f8fafc 100%);
}
.qtr-tree-flow-card.is-history{border-color:#f3c8c8;background:linear-gradient(180deg,#fff5f5 0%,#fef2f2 100%)}
.qtr-tree-flow-card.is-history .qtr-tree-flow-code{color:#991b1b}
.qtr-tree-flow-card.is-history .qtr-tree-flow-title{color:#7f1d1d}
.qtr-tree-flow-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 8px;
}
.qtr-tree-flow-code {
  font-size: 11px;
  font-weight: 800;
  color: #0f172a;
}
.qtr-tree-flow-title {
  font-size: 12px;
  font-weight: 600;
  color: #334155;
  line-height: 1.45;
  margin-top: 2px;
}
.qtr-tree-flow-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-top: 9px;
}
.qtr-tree-flow-pill {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  border: 1px solid #dbe5f0;
  background: #fff;
  color: #475569;
  padding: 4px 8px;
  font-size: 10px;
  font-weight: 700;
}
.qtr-tree-flow-pill.is-history-type{border-color:#f3c8c8;background:#fff1f2;color:#be123c}
.qtr-tree-flow-pill.is-history-state{border-color:#f5b4b4;background:#fee2e2;color:#b91c1c}
.qtr-tree-flow-pill.is-flow-type{border-color:#ddd6fe;background:#f5f3ff;color:#6d28d9}
.qtr-tree-flow-history-note{margin-top:8px;padding:7px 9px;border-radius:9px;background:rgba(254,226,226,.72);border:1px solid #fecaca;color:#7f1d1d;font-size:11px;line-height:1.45}
.qtr-tree-panel-chip.is-detail{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}
.qtr-tree-panel-chip.is-detail span{background:#dbeafe;color:#1d4ed8}
.qtr-tree-panel-chip.is-detail:hover{border-color:#93c5fd;background:#dbeafe;color:#1d4ed8}
.qtr-tree-panel-actions{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}
.qtr-tree-panel-actions .qtr-mini-btn span{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 6px;border-radius:999px;background:rgba(255,255,255,.8);font-size:10px;font-weight:800;margin-left:6px}
.qtr-tree-sideempty {
  padding: 24px 12px;
  text-align: center;
  color: #64748b;
  font-size: 12px;
}
.qtr-tree-sideempty.is-history{border:1px dashed #f3c8c8;background:#fff5f5;color:#991b1b;border-radius:12px}
.qtr-tree-sidecard.is-history{border-color:#f3c8c8;background:linear-gradient(180deg,#fff 0%,#fff7f7 100%)}
.qtr-history-open-btn{border-color:#f5c2c7;background:#fff;color:#991b1b}
.qtr-history-open-btn:hover{border-color:#ef4444;background:#fff5f5;color:#7f1d1d}
.qtr-wbs-history-chip{background:#fff1f2;border-color:#fecdd3;color:#be123c}
.qtr-wbs-history-chip span{background:#fecaca;color:#991b1b}
.qtr-wbs-history-chip:hover{border-color:#fda4af;background:#fff5f5;color:#9f1239}
.qtr-wbs-history-chip.is-open{background:#ffe4e6;border-color:#fda4af;color:#9f1239}
.qtr-tree-sideempty.compact {
  padding: 10px 12px;
  border: 1px dashed #dbe5f0;
  border-radius: 10px;
  background: #f8fafc;
}
#qtr-tree-container {
  background: linear-gradient(180deg,#eef4fb 0%,#e8eef7 100%);
  border: 1px solid var(--border,#c8d3df);
  border-radius: 10px;
  overflow: auto;
  position: relative;
  min-height: clamp(620px, 76vh, 1280px);
  height: clamp(620px, 76vh, 1280px);
  width: 100%;
  max-height: none;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.55);
  overscroll-behavior: contain;
  cursor: grab;
}
#qtr-tree-container.is-grabbing { cursor: grabbing; }
#qtr-tree-container:fullscreen {
  height: 100vh;
  min-height: 100vh;
  border-radius: 0;
  border: none;
  padding: 12px;
  background: linear-gradient(180deg,#ecf3fb 0%,#e4edf8 100%);
}
#qtr-tree-stage {
  position: relative;
  min-width: 100%;
  min-height: 100%;
}
#qtr-tree-canvas { display: block; transform-origin: 0 0; }
#qtr-tree-tooltip {
  position: absolute; background: rgba(30,38,52,.94); color: #d8e5f3;
  font-size: 10px; font-family: var(--sans); padding: 6px 8px; border-radius: 5px;
  pointer-events: auto;
  user-select: text;
  max-width: 460px;
  min-width: 0; opacity: 0; transition: opacity .12s; z-index: 20;
  white-space: normal; max-width: 260px; line-height: 1.35;
  box-shadow: 0 8px 18px rgba(15,23,42,.2);
}
#qtr-tree-legend {
  display: flex; gap: 10px; flex-wrap: wrap; padding: 7px 10px;
  background: #f5f8fc; border: 1px solid var(--border,#c8d3df); border-radius: 8px;
  margin-bottom: 8px; align-items: center; font-size: 10px; color: var(--t2);
}
.qtr-tree-leg { display: flex; align-items: center; gap: 4px; }
.qtr-tree-leg-dot { width: 9px; height: 9px; border-radius: 2px; flex-shrink: 0; }
.qtr-tree-leg-note { color: var(--t3); font-style: italic; flex: 1 1 240px; }
.qtr-tree-legend-actions { margin-left: auto; display: inline-flex; align-items: center; gap: 6px; flex-wrap: wrap; justify-content: flex-end; }
.qtr-tree-legend-actions .qtr-mini-btn { min-height: 26px; padding: 0 9px; border-radius: 5px; }
.qtr-tree-zoom-pill { display:inline-flex; align-items:center; justify-content:center; min-width:50px; min-height:26px; padding:0 8px; border-radius:999px; border:1px solid var(--border,#c8d3df); background:#fff; color:var(--t2); font-size:10px; font-weight:700; }
#qtr-tree-nodeinfo {
  margin-top: 8px; padding: 8px 10px;
  background: #fff; border: 1px solid var(--border,#c8d3df); border-radius: 8px;
  font-size: 11px; color: var(--t3); min-height: 36px;
  display: flex; align-items: center; flex-wrap: wrap; gap: 7px;
  line-height: 1.45;
}
.qtr-tree-info-meta { display: inline-flex; flex-wrap: wrap; gap: 6px; margin-left: 8px; }
.qtr-tree-info-chip {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 2px 6px; border-radius: 999px;
  background: #eef4fb; border: 1px solid #d6e1ee; color: #516174;
  font-size: 10px; font-weight: 700;
}
.qtr-tree-info-chip.is-open {
  background: #ecfdf5;
  border-color: #a7f3d0;
  color: #065f46;
}
.qtr-tree-info-chip.is-closed {
  background: #fff1f2;
  border-color: #fecdd3;
  color: #9f1239;
}

/* Responsive */
@media (max-width:900px) {
  .qtr-listband-filters { flex-wrap: wrap; }
  .qtr-flt-inp,.qtr-flt-sel { min-width: 80px; }
  .qtr-listband-scroll { height: 120px; }
  .qtr-edit-grid,.qtr-form-grid { grid-template-columns: 1fr; }
  .qtr-tree-layout { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════════════════════════════
   YÜRÜTME HATTI — Hiyerarşik tablo stilleri
   ══════════════════════════════════════════════════════════════ */
.qtr-hat-row { transition: background .1s; }
.qtr-hat-row:hover td { background: #f3f7fc; }
.qtr-hat-row.qtr-hat-selected td {
  background: #ddeaf7 !important;
  border-bottom-color: #b0cde5;
}
.qtr-hat-row td { vertical-align: middle; }

/* Derinlik göstergesi — alt hatlar hafif sol kenarlık */
.qtr-hat-row[data-depth="1"] td:first-child { border-left: 3px solid #d97706; }
.qtr-hat-row[data-depth="2"] td:first-child { border-left: 3px solid #7c3aed; }
.qtr-hat-row[data-depth="3"] td:first-child { border-left: 3px solid #0f766e; }

/* ══════════════════════════════════════════════════════════════
   SENARYO SEÇİM KARTLARI
   ══════════════════════════════════════════════════════════════ */
.qtr-senaryo-kart {
  border: 2px solid var(--border,#c8d3df);
  border-radius: 5px; padding: 8px 10px;
  cursor: pointer; transition: all .15s;
  background: #fff; font-size: 12px; font-weight: 700;
  color: var(--t,#233042); display: flex; flex-direction: column; gap: 2px;
}
.qtr-senaryo-kart span {
  font-size: 10px; font-weight: 400; color: var(--t3,#8b97a8); line-height: 1.3;
}
.qtr-senaryo-kart:hover {
  border-color: #7aacc8; background: #f0f6fd;
  transform: translateY(-1px); box-shadow: 0 3px 8px rgba(122,172,200,.2);
}
.qtr-senaryo-kart.secili {
  border-color: #7aacc8; background: #e8f2fb;
  box-shadow: 0 0 0 3px rgba(122,172,200,.25);
  color: #1a3a5c;
}
.qtr-senaryo-kart.secili span { color: #4a7090; }

/* Talep eden satırı */
.qtr-talep-row {
  display: grid; grid-template-columns: 1fr 140px 1fr 32px;
  gap: 5px; align-items: center; margin-bottom: 5px;
}

/* ══════════════════════════════════════════════════════════════
   MERKEZİ EMAIL MODAL
   ══════════════════════════════════════════════════════════════ */
.em-kanal-kart {
  display: flex; align-items: center; gap: 4px;
  padding: 7px 12px; border: 2px solid var(--border,#c8d3df);
  border-radius: 5px; cursor: pointer; font-size: 11px; font-weight: 600;
  color: var(--t); background: #f8fafc; transition: all .12s;
  flex-direction: row;
}
.em-kanal-kart span {
  display: block; font-size: 9px; font-weight: 400;
  color: var(--t3); margin-left: 4px;
}
.em-kanal-kart:has(input:checked) {
  border-color: #7aacc8; background: #f0f7fd;
}
.em-alici-row {
  display: grid; grid-template-columns: 28px 1fr 110px 160px 110px;
  gap: 5px; align-items: center; padding: 5px 8px;
  border-bottom: 1px solid #edf2f8; font-size: 11px;
}
.em-alici-row:last-child { border-bottom: none; }
.em-alici-row:hover { background: #f5f9fd; }

/* Modal içi autocomplete — üste taşmasın */
.mdl .acr, .ov .acr {
  z-index: 9999 !important;
  position: absolute !important;
  top: 100% !important;
  left: 0 !important;
  min-width: 280px !important;
  max-height: 220px !important;
  overflow-y: auto !important;
  background: #fff !important;
  border: 1px solid var(--border,#c8d3df) !important;
  border-radius: 0 0 4px 4px !important;
  box-shadow: 0 6px 18px rgba(15,23,42,.12) !important;
}

/* Talep satırı */
.qtr-talep-row { position: relative; }

@media (max-width: 1400px) {
  .qtr-ribbon-inner { padding-right: clamp(230px, 24vw, 330px); }
  .qtr-ribbon-file-ref-input { width: 300px; }
  .qtr-detail-head { padding-right: 300px; }
}

/* QUTRIT WBS — büyük ekran çalışma alanı */
.qtr-wbs-preview-box{
  display:grid;
  gap:12px;
  padding:14px;
  border:1px solid var(--border,#c8d3df);
  border-radius:14px;
  background:linear-gradient(180deg,#ffffff 0%,#f8fbff 100%);
  box-shadow:0 10px 28px rgba(15,23,42,.06);
}
.qtr-wbs-preview-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;flex-wrap:wrap}
.qtr-wbs-preview-kicker{font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:#64748b}
.qtr-wbs-preview-title{font-size:18px;font-weight:800;color:#0f172a;margin-top:4px}
.qtr-wbs-preview-sub{font-size:12px;color:#475569;line-height:1.6;max-width:760px;margin-top:6px}
.qtr-wbs-preview-actions{display:flex;gap:8px;align-items:center}
.qtr-wbs-preview-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px}
.qtr-wbs-preview-stat{padding:12px;border:1px solid #dbe5f0;border-radius:12px;background:#fff;display:grid;gap:5px}
.qtr-wbs-preview-stat span{font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#64748b}
.qtr-wbs-preview-stat strong{font-size:16px;color:#0f172a}

:root{--qtr-wbs-l0-width:236px;--qtr-wbs-l1-width:200px;--qtr-wbs-l2-width:176px;--qtr-wbs-l3-width:152px;--qtr-wbs-l0-scale:1.04;--qtr-wbs-l1-scale:.92;--qtr-wbs-l2-scale:.80;--qtr-wbs-l3-scale:.64;}
.qtr-wbs-overlay{position:fixed;inset:0;background:rgba(15,23,42,.34);backdrop-filter:blur(2px);display:none;z-index:1200;padding:12px}
.qtr-wbs-overlay.on{display:block}
.qtr-wbs-shell{width:100%;height:100%;background:#f3f6fb;border:1px solid rgba(148,163,184,.35);border-radius:20px;box-shadow:0 30px 80px rgba(15,23,42,.24);display:grid;grid-template-rows:auto 1fr;overflow:hidden;position:relative}
.qtr-wbs-topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:14px 18px 12px;border-bottom:1px solid #d7e2ee;background:linear-gradient(180deg,#ffffff 0%,#f8fbff 100%)}
.qtr-wbs-topbar-main{display:grid;gap:4px}
.qtr-wbs-top-kicker{font-size:9px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:#64748b}
.qtr-wbs-top-title{font-size:22px;font-weight:800;color:#0f172a;line-height:1.18}
.qtr-wbs-top-sub{font-size:12px;color:#475569;line-height:1.4;max-width:980px}
.qtr-wbs-top-actions{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}
.qtr-wbs-top-actions .qtr-mini-btn,.qtr-wbs-close-btn{padding:3px 8px;min-height:26px;font-size:10px;border-radius:7px}
.qtr-wbs-body{min-height:0;padding:14px 16px 16px;overflow:auto}
.qtr-wbs-layout{display:grid;grid-template-columns:minmax(0,1fr) 336px;gap:16px;min-height:100%}
.qtr-wbs-layout.is-side-closed{grid-template-columns:minmax(0,1fr)}
.qtr-wbs-board-shell{min-width:0;display:grid;grid-template-rows:auto 1fr;gap:12px}
.qtr-wbs-board-head{display:flex;justify-content:space-between;align-items:center;gap:10px;flex:0 0 auto}
.qtr-wbs-board-note{padding:9px 12px;border:1px solid #dbe5f0;border-radius:12px;background:#fff;font-size:11px;color:#475569;line-height:1.45}
.qtr-wbs-stage{position:relative;overflow:auto;padding:2px 10px 8px 2px}
.qtr-wbs-links{position:absolute;left:0;top:0;pointer-events:none;z-index:0;overflow:visible}
.qtr-wbs-link-path{fill:none;stroke:#c7d6e8;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;opacity:.95}
.qtr-wbs-link-dot{fill:#d7e5f5;opacity:.95}
.qtr-wbs-columns{position:relative;z-index:1;display:grid;grid-auto-flow:column;grid-auto-columns:max-content;gap:22px;align-items:start;width:max-content;padding-bottom:10px;padding-right:12px}
.qtr-wbs-column{background:rgba(255,255,255,.82);border:1px solid #dbe5f0;border-radius:16px;padding:6px 9px 9px;display:grid;gap:2px;min-height:0;align-self:start;box-shadow:0 8px 24px rgba(15,23,42,.035);width:var(--qtr-wbs-l1-width)}
.qtr-wbs-column.level-0{width:var(--qtr-wbs-l0-width)}
.qtr-wbs-column.level-1{width:var(--qtr-wbs-l1-width)}
.qtr-wbs-column.level-2{width:var(--qtr-wbs-l2-width)}
.qtr-wbs-column.level-3{width:var(--qtr-wbs-l3-width)}
.qtr-wbs-column-head{display:grid;gap:0;padding-bottom:2px;border-bottom:1px solid #e5edf6}
.qtr-wbs-column-title{font-size:11px;font-weight:800;color:#0f172a;line-height:1.02;letter-spacing:0;word-break:break-word}
.qtr-wbs-column-sub{font-size:8px;color:#64748b;line-height:1}
.qtr-wbs-column-body{display:grid;gap:6px;align-content:start;padding-top:0;margin-top:0}
.qtr-wbs-empty-col{padding:18px 14px;border:1px dashed #cfdbe8;border-radius:14px;background:#f8fbff;color:#64748b;font-size:12px;text-align:center}
.qtr-wbs-card{--card-scale:1;display:grid;gap:calc(10px * var(--card-scale));padding:calc(12px * var(--card-scale)) calc(12px * var(--card-scale)) calc(11px * var(--card-scale));border:1px solid #dbe5f0;border-radius:16px;background:#fff;box-shadow:0 8px 20px rgba(15,23,42,.05);cursor:pointer;transition:transform .12s ease, box-shadow .12s ease, border-color .12s ease;position:relative;overflow:hidden}
.qtr-wbs-card.level-0{--card-scale:var(--qtr-wbs-l0-scale)}
.qtr-wbs-card.level-1{--card-scale:var(--qtr-wbs-l1-scale)}
.qtr-wbs-card.level-2{--card-scale:var(--qtr-wbs-l2-scale)}
.qtr-wbs-card.level-3{--card-scale:var(--qtr-wbs-l3-scale)}
.qtr-wbs-card:hover{transform:translateY(-1px);box-shadow:0 16px 28px rgba(15,23,42,.08);border-color:#c1d4e8}
.qtr-wbs-card.is-selected{border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.14),0 16px 28px rgba(15,23,42,.08)}
.qtr-wbs-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:#10b981}
.qtr-wbs-card.tip-kok{background:linear-gradient(180deg,#173a72 0%,#15315f 100%);color:#fff;border-color:rgba(37,99,235,.28);box-shadow:0 16px 36px rgba(15,23,42,.16)}
.qtr-wbs-card.tip-kok::before{background:#60a5fa}
.qtr-wbs-card.tip-kok .qtr-wbs-card-kicker,.qtr-wbs-card.tip-kok .qtr-wbs-card-title,.qtr-wbs-card.tip-kok .qtr-wbs-card-code,.qtr-wbs-card.tip-kok .qtr-wbs-card-owner strong{color:#fff}
.qtr-wbs-card.tip-kok .qtr-wbs-card-kicker{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.18);color:#e2e8f0}
.qtr-wbs-card.tip-kok .qtr-wbs-card-level{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.18);color:#dbeafe}
.qtr-wbs-card.tip-kok .qtr-wbs-card-code{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.18)}
.qtr-wbs-card.tip-kok .qtr-wbs-card-owner span{color:#cbd5e1}
.qtr-wbs-card.tip-kok .qtr-wbs-pill{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.16);color:#e2e8f0}
.qtr-wbs-card.tip-kok .qtr-wbs-pill.is-open{background:rgba(34,197,94,.14);border-color:rgba(134,239,172,.28);color:#dcfce7}
.qtr-wbs-card.tip-kok .qtr-wbs-chip{border-color:rgba(255,255,255,.18)}
.qtr-wbs-card.tip-kok .qtr-wbs-chip span{background:rgba(255,255,255,.16);color:#fff}
.qtr-wbs-card.tip-kok .qtr-wbs-chip-placeholder{color:#dbeafe}
.qtr-wbs-card.tip-parca::before{background:#10b981}
.qtr-wbs-card.tip-alt::before{background:#3b82f6}
.qtr-wbs-card-top{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:calc(8px * var(--card-scale));align-items:start}
.qtr-wbs-card-badges{display:flex;flex-wrap:wrap;align-items:center;gap:calc(6px * var(--card-scale));min-width:0}
.qtr-wbs-card-kicker{display:inline-flex;align-items:center;padding:calc(4px * var(--card-scale)) calc(8px * var(--card-scale));border-radius:999px;border:1px solid #dbe5f0;background:#f8fbff;font-size:calc(9px * var(--card-scale));font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#64748b;max-width:100%}
.qtr-wbs-card-code{display:inline-flex;align-items:center;justify-content:center;max-width:100%;padding:calc(6px * var(--card-scale)) calc(10px * var(--card-scale));border-radius:12px;border:1px solid #dbe5f0;background:#f8fbff;font-size:calc(15px * var(--card-scale));font-weight:800;color:#0f172a;line-height:1.05;letter-spacing:-.01em;word-break:break-word;text-align:right}
.qtr-wbs-card-title{font-size:calc(14px * var(--card-scale));font-weight:800;color:#111827;line-height:1.32;word-break:break-word;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:calc(36px * var(--card-scale))}
.qtr-wbs-card-level{display:inline-flex;align-items:center;padding:calc(4px * var(--card-scale)) calc(8px * var(--card-scale));border-radius:999px;border:1px solid #dbe5f0;background:#eef4ff;color:#1d4ed8;font-size:calc(10px * var(--card-scale));font-weight:800;white-space:nowrap}
.qtr-wbs-card-owner{display:grid;gap:calc(2px * var(--card-scale));min-width:0}
.qtr-wbs-card-owner span{font-size:calc(9px * var(--card-scale));font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#94a3b8}
.qtr-wbs-card-owner strong{font-size:calc(11px * var(--card-scale));font-weight:700;color:#334155;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.qtr-wbs-card-meta{display:flex;flex-wrap:wrap;gap:calc(5px * var(--card-scale))}
.qtr-wbs-pill{display:inline-flex;align-items:center;padding:calc(3px * var(--card-scale)) calc(8px * var(--card-scale));border-radius:999px;border:1px solid #dbe5f0;background:#f8fafc;color:#475569;font-size:calc(10px * var(--card-scale));font-weight:700}
.qtr-wbs-pill.is-open{background:#ecfdf5;border-color:#a7f3d0;color:#047857}
.qtr-wbs-pill.is-closed{background:#fff1f2;border-color:#fecdd3;color:#be123c}
.qtr-wbs-pill.is-passive{background:#fffbeb;border-color:#fde68a;color:#b45309}
.qtr-wbs-card-chips{display:flex;flex-wrap:wrap;gap:calc(6px * var(--card-scale));min-height:calc(20px * var(--card-scale))}
.qtr-wbs-chip{display:inline-flex;align-items:center;gap:calc(6px * var(--card-scale));padding:calc(5px * var(--card-scale)) calc(8px * var(--card-scale));border-radius:999px;border:1px solid #dbe5f0;background:#f8fafc;color:#334155;font-size:calc(10px * var(--card-scale));font-weight:800;cursor:pointer;transition:transform .12s ease, box-shadow .12s ease, border-color .12s ease}
.qtr-wbs-chip:hover{transform:translateY(-1px);box-shadow:0 6px 14px rgba(15,23,42,.08)}
.qtr-wbs-chip span{display:inline-flex;align-items:center;justify-content:center;min-width:calc(18px * var(--card-scale));height:calc(18px * var(--card-scale));padding:0 calc(5px * var(--card-scale));border-radius:999px;background:#e2e8f0;color:#0f172a;font-size:calc(10px * var(--card-scale))}
.qtr-wbs-chip.hat{background:rgba(124,58,237,.08);border-color:rgba(124,58,237,.18);color:#5b21b6}
.qtr-wbs-chip.dec{background:rgba(234,88,12,.08);border-color:rgba(234,88,12,.18);color:#c2410c}
.qtr-wbs-chip.ret{background:rgba(37,99,235,.08);border-color:rgba(37,99,235,.18);color:#1d4ed8}
.qtr-wbs-chip-placeholder{font-size:calc(10px * var(--card-scale));color:#94a3b8;align-self:center}
.qtr-wbs-card-actions{display:flex;justify-content:space-between;align-items:center;gap:calc(8px * var(--card-scale));flex-wrap:wrap}
.qtr-wbs-card-actions-left,.qtr-wbs-card-actions-right{display:flex;align-items:center;gap:calc(6px * var(--card-scale));flex-wrap:wrap}
.qtr-wbs-card-actions-right{margin-left:auto}
.qtr-wbs-card-guard-note{padding:calc(7px * var(--card-scale)) calc(9px * var(--card-scale));border-radius:12px;border:1px dashed #f5d0fe;background:#fdf4ff;color:#7e22ce;font-size:calc(10px * var(--card-scale));line-height:1.45}
.qtr-wbs-card.status-passive .qtr-wbs-card-code{border-color:#fde68a;background:#fffbeb;color:#92400e}
.qtr-wbs-card.status-closed .qtr-wbs-card-code{border-color:#fecdd3;background:#fff5f5;color:#9f1239}
.qtr-wbs-sidehead-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.qtr-wbs-sidecard-detail{display:grid;gap:14px}
.qtr-wbs-side-groups{display:grid;gap:12px}
.qtr-wbs-side-flow-group{padding:12px;border:1px solid #dbe5f0;border-radius:16px;background:#fff}
.qtr-wbs-side-flow-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px}
.qtr-wbs-side-flow-heading{font-size:14px;font-weight:800;color:#0f172a}
.qtr-wbs-side-flow-heading span{color:#64748b;font-size:12px;font-weight:700}
.qtr-wbs-side-link{border:none;background:transparent;color:#1d4ed8;font-size:12px;font-weight:700;cursor:pointer}
.qtr-wbs-side-flow-list{display:grid;gap:10px}
.qtr-wbs-side-flow-list.compact{gap:8px}
.qtr-wbs-side-flow-item{display:grid;grid-template-columns:32px minmax(0,1fr);gap:10px;align-items:flex-start;padding:10px;border:1px solid #eef2f7;border-radius:12px;background:#f8fafc}
.qtr-wbs-side-flow-icon{width:32px;height:32px;border-radius:10px;display:grid;place-items:center;font-size:10px;font-weight:800}
.qtr-wbs-side-flow-icon.hat{background:rgba(124,58,237,.12);color:#5b21b6}
.qtr-wbs-side-flow-icon.dec{background:rgba(234,88,12,.12);color:#c2410c}
.qtr-wbs-side-flow-icon.ret{background:rgba(37,99,235,.12);color:#1d4ed8}
.qtr-wbs-side-flow-title{font-size:13px;font-weight:700;color:#0f172a;line-height:1.35}
.qtr-wbs-side-flow-sub{font-size:11px;color:#64748b;line-height:1.45;margin-top:3px}
.qtr-mini-btn.is-primary{background:#0f2d5c;border-color:#0f2d5c;color:#fff}
.qtr-mini-btn.is-primary:hover{background:#173f7b;border-color:#173f7b;color:#fff}
.qtr-wbs-card .qtr-mini-btn{font-size:calc(10px * var(--card-scale));padding:calc(4px * var(--card-scale)) calc(8px * var(--card-scale));line-height:1.1;border-radius:7px;min-height:calc(24px * var(--card-scale))}
.qtr-wbs-card.level-3 .qtr-wbs-card-kicker{display:none}
.qtr-wbs-card.level-3 .qtr-wbs-card-title{-webkit-line-clamp:1;min-height:auto}
.qtr-wbs-card.level-3 .qtr-wbs-card-owner{display:none}
.qtr-wbs-card.level-3 .qtr-wbs-card-actions-left{display:none}
.qtr-wbs-overlay[data-l0-density="compact"] .qtr-wbs-card.level-0{gap:8px;padding:11px 11px 10px;border-radius:15px}
.qtr-wbs-overlay[data-l0-density="compact"] .qtr-wbs-card.level-0 .qtr-wbs-card-title{-webkit-line-clamp:2;min-height:auto}
.qtr-wbs-overlay[data-l0-density="compact"] .qtr-wbs-card.level-0 .qtr-wbs-card-kicker{font-size:8px}
.qtr-wbs-overlay[data-l0-density="compact"] .qtr-wbs-card.level-0 .qtr-wbs-card-code{font-size:16px}
.qtr-wbs-overlay[data-l0-density="compact"] .qtr-wbs-card.level-0 .qtr-wbs-card-chips{min-height:0;gap:4px}
.qtr-wbs-overlay[data-l0-density="compact"] .qtr-wbs-card.level-0 .qtr-wbs-chip{padding:4px 7px;gap:4px}
.qtr-wbs-overlay[data-l0-density="compact"] .qtr-wbs-card.level-0 .qtr-mini-btn{min-height:23px;padding:4px 7px}
.qtr-wbs-overlay[data-l1-density="compact"] .qtr-wbs-card.level-1 .qtr-wbs-card-title,
.qtr-wbs-overlay[data-l2-density="compact"] .qtr-wbs-card.level-2 .qtr-wbs-card-title,
.qtr-wbs-overlay[data-l3-density="compact"] .qtr-wbs-card.level-3 .qtr-wbs-card-title{-webkit-line-clamp:1;min-height:auto}
.qtr-wbs-overlay[data-l1-density="compact"] .qtr-wbs-card.level-1,
.qtr-wbs-overlay[data-l2-density="compact"] .qtr-wbs-card.level-2,
.qtr-wbs-overlay[data-l3-density="compact"] .qtr-wbs-card.level-3{gap:calc(7px * var(--card-scale));padding:calc(10px * var(--card-scale)) calc(10px * var(--card-scale)) calc(9px * var(--card-scale))}
.qtr-wbs-overlay[data-l1-density="compact"] .qtr-wbs-card.level-1 .qtr-wbs-card-chips,
.qtr-wbs-overlay[data-l2-density="compact"] .qtr-wbs-card.level-2 .qtr-wbs-card-chips,
.qtr-wbs-overlay[data-l3-density="compact"] .qtr-wbs-card.level-3 .qtr-wbs-card-chips{min-height:calc(16px * var(--card-scale));gap:calc(4px * var(--card-scale))}
.qtr-wbs-overlay[data-l1-density="ultra"] .qtr-wbs-card.level-1,
.qtr-wbs-overlay[data-l2-density="ultra"] .qtr-wbs-card.level-2,
.qtr-wbs-overlay[data-l3-density="ultra"] .qtr-wbs-card.level-3{gap:calc(5px * var(--card-scale));padding:calc(8px * var(--card-scale)) calc(9px * var(--card-scale)) calc(8px * var(--card-scale));border-radius:14px}
.qtr-wbs-overlay[data-l1-density="ultra"] .qtr-wbs-card.level-1 .qtr-wbs-card-kicker,
.qtr-wbs-overlay[data-l2-density="ultra"] .qtr-wbs-card.level-2 .qtr-wbs-card-kicker,
.qtr-wbs-overlay[data-l3-density="ultra"] .qtr-wbs-card.level-3 .qtr-wbs-card-kicker{display:none}
.qtr-wbs-overlay[data-l1-density="ultra"] .qtr-wbs-card.level-1 .qtr-wbs-card-code,
.qtr-wbs-overlay[data-l2-density="ultra"] .qtr-wbs-card.level-2 .qtr-wbs-card-code,
.qtr-wbs-overlay[data-l3-density="ultra"] .qtr-wbs-card.level-3 .qtr-wbs-card-code{font-size:calc(15px * var(--card-scale));line-height:1.05}
.qtr-wbs-overlay[data-l1-density="ultra"] .qtr-wbs-card.level-1 .qtr-wbs-card-title,
.qtr-wbs-overlay[data-l2-density="ultra"] .qtr-wbs-card.level-2 .qtr-wbs-card-title,
.qtr-wbs-overlay[data-l3-density="ultra"] .qtr-wbs-card.level-3 .qtr-wbs-card-title{-webkit-line-clamp:1;min-height:auto;font-size:calc(11px * var(--card-scale));line-height:1.2}
.qtr-wbs-overlay[data-l1-density="ultra"] .qtr-wbs-card.level-1 .qtr-wbs-card-meta,
.qtr-wbs-overlay[data-l2-density="ultra"] .qtr-wbs-card.level-2 .qtr-wbs-card-meta,
.qtr-wbs-overlay[data-l3-density="ultra"] .qtr-wbs-card.level-3 .qtr-wbs-card-meta{gap:calc(3px * var(--card-scale))}
.qtr-wbs-overlay[data-l1-density="ultra"] .qtr-wbs-card.level-1 .qtr-wbs-card-meta .qtr-wbs-pill:not(.is-open):not(.is-closed),
.qtr-wbs-overlay[data-l2-density="ultra"] .qtr-wbs-card.level-2 .qtr-wbs-card-meta .qtr-wbs-pill:not(.is-open):not(.is-closed),
.qtr-wbs-overlay[data-l3-density="ultra"] .qtr-wbs-card.level-3 .qtr-wbs-card-meta .qtr-wbs-pill:not(.is-open):not(.is-closed){display:none}
.qtr-wbs-overlay[data-l1-density="ultra"] .qtr-wbs-card.level-1 .qtr-wbs-card-chips,
.qtr-wbs-overlay[data-l2-density="ultra"] .qtr-wbs-card.level-2 .qtr-wbs-card-chips,
.qtr-wbs-overlay[data-l3-density="ultra"] .qtr-wbs-card.level-3 .qtr-wbs-card-chips{min-height:0;gap:calc(3px * var(--card-scale))}
.qtr-wbs-overlay[data-l1-density="ultra"] .qtr-wbs-card.level-1 .qtr-wbs-chip,
.qtr-wbs-overlay[data-l2-density="ultra"] .qtr-wbs-card.level-2 .qtr-wbs-chip,
.qtr-wbs-overlay[data-l3-density="ultra"] .qtr-wbs-card.level-3 .qtr-wbs-chip{padding:calc(3px * var(--card-scale)) calc(6px * var(--card-scale));gap:calc(4px * var(--card-scale))}
.qtr-wbs-overlay[data-l1-density="ultra"] .qtr-wbs-card.level-1 .qtr-wbs-chip-placeholder,
.qtr-wbs-overlay[data-l2-density="ultra"] .qtr-wbs-card.level-2 .qtr-wbs-chip-placeholder,
.qtr-wbs-overlay[data-l3-density="ultra"] .qtr-wbs-card.level-3 .qtr-wbs-chip-placeholder{display:none}
.qtr-wbs-overlay[data-l1-density="ultra"] .qtr-wbs-card.level-1 .qtr-wbs-card-actions-left,
.qtr-wbs-overlay[data-l2-density="ultra"] .qtr-wbs-card.level-2 .qtr-wbs-card-actions-left,
.qtr-wbs-overlay[data-l3-density="ultra"] .qtr-wbs-card.level-3 .qtr-wbs-card-actions-left{display:none}
.qtr-wbs-overlay[data-l1-density="ultra"] .qtr-wbs-card.level-1 .qtr-wbs-card-actions,
.qtr-wbs-overlay[data-l2-density="ultra"] .qtr-wbs-card.level-2 .qtr-wbs-card-actions,
.qtr-wbs-overlay[data-l3-density="ultra"] .qtr-wbs-card.level-3 .qtr-wbs-card-actions{justify-content:flex-end}
.qtr-wbs-settings-pop{position:absolute;right:16px;top:62px;z-index:3;width:min(448px,calc(100vw - 40px));display:none}
.qtr-wbs-settings-pop.on{display:block}
.qtr-wbs-settings-card{background:#fff;border:1px solid #dbe5f0;border-radius:18px;box-shadow:0 24px 48px rgba(15,23,42,.18);padding:16px;display:grid;gap:14px}
.qtr-wbs-settings-top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.qtr-wbs-settings-kicker{font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:#64748b}
.qtr-wbs-settings-title{font-size:18px;font-weight:800;color:#0f172a;margin-top:3px}
.qtr-wbs-settings-sub{font-size:12px;color:#475569;line-height:1.5;margin-top:5px}
.qtr-wbs-settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px 14px}
.qtr-wbs-setting-field{display:grid;gap:7px}
.qtr-wbs-setting-head{display:flex;justify-content:space-between;align-items:center;gap:10px;font-size:12px;color:#334155;font-weight:700}
.qtr-wbs-setting-head strong{font-size:12px;color:#0f172a}
.qtr-wbs-setting-field input[type=range]{width:100%}
.qtr-wbs-settings-actions{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;border-top:1px solid #eef2f7;padding-top:12px}
.qtr-wbs-settings-actions-right{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
body.qtr-wbs-open{overflow:hidden}

@media (max-width: 1280px){
  .qtr-wbs-layout{grid-template-columns:1fr}
}
@media (max-width: 900px){
  .qtr-wbs-overlay{padding:6px}
  .qtr-wbs-shell{border-radius:12px}
  .qtr-wbs-topbar{padding:12px}
  .qtr-wbs-columns{grid-auto-columns:minmax(260px,300px)}
}

/* DEV46 - Qutrit WBS side panel tabs and detail polish */
.qtr-wbs-sidehero{display:grid;gap:10px;margin-bottom:2px}
.qtr-tree-hero-main{display:grid;gap:6px}
.qtr-tree-status-pill{display:inline-flex;align-items:center;justify-content:center;align-self:start;border-radius:999px;padding:6px 10px;font-size:11px;font-weight:800;border:1px solid #dbe5f0;background:#f8fafc;color:#334155}
.qtr-tree-status-pill.is-open{background:#dcfce7;border-color:#86efac;color:#166534}
.qtr-tree-status-pill.is-closed{background:#e2e8f0;border-color:#cbd5e1;color:#475569}
.qtr-tree-hero-meta{font-size:11px;color:#64748b;line-height:1.45}
.qtr-tree-tabs{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
.qtr-tree-tab{border:1px solid #dbe5f0;background:#f8fafc;color:#475569;border-radius:12px;padding:9px 10px;font-size:12px;font-weight:700;cursor:pointer;transition:all .15s ease}
.qtr-tree-tab:hover{border-color:#93c5fd;background:#eff6ff;color:#1d4ed8}
.qtr-tree-tab.is-active{background:#0f2d5c;border-color:#0f2d5c;color:#fff;box-shadow:0 8px 18px rgba(15,45,92,.18)}
.qtr-tree-panel-body{display:grid;gap:12px}
.qtr-tree-sidegrid.compact{margin-top:0}
.qtr-tree-alert{border-radius:14px;padding:12px 14px;border:1px solid #dbe5f0;background:#f8fafc}
.qtr-tree-alert.is-ok{background:#ecfdf5;border-color:#86efac}
.qtr-tree-alert.is-blocked{background:#fff7ed;border-color:#fdba74}
.qtr-tree-alert-title{font-size:12px;font-weight:800;color:#0f172a;margin-bottom:4px}
.qtr-tree-alert-text{font-size:12px;line-height:1.55;color:#475569}
.qtr-tree-linkgrid{display:grid;gap:10px}
.qtr-tree-linkbox{border:1px solid #dbe5f0;border-radius:14px;background:linear-gradient(180deg,#fff 0%,#f8fafc 100%);padding:12px}
.qtr-tree-linkbox>span{display:block;font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#64748b;margin-bottom:5px}
.qtr-tree-linkbox>strong{display:block;font-size:13px;color:#0f172a;line-height:1.4;margin-bottom:4px}
.qtr-tree-linkbox>div{font-size:12px;color:#475569;line-height:1.55}
.qtr-tree-linkrow{display:grid;gap:2px;padding:8px 0;border-top:1px dashed #dbe5f0}
.qtr-tree-linkrow:first-child{border-top:none;padding-top:0}
.qtr-tree-linkrow strong{font-size:12px;color:#0f172a}
.qtr-tree-linkrow span{font-size:11px;color:#475569;line-height:1.45}
.qtr-tree-linkrow em{font-style:normal;font-size:10px;color:#64748b}
.qtr-wbs-side-flow-group.is-focused{border-color:#93c5fd;box-shadow:0 8px 20px rgba(59,130,246,.10)}
.qtr-wbs-side-flow-item[data-wbs-flow-detail]{cursor:pointer}
.qtr-wbs-side-flow-item[data-wbs-flow-detail]:hover{border-color:#cbd5e1;background:#fff}
@media (max-width: 1200px){
  .qtr-tree-tabs{grid-template-columns:1fr}
}

#ov-qtr-detay{z-index:1405}
#ov-qtr-cikti{z-index:1410}
#ov-qtr-detay .mdl{width:min(980px,calc(100vw - 32px));max-width:min(980px,calc(100vw - 32px));max-height:calc(100vh - 24px);display:flex;flex-direction:column}
#ov-qtr-detay .modal-ribbon{flex:0 0 auto}
#ov-qtr-detay .mbdy{padding:0;overflow:auto;flex:1 1 auto;min-height:0}
#ov-qtr-detay .qtr-detay-body-inner{padding:14px 16px 16px}
.qtr-detay-feedback{display:block;margin:0 16px 0;min-height:14px;padding:0;border-radius:10px;border:1px solid transparent;font-size:12px;line-height:1.5;font-weight:600;box-shadow:none;transition:all .18s ease}
.qtr-detay-feedback.is-empty{background:transparent;border-color:transparent;color:transparent;min-height:12px;padding:0;box-shadow:none}
.qtr-detay-feedback.is-error{background:#fef2f2;border-color:#fecaca;color:#991b1b;padding:11px 13px;box-shadow:0 1px 2px rgba(15,23,42,.04)}
.qtr-detay-feedback.is-warn{background:#fffbeb;border-color:#fde68a;color:#92400e;padding:11px 13px;box-shadow:0 1px 2px rgba(15,23,42,.04)}
.qtr-detay-feedback.is-success{background:#ecfdf5;border-color:#a7f3d0;color:#166534;padding:11px 13px;box-shadow:0 1px 2px rgba(15,23,42,.04)}
.qtr-detay-feedback.is-info{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8;padding:11px 13px;box-shadow:0 1px 2px rgba(15,23,42,.04)}
.qtr-model-action-btn.is-disabled:hover{transform:none;box-shadow:0 1px 2px rgba(0,0,0,.04)}
.qtr-model-action-btn.is-disabled:focus-visible{outline:2px solid #f59e0b;outline-offset:2px}
@media (max-width: 760px){
  #ov-qtr-detay .mdl{width:calc(100vw - 16px);max-width:calc(100vw - 16px);max-height:calc(100vh - 16px)}
  #ov-qtr-detay .qtr-detay-body-inner{padding:12px}
  .qtr-detay-feedback{margin:0 12px}
}

.qtr-genel-top-actions {
  display: flex;
  gap: 5px;
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: 10px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border,#c8d3df);
}


/* ==== Qutrit GANTT ERP workspace ==== */
.qtr-gantt-workspace-overlay{position:fixed;inset:0;background:rgba(15,23,42,.24);backdrop-filter:blur(2px);display:none;z-index:1250;padding:8px}
.qtr-gantt-workspace-overlay.on{display:block}
.qtr-gantt-workspace-shell{height:100%;background:#f8fafc;border:1px solid rgba(148,163,184,.18);border-radius:18px;box-shadow:0 22px 60px rgba(15,23,42,.18);display:flex;flex-direction:column;overflow:hidden}
.qtr-gantt-workspace-heading{min-width:0;flex:1 1 auto}
.qtr-gantt-workspace-title-row{display:flex;align-items:center;gap:10px;min-width:0;max-width:100%;width:100%}
.qtr-gantt-workspace-title-row .qtr-common-modal-title{flex:0 1 clamp(220px,42vw,720px);min-width:0;max-width:min(42vw,720px);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.qtr-gantt-workspace-strip{display:flex;align-items:center;min-width:0;flex:1 1 auto;overflow:hidden}
.qtr-gantt-workspace-strip.is-empty{display:none}
.qtr-gantt-workspace-tabs{display:flex;align-items:center;gap:6px;min-width:0;overflow-x:auto;overflow-y:hidden;flex:1 1 auto;padding-bottom:2px;scrollbar-width:thin}
.qtr-gantt-workspace-tab{position:relative;display:inline-flex;align-items:center;justify-content:center;min-width:30px;height:28px;padding:0 10px;border:1px solid #d0dceb;border-radius:999px;background:#fff;color:#334155;cursor:pointer;font:700 12px/1 inherit;box-shadow:0 1px 2px rgba(15,23,42,.04);flex:0 0 auto;transition:border-color .18s ease, background-color .18s ease, color .18s ease, box-shadow .18s ease, transform .18s ease}
.qtr-gantt-workspace-tab:hover{border-color:#818cf8;background:#f8faff;color:#1e293b;box-shadow:0 4px 14px rgba(99,102,241,.10);transform:translateY(-1px)}
.qtr-gantt-workspace-tab.is-active{border-color:#4338ca;background:linear-gradient(180deg,#eef2ff 0%,#e0e7ff 100%);color:#1e1b4b;box-shadow:0 0 0 2px rgba(79,70,229,.18),0 10px 24px rgba(79,70,229,.18);transform:translateY(-1px)}
.qtr-gantt-workspace-tab-label{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.qtr-gantt-workspace-body{position:relative;flex:1;min-height:0;background:#e2e8f0}
.qtr-gantt-workspace-pane{position:absolute;inset:0;display:none;background:#fff}
.qtr-gantt-workspace-pane.is-active{display:block}
.qtr-gantt-workspace-frame{width:100%;height:100%;border:0;background:#fff;display:block}
.qtr-gantt-workspace-empty{height:100%;display:grid;place-items:center;padding:24px;color:#64748b;font-size:13px}
body.qtr-gantt-workspace-open{overflow:hidden}
@media (max-width: 980px){
  .qtr-gantt-workspace-overlay{padding:4px}
  .qtr-gantt-workspace-shell{border-radius:14px}
  .qtr-gantt-workspace-title-row{gap:8px}
  .qtr-gantt-workspace-title-row .qtr-common-modal-title{flex-basis:min(56vw,360px);max-width:min(56vw,360px);min-width:0}
  .qtr-gantt-workspace-tab{min-width:28px;height:26px;padding:0 8px}
  .qtr-gantt-workspace-tab{max-width:220px}
}


/* WBS layout fix: keep new cards, old working shell flow */
.qtr-wbs-workspace-shell{background:#f3f6fb;border:1px solid rgba(148,163,184,.35);box-shadow:0 30px 80px rgba(15,23,42,.24);}
.qtr-wbs-workspace-shell .qtr-wbs-topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:12px 14px 10px;border-bottom:1px solid #dce5ef;background:linear-gradient(180deg,#f8fbff 0%,#eff5fb 100%);}
.qtr-wbs-topbar-main{display:grid;gap:4px;min-width:0;}
.qtr-wbs-top-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px;}
#qtr-wbs-top-title{font-size:15px;font-weight:800;color:#0f172a;line-height:1.2;}
#qtr-wbs-top-sub{font-size:12px;color:#64748b;line-height:1.35;}

/* APPEND_OK */

/* Revize: Qutrit bant filtre/komut butonları büyütüldü ve detay alanı aşağıdan kısaltıldı */
.qtr-listband-filters{
  gap:7px !important;
  padding:5px 8px !important;
}
.qtr-life-filters-inline{
  gap:6px !important;
}
.qtr-life-chip{
  min-height:32px !important;
  padding:8px 12px !important;
  border-radius:5px !important;
  font:800 12px/1 var(--sans) !important;
  gap:6px !important;
}
.qtr-life-chip span{
  min-width:20px !important;
  padding:3px 5px !important;
  border-radius:4px !important;
  font-size:11px !important;
  font-weight:800 !important;
}
.qtr-flt-inp,.qtr-flt-sel{
  height:31px !important;
  font-size:12px !important;
  border-radius:4px !important;
}
.qtr-life-chip.qtr-life-chip-modal{
  background:linear-gradient(180deg,#fff7e8,#f3ead7) !important;
  border-color:#ddb979 !important;
  color:#68410c !important;
  box-shadow:0 2px 5px rgba(128,92,20,.12) !important;
}
.qtr-life-chip.qtr-life-chip-modal:hover{
  background:linear-gradient(180deg,#fff1d4,#efd9ad) !important;
  border-color:#c99638 !important;
}

/* Qutrit ribbon ana ölçüleri tek merkezde üst bölümden yönetilir. */

/* ═══════════════════════════════════════════════════════════════
   TUR31 — LISTE SON SATIRIN ALT ÇİZGİSİ
   24 Nisan 2026

   Sorun: Yukarıda satır 274 civarında şu kural var:
     .qtr-list-row:last-child td { border-bottom: none; }
   Kasıtlı eklenmiş ama listband'in kendi 3px border'ı satırdan
   uzakta (içeride scroll alanı var), çift çizgi riski yok. Bu
   kural son satırı "asılı kalmış / boşlukta" görünür yapıyor.

   Çözüm: Özgüllük aynı, daha sonra tanımlandığı için bu kural
   öncekini override eder — !important gerekmez.
   ═══════════════════════════════════════════════════════════════ */
.qtr-list-row:last-child td { border-bottom: 1px solid #edf2f8; }
