/* ==========================================================
   Project : Navira Stock Management
   File    : static/navira/ui.css
   Module  : Global UI Primitives (Tokens / Buttons / Inputs / Combo)

   Version : v0.2.14
   Change Log:
     v0.2.14
       - ADD: Global page header title style (.navira-page-title)
       - KEEP: everything else unchanged (safe update)
     v0.2.13
       - CLEAN: removed ALL AG Grid related CSS from this file
       - MOVE: grid container/theme/floating-filter polish → navira_grid_defaults.js (CSS injected there)
       - KEEP: tokens, pills, inputs, textarea unchanged
     v0.2.12
       - CLEAN: removed duplicated / page-specific layout CSS
       - KEEP: stable tokens, buttons, inputs, textarea, pills, cards
       - ADD: Navira Combo primitives + TradingView slim scrollbar (.navira-dd)
       - FIX: AG Grid container gets real height (prevents invisible grid)
   ========================================================== */

/* -----------------------------
   1) Typography (Inter locked)
   ----------------------------- */
  :root{
    --navira-font: "Trebuchet MS", "Segoe UI", Arial, sans-serif;
  }
  html{ font-family: var(--navira-font); font-size: 14px; scrollbar-width: thin; scrollbar-color: rgba(var(--accent-rgb),0.40) transparent; }
  body{ font-family: var(--navira-font) !important; }
  body{ line-height: 1.45; }

  /* Global thin scrollbar (Webkit) */
  ::-webkit-scrollbar { width: 3px; height: 3px; }
  ::-webkit-scrollbar-track { background: transparent; }
  ::-webkit-scrollbar-thumb { background: rgba(var(--accent-rgb),0.40); border-radius: 999px; }
  ::-webkit-scrollbar-thumb:hover { background: rgba(var(--accent-rgb),0.65); }
  .navira-numeric{ font-variant-numeric: tabular-nums; }
  
  /* -----------------------------
     2) Color tokens are defined in templates/navira/components/navira_theme.html
     ----------------------------- */
  
  /* Legacy alias (do not break old refs) */
  :root{
    --nv-bg: var(--bg);
    --nv-card: var(--card);
    --nv-surface: var(--surface);
    --nv-border: var(--border);
    --nv-text: var(--text);
    --nv-muted: var(--muted);
    --nv-accent: var(--accent);
    --nv-accent-weak: rgba(var(--accent-rgb),0.12);
    --nv-danger: var(--danger-text);
    --nv-danger-weak: rgba(239,68,68,0.15);
    --nv-radius: 10px;
  }
  
  /* -----------------------------
     3) Base primitives
     ----------------------------- */
  .navira-card{
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: 20px;
    padding: 16px;
  }
  html.dark .navira-card {
    box-shadow: none;
  }
  .navira-surface{
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 20px;
  }
  .navira-shadow{ box-shadow: var(--shadow); }

  
  /* SVG-only sizing helpers */
  .navira-ico-12{ width:12px; height:12px; }
  .navira-ico-14{ width:14px; height:14px; }
  .navira-ico-18{ width:18px; height:18px; }
  .navira-ico-20{ width:20px; height:20px; }
  
  /* -----------------------------
     4) Page header title (GLOBAL)
     ----------------------------- */
  .navira-page-title{
    font-size: 45px;
    font-weight: 800;
    letter-spacing: -0.03em;
    line-height: 1.1;
    color: var(--text);
  }

  
  /* -----------------------------
     5) Pills / labels
     ----------------------------- */
  .navira-pill{
    display:inline-flex;
    align-items:center;
    gap:6px;
  
    height:26px;
    padding:0 10px;
  
    border-radius:9999px;
    border:1px solid var(--border);
    background: var(--surface);
  
    font-size:12px;
    font-weight:600;
    color: var(--muted);
  }
  
  /* Standard field label */
  .navira-field{ display:flex; flex-direction: column; gap: 6px; }
  .navira-field-label{
    font-size: 16px;
    font-weight: 800;
    letter-spacing: .01em;
    line-height: 1.1;
    color: var(--accent);
  }
  .dark .navira-field-label{ color: var(--accent); }
  .navira-field-label .req{
    color: rgba(248,113,113,0.95);
    font-weight: 800;
  }
  
  /* -----------------------------
     6) Inputs moved to component templates
     ----------------------------- */

  /* -----------------------------
     7) Sidebar + nav
     ----------------------------- */
  :root{
    --navira-sidebar-expanded: 340px;
    --navira-sidebar-collapsed: 84px;
  }

  .navira-sidebar{
    transition: width 300ms cubic-bezier(0.2, 0.8, 0.2, 1),
      transform 300ms cubic-bezier(0.2, 0.8, 0.2, 1);
    will-change: width;
    contain: layout paint;
    height: 100vh;
    overflow: hidden;
    background: var(--sidebar-bg, var(--bg)) !important;
    border-right: 1px solid var(--sidebar-border, var(--border)) !important;
    box-shadow: none !important;
  }

  html.dark .navira-sidebar{
    background: var(--sidebar-bg, var(--bg)) !important;
    border-right: 1px solid var(--sidebar-border, var(--border)) !important;
    box-shadow: 1px 0 0 var(--sidebar-border, var(--border)) !important;
  }

  .navira-main{
    transition: padding-left 300ms cubic-bezier(0.2, 0.8, 0.2, 1);
    will-change: padding-left;
  }

  .navira-icon-btn{
    border-color: var(--border);
    background: var(--surface);
    color: var(--text);
  }

  .navira-icon-btn:hover{
    border-color: rgba(var(--accent-rgb), 0.55);
    background: rgba(var(--accent-rgb), 0.12);
  }

  .navira-icon-chip{
    border-color: var(--border);
    background: rgba(255, 255, 255, 0.06);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08);
  }

  .navira-icon-chip .navira-ico-wrap{
    color: var(--text);
  }

  html.dark .navira-icon-chip .navira-ico-wrap{
    filter: brightness(1.12);
  }

  .navira-nav-item{
    display: flex;
    align-items: center;
    gap: 12px;
    width: 100%;
    text-decoration: none;
    border: 1px solid transparent;
    background: transparent;
    color: var(--text);
    min-height: 50px;
    padding: 10px 12px;
    border-radius: 14px;
    font-size: 15px;
    font-weight: 700;
    letter-spacing: 0.02em;
  }

  .navira-nav-item > div{
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
  }

  button.navira-nav-item{
    justify-content: space-between;
  }

  .navira-sidebar a{
    text-decoration: none;
  }

  .navira-nav-item:hover{
    border-color: rgba(255, 255, 255, 0.18);
    background: rgba(255, 255, 255, 0.06);
  }

  .navira-nav-item.is-active{
    border-color: rgba(var(--accent-rgb), 0.60);
    background: rgba(var(--accent-rgb), 0.18);
    box-shadow: inset 3px 0 0 rgba(var(--accent-rgb), 0.9);
  }

  /* -----------------------------
     8) Progress (indeterminate)
     ----------------------------- */
  .navira-progress{
    width: 100%;
    height: 6px;
    border-radius: 999px;
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.12);
    overflow: hidden;
    display: none;
  }
  .navira-progress.show{ display: block; }
  .navira-progress .navira-progress-bar{
    display: block;
    height: 100%;
    width: 40%;
    background: linear-gradient(90deg, rgba(var(--accent-rgb),0.25), rgba(var(--accent-rgb),0.95), rgba(var(--accent-rgb),0.6));
    box-shadow: 0 0 8px rgba(var(--accent-rgb), 0.50);
    animation: navira-indeterminate 1.1s ease infinite;
  }
  @keyframes navira-indeterminate{
    0%{ transform: translateX(-120%); }
    100%{ transform: translateX(260%); }
  }

  .navira-nav-item .navira-icon-chip{
    width: 38px;
    height: 38px;
    border-color: rgba(255, 255, 255, 0.14);
  }

  .navira-nav-item .navira-icon-chip svg{
    width: 18px;
    height: 18px;
  }

  .navira-sub-item{
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    text-decoration: none;
    padding: 10px 12px;
    border-radius: 14px;
    border: 1px solid transparent;
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 0.015em;
    color: var(--text);
    transition: background 0.15s ease, border-color 0.15s ease;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .navira-sub-item:hover{
    border-color: rgba(255, 255, 255, 0.16);
    background: rgba(255, 255, 255, 0.06);
  }

  .navira-sub-item.is-active{
    border-color: rgba(var(--accent-rgb), 0.60);
    background: rgba(var(--accent-rgb), 0.18);
    box-shadow: inset 3px 0 0 rgba(var(--accent-rgb), 0.9);
  }

  .navira-sidebar nav{
    padding: 16px 12px;
    overflow-y: auto;
    flex: 1 1 auto;
    min-height: 0;
  }

  .navira-sidebar .navira-nav-item + .navira-nav-item{
    margin-top: 6px;
  }

  .navira-sidebar .navira-sub-item{
    min-height: 40px;
  }

  .navira-sidebar .navira-sub-ico{
    width: 18px;
    height: 18px;
    flex: 0 0 18px;
  }

  .navira-sidebar .navira-sub-item--settings .navira-sub-ico{
    filter: drop-shadow(0 6px 12px rgba(var(--accent-rgb), 0.15));
  }

  .navira-nav-label{
    margin: 12px 12px 6px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.45);
  }

  .navira-sub-ico{
    width: 16px;
    height: 16px;
    flex: 0 0 16px;
    opacity: 0.95;
    display: inline-block;
  }

  .navira-sub-ico svg{
    width: 100%;
    height: 100%;
    display: block;
  }

  .navira-sub-item--settings .navira-sub-ico{
    color: var(--muted);
  }

  .navira-sub-item--settings[data-icon="account-holders"] .navira-sub-ico{
    color: var(--accent);
  }

  .navira-sub-item--settings[data-icon="broker-accounts"] .navira-sub-ico{
    color: #38bdf8;
  }

  .navira-sub-item--settings[data-icon="bank-accounts"] .navira-sub-ico{
    color: var(--muted);
  }

  .navira-sub-item--settings[data-icon="credentials"] .navira-sub-ico{
    color: #a78bfa;
  }

  .navira-sub-item--settings[data-icon="contract-notes"] .navira-sub-ico{
    color: #fb7185;
  }

  .navira-sub-item--settings[data-icon="brokers"] .navira-sub-ico{
    color: #f472b6;
  }

  .navira-sub-item--settings[data-icon="strategies"] .navira-sub-ico{
    color: #60a5fa;
  }

  .navira-sub-item--settings[data-icon="connections"] .navira-sub-ico{
    color: var(--accent);
  }

  .navira-sub-item--settings.is-active .navira-sub-ico{
    color: var(--accent);
  }

  .navira-nav-ico,
  .navira-sub-ico{
    color: inherit;
  }

  .navira-sub-ico .navira-ico-wrap{
    color: inherit;
  }

  .navira-nav-ico svg,
  .navira-sub-ico svg{
    width: 18px;
    height: 18px;
    display: block;
    color: inherit;
    stroke: currentColor;
    fill: none;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
  }

  @media (prefers-reduced-motion: reduce){
    body,
    .navira-sidebar,
    .navira-main{
      animation-duration: 0ms !important;
      transition-duration: 0ms !important;
    }
  }

  /* -----------------------------
     6) Combo dropdown
     ----------------------------- */
  .navira-dd{
    max-height: 260px;
    overflow-y: auto;
    scrollbar-width: thin;
    scrollbar-color: rgba(255,255,255,0.35) transparent;
    position: relative;
    z-index: 9999;
  }
  .navira-dd::-webkit-scrollbar{
    width: 8px;
  }
  .navira-dd::-webkit-scrollbar-thumb{
    background: rgba(255,255,255,0.35);
    border-radius: 999px;
  }
  .navira-dd::-webkit-scrollbar-track{
    background: transparent;
  }

  /* Summary table (flow tab) */
  .navira-table-wrap{ width:100%; overflow-x:auto; }
  .navira-table{ border-collapse: collapse; width:100%; }
  .navira-table th, .navira-table td{
    padding: 6px 8px;
    border-bottom: 1px solid var(--border);
  }
  .navira-table th{ text-align:left; color: var(--muted); font-weight:700; }
  .navira-table td{ color: var(--text); }

  /* Force-hide AG Grid loading overlay if stuck */
  .ag-overlay-loading-center{ display:none !important; }

  /* ======================================================
     Sidebar v2  —  nv-sb-* namespace
     ====================================================== */

  :root {
    --navira-sidebar-expanded: 270px;
    --navira-sidebar-collapsed: 80px;
  }

  /* --- Collapsed state: center icons --- */
  .nv-sb-collapsed .nv-sb-nav {
    padding: 8px 6px;
  }

  .nv-sb-collapsed .nv-sb-item {
    justify-content: center;
    padding: 6px;
  }

  .nv-sb-collapsed .nv-sb-ico {
    width: 36px;
    height: 36px;
  }

  .nv-sb-collapsed .nv-sb-item:hover .nv-sb-ico {
    transform: scale(1.12);
  }

  .nv-sb-collapsed .nv-sb-header {
    justify-content: center;
    padding: 0;
  }

  .nv-sb-collapsed .nv-sb-footer {
    justify-content: center;
    padding: 10px 6px;
  }

  /* --- Header --- */
  .nv-sb-header {
    height: 56px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 12px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.07);
    flex-shrink: 0;
    gap: 8px;
  }

  html:not(.dark) .nv-sb-header {
    border-bottom-color: var(--border);
  }
  html.dark .nv-sb-header {
    border-bottom-color: var(--sidebar-border, var(--border));
  }

  .nv-sb-brand {
    display: flex;
    align-items: center;
    gap: 9px;
    overflow: hidden;
    flex: 1;
    min-width: 0;
  }

  .nv-sb-logo-mark {
    width: 34px;
    height: 34px;
    border-radius: 9px;
    background: linear-gradient(135deg, var(--accent-hover) 0%, var(--accent) 100%);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 17px;
    font-weight: 900;
    color: #ffffff;
    flex-shrink: 0;
    letter-spacing: -0.03em;
    user-select: none;
    box-shadow: 0 3px 10px rgba(var(--accent-rgb), 0.50),
                0 0 28px rgba(var(--accent-rgb), 0.35);
  }

  .nv-sb-brand-text {
    font-size: 17px;
    font-weight: 800;
    color: var(--text);
    letter-spacing: -0.01em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .nv-sb-pin-btn {
    width: 28px;
    height: 28px;
    border-radius: 7px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    background: rgba(255, 255, 255, 0.06);
    color: var(--muted);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    flex-shrink: 0;
    transition: background 0.14s, color 0.14s, border-color 0.14s;
  }

  html:not(.dark) .nv-sb-pin-btn {
    border-color: var(--border);
    background: transparent;
    color: var(--muted);
  }

  .nv-sb-pin-btn:hover {
    background: rgba(255, 255, 255, 0.10);
    border-color: rgba(255, 255, 255, 0.22);
    color: var(--text);
  }

  /* --- Nav scroll area --- */
  .nv-sb-nav {
    padding: 8px;
    overflow-y: auto;
    flex: 1 1 auto;
    min-height: 0;
    scrollbar-width: none;
  }

  .nv-sb-nav::-webkit-scrollbar { display: none; }

  /* --- Group / section labels --- */
  .nv-sb-group-label {
    padding: 14px 8px 4px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.13em;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.38);
    user-select: none;
    white-space: nowrap;
    overflow: hidden;
  }

  html:not(.dark) .nv-sb-group-label {
    color: var(--muted);
    opacity: 0.55;
  }

  /* --- Top-level nav items --- */
  .nv-sb-item {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    padding: 7px 9px;
    border-radius: 10px;
    border: 1px solid transparent;
    text-decoration: none;
    color: var(--text);
    font-size: 14.5px;
    font-weight: 600;
    background: transparent;
    cursor: pointer;
    transition: background 0.16s ease,
                border-color 0.16s ease,
                color 0.16s ease,
                box-shadow 0.16s ease;
    white-space: nowrap;
    overflow: hidden;
    margin-bottom: 2px;
    letter-spacing: 0.01em;
  }

  html.dark .nv-sb-item {
    color: rgba(255, 255, 255, 0.45);
    background: transparent;
    border-color: transparent;
  }

  .nv-sb-item:hover {
    background: rgba(255, 255, 255, 0.07);
    border-color: rgba(255, 255, 255, 0.18);
    color: rgba(255, 255, 255, 0.90);
    box-shadow: none;
  }

  html:not(.dark) .nv-sb-item:hover {
    background: rgba(0, 0, 0, 0.05);
    border-color: rgba(0, 0, 0, 0.18);
    color: var(--text);
    box-shadow: none;
  }

  .nv-sb-item.is-active {
    background: #AC4314;
    border-color: #AC4314;
    color: #FFFFFF;
    box-shadow: none;
  }

  html:not(.dark) .nv-sb-item.is-active {
    background: #AC4314;
    border-color: #AC4314;
    color: #FFFFFF;
  }

  /* --- Icon container --- */
  .nv-sb-ico {
    width: 36px;
    height: 36px;
    border-radius: 8px;
    border: none;
    background: transparent;
    color: var(--muted);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: color 0.16s ease,
                transform 0.18s cubic-bezier(0.34, 1.56, 0.64, 1);
  }

  .nv-sb-ico svg {
    stroke-width: 2.5;
  }

  .nv-sb-item:hover .nv-sb-ico {
    color: var(--text);
    transform: scale(1.12);
  }

  .nv-sb-item.is-active .nv-sb-ico {
    color: #FFFFFF;
  }

  html:not(.dark) .nv-sb-item.is-active .nv-sb-ico {
    color: #FFFFFF;
  }

  /* --- Label text --- */
  .nv-sb-text {
    flex: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  /* --- Chevron --- */
  .nv-sb-chevron {
    flex-shrink: 0;
    color: rgba(255, 255, 255, 0.40);
    transition: transform 0.22s ease;
    margin-left: auto;
    display: inline-flex;
  }

  html:not(.dark) .nv-sb-chevron {
    color: var(--muted);
    opacity: 0.6;
  }

  .nv-sb-chevron.nv-chevron-open {
    transform: rotate(180deg);
  }

  /* --- Non-interactive section headers → compact group labels --- */
  div.nv-sb-section-header {
    min-height: 0 !important;
    height: auto !important;
    padding: 18px 10px 5px !important;
    background: transparent !important;
    border-color: transparent !important;
    box-shadow: none !important;
    cursor: default !important;
    opacity: 1;
    font-size: 10px !important;
    font-weight: 700 !important;
    letter-spacing: 0.14em !important;
    text-transform: uppercase;
    color: rgba(255, 255, 255, 0.28) !important;
    margin-bottom: 0;
  }

  html:not(.dark) div.nv-sb-section-header {
    color: rgba(0, 0, 0, 0.28) !important;
  }

  div.nv-sb-section-header:hover {
    background: transparent !important;
    border-color: transparent !important;
    box-shadow: none !important;
    color: rgba(255, 255, 255, 0.28) !important;
  }

  div.nv-sb-section-header .nv-sb-ico {
    display: none;
  }

  /* Hide group labels in collapsed mode — only icons remain */
  .nv-sb-collapsed div.nv-sb-section-header {
    display: none;
  }

  /* Clickable section headers (e.g. Portfolio link) keep full nav-item look */
  a.nv-sb-section-header {
    cursor: pointer;
    opacity: 1;
  }

  a.nv-sb-section-header:hover {
    background: rgba(255, 255, 255, 0.07);
    border-color: rgba(255, 255, 255, 0.18);
    color: rgba(255, 255, 255, 0.90);
    box-shadow: none;
  }

  a.nv-sb-section-header:hover .nv-sb-ico {
    color: var(--text);
    transform: scale(1.12);
  }

  html:not(.dark) a.nv-sb-section-header:hover {
    background: rgba(0, 0, 0, 0.05);
    border-color: rgba(0, 0, 0, 0.18);
    color: var(--text);
    box-shadow: none;
  }

  /* --- Submenu container --- */
  .nv-sb-submenu {
    margin: 2px 0 6px 12px;
    padding-left: 10px;
    border-left: 1px solid rgba(255, 255, 255, 0.08);
  }

  html:not(.dark) .nv-sb-submenu {
    border-left-color: rgba(0, 0, 0, 0.10);
  }
  html.dark .nv-sb-submenu {
    border-left-color: var(--sidebar-border, var(--border));
  }

  /* --- Submenu items --- */
  .nv-sb-sub {
    display: flex;
    align-items: center;
    gap: 7px;
    padding: 6px 9px;
    border-radius: 8px;
    text-decoration: none;
    color: rgba(255, 255, 255, 0.32);
    font-size: 13.5px;
    font-weight: 500;
    border: 1px solid transparent;
    margin-bottom: 1px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    transition: background 0.14s ease, color 0.14s ease, border-color 0.14s ease;
  }

  html:not(.dark) .nv-sb-sub {
    color: rgba(0, 0, 0, 0.32);
  }

  .nv-sb-sub:hover {
    background: rgba(255, 255, 255, 0.07);
    border-color: rgba(255, 255, 255, 0.12);
    color: rgba(255, 255, 255, 0.80);
  }

  html:not(.dark) .nv-sb-sub:hover {
    background: rgba(0, 0, 0, 0.05);
    border-color: rgba(0, 0, 0, 0.10);
    color: rgba(0, 0, 0, 0.70);
  }

  .nv-sb-sub.is-active {
    background: rgba(var(--accent-rgb), 0.15);
    border-color: rgba(var(--accent-rgb), 0.40);
    color: var(--accent-hover);
    font-weight: 600;
  }

  html:not(.dark) .nv-sb-sub.is-active {
    background: rgba(var(--accent-rgb), 0.10);
    border-color: rgba(var(--accent-rgb), 0.30);
    color: var(--accent);
  }

  /* --- Footer --- */
  .nv-sb-footer {
    padding: 10px;
    border-top: 1px solid rgba(255, 255, 255, 0.07);
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-shrink: 0;
    gap: 8px;
  }

  html:not(.dark) .nv-sb-footer {
    border-top-color: var(--border);
  }
  html.dark .nv-sb-footer {
    border-top-color: var(--sidebar-border, var(--border));
  }

  .nv-sb-version {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 11px;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.35);
    white-space: nowrap;
    overflow: hidden;
  }

  html:not(.dark) .nv-sb-version {
    color: var(--muted);
    opacity: 0.6;
  }

  .nv-sb-theme-btn {
    width: 32px;
    height: 32px;
    border-radius: 8px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    background: rgba(255, 255, 255, 0.06);
    color: var(--muted);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    flex-shrink: 0;
    transition: background 0.14s, color 0.14s, border-color 0.14s;
  }

  html:not(.dark) .nv-sb-theme-btn {
    border-color: var(--border);
    background: transparent;
    color: var(--muted);
  }

  .nv-sb-theme-btn:hover {
    background: rgba(255, 255, 255, 0.10);
    border-color: rgba(255, 255, 255, 0.22);
    color: var(--text);
  }

  .nv-sb-signout-form {
    flex: 1;
    min-width: 0;
  }

  .nv-sb-signout-btn {
    width: 100%;
    height: 32px;
    border-radius: 8px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    background: rgba(255, 255, 255, 0.06);
    color: var(--muted);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    cursor: pointer;
    transition: background 0.14s, color 0.14s, border-color 0.14s;
    white-space: nowrap;
  }

  .nv-sb-signout-btn .navira-ico-wrap {
    flex-shrink: 0;
  }

  .nv-sb-signout-text {
    font-size: 12px;
    font-weight: 600;
  }

  html:not(.dark) .nv-sb-signout-btn {
    border-color: var(--border);
    background: transparent;
    color: var(--muted);
  }

  .nv-sb-signout-btn:hover {
    background: rgba(255, 255, 255, 0.10);
    border-color: rgba(255, 255, 255, 0.22);
    color: var(--text);
  }

  .nv-sb-collapsed .nv-sb-signout-form {
    flex: 0 0 auto;
  }

  .nv-sb-collapsed .nv-sb-signout-btn {
    width: 32px;
    padding: 0;
    gap: 0;
  }

  /* ======================================================
     Tab Navigation  —  global canonical style
     All pages use these classes; per-page overrides allowed
     ====================================================== */

  /* ── Container — pill row, no separator ── */
  .navira-tabs {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    padding: 0 0 12px;
    background: transparent;
    border: none;
    margin-bottom: 14px;
    position: relative;
  }

  .navira-tabs::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 1px;
    background: var(--border);
    opacity: 0.95;
  }

  html:not(.dark) .navira-tabs {
    border-bottom: none;
  }

  /* ── Tab button — neutral ghost (inactive) ── */
  .navira-tab-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 20px;
    border-radius: 10px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    background: rgba(255, 255, 255, 0.06);
    color: rgba(255, 255, 255, 0.50);
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 0.01em;
    cursor: pointer;
    margin-bottom: 0;
    transition: color 150ms ease, background 150ms ease,
                border-color 150ms ease, transform 200ms cubic-bezier(0.34, 1.56, 0.64, 1);
    white-space: nowrap;
    transform: translateY(0);
    position: relative;
    z-index: 1;
  }

  html:not(.dark) .navira-tab-btn {
    border-color: rgba(0, 0, 0, 0.14);
    background: rgba(0, 0, 0, 0.04);
    color: rgba(0, 0, 0, 0.50);
  }

  /* Icon dim on inactive */
  .navira-tab-btn .navira-ico-wrap {
    opacity: 0.70;
    width: 18px !important;
    height: 18px !important;
    transition: opacity 150ms ease, color 150ms ease,
                transform 200ms cubic-bezier(0.34, 1.56, 0.64, 1);
  }

  /* ── Hover (inactive only) ── */
  .navira-tab-btn:hover:not(.disabled):not(.active) {
    color: rgba(255, 255, 255, 0.88);
    background: rgba(255, 255, 255, 0.10);
    border-color: rgba(255, 255, 255, 0.22);
    transform: translateY(-1px);
  }

  .navira-tab-btn:hover:not(.disabled):not(.active) .navira-ico-wrap {
    opacity: 1;
    transform: scale(1.10);
  }

  html:not(.dark) .navira-tab-btn:hover:not(.disabled):not(.active) {
    color: rgba(0, 0, 0, 0.80);
    background: rgba(0, 0, 0, 0.08);
    border-color: rgba(0, 0, 0, 0.22);
    transform: translateY(-1px);
  }

  /* ── Active tab — coral pill ── */
  .navira-tab-btn.active {
    color: #FFFFFF;
    background: #AC4314;
    border-color: #AC4314;
    text-shadow: none;
  }

  .navira-tab-btn.active::after {
    content: "";
    position: absolute;
    left: 14px;
    right: 14px;
    bottom: -13px;
    height: 3px;
    border-radius: 999px;
    background: #AC4314;
  }

  .navira-tab-btn.active .navira-ico-wrap {
    opacity: 1;
    color: #FFFFFF;
  }

  html:not(.dark) .navira-tab-btn.active {
    color: #FFFFFF;
    background: #AC4314;
    border-color: #AC4314;
  }

  html:not(.dark) .navira-tab-btn.active .navira-ico-wrap {
    color: #FFFFFF;
  }

  /* ── Disabled ── */
  .navira-tab-btn.disabled {
    opacity: 0.35;
    cursor: not-allowed;
    pointer-events: none;
  }

  /* ── Panel visibility ── */
  .navira-tab-panel {
    display: block;
  }

  .navira-tab-panel.hidden {
    display: none;
  }

  /* ── Secondary subtab strip ── */
  .navira-subtabs {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    margin: 8px 0 4px;
  }

  .navira-subtab-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 13px;
    border-radius: 10px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    background: rgba(255, 255, 255, 0.06);
    color: rgba(255, 255, 255, 0.50);
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
    transition: color 140ms ease, background 140ms ease, border-color 140ms ease;
    white-space: nowrap;
  }

  html:not(.dark) .navira-subtab-btn {
    border-color: rgba(0, 0, 0, 0.14);
    background: rgba(0, 0, 0, 0.04);
    color: rgba(0, 0, 0, 0.50);
  }

  .navira-subtab-btn:hover {
    color: rgba(255, 255, 255, 0.88);
    background: rgba(255, 255, 255, 0.10);
    border-color: rgba(255, 255, 255, 0.22);
  }

  html:not(.dark) .navira-subtab-btn:hover {
    color: rgba(0, 0, 0, 0.80);
    background: rgba(0, 0, 0, 0.08);
    border-color: rgba(0, 0, 0, 0.22);
  }

  .navira-subtab-btn.active {
    color: #FFFFFF;
    background: #AC4314;
    border-color: #AC4314;
  }

  html:not(.dark) .navira-subtab-btn.active {
    color: #FFFFFF;
    background: #AC4314;
    border-color: #AC4314;
  }

  /* ── Small inline filter toggle variant ── */
  .navira-tabs-sm {
    display: inline-flex;
    gap: 3px;
    padding: 3px;
    border-radius: 9px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.07);
  }

  html:not(.dark) .navira-tabs-sm {
    background: var(--surface);
    border: 1px solid var(--border);
  }

  .navira-tab-btn-sm {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 4px 10px;
    border-radius: 7px;
    border: 1px solid rgba(var(--accent-rgb), 0.45);
    background: rgba(var(--accent-rgb), 0.18);
    color: var(--accent-hover);
    font-size: 11px;
    font-weight: 600;
    cursor: pointer;
    transition: color 140ms ease, background 140ms ease, border-color 140ms ease;
    white-space: nowrap;
  }

  html:not(.dark) .navira-tab-btn-sm {
    border-color: rgba(var(--accent-rgb), 0.40);
    background: rgba(var(--accent-rgb), 0.14);
    color: var(--accent);
  }

  .navira-tab-btn-sm:hover:not(.active) {
    color: #FFFFFF;
    background: rgba(var(--accent-rgb), 0.28);
    border-color: rgba(var(--accent-rgb), 0.65);
  }

  html:not(.dark) .navira-tab-btn-sm:hover:not(.active) {
    color: var(--accent);
    background: rgba(var(--accent-rgb), 0.22);
    border-color: rgba(var(--accent-rgb), 0.60);
  }

  .navira-tab-btn-sm.active {
    color: #FFFFFF;
    background: #AC4314;
    border-color: #AC4314;
  }

  html:not(.dark) .navira-tab-btn-sm.active {
    color: #FFFFFF;
    background: #AC4314;
    border-color: #AC4314;
  }

  html.dark {
    --navira-white-soft: #e6eaf1;
  }

  html.dark :is(
    .navira-tab-btn.active,
    .navira-tab-btn.active .navira-ico-wrap,
    .navira-subtab-btn.active,
    .navira-tab-btn-sm.active,
    .navira-tab-btn-sm:hover:not(.active)
  ) {
    color: var(--navira-white-soft) !important;
  }
