/* ===== BbnkV03 Workspace — desktop shell (M1) ===== */
.bbnk-desktop {
  position: fixed;
  inset: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  color: var(--d-text);
  background: var(--d-bg);
  background-image: var(--d-wall);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  user-select: none;
}
.bbnk-desktop.dragging { cursor: grabbing; }
.bbnk-desktop * { box-sizing: border-box; }

/* ---- themes (colors only; structure is shared) ---- */
.bbnk-desktop[data-theme="dark"] {
  --d-bg: #0f1115; --d-wall: radial-gradient(1100px 760px at 75% -12%, #1b2333, #0f1115);
  --d-panel: rgba(25,28,36,.78); --d-solid: #1c1f26; --d-text: #e6e8ec; --d-muted: #9aa1ad;
  --d-border: #2c313b; --d-accent: #6f8cff; --d-ink: #0f1115; --d-title: #222735;
  --d-shadow: 0 16px 44px rgba(0,0,0,.5);
}
.bbnk-desktop[data-theme="light"] {
  --d-bg: #e9eef6; --d-wall: radial-gradient(1200px 800px at 70% -10%, #dbe6fb, #e9eef6);
  --d-panel: rgba(255,255,255,.74); --d-solid: #ffffff; --d-text: #1f2328; --d-muted: #5c636e;
  --d-border: #d3d9e3; --d-accent: #3b5bdb; --d-ink: #ffffff; --d-title: #f3f6fc;
  --d-shadow: 0 14px 40px rgba(20,30,60,.18);
}
.bbnk-desktop[data-theme="midnight"] {
  --d-bg: #0a0f1f; --d-wall: radial-gradient(1100px 760px at 50% -10%, #122046, #0a0f1f);
  --d-panel: rgba(15,23,48,.8); --d-solid: #101a36; --d-text: #dfe7ff; --d-muted: #8a96bd;
  --d-border: #243056; --d-accent: #5ad1ff; --d-ink: #04101f; --d-title: #15224a;
  --d-shadow: 0 16px 44px rgba(0,0,0,.55);
}
.bbnk-desktop[data-theme="sand"] {
  --d-bg: #efe7da; --d-wall: radial-gradient(1100px 760px at 70% -10%, #f6efe2, #e7dcc9);
  --d-panel: rgba(255,253,248,.78); --d-solid: #fffdf8; --d-text: #2e2a23; --d-muted: #7a715f;
  --d-border: #ddd0bc; --d-accent: #b3722a; --d-ink: #ffffff; --d-title: #f3ead9;
  --d-shadow: 0 14px 40px rgba(80,60,30,.2);
}

/* ---- top bar ---- */
.bbnk-topbar {
  flex: none; height: 38px; display: flex; align-items: center; justify-content: space-between;
  padding: 0 12px; background: var(--d-panel); -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--d-border); z-index: 5;
}
.bbnk-brand { font-weight: 700; letter-spacing: -.01em; font-size: 14px; }
.bbnk-brand-sub { font-weight: 500; color: var(--d-muted); font-size: 12px; margin-left: 6px; }
.bbnk-topbar-right { display: flex; align-items: center; gap: 14px; font-size: 13px; }
.bbnk-clock { font-variant-numeric: tabular-nums; color: var(--d-muted); }
.bbnk-avatar {
  display: inline-flex; width: 20px; height: 20px; border-radius: 50%; align-items: center; justify-content: center;
  background: var(--d-accent); color: var(--d-ink); font-size: 11px; font-weight: 700;
}
.bbnk-avatar.admin { box-shadow: 0 0 0 2px color-mix(in srgb, var(--d-accent) 40%, transparent); }
img.bbnk-avatar { object-fit: cover; display: inline-block; vertical-align: middle; }
.bbnk-admin-dot { color: var(--d-accent); font-size: 11px; line-height: 1; }
.caret { color: var(--d-muted); }

/* reusable popover/flyout — panel auto-closes 500ms after the pointer leaves (see Popover.razor) */
.bbnk-popover { position: relative; }
.bbnk-popover-trigger { display: inline-flex; }
.bbnk-trigger-btn {
  display: inline-flex; align-items: center; gap: 7px; background: transparent; color: var(--d-text);
  border: 1px solid var(--d-border); border-radius: 8px; padding: 4px 10px; cursor: pointer; font-size: 13px;
  user-select: none; white-space: nowrap;
}
.bbnk-popover-trigger:hover .bbnk-trigger-btn { background: var(--d-solid); }
.bbnk-popover-panel {
  position: absolute; right: 0; top: calc(100% + 6px); min-width: 210px; background: var(--d-solid);
  border: 1px solid var(--d-border); border-radius: 10px; box-shadow: var(--d-shadow); padding: 8px; z-index: 50;
}
.bbnk-menu-head { font-size: 12px; color: var(--d-muted); padding: 4px 8px 8px; }
.bbnk-menu-item {
  display: flex; align-items: center; gap: 8px; width: 100%; text-align: left; background: transparent;
  border: none; color: var(--d-text); padding: 8px; border-radius: 7px; cursor: pointer; font-size: 13.5px;
}
.bbnk-menu-item:hover:not([disabled]) { background: var(--d-border); }
.bbnk-menu-item.on { background: var(--d-accent); color: var(--d-ink); }
.bbnk-menu-item[disabled] { opacity: .55; cursor: default; justify-content: space-between; }
.swatch { width: 16px; height: 16px; border-radius: 5px; border: 1px solid var(--d-border); flex: none; }
.swatch[data-theme="dark"] { background: #1c1f26; }
.swatch[data-theme="light"] { background: #e9eef6; }
.swatch[data-theme="midnight"] { background: #101a36; }
.swatch[data-theme="sand"] { background: #efe7da; }
.soon { font-size: 10px; background: var(--d-accent); color: var(--d-ink); border-radius: 999px; padding: 1px 7px; }
.bbnk-menu-note { font-size: 11px; color: var(--d-muted); padding: 6px 8px 2px; }

/* remembered-accounts switcher (TopBar account menu) */
.bbnk-menu-sep { height: 1px; background: var(--d-border); margin: 6px 4px; }
.bbnk-acct-row { display: flex; align-items: center; gap: 2px; }
.bbnk-acct-pick { flex: 1; min-width: 0; }
.bbnk-acct-email { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.bbnk-avatar.small { width: 18px; height: 18px; font-size: 10px; flex: none; }
.bbnk-acct-forget {
  flex: none; background: transparent; border: none; color: var(--d-muted); cursor: pointer;
  font-size: 16px; line-height: 1; padding: 4px 8px; border-radius: 7px;
}
.bbnk-acct-forget:hover { background: var(--d-border); color: var(--d-text); }

/* ---- surface + windows ---- */
.bbnk-surface { position: relative; flex: 1; overflow: hidden; }
.bbnk-empty {
  position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 8px; color: var(--d-muted);
}
.bbnk-empty-badge { font-size: 44px; font-weight: 800; letter-spacing: -.03em; color: var(--d-text); opacity: .28; }

.bbnk-window {
  position: absolute; display: flex; flex-direction: column; min-width: 300px; min-height: 170px;
  background: var(--d-solid); border: 1px solid var(--d-border); border-radius: 12px;
  box-shadow: var(--d-shadow); overflow: hidden;
}
.bbnk-window.min { display: none; }
.bbnk-window.max { left: 0; top: 0; width: 100%; height: 100%; border-radius: 0; }
.bbnk-titlebar {
  flex: none; height: 34px; display: flex; align-items: center; justify-content: space-between;
  padding: 0 6px 0 12px; background: var(--d-title); border-bottom: 1px solid var(--d-border); cursor: grab;
}
.bbnk-title { font-size: 13px; font-weight: 600; }
.bbnk-winbtns { display: flex; gap: 2px; }
.wb { width: 28px; height: 24px; border: none; background: transparent; color: var(--d-muted);
  border-radius: 6px; cursor: pointer; font-size: 14px; line-height: 1; }
.wb:hover { background: var(--d-border); color: var(--d-text); }
.wb.close:hover { background: #e5484d; color: #fff; }
.bbnk-winbody { flex: 1; overflow: auto; padding: 16px; font-size: 14px; line-height: 1.55; user-select: text; }

/* ---- taskbar ---- */
.bbnk-taskbar {
  flex: none; height: 52px; display: flex; align-items: center; gap: 14px; padding: 0 12px;
  background: var(--d-panel); -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px);
  border-top: 1px solid var(--d-border); z-index: 5;
}
.bbnk-launchers, .bbnk-tasklist { display: flex; align-items: center; gap: 8px; }
.bbnk-tasklist { padding-left: 14px; border-left: 1px solid var(--d-border); }
.bbnk-launch {
  display: flex; align-items: center; gap: 7px; background: transparent; border: 1px solid transparent;
  color: var(--d-text); border-radius: 9px; padding: 6px 11px; cursor: pointer; font-size: 13px;
}
.bbnk-launch:hover { background: var(--d-solid); border-color: var(--d-border); }
.bbnk-launch.active { border-color: var(--d-accent); }
.bbnk-launch .ico { font-size: 15px; }
.bbnk-task {
  background: var(--d-solid); border: 1px solid var(--d-border); color: var(--d-text);
  border-radius: 8px; padding: 5px 10px; cursor: pointer; font-size: 12.5px;
}
.bbnk-task.min { opacity: .55; }

/* ---- apps ---- */
.app-welcome { display: flex; flex-direction: column; height: 100%; }
.app-welcome h2 { margin: 0 0 8px; font-size: 20px; }
/* "Bir daha gösterme" — sağ altta */
.welcome-hide { margin-top: auto; align-self: flex-end; display: inline-flex; align-items: center; gap: 6px;
  padding-top: 10px; font-size: 12.5px; color: var(--d-muted); cursor: pointer; user-select: none; }
.welcome-hide input { accent-color: var(--d-accent); cursor: pointer; }
.app-welcome p { margin: 10px 0; }
.app-welcome .kv { margin: 12px 0 0; padding-left: 18px; }
.app-welcome .kv li { margin: 5px 0; }

.app-settings { display: flex; height: 100%; margin: -16px; }
.set-nav { flex: none; width: 152px; display: flex; flex-direction: column; gap: 2px; padding: 12px 8px;
  border-right: 1px solid var(--d-border); }
.set-nav button { text-align: left; background: transparent; border: none; color: var(--d-text);
  padding: 8px 10px; border-radius: 7px; cursor: pointer; font-size: 13.5px; }
.set-nav button:hover { background: var(--d-border); }
.set-nav button.on { background: var(--d-accent); color: var(--d-ink); }
.set-body { flex: 1; padding: 16px 18px; overflow: auto; }
.set-body h3 { margin: 0 0 6px; }
.muted { color: var(--d-muted); font-size: 13px; }
.theme-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; margin-top: 12px; }
.theme-chip { display: flex; align-items: center; gap: 8px; background: var(--d-solid); border: 1px solid var(--d-border);
  color: var(--d-text); border-radius: 9px; padding: 9px 11px; cursor: pointer; }
.theme-chip.on { border-color: var(--d-accent); box-shadow: 0 0 0 1px var(--d-accent); }
.theme-chip .sw { width: 22px; height: 22px; border-radius: 6px; border: 1px solid var(--d-border); }
.theme-chip[data-theme="dark"] .sw { background: #1c1f26; }
.theme-chip[data-theme="light"] .sw { background: #e9eef6; }
.theme-chip[data-theme="midnight"] .sw { background: #101a36; }
.theme-chip[data-theme="sand"] .sw { background: #efe7da; }
.set-head { margin-bottom: 6px; }
.set-head p { margin: 6px 0 0; max-width: 70ch; }
.ai-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 14px; margin-top: 16px; }
.ai-card { border: 1px solid var(--d-border); border-radius: 12px; padding: 14px; background: var(--d-bg); }
.ai-card-head { display: flex; align-items: center; gap: 11px; margin-bottom: 12px; }
.ai-logo { display: inline-flex; width: 36px; height: 36px; border-radius: 9px; align-items: center;
  justify-content: center; background: var(--d-title); border: 1px solid var(--d-border); font-size: 18px; }
.ai-name { font-weight: 700; font-size: 14px; }
.ai-models { font-size: 12px; color: var(--d-muted); }
.ai-field { display: flex; flex-direction: column; gap: 4px; font-size: 12px; color: var(--d-muted); }
.ai-field input, .ai-field select { background: var(--d-solid); border: 1px solid var(--d-border);
  border-radius: 7px; padding: 7px 9px; color: var(--d-text); font-size: 13px; width: 100%; }
.ai-row { display: flex; gap: 10px; align-items: flex-end; margin-top: 10px; }
.ai-field.grow { flex: 1; }
.ai-save { flex: none; height: 34px; background: var(--d-accent); color: var(--d-ink); border: none;
  border-radius: 8px; padding: 0 16px; cursor: default; opacity: .65; font-weight: 600; }
.ai-add { grid-column: 1 / -1; border: 1px dashed var(--d-border); background: transparent; color: var(--d-muted);
  border-radius: 12px; padding: 16px; cursor: default; font-size: 13px; }

/* E-mail (SMTP) ayar formu — .ai-* sınıflarını yeniden kullanır; buton burada gerçekten etkin. */
.email-form { display: flex; flex-direction: column; gap: 12px; max-width: 540px; margin-top: 6px; }
.email-form .ai-row { margin-top: 0; }
.email-actions { margin-top: 2px; }
.email-form .ai-save:not(:disabled) { cursor: pointer; opacity: 1; }
.email-form .ai-save:disabled { cursor: default; opacity: .55; }
/* Test e-postası satırı: alıcı girişi + ikincil (outline) "Send test" butonu, ince bir ayraçla ayrılır. */
.email-test { display: flex; gap: 10px; align-items: flex-end; margin-top: 6px;
  padding-top: 12px; border-top: 1px solid var(--d-border); }
.email-test .ai-field { flex: 1; }
.ai-save.secondary { background: transparent; border: 1px solid var(--d-border); color: var(--d-text); }
.email-form .ai-save.secondary:not(:disabled):hover { border-color: var(--d-accent); }
.set-msg { border-radius: 8px; padding: 4px; font-size: 13px; }
.set-msg.ok { background: color-mix(in srgb, #3fb950 18%, transparent); border: 1px solid color-mix(in srgb, #3fb950 50%, transparent); }
.set-msg.err { background: color-mix(in srgb, #f85149 16%, transparent); border: 1px solid color-mix(in srgb, #f85149 50%, transparent); }

/* Genel rozetler (Settings ve diğer alanlarda) */
.badge { display: inline-block; background: var(--d-title); border: 1px solid var(--d-border); border-radius: 999px;
  padding: 2px 9px; font-size: 11px; color: var(--d-text); }
.badge.admin { background: var(--d-accent); color: var(--d-ink); border-color: transparent; font-weight: 700; }
.badge.danger { background: color-mix(in srgb, #e5484d 22%, transparent); border-color: color-mix(in srgb, #e5484d 55%, transparent); color: var(--d-text); }

/* Admin kullanıcı yönetimi listesi */
.users-actions { margin: 4px 0 10px; }
.user-list { display: flex; flex-direction: column; gap: 8px; max-width: 640px; }
.user-row { border: 1px solid var(--d-border); border-radius: 10px; padding: 10px 12px; background: var(--d-panel);
  display: flex; flex-wrap: wrap; align-items: center; gap: 8px 12px; }
.user-row.is-disabled { opacity: .72; }
.user-main { flex: 1; min-width: 200px; display: flex; flex-direction: column; gap: 4px; }
.user-email { font-size: 14px; font-weight: 600; }
.user-self { color: var(--d-muted); font-weight: 400; font-size: 12px; }
.user-badges { display: flex; gap: 6px; flex-wrap: wrap; }
.user-note { font-size: 12px; color: var(--d-muted); }
.user-ops { display: flex; gap: 6px; flex-wrap: wrap; }
.op { background: var(--d-solid); border: 1px solid var(--d-border); color: var(--d-text); border-radius: 7px;
  padding: 6px 10px; font-size: 12px; cursor: pointer; }
.op:hover:not(:disabled) { background: var(--d-border); }
.op:disabled { opacity: .5; cursor: default; }
.op.danger { border-color: color-mix(in srgb, #e5484d 55%, transparent); color: #f08a8d; }
.op.danger:hover:not(:disabled) { background: color-mix(in srgb, #e5484d 18%, transparent); }
.op.deferred { font-style: italic; }
.disable-form { flex-basis: 100%; display: flex; gap: 8px; margin-top: 6px; }
.disable-form input { flex: 1; background: var(--d-solid); border: 1px solid var(--d-border); color: var(--d-text);
  border-radius: 7px; padding: 7px 10px; font-size: 13px; outline: none; }
.disable-form input:focus { border-color: var(--d-accent); }

/* Scope ana içerik (mainContent) paneli — ScopeContentBase. Form-tabanlı pencere paneli; başlık çubuğunda
   minimize / normalize / maximize / close. Host'un (ör. Project Manager) yüzeyini (position:relative) kaplar. */
/* Normal: konum/boyut inline (taşı/boyutlandır) · max: host yüzeyini doldurur · full: tüm görünüm. Opak + belirgin. */
.scope-content { position: absolute; display: flex; flex-direction: column;
  background: var(--d-panel); border: 1px solid var(--d-border); border-radius: 12px; overflow: hidden;
  box-shadow: 0 20px 64px rgba(0,0,0,.6), 0 0 0 1px color-mix(in srgb, var(--d-accent) 22%, transparent); }
.scope-content.max { inset: 0; border-radius: 0; }                          /* maximize: host yüzeyini (PM) tam kapla */
.scope-content.full { position: fixed; inset: 0; z-index: 9999; border-radius: 0; } /* full screen: TÜM görünümü kapla (backdrop'un da üstünde) */
/* Modal: paneli viewport seviyesine taşı (fixed) → TÜM body üzerinde, koyu örtünün üstünde durur. z host'tan (8001). */
.scope-content.modal { position: fixed; }
/* Başlık çubuğu = taşıma tutamacı (yalnız Moveable açık + Normal durumda → .mv). Butonlar kendi pointer imlecini korur. */
.scope-content.mv .sc-titlebar { cursor: move; }
/* Çok-örnek host: yalnız görünür paneller render edilir; gizliler (modal/minimize) display:none ile canlı kalır (durum korunur). */
.sc-hidden { display: none; }

/* Desktop-seviyesi scope panel katmanı (ScopePanelHost): topbar/taskbar (z:5) ve pencerelerin üstünde, confirm (z:9000) altında.
   Katmanın kendisi tıklamaları geçirir (pointer-events:none); yalnız gerçek paneller/örtü/şerit yakalar → boş alan masaüstüne geçer. */
.sc-layer { position: fixed; inset: 0; z-index: 4000; pointer-events: none; }
.sc-layer .scope-content,
.sc-layer .sc-modal-backdrop,
.sc-layer .sc-strip { pointer-events: auto; }

/* Modal arkaplan: TÜM viewport'u (body) kaplayan ÇOK KOYU örtü → panel belirginleşir; arkayla etkileşim engellenir. */
.sc-modal-backdrop { position: fixed; inset: 0; z-index: 8000; background: rgba(0,0,0,.62); }
/* Header on/off grupları ince boşluklarla ayrılır: görünürlük | modal | taşı-boyutlandır */
.sc-modalbtn { margin-left: 8px; }
.sc-mvbtn { margin-left: 8px; }

/* Pencere boyutlandırma tutamaçları (yalnız Normal): sağ kenar · alt kenar · sağ-alt köşe */
.sc-rz { position: absolute; z-index: 6; }
.sc-rz.r { top: 0; right: 0; width: 6px; height: 100%; cursor: ew-resize; }
.sc-rz.b { left: 0; bottom: 0; height: 6px; width: 100%; cursor: ns-resize; }
.sc-rz.br { right: 0; bottom: 0; width: 14px; height: 14px; cursor: nwse-resize; z-index: 7; }
/* Taşı/boyutlandır sırasında imleci yakalayan örtü */
.sc-dragscrim2 { position: fixed; inset: 0; z-index: 3000; }
.sc-dragscrim2.move { cursor: move; }
.sc-dragscrim2.ew { cursor: ew-resize; }
.sc-dragscrim2.ns { cursor: ns-resize; }
.sc-dragscrim2.nwse { cursor: nwse-resize; }
.sc-titlebar { flex: 0 0 auto; display: flex; align-items: center; justify-content: space-between; gap: 8px;
  padding: 7px 6px 7px 12px; background: var(--d-title); border-bottom: 1px solid var(--d-border); }
.sc-title { font-weight: 700; font-size: 13.5px; color: var(--d-text); min-width: 0;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sc-winbtns { display: flex; gap: 2px; flex: 0 0 auto; }
.sc-wb { width: 30px; height: 26px; border: none; background: transparent; color: var(--d-muted);
  border-radius: 6px; cursor: pointer; font-size: 13px; line-height: 1; }
.sc-wb:hover { background: var(--d-solid); color: var(--d-text); }
.sc-wb.on { background: var(--d-accent); color: var(--d-ink); }   /* full screen aktifken vurgulanır */
.sc-wb.close:hover { background: #e5484d; color: #fff; }
/* Başlık sol grubu: simge+ad + sol/footer/sağ görünürlük toggle'ları */
.sc-tl-left { display: flex; align-items: center; gap: 10px; min-width: 0; }
.sc-vis { display: flex; gap: 2px; flex: 0 0 auto; }
.sc-vb { width: 26px; height: 22px; border: none; background: transparent; color: var(--d-muted);
  border-radius: 5px; cursor: pointer; font-size: 12px; line-height: 1; }
.sc-vb:hover { background: var(--d-solid); color: var(--d-text); }
.sc-vb.on { color: var(--d-accent); }

/* Açık projeler şeridi (alt taskbar) — panellerin üstünde (z:900) ama full-screen panelin (z:1000) altında. */
.sc-strip { position: absolute; left: 10px; right: 10px; bottom: 10px; z-index: 900;
  display: flex; gap: 6px; flex-wrap: wrap; align-items: center;
  background: var(--d-title); border: 1px solid var(--d-border); border-radius: 10px; padding: 6px 8px;
  box-shadow: 0 6px 20px rgba(0,0,0,.3); }
.sc-strip-item { display: flex; align-items: center; max-width: 220px; overflow: hidden;
  border: 1px solid var(--d-border); border-radius: 8px; background: var(--d-solid); }
.sc-strip-item.on { border-color: var(--d-accent); box-shadow: inset 0 0 0 1px var(--d-accent); }
.sc-strip-item.min { opacity: .55; }   /* minimize edilmiş = soluk */
.sc-strip-name { background: none; border: none; color: var(--d-text); font-size: 12.5px; cursor: pointer;
  padding: 5px 9px; max-width: 180px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sc-strip-item.on .sc-strip-name { font-weight: 600; }
.sc-strip-x { background: none; border: none; color: var(--d-muted); cursor: pointer; padding: 5px 8px; font-size: 14px; line-height: 1; }
.sc-strip-x:hover { background: #e5484d; color: #fff; }
