/* ============================================================
   FinToolbox — Navigation v2 (Schritt 22)
   Sectioned sidebar · status pills · ⌘K command palette ·
   mobile drawer + bottom tab-bar · category breadcrumb.
   Loaded AFTER css/styles.css (extends its base .sidebar/.sb-link/.topbar).
   ============================================================ */

/* ---- Sidebar: collapsible group containers ---- */
.sb-group { display: flex; flex-direction: column; gap: 1px; }
.sb-group.is-collapsed .sb-link { display: none; }

.sb-section-chev { margin-left: 4px; color: var(--text-4); transition: transform 0.15s; display: inline-flex; align-items: center; }
.sb-section-chev.rot { transform: rotate(-90deg); }

.sb-section.sb-section-btn {
  display: flex; align-items: center; gap: 8px; width: 100%;
  background: transparent; border: 0; cursor: pointer;
  padding: 14px 10px 6px; color: var(--text-4); text-align: left;
}
.sb-section.sb-section-btn:hover { color: var(--text-3); }
.sb-section.sb-section-btn .sb-section-ico { width: 13px; height: 13px; display: inline-flex; }
.sb-section.sb-section-btn .sb-section-count {
  margin-left: auto; font-size: 9.5px; background: var(--card); border: 1px solid var(--line);
  padding: 1px 6px; border-radius: 999px; color: var(--text-3); letter-spacing: 0; text-transform: none; font-weight: 600;
}
.sb-section.flush { padding-top: 4px; }

/* Featured star next to a sidebar link */
.sb-feat { margin-left: auto; color: var(--yellow); display: inline-flex; }
.sb-link .pill + .sb-feat, .sb-link .sb-feat + .pill { margin-left: 6px; }

/* Quick "open command palette" pill in the sidebar */
.sb-cmdk {
  display: flex; align-items: center; gap: 8px; background: var(--card); border: 1px solid var(--line);
  border-radius: 8px; padding: 8px 10px; margin: 0 0 6px; width: 100%; color: var(--text-3);
  font-size: 12px; cursor: pointer; text-align: left;
}
.sb-cmdk:hover { border-color: var(--text-4); color: var(--text-2); }
.sb-cmdk span { flex: 1; }
.sb-cmdk kbd {
  margin-left: auto; font-family: var(--mono); font-size: 10px; padding: 2px 6px;
  background: var(--card-2); border: 1px solid var(--line); border-radius: 4px; color: var(--text-3);
}

/* Sidebar link label + disabled */
.sb-link .lbl { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.sb-link[disabled], .sb-link.is-disabled { opacity: 0.5; cursor: not-allowed; }
.sb-link .pills { margin-left: auto; display: inline-flex; align-items: center; gap: 5px; }

/* Close-X (mobile drawer only) */
.sb-close {
  display: none; margin-left: auto; background: transparent; border: 0; color: var(--text-3);
  cursor: pointer; padding: 4px; border-radius: 6px;
}
.sb-close:hover { background: var(--card-2); color: var(--text); }

/* ---- Status pills ---- */
.pill {
  display: inline-flex; align-items: center; font-size: 9.5px; font-weight: 700; padding: 2px 7px;
  border-radius: 999px; letter-spacing: 0.04em; text-transform: uppercase; white-space: nowrap; flex-shrink: 0;
}
.pill-pro   { background: rgba(240, 178, 50, 0.15); color: var(--yellow); border: 1px solid rgba(240, 178, 50, 0.3); }
.pill-soon  { background: var(--card);              color: var(--text-3); border: 1px solid var(--line); }
.pill-new   { background: var(--green-soft);        color: var(--green);  border: 1px solid var(--green-dim); }
.pill-login { background: rgba(77, 141, 255, 0.12); color: var(--blue);   border: 1px solid rgba(77, 141, 255, 0.3); }
.pill-v     { background: var(--card-2);            color: var(--text-3); border: 1px solid var(--line); letter-spacing: 0; text-transform: none; }

/* ---- Topbar: burger + breadcrumb + search opener ---- */
.tb-burger {
  display: none; width: 32px; height: 32px; align-items: center; justify-content: center;
  background: var(--card); border: 1px solid var(--line); border-radius: 8px; color: var(--text-2); cursor: pointer;
}
.tb-burger:hover { background: var(--card-2); color: var(--text); }
.topbar .crumb-link { background: transparent; border: 0; padding: 0; color: var(--text-3); font-size: 12px; cursor: pointer; font-weight: 500; }
.topbar .crumb-link:hover { color: var(--text); }
.topbar .crumb-sep { color: var(--text-4); padding: 0 6px; }
.topbar .tb-search {
  cursor: pointer; text-align: left; background: var(--card); border: 1px solid var(--line);
  border-radius: 8px; padding: 6px 10px; width: 280px; display: flex; align-items: center; gap: 8px;
  color: var(--text-3); font-size: 12.5px;
}
.topbar .tb-search:hover { border-color: var(--text-4); color: var(--text-2); }
.topbar .tb-search span { flex: 1; }
.topbar .tb-search kbd {
  font-family: var(--mono); font-size: 10px; padding: 2px 6px; background: var(--card-2);
  border: 1px solid var(--line); border-radius: 4px; color: var(--text-3);
}

/* ---- Mobile drawer scrim ---- */
.sb-scrim { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.55); z-index: 40; backdrop-filter: blur(2px); }
.sb-scrim.is-open { display: block; }

/* ---- Mobile bottom tab-bar ---- */
.mobile-tabbar {
  display: none; position: fixed; bottom: 0; left: 0; right: 0; background: var(--bg-elev);
  border-top: 1px solid var(--line); padding: 6px 4px calc(6px + env(safe-area-inset-bottom));
  z-index: 30; justify-content: space-around; gap: 2px;
}
.mt-tab {
  flex: 1; background: transparent; border: 0; display: flex; flex-direction: column; align-items: center;
  justify-content: center; gap: 3px; padding: 6px 4px; border-radius: 8px; color: var(--text-3);
  font-size: 9.5px; font-weight: 600; cursor: pointer; min-width: 0;
}
.mt-tab:hover { color: var(--text-2); }
.mt-tab.active { color: var(--text); }
.mt-tab > span:first-child { display: inline-flex; }
.mt-tab > span:last-child { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 100%; }

/* ---- Command palette (⌘K) ---- */
.cmdk-scrim {
  position: fixed; inset: 0; background: rgba(0,0,0,0.65); z-index: 60; display: flex;
  align-items: flex-start; justify-content: center; padding: 13vh 16px 16px;
  backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px); animation: cmdkFadeIn 0.12s ease-out;
}
@keyframes cmdkFadeIn { from { opacity: 0; } to { opacity: 1; } }
.cmdk {
  width: 100%; max-width: 620px; background: var(--bg-elev); border: 1px solid var(--line);
  border-radius: 12px; box-shadow: 0 24px 60px rgba(0,0,0,0.5); display: flex; flex-direction: column;
  max-height: min(70vh, 600px); overflow: hidden; animation: cmdkSlideIn 0.14s ease-out;
}
@keyframes cmdkSlideIn { from { transform: translateY(-8px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
.cmdk-input { display: flex; align-items: center; gap: 10px; padding: 14px 16px; border-bottom: 1px solid var(--line); color: var(--text-3); }
.cmdk-input input { flex: 1; background: transparent; border: 0; outline: none; color: var(--text); font-size: 14.5px; font-weight: 500; }
.cmdk-input input::placeholder { color: var(--text-4); }
.cmdk-input kbd { font-family: var(--mono); font-size: 10px; padding: 3px 7px; background: var(--card-2); border: 1px solid var(--line); border-radius: 4px; color: var(--text-3); }
.cmdk-body { flex: 1; overflow: auto; padding: 6px 6px 8px; }
.cmdk-empty { padding: 24px 18px; text-align: center; font-size: 13px; color: var(--text-3); }
.cmdk-group + .cmdk-group { margin-top: 4px; }
.cmdk-group-h { display: flex; align-items: center; gap: 8px; padding: 10px 12px 4px; font-size: 10.5px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-4); }
.cmdk-group-h > span:first-child { display: inline-flex; width: 13px; height: 13px; }
.cmdk-row { width: 100%; display: flex; align-items: center; gap: 10px; padding: 9px 12px; background: transparent; border: 0; border-radius: 8px; color: var(--text-2); font-size: 13px; font-weight: 500; cursor: pointer; text-align: left; }
.cmdk-row .ico { width: 16px; height: 16px; color: var(--text-3); flex-shrink: 0; display: inline-flex; }
.cmdk-row .lbl { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cmdk-row .cmdk-feat { color: var(--yellow); display: inline-flex; }
.cmdk-row .cmdk-section-tag { font-size: 10.5px; font-weight: 500; color: var(--text-4); margin-left: 4px; }
.cmdk-row.is-active { background: var(--card); color: var(--text); }
.cmdk-row.is-active .ico { color: var(--green); }
.cmdk-foot { display: flex; align-items: center; gap: 16px; padding: 10px 16px; border-top: 1px solid var(--line); font-size: 11px; color: var(--text-4); }
.cmdk-foot kbd { font-family: var(--mono); font-size: 9.5px; padding: 2px 5px; background: var(--card-2); border: 1px solid var(--line); border-radius: 3px; color: var(--text-3); margin: 0 3px; }
.cmdk-foot > span { display: inline-flex; align-items: center; }

/* ---- Mobile (≤720px): drawer + bottom tab-bar ---- */
@media (max-width: 720px) {
  .app { grid-template-columns: 1fr; }
  .sidebar {
    position: fixed; top: 0; left: 0; bottom: 0; width: 280px; height: 100vh;
    transform: translateX(-100%); transition: transform 0.22s ease-out; z-index: 50;
    box-shadow: 8px 0 24px rgba(0,0,0,0.35);
  }
  .sidebar.is-open { transform: translateX(0); }
  .sb-close { display: inline-flex; }
  .tb-burger { display: inline-flex; }
  .mobile-tabbar { display: flex; }
  .topbar .tb-search, .topbar .tb-seg { display: none; }
  .topbar { padding: 10px 14px; gap: 8px; }
  main { padding-bottom: calc(68px + env(safe-area-inset-bottom)); }
}
