/* ═══════════════════════════════════════════════════════
   JA GREEN PULSE — DARK DESIGN SYSTEM
   ═══════════════════════════════════════════════════════ */
:root {
  --bg:           #0f1525;
  --bg-soft:      #162035;
  --panel:        #162035;
  --panel-2:      #1e2d50;
  --panel-3:      #233260;
  --line:         rgba(255,255,255,.13);
  --line-2:       rgba(255,255,255,.22);
  --text:         #edf1ff;
  --muted:        #b8c4e0;
  --gold:         #d9b75f;
  --gold-soft:    rgba(217,183,95,.18);
  --gold-brd:     rgba(217,183,95,.38);
  --blue:         #70a0ff;
  --green:        #43c59e;
  --red:          #ff7b7b;
  --amber:        #ffbf5f;
  --shadow:       0 20px 50px rgba(0,0,0,.32);
  --radius:       20px;
  --navy:         #1a2744;
  --mid:          #2E5496;
  --sub:          #8a9bbf;
  --border:       #C8D6ED;
}
*{box-sizing:border-box;margin:0;padding:0}
html{min-height:100%}body{min-height:100%;background:radial-gradient(circle at top,#1a2d55 0%,#0f1525 50%,#0b1020 100%);color:var(--text);font-family:Inter,sans-serif;font-size:14px}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font:inherit;box-sizing:border-box}

/* ── TOP BAR ── */
.topbar{position:sticky;top:0;z-index:200;backdrop-filter:blur(18px);background:rgba(10,16,31,.92);border-bottom:1px solid var(--line)}
.topbar-inner{max-width:1440px;margin:0 auto;padding:10px 24px;display:flex;justify-content:space-between;align-items:center;gap:20px;min-height:54px}
.topbar-brand{display:flex;align-items:center;gap:14px;flex-shrink:0}
.topbar-logo{height:34px;width:auto;display:block;flex-shrink:0;object-fit:contain}
.topbar-text{display:flex;flex-direction:column;justify-content:center;gap:0}
.brand-title{font-family:Manrope,sans-serif;font-weight:800;font-size:1.1rem;letter-spacing:-.03em;color:#fff;line-height:1.2}
.brand-sub{color:var(--muted);font-size:.72rem;line-height:1.3;margin-top:2px}
.topbar-chips{display:flex;gap:6px;align-items:center;flex-wrap:nowrap;flex-shrink:0}
.mini-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 11px;border:1px solid var(--line);background:rgba(255,255,255,.06);border-radius:999px;color:var(--muted);font-size:.7rem;white-space:nowrap}
.mini-chip strong{color:var(--gold);font-family:'DM Mono',monospace;font-weight:600;font-size:.75rem}

/* ── TAB NAV ── */
.tab-nav{background:rgba(10,16,31,.9);border-bottom:2px solid var(--gold);padding:0 24px;display:flex;align-items:flex-end;gap:0;height:42px;position:sticky;top:54px;z-index:190}
.tab-nav a{display:inline-flex;align-items:center;height:42px;padding:0 18px;font-family:'DM Mono',monospace;font-size:9px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.65);border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s;white-space:nowrap;cursor:pointer}
.tab-nav a:hover{color:rgba(255,255,255,.9);border-bottom-color:rgba(217,183,95,.55)}
.tab-nav a.active{color:var(--gold);border-bottom-color:var(--gold)}
.tab-nav-badge{display:inline-flex;align-items:center;justify-content:center;margin-left:6px;min-width:16px;height:16px;padding:0 5px;border-radius:8px;background:var(--gold);color:#0f1525;font-family:'DM Mono',monospace;font-size:8px;font-weight:800;line-height:1;vertical-align:middle}

/* ── MAIN SHELL ── */
.app-shell{display:flex;min-height:calc(100vh - 99px)}

/* ── LEFT SIDEBAR (Solicitations) ── */
.left-nav{width:240px;flex-shrink:0;background:linear-gradient(180deg,rgba(22,32,60,.99),rgba(15,21,37,.99));position:sticky;top:99px;height:calc(100vh - 99px);overflow-y:auto;overflow-x:hidden;border-right:1px solid var(--line);scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.15) transparent}
.left-nav::-webkit-scrollbar{width:3px}
.left-nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:2px}
.nav-section-label{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.24em;text-transform:uppercase;color:rgba(217,183,95,.75);padding:18px 14px 8px;border-bottom:1px solid var(--line)}
.sector-nav-item{display:flex;align-items:center;gap:10px;padding:0 14px 0 12px;height:48px;cursor:pointer;border-left:3px solid transparent;transition:all .18s;position:relative}
.sector-nav-item:hover{background:rgba(217,183,95,.09);border-left-color:rgba(217,183,95,.4)}
.sector-nav-item.active{background:linear-gradient(90deg,rgba(217,183,95,.18),rgba(217,183,95,.04));border-left-color:var(--gold)}
.nav-icon{width:30px;height:30px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;border:1px solid rgba(255,255,255,.15);box-shadow:0 1px 4px rgba(0,0,0,.3)}
.nav-label-wrap{flex:1;min-width:0}
.nav-label{font-size:11px;font-weight:600;color:rgba(237,241,255,.65);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2}
.sector-nav-item.active .nav-label{color:var(--gold)}
.sector-nav-item:hover .nav-label{color:#fff}
.nav-count{font-family:'DM Mono',monospace;font-size:9px;font-weight:500;color:rgba(255,255,255,.5);background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);border-radius:10px;padding:1px 7px;min-width:20px;text-align:center}
.sector-nav-item.active .nav-count{color:var(--gold);background:var(--gold-soft);border-color:var(--gold-brd)}

/* ── MAIN CONTENT ── */
.main-content{flex:1;min-width:0;padding:28px 28px 64px}
.sector-panel{display:none}
.sector-panel.active{display:block;animation:fadeIn .2s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}

/* ── SOL SECTOR HEADER ── */
.sector-page-header{display:flex;align-items:center;gap:16px;margin-bottom:24px;padding:18px 20px;background:rgba(255,255,255,.07);border:1px solid var(--line);border-left:3px solid var(--gold);border-radius:8px}
.sector-page-icon{width:48px;height:48px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;border:1px solid rgba(255,255,255,.1);box-shadow:0 2px 8px rgba(0,0,0,.25)}
.sector-page-title{font-family:Manrope,sans-serif;font-size:1.4rem;font-weight:800;color:#fff;letter-spacing:-.03em}
.sector-page-desc{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.08em;color:rgba(255,255,255,.75);margin-top:4px}
.sector-page-badge{margin-left:auto;text-align:right;flex-shrink:0}
.sector-page-badge-count{font-family:Manrope,sans-serif;font-size:2.2rem;font-weight:800;color:var(--gold);line-height:1}
.sector-page-badge-label{font-family:'DM Mono',monospace;font-size:7px;letter-spacing:.18em;color:rgba(255,255,255,.75);text-transform:uppercase;margin-top:2px}

/* ── SOL CARDS ── */
.sol-grid{display:flex;flex-direction:column;gap:14px}
.sol-card{background:linear-gradient(180deg,rgba(22,32,58,.98),rgba(16,22,40,1));border:1px solid var(--line);border-left:3px solid rgba(112,160,255,.5);border-radius:10px;overflow:hidden;transition:box-shadow .2s,border-left-color .2s,transform .2s}
.sol-card:hover{box-shadow:0 4px 24px rgba(0,0,0,.4);border-left-color:var(--gold);transform:translateY(-1px)}
.sol-card-manual{border-left-color:rgba(46,160,67,.5)}
.sol-card-manual:hover{border-left-color:#3fb950}
.sol-card-header{padding:16px 20px 12px;display:flex;align-items:flex-start;justify-content:space-between;gap:12px;background:rgba(255,255,255,.05);border-bottom:1px solid var(--line)}
.sol-manual-delete-btn{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.1em;text-transform:uppercase;padding:4px 9px;border:1px solid rgba(255,80,80,.35);border-radius:4px;background:rgba(255,80,80,.1);color:rgba(255,130,130,.9);cursor:pointer;white-space:nowrap;transition:background .15s,border-color .15s}
.sol-manual-delete-btn:hover{background:rgba(255,80,80,.25);border-color:rgba(255,80,80,.6)}
.sol-title-group{flex:1;min-width:0}
.sol-type-tag{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-bottom:5px;display:flex;align-items:center;gap:6px}
.sol-type-tag::before{content:'';display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--gold);flex-shrink:0}
.sol-title{font-family:Manrope,sans-serif;font-size:1.05rem;font-weight:700;color:#fff;line-height:1.25;letter-spacing:-.02em}
.sol-actions{display:flex;align-items:flex-start;gap:6px;flex-shrink:0;flex-wrap:wrap;justify-content:flex-end;padding-top:2px}
.tech-meta-strip{display:flex;flex-wrap:wrap;gap:5px;padding:9px 20px 10px;background:rgba(255,255,255,.04);border-bottom:1px solid var(--line)}
.tm-chip{display:inline-flex;align-items:baseline;gap:4px;padding:3px 8px;border-radius:4px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.08);white-space:nowrap}
.tm-lbl{font-family:'DM Mono',monospace;font-size:7px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.6);flex-shrink:0}
.tm-val{font-family:'DM Mono',monospace;font-size:9px;font-weight:600;color:#fff}
.tm-chip.gold{background:var(--gold-soft);border-color:var(--gold-brd)}.tm-chip.gold .tm-val{color:var(--gold)}
.tm-chip.red{background:rgba(255,123,123,.12);border-color:rgba(255,123,123,.35)}.tm-chip.red .tm-val{color:#ffaaaa}
.tm-chip.green{background:rgba(67,197,158,.12);border-color:rgba(67,197,158,.35)}.tm-chip.green .tm-val{color:#6ee7c7}
.sol-body{padding:14px 20px}
.sol-summary{font-size:.9rem;line-height:1.75;color:var(--text)}

/* Action buttons in cards */
.sol-link,.send-btn,.save-btn,.delete-btn{display:inline-flex;align-items:center;gap:5px;font-family:'DM Mono',monospace;font-size:9px;letter-spacing:.05em;padding:5px 10px;border-radius:4px;flex-shrink:0;cursor:pointer;transition:all .15s;white-space:nowrap;border:1px solid}
.sol-link{color:var(--gold);border-color:var(--gold-brd);background:transparent}.sol-link:hover{background:var(--gold);color:#141414}
.send-btn{color:#fff;background:rgba(112,160,255,.2);border-color:rgba(112,160,255,.35)}.send-btn:hover{background:var(--blue);border-color:var(--blue);color:#141414}
.save-btn{color:#fff;background:rgba(67,197,158,.2);border-color:rgba(67,197,158,.3)}.save-btn:hover{background:var(--green);border-color:var(--green);color:#141414}
.save-btn.saved{background:var(--gold-soft);border-color:var(--gold-brd);color:var(--gold)}
.delete-btn{color:var(--red);background:rgba(255,123,123,.1);border-color:rgba(255,123,123,.25)}.delete-btn:hover{background:var(--red);border-color:var(--red);color:#141414}
.add-to-rt-btn{color:#fff;background:rgba(217,183,95,.2);border-color:var(--gold-brd);border:1px solid;padding:5px 10px;border-radius:4px;font-family:'DM Mono',monospace;font-size:9px;letter-spacing:.05em;cursor:pointer;transition:all .15s;white-space:nowrap;display:inline-flex;align-items:center;gap:5px}
.add-to-rt-btn:hover{background:var(--gold);color:#141414}
.add-to-rt-btn.in-rt{background:rgba(67,197,158,.15);border-color:rgba(67,197,158,.3);color:var(--green)}

/* ── Bid / No Bid buttons on Solicitation Dashboard ── */
.bid-btn{color:#fff;background:rgba(67,197,158,.2);border:1px solid rgba(67,197,158,.4);padding:5px 12px;border-radius:4px;font-family:'DM Mono',monospace;font-size:9px;font-weight:600;letter-spacing:.06em;cursor:pointer;transition:all .15s;white-space:nowrap;display:inline-flex;align-items:center;gap:5px}
.bid-btn:hover{background:#43c59e;color:#0f1525;border-color:#43c59e}
.nobid-btn{color:#fff;background:rgba(255,123,123,.18);border:1px solid rgba(255,123,123,.35);padding:5px 12px;border-radius:4px;font-family:'DM Mono',monospace;font-size:9px;font-weight:600;letter-spacing:.06em;cursor:pointer;transition:all .15s;white-space:nowrap;display:inline-flex;align-items:center;gap:5px}
.nobid-btn:hover{background:#ff7b7b;color:#0f1525;border-color:#ff7b7b}

/* ── Queue Tab ── */
.queue-topbar{background:rgba(10,16,31,.85);border-bottom:1px solid var(--line);padding:16px 24px 0;position:sticky;top:96px;z-index:100;backdrop-filter:blur(12px)}
.queue-topbar-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-bottom:12px}
.queue-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.queue-archive-label{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--muted);cursor:pointer;white-space:nowrap}
.queue-archive-label input{accent-color:var(--gold)}
.queue-undo-btn{font-size:10px;font-weight:700;font-family:'DM Mono',monospace;background:rgba(217,183,95,.12);border:1px solid rgba(217,183,95,.4);color:var(--gold);border-radius:4px;padding:4px 10px;cursor:pointer;transition:background .15s,border-color .15s;white-space:nowrap}
.queue-undo-btn:hover{background:rgba(217,183,95,.22);border-color:var(--gold)}
.queue-card{background:linear-gradient(180deg,rgba(22,32,58,.98),rgba(16,22,40,1));border:1px solid var(--line);border-left:3px solid rgba(67,197,158,.5);border-radius:10px;padding:16px 20px;margin-bottom:12px;transition:box-shadow .2s,border-left-color .2s}
.queue-card:hover{box-shadow:0 4px 24px rgba(0,0,0,.4);border-left-color:var(--green)}
.queue-card-archived{border-left-color:rgba(255,123,123,.4);opacity:.8}
.queue-card-archived:hover{border-left-color:#ff7b7b}
.queue-card-hd{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:8px}
.queue-card-title{font-size:13px;font-weight:600;color:var(--text);line-height:1.4;flex:1}
.queue-card-title-link{font-size:13px;font-weight:600;color:var(--blue);line-height:1.4;flex:1;text-decoration:none;cursor:pointer}
.queue-card-title-link:hover{color:#fff;text-decoration:underline;text-underline-offset:3px}
.queue-archive-badge{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.08em;font-weight:700;color:#ff7b7b;background:rgba(255,123,123,.12);border:1px solid rgba(255,123,123,.3);border-radius:3px;padding:2px 6px;white-space:nowrap;flex-shrink:0}
.queue-card-clients{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:8px}
.queue-client-chip{font-family:'DM Mono',monospace;font-size:9px;background:rgba(112,160,255,.15);border:1px solid rgba(112,160,255,.3);color:var(--blue);border-radius:4px;padding:2px 7px}
.queue-card-comment{font-size:11px;color:var(--muted);font-style:italic;margin-bottom:8px;line-height:1.5;border-left:2px solid var(--line);padding-left:8px}
.queue-card-summary{font-size:11.5px;color:var(--muted);line-height:1.6;margin-bottom:8px;padding:8px 10px;background:rgba(255,255,255,.03);border-radius:6px;border:1px solid var(--line)}
.queue-staff{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:10px}
.queue-staff-pip{width:26px;height:26px;border-radius:50%;background:var(--mid);display:inline-flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:#fff;cursor:default;font-family:'DM Mono',monospace}
.queue-staff-more{font-size:9px;color:var(--muted);padding:6px 2px;font-family:'DM Mono',monospace}
.queue-card-footer{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-top:4px}
.queue-card-by{font-size:10px;color:var(--muted);font-family:'DM Mono',monospace}
.queue-card-actions{display:flex;gap:6px;align-items:center}
.queue-dismiss-btn{font-size:10px;font-weight:600;font-family:'DM Mono',monospace;background:transparent;border:1px solid rgba(255,123,123,.35);color:rgba(255,123,123,.8);border-radius:4px;padding:4px 9px;cursor:pointer;transition:background .15s,color .15s,border-color .15s;margin-left:auto}
.queue-dismiss-btn:hover{background:rgba(255,123,123,.12);color:#ff7b7b;border-color:#ff7b7b}
.queue-main{flex:1;min-width:0}
.queue-nav-icon{background:#2a3a6e;font-family:'DM Mono',monospace;font-size:10px;font-weight:700;letter-spacing:0}

/* ── NEWS UPDATES ── */
.news-page{display:block;min-height:calc(100vh - 99px);padding:0;background:transparent}
/* Jump bar — sticky pill-button sector navigator */
.news-jump-bar{position:sticky;top:99px;z-index:80;display:flex;align-items:center;gap:6px;padding:8px 24px;background:rgba(10,16,31,.96);border-bottom:1px solid var(--line);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);overflow-x:auto;scrollbar-width:none}
.news-jump-bar::-webkit-scrollbar{display:none}
.news-jump-btn{display:inline-flex;align-items:center;gap:4px;padding:5px 13px;border-radius:20px;border:1px solid var(--line);background:transparent;color:var(--muted);font-family:'DM Mono',monospace;font-size:9px;font-weight:600;letter-spacing:.09em;text-transform:uppercase;cursor:pointer;transition:all .15s;white-space:nowrap;flex-shrink:0}
.news-jump-btn:hover{background:rgba(217,183,95,.12);border-color:rgba(217,183,95,.4);color:var(--gold)}
.news-jump-btn.nj-active{background:rgba(217,183,95,.18);border-color:var(--gold);color:var(--gold)}
.news-jump-btn.nj-admin{border-color:rgba(212,160,23,.35);color:#d4a017}
.news-jump-btn.nj-admin:hover,.news-jump-btn.nj-admin.nj-active{background:rgba(212,160,23,.18);border-color:#d4a017;color:#d4a017}
.news-jump-count{font-size:8px;opacity:.75}
/* Single scrollable content area */
.news-main-content{max-width:1440px;margin:0 auto;padding:32px 20px 80px}
/* ── Two-column editorial layout: unified magazine grid + Inside Defense sidebar ── */
.news-editorial-wrap{display:grid;grid-template-columns:1fr 270px;gap:22px;align-items:start}
@media(max-width:960px){.news-editorial-wrap{grid-template-columns:1fr}}
/* Inside Defense sidebar — far right, headline-only links */
.news-inside-defense-sidebar{position:sticky;top:120px;border-left:2px solid var(--gold-brd);padding-left:14px;max-height:calc(100vh - 140px);overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(217,183,95,.3) transparent}
.news-id-heading{font-family:'DM Mono',monospace;font-size:.65rem;font-weight:700;color:var(--gold);letter-spacing:.15em;text-transform:uppercase;margin-bottom:10px}
.news-id-empty{font-size:.75rem;color:var(--muted);font-style:italic}
.news-id-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:16px}
.news-id-item{padding:5px 0 16px 10px;border-bottom:1px solid rgba(255,255,255,.07);border-left:2px solid rgba(217,183,95,.22)}
.news-id-item:last-child{border-bottom:none;padding-bottom:0}
.news-id-link{display:block;font-family:Manrope,sans-serif;font-size:.8rem;font-weight:600;color:#dde6f5;line-height:1.38;text-decoration:none;transition:color .15s}
.news-id-link:hover{color:var(--gold)}
.news-id-meta{display:flex;gap:6px;margin-top:3px;font-family:'DM Mono',monospace;font-size:7px;letter-spacing:.08em;text-transform:uppercase}
.news-id-topic{color:var(--gold);opacity:.8}
.news-id-date{color:var(--muted)}
@media(max-width:960px){.news-inside-defense-sidebar{position:static;border-left:none;border-top:1px solid var(--gold-brd);padding-left:0;padding-top:12px;max-height:none;overflow-y:visible}}
/* Per-sector sections (kept for admin curation panels) */
.news-sector-section{margin-bottom:10px}
/* Thin top-rule between consecutive sectors creates a newspaper-page-flow feel
   without hard page breaks between sections. The first child gets no top rule. */
.news-sector-section+.news-sector-section{padding-top:10px;border-top:1px solid rgba(255,255,255,.06)}
/* Sector header: thin inline label with a fading gold rule extending to the right.
   Replaces the heavy banner card so sectors feel inlaid rather than page-broken. */
.news-sector-section-header{display:flex;align-items:center;gap:10px;margin-bottom:10px;padding:0;background:transparent;border:none;border-left:none;border-radius:0}
.news-sector-section-header::after{content:'';flex:1;height:1px;background:linear-gradient(to right,rgba(217,183,95,.3),transparent)}
.news-sector-icon{width:22px;height:22px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;border:none;box-shadow:none}
.news-sector-title{font-family:'DM Mono',monospace;font-size:.65rem;font-weight:700;color:var(--gold);letter-spacing:.15em;text-transform:uppercase;white-space:nowrap}
.news-sector-badge{margin-left:0;margin-right:8px;font-family:'DM Mono',monospace;font-size:.6rem;color:var(--muted);background:transparent;border:none;border-radius:0;padding:0;letter-spacing:.05em;flex-shrink:0}
/* Admin section header stays visually distinct — preserve a subtle tinted box */
.nc-admin-section-header{background:rgba(122,92,0,.15);border:1px solid rgba(212,160,23,.22);border-radius:6px;padding:8px 14px}
.nc-admin-section-header::after{display:none}
.nc-admin-section-header .news-sector-title{color:#d4a017;font-family:Manrope,sans-serif;font-size:.75rem;font-weight:800;letter-spacing:-.01em;text-transform:none}
.news-sector-summary{margin:-8px 0 20px;color:var(--text);font-size:.875rem;line-height:1.7;max-width:900px}
.news-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}
.news-card{background:linear-gradient(180deg,rgba(22,32,58,.98),rgba(16,22,40,1));border:1px solid var(--line);border-top:3px solid var(--gold);border-radius:10px;padding:16px 16px 14px;box-shadow:var(--shadow);transition:transform .18s,box-shadow .18s}
.news-card:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,0,0,.4)}
.news-card-kicker{display:flex;justify-content:space-between;gap:12px;margin-bottom:10px;font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.news-card-topic{color:var(--gold)}
.news-card-title a{font-family:Manrope,sans-serif;font-size:1.05rem;font-weight:700;color:#fff;line-height:1.2;display:block}
.news-card-title a:hover{color:var(--gold)}
.news-card-preview{margin-top:10px;color:var(--text);font-size:.875rem;line-height:1.7}
.news-card-footer{margin-top:12px;display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap}
.news-card-source{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.news-card-action{display:inline-flex;align-items:center;gap:4px;text-decoration:none;border:1px solid var(--gold-brd);color:var(--gold);padding:5px 9px;border-radius:4px;font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.06em;text-transform:uppercase;transition:all .15s}
.news-card-action:hover{background:var(--gold);color:#141414}
.news-card-delete-btn{display:inline-flex;align-items:center;gap:4px;font-family:'DM Mono',monospace;font-size:9px;letter-spacing:.05em;padding:5px 9px;border-radius:4px;border:1px solid rgba(255,123,123,.35);background:rgba(255,123,123,.12);color:#ff7b7b;cursor:pointer;transition:all .15s}
.news-card-delete-btn:hover{background:#ff7b7b;border-color:#ff7b7b;color:#141414}
.news-card-footer-actions{display:flex;gap:6px;align-items:center}
.news-grid.drag-over-grid{outline:2px dashed var(--gold);outline-offset:4px;border-radius:8px;background:rgba(217,183,95,.05)}
article.news-card[draggable="true"]{cursor:grab}
article.news-card[draggable="true"]:active{cursor:grabbing}
.news-updates-note{margin:-4px 0 20px;padding:11px 14px;background:rgba(255,255,255,.06);border:1px solid var(--line);border-radius:6px;color:var(--text);font-size:.83rem;line-height:1.6}
.news-updates-note strong{color:#fff}

/* ── TABS ── */
.tab-placeholder{display:none}

/* ═══════════════════════════════════════════════════════
   RESPONSE TRACKER — dark adapted
   ═══════════════════════════════════════════════════════ */
#tab-response-tracker{display:none;flex-direction:column;align-items:flex-start;justify-content:flex-start;background:transparent;min-height:calc(100vh - 99px);width:100%}
.rt-topbar{background:rgba(22,32,58,.97);padding:10px 18px;position:sticky;top:99px;z-index:150;box-shadow:0 2px 16px rgba(0,0,0,.4);width:100%;backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.rt-topbar-row1{display:flex;align-items:center;gap:10px;margin-bottom:8px;flex-wrap:wrap}
.rt-topbar-title{color:var(--muted);font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.2em;text-transform:uppercase}
.rt-topbar-heading{color:#fff;font-size:14px;font-weight:700;margin-top:2px}
.rt-nav-tabs{display:flex;gap:2px;margin-left:14px}
.rt-nav-tab{padding:6px 14px;font-size:11px;font-weight:700;color:rgba(255,255,255,.55);cursor:pointer;border-radius:5px;transition:all .15s}
.rt-nav-tab:hover,.rt-nav-tab.rt-active{color:#fff;background:rgba(255,255,255,.15)}
.rt-topbar-controls{margin-left:auto;display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.rt-ctrl-input{height:32px;padding:0 10px;border:none;border-radius:5px;font-size:12px;font-family:inherit;color:#1a2744;background:rgba(255,255,255,.92);min-width:130px}
.rt-ctrl-select{height:32px;padding:0 10px;border:none;border-radius:5px;font-size:12px;font-family:inherit;color:#1a2744;background:rgba(255,255,255,.92);min-width:115px}
.rt-view-select{min-width:165px;font-weight:600}
.rt-add-btn{height:32px;padding:0 14px;background:linear-gradient(135deg,#d9b75f,#f3d380);border:none;border-radius:5px;font-weight:800;font-size:11px;cursor:pointer;color:#191919;white-space:nowrap;font-family:inherit}
.rt-summary-btn{height:32px;padding:0 12px;background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.18);border-radius:5px;font-weight:700;font-size:11px;cursor:pointer;color:rgba(255,255,255,.82);white-space:nowrap;font-family:inherit;transition:background .15s,border-color .15s,color .15s}
.rt-summary-btn:hover{background:rgba(217,183,95,.18);border-color:rgba(217,183,95,.5);color:#d9b75f}
.rt-stat-strip{display:flex;gap:16px;padding:4px 0 2px;overflow-x:auto;scrollbar-width:none}
.rt-stat-strip::-webkit-scrollbar{display:none}
.si{display:flex;flex-direction:column;align-items:flex-start;gap:0}
.sv{font-family:'DM Mono',monospace;font-size:15px;font-weight:700;color:#fff}
.sl{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.sd{width:1px;background:rgba(255,255,255,.2);align-self:stretch}

/* Board */
#rt-view-board{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:60px}
#rt-board{display:flex;gap:10px;padding:14px 14px 8px;align-items:stretch;width:100%}
.rt-col{flex:1 1 0;min-width:0;background:rgba(255,255,255,.07);border-radius:8px;display:flex;flex-direction:column;border:1px solid var(--line)}
.rt-col-head{padding:9px 11px 7px;display:flex;align-items:center;gap:6px;background:rgba(255,255,255,.08);border-radius:8px 8px 0 0;border-bottom:1px solid var(--line)}
.rt-col-label{font-weight:700;font-size:10px;text-transform:uppercase;letter-spacing:.7px;color:#fff}
.rt-col-count{background:rgba(255,255,255,.2);color:#fff;font-family:'DM Mono',monospace;font-size:10px;font-weight:700;border-radius:12px;padding:1px 7px;margin-left:auto}
.rt-col-closed{flex:1 1 0;min-width:0}
.rt-wl-section{display:flex;flex-direction:column;flex:1;padding:5px 5px 8px;gap:4px}
.rt-wl-sub-label{font-family:'DM Mono',monospace;font-size:8px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:3px 4px}
.rt-wl-won{color:#4ade80}
.rt-wl-lost{color:#ff7b7b}
.rt-cards-zone{padding:6px 6px 8px;display:flex;flex-direction:column;gap:5px;flex:1;min-height:80vh;transition:background .15s}
.rt-cards-zone.drag-over{background:rgba(217,183,95,.1)}
.rt-col-closed .rt-cards-zone{min-height:40px;flex:0 0 auto}
.rt-bd-title-link{color:inherit;text-decoration:none}
.rt-bd-title-link:hover{text-decoration:underline}
.rt-drop-hint{text-align:center;padding:12px 6px;color:var(--muted);font-size:10px;font-style:italic}

/* Opp cards */
.rt-opp-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:7px;overflow:hidden}
.rt-opp-card-won{background:rgba(34,197,94,.13);border-color:rgba(34,197,94,.38)}
.rt-opp-card-lost{background:rgba(255,123,123,.13);border-color:rgba(255,123,123,.38)}
.rt-opp-header{padding:10px 11px 8px;cursor:pointer;transition:background .15s}
.rt-opp-header:hover{background:rgba(255,255,255,.06)}
.rt-opp-title{font-size:11.5px;font-weight:700;color:#fff;line-height:1.3;margin-bottom:5px}
.rt-opp-meta{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:5px}
.bdg{display:inline-flex;align-items:center;font-family:'DM Mono',monospace;font-size:8px;font-weight:700;padding:2px 6px;border-radius:3px;white-space:nowrap}
.bdg-type{background:rgba(112,160,255,.2);color:#c0d4ff;border:1px solid rgba(112,160,255,.35)}
.bdg-dl-ok{background:rgba(67,197,158,.15);color:#6ee7c7;border:1px solid rgba(67,197,158,.35)}
.bdg-dl-warn{background:rgba(255,191,95,.15);color:#ffd580;border:1px solid rgba(255,191,95,.35)}
.bdg-dl-hot{background:rgba(255,123,123,.18);color:#ffaaaa;border:1px solid rgba(255,123,123,.35)}
.bdg-dl-na{background:rgba(255,255,255,.1);color:var(--muted);border:1px solid rgba(255,255,255,.2)}
.bdg-flag{background:rgba(255,191,95,.15);color:#ffd580;border:1px solid rgba(255,191,95,.35)}
.bdg-ns{background:rgba(255,255,255,.1);color:var(--muted);border:1px solid rgba(255,255,255,.2)}
.bdg-bid-go{background:rgba(67,197,158,.18);color:#6ee7c7;border:1px solid rgba(67,197,158,.35)}
.bdg-bid-nobid{background:rgba(255,123,123,.18);color:#ffaaaa;border:1px solid rgba(255,123,123,.35)}
.bdg-bid-hold{background:rgba(255,191,95,.15);color:#ffd580;border:1px solid rgba(255,191,95,.35)}
.pwin-row{display:flex;align-items:center;gap:6px;margin-top:5px}
.pwin-lbl{font-family:'DM Mono',monospace;font-size:8px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;flex-shrink:0}
.pwin-track{flex:1;height:4px;background:rgba(255,255,255,.15);border-radius:2px;overflow:hidden}
.pwin-fill{height:100%;border-radius:2px}
.pwin-pct{font-family:'DM Mono',monospace;font-size:9px;font-weight:700;flex-shrink:0}
.rt-opp-card .prospect-badge{display:inline-flex;align-items:center;gap:4px;margin-left:4px;font-family:'DM Mono',monospace;font-size:8px;font-weight:700;padding:2px 6px;border-radius:3px;background:rgba(255,191,95,.15);color:#ffd580;border:1px solid rgba(255,191,95,.35)}

/* Leaderboard */
.section-hd{display:flex;align-items:center;gap:14px;margin-bottom:18px;flex-wrap:wrap}
.section-hd h2{font-family:Manrope,sans-serif;font-size:1.2rem;font-weight:800;color:#fff}
.sec-filter select{height:30px;padding:0 10px;border:1px solid var(--line);border-radius:5px;font-size:12px;font-family:inherit;color:var(--text);background:rgba(255,255,255,.06);cursor:pointer}
.tbl-wrap{overflow-x:auto}
table.tbl{width:100%;border-collapse:collapse;font-size:13px}
table.tbl th{padding:9px 12px;text-align:left;font-family:'DM Mono',monospace;font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);border-bottom:2px solid var(--line);white-space:nowrap}
table.tbl th.r,table.tbl td.r{text-align:right}
table.tbl td{padding:9px 12px;border-bottom:1px solid var(--line);color:var(--text);vertical-align:middle}
table.tbl tr:hover td{background:rgba(255,255,255,.04)}
.lb-nc{display:flex;align-items:center;gap:10px}
.lb-pip{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;flex-shrink:0}
.lb-nm{font-weight:700;font-size:13px;color:#fff}
.lb-rl{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.wr-cell{display:flex;align-items:center;gap:8px}
.wr-track{flex:1;height:5px;background:rgba(255,255,255,.15);border-radius:3px;overflow:hidden;min-width:60px}
.wr-fill{height:100%;border-radius:3px}
.dim{color:rgba(255,255,255,.35)}

/* ═══════════════════════════════════════════════════════
   PROPOSAL WORKSHOP — dark adapted
   ═══════════════════════════════════════════════════════ */
#tab-proposal-workshop{display:none;flex-direction:column;align-items:flex-start;justify-content:flex-start;min-height:calc(100vh - 99px);width:100%}
.pw-shell{display:flex;width:100%;min-height:calc(100vh - 99px)}
.pw-sidebar{width:260px;flex-shrink:0;background:rgba(22,32,58,.97);display:flex;flex-direction:column;overflow-y:auto;position:sticky;top:99px;height:calc(100vh - 99px);border-right:1px solid var(--line)}
.pw-sidebar-head{padding:14px 14px 10px;border-bottom:1px solid var(--line)}
.pw-sidebar-title{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:8px}
.pw-sidebar-search{width:100%;background:rgba(255,255,255,.1);border:1px solid var(--line);border-radius:5px;padding:6px 9px;font-size:11px;color:#fff;outline:none}
.pw-sidebar-search::placeholder{color:var(--muted)}
.pw-opp-list{flex:1;overflow-y:auto;padding:6px 0}
.pw-opp-item{padding:10px 14px;cursor:pointer;border-left:3px solid transparent;transition:background .15s,border-color .15s}
.pw-opp-item:hover{background:rgba(255,255,255,.07)}
.pw-opp-item.active{background:rgba(217,183,95,.14);border-left-color:var(--gold)}
.pw-opp-name{font-size:11px;font-weight:700;color:#fff;line-height:1.3;margin-bottom:3px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.pw-opp-meta{font-size:9px;color:var(--muted);display:flex;gap:6px;flex-wrap:wrap}
.pw-opp-type{background:var(--gold-soft);color:var(--gold);font-size:8px;font-weight:700;padding:1px 5px;border-radius:8px;text-transform:uppercase}
.pw-opp-empty{padding:20px 14px;font-size:12px;color:var(--muted);text-align:center;line-height:1.6}
.pw-sidebar-footer{padding:10px 14px;border-top:1px solid var(--line)}
.pw-new-btn{width:100%;padding:8px;background:linear-gradient(135deg,#d9b75f,#f3d380);color:#191919;border:none;border-radius:6px;font-weight:800;font-size:11px;cursor:pointer;font-family:inherit}
.pw-main{flex:1;display:flex;flex-direction:column;overflow:hidden}
.pw-topbar{background:rgba(22,32,58,.92);border-bottom:1px solid var(--line);padding:11px 18px;display:flex;align-items:center;gap:12px;flex-wrap:wrap;flex-shrink:0}
.pw-opp-title-display{font-size:13px;font-weight:700;color:#fff;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pw-type-badge{background:rgba(112,160,255,.2);color:#c0d4ff;font-size:10px;font-weight:700;padding:3px 9px;border-radius:20px;white-space:nowrap}
.pw-content{flex:1;overflow-y:auto;padding:18px}
.pw-welcome{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:360px;text-align:center;color:var(--muted)}
.pw-welcome-icon{font-size:44px;margin-bottom:14px;opacity:.5}
.pw-welcome-title{font-family:Manrope,sans-serif;font-size:1.25rem;font-weight:800;color:#fff;margin-bottom:8px}
.pw-welcome-sub{font-size:.875rem;line-height:1.65;max-width:400px;color:var(--muted)}
.pw-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}
.pw-card{background:rgba(255,255,255,.07);border:1px solid var(--line);border-radius:10px;overflow:hidden}
.pw-card-head{background:rgba(22,32,58,.95);padding:9px 13px;display:flex;align-items:center;gap:7px;border-bottom:1px solid var(--line)}
.pw-card-head-title{font-family:'DM Mono',monospace;font-size:10px;font-weight:700;color:var(--gold);text-transform:uppercase;letter-spacing:.5px;flex:1}
.pw-card-body{padding:12px}
.pw-fact-row{display:flex;gap:8px;margin-bottom:6px;align-items:flex-start}
.pw-fact-label{font-family:'DM Mono',monospace;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);width:85px;flex-shrink:0;padding-top:2px}
.pw-fact-val{font-size:11.5px;color:#fff;font-weight:500;flex:1;line-height:1.4}
.pw-section{background:rgba(255,255,255,.06);border:1px solid var(--line);border-radius:10px;margin-bottom:12px;overflow:hidden}
.pw-section-head{padding:10px 14px;background:rgba(255,255,255,.06);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:9px}
.pw-section-num{width:20px;height:20px;border-radius:50%;background:var(--gold);color:#141414;font-size:9px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.pw-section-title{font-family:'DM Mono',monospace;font-size:11px;font-weight:700;color:#fff;flex:1;text-transform:uppercase;letter-spacing:.5px}
.pw-section-hint{font-size:10px;color:var(--muted);font-style:italic}
.pw-section-body{padding:13px}
.pw-gen-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;background:var(--gold-soft);color:var(--gold);border:1px solid var(--gold-brd);border-radius:5px;font-family:'DM Mono',monospace;font-size:10px;font-weight:700;cursor:pointer;white-space:nowrap;transition:all .15s}
.pw-gen-btn:hover{background:var(--gold);color:#141414;border-color:var(--gold)}
.pw-gen-btn:disabled{background:rgba(255,255,255,.05);color:var(--muted);border-color:var(--line);cursor:not-allowed}
.pw-gen-btn.generating{background:rgba(112,160,255,.2);color:var(--blue);border-color:rgba(112,160,255,.3)}
.pw-textarea{width:100%;border:1px solid var(--line);border-radius:6px;padding:10px 12px;font-size:12px;font-family:Inter,sans-serif;color:#fff;resize:vertical;line-height:1.6;background:rgba(255,255,255,.07);transition:border-color .15s}
.pw-textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(217,183,95,.1)}
.pw-textarea.streaming{border-color:var(--blue);background:rgba(112,160,255,.06)}
.pw-actions-bar{background:rgba(22,32,58,.92);border-top:1px solid var(--line);padding:11px 18px;display:flex;gap:8px;align-items:center;flex-shrink:0}
.pw-action-btn{padding:8px 18px;border-radius:6px;font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;border:none;transition:all .15s}
.pw-action-primary{background:rgba(112,160,255,.2);color:var(--blue);border:1px solid rgba(112,160,255,.3)}.pw-action-primary:hover{background:var(--blue);color:#141414}
.pw-action-secondary{background:rgba(255,255,255,.06);color:var(--text);border:1px solid var(--line)}.pw-action-secondary:hover{background:rgba(255,255,255,.1)}
.pw-action-export{background:linear-gradient(135deg,#d9b75f,#f3d380);color:#191919}.pw-action-export:hover{opacity:.9}
.pw-progress{height:3px;background:rgba(255,255,255,.1);border-radius:2px;overflow:hidden;margin:8px 0}
.pw-progress-fill{height:100%;background:var(--gold);border-radius:2px;transition:width .3s}
.pw-checklist{list-style:none;padding:0;margin:0}
.pw-checklist li{display:flex;align-items:flex-start;gap:8px;padding:5px 0;border-bottom:1px solid var(--line);font-size:12px;color:var(--text)}
.pw-checklist li:last-child{border-bottom:none}
.pw-check-icon{font-size:13px;flex-shrink:0;margin-top:1px}
.pw-check-done .pw-check-icon{color:var(--green)}
.pw-check-warn .pw-check-icon{color:var(--amber)}
.pw-check-fail .pw-check-icon{color:var(--red)}
.pw-tabs{display:flex;gap:0;border-bottom:2px solid var(--line);margin-bottom:14px;overflow-x:auto}
.pw-tab{padding:7px 14px;font-family:'DM Mono',monospace;font-size:10px;font-weight:700;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;white-space:nowrap;transition:color .15s,border-color .15s}
.pw-tab.active{color:var(--gold);border-bottom-color:var(--gold)}
.pw-tab-pane{display:none}.pw-tab-pane.active{display:block}

/* ═══════════════════════════════════════════════════════
   MODAL + FORM — RT Add/Edit
   ═══════════════════════════════════════════════════════ */
.overlay{position:fixed;inset:0;background:rgba(5,8,18,.72);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:18px;z-index:900}
.overlay.off{display:none}
.modal{width:min(820px,100%);max-height:min(92vh,900px);overflow:auto;background:linear-gradient(180deg,#162035,#111c30);border:1px solid var(--line-2);border-radius:16px;box-shadow:var(--shadow)}
.modal-hd{padding:18px 20px 14px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:rgba(22,32,58,.97);backdrop-filter:blur(12px);z-index:5}
.modal-hd h2{font-family:Manrope,sans-serif;font-size:1.1rem;font-weight:800;color:#fff;letter-spacing:-.02em}
.close-btn{width:32px;height:32px;border-radius:8px;border:1px solid var(--line);background:rgba(255,255,255,.1);color:#fff;cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center}
.modal-bd{padding:18px 20px}
.modal-ft{padding:12px 20px 16px;border-top:1px solid var(--line);display:flex;gap:8px;align-items:center;flex-wrap:wrap;position:sticky;bottom:0;background:rgba(22,32,58,.97);backdrop-filter:blur(12px)}
.fg{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.fld{display:flex;flex-direction:column;gap:5px}
.fld.s2{grid-column:span 2}
.fld label{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.fld input,.fld select,.fld textarea{background:rgba(255,255,255,.09);border:1px solid var(--line);border-radius:6px;padding:8px 10px;color:#fff;font-size:12px;outline:none;transition:border-color .15s;width:100%}
.fld input::placeholder,.fld textarea::placeholder{color:rgba(255,255,255,.35)}
.fld input:focus,.fld select:focus,.fld textarea:focus{border-color:var(--gold);box-shadow:0 0 0 2px rgba(217,183,95,.12)}
.fld select option{background:#1a2744;color:#fff}
.fld textarea{resize:vertical;line-height:1.6}
.dlbl{grid-column:span 2;font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);padding:8px 0 2px;border-top:1px solid var(--line);margin-top:4px}
.check-row{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text);cursor:pointer}
.tab-row{display:flex;gap:0;border-bottom:2px solid var(--line)}
.form-tab{padding:7px 13px;font-family:'DM Mono',monospace;font-size:10px;font-weight:700;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s}
.form-tab.active,.form-tab[style*="color:#1F3864"]{color:var(--gold)!important;border-bottom-color:var(--gold)!important}
.rubric-box{border:1px solid var(--line);border-radius:8px;overflow:hidden}
.rubric-hd{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:rgba(255,255,255,.07);border-bottom:1px solid var(--line)}
.rubric-hd-lbl{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.rubric-total-val{font-family:'DM Mono',monospace;font-size:1.3rem;font-weight:700;color:var(--gold)}
.rubric-total-lbl{font-family:'DM Mono',monospace;font-size:9px;color:var(--muted);margin-left:3px}
.rubric-factor{display:flex;align-items:flex-start;gap:12px;padding:10px 14px;border-bottom:1px solid var(--line)}
.rubric-factor:last-child{border-bottom:none}
.rf-lbl{font-size:12px;font-weight:700;color:#fff}
.rf-hint{font-size:10px;color:var(--muted);margin-top:3px;line-height:1.4}
.rf-slider{flex:1;padding-top:4px}
.rf-slider input[type=range]{width:100%;accent-color:var(--gold)}
.rf-num-area{display:flex;align-items:center;gap:2px;flex-shrink:0;min-width:38px}
.rf-score{font-family:'DM Mono',monospace;font-size:13px;font-weight:700;color:var(--gold)}
.rf-max{font-family:'DM Mono',monospace;font-size:9px;color:var(--muted)}
.exsum-box,.notes-box{background:rgba(255,255,255,.06);border:1px solid var(--line);border-radius:6px;padding:11px 13px;font-size:12px;color:#fff;white-space:pre-wrap;line-height:1.7}
.email-body{background:rgba(255,255,255,.06);border:1px solid var(--line);border-radius:6px;padding:13px;font-family:'DM Mono',monospace;font-size:11px;line-height:1.7;color:var(--text);white-space:pre-wrap;max-height:360px;overflow-y:auto}
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.detail-row{display:flex;flex-direction:column;gap:3px;padding:9px 11px;background:rgba(255,255,255,.07);border:1px solid var(--line);border-radius:6px}
.dk{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.dv{font-size:12px;color:#fff;font-weight:500;line-height:1.4}
.tab-pane{display:none}.tab-pane.active{display:block;padding-top:12px}
.staff-cards{display:flex;flex-wrap:wrap;gap:8px}
.staff-card{display:flex;align-items:center;gap:8px;padding:8px 12px;background:rgba(255,255,255,.08);border:1px solid var(--line);border-radius:8px}
.sc-pip{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;flex-shrink:0}
.sc-role{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.sc-name{font-size:12px;font-weight:700;color:#fff}
.bid-decision-banner{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-family:'DM Mono',monospace;font-size:9px;font-weight:700;margin-left:auto}
.btn-p{padding:9px 18px;background:linear-gradient(135deg,#d9b75f,#f3d380);color:#191919;font-weight:800;font-size:12px;cursor:pointer;border-radius:6px;border:none;font-family:inherit}
.btn-s{padding:9px 18px;background:rgba(255,255,255,.07);color:var(--text);font-weight:600;font-size:12px;cursor:pointer;border-radius:6px;border:1px solid var(--line);font-family:inherit}
.btn-d{padding:9px 18px;background:rgba(255,123,123,.15);color:var(--red);font-weight:700;font-size:12px;cursor:pointer;border-radius:6px;border:1px solid rgba(255,123,123,.25);font-family:inherit;margin-left:auto}
.copy-btn{padding:9px 18px;background:rgba(67,197,158,.15);color:var(--green);font-weight:700;font-size:12px;cursor:pointer;border-radius:6px;border:1px solid rgba(67,197,158,.25);font-family:inherit}

/* ── Add solicitation form (modal) ── */
.status-sel{background:rgba(255,255,255,.07);border:1px solid var(--line);border-radius:4px;color:var(--text);padding:3px 6px;font-size:11px;font-family:'DM Mono',monospace;cursor:pointer}
.status-sel option{background:#1a2744;color:#fff}
.s-nc{color:var(--muted)}.s-os{color:var(--amber)}.s-reg{color:var(--green)}.s-ni{color:var(--red)}.s-def{color:var(--muted)}
.cons-input{background:transparent;border:none;border-bottom:1px solid var(--line);color:var(--text);font-size:11px;font-family:Inter,sans-serif;padding:3px 2px;outline:none;width:100%}
.email-btn{padding:5px 10px;background:rgba(112,160,255,.15);color:var(--blue);border:1px solid rgba(112,160,255,.25);border-radius:4px;font-size:10px;cursor:pointer;font-family:'DM Mono',monospace}
.cons-desc{margin-bottom:16px;padding:12px 14px;background:rgba(255,255,255,.07);border:1px solid var(--line);border-radius:6px;font-size:12px;color:var(--text);line-height:1.65}
.cons-linked{font-family:'DM Mono',monospace;font-size:8px;color:var(--green);letter-spacing:.06em;text-transform:uppercase;margin-top:2px}

/* ── Add solicitation modal ── */
.add-sol-note{font-size:11.5px;color:var(--text);line-height:1.65;padding:11px 14px;background:rgba(217,183,95,.08);border:1px solid var(--gold-brd);border-radius:6px;margin-bottom:14px}

/* Toast */
#rt-toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);background:#1F3864;color:#fff;font-family:'DM Mono',monospace;font-size:12px;font-weight:600;padding:10px 22px;border-radius:24px;box-shadow:0 4px 20px rgba(0,0,0,.35);z-index:9999;opacity:0;transition:opacity .25s,transform .25s;pointer-events:none;border:1.5px solid var(--gold)}

/* ── RESPONSIVE ── */

/* Large desktop monitors (≥ 1680px) — more breathing room and slightly larger type */
@media(min-width:1680px){
  html{font-size:15px}
  .topbar-inner{padding:10px 40px}
  .tab-nav{padding:0 40px}
  .left-nav{width:260px}
  .pw-sidebar{width:280px}
  .main-content{padding:28px 32px 80px}
  .sol-card{padding:18px 22px}
  .rt-topbar-row1{padding:14px 28px}
  .rt-board{padding:0 28px 80px}
  /* Increase card font sizes */
  .sol-title{font-size:1.1rem}
  .rt-card-title{font-size:12px}
}

/* Standard desktop / wide laptop (≥ 1280px) — defaults already set */
@media(min-width:1280px) and (max-width:1679px){
  html{font-size:14px}
  .left-nav{width:240px}
  .pw-sidebar{width:260px}
}

/* Laptop / Tablet (768px – 1279px) */
@media(max-width:1279px) and (min-width:768px){
  html{font-size:13.5px}
  .left-nav{width:200px}
  .pw-sidebar{width:220px}
  .tab-nav a{padding:0 12px}
  .rt-topbar-controls{flex-wrap:wrap;gap:4px}
  .sol-card-header{flex-wrap:wrap}
  #rt-view-board{-webkit-overflow-scrolling:touch}
}

/* Small laptop / large tablet (768px – 1024px) */
@media(max-width:1024px) and (min-width:768px){
  .topbar-chips{display:none}
  .rt-topbar-controls{flex-wrap:wrap}
  .rt-ctrl-input{min-width:100px}
}

/* Mobile (≤ 767px) */
@media(max-width:767px){
  /* Topbar */
  .topbar-inner{padding:8px 12px}
  .topbar-logo{height:28px}
  .brand-sub{display:none}

  /* Tab nav — horizontal scroll */
  .tab-nav{overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;gap:0;padding:0 8px}
  .tab-nav::-webkit-scrollbar{display:none}
  .tab-nav a{white-space:nowrap;padding:0 12px;font-size:8px}

  /* Main content */
  .main-content{padding:12px 12px 80px}
  .news-main-content{padding:16px 12px 80px}
  .news-jump-bar{padding:6px 12px;gap:4px}

  /* Form grids */
  .fg{grid-template-columns:1fr}
  .fld.s2{grid-column:auto}
  .dlbl{grid-column:auto}
  .pw-grid{grid-template-columns:1fr}
  .detail-grid{grid-template-columns:1fr}

  /* Proposal workshop */
  .pw-shell{flex-direction:column}
  .pw-main{width:100%}

  /* Response tracker topbar */
  .rt-topbar-row1{flex-direction:column;align-items:flex-start;gap:6px}
  .rt-topbar-controls{width:100%;flex-wrap:wrap}
  .rt-ctrl-input,.rt-ctrl-select{min-width:0;flex:1 1 120px}

  /* Queue topbar */
  .queue-topbar-inner{flex-direction:column;align-items:flex-start;gap:8px}

  /* Modal — sheet from bottom */
  .modal{width:100%;max-height:100vh;border-radius:12px 12px 0 0}
  .overlay{align-items:flex-end;padding:0}

  /* Solicitation actions */
  .sol-actions{flex-wrap:wrap}

  /* Board */
  #rt-view-board{-webkit-overflow-scrolling:touch}
  .rt-col{min-width:260px}

  /* Touch targets — 44px minimum */
  .btn-p,.btn-s,.btn-d,.sol-link,.send-btn,.save-btn,.delete-btn,
  .add-to-rt-btn,.bid-btn,.nobid-btn{min-height:44px}

  /* Send-to-client preview */
  .stc-preview-frame{height:300px}

  /* Prevent horizontal viewport overflow — keeps the sticky topbar and tab-nav
     always covering the full screen width so content never scrolls under them */
  html, body { overflow-x: hidden; }

  /* Compact user-menu chip — hide the label text, keep the avatar icon + caret
     so the topbar doesn't show an empty-looking right column */
  .user-menu-label { display: none; }

  /* Subtab bars — let buttons scroll internally so they never push the page wider */
  .sol-subtab-bar { overflow-x: auto; scrollbar-width: none; -webkit-overflow-scrolling: touch; padding: 0 12px; }
  .sol-subtab-bar::-webkit-scrollbar { display: none; }
  .sol-inner-tab-bar { overflow-x: auto; scrollbar-width: none; -webkit-overflow-scrolling: touch; padding: 6px 12px; }
  .sol-inner-tab-bar::-webkit-scrollbar { display: none; }

  /* Sol card header — let the action buttons wrap below the title on small screens */
  .sol-card-header { flex-wrap: wrap; }

  /* Queue card header — badges wrap below the title so they never cover it */
  .queue-card-hd { flex-wrap: wrap; }
}

/* ═══════════════════════════════════════════════════════
   PIPELINE VIEW — opportunity tracking table
   ═══════════════════════════════════════════════════════ */
.pl-shell{display:flex;flex-direction:column;min-height:calc(100vh - 160px);width:100%}

/* ── Header ── */
.pl-header{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;padding:18px 20px 14px;background:rgba(22,32,58,.97);border-bottom:1px solid var(--line);flex-wrap:wrap;position:sticky;top:0;z-index:10;backdrop-filter:blur(12px)}
.pl-header-title{font-family:Manrope,sans-serif;font-size:1.1rem;font-weight:800;color:#fff;letter-spacing:-.02em}
.pl-header-sub{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:4px}

/* ── Summary stat strip ── */
.pl-summary-strip{display:flex;align-items:center;gap:10px;flex-wrap:wrap;flex-shrink:0}
.pl-sum-cell{display:flex;flex-direction:column;align-items:center;gap:2px;min-width:42px}
.pl-sum-val{font-family:'DM Mono',monospace;font-size:1.2rem;font-weight:700;color:#fff;line-height:1}
.pl-sum-lbl{font-family:'DM Mono',monospace;font-size:7.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.pl-sum-div{width:1px;height:32px;background:var(--line);flex-shrink:0}

/* ── Table wrapper ── */
.pl-table-wrap{flex:1;overflow-x:auto;overflow-y:auto;-webkit-overflow-scrolling:touch}

/* ── Table base ── */
.pl-tbl{width:100%;border-collapse:collapse;font-size:12.5px;table-layout:auto}

/* ── Header row ── */
.pl-th{padding:10px 14px;text-align:left;font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);border-bottom:2px solid var(--line);white-space:nowrap;position:sticky;top:0;background:rgba(15,21,37,.98);backdrop-filter:blur(8px);user-select:none;transition:color .15s}
.pl-th:hover{color:#fff}
.pl-th-opp{min-width:280px;max-width:380px}
.pl-th-type{min-width:90px}
.pl-th-office{min-width:180px}
.pl-th-client{min-width:130px}
.pl-th-deadline{min-width:110px}
.pl-th-stage{min-width:130px}
.pl-th-bid{min-width:110px}
.pl-th-wf{min-width:110px;text-align:center}
.pl-th-staff{min-width:200px}

/* ── Body rows ── */
.pl-tr{border-bottom:1px solid var(--line);transition:background .12s;cursor:default}
.pl-tr-even{background:rgba(255,255,255,.02)}
.pl-tr-odd{background:rgba(255,255,255,.045)}
.pl-tr:hover{background:rgba(217,183,95,.07)!important}

.pl-td{padding:10px 14px;vertical-align:middle;color:var(--text)}
.pl-td-center{text-align:center}
.pl-td-toggle{text-align:center;padding:8px 10px}
.pl-td-stage{white-space:nowrap}
.pl-td-office{max-width:200px}
.pl-td-client{max-width:160px}
.pl-client-name{font-size:12px;color:var(--text);display:flex;align-items:center;gap:5px}
.pl-client-more{display:inline-flex;align-items:center;justify-content:center;background:rgba(217,183,95,.18);border:1px solid rgba(217,183,95,.35);color:var(--gold);font-family:'DM Mono',monospace;font-size:8px;font-weight:700;padding:1px 5px;border-radius:10px;white-space:nowrap}

/* ── Opportunity title + link ── */
.pl-opp-title{margin-bottom:2px}
.pl-opp-link{color:#fff;font-weight:700;font-size:12.5px;line-height:1.35;text-decoration:none;display:inline;transition:color .15s}
.pl-opp-link:hover{color:var(--gold)}
.pl-ext-icon{font-size:9px;color:var(--gold);margin-left:4px;opacity:.7;vertical-align:super}
.pl-opp-text{color:#fff;font-weight:700;font-size:12.5px;line-height:1.35}
.pl-opp-sol{font-family:'DM Mono',monospace;font-size:9px;color:var(--muted);margin-top:2px;letter-spacing:.04em}
.pl-office-text{font-size:12px;color:var(--text);line-height:1.4;display:block}

/* ── Type tag ── */
.pl-type-tag{display:inline-flex;align-items:center;background:rgba(112,160,255,.18);color:#c0d4ff;border:1px solid rgba(112,160,255,.32);font-family:'DM Mono',monospace;font-size:9px;font-weight:700;padding:2px 8px;border-radius:4px;white-space:nowrap;letter-spacing:.04em}

/* ── Deadline ── */
.pl-dl{display:inline-flex;align-items:center;font-family:'DM Mono',monospace;font-size:10px;font-weight:700;padding:3px 9px;border-radius:4px;white-space:nowrap}
.pl-dl-ok{background:rgba(67,197,158,.15);color:#6ee7c7;border:1px solid rgba(67,197,158,.3)}
.pl-dl-warn{background:rgba(255,191,95,.15);color:#ffd580;border:1px solid rgba(255,191,95,.3)}
.pl-dl-hot{background:rgba(255,123,123,.18);color:#ffaaaa;border:1px solid rgba(255,123,123,.3)}
.pl-dl-na{color:var(--muted);font-family:'DM Mono',monospace;font-size:11px}

/* ── Stage ── */
.pl-stage-dot{display:inline-block;width:7px;height:7px;border-radius:50%;flex-shrink:0}
.pl-stage-lbl{font-family:'DM Mono',monospace;font-size:9.5px;font-weight:600;color:var(--text);white-space:nowrap}

/* ── Bid decision badge ── */
.pl-bid{display:inline-flex;align-items:center;font-family:'DM Mono',monospace;font-size:9px;font-weight:800;padding:3px 10px;border-radius:4px;letter-spacing:.06em;white-space:nowrap}
.pl-bid-go{background:rgba(67,197,158,.18);color:#6ee7c7;border:1px solid rgba(67,197,158,.35)}
.pl-bid-nobid{background:rgba(255,123,123,.18);color:#ffaaaa;border:1px solid rgba(255,123,123,.35)}
.pl-bid-hold{background:rgba(255,191,95,.15);color:#ffd580;border:1px solid rgba(255,191,95,.35)}
.pl-bid-none{color:var(--muted);font-family:'DM Mono',monospace;font-size:11px}

/* ── Workflow toggle buttons ── */
.pl-toggle{width:32px;height:32px;border-radius:8px;border:none;font-size:14px;font-weight:700;cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;justify-content:center;font-family:inherit}
.pl-toggle-off{background:rgba(255,255,255,.07);color:rgba(255,255,255,.3);border:1px solid rgba(255,255,255,.15)}
.pl-toggle-off:hover{background:rgba(255,255,255,.12);color:rgba(255,255,255,.6);border-color:rgba(255,255,255,.25)}
.pl-toggle-on{background:rgba(67,197,158,.2);color:#6ee7c7;border:1px solid rgba(67,197,158,.4);font-size:16px}
.pl-toggle-on:hover{background:rgba(67,197,158,.3)}

/* ── Staff chips ── */
.pl-staff-wrap{display:flex;flex-direction:column;gap:5px}
.pl-staff-chip{display:inline-flex;align-items:center;gap:6px;padding:3px 8px 3px 4px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap}
.pl-staff-lead{background:rgba(46,84,150,.25);border:1px solid rgba(46,84,150,.4);color:#c0d4ff}
.pl-staff-pol{background:rgba(74,45,122,.25);border:1px solid rgba(74,45,122,.4);color:#d4b4ff}
.pl-staff-pip{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:8px;font-weight:800;color:#fff;flex-shrink:0;letter-spacing:0}
.pl-staff-role{font-family:'DM Mono',monospace;font-size:7.5px;letter-spacing:.1em;text-transform:uppercase;opacity:.65;margin-left:2px}

/* ── Footer ── */
.pl-footer{padding:12px 20px;font-family:'DM Mono',monospace;font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);border-top:1px solid var(--line);background:rgba(15,21,37,.97)}
.pl-footer strong{color:var(--text)}

/* ── Pipeline: chevron expand column ── */
.pl-th-chevron{width:44px;min-width:44px;padding:10px 8px!important}
.pl-td-chevron{width:44px;min-width:44px;padding:8px!important;text-align:center;cursor:pointer;vertical-align:middle;user-select:none}
.pl-td-chevron:hover .pl-chevron{color:#fff}

.pl-chevron{display:inline-block;font-size:16px;font-weight:700;color:var(--muted);transition:transform .18s ease,color .15s;line-height:1;vertical-align:middle}
.pl-chevron-open{transform:rotate(90deg);color:var(--gold)!important}

.pl-client-count{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:var(--gold-soft);border:1px solid var(--gold-brd);color:var(--gold);font-family:'DM Mono',monospace;font-size:9px;font-weight:700;margin-top:3px;display:block}

/* ── Row expanded state ── */
.pl-tr-expanded{background:rgba(217,183,95,.05)!important;border-bottom:none!important}
.pl-tr-expanded td{border-bottom:none!important}

/* ── Sub-row ── */
.pl-sub-row{border-bottom:2px solid var(--gold-brd)!important}
.pl-sub-row td{padding:0!important;background:rgba(217,183,95,.04)}

.pl-sub-panel{padding:14px 20px 16px 52px;border-top:1px solid var(--line)}

.pl-sub-header{display:flex;align-items:baseline;gap:14px;margin-bottom:12px;flex-wrap:wrap}
.pl-sub-title{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:700}
.pl-sub-hint{font-size:11px;color:var(--muted);font-style:italic}

/* ── Client bid list ── */
.pl-cb-list{display:flex;flex-direction:column;gap:7px;margin-bottom:12px}
.pl-cb-empty{font-size:12px;color:var(--muted);font-style:italic;padding:8px 0}

.pl-cb-row{display:flex;align-items:center;gap:10px;padding:8px 12px;background:rgba(255,255,255,.05);border:1px solid var(--line);border-radius:8px;transition:background .13s,border-color .13s}
.pl-cb-row:hover{background:rgba(255,255,255,.09);border-color:var(--line-2)}
.pl-cb-row-bid-go{background:rgba(67,197,158,.15);border-color:rgba(67,197,158,.35)}
.pl-cb-row-bid-go:hover{background:rgba(67,197,158,.22)}
.pl-cb-row-bid-nobid{background:rgba(255,90,90,.15);border-color:rgba(255,90,90,.35)}
.pl-cb-row-bid-nobid:hover{background:rgba(255,90,90,.22)}
.pl-cb-row-bid-hold{background:rgba(255,191,95,.12);border-color:rgba(255,191,95,.35)}
.pl-cb-row-bid-hold:hover{background:rgba(255,191,95,.19)}

.pl-cb-num{font-family:'DM Mono',monospace;font-size:10px;color:var(--muted);min-width:18px;text-align:right;flex-shrink:0}

.pl-cb-name-input{flex:1;min-width:160px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.15);border-radius:6px;padding:6px 10px;font-size:12px;font-weight:600;color:#fff;font-family:Inter,sans-serif;outline:none;transition:border-color .15s}
.pl-cb-name-input::placeholder{color:rgba(255,255,255,.3);font-weight:400}
.pl-cb-name-input:focus{border-color:var(--gold);box-shadow:0 0 0 2px rgba(217,183,95,.12)}

/* ── Per-client bid selector ── */
.pl-cb-sel{height:32px;padding:0 10px;border-radius:6px;font-family:'DM Mono',monospace;font-size:10px;font-weight:700;letter-spacing:.04em;cursor:pointer;outline:none;transition:all .15s;flex-shrink:0;min-width:150px}
.pl-cb-sel option{background:#1a2744;color:#fff;font-weight:400}

.pl-cb-none{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.18);color:var(--muted)}
.pl-cb-go{background:rgba(67,197,158,.2);border:1px solid rgba(67,197,158,.45);color:#6ee7c7}
.pl-cb-go option{background:#145a32}
.pl-cb-nobid{background:rgba(255,123,123,.2);border:1px solid rgba(255,123,123,.45);color:#ffaaaa}
.pl-cb-nobid option{background:#7b2020}
.pl-cb-hold{background:rgba(255,191,95,.18);border:1px solid rgba(255,191,95,.4);color:#ffd580}
.pl-cb-hold option{background:#7a5500}

/* ── Remove button ── */
.pl-cb-remove{width:28px;height:28px;border-radius:6px;border:1px solid rgba(255,123,123,.25);background:rgba(255,123,123,.1);color:var(--red);font-size:16px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s;line-height:1}
.pl-cb-remove:hover{background:rgba(255,123,123,.25);border-color:rgba(255,123,123,.5)}

/* ── Add client button ── */
.pl-cb-add-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 16px;background:var(--gold-soft);border:1px solid var(--gold-brd);border-radius:7px;color:var(--gold);font-family:'DM Mono',monospace;font-size:10px;font-weight:700;letter-spacing:.06em;cursor:pointer;transition:all .15s}
.pl-cb-add-btn:hover{background:var(--gold);color:#141414;border-color:var(--gold)}

/* ── Add-to-Tracker client team preview ── */
.add-sol-team-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 10px 0 2px;
}
.add-sol-team-chip {
  display: flex;
  align-items: center;
  gap: 5px;
  background: rgba(255,255,255,.06);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 4px 9px;
  font-size: 11px;
}
.add-sol-team-lbl {
  color: var(--muted);
  font-family: 'DM Mono', monospace;
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: .07em;
}
.add-sol-team-val {
  color: #e2e8f0;
  font-weight: 600;
}

/* ── Skeleton / shimmer shared utilities ── */
@keyframes skelShimmer{0%{background-position:-600px 0}100%{background-position:600px 0}}
.skel-line{display:block;border-radius:4px;background:linear-gradient(90deg,rgba(255,255,255,.04) 25%,rgba(255,255,255,.11) 50%,rgba(255,255,255,.04) 75%);background-size:1200px 100%;animation:skelShimmer 1.6s linear infinite}
/* Solicitation card skeleton */
.sol-skeleton-grid{display:flex;flex-direction:column;gap:14px}
.sol-skeleton-card{background:linear-gradient(180deg,rgba(22,32,58,.98),rgba(16,22,40,1));border:1px solid var(--line);border-left:3px solid rgba(112,160,255,.18);border-radius:10px;overflow:hidden}
.sol-skeleton-card-hd{padding:16px 20px 14px;background:rgba(255,255,255,.04);border-bottom:1px solid var(--line);display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.sol-skeleton-card-bd{padding:12px 20px 14px;display:flex;flex-direction:column;gap:8px}
/* Queue item skeleton */
.queue-skeleton-card{background:linear-gradient(180deg,rgba(22,32,58,.98),rgba(16,22,40,1));border:1px solid var(--line);border-left:3px solid rgba(67,197,158,.18);border-radius:10px;padding:16px 20px;margin-bottom:12px;display:flex;flex-direction:column;gap:9px}
/* ── News live-feed additions ── */
.news-loading-skeleton{padding:24px 0;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}
.news-skeleton-card{background:rgba(255,255,255,.06);border:1px solid var(--line);border-top:3px solid rgba(217,183,95,.25);border-radius:10px;padding:16px 18px;min-height:160px;display:flex;flex-direction:column;gap:9px}
@keyframes skelPulse{0%,100%{opacity:.5}50%{opacity:1}}
.news-refresh-btn{display:inline-flex;align-items:center;gap:4px;margin-left:10px;padding:3px 10px;border-radius:999px;border:1px solid var(--gold-brd);background:var(--gold-soft);color:var(--gold);font-family:'DM Mono',monospace;font-size:8px;font-weight:700;letter-spacing:.08em;cursor:pointer;transition:all .15s;vertical-align:middle}
.news-refresh-btn:hover{background:var(--gold);color:#141414;border-color:var(--gold)}
.news-last-refreshed{margin-left:8px;font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.08em;color:var(--muted);vertical-align:middle}
.news-empty-state{padding:36px 24px;text-align:center;color:var(--muted);font-size:.9rem;background:rgba(255,255,255,.04);border:1px dashed var(--line);border-radius:10px;line-height:1.7;grid-column:1/-1}

/* ── News Magazine Layout ── */
.news-magazine{display:flex;flex-direction:column;gap:22px}
/* Headliner row wrapper — stacks headliner + secondary vertically */
.news-headliner-row{display:flex;flex-direction:column;gap:18px}
/* Headliner: side-by-side (image left 54%, text right 46%), fixed height so it's prominent but not full-screen */
.news-headliner{display:grid;grid-template-columns:minmax(0,54%) minmax(0,46%);height:300px;background:linear-gradient(180deg,rgba(22,32,58,.98),rgba(16,22,40,1));border:1px solid var(--line);border-top:3px solid var(--gold);border-radius:12px;overflow:hidden;text-decoration:none;transition:box-shadow .18s,transform .18s;color:inherit}
.news-headliner:hover{transform:translateY(-2px);box-shadow:0 10px 36px rgba(0,0,0,.5)}
/* Image pane fills the grid cell height entirely */
.news-headliner-img-wrap{position:relative;overflow:hidden;background:rgba(255,255,255,.05)}
.news-headliner-img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;transition:transform .4s}
.news-headliner:hover .news-headliner-img{transform:scale(1.04)}
.news-headliner-img-placeholder{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,rgba(217,183,95,.1),rgba(112,160,255,.08))}
.news-img-logo-caption{position:absolute;bottom:6px;right:8px;font-family:'DM Mono',monospace;font-size:7.5px;letter-spacing:.08em;color:rgba(255,255,255,.75);background:rgba(0,0,0,.6);padding:2px 7px;border-radius:3px}
.news-headliner-body{padding:22px 22px 22px;display:flex;flex-direction:column;gap:10px;overflow:hidden}
.news-headliner-kicker{display:flex;justify-content:space-between;gap:12px;font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.news-headliner-title{font-family:Manrope,sans-serif;font-size:1.25rem;font-weight:800;color:#fff;line-height:1.25;letter-spacing:-.025em;overflow:hidden;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical}
.news-headliner-preview{color:var(--text);font-size:.83rem;line-height:1.68;overflow:hidden;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}
.news-headliner-source{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:auto}
@media(max-width:860px){
  .news-headliner{grid-template-columns:1fr;height:auto}
  .news-headliner-img-wrap{padding-top:52%;position:relative}
  .news-headliner-img-wrap .news-headliner-img,
  .news-headliner-img-wrap .news-headliner-img-placeholder{position:absolute;top:0;left:0;width:100%;height:100%}
}
/* Secondary group: 3-column portrait card grid with images on top */
.news-secondary-group{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:860px){.news-secondary-group{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.news-secondary-group{grid-template-columns:1fr}}
.news-secondary-item{display:flex;flex-direction:column;background:linear-gradient(180deg,rgba(22,32,58,.98),rgba(16,22,40,1));border:1px solid var(--line);border-top:3px solid var(--gold-brd);border-radius:10px;overflow:hidden;text-decoration:none;transition:border-top-color .18s,box-shadow .18s,transform .18s;color:inherit}
.news-secondary-item:hover{border-top-color:var(--gold);box-shadow:0 6px 22px rgba(0,0,0,.4);transform:translateY(-1px)}
/* Image wrap uses padding-top ratio for responsive aspect ratio */
.news-secondary-img-wrap{position:relative;width:100%;padding-top:58%;overflow:hidden;background:rgba(255,255,255,.04);flex-shrink:0}
.news-secondary-img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;transition:transform .35s}
.news-secondary-item:hover .news-secondary-img{transform:scale(1.04)}
.news-secondary-img-placeholder{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,rgba(217,183,95,.09),rgba(112,160,255,.07))}
.news-secondary-body{flex:1;padding:12px 14px 14px;display:flex;flex-direction:column;gap:5px}
.news-secondary-kicker{font-family:'DM Mono',monospace;font-size:7px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold)}
.news-secondary-title{font-family:Manrope,sans-serif;font-size:.875rem;font-weight:700;color:#fff;line-height:1.3;overflow:hidden;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}
.news-secondary-meta{font-family:'DM Mono',monospace;font-size:7.5px;letter-spacing:.06em;color:var(--muted);margin-top:auto}
/* Tertiary 4-card grid — bigger images */
.news-tertiary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
@media(max-width:860px){.news-tertiary-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.news-tertiary-grid{grid-template-columns:1fr}}
.news-tertiary-item{display:flex;flex-direction:column;background:linear-gradient(180deg,rgba(22,32,58,.98),rgba(16,22,40,1));border:1px solid var(--line);border-top:2px solid var(--gold-brd);border-radius:8px;overflow:hidden;text-decoration:none;transition:border-top-color .18s,box-shadow .18s;color:inherit}
.news-tertiary-item:hover{border-top-color:var(--gold);box-shadow:0 4px 14px rgba(0,0,0,.35)}
.news-tertiary-img{width:100%;height:150px;object-fit:cover}
.news-tertiary-img-placeholder{width:100%;height:150px;background:linear-gradient(135deg,rgba(217,183,95,.08),rgba(112,160,255,.06))}
.news-tertiary-body{padding:10px 12px 12px;display:flex;flex-direction:column;gap:4px;flex:1}
.news-tertiary-kicker{font-family:'DM Mono',monospace;font-size:7px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold)}
.news-tertiary-title{font-family:Manrope,sans-serif;font-size:.8rem;font-weight:700;color:#fff;line-height:1.3;overflow:hidden;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}
.news-tertiary-meta{font-family:'DM Mono',monospace;font-size:7px;letter-spacing:.06em;color:var(--muted);margin-top:auto}
/* Text-only follow-up list */
.news-text-list{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:8px;overflow:hidden}
.news-text-item{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:10px 16px;border-bottom:1px solid var(--line);text-decoration:none;transition:background .15s;color:inherit}
.news-text-item:last-child{border-bottom:none}
.news-text-item:hover{background:rgba(255,255,255,.04)}
.news-text-item-title{font-size:.85rem;font-weight:600;color:#fff;flex:1;line-height:1.4;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
.news-text-item-meta{font-family:'DM Mono',monospace;font-size:7.5px;letter-spacing:.06em;color:var(--muted);flex-shrink:0;white-space:nowrap}

/* Logo fallback images — contained, centred; dark background so logos read correctly */
.news-img--logo{object-fit:contain!important;background:linear-gradient(135deg,rgba(18,26,48,1),rgba(10,15,28,1))!important}
/* ── Headliner logo wrap: flex-centre, reduced height so a slim logo isn't dwarfed ── */
.news-headliner-img-wrap.logo-wrap{display:flex!important;align-items:center!important;justify-content:center!important;background:linear-gradient(135deg,rgba(18,26,48,1),rgba(10,15,28,1))!important}
.news-headliner-img-wrap.logo-wrap .news-headliner-img{position:static!important;width:auto!important;height:auto!important;max-width:62%!important;max-height:90px!important;padding:0!important;object-fit:contain!important;filter:brightness(1.08) drop-shadow(0 2px 8px rgba(0,0,0,.5))}
/* ── Secondary logo wrap: shorter container, flex-centred ── */
.news-secondary-img-wrap.logo-wrap{padding-top:0!important;height:88px!important;display:flex!important;align-items:center!important;justify-content:center!important;background:linear-gradient(135deg,rgba(18,26,48,1),rgba(10,15,28,1))!important}
.news-secondary-img-wrap.logo-wrap .news-secondary-img{position:static!important;width:auto!important;height:auto!important;max-width:58%!important;max-height:52px!important;padding:0!important;object-fit:contain!important;filter:brightness(1.08) drop-shadow(0 1px 6px rgba(0,0,0,.45))}
/* ── Tertiary logo item: reduced height, dark bg ── */
.news-tertiary-item.logo-item>.news-tertiary-img{height:80px!important;object-fit:contain!important;padding:14px 20px!important;background:linear-gradient(135deg,rgba(18,26,48,1),rgba(10,15,28,1))!important;filter:brightness(1.08)}
/* ── Text-only list logo: dark bg, contain ── */
.news-text-item-logo.news-img--logo{background:linear-gradient(135deg,rgba(18,26,48,1),rgba(10,15,28,1))!important;padding:5px!important}
/* Caption for tertiary logo images (sits below the img in the normal flow) */
.news-tertiary-logo-caption{font-family:'DM Mono',monospace;font-size:7px;letter-spacing:.08em;color:var(--muted);padding:3px 8px;text-align:center}
/* Text-only list — thumbnail on the left */
.news-text-item-logo{width:38px;height:38px;object-fit:cover;border-radius:5px;flex-shrink:0}
.news-text-item-logo-placeholder{width:38px;height:38px;background:linear-gradient(135deg,rgba(217,183,95,.09),rgba(112,160,255,.07));border-radius:5px;flex-shrink:0}

/* ── Compact magazine card grid (new uniform portrait-card layout) ── */
/* 4-column grid on desktop, responsive down to 1 col on mobile */
.news-mag-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;align-items:stretch}
@media(max-width:1000px){.news-mag-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:680px){.news-mag-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:400px){.news-mag-grid{grid-template-columns:1fr}}
/* ── Sector-column magazine layout (unified reader view) ── */
/* Outer container: sectors flow left-to-right; each sector is one column.
   auto-fill lets the grid add/remove columns as sectors are published. */
.news-mag-columns{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;align-items:start}
@media(max-width:600px){.news-mag-columns{grid-template-columns:1fr}}
/* One sector = one column block */
.news-sector-col{display:flex;flex-direction:column;min-width:0}
.news-sector-col-header{margin-bottom:10px}
.news-sector-col-header .news-sector-section-header{margin-bottom:0}
/* Articles stack vertically within the column */
.news-sector-col-articles{display:flex;flex-direction:column;gap:10px}
/* Hero card inside a column: full-width (cancel the span-2 grid rule) */
.news-sector-col-articles .news-mag-card--hero{grid-column:unset}
/* ── Admin/curation panel grid (legacy per-sector flat grid) ── */

.news-mag-card{display:flex;flex-direction:column;background:linear-gradient(180deg,rgba(22,32,58,.98),rgba(16,22,40,1));border:1px solid var(--line);border-top:2px solid var(--gold-brd);border-radius:8px;overflow:hidden;text-decoration:none;color:inherit;transition:border-top-color .18s,box-shadow .18s,transform .15s;position:relative}
.news-mag-card:hover{border-top-color:var(--gold);box-shadow:0 4px 18px rgba(0,0,0,.4);transform:translateY(-1px)}
/* Image pane: 16:9-ish aspect ratio */
.news-mag-img-wrap{width:100%;padding-top:58%;position:relative;overflow:hidden;background:rgba(255,255,255,.04);flex-shrink:0}
.news-mag-img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;transition:transform .35s}
.news-mag-card:hover .news-mag-img{transform:scale(1.04)}
.news-mag-img-placeholder{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,rgba(217,183,95,.09),rgba(112,160,255,.07))}
/* Card body: topic kicker, headline, preview snippet, source */
.news-mag-card-body{flex:1;padding:9px 11px 11px;display:flex;flex-direction:column;gap:4px}
.news-mag-kicker{display:flex;justify-content:space-between;align-items:center;gap:4px;font-family:'DM Mono',monospace;font-size:7px;letter-spacing:.12em;text-transform:uppercase}
.news-mag-date{color:var(--muted);flex-shrink:0}
.news-mag-title{font-family:Manrope,sans-serif;font-size:.87rem;font-weight:700;color:#fff;line-height:1.3;overflow:hidden;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}
.news-mag-preview{font-size:.75rem;color:var(--text);line-height:1.6;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.news-mag-source{font-family:'DM Mono',monospace;font-size:7px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-top:auto}
/* Logo fallback in compact card: fixed-height dark box, contain */
.news-mag-img-wrap.logo-wrap{padding-top:0!important;height:72px!important;display:flex!important;align-items:center!important;justify-content:center!important;background:linear-gradient(135deg,rgba(18,26,48,1),rgba(10,15,28,1))!important}
.news-mag-img-wrap.logo-wrap .news-mag-img{position:static!important;width:auto!important;height:auto!important;max-width:55%!important;max-height:44px!important;object-fit:contain!important;filter:brightness(1.08) drop-shadow(0 1px 6px rgba(0,0,0,.45))}
/* Hero card: first article per sector spans two columns, larger headline */
.news-mag-card--hero{grid-column:span 2}
.news-mag-card--hero .news-mag-title{font-size:1.05rem;-webkit-line-clamp:4}
.news-mag-card--hero .news-mag-preview{font-size:.78rem;-webkit-line-clamp:3}
.news-mag-card--hero .news-mag-card-body{padding:12px 14px 14px;gap:6px}
/* On 1-col grids the hero span has no effect — already occupies the only column */
@media(max-width:400px){.news-mag-card--hero{grid-column:span 1}}
/* Lead card: full-width horizontal — image fills left 38%, large headline on right */
.news-mag-card--lead{grid-column:1/-1;flex-direction:row;min-height:230px;border-top-width:3px}
.news-mag-img-wrap--lead{width:38%;padding-top:0!important;align-self:stretch;flex-shrink:0}
.news-mag-card--lead .news-mag-card-body{padding:20px 22px;justify-content:center;gap:10px}
.news-mag-card--lead .news-mag-title{font-size:1.3rem;-webkit-line-clamp:5;font-weight:800;letter-spacing:-.01em}
.news-mag-card--lead .news-mag-preview{font-size:.84rem;-webkit-line-clamp:4;line-height:1.65}
.news-mag-card--lead .news-mag-kicker{font-size:8px}
.news-mag-card--lead .news-mag-source{font-size:8px}
@media(max-width:680px){.news-mag-card--lead{flex-direction:column;min-height:0}.news-mag-img-wrap--lead{width:100%!important;align-self:auto;padding-top:58%!important}}
/* Sector row header (legacy — used only in admin curation panels, not in unified reader view) */
.news-sector-row-header{grid-column:1/-1;padding-top:6px;margin-top:0;border-top:1px solid rgba(255,255,255,.05)}
.news-sector-row-header:first-child{padding-top:0;border-top:none}
.news-sector-row-header .news-sector-section-header{margin-bottom:6px}
.news-sector-row-header .news-sector-section-header::after{display:none}


.send-to-client-btn{color:#fff;background:rgba(112,160,255,.18);border:1px solid rgba(112,160,255,.35);padding:5px 10px;border-radius:4px;font-family:'DM Mono',monospace;font-size:9px;letter-spacing:.05em;cursor:pointer;transition:all .15s;white-space:nowrap;display:inline-flex;align-items:center;gap:5px}
.send-to-client-btn:hover{background:var(--blue);color:#141414;border-color:var(--blue)}

/* ── Admin delete badge on magazine articles ── */
.nc-mag-del-btn{position:absolute;top:6px;right:6px;z-index:20;background:rgba(200,30,30,.9);border:none;color:#fff;border-radius:4px;padding:3px 8px;font-size:10px;cursor:pointer;opacity:0;transition:opacity .2s;line-height:1.4}
.nc-mag-del-btn--visible{opacity:1}

/* ── Send to Client modal ── */
.stc-modal{max-width:760px;width:100%}
.stc-modal-bd{display:flex;flex-direction:column;gap:16px}
.stc-outlook-instruction{display:flex;flex-direction:column;gap:4px;background:rgba(67,197,158,.12);border:1px solid rgba(67,197,158,.35);border-radius:8px;padding:12px 16px;font-size:12px;color:#6ee7c7;line-height:1.55}
.stc-modal-ft-note{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:.04em;color:var(--muted);margin-left:auto;align-self:center}
.stc-preview-wrap{border:1px solid var(--line);border-radius:8px;overflow:hidden}
.stc-preview-label{padding:7px 14px;font-family:'DM Mono',monospace;font-size:8.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);background:rgba(255,255,255,.05);border-bottom:1px solid var(--line)}
.stc-preview-frame{width:100%;height:480px;border:none;display:block;background:#fff}

/* ── Bulk Send to Client modal ── */
.stc-bulk-modal{max-width:860px;width:100%}
.stc-bulk-modal-bd{display:flex;flex-direction:column;gap:16px}
.stc-bulk-checklist-wrap{border:1px solid var(--line);border-radius:8px;overflow:hidden}
.stc-bulk-checklist-hd{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;background:rgba(255,255,255,.05);border-bottom:1px solid var(--line)}
.stc-bulk-checklist-label{font-family:'DM Mono',monospace;font-size:8.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.stc-bulk-toggle-all-btn{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:.05em;background:transparent;border:1px solid rgba(255,255,255,.2);color:rgba(255,255,255,.55);border-radius:4px;padding:3px 10px;cursor:pointer;transition:all .15s}
.stc-bulk-toggle-all-btn:hover{border-color:rgba(217,183,95,.5);color:#d9b75f}
.stc-bulk-checklist{display:flex;flex-direction:column;gap:0;max-height:180px;overflow-y:auto;padding:6px 8px}
.stc-bulk-item{display:flex;align-items:flex-start;gap:8px;padding:6px 8px;border-radius:5px;cursor:pointer;transition:background .12s;line-height:1.4}
.stc-bulk-item:hover{background:rgba(255,255,255,.06)}
.stc-bulk-item-checked{background:rgba(217,183,95,.07)}
.stc-bulk-cb{flex-shrink:0;margin-top:2px;accent-color:#d9b75f;cursor:pointer}
.stc-bulk-item-title{font-family:Arial,sans-serif;font-size:12px;color:rgba(255,255,255,.85)}
/* Section-level send button in queue header */
.queue-section-send-btn{margin-left:auto;flex-shrink:0}

/* ── Board: client sub-rows ── */
.rt-client-rows { border-top: 1px solid rgba(255,255,255,.1); padding: 5px 6px 4px; display: flex; flex-direction: column; gap: 4px; }
.rt-client-row { display: flex; align-items: center; gap: 5px; padding: 4px 7px; border-radius: 5px; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.1); cursor: grab; transition: background .13s, border-color .13s; user-select: none; }
.rt-client-row:hover { background: rgba(255,255,255,.10); border-color: rgba(255,255,255,.2); }
.rt-client-row.dragging { opacity: .45; }
.rt-client-row-bid-go { background: rgba(67,197,158,.18); border-color: rgba(67,197,158,.4); }
.rt-client-row-bid-go:hover { background: rgba(67,197,158,.26); }
.rt-client-row-bid-nobid { background: rgba(255,90,90,.18); border-color: rgba(255,90,90,.4); }
.rt-client-row-bid-nobid:hover { background: rgba(255,90,90,.26); }
.rt-client-row-bid-hold { background: rgba(255,191,95,.15); border-color: rgba(255,191,95,.4); }
.rt-client-row-bid-hold:hover { background: rgba(255,191,95,.22); }
.rt-client-stage-dot { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; }
.rt-client-name { flex: 1; min-width: 0; font-size: 10px; font-weight: 700; color: #fff; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.rt-client-name-input { flex: 1; min-width: 0; max-width: 110px; font-size: 11px; font-weight: 700; color: #fff; background: transparent; border: none; border-bottom: 1px solid transparent; outline: none; padding: 1px 2px; font-family: inherit; transition: border-color .15s; }
.rt-client-name-input::placeholder { color: rgba(255,255,255,.3); font-weight: 400; }
.rt-client-name-input:focus { border-bottom-color: rgba(217,183,95,.55); background: rgba(255,255,255,.05); border-radius: 3px 3px 0 0; }
.rt-client-bid-badge { font-family: 'DM Mono', monospace; font-size: 8px; font-weight: 800; padding: 1px 5px; border-radius: 3px; flex-shrink: 0; letter-spacing: .04em; }
.rt-client-bid-go { background: rgba(67,197,158,.2); color: #6ee7c7; border: 1px solid rgba(67,197,158,.4); }
.rt-client-bid-nobid { background: rgba(255,123,123,.2); color: #ffaaaa; border: 1px solid rgba(255,123,123,.4); }
.rt-client-bid-hold { background: rgba(255,191,95,.15); color: #ffd580; border: 1px solid rgba(255,191,95,.35); }
.rt-client-bid-none { color: var(--muted); font-family: 'DM Mono', monospace; font-size: 9px; }
.rt-client-wf-btn { width: 20px; height: 20px; border-radius: 4px; border: none; font-size: 10px; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; transition: all .13s; flex-shrink: 0; }
.rt-client-wf-off { background: rgba(255,255,255,.07); color: rgba(255,255,255,.3); border: 1px solid rgba(255,255,255,.12) !important; }
.rt-client-wf-on { background: rgba(67,197,158,.2); color: #6ee7c7; border: 1px solid rgba(67,197,158,.4) !important; }
.rt-client-remove-btn { width: 18px; height: 18px; border-radius: 4px; border: none; font-size: 12px; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; background: transparent; color: rgba(255,255,255,.3); flex-shrink: 0; transition: all .13s; margin-left: auto; }
.rt-client-remove-btn:hover { background: rgba(220,53,69,.2); color: #ff8a9a; border: 1px solid rgba(220,53,69,.35); }
.rt-client-add-btn { display: block; width: 100%; margin-top: 5px; padding: 4px 0; background: transparent; border: 1px dashed rgba(217,183,95,.3); border-radius: 5px; color: rgba(217,183,95,.6); font-family: 'DM Mono', monospace; font-size: 9px; font-weight: 700; letter-spacing: .08em; cursor: pointer; text-align: center; transition: all .15s; }
.rt-client-add-btn:hover { background: var(--gold-soft); border-color: var(--gold-brd); color: var(--gold); }
.rt-col-client-count { font-size: 9px; color: var(--muted); font-family: 'DM Mono', monospace; margin-left: 3px; }
.rt-opp-title-row { display: flex; align-items: flex-start; gap: 6px; }
.rt-opp-title-row .rt-opp-title { flex: 1; }
.rt-bd-card-actions { display: flex; align-items: center; gap: 4px; flex-shrink: 0; margin-top: 1px; }
.rt-bd-staff { display: flex; gap: 3px; align-items: center; }
.rt-bd-staff-pip { width: 20px; height: 20px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 7px; font-weight: 800; color: #fff; flex-shrink: 0; letter-spacing: 0; cursor: default; }
.rt-bd-comment-btn { background: transparent; border: none; font-size: 12px; cursor: pointer; padding: 0; line-height: 1; opacity: .65; transition: opacity .13s; flex-shrink: 0; }
.rt-bd-comment-btn:hover { opacity: 1; }
.rt-bd-link-btn { background: transparent; border: none; font-size: 11px; cursor: pointer; padding: 0; line-height: 1; opacity: .65; transition: opacity .13s; flex-shrink: 0; color: var(--gold); }
.rt-bd-link-btn:hover { opacity: 1; }
.rt-bd-comment-popup { position: fixed; z-index: 9999; background: #1a2744; border: 1px solid rgba(255,255,255,.22); border-radius: 8px; box-shadow: 0 8px 32px rgba(0,0,0,.5); padding: 0; min-width: 220px; max-width: 320px; bottom: 60px; right: 24px; }
.rt-bd-comment-popup-hd { display: flex; align-items: center; justify-content: space-between; padding: 8px 12px 6px; border-bottom: 1px solid rgba(255,255,255,.12); font-family: 'DM Mono', monospace; font-size: 10px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--muted); }
.rt-bd-comment-popup-hd button { background: transparent; border: none; color: var(--muted); font-size: 16px; cursor: pointer; line-height: 1; padding: 0; }
.rt-bd-comment-popup-hd button:hover { color: var(--text); }
.rt-bd-comment-popup-body { padding: 10px 12px 12px; font-size: 12px; color: var(--text); white-space: pre-wrap; line-height: 1.5; }

/* ── Pipeline: extended client row ── */
.pl-cb-stage-sel { height: 28px; padding: 0 7px; border-radius: 5px; font-family: 'DM Mono', monospace; font-size: 9px; font-weight: 700; cursor: pointer; outline: none; background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.18); color: var(--text); flex-shrink: 0; min-width: 110px; }
.pl-cb-stage-sel option { background: #1a2744; color: #fff; }
.pl-cb-wf-btn { width: 26px; height: 26px; border-radius: 6px; border: none; font-size: 13px; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; transition: all .13s; flex-shrink: 0; }
.pl-cb-wf-off { background: rgba(255,255,255,.07); color: rgba(255,255,255,.3); border: 1px solid rgba(255,255,255,.15) !important; }
.pl-cb-wf-on { background: rgba(67,197,158,.2); color: #6ee7c7; border: 1px solid rgba(67,197,158,.4) !important; }
.pl-cb-staff-hint { font-family: 'DM Mono', monospace; font-size: 8.5px; color: var(--muted); letter-spacing: .04em; flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* ── Add-to-Tracker: multi-client picker ── */
.add-sol-client-list { display: flex; flex-direction: column; gap: 7px; margin-bottom: 10px; }
.add-sol-client-chip { display: flex; align-items: flex-start; gap: 8px; padding: 8px 10px; background: rgba(255,255,255,.05); border: 1px solid var(--line); border-radius: 8px; }
.add-sol-client-chip-evp-pending { border-color: rgba(251,191,36,.35); background: rgba(251,191,36,.05); }
.add-sol-client-chip-name { font-size: 12px; font-weight: 700; color: #fff; flex: 1; }
.add-sol-client-chip-remove { background: rgba(255,123,123,.1); border: 1px solid rgba(255,123,123,.25); color: var(--red); width: 22px; height: 22px; border-radius: 5px; cursor: pointer; font-size: 14px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.add-sol-client-chip-remove:hover { background: rgba(255,123,123,.25); }
.add-sol-multi-row { display: flex; gap: 8px; align-items: center; }
.add-sol-multi-sel { flex: 1; }
.add-sol-add-client-btn { padding: 7px 14px; background: var(--gold-soft); border: 1px solid var(--gold-brd); border-radius: 6px; color: var(--gold); font-family: 'DM Mono', monospace; font-size: 9px; font-weight: 700; letter-spacing: .06em; cursor: pointer; white-space: nowrap; transition: all .15s; }
.add-sol-add-client-btn:hover { background: var(--gold); color: #141414; border-color: var(--gold); }

/* ── Add-to-Tracker destination radio (Response Tracker / Just Tracking) ── */
.add-sol-dest-row { display: flex; gap: 10px; margin-bottom: 8px; }
.add-sol-dest-opt { flex: 1; display: flex; align-items: center; gap: 8px; padding: 9px 12px; background: rgba(255,255,255,.04); border: 1px solid var(--line); border-radius: 8px; cursor: pointer; font-size: 12px; font-weight: 600; color: #e8e8e8; transition: all .15s; }
.add-sol-dest-opt:hover { border-color: var(--gold-brd); background: rgba(217,183,95,.08); }
.add-sol-dest-opt input[type="radio"] { accent-color: var(--gold); cursor: pointer; }
.add-sol-dest-opt input[type="radio"]:checked + span { color: var(--gold); }

/* ── Additional Opportunities board (uses #rt-board styling) ── */
#ao-board { display: flex; gap: 10px; padding: 14px 14px 8px; align-items: stretch; width: 100%; box-sizing: border-box; overflow-x: auto; }

/* ── Solicitation Dashboard: title becomes a clickable link (replaces SAM.gov button) ── */
.sol-title-link { color: inherit; text-decoration: none; cursor: pointer; transition: color .15s; }
.sol-title-link:hover { color: var(--gold); text-decoration: underline; text-underline-offset: 3px; }


/* ── Searchable client dropdown (board & pipeline) ── */
/* Portal: fixed-position container appended to <body> so it escapes overflow:hidden on cards */
#rt-cd-portal { position: fixed; z-index: 99999; display: none; }
/* Trigger button (closed & open states) — board view */
.rt-client-dd-trigger { flex: 1; min-width: 0; max-width: 150px; font-size: 11px; font-weight: 700; color: #fff; background: transparent; border: none; border-bottom: 1px solid transparent; outline: none; padding: 1px 2px; font-family: inherit; cursor: pointer; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; transition: border-color .15s; display: block; text-align: left; }
.rt-client-dd-trigger:hover, .rt-client-dd-trigger:focus { border-bottom-color: rgba(217,183,95,.55); background: rgba(255,255,255,.05); border-radius: 3px 3px 0 0; }
.rt-client-dd-open { border-bottom-color: rgba(217,183,95,.55) !important; background: rgba(255,255,255,.05) !important; border-radius: 3px 3px 0 0 !important; }
.rt-cd-placeholder { color: rgba(255,255,255,.3); font-weight: 400; font-size: 10px; }
/* Dropdown panel — rendered inside #rt-cd-portal */
.rt-client-dd-panel { background: #1a2744; border: 1px solid rgba(217,183,95,.45); border-radius: 6px; box-shadow: 0 10px 32px rgba(0,0,0,.65); display: flex; flex-direction: column; overflow: hidden; width: 100%; }
.rt-client-dd-search { width: 100%; box-sizing: border-box; padding: 8px 12px; background: rgba(255,255,255,.08); border: none; border-bottom: 1px solid rgba(255,255,255,.12); color: #fff; font-size: 12px; font-family: inherit; outline: none; }
.rt-client-dd-search::placeholder { color: rgba(255,255,255,.35); }
.rt-client-dd-list { max-height: 320px; overflow-y: auto; scrollbar-width: thin; scrollbar-color: rgba(217,183,95,.3) transparent; }
.rt-cd-option { padding: 7px 12px; font-size: 12px; font-weight: 600; color: #e8e8e8; cursor: pointer; transition: background .1s; }
.rt-cd-option:hover { background: rgba(217,183,95,.18); color: #fff; }
.rt-cd-option-sel { background: rgba(217,183,95,.22); color: var(--gold); }
.rt-cd-no-results { padding: 10px 12px; font-size: 11px; color: var(--muted); font-style: italic; }
/* Pipeline trigger — styled to match old .pl-cb-name-input */
.pl-cb-row .rt-client-dd-trigger { flex: 1; min-width: 160px; max-width: none; font-size: 12px; background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.15); border-radius: 6px; padding: 6px 10px; min-height: 32px; line-height: 1.4; display: flex; align-items: center; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.pl-cb-row .rt-client-dd-trigger:hover, .pl-cb-row .rt-client-dd-trigger:focus { border-color: var(--gold); box-shadow: 0 0 0 2px rgba(217,183,95,.12); background: rgba(255,255,255,.07); border-radius: 6px; }
.pl-cb-row .rt-client-dd-open { border-color: var(--gold) !important; box-shadow: 0 0 0 2px rgba(217,183,95,.12) !important; }

/* ── Client-row staffer bubbles (board view) ── */
.rt-client-staff-pips { display: flex; gap: 2px; align-items: center; flex-shrink: 0; }
.rt-client-staff-pip { width: 16px; height: 16px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 6px; font-weight: 800; color: #fff; flex-shrink: 0; letter-spacing: 0; cursor: default; }

/* ── Most Relevant Tab ─────────────────────────────────────────────────────── */
/* Nav item: star icon */
.mr-nav-item .nav-label { color: #f5c842; }
.mr-nav-item.active .nav-label { color: #f5c842; }
.mr-nav-icon { font-size: 18px; line-height: 1; display: flex; align-items: center; justify-content: center; width: 32px; height: 32px; background: rgba(245,200,66,.15); border: 1px solid rgba(245,200,66,.3); border-radius: 6px; }
/* Panel header */
.mr-page-header { border-left-color: #f5c842 !important; }
.mr-page-header .sector-page-title { color: #f5c842; }
.mr-page-icon { font-size: 20px; line-height: 1; display: flex; align-items: center; justify-content: center; width: 40px; height: 40px; background: rgba(245,200,66,.15); border: 1px solid rgba(245,200,66,.3); border-radius: 8px; flex-shrink: 0; }
.sector-page-desc { font-size: 11px; color: var(--muted); margin-top: 2px; }
/* Client tag and keyword chips in the Most Relevant panel */
.mr-client-tag { background: rgba(245,200,66,.15) !important; border-color: rgba(245,200,66,.4) !important; }
.mr-client-tag .tm-val { color: #f5c842 !important; }
.mr-keyword-tag { background: rgba(67,197,158,.1) !important; border-color: rgba(67,197,158,.35) !important; }
.mr-keyword-tag .tm-val { color: #6ee7c7 !important; }
.mr-relevance-strip { border-top: 1px solid rgba(245,200,66,.15); background: rgba(245,200,66,.04) !important; }
/* Loading state */
.mr-loading-state { padding: 40px 20px; text-align: center; color: var(--muted); font-style: italic; font-size: 14px; }
.mr-loading-dots::after { content: ''; animation: mr-dots 1.2s steps(3,end) infinite; }
@keyframes mr-dots { 0%,100% { content: '.'; } 33% { content: '..'; } 66% { content: '...'; } }
/* Empty state */
.mr-empty-state { padding: 60px 20px; text-align: center; }
.mr-empty-icon { font-size: 40px; margin-bottom: 16px; }
.mr-empty-title { font-size: 16px; font-weight: 700; color: var(--text); margin-bottom: 8px; }
.mr-empty-sub { font-size: 13px; color: var(--muted); max-width: 480px; margin: 0 auto; line-height: 1.6; }

/* ═══════════════════════════════════════════════════════
   DEVICE-CLASS OVERRIDES
   Applied via JS — html.device-phone / .device-tablet / .device-desktop
   ═══════════════════════════════════════════════════════ */

/* Phone-specific */
html.device-phone .rt-board { flex-wrap:nowrap; overflow-x:auto; -webkit-overflow-scrolling:touch; }
html.device-phone .rt-col   { min-width:260px; flex:0 0 260px; }
html.device-phone .news-secondary-group { grid-template-columns:1fr; }
html.device-phone .news-tertiary-grid   { grid-template-columns:1fr; }
html.device-phone .sol-actions          { flex-wrap:wrap; gap:4px; }
html.device-phone .topbar-inner         { padding:6px 10px; }
html.device-phone .tab-nav              { padding:0 8px; }

/* Tablet-specific */
html.device-tablet .rt-col  { min-width:220px; }
html.device-tablet .left-nav{ width:200px; }

/* Touch device — larger hit targets */
html.has-touch .sector-nav-item  { min-height:48px; }
html.has-touch .tab-nav a        { min-height:44px; }
html.has-touch .rt-nav-tab       { padding:8px 14px; }
/* Prevent double-tap zoom on interactive elements without blocking native gestures */
html.has-touch button,
html.has-touch a,
html.has-touch [role="button"] { touch-action: manipulation; }

/* Mobile nav toggle button */
.mobile-nav-toggle {
  display: none;
  width: 40px;
  height: 40px;
  border-radius: 8px;
  border: 1px solid var(--gold-brd);
  background: var(--gold-soft);
  color: var(--gold);
  font-size: 18px;
  cursor: pointer;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-left: 8px;
}
@media (max-width: 767px) {
  .mobile-nav-toggle { display: inline-flex; }
}

/* Nav overlay backdrop */
.nav-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, .55);
  z-index: 499;
  backdrop-filter: blur(2px);
}
.nav-overlay.open { display: block; }

/* Mobile horizontal sector/client strip — replaces the hidden drawer */
@media (max-width: 767px) {
  .left-nav {
    position: static !important;
    top: auto !important;
    left: auto !important;
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    transform: none !important;
    transition: none !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    border-right: none !important;
    border-bottom: 1px solid var(--line) !important;
    border-radius: 0 !important;
    z-index: auto !important;
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    gap: 4px !important;
    padding: 8px 10px !important;
    scrollbar-width: none !important;
    -webkit-overflow-scrolling: touch;
    background: rgba(15,21,37,.97);
  }
  .left-nav::-webkit-scrollbar { display: none !important; }
  /* .open class is no-op on mobile strip */
  .left-nav.open { transform: none !important; }

  /* Stack content below the strip */
  .app-shell { flex-direction: column !important; }
  .news-page { flex-direction: column !important; }

  /* Hide the "Sectors" label — not needed in the strip */
  .left-nav .nav-section-label { display: none !important; }

  /* Sector/client nav items become horizontal pills */
  .sector-nav-item {
    flex-direction: row !important;
    flex-shrink: 0 !important;
    height: auto !important;
    min-height: 34px !important;
    border-left: none !important;
    border-bottom: 2px solid transparent !important;
    border-radius: 18px !important;
    padding: 5px 12px !important;
    gap: 5px !important;
    white-space: nowrap !important;
    background: rgba(255,255,255,.05) !important;
  }
  .sector-nav-item:hover {
    border-left-color: transparent !important;
    background: rgba(217,183,95,.09) !important;
    border-bottom-color: rgba(217,183,95,.4) !important;
  }
  .sector-nav-item.active {
    border-left-color: transparent !important;
    background: linear-gradient(90deg,rgba(217,183,95,.2),rgba(217,183,95,.07)) !important;
    border-bottom: 2px solid var(--gold) !important;
  }
  /* Hide icon inside pill to keep strip compact */
  .sector-nav-item .nav-icon { display: none !important; }
  /* Keep label and count inline */
  .sector-nav-item .nav-label-wrap { flex: 0 0 auto !important; min-width: 0 !important; }
  .sector-nav-item .nav-label {
    font-size: 11px !important;
    white-space: nowrap !important;
    overflow: visible !important;
    text-overflow: unset !important;
  }
  .sector-nav-item .nav-count {
    font-size: 9px !important;
    padding: 1px 5px !important;
  }
  /* Most-Relevant star pill label keeps gold color */
  .mr-nav-item .nav-label, .mr-nav-item.active .nav-label { color: #f5c842 !important; }

  /* Queue nav icon (initials) — hide on phone pill strip */
  .queue-nav-icon { display: none !important; }

  /* Mobile nav toggle: show ONLY when on Proposal Workshop (handled via body data attr) */
  .mobile-nav-toggle { display: none !important; }
  body[data-active-tab="proposal-workshop"] .mobile-nav-toggle { display: inline-flex !important; }

  /* pw-sidebar drawer remains for Proposal Workshop only */
  .pw-sidebar {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 80vw !important;
    max-width: 280px !important;
    height: 100vh !important;
    z-index: 500 !important;
    transform: translateX(-100%);
    transition: transform .28s ease;
  }
  .pw-sidebar.open {
    transform: translateX(0);
  }
  .pw-shell {
    flex-direction: column;
  }
  .pw-main {
    width: 100%;
  }
}

@media (max-width: 767px) {
  .app-shell > .main-content,
  .news-page > .main-content {
    width: 100% !important;
    min-width: 0 !important;
  }
  .app-shell > .queue-main {
    width: 100% !important;
    min-width: 0 !important;
  }
}

/* ── Print styles ── */
@media print {
  .topbar, .tab-nav, .left-nav, .rt-topbar, .pw-sidebar { display:none !important; }
  body { background:#fff; color:#000; }
}

/* ── Feedback Loop ── */
.fb-setup-notice{display:flex;align-items:flex-start;gap:10px;background:rgba(255,191,95,.1);border:1px solid rgba(255,191,95,.35);border-radius:10px;padding:12px 16px;margin-bottom:20px;font-size:12px;color:var(--amber);line-height:1.5}
.fb-setup-icon{font-size:16px;flex-shrink:0;margin-top:1px}
.fb-setup-notice code{font-family:'DM Mono',monospace;font-size:10px;background:rgba(0,0,0,.3);padding:1px 5px;border-radius:4px}
.fb-header{margin-bottom:24px}
.fb-title{font-family:Manrope,sans-serif;font-size:1.4rem;font-weight:800;color:#fff;letter-spacing:-.02em;margin-bottom:6px}
.fb-subtitle{color:var(--muted);font-size:13px;line-height:1.5}
.fb-composer{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:20px;margin-bottom:28px}
.fb-composer-hd{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:12px}
.fb-textarea{width:100%;background:rgba(255,255,255,.05);border:1px solid var(--line);border-radius:8px;padding:10px 13px;color:var(--text);font:inherit;font-size:13px;resize:vertical;outline:none;transition:border-color .15s;line-height:1.5}
.fb-textarea:focus{border-color:rgba(112,160,255,.5)}
.fb-sections-label{font-size:11px;color:var(--muted);margin:12px 0 8px;font-weight:500}
.fb-sections-grid{display:flex;flex-wrap:wrap;gap:8px}
.fb-section-cb{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--muted);cursor:pointer;padding:4px 10px;border:1px solid var(--line);border-radius:6px;background:rgba(255,255,255,.03);transition:background .12s,border-color .12s}
.fb-section-cb:hover{background:rgba(255,255,255,.07);border-color:var(--line-2)}
.fb-section-cb input{accent-color:var(--gold);cursor:pointer}
/* Avatar circles */
.fb-avatar{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;background:var(--panel-2);border:1px solid var(--line);font-family:'DM Mono',monospace;font-size:11px;font-weight:700;color:var(--gold);flex-shrink:0;letter-spacing:0}
.fb-avatar-sm{width:24px;height:24px;font-size:9px}
.fb-post{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:18px 20px;margin-bottom:16px}
.fb-post-meta{display:flex;align-items:center;gap:10px;margin-bottom:10px;flex-wrap:wrap}
.fb-post-author-block{display:flex;flex-direction:column;gap:1px}
.fb-post-author{font-family:Manrope,sans-serif;font-size:13px;color:#fff;font-weight:700;line-height:1.2}
.fb-post-time{font-size:10px;color:var(--muted)}
.fb-post-sections{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:10px}
.fb-section-tag{display:inline-block;padding:2px 8px;border-radius:4px;background:rgba(112,160,255,.15);border:1px solid rgba(112,160,255,.3);color:#70a0ff;font-size:10px;font-family:'DM Mono',monospace}
.fb-post-body{font-size:13px;line-height:1.6;color:var(--text);white-space:pre-wrap;word-break:break-word}
.fb-post-actions{display:flex;align-items:center;gap:10px;margin-top:14px;padding-top:12px;border-top:1px solid var(--line)}
.fb-like-btn{background:none;border:1px solid var(--line);border-radius:6px;padding:4px 12px;color:var(--muted);font-size:12px;cursor:pointer;transition:background .12s,color .12s;display:inline-flex;align-items:center;gap:5px}
.fb-like-btn:hover{background:rgba(255,255,255,.07)}
.fb-like-btn.fb-liked{border-color:rgba(255,100,100,.4);color:#ff7b7b;background:rgba(255,100,100,.08)}
.fb-reply-toggle{background:none;border:1px solid var(--line);border-radius:6px;padding:4px 12px;color:var(--muted);font-size:12px;cursor:pointer;transition:background .12s}
.fb-reply-toggle:hover{background:rgba(255,255,255,.07)}
.fb-comments-wrap{margin-top:14px}
.fb-comment{padding:10px 14px;background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:8px;margin-bottom:8px}
.fb-comment-meta{display:flex;gap:8px;align-items:center;margin-bottom:5px;flex-wrap:wrap}
.fb-comment-author{font-family:Manrope,sans-serif;font-size:12px;color:var(--blue);font-weight:700}
.fb-comment-time{font-size:9px;color:var(--muted)}
.fb-comment-body{font-size:12px;color:var(--text);line-height:1.5;white-space:pre-wrap;word-break:break-word}
.fb-reply-form{margin-top:10px}
.fb-reply-textarea{font-size:12px}

/* ═══════════════════════════════════════════════════════
   COVER / HOME SCREEN
   ═══════════════════════════════════════════════════════ */
#cover-screen {
  min-height: calc(100vh - 99px);
  padding: clamp(32px, 5vw, 64px) clamp(16px, 3vw, 48px) 80px;
  box-sizing: border-box;
  animation: fadeIn .3s ease;
  transition: opacity .22s ease;
}
.cover-tab-enter {
  animation: fadeIn .28s ease both;
}
@keyframes tabFadeIn{from{opacity:0}to{opacity:1}}
.tab-nav-enter {
  animation: tabFadeIn .18s ease both;
}
.cover-inner {
  max-width: 1280px;
  margin: 0 auto;
}
.cover-header {
  text-align: center;
  margin-bottom: clamp(24px, 3.5vw, 40px);
}
.cover-welcome-line {
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 10px;
}
.cover-user-name {
  font-family: Manrope, sans-serif;
  font-size: clamp(1.8rem, 4vw, 3rem);
  font-weight: 800;
  color: #fff;
  letter-spacing: -.03em;
  line-height: 1.1;
  margin-bottom: 8px;
}
.cover-tagline {
  font-family: 'DM Mono', monospace;
  font-size: 9px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(255,255,255,.45);
  margin-bottom: 6px;
}
.cover-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  width: 100%;
  align-items: start;
}
/* Branch sections */
.cover-section {
  width: 100%;
  display: flex;
  flex-direction: column;
}
.cover-section-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(255,255,255,.09);
}
.cover-section-icon {
  font-size: 20px;
  line-height: 1;
}
.cover-section-title {
  font-family: Manrope, sans-serif;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.55);
}
.cover-section-grid {
  display: grid;
  grid-template-columns: 1fr;
  grid-auto-rows: 1fr;
  gap: 14px;
  flex: 1;
}
@media(max-width:900px) {
  .cover-grid { grid-template-columns: 1fr; }
}
@media(max-width:600px) {
  .cover-section-grid { gap: 12px; }
  #cover-screen { padding: 24px 14px 60px; }
}
.cover-card {
  background: linear-gradient(160deg, rgba(24,36,68,.98) 0%, rgba(14,20,38,1) 100%);
  border: 1px solid var(--line);
  border-top: 3px solid rgba(255,255,255,.08);
  border-radius: 14px;
  padding: 28px 24px 22px;
  cursor: pointer;
  transition: transform .22s ease, box-shadow .22s ease, border-top-color .22s ease, background .22s ease;
  display: flex;
  flex-direction: column;
  gap: 8px;
  position: relative;
  overflow: hidden;
  user-select: none;
  outline: none;
}
.cover-card::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 13px;
  background: radial-gradient(ellipse at top left, rgba(217,183,95,.09) 0%, transparent 65%);
  opacity: 0;
  transition: opacity .25s;
  pointer-events: none;
}
.cover-card:hover::after,
.cover-card:focus::after { opacity: 1; }
.cover-card:hover,
.cover-card:focus {
  transform: translateY(-5px);
  box-shadow: 0 16px 48px rgba(0,0,0,.55), 0 0 0 1px rgba(217,183,95,.18);
  border-top-color: var(--gold);
}
.cover-card:active { transform: translateY(-2px); }
.cover-card-icon {
  font-size: 38px;
  line-height: 1;
  display: block;
  margin-bottom: 6px;
}
.cover-card-eyebrow {
  font-family: 'DM Mono', monospace;
  font-size: 8px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 700;
}
.cover-card-title {
  font-family: Manrope, sans-serif;
  font-size: 1.15rem;
  font-weight: 800;
  color: #fff;
  letter-spacing: -.02em;
  line-height: 1.2;
}
.cover-card-desc {
  font-size: .83rem;
  color: var(--muted);
  line-height: 1.7;
  flex: 1;
  margin-top: 2px;
}
.cover-card-cta {
  margin-top: 14px;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-family: 'DM Mono', monospace;
  font-size: 9px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 700;
  opacity: .55;
  transition: opacity .18s, gap .18s;
}
.cover-card-cta-arrow {
  font-size: 12px;
  transition: transform .18s;
}
.cover-card:hover .cover-card-cta,
.cover-card:focus .cover-card-cta {
  opacity: 1;
}
.cover-card:hover .cover-card-cta-arrow,
.cover-card:focus .cover-card-cta-arrow {
  transform: translateX(4px);
}
/* Colour accent variants — each card gets a subtle top-border tint on hover */
.cover-card[data-tab="solicitations"]:hover  { border-top-color: var(--blue); }
.cover-card[data-tab="solicitations"]:hover .cover-card-eyebrow,
.cover-card[data-tab="solicitations"]:hover .cover-card-cta { color: var(--blue); }
.cover-card[data-tab="queue"]:hover          { border-top-color: var(--amber); }
.cover-card[data-tab="queue"]:hover .cover-card-eyebrow,
.cover-card[data-tab="queue"]:hover .cover-card-cta { color: var(--amber); }
.cover-card[data-tab="response-tracker"]:hover { border-top-color: var(--green); }
.cover-card[data-tab="response-tracker"]:hover .cover-card-eyebrow,
.cover-card[data-tab="response-tracker"]:hover .cover-card-cta { color: var(--green); }
.cover-card[data-tab="proposal-workshop"]:hover { border-top-color: #c084fc; }
.cover-card[data-tab="proposal-workshop"]:hover .cover-card-eyebrow,
.cover-card[data-tab="proposal-workshop"]:hover .cover-card-cta { color: #c084fc; }
.cover-card[data-tab="news"]:hover          { border-top-color: var(--gold); }
.cover-card[data-tab="feedback"]:hover      { border-top-color: var(--red); }
.cover-card[data-tab="feedback"]:hover .cover-card-eyebrow,
.cover-card[data-tab="feedback"]:hover .cover-card-cta { color: var(--red); }
.cover-card[data-tab="legislative-calendar"]:hover { border-top-color: #8b5cf6; }
.cover-card[data-tab="legislative-calendar"]:hover .cover-card-eyebrow,
.cover-card[data-tab="legislative-calendar"]:hover .cover-card-cta { color: #8b5cf6; }
.cover-card[data-tab="staff-portal"]:hover  { border-top-color: var(--gold); }
.cover-card[data-tab="staff-portal"]:hover .cover-card-eyebrow,
.cover-card[data-tab="staff-portal"]:hover .cover-card-cta { color: var(--gold); }
/* ── Home page feature button: size/spacing single source of truth ── */
.home-feature-btn {
  min-height: 155px;
  padding: 28px 24px 22px;
  box-sizing: border-box;
}

/* Badge pill on card (e.g. queue count) */
.cover-card-badge {
  position: absolute;
  top: 18px;
  right: 18px;
  background: var(--gold);
  color: #0f1525;
  font-family: 'DM Mono', monospace;
  font-size: 9px;
  font-weight: 800;
  padding: 3px 8px;
  border-radius: 999px;
  min-width: 22px;
  text-align: center;
}

/* ═══════════════════════════════════════════════════════
   USER MENU (topbar dropdown — Settings + Sign Out)
   ═══════════════════════════════════════════════════════ */
.tab-nav-spacer{flex:1}
/* Legacy class kept for backward compat with tutorial.js target */
.settings-tab-wrap{position:relative;display:flex;align-items:center}
/* User menu button in the topbar */
.user-menu-wrap{position:relative;display:flex;align-items:center}
.user-menu-btn{display:inline-flex;align-items:center;gap:7px;padding:5px 10px 5px 8px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);border-radius:999px;color:rgba(255,255,255,.82);font-family:Inter,sans-serif;font-size:12px;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s,color .15s;white-space:nowrap}
.user-menu-btn:hover,.user-menu-btn.active{background:rgba(217,183,95,.15);border-color:rgba(217,183,95,.5);color:#fff}
.user-menu-avatar{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:rgba(217,183,95,.2);border:1px solid rgba(217,183,95,.4);font-size:11px;flex-shrink:0}
.user-menu-label{max-width:130px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.user-menu-caret{font-size:9px;opacity:.7;margin-left:1px;transition:transform .2s}
.user-menu-btn.active .user-menu-caret{transform:rotate(180deg)}
.settings-dropdown{position:absolute;top:calc(100% + 6px);right:0;min-width:220px;background:rgba(12,18,38,.98);border:1px solid var(--line-2);border-radius:10px;box-shadow:0 8px 32px rgba(0,0,0,.6);z-index:600;padding:8px 0;backdrop-filter:blur(18px)}
.settings-dd-item{display:flex;align-items:center;gap:8px;width:100%;padding:10px 18px;background:transparent;border:none;color:rgba(255,255,255,.8);font-family:Inter,sans-serif;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s,color .15s;text-align:left;-webkit-appearance:none;appearance:none}
.settings-dd-item:hover{background:rgba(217,183,95,.1);color:#fff}
.settings-dd-item.danger{color:rgba(255,123,123,.85)}
.settings-dd-item.danger:hover{background:rgba(255,123,123,.1);color:#ff7b7b}
.settings-dd-divider{height:1px;background:var(--line);margin:6px 12px}
.settings-dd-theme-section{padding:10px 18px 12px}
.settings-dd-theme-label{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.18em;text-transform:uppercase;color:rgba(217,183,95,.75);margin-bottom:8px}
.theme-toggle-group{display:flex;gap:6px}
.theme-btn{padding:5px 14px;border-radius:6px;border:1px solid var(--line-2);background:rgba(255,255,255,.06);color:rgba(255,255,255,.6);font-family:'DM Mono',monospace;font-size:9px;font-weight:600;letter-spacing:.08em;cursor:pointer;transition:all .15s}
.theme-btn:hover{background:rgba(217,183,95,.15);border-color:rgba(217,183,95,.5);color:#fff}
.theme-btn.theme-btn-active{background:var(--gold-soft);border-color:var(--gold);color:var(--gold)}

/* ═══════════════════════════════════════════════════════
   SOLICITATIONS SUB-TABS (Sectors | Queue)
   ═══════════════════════════════════════════════════════ */
.sol-tab-shell{display:block;min-height:calc(100vh - 99px)}
.sol-subtab-bar{display:flex;align-items:center;gap:0;padding:0 24px;background:rgba(10,16,31,.92);border-bottom:2px solid var(--gold);position:sticky;top:96px;z-index:180;height:40px;backdrop-filter:blur(12px)}
.sol-subtab{display:inline-flex;align-items:center;gap:6px;height:40px;padding:0 18px;font-family:'DM Mono',monospace;font-size:9px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.65);border:none;background:transparent;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;transition:color .15s,border-color .15s;white-space:nowrap;-webkit-appearance:none;appearance:none}
.sol-subtab:hover{color:rgba(255,255,255,.9);border-bottom-color:rgba(217,183,95,.55)}
.sol-subtab.sol-subtab-active{color:var(--gold);border-bottom-color:var(--gold)}
.sol-subtab-add-btn{margin-left:auto;background:rgba(46,160,67,.18);border:1px solid rgba(46,160,67,.45);border-radius:6px;color:#3fb950;height:32px;padding:0 16px;font-size:9px;letter-spacing:.12em;font-weight:600;align-self:center}
.sol-subtab-add-btn:hover{background:rgba(46,160,67,.35);border-color:rgba(46,160,67,.7);color:#7ee787;border-bottom-color:transparent}
.sol-admin-send-btn{margin-left:8px;background:rgba(112,160,255,.14);border:1px solid rgba(112,160,255,.4);border-radius:6px;color:#70a0ff;height:32px;padding:0 16px;font-size:9px;letter-spacing:.12em;font-weight:600;align-self:center;white-space:nowrap}
.sol-admin-send-btn:hover{background:rgba(112,160,255,.28);border-color:rgba(112,160,255,.65);color:#a8c8ff;border-bottom-color:transparent}
.admin-sol-search-input{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.15);border-radius:4px;color:var(--text);padding:4px 10px;font-size:12px;min-width:0;flex:1;outline:none}
.admin-sol-search-input::placeholder{color:var(--muted)}
.admin-sol-search-input:focus{border-color:rgba(217,183,95,.5)}
.admin-sol-checklist{max-height:250px}
.sol-queue-badge{font-size:8px}
#sol-sectors-view{display:flex;min-height:calc(100vh - 137px)}
#sol-queue-view{display:flex;min-height:calc(100vh - 137px)}

/* Queue submission sub-items (who sent it and when) */
.queue-submissions{margin-top:8px;padding:8px 10px;background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:6px;display:flex;flex-direction:column;gap:4px}
.queue-submissions-label{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.14em;text-transform:uppercase;color:rgba(217,183,95,.75);margin-bottom:4px}
.queue-submission-item{font-family:'DM Mono',monospace;font-size:10px;color:var(--muted);display:flex;align-items:flex-start;gap:6px;line-height:1.4}
.queue-submission-item::before{content:'↳';color:rgba(217,183,95,.5);flex-shrink:0}
.queue-submission-user{color:rgba(255,255,255,.75);font-weight:600}
.queue-submission-comment{font-style:italic;color:rgba(255,255,255,.45);margin-top:2px;padding-left:16px;font-size:9.5px}

/* ══════════════════════════════════════════════════════════════════════════════
   JAG Pulse · New Features: Sort Dropdown, Sector Jump Bar,
   Sent-to-Client Color Coding, Continuous Scroll
   ══════════════════════════════════════════════════════════════════════════════ */

/* ── Sort dropdown ─────────────────────────────────────────────────────────── */

/* ── Sector jump bar ───────────────────────────────────────────────────────── */
.sol-sector-jump-bar {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  background: rgba(255,255,255,.03);
  border-bottom: 1px solid rgba(255,255,255,.08);
  overflow-x: auto;
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,.15) transparent;
  flex-shrink: 0;
  position: sticky;
  top: 0;
  z-index: 10;
}
.sol-sector-jump-bar:empty { display: none; }
.sol-jump-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 12px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.04);
  color: var(--muted, #8b949e);
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  transition: all .15s;
  font-family: inherit;
}
.sol-jump-btn:hover,
.sol-jump-btn.active {
  border-color: rgba(217,183,95,.55);
  color: var(--gold, #d9b75f);
  background: rgba(217,183,95,.1);
}
.sol-jump-btn.mr-jump-btn { border-color: rgba(250,200,60,.3); }
.sol-jump-btn.mr-jump-btn.active,
.sol-jump-btn.mr-jump-btn:hover {
  border-color: rgba(250,200,60,.7);
  color: #f9d46a;
  background: rgba(250,200,60,.1);
}
.sol-jump-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  border-radius: 999px;
  background: rgba(255,255,255,.1);
  font-size: 10px;
  font-family: 'DM Mono', monospace;
  font-weight: 700;
}

/* ── Continuous scroll: all sector sections visible ──────────────────────── */
.sol-sector-section {
  margin-bottom: 16px;
  scroll-margin-top: 52px; /* account for jump bar height */
}
.sol-sector-section + .sol-sector-section { margin-top: 0; }
.sector-scroll-anchor {
  display: block;
  height: 0;
  visibility: hidden;
  scroll-margin-top: 56px;
}

/* Date group header for "Group by Upload Date" sort mode */
.sol-date-group-header {
  padding: 10px 20px 6px;
  position: sticky;
  top: 52px;
  z-index: 5;
  background: var(--bg, #0d1117);
}
.sol-date-label {
  font-size: 11px;
  font-weight: 700;
  color: var(--gold, #d9b75f);
  font-family: 'DM Mono', monospace;
  letter-spacing: .08em;
  text-transform: uppercase;
  opacity: .85;
}

/* ── Sent to Client — green card state ──────────────────────────────────────── */
.sol-card.sent-to-client {
  border-left-color: #2ea043 !important;
  background: linear-gradient(135deg, rgba(46,160,67,.13) 0%, rgba(46,160,67,.05) 100%) !important;
  box-shadow: 0 0 0 1px rgba(46,160,67,.25), 0 4px 16px rgba(46,160,67,.1);
}
.sol-card.sent-to-client .sol-card-header { opacity: .95; }

.sol-sent-btn {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: 6px;
  border: 1px solid rgba(46,160,67,.4);
  background: rgba(46,160,67,.1);
  color: #4ade80;
  font-size: 11px;
  font-weight: 700;
  font-family: inherit;
  cursor: pointer;
  white-space: nowrap;
  transition: all .15s;
  height: 28px;
}
.sol-sent-btn:hover {
  border-color: rgba(46,160,67,.8);
  background: rgba(46,160,67,.22);
  color: #6ee7b7;
}
.sol-card.sent-to-client .sol-sent-btn {
  border-color: rgba(46,160,67,.6);
  background: rgba(46,160,67,.2);
  color: #6ee7b7;
}

.sol-sent-badge {
  margin-top: 8px;
  padding: 5px 10px;
  border-radius: 5px;
  background: rgba(46,160,67,.15);
  border: 1px solid rgba(46,160,67,.3);
  color: #86efac;
  font-size: 11px;
  font-weight: 700;
  font-family: 'DM Mono', monospace;
  letter-spacing: .03em;
}

/* Flagged-clients strip on solicitation cards — shows which clients have
   been flagged for this opportunity via the Queue or EVP/Lobbyist Most Relevant.
   Pills sit side-by-side at the bottom of the card, visible to all users. */
.sol-flagged-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 10px;
  padding: 10px 20px;
  border-top: 1px solid rgba(245,200,66,.15);
}
.sol-flagged-pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 9px;
  border-radius: 999px;
  background: rgba(245,200,66,.15);
  border: 1px solid rgba(245,200,66,.4);
  color: #f5c842;
  font-size: 11px;
  font-weight: 700;
  font-family: 'DM Mono', monospace;
  letter-spacing: .02em;
  white-space: nowrap;
  line-height: 1.3;
}
/* Green — EVP/Lobbyist yes bid */
.sol-flagged-pill--bid {
  background: rgba(67,197,158,.18);
  border-color: rgba(67,197,158,.5);
  color: #43c59e;
}
/* Red — declined / no bid */
.sol-flagged-pill--declined {
  background: rgba(255,90,90,.15);
  border-color: rgba(255,90,90,.45);
  color: #ff7b7b;
}

/* ── Color legend ──────────────────────────────────────────────────────────── */
.sol-color-legend {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 12px 20px;
  border-top: 1px solid rgba(255,255,255,.06);
  margin-top: 8px;
  font-size: 11px;
  color: var(--muted, #8b949e);
}
.legend-item { display: inline-flex; align-items: center; gap: 5px; }
.legend-default { color: var(--muted, #8b949e); }
.legend-sent { color: #4ade80; }

/* ── Make sol-sectors-view main-content scroll as a continuous list ────────── */
#sol-sectors-view > .main-content {
  overflow-y: auto;
  overflow-x: hidden;
}
/* ── Ensure the jump bar doesn't get clipped by app-shell flex layout ──────── */
.sol-tab-shell {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
}
#sol-sector-jump-bar {
  flex-shrink: 0;
}
#sol-sectors-view {
  flex: 1;
  min-height: 0;
}


/* ── Queue Comment Replies (Feature 2) ───────────────────────────────────── */
.queue-reply-item { font-size:9.5px; color:rgba(255,255,255,.5); padding:3px 0 3px 20px; border-left:1px solid rgba(255,255,255,.12); margin-top:3px; font-style:italic; }
.queue-reply-item .queue-reply-author { color:rgba(255,255,255,.75); font-weight:600; font-style:normal; }
.queue-reply-toggle { background:none; border:1px solid var(--line); border-radius:4px; padding:2px 8px; color:var(--muted); font-size:9px; cursor:pointer; margin-top:4px; }
.queue-reply-toggle:hover { background:rgba(255,255,255,.07); }
.queue-reply-form { margin-top:6px; padding-left:16px; }
.queue-reply-form textarea { width:100%; background:rgba(255,255,255,.05); border:1px solid var(--line); border-radius:4px; padding:5px 8px; color:#fff; font-family:Inter,sans-serif; font-size:11px; resize:vertical; }

/* Per-client comment label on queue cards */
.queue-comment-client-label { font-weight:700; font-style:normal; color:rgba(255,255,255,.7); margin-right:3px; }

/* ── EVP Approved Badge (Feature 4) — top-right of card header ───────────── */
.queue-evp-badge { display:inline-flex; align-items:center; background:#1a4a2e; border:1px solid #22c55e; color:#22c55e; font-size:9px; font-family:'DM Mono',monospace; font-weight:700; letter-spacing:.1em; padding:2px 8px; border-radius:4px; text-transform:uppercase; flex-shrink:0; align-self:flex-start; }
.queue-card-evp { border-color:rgba(34,197,94,.45) !important; background:rgba(34,197,94,.05) !important; }
.queue-card-evp .queue-card-hd { border-bottom-color:rgba(34,197,94,.2); }
/* Ensure the card header has position context for the badge */
.queue-card-hd { position:relative; }

/* ── Lobbyist Approved Badge — mirrors EVP badge for no-EVP clients ────── */
.queue-lobbyist-badge { display:inline-flex; align-items:center; background:#1a4a2e; border:1px solid #22c55e; color:#22c55e; font-size:9px; font-family:'DM Mono',monospace; font-weight:700; letter-spacing:.1em; padding:2px 8px; border-radius:4px; text-transform:uppercase; flex-shrink:0; align-self:flex-start; }
.queue-card-lobbyist { border-color:rgba(34,197,94,.45) !important; background:rgba(34,197,94,.05) !important; }
.queue-card-lobbyist .queue-card-hd { border-bottom-color:rgba(34,197,94,.2); }

/* ── Sent-to-Client tracking (Policy/admin) ─────────────────────────────── */
.queue-sent-strip { display:flex; flex-wrap:wrap; gap:6px; margin:8px 0 4px; }
.queue-sent-badge { display:inline-flex; align-items:center; background:rgba(99,179,255,.14); border:1px solid rgba(99,179,255,.45); color:#90c2ff; font-size:10px; font-family:'DM Mono',monospace; font-weight:700; letter-spacing:.08em; padding:3px 9px; border-radius:4px; text-transform:uppercase; }
.queue-mark-sent-btn { background:rgba(99,179,255,.10); border:1px solid rgba(99,179,255,.4); color:#90c2ff; font-family:'DM Mono',monospace; font-size:10px; font-weight:600; letter-spacing:.06em; padding:5px 10px; border-radius:4px; cursor:pointer; text-transform:uppercase; transition:background .15s, color .15s, border-color .15s; }
.queue-mark-sent-btn:hover { background:rgba(99,179,255,.22); color:#bcd9ff; border-color:rgba(99,179,255,.6); }
.queue-unmark-sent-btn { background:rgba(255,255,255,.05); border:1px solid var(--line); color:rgba(255,255,255,.6); font-family:'DM Mono',monospace; font-size:10px; font-weight:600; letter-spacing:.06em; padding:5px 10px; border-radius:4px; cursor:pointer; text-transform:uppercase; transition:background .15s, color .15s; }
.queue-unmark-sent-btn:hover { background:rgba(255,255,255,.10); color:#fff; }

/* ── Queue delete button (admin only) ────────────────────────────────────── */
.queue-delete-btn { font-size:10px; font-weight:600; font-family:'DM Mono',monospace; background:transparent; border:1px solid rgba(255,100,100,.35); color:rgba(255,100,100,.8); border-radius:4px; padding:4px 9px; cursor:pointer; transition:background .15s,color .15s,border-color .15s; letter-spacing:.05em; text-transform:uppercase; margin-left:auto; }
.queue-delete-btn:hover { background:rgba(255,100,100,.14); color:#ff6464; border-color:#ff6464; }

/* ── Add Client button (queue cards) ─────────────────────────────────────── */
.queue-add-client-btn { background:rgba(74,222,128,.12); border:1px solid rgba(74,222,128,.45); color:#86efac; font-family:'DM Mono',monospace; font-size:10px; font-weight:600; letter-spacing:.06em; padding:5px 10px; border-radius:4px; cursor:pointer; text-transform:uppercase; transition:background .15s, color .15s, border-color .15s; }
.queue-add-client-btn:hover { background:rgba(74,222,128,.22); color:#bbf7d0; border-color:rgba(74,222,128,.6); }

/* ── Queue Clear button (small square red X) ─────────────────────────────── */
.queue-clear-btn { font-size:12px; font-weight:700; font-family:'DM Mono',monospace; background:transparent; border:1px solid rgba(255,100,100,.35); color:rgba(255,100,100,.8); border-radius:4px; padding:4px 8px; cursor:pointer; transition:background .15s,color .15s,border-color .15s; }
.queue-clear-btn:hover { background:rgba(255,100,100,.14); color:#ff6464; border-color:#ff6464; }

/* ── No-Bid Archive card (Feature 1) ─────────────────────────────────────── */
.nobid-archive-card { background:linear-gradient(180deg,rgba(22,32,58,.98),rgba(16,22,40,1)); border:1px solid var(--line); border-left:3px solid #fbbf24; border-radius:10px; padding:16px; margin-bottom:12px; }
.nobid-archive-card-title { font-size:13px; font-weight:600; color:var(--text); margin-bottom:6px; }
.nobid-archive-card-meta { font-size:11px; color:var(--muted); margin-bottom:10px; }
.nobid-restore-btn { background:rgba(251,191,36,.12); border:1px solid rgba(251,191,36,.45); color:#fbbf24; font-family:'DM Mono',monospace; font-size:10px; font-weight:600; letter-spacing:.06em; padding:5px 12px; border-radius:4px; cursor:pointer; text-transform:uppercase; transition:background .15s, color .15s, border-color .15s; }
.nobid-restore-btn:hover { background:rgba(251,191,36,.22); color:#fcd34d; border-color:rgba(251,191,36,.6); }

/* ── Admin Decision Archive table (Feature 3) ────────────────────────────── */
.admin-archive-toggle { display:flex; gap:0; margin-bottom:16px; }
.admin-archive-toggle-btn { font-family:'DM Mono',monospace; font-size:10px; font-weight:600; letter-spacing:.08em; text-transform:uppercase; padding:8px 16px; border:1px solid var(--line); background:rgba(255,255,255,.04); color:rgba(255,255,255,.6); cursor:pointer; transition:background .15s, color .15s, border-color .15s; }
.admin-archive-toggle-btn:first-child { border-radius:6px 0 0 6px; }
.admin-archive-toggle-btn:last-child { border-radius:0 6px 6px 0; border-left:none; }
.admin-archive-toggle-btn.active { background:rgba(217,183,95,.15); border-color:rgba(217,183,95,.5); color:#d9b75f; }
.admin-decision-table { width:100%; border-collapse:collapse; font-size:12px; }
.admin-decision-table th { text-align:left; padding:10px 12px; background:rgba(255,255,255,.04); border-bottom:1px solid var(--line); font-family:'DM Mono',monospace; font-size:10px; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); cursor:pointer; }
.admin-decision-table th:hover { color:#fff; }
.admin-decision-table th.sorted { color:#d9b75f; }
.admin-decision-table td { padding:10px 12px; border-bottom:1px solid var(--line); vertical-align:top; }
.admin-decision-table tr:nth-child(even) { background:rgba(255,255,255,.02); }
.admin-decision-pill { display:inline-block; font-family:'DM Mono',monospace; font-size:9px; font-weight:700; letter-spacing:.08em; padding:2px 8px; border-radius:4px; text-transform:uppercase; }
.admin-decision-pill.bid { background:rgba(34,197,94,.15); border:1px solid rgba(34,197,94,.4); color:#22c55e; }
.admin-decision-pill.no-bid { background:rgba(255,100,100,.12); border:1px solid rgba(255,100,100,.35); color:#ff6464; }

/* ── Send-to-Client awaiting state ──────────────────────────────────────── */
.send-to-client-btn-disabled { opacity:.55; cursor:not-allowed !important; background:rgba(255,255,255,.04) !important; border-color:rgba(255,255,255,.15) !important; color:rgba(255,255,255,.55) !important; }
.send-to-client-btn-disabled:hover { background:rgba(255,255,255,.04) !important; color:rgba(255,255,255,.55) !important; }

/* ── Queue per-client section headers ───────────────────────────────────── */
.queue-client-section { margin-bottom:24px; }
.queue-section-header { display:flex; align-items:center; gap:10px; padding:10px 14px; margin-bottom:12px; background:rgba(255,255,255,.04); border:1px solid var(--line); border-left:3px solid #d9b75f; border-radius:6px; }
.queue-section-title { font-family:'DM Mono',monospace; font-size:13px; font-weight:700; letter-spacing:.05em; color:#fff; margin:0; text-transform:uppercase; }
.queue-section-count { display:inline-block; background:rgba(217,183,95,.15); border:1px solid rgba(217,183,95,.4); color:#d9b75f; font-size:10px; font-family:'DM Mono',monospace; padding:1px 7px; border-radius:10px; margin-left:6px; }
.queue-section-sub { font-size:11px; color:var(--muted); margin-left:auto; }

/* ── Pending EVP Review panel (Policy/Lobbyist) ─────────────────────────── */
.queue-pending-evp-section { margin-bottom:28px; padding:14px; background:rgba(34,197,94,.04); border:1px solid rgba(34,197,94,.25); border-radius:8px; }
.queue-section-header-pending { background:rgba(34,197,94,.10); border-color:rgba(34,197,94,.35); border-left-color:#22c55e; }
.queue-section-header-pending .queue-section-title { color:#22c55e; }
.queue-section-header-pending .queue-section-count { background:rgba(34,197,94,.18); border-color:rgba(34,197,94,.45); color:#22c55e; }
.queue-card-pending-evp { border-color:rgba(34,197,94,.30) !important; }
.queue-pending-evp-badge { display:inline-flex; align-items:center; background:#1a4a2e; border:1px solid #22c55e; color:#22c55e; font-size:9px; font-family:'DM Mono',monospace; font-weight:700; letter-spacing:.1em; padding:2px 8px; border-radius:4px; text-transform:uppercase; flex-shrink:0; align-self:flex-start; }

/* ── EVP Most Relevant section (solicitations dashboard) ────────────────── */
.sol-sector-evp-mr { border-left:3px solid #22c55e; padding-left:12px; margin-bottom:24px; }
.evp-mr-header { background:rgba(34,197,94,.05); border-radius:8px; }
.sol-card-evp-referral { border-color:rgba(34,197,94,.35) !important; position:relative; }
.evp-mr-comments { padding:8px 12px; background:rgba(255,255,255,.03); border-radius:6px; margin:8px 0; }
.evp-mr-comment { font-size:12px; color:rgba(255,255,255,.85); padding:3px 0; line-height:1.5; }
.evp-mr-comment-client { font-weight:700; color:#22c55e; margin-right:4px; }

/* Per-client name badges in the EVP MR card header — lighter green styling */
.evp-mr-client-badges { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:8px; }
.evp-mr-client-badge { display:inline-flex; align-items:center; background:rgba(134,239,172,.12); border:1px solid rgba(134,239,172,.45); color:#86efac; font-size:10px; font-family:'DM Mono',monospace; font-weight:700; letter-spacing:.08em; padding:3px 9px; border-radius:4px; text-transform:uppercase; }

/* "Referred by" footer at the bottom of the EVP MR card — softer, larger, easier to read */
.evp-mr-footer { display:flex; flex-wrap:wrap; align-items:flex-start; gap:8px; margin-top:14px; padding:10px 14px; background:rgba(255,255,255,.08); border-top:1px solid rgba(34,197,94,.25); border-radius:0 0 6px 6px; font-family:Inter,sans-serif; }
.evp-mr-footer-label { font-size:12px; color:rgba(255,255,255,.85); font-weight:500; letter-spacing:.02em; text-transform:uppercase; padding-top:2px; }
.evp-mr-referrer-list { display:flex; flex-direction:column; gap:4px; }
.evp-mr-referrer-item { display:flex; flex-wrap:wrap; align-items:baseline; gap:6px; }
.evp-mr-footer-name { font-size:14px; color:#ffffff; font-weight:600; }
.evp-mr-footer-sep { color:rgba(255,255,255,.55); font-size:13px; }
.evp-mr-footer-ts { font-size:13px; color:rgba(255,255,255,.9); }

/* EVP-only inner toggle bar (Sectors / Most Relevant) on the Solicitations
   page, positioned above the sectors content. Lighter green accent. */
.sol-inner-tab-bar { display:flex; align-items:center; gap:6px; padding:10px 24px; background:rgba(10,16,31,.6); border-bottom:1px solid var(--line); }
.sol-inner-tab { display:inline-flex; align-items:center; gap:6px; height:30px; padding:0 14px; font-family:'DM Mono',monospace; font-size:10px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.7); background:rgba(255,255,255,.04); border:1px solid var(--line); border-radius:6px; cursor:pointer; transition:color .15s, background .15s, border-color .15s; -webkit-appearance:none; appearance:none; }
.sol-inner-tab:hover { color:#fff; background:rgba(255,255,255,.08); }
.sol-inner-tab.sol-inner-tab-active { color:#fff; background:rgba(134,239,172,.14); border-color:rgba(134,239,172,.5); }
.sol-inner-tab-mr { color:#86efac; }
.sol-inner-tab-mr:hover { color:#bbf7d0; border-color:rgba(134,239,172,.45); }
.sol-inner-tab-mr.sol-inner-tab-active { color:#bbf7d0; background:rgba(134,239,172,.18); border-color:rgba(134,239,172,.6); }
.sol-mr-badge { background:rgba(134,239,172,.18); border:1px solid rgba(134,239,172,.5); color:#86efac; }
.sol-inner-tab-nobid { color:#fbbf24; }
.sol-inner-tab-nobid:hover { color:#fcd34d; border-color:rgba(251,191,36,.45); }
.sol-inner-tab-nobid.sol-inner-tab-active { color:#fcd34d; background:rgba(251,191,36,.18); border-color:rgba(251,191,36,.6); }
.sol-nobid-badge { background:rgba(251,191,36,.18); border:1px solid rgba(251,191,36,.5); color:#fbbf24; }

/* Lobbyist "Most Relevant" card and section styles — blue accent (mirrors EVP green) */
.sol-sector-lob-mr { border-left:3px solid #3b82f6; padding-left:12px; margin-bottom:24px; }
.lob-mr-header { background:rgba(59,130,246,.05); border-radius:8px; }
.sol-card-lob-referral { border-color:rgba(59,130,246,.35) !important; position:relative; }
.lob-mr-comments { padding:8px 12px; background:rgba(255,255,255,.03); border-radius:6px; margin:8px 0; }
.lob-mr-comment { font-size:12px; color:rgba(255,255,255,.85); padding:3px 0; line-height:1.5; }
.lob-mr-comment-client { font-weight:700; color:#60a5fa; margin-right:4px; }
.lob-mr-client-badges { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:8px; }
.lob-mr-client-badge { display:inline-flex; align-items:center; background:rgba(147,197,253,.12); border:1px solid rgba(147,197,253,.45); color:#93c5fd; font-size:10px; font-family:'DM Mono',monospace; font-weight:700; letter-spacing:.08em; padding:3px 9px; border-radius:4px; text-transform:uppercase; }
.lob-mr-footer { display:flex; flex-wrap:wrap; align-items:flex-start; gap:8px; margin-top:14px; padding:10px 14px; background:rgba(255,255,255,.08); border-top:1px solid rgba(59,130,246,.25); border-radius:0 0 6px 6px; font-family:Inter,sans-serif; }
.lob-mr-footer-label { font-size:12px; color:rgba(255,255,255,.85); font-weight:500; letter-spacing:.02em; text-transform:uppercase; padding-top:2px; }
.lob-mr-referrer-list { display:flex; flex-direction:column; gap:4px; }
.lob-mr-referrer-item { display:flex; flex-wrap:wrap; align-items:baseline; gap:6px; }
.lob-mr-footer-name { font-size:14px; color:#ffffff; font-weight:600; }
.lob-mr-footer-sep { color:rgba(255,255,255,.55); font-size:13px; }
.lob-mr-footer-ts { font-size:13px; color:rgba(255,255,255,.9); }
/* Pending Lobbyist review badge in the queue */
.queue-card-pending-lob { border-color:rgba(59,130,246,.35) !important; }
.queue-pending-lob-badge { display:inline-flex; align-items:center; background:rgba(59,130,246,.15); border:1px solid rgba(59,130,246,.45); color:#60a5fa; font-size:10px; font-family:'DM Mono',monospace; font-weight:700; letter-spacing:.06em; padding:3px 8px; border-radius:4px; text-transform:uppercase; margin-left:8px; white-space:nowrap; }
.queue-pending-lob-section { margin-bottom:24px; }

/* ── EVP/Lobbyist Reviewer Notes (MR cards + pending queue) ────────────────── */
/* EVP reviewer notes (green tint) */
.evp-mr-reviewer-notes { padding:10px 12px; background:rgba(134,239,172,.06); border:1px solid rgba(134,239,172,.2); border-radius:6px; margin:10px 0; }
.evp-mr-reviewer-label { font-size:10px; font-weight:700; color:#86efac; letter-spacing:.08em; text-transform:uppercase; margin-bottom:8px; }
.evp-mr-reviewer-comment { padding:6px 0; border-bottom:1px solid rgba(134,239,172,.1); }
.evp-mr-reviewer-comment:last-child { border-bottom:none; }
.evp-mr-reviewer-name { font-size:12px; font-weight:600; color:#22c55e; margin-right:6px; }
.evp-mr-reviewer-ts { font-size:11px; color:var(--muted); }
.evp-mr-reviewer-text { font-size:12px; color:rgba(255,255,255,.85); margin-top:4px; line-height:1.5; }
.evp-mr-reviewer-add-btn { margin-left:auto; padding:5px 10px; background:rgba(134,239,172,.1); border:1px solid rgba(134,239,172,.35); border-radius:5px; color:#86efac; font-size:10px; font-family:'DM Mono',monospace; font-weight:600; cursor:pointer; transition:all .15s; }
.evp-mr-reviewer-add-btn:hover { background:rgba(134,239,172,.2); border-color:rgba(134,239,172,.5); }

/* Lobbyist reviewer notes (blue tint) */
.lob-mr-reviewer-notes { padding:10px 12px; background:rgba(147,197,253,.06); border:1px solid rgba(147,197,253,.2); border-radius:6px; margin:10px 0; }
.lob-mr-reviewer-label { font-size:10px; font-weight:700; color:#93c5fd; letter-spacing:.08em; text-transform:uppercase; margin-bottom:8px; }
.lob-mr-reviewer-comment { padding:6px 0; border-bottom:1px solid rgba(147,197,253,.1); }
.lob-mr-reviewer-comment:last-child { border-bottom:none; }
.lob-mr-reviewer-name { font-size:12px; font-weight:600; color:#3b82f6; margin-right:6px; }
.lob-mr-reviewer-ts { font-size:11px; color:var(--muted); }
.lob-mr-reviewer-text { font-size:12px; color:rgba(255,255,255,.85); margin-top:4px; line-height:1.5; }
.lob-mr-reviewer-add-btn { margin-left:auto; padding:5px 10px; background:rgba(147,197,253,.1); border:1px solid rgba(147,197,253,.35); border-radius:5px; color:#93c5fd; font-size:10px; font-family:'DM Mono',monospace; font-weight:600; cursor:pointer; transition:all .15s; }
.lob-mr-reviewer-add-btn:hover { background:rgba(147,197,253,.2); border-color:rgba(147,197,253,.5); }

/* Pending review cards in queue — reviewer notes */
.queue-pending-reviewer-notes { padding:10px 12px; background:rgba(255,255,255,.03); border:1px solid var(--line); border-radius:6px; margin:10px 0; }
.queue-pending-reviewer-label { font-size:10px; font-weight:700; color:#86efac; letter-spacing:.06em; text-transform:uppercase; margin-bottom:8px; }
.queue-card-pending-lob .queue-pending-reviewer-label { color:#93c5fd; }
.queue-pending-reviewer-item { padding:6px 0; border-bottom:1px solid rgba(255,255,255,.06); }
.queue-pending-reviewer-item:last-child { border-bottom:none; }
.queue-pending-reviewer-meta { font-size:11px; color:var(--muted); margin-bottom:3px; }
.queue-pending-reviewer-text { font-size:12px; color:rgba(255,255,255,.85); line-height:1.5; }

/* ── Undo Button (Feature 5) ─────────────────────────────────────────────── */
.sol-undo-btn { color:rgba(255,255,255,.65); border-color:rgba(255,255,255,.2); }
.sol-undo-btn:hover { background:rgba(255,255,255,.1); color:#fff; }

/* Per-client comment textarea in bid modal */
.bid-client-comment-ta { width:100%; margin-top:7px; background:rgba(255,255,255,.05); border:1px solid var(--line); border-radius:5px; padding:6px 8px; color:#fff; font-family:Inter,sans-serif; font-size:11px; resize:vertical; }

/* "Already sent to EVP" badge inside bid modal client chips */
.bid-evp-sent-badge { display:inline-block; margin-left:6px; background:rgba(251,191,36,.15); border:1px solid rgba(251,191,36,.45); color:#fbbf24; font-size:9px; font-family:'DM Mono',monospace; font-weight:700; letter-spacing:.08em; padding:1px 6px; border-radius:3px; text-transform:uppercase; vertical-align:middle; white-space:nowrap; }
/* "Already sent to Lobbyist" badge inside bid modal client chips */
.bid-lob-sent-badge { display:inline-block; margin-left:6px; background:rgba(59,130,246,.15); border:1px solid rgba(59,130,246,.45); color:#93c5fd; font-size:9px; font-family:'DM Mono',monospace; font-weight:700; letter-spacing:.08em; padding:1px 6px; border-radius:3px; text-transform:uppercase; vertical-align:middle; white-space:nowrap; }

/* "→ EVP" indicator on queue card client chips */
.queue-client-chip-evp { border-color:rgba(251,191,36,.45); color:#fbbf24; background:rgba(251,191,36,.1); }
.queue-client-evp-indicator { font-family:'DM Mono',monospace; font-size:8px; font-weight:700; letter-spacing:.06em; opacity:.85; margin-left:4px; }

/* ── Opportunity Tracker: Pipeline Improvements (Comment Feedback #5) ─────── */

/* Stage pill — color-coded rounded badge */
.pl-stage-pill {
  display:inline-flex;
  align-items:center;
  gap:5px;
  padding:3px 10px 3px 7px;
  border-radius:20px;
  border:1px solid var(--stage-color, rgba(255,255,255,.2));
  /* Fallback for browsers without color-mix() support */
  background:rgba(255,255,255,.08);
  background:color-mix(in srgb, var(--stage-color, rgba(255,255,255,.08)) 15%, transparent);
  font-family:'DM Mono',monospace;
  font-size:9px;
  font-weight:700;
  color:#fff;
  white-space:nowrap;
  letter-spacing:.04em;
}
.pl-stage-dot-sm {
  width:6px;
  height:6px;
  border-radius:50%;
  flex-shrink:0;
}

/* Summary strip value color accents */
.pl-sum-val-identified { color:#70a0ff; }
.pl-sum-val-drafting   { color:#ffd580; }
.pl-sum-val-submitted  { color:#6ee7c7; }

/* Toggle buttons — improved filled-circle style */
.pl-toggle { width:30px; height:30px; border-radius:50%; border:none; font-size:13px; font-weight:700; cursor:pointer; transition:all .15s; display:inline-flex; align-items:center; justify-content:center; font-family:inherit; }
.pl-toggle-off { background:rgba(255,255,255,.06); color:rgba(255,255,255,.25); border:1px solid rgba(255,255,255,.12); }
.pl-toggle-off:hover { background:rgba(255,255,255,.13); color:rgba(255,255,255,.7); border-color:rgba(255,255,255,.3); transform:scale(1.1); }
.pl-toggle-on { background:rgba(67,197,158,.22); color:#6ee7c7; border:1px solid rgba(67,197,158,.45); }
.pl-toggle-on:hover { background:rgba(67,197,158,.35); transform:scale(1.05); }

/* Board card agency label */
.rt-opp-agency { font-size:9px; color:var(--muted); margin-top:4px; font-family:'DM Mono',monospace; letter-spacing:.04em; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }

/* Board cards — improved shadow and hover */
.rt-opp-card { box-shadow:0 2px 8px rgba(0,0,0,.25); transition:box-shadow .15s, transform .1s; }
.rt-opp-card:hover { box-shadow:0 4px 16px rgba(0,0,0,.4); transform:translateY(-1px); }

/* Workflow column headers — use emoji icons so columns are narrower */
.pl-th-wf { min-width:44px !important; text-align:center; font-size:13px !important; letter-spacing:0 !important; text-transform:none !important; }

/* ── Queue card action row ────────────────────────────────────────────────── */
.queue-card-actions { display:flex; align-items:center; gap:8px; }

/* ── Queue Archive Section (admin-only collapsible archive with sort) ──────── */
.queue-archive-section { margin-top:28px; border-top:2px solid rgba(255,123,123,.2); padding-top:16px; }
.queue-archive-section-hd { margin-bottom:14px; }
.queue-archive-section-title { font-family:'DM Mono',monospace; font-size:11px; font-weight:700; color:rgba(255,123,123,.8); text-transform:uppercase; letter-spacing:.1em; }
.queue-archive-section-count { display:inline-block; background:rgba(255,123,123,.15); border:1px solid rgba(255,123,123,.3); color:rgba(255,123,123,.9); border-radius:10px; font-size:10px; padding:1px 7px; margin-left:6px; }

/* ── Board card quick-action bar (Change 6c) ─────────────────────────────── */
.rt-card-quick-actions { display:flex; align-items:center; gap:6px; padding:5px 11px 6px; border-top:1px solid rgba(255,255,255,.08); }
.rt-quick-bid { font-family:'DM Mono',monospace; font-size:9px; font-weight:700; padding:3px 10px; border-radius:4px; border:1px solid rgba(255,255,255,.2); background:rgba(255,255,255,.06); color:rgba(255,255,255,.6); cursor:pointer; transition:all .15s; letter-spacing:.04em; }
.rt-qb-go    { background:rgba(67,197,158,.2); border-color:rgba(67,197,158,.4); color:#6ee7c7; }
.rt-qb-nobid { background:rgba(255,123,123,.18); border-color:rgba(255,123,123,.35); color:#ffaaaa; }
.rt-qb-hold  { background:rgba(255,191,95,.15); border-color:rgba(255,191,95,.35); color:#ffd580; }
.rt-quick-stc { width:28px; height:28px; border-radius:6px; border:1px solid rgba(255,255,255,.15); background:rgba(255,255,255,.06); color:rgba(255,255,255,.4); cursor:pointer; font-size:13px; display:inline-flex; align-items:center; justify-content:center; transition:all .15s; }
.rt-quick-stc-on { background:rgba(67,197,158,.2); border-color:rgba(67,197,158,.4); color:#6ee7c7; }
.rt-quick-stc:hover, .rt-quick-bid:hover { filter:brightness(1.25); }

/* ── iMessage-style chat threads in queue ── */
.queue-submissions { padding:8px 0 2px; }
.chat-thread { display:flex; flex-direction:column; gap:4px; padding:4px 0; }
.chat-message { display:flex; align-items:flex-end; gap:7px; margin-bottom:2px; }
.chat-bubble-left  { flex-direction:row; }
.chat-bubble-right { flex-direction:row-reverse; }
.chat-avatar { width:26px; height:26px; border-radius:50%; flex-shrink:0; display:flex; align-items:center; justify-content:center; font-size:9px; font-weight:700; color:#fff; }
.chat-bubble-wrap { display:flex; flex-direction:column; max-width:75%; }
.chat-bubble-left  .chat-bubble-wrap { align-items:flex-start; }
.chat-bubble-right .chat-bubble-wrap { align-items:flex-end; }
.chat-sender-name { font-size:9px; color:var(--muted); margin-bottom:2px; padding-left:2px; }
.chat-bubble { border-radius:14px; padding:7px 12px; font-size:11px; line-height:1.5; word-break:break-word; }
.chat-bubble-left  .chat-bubble { background:rgba(255,255,255,.10); color:rgba(255,255,255,.85); border-bottom-left-radius:4px; }
.chat-bubble-right .chat-bubble { background:rgba(29,78,216,.65); color:#fff; border-bottom-right-radius:4px; }
.chat-ts { font-size:9px; color:var(--muted); margin-top:2px; padding-left:2px; padding-right:2px; }
.chat-submission-label { font-size:8.5px; text-transform:uppercase; letter-spacing:.08em; color:rgba(217,183,95,.7); margin-bottom:3px; font-family:'DM Mono',monospace; }

/* ── Pipeline table — new avatar/link/status columns ── */
.pl-avatar-pip { width:24px; height:24px; border-radius:50%; display:inline-flex; align-items:center; justify-content:center; font-size:9px; font-weight:700; color:#fff; flex-shrink:0; }
.pl-avatar-pol { box-shadow:0 0 0 2px rgba(255,255,255,.15); }
.pl-avatars-row { display:flex; gap:3px; align-items:center; }
.pl-doc-link { color:var(--gold); font-size:10px; text-decoration:none; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; display:block; max-width:90px; }
.pl-doc-link:hover { text-decoration:underline; }
.pl-link-empty { color:var(--muted); font-size:10px; }
.pl-status-empty { color:var(--muted); font-size:10px; }
.pl-status-pill { font-size:9px; font-weight:700; font-family:'DM Mono',monospace; letter-spacing:.04em; padding:3px 8px; border-radius:4px; white-space:nowrap; }
.pl-status-ready    { background:rgba(67,197,158,.2); color:#6ee7c7; }
.pl-status-na       { background:rgba(255,255,255,.08); color:var(--muted); }
.pl-status-submitted{ background:rgba(29,78,216,.3); color:#93c5fd; }
.pl-status-progress { background:rgba(255,191,95,.15); color:#ffd580; }
.pl-td-lead { padding:6px 10px; }
.pl-td-doclink { padding:4px 8px; max-width:100px; overflow:hidden; }
.pl-td-status { padding:4px 10px; }
.pl-th-lead { min-width:60px; }
.pl-th-doclink { min-width:90px; }
.pl-th-status { min-width:100px; }

/* ═══════════════════════════════════════════════════════
   LIGHT THEME — Professional Claude-inspired palette
   Applied when html[data-theme="light"]
   ═══════════════════════════════════════════════════════ */

html[data-theme="light"] {
  --bg:         #f0ede6;
  --bg-soft:    #ece9e0;
  --panel:      #f8f6f2;
  --panel-2:    #ece9e2;
  --panel-3:    #e4dfd8;
  --line:       rgba(0,0,0,.12);
  --line-2:     rgba(0,0,0,.20);
  --text:       #2c3545;
  --muted:      #606470;
  --gold:       #b8832a;
  --gold-soft:  rgba(184,131,42,.15);
  --gold-brd:   rgba(184,131,42,.35);
  --blue:       #2257d4;
  --green:      #1a8a6e;
  --red:        #c94040;
  --amber:      #b86f10;
  --shadow:     0 20px 50px rgba(0,0,0,.12);
  --navy:       #cbc8bf;
  --mid:        #4a6db0;
  --sub:        #7a8fba;
  --border:     #c6c0b8;
}

/* ── Body ── */
html[data-theme="light"] body {
  background: radial-gradient(circle at top,#e0ddd5 0%,#f0ede6 50%,#ece9e0 100%);
  color: var(--text);
}

/* ── Topbar — stays dark/black in light mode ── */
html[data-theme="light"] .topbar {
  background: rgba(8,13,26,.97);
  border-bottom-color: rgba(0,0,0,.35);
}
html[data-theme="light"] .brand-title { color: #fff; }
html[data-theme="light"] .brand-sub { color: rgba(255,255,255,.55); }
html[data-theme="light"] .mini-chip {
  border-color: rgba(255,255,255,.15);
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.7);
}
html[data-theme="light"] .user-menu-btn {
  background: rgba(255,255,255,.1);
  border-color: rgba(255,255,255,.2);
  color: rgba(255,255,255,.85);
}
html[data-theme="light"] .user-menu-btn:hover,
html[data-theme="light"] .user-menu-btn.active {
  background: rgba(217,183,95,.22);
  border-color: rgba(217,183,95,.55);
  color: #fff;
}

/* ── Tab nav — always stays dark/black in both light and dark mode ── */
html[data-theme="light"] .tab-nav {
  background: rgba(10,16,31,.9);
  border-bottom-color: #d9b75f;
}
html[data-theme="light"] .tab-nav a { color: rgba(255,255,255,.65); }
html[data-theme="light"] .tab-nav a:hover { color: rgba(255,255,255,.9); border-bottom-color: rgba(217,183,95,.55); }
html[data-theme="light"] .tab-nav a.active { color: #d9b75f; border-bottom-color: #d9b75f; }
html[data-theme="light"] .tab-nav-badge { background: #d9b75f; color: #0f1525; }

/* ── Left nav ── */
html[data-theme="light"] .left-nav {
  background: linear-gradient(160deg,rgba(252,250,247,.99) 0%,rgba(245,242,236,1) 100%);
  border-right-color: rgba(0,0,0,.12);
}
html[data-theme="light"] .nav-section-label { color: rgba(184,131,42,.8); border-bottom-color: rgba(0,0,0,.1); }
html[data-theme="light"] .nav-label { color: rgba(44,53,69,.65); }
html[data-theme="light"] .sector-nav-item.active .nav-label { color: var(--gold); }
html[data-theme="light"] .sector-nav-item:hover .nav-label { color: var(--text); }
html[data-theme="light"] .nav-count {
  color: var(--muted);
  background: rgba(0,0,0,.07);
  border-color: rgba(0,0,0,.12);
}
html[data-theme="light"] .sector-nav-item:hover { background: rgba(184,131,42,.07); border-left-color: rgba(184,131,42,.4); }
html[data-theme="light"] .sector-nav-item.active { background: linear-gradient(90deg,rgba(184,131,42,.15),rgba(184,131,42,.05)); border-left-color: var(--gold); }

/* ── Main content area — subtle lift from body bg ── */
html[data-theme="light"] .main-content { background: rgba(248,246,242,.12); }

/* ── Sol subtab bar — clearly whiter than the body blue-gray ── */
html[data-theme="light"] .sol-subtab-bar {
  background: rgba(244,242,237,.85);
  border-bottom-color: var(--gold);
  box-shadow: 0 2px 6px rgba(0,0,0,.06);
}
html[data-theme="light"] .sol-subtab { color: rgba(44,53,69,.7); background: transparent; border: none; }
html[data-theme="light"] .sol-subtab:hover { color: var(--text); border-bottom-color: rgba(184,131,42,.55); }
html[data-theme="light"] .sol-subtab.sol-subtab-active { color: var(--gold); border-bottom-color: var(--gold); }

/* ── Sol cards ── */
html[data-theme="light"] .sol-card {
  background: linear-gradient(160deg,rgba(252,250,247,.99) 0%,rgba(245,242,236,1) 100%);
  border-color: rgba(0,0,0,.12);
  border-left-color: #4a7ecf;
  box-shadow: 0 2px 10px rgba(0,0,0,.07);
}
html[data-theme="light"] .sol-card-manual { border-left-color: #26864c; }
html[data-theme="light"] .sol-card:hover {
  box-shadow: 0 4px 20px rgba(0,0,0,.12);
}
html[data-theme="light"] .sol-card-header {
  background: rgba(184,131,42,.16);
  border-bottom-color: rgba(184,131,42,.32);
}
html[data-theme="light"] .sol-title { color: var(--text); }
html[data-theme="light"] .sol-type-tag { color: rgba(44,53,69,.65); }
html[data-theme="light"] .sol-summary { color: var(--text); }
html[data-theme="light"] .tech-meta-strip { background: rgba(0,0,0,.02); border-bottom-color: rgba(0,0,0,.06); }
html[data-theme="light"] .tm-chip { border-color: rgba(0,0,0,.15); background: rgba(0,0,0,.05); }
html[data-theme="light"] .tm-lbl { color: rgba(44,53,69,.55); }
html[data-theme="light"] .tm-val { color: var(--text); }
/* Colored chip variants — darken text and adjust backgrounds for light bg */
html[data-theme="light"] .tm-chip.red { background: rgba(153,27,27,.1); border-color: rgba(153,27,27,.28); }
html[data-theme="light"] .tm-chip.red .tm-val { color: #7f1d1d; }
html[data-theme="light"] .tm-chip.green { background: rgba(22,101,52,.1); border-color: rgba(22,101,52,.28); }
html[data-theme="light"] .tm-chip.green .tm-val { color: #166534; }
html[data-theme="light"] .tm-chip.gold .tm-val { color: #7a5010; }

/* ── Sector page header ── */
html[data-theme="light"] .sector-page-header {
  background: rgba(184,131,42,.07);
  border-color: rgba(0,0,0,.12);
  border-left-color: var(--gold);
}
html[data-theme="light"] .sector-page-title { color: var(--text); }
html[data-theme="light"] .sector-page-desc { color: rgba(44,53,69,.7); }
html[data-theme="light"] .sector-page-badge-label { color: rgba(44,53,69,.65); }

/* ── Sol sector jump bar ── */
html[data-theme="light"] .sol-sector-jump-bar {
  background: rgba(244,242,237,.65);
  border-bottom-color: rgba(0,0,0,.1);
}
html[data-theme="light"] .sol-jump-btn {
  border-color: rgba(0,0,0,.16);
  background: rgba(244,242,237,.7);
  color: rgba(44,53,69,.7);
}
html[data-theme="light"] .sol-jump-btn:hover,
html[data-theme="light"] .sol-jump-btn.active {
  border-color: rgba(184,131,42,.55);
  color: var(--gold);
  background: rgba(184,131,42,.1);
}

/* ── Sol inner tab bar ── */
html[data-theme="light"] .sol-inner-tab-bar {
  background: rgba(244,242,237,.68);
  border-bottom-color: rgba(0,0,0,.1);
}
html[data-theme="light"] .sol-inner-tab {
  color: rgba(44,53,69,.75);
  background: rgba(244,242,237,.58);
  border-color: rgba(0,0,0,.12);
}
html[data-theme="light"] .sol-inner-tab:hover { color: var(--text); background: rgba(0,0,0,.08); }
html[data-theme="light"] .sol-inner-tab.sol-inner-tab-active { color: #0d5228; background: rgba(22,101,52,.12); border-color: rgba(22,101,52,.35); }

/* ── Date group header — clear panel bg so date dividers stand out ── */
html[data-theme="light"] .sol-date-group-header {
  background: rgba(184,131,42,.12);
  border-bottom: 1px solid rgba(184,131,42,.3);
  color: #6b4110;
}

/* ── Queue topbar ── */
html[data-theme="light"] .queue-topbar {
  background: rgba(248,246,242,.92);
  border-bottom-color: rgba(0,0,0,.1);
}
html[data-theme="light"] .queue-card {
  background: linear-gradient(160deg,rgba(252,250,247,.99) 0%,rgba(245,242,236,1) 100%);
  border-color: rgba(0,0,0,.1);
}
html[data-theme="light"] .queue-card-title { color: var(--text); }
html[data-theme="light"] .queue-card-title-link { color: var(--blue); }
html[data-theme="light"] .queue-card-title-link:hover { color: var(--text); }
html[data-theme="light"] .queue-card-comment { color: var(--muted); border-left-color: rgba(0,0,0,.12); }
html[data-theme="light"] .queue-card-summary { color: var(--muted); background: rgba(0,0,0,.03); border-color: rgba(0,0,0,.08); }
html[data-theme="light"] .queue-card-by { color: var(--muted); }
/* ── Yes / No bid action buttons ── */
html[data-theme="light"] .bid-btn {
  background: rgba(6,95,70,.16);
  border-color: rgba(6,95,70,.45);
  color: #055040;
}
html[data-theme="light"] .bid-btn:hover { background: #1a8a6e; border-color: #1a8a6e; color: #fff; }
html[data-theme="light"] .nobid-btn {
  background: rgba(153,27,27,.14);
  border-color: rgba(153,27,27,.45);
  color: #7f1d1d;
}
html[data-theme="light"] .nobid-btn:hover { background: #c94040; border-color: #c94040; color: #fff; }
html[data-theme="light"] .queue-section-header {
  background: rgba(0,0,0,.04);
  border-color: rgba(0,0,0,.1);
  border-left-color: var(--gold);
}
html[data-theme="light"] .queue-section-title { color: var(--text); }
html[data-theme="light"] .queue-submissions { background: rgba(0,0,0,.03); border-color: rgba(0,0,0,.08); }
html[data-theme="light"] .queue-submission-item { color: var(--muted); }
html[data-theme="light"] .queue-submission-user { color: rgba(44,53,69,.75); }
html[data-theme="light"] .queue-reply-form textarea {
  background: rgba(250,248,244,.75);
  border-color: rgba(0,0,0,.12);
  color: var(--text);
}
html[data-theme="light"] .chat-bubble-left .chat-bubble { background: rgba(0,0,0,.08); color: rgba(44,53,69,.85); }

/* ── No-bid archive ── */
html[data-theme="light"] .nobid-archive-card {
  background: linear-gradient(180deg,rgba(250,248,245,.99),rgba(248,245,242,1));
  border-color: rgba(0,0,0,.1);
}
html[data-theme="light"] .nobid-archive-card-title { color: var(--text); }

/* ── News ── */
html[data-theme="light"] .news-card {
  background: linear-gradient(180deg,rgba(250,248,245,.99),rgba(248,245,242,1));
  border-color: rgba(0,0,0,.1);
}
html[data-theme="light"] .news-card-title a { color: var(--text); }
html[data-theme="light"] .news-headliner {
  background: linear-gradient(180deg,rgba(250,248,245,.99),rgba(248,245,242,1));
  border-color: rgba(0,0,0,.1);
  color: inherit;
}
html[data-theme="light"] .news-headliner-title { color: var(--text); }
html[data-theme="light"] .news-secondary-item {
  background: linear-gradient(180deg,rgba(250,248,245,.99),rgba(248,245,242,1));
  border-color: rgba(0,0,0,.1);
  color: inherit;
}
html[data-theme="light"] .news-secondary-title { color: var(--text); }
html[data-theme="light"] .news-tertiary-item {
  background: linear-gradient(180deg,rgba(250,248,245,.99),rgba(248,245,242,1));
  border-color: rgba(0,0,0,.1);
  color: inherit;
}
html[data-theme="light"] .news-tertiary-title { color: var(--text); }
html[data-theme="light"] .news-text-list { border-color: rgba(0,0,0,.12); }
html[data-theme="light"] .news-text-item { border-bottom-color: rgba(0,0,0,.08); color: inherit; }
html[data-theme="light"] .news-text-item:hover { background: rgba(0,0,0,.04); }
html[data-theme="light"] .news-text-item-title { color: var(--text); }
html[data-theme="light"] .news-updates-note { background: rgba(0,0,0,.04); border-color: rgba(0,0,0,.1); color: var(--text); }
html[data-theme="light"] .news-updates-note strong { color: var(--text); }
html[data-theme="light"] .news-empty-state { background: rgba(0,0,0,.03); border-color: rgba(0,0,0,.1); }

/* ── RT topbar ── */
html[data-theme="light"] .rt-topbar {
  background: rgba(250,248,244,.78);
  border-bottom-color: rgba(0,0,0,.12);
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
}
html[data-theme="light"] .rt-topbar-heading { color: var(--text); }
html[data-theme="light"] .rt-nav-tab { color: rgba(44,53,69,.72); }
html[data-theme="light"] .rt-nav-tab:hover,
html[data-theme="light"] .rt-nav-tab.rt-active { color: var(--text); background: rgba(0,0,0,.1); }
html[data-theme="light"] .sv { color: var(--text); }
html[data-theme="light"] .rt-ctrl-input,
html[data-theme="light"] .rt-ctrl-select { background: rgba(248,246,242,.88); color: var(--text); }

/* ── RT board ── */
html[data-theme="light"] .rt-col {
  background: rgba(250,248,244,.35);
  border-color: rgba(0,0,0,.13);
  box-shadow: 0 2px 8px rgba(0,0,0,.05);
}
html[data-theme="light"] .rt-col-head {
  background: rgba(184,131,42,.22);
  border-bottom-color: rgba(184,131,42,.40);
  border-radius: 8px 8px 0 0;
}
html[data-theme="light"] .rt-col-label { color: #6b4110; }
html[data-theme="light"] .rt-col-count { background: rgba(184,131,42,.28); color: #6b4110; }
html[data-theme="light"] .rt-opp-card {
  background: linear-gradient(160deg,rgba(252,250,247,.99) 0%,rgba(245,242,236,1) 100%);
  border-color: rgba(0,0,0,.12);
  box-shadow: 0 1px 5px rgba(0,0,0,.07);
}
html[data-theme="light"] .rt-opp-card:hover { box-shadow: 0 3px 12px rgba(0,0,0,.12); }
html[data-theme="light"] .rt-opp-card-won { background: rgba(22,101,52,.1); border-color: rgba(22,101,52,.25); }
html[data-theme="light"] .rt-opp-card-lost { background: rgba(153,27,27,.08); border-color: rgba(153,27,27,.2); }
html[data-theme="light"] .rt-opp-title { color: var(--text); }
/* Board meta badges — dark readable text */
html[data-theme="light"] .bdg-type { background: rgba(30,66,160,.1); color: #1e4080; border-color: rgba(30,66,160,.25); }
html[data-theme="light"] .bdg-dl-ok   { background: rgba(6,95,70,.1);    color: #065f46; border-color: rgba(6,95,70,.25); }
html[data-theme="light"] .bdg-dl-warn { background: rgba(124,82,0,.1);   color: #7c5200; border-color: rgba(124,82,0,.25); }
html[data-theme="light"] .bdg-dl-hot  { background: rgba(153,27,27,.12); color: #7f1d1d; border-color: rgba(153,27,27,.28); }
html[data-theme="light"] .bdg-dl-na   { background: rgba(0,0,0,.05); color: rgba(44,53,69,.55); border-color: rgba(0,0,0,.12); }
html[data-theme="light"] .rt-opp-header:hover { background: rgba(0,0,0,.04); }
html[data-theme="light"] .rt-drop-hint { color: var(--muted); }
html[data-theme="light"] .rt-client-row { background: rgba(0,0,0,.05); border-color: rgba(0,0,0,.1); }
html[data-theme="light"] .rt-client-row:hover { background: rgba(0,0,0,.1); border-color: rgba(0,0,0,.18); }
html[data-theme="light"] .rt-client-name { color: var(--text); }
html[data-theme="light"] .rt-client-name-input { color: var(--text); }
html[data-theme="light"] .rt-client-dd-trigger { color: var(--text); }
html[data-theme="light"] .rt-bd-comment-popup { background: var(--panel); border-color: rgba(0,0,0,.15); }
html[data-theme="light"] .rt-bd-comment-popup-body { color: var(--text); }
html[data-theme="light"] .rt-client-dd-panel { background: var(--panel); border-color: rgba(184,131,42,.45); }
html[data-theme="light"] .rt-client-dd-search { background: rgba(0,0,0,.05); border-bottom-color: rgba(0,0,0,.1); color: var(--text); }
html[data-theme="light"] .rt-client-dd-search::placeholder { color: rgba(44,53,69,.35); }
html[data-theme="light"] .rt-cd-option { color: #2a3458; }
html[data-theme="light"] .rt-cd-option:hover { background: rgba(184,131,42,.15); color: var(--text); }
html[data-theme="light"] .rt-cd-option-sel { background: rgba(184,131,42,.2); color: var(--gold); }
html[data-theme="light"] .rt-cd-no-results { color: var(--muted); }

/* ── Proposal Workshop ── */
html[data-theme="light"] .pw-sidebar {
  background: rgba(235,231,221,.97);
  border-right-color: rgba(0,0,0,.1);
}
html[data-theme="light"] .pw-sidebar-head { border-bottom-color: rgba(0,0,0,.1); }
html[data-theme="light"] .pw-sidebar-search {
  background: rgba(0,0,0,.08);
  border-color: rgba(0,0,0,.12);
  color: var(--text);
}
html[data-theme="light"] .pw-sidebar-search::placeholder { color: rgba(44,53,69,.4); }
html[data-theme="light"] .pw-opp-item:hover { background: rgba(0,0,0,.06); }
html[data-theme="light"] .pw-opp-item.active { background: rgba(184,131,42,.12); border-left-color: var(--gold); }
html[data-theme="light"] .pw-opp-name { color: var(--text); }
html[data-theme="light"] .pw-topbar {
  background: rgba(235,231,221,.95);
  border-bottom-color: rgba(0,0,0,.1);
}
html[data-theme="light"] .pw-opp-title-display { color: var(--text); }
html[data-theme="light"] .pw-welcome-title { color: var(--text); }
html[data-theme="light"] .pw-card {
  background: rgba(0,0,0,.04);
  border-color: rgba(0,0,0,.1);
}
html[data-theme="light"] .pw-card-head {
  background: rgba(235,231,221,.95);
  border-bottom-color: rgba(0,0,0,.1);
}
html[data-theme="light"] .pw-fact-val { color: var(--text); }
html[data-theme="light"] .pw-section {
  background: rgba(0,0,0,.03);
  border-color: rgba(0,0,0,.1);
}
html[data-theme="light"] .pw-section-head {
  background: rgba(0,0,0,.04);
  border-bottom-color: rgba(0,0,0,.1);
}
html[data-theme="light"] .pw-section-title { color: var(--text); }
html[data-theme="light"] .pw-textarea {
  background: rgba(250,248,244,.85);
  border-color: rgba(0,0,0,.15);
  color: var(--text);
}
html[data-theme="light"] .pw-textarea::placeholder { color: rgba(44,53,69,.35); }
html[data-theme="light"] .pw-actions-bar {
  background: rgba(235,231,221,.95);
  border-top-color: rgba(0,0,0,.1);
}
html[data-theme="light"] .pw-tabs { border-bottom-color: rgba(0,0,0,.1); }
html[data-theme="light"] .pw-checklist li { color: var(--text); border-bottom-color: rgba(0,0,0,.08); }
html[data-theme="light"] .pw-sidebar-footer { border-top-color: rgba(0,0,0,.1); }

/* ── Modal & overlays ── */
html[data-theme="light"] .overlay { background: rgba(140,155,190,.72); }
html[data-theme="light"] .modal {
  background: linear-gradient(180deg,var(--panel),var(--bg-soft));
  border-color: rgba(0,0,0,.15);
}
html[data-theme="light"] .modal-hd {
  background: rgba(235,231,221,.97);
  border-bottom-color: rgba(0,0,0,.1);
}
html[data-theme="light"] .modal-hd h2 { color: var(--text); }
html[data-theme="light"] .close-btn {
  background: rgba(0,0,0,.08);
  border-color: rgba(0,0,0,.12);
  color: var(--text);
}
html[data-theme="light"] .modal-ft {
  background: rgba(235,231,221,.97);
  border-top-color: rgba(0,0,0,.1);
}
html[data-theme="light"] .fld input,
html[data-theme="light"] .fld select,
html[data-theme="light"] .fld textarea {
  background: rgba(250,248,244,.85);
  border-color: rgba(0,0,0,.15);
  color: var(--text);
}
html[data-theme="light"] .fld label { color: var(--muted); }
html[data-theme="light"] .fld input::placeholder,
html[data-theme="light"] .fld textarea::placeholder { color: rgba(44,53,69,.35); }
html[data-theme="light"] .fld select option { background: var(--panel); color: var(--text); }
html[data-theme="light"] .dlbl { color: var(--gold); border-top-color: rgba(0,0,0,.1); }
html[data-theme="light"] .tab-row { border-bottom-color: rgba(0,0,0,.1); }
html[data-theme="light"] .check-row { color: var(--text); }
html[data-theme="light"] .detail-row { background: rgba(0,0,0,.04); border-color: rgba(0,0,0,.1); }
html[data-theme="light"] .dv { color: var(--text); }
html[data-theme="light"] .rubric-box { border-color: rgba(0,0,0,.12); }
html[data-theme="light"] .rubric-hd { background: rgba(0,0,0,.04); border-bottom-color: rgba(0,0,0,.1); }
html[data-theme="light"] .rubric-factor { border-bottom-color: rgba(0,0,0,.08); }
html[data-theme="light"] .rf-lbl { color: var(--text); }
html[data-theme="light"] .exsum-box,
html[data-theme="light"] .notes-box { background: rgba(0,0,0,.04); border-color: rgba(0,0,0,.1); color: var(--text); }
html[data-theme="light"] .email-body { background: rgba(0,0,0,.04); border-color: rgba(0,0,0,.1); color: var(--text); }
html[data-theme="light"] .staff-card { background: rgba(0,0,0,.05); border-color: rgba(0,0,0,.1); }
html[data-theme="light"] .sc-name { color: var(--text); }
html[data-theme="light"] .add-sol-note { background: rgba(184,131,42,.07); border-color: var(--gold-brd); color: var(--text); }
html[data-theme="light"] .add-sol-dest-opt { background: rgba(0,0,0,.04); border-color: rgba(0,0,0,.1); color: var(--text); }
html[data-theme="light"] .add-sol-dest-opt:hover { border-color: var(--gold-brd); background: rgba(184,131,42,.07); }
html[data-theme="light"] .add-sol-client-chip { background: rgba(0,0,0,.04); border-color: rgba(0,0,0,.1); }
html[data-theme="light"] .add-sol-client-chip-name { color: var(--text); }
html[data-theme="light"] .add-sol-team-chip { background: rgba(0,0,0,.05); border-color: rgba(0,0,0,.1); }
html[data-theme="light"] .add-sol-team-val { color: var(--text); }
html[data-theme="light"] .cons-desc { background: rgba(0,0,0,.05); border-color: rgba(0,0,0,.1); color: var(--text); }
html[data-theme="light"] .cons-input { border-bottom-color: rgba(0,0,0,.12); color: var(--text); }

/* ── Pipeline table ── */
html[data-theme="light"] .pl-header { background: rgba(250,248,244,.78); border-bottom-color: rgba(0,0,0,.12); box-shadow: 0 2px 6px rgba(0,0,0,.06); }
html[data-theme="light"] .pl-header-title { color: var(--text); }
html[data-theme="light"] .pl-th { background: rgba(232,228,218,.98); color: rgba(44,53,69,.7); border-bottom-color: rgba(0,0,0,.14); }
html[data-theme="light"] .pl-th:hover { color: var(--text); }
html[data-theme="light"] .pl-tr { border-bottom-color: rgba(0,0,0,.09); }
html[data-theme="light"] .pl-tr-even { background: rgba(250,248,244,.55); }
html[data-theme="light"] .pl-tr-odd  { background: rgba(250,248,244,.2); }
html[data-theme="light"] .pl-tr:hover { background: rgba(184,131,42,.07)!important; }
html[data-theme="light"] .pl-opp-link { color: var(--text); }
html[data-theme="light"] .pl-opp-text { color: var(--text); }
html[data-theme="light"] .pl-opp-sol { color: rgba(44,53,69,.6); }
html[data-theme="light"] .pl-office-text { color: var(--text); }
html[data-theme="light"] .pl-client-name { color: var(--text); }
html[data-theme="light"] .pl-stage-lbl { color: var(--text); }
/* Type tag — dark blue text on light bg */
html[data-theme="light"] .pl-type-tag { background: rgba(30,66,160,.1); color: #1e4080; border-color: rgba(30,66,160,.25); }
/* Deadline badges — dark text versions */
html[data-theme="light"] .pl-dl-hot  { background: rgba(153,27,27,.12);  color: #7f1d1d; border-color: rgba(153,27,27,.28); }
html[data-theme="light"] .pl-dl-warn { background: rgba(124,82,0,.1);    color: #7c5200; border-color: rgba(124,82,0,.25); }
html[data-theme="light"] .pl-dl-ok   { background: rgba(6,95,70,.1);     color: #065f46; border-color: rgba(6,95,70,.25); }
/* Stage pill — dark text (pill bg is tinted from stage color variable) */
html[data-theme="light"] .pl-stage-pill { color: rgba(15,20,45,.85); }
/* Bid decision badges — dark text */
html[data-theme="light"] .pl-bid-go    { background: rgba(6,95,70,.1);    color: #065f46; border-color: rgba(6,95,70,.3); }
html[data-theme="light"] .pl-bid-nobid { background: rgba(153,27,27,.1);  color: #7f1d1d; border-color: rgba(153,27,27,.25); }
html[data-theme="light"] .pl-bid-hold  { background: rgba(124,82,0,.1);   color: #7c5200; border-color: rgba(124,82,0,.25); }
html[data-theme="light"] .pl-footer { background: rgba(232,228,218,.97); border-top-color: rgba(0,0,0,.1); }
html[data-theme="light"] .pl-footer strong { color: var(--text); }
html[data-theme="light"] .pl-sub-panel { border-top-color: rgba(0,0,0,.08); }
html[data-theme="light"] .pl-cb-row { background: rgba(0,0,0,.04); border-color: rgba(0,0,0,.1); }
html[data-theme="light"] .pl-cb-row:hover { background: rgba(0,0,0,.08); border-color: rgba(0,0,0,.18); }
html[data-theme="light"] .pl-cb-stage-sel { background: rgba(250,248,244,.75); border-color: rgba(0,0,0,.15); color: var(--text); }
html[data-theme="light"] .pl-cb-stage-sel option { background: var(--panel); color: var(--text); }
html[data-theme="light"] .status-sel { background: rgba(250,248,244,.75); border-color: rgba(0,0,0,.15); color: var(--text); }
html[data-theme="light"] .status-sel option { background: var(--panel); color: var(--text); }

/* ── Cover screen ── */
html[data-theme="light"] .cover-card {
  background: linear-gradient(160deg,rgba(252,250,247,.99) 0%,rgba(245,242,236,1) 100%);
  border-color: rgba(0,0,0,.1);
  border-top-color: rgba(0,0,0,.07);
}
html[data-theme="light"] .cover-card:hover,
html[data-theme="light"] .cover-card:focus { box-shadow: 0 16px 48px rgba(0,0,0,.15), 0 0 0 1px rgba(184,131,42,.18); }
html[data-theme="light"] .cover-user-name { color: var(--text); }
html[data-theme="light"] .cover-tagline { color: rgba(44,53,69,.45); }
html[data-theme="light"] .cover-section-title { color: rgba(44,53,69,.55); }
html[data-theme="light"] .cover-card-title { color: var(--text); }
html[data-theme="light"] .cover-section-header { border-bottom-color: rgba(0,0,0,.1); }

/* ── Leaderboard / Tables ── */
html[data-theme="light"] .section-hd h2 { color: var(--text); }
html[data-theme="light"] .lb-nm { color: var(--text); }
html[data-theme="light"] .wr-track { background: rgba(0,0,0,.1); }
html[data-theme="light"] .dim { color: rgba(44,53,69,.35); }
html[data-theme="light"] table.tbl th { border-bottom-color: rgba(0,0,0,.12); }
html[data-theme="light"] table.tbl td { border-bottom-color: rgba(0,0,0,.08); color: var(--text); }
html[data-theme="light"] table.tbl tr:hover td { background: rgba(0,0,0,.03); }
html[data-theme="light"] .sec-filter select { background: rgba(250,248,244,.75); border-color: rgba(0,0,0,.12); color: var(--text); }

/* ── Feedback tab ── */
html[data-theme="light"] .fb-title { color: var(--text); }
html[data-theme="light"] .fb-composer { background: var(--panel); border-color: rgba(0,0,0,.1); }
html[data-theme="light"] .fb-textarea {
  background: rgba(250,248,244,.75);
  border-color: rgba(0,0,0,.12);
  color: var(--text);
}
html[data-theme="light"] .fb-textarea::placeholder { color: rgba(44,53,69,.35); }
html[data-theme="light"] .fb-section-cb { color: var(--muted); border-color: rgba(0,0,0,.12); background: rgba(0,0,0,.03); }
html[data-theme="light"] .fb-avatar { background: var(--panel-2); border-color: rgba(0,0,0,.1); }
html[data-theme="light"] .fb-post { background: var(--panel); border-color: rgba(0,0,0,.1); }
html[data-theme="light"] .fb-post-author { color: var(--text); }
html[data-theme="light"] .fb-post-actions { border-top-color: rgba(0,0,0,.08); }
html[data-theme="light"] .fb-like-btn { border-color: rgba(0,0,0,.12); color: var(--muted); }
html[data-theme="light"] .fb-like-btn:hover { background: rgba(0,0,0,.06); }
html[data-theme="light"] .fb-reply-toggle { border-color: rgba(0,0,0,.12); color: var(--muted); }
html[data-theme="light"] .fb-reply-toggle:hover { background: rgba(0,0,0,.06); }
html[data-theme="light"] .fb-comment { background: rgba(0,0,0,.03); border-color: rgba(0,0,0,.08); }
html[data-theme="light"] .fb-post-body { color: var(--text); }
html[data-theme="light"] .fb-comment-body { color: var(--text); }
html[data-theme="light"] .fb-comments-wrap { border-top-color: rgba(0,0,0,.08); }

/* ── Admin tables ── */
html[data-theme="light"] .admin-archive-toggle-btn {
  background: rgba(0,0,0,.04);
  border-color: rgba(0,0,0,.12);
  color: rgba(44,53,69,.6);
}
html[data-theme="light"] .admin-decision-table th {
  background: rgba(0,0,0,.04);
  border-bottom-color: rgba(0,0,0,.12);
  color: var(--muted);
}
html[data-theme="light"] .admin-decision-table th:hover { color: var(--text); }
html[data-theme="light"] .admin-decision-table td { border-bottom-color: rgba(0,0,0,.08); color: var(--text); }
html[data-theme="light"] .admin-decision-table tr:nth-child(even) { background: rgba(0,0,0,.02); }

/* ── Settings dropdown ── */
html[data-theme="light"] .settings-dropdown {
  background: rgba(240,243,251,.98);
  border-color: rgba(0,0,0,.15);
  box-shadow: 0 8px 32px rgba(0,0,0,.15);
}
html[data-theme="light"] .settings-dd-item { color: rgba(44,53,69,.8); }
html[data-theme="light"] .settings-dd-item:hover { background: rgba(184,131,42,.08); color: var(--text); }
html[data-theme="light"] .settings-dd-item.danger { color: rgba(201,64,64,.85); }
html[data-theme="light"] .settings-dd-item.danger:hover { background: rgba(201,64,64,.08); color: var(--red); }
html[data-theme="light"] .settings-dd-divider { background: rgba(0,0,0,.1); }
html[data-theme="light"] .theme-btn {
  border-color: rgba(0,0,0,.18);
  background: rgba(0,0,0,.07);
  color: #3a4560;
}
html[data-theme="light"] .theme-btn:hover {
  background: rgba(184,131,42,.15);
  border-color: rgba(184,131,42,.55);
  color: var(--text);
}
html[data-theme="light"] .theme-btn.theme-btn-active {
  background: rgba(184,131,42,.2);
  border-color: var(--gold);
  color: #7a5010;
  font-weight: 700;
}

/* ── Toast ── */
html[data-theme="light"] #rt-toast { background: var(--text); color: #fff; }

/* ── Mobile left-nav in light mode ── */
@media (max-width:767px) {
  html[data-theme="light"] .left-nav {
    background: rgba(235,231,221,.97);
    border-bottom-color: rgba(0,0,0,.1);
  }
  html[data-theme="light"] .sector-nav-item { background: rgba(0,0,0,.05)!important; }
  html[data-theme="light"] .sector-nav-item:hover { background: rgba(184,131,42,.08)!important; }
  html[data-theme="light"] .sector-nav-item.active {
    background: linear-gradient(90deg,rgba(184,131,42,.18),rgba(184,131,42,.07))!important;
  }
}

/* ═══════════════════════════════════════════════════════
   LIGHT THEME — Weekly Status page overrides
   ═══════════════════════════════════════════════════════ */
html[data-theme="light"] .ws-report-header {
  background: linear-gradient(135deg, rgba(45,100,79,.12) 0%, rgba(184,131,42,.1) 60%);
  border-color: rgba(184,131,42,.3);
}
html[data-theme="light"] .ws-report-title { color: var(--text); }
html[data-theme="light"] .ws-report-week { color: var(--text); }
html[data-theme="light"] .ws-kpi {
  background: linear-gradient(135deg, rgba(248,246,242,.97), rgba(234,231,222,1));
  border-color: rgba(0,0,0,.1);
}
html[data-theme="light"] .ws-kpi-value { color: var(--text); }
html[data-theme="light"] .ws-kpi-sub { color: rgba(44,53,69,.45); }
html[data-theme="light"] .ws-section {
  background: rgba(244,240,230,.92);
  border-color: rgba(0,0,0,.1);
}
html[data-theme="light"] .ws-section-head {
  background: rgba(0,0,0,.03);
  border-bottom-color: rgba(0,0,0,.08);
}
html[data-theme="light"] .ws-section-title { color: var(--text); }
html[data-theme="light"] .ws-table-wrap {
  background: rgba(250,248,244,.65);
  border-color: rgba(0,0,0,.1);
}
html[data-theme="light"] .ws-table th {
  color: var(--gold);
  background: rgba(0,0,0,.03);
  border-bottom-color: rgba(0,0,0,.1);
}
html[data-theme="light"] .ws-table td {
  border-bottom-color: rgba(0,0,0,.07);
  color: var(--text);
}
html[data-theme="light"] .ws-table tr:hover td { background: rgba(0,0,0,.03); }
html[data-theme="light"] .ws-table .ws-td-title { color: var(--text); }
html[data-theme="light"] .ws-rank-name { color: var(--text); }
html[data-theme="light"] .ws-rank-bar-wrap { background: rgba(0,0,0,.1); }
html[data-theme="light"] .ws-vel-track { background: rgba(0,0,0,.08); }
html[data-theme="light"] .ws-vel-total { color: rgba(44,53,69,.55); }
html[data-theme="light"] .ws-summary {
  color: rgba(44,53,69,.8);
  background: rgba(184,131,42,.07);
  border-left-color: rgba(184,131,42,.5);
}
html[data-theme="light"] .ws-denied-card {
  background: rgba(244,240,230,.97);
  border-color: rgba(239,68,68,.25);
}
html[data-theme="light"] .ws-denied-title { color: var(--text); }
html[data-theme="light"] .ws-filter-bar {
  background: rgba(248,246,242,.95);
  border-bottom-color: rgba(0,0,0,.1);
}
html[data-theme="light"] .ws-filter-select {
  background: rgba(250,248,244,.9);
  border-color: rgba(0,0,0,.15);
  color: var(--text);
}
html[data-theme="light"] .ws-stage-card {
  background: rgba(248,246,242,.97);
  border-color: rgba(0,0,0,.1);
}
html[data-theme="light"] .ws-stage-card-label { color: var(--text); }
html[data-theme="light"] .ws-stage-card-total { color: var(--text); }
html[data-theme="light"] .ws-stage-card-updated { color: var(--muted); }
html[data-theme="light"] .ws-sol-section .ws-summary { color: rgba(44,53,69,.8); }
html[data-theme="light"] .ws-upload-day-date { color: var(--text); }
html[data-theme="light"] .ws-upload-day-count { color: var(--text); }
html[data-theme="light"] .ws-upload-day-label { color: var(--muted); }

/* ═══════════════════════════════════════════════════════
   LIGHT THEME — Legislative Calendar page overrides
   ═══════════════════════════════════════════════════════ */
html[data-theme="light"] .lc-header {
  background: linear-gradient(135deg, rgba(139,92,246,.1) 0%, rgba(184,131,42,.08) 60%);
  border-color: rgba(139,92,246,.3);
}
html[data-theme="light"] .lc-header-title { color: var(--text); }
html[data-theme="light"] .lc-cal-month-label { color: var(--text); }
html[data-theme="light"] .lc-cal-nav-btn {
  background: rgba(0,0,0,.06);
  border-color: rgba(0,0,0,.14);
  color: rgba(44,53,69,.7);
}
html[data-theme="light"] .lc-cal-nav-btn:hover {
  background: rgba(139,92,246,.18);
  border-color: rgba(139,92,246,.45);
  color: var(--text);
}
html[data-theme="light"] .lc-cal-today-btn {
  background: rgba(0,0,0,.06);
  border-color: rgba(0,0,0,.14);
  color: rgba(44,53,69,.7);
}
html[data-theme="light"] .lc-cal-today-btn:hover {
  background: rgba(139,92,246,.15);
  border-color: rgba(139,92,246,.4);
  color: var(--text);
}
html[data-theme="light"] .lc-cal-wrap {
  background: rgba(244,240,230,.92);
  border-color: rgba(0,0,0,.12);
}
html[data-theme="light"] .lc-cal-dow-row { border-bottom-color: rgba(0,0,0,.1); }
html[data-theme="light"] .lc-cal-day {
  border-right-color: rgba(0,0,0,.07);
  border-bottom-color: rgba(0,0,0,.07);
}
html[data-theme="light"] .lc-cal-day:hover { background: rgba(139,92,246,.06); }
html[data-theme="light"] .lc-cal-day.lc-today { background: rgba(139,92,246,.09); }
html[data-theme="light"] .lc-cal-day.lc-other-month .lc-day-num { color: rgba(44,53,69,.25); }
html[data-theme="light"] .lc-day-num { color: rgba(44,53,69,.7); }
/* Event pills — override inline colors with dark readable text */
html[data-theme="light"] .lc-event-pill { color: rgba(15,20,45,.85) !important; }
html[data-theme="light"] .lc-legend-chip { color: rgba(15,20,45,.75) !important; }
html[data-theme="light"] .lc-upcoming {
  background: rgba(244,240,230,.92);
  border-color: rgba(0,0,0,.1);
}
html[data-theme="light"] .lc-upcoming-title { color: var(--text); }
html[data-theme="light"] .lc-upcoming-item { border-bottom-color: rgba(0,0,0,.08); }
html[data-theme="light"] .lc-upcoming-item:hover .lc-upcoming-item-title { color: #000; }
html[data-theme="light"] .lc-upcoming-item-title { color: rgba(44,53,69,.85); }
html[data-theme="light"] .lc-upcoming-item-del { color: rgba(44,53,69,.25); }
html[data-theme="light"] .lc-stats {
  background: rgba(244,240,230,.92);
  border-color: rgba(0,0,0,.1);
}
html[data-theme="light"] .lc-stats-title { color: var(--text); }
html[data-theme="light"] .lc-stat-row { border-bottom-color: rgba(0,0,0,.07); }
html[data-theme="light"] .lc-stat-label { color: rgba(44,53,69,.7); }
html[data-theme="light"] .lc-stat-count { color: var(--text); }
html[data-theme="light"] .lc-overlay { background: rgba(140,155,190,.65); }
html[data-theme="light"] .lc-detail-overlay { background: rgba(140,155,190,.65); }
html[data-theme="light"] .lc-modal {
  background: var(--panel);
  border-color: rgba(0,0,0,.15);
}
html[data-theme="light"] .lc-modal-hd { border-bottom-color: rgba(0,0,0,.1); }
html[data-theme="light"] .lc-modal-title { color: var(--text); }
html[data-theme="light"] .lc-modal-close { color: rgba(44,53,69,.5); }
html[data-theme="light"] .lc-modal-close:hover { color: var(--text); }
html[data-theme="light"] .lc-modal-ft { border-top-color: rgba(0,0,0,.08); }
html[data-theme="light"] .lc-fld input,
html[data-theme="light"] .lc-fld select,
html[data-theme="light"] .lc-fld textarea {
  background: rgba(250,248,244,.85);
  border-color: rgba(0,0,0,.15);
  color: var(--text);
}
html[data-theme="light"] .lc-fld select option { background: var(--panel); color: var(--text); }
html[data-theme="light"] .lc-btn-secondary {
  border-color: rgba(0,0,0,.18);
  color: rgba(44,53,69,.7);
}
html[data-theme="light"] .lc-btn-secondary:hover {
  background: rgba(0,0,0,.07);
  border-color: rgba(0,0,0,.28);
  color: var(--text);
}
html[data-theme="light"] .lc-detail-modal {
  background: var(--panel);
  border-color: rgba(0,0,0,.15);
}
html[data-theme="light"] .lc-detail-title { color: var(--text); }
html[data-theme="light"] .lc-detail-notes {
  color: rgba(44,53,69,.8);
  background: rgba(0,0,0,.04);
  border-color: rgba(0,0,0,.08);
}

/* ═══════════════════════════════════════════════════════
   BUDGET ANALYSIS TAB
   Sharp Fluent 2-inspired design matching site theme
   ═══════════════════════════════════════════════════════ */

/* ── Shell layout ── */
.ba-shell {
  display: flex;
  min-height: calc(100vh - 99px);
}

/* ── Left sidebar ── */
.ba-sidebar {
  width: 220px;
  flex-shrink: 0;
  background: linear-gradient(180deg, rgba(22,32,60,.99), rgba(15,21,37,.99));
  border-right: 1px solid var(--line);
  position: sticky;
  top: 99px;
  height: calc(100vh - 99px);
  overflow-y: auto;
  overflow-x: hidden;
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,.12) transparent;
}
.ba-sidebar::-webkit-scrollbar { width: 3px; }
.ba-sidebar::-webkit-scrollbar-thumb { background: rgba(255,255,255,.12); border-radius: 2px; }

.ba-sidebar-header {
  padding: 16px 14px 10px;
  border-bottom: 1px solid var(--line);
}
.ba-sidebar-title {
  font-family: 'DM Mono', monospace;
  font-size: 8px;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: rgba(217,183,95,.75);
}

.ba-filter-group {
  padding: 12px 14px 6px;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.ba-filter-group:last-child { border-bottom: none; }

.ba-filter-group-label {
  font-family: 'DM Mono', monospace;
  font-size: 7.5px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(255,255,255,.38);
  margin-bottom: 8px;
}

/* Sector & appropriation filter buttons — sharp Fluent style */
.ba-sector-btn,
.ba-appro-btn {
  display: block;
  width: 100%;
  text-align: left;
  padding: 7px 10px;
  margin-bottom: 3px;
  background: transparent;
  border: 1px solid transparent;
  border-left: 2px solid transparent;
  border-radius: 2px;
  color: rgba(237,241,255,.6);
  font-size: 11.5px;
  font-weight: 500;
  cursor: pointer;
  transition: background .14s, border-color .14s, color .14s;
  line-height: 1.3;
}
.ba-sector-btn:hover,
.ba-appro-btn:hover {
  background: rgba(217,183,95,.08);
  border-left-color: rgba(217,183,95,.4);
  color: rgba(255,255,255,.9);
}
.ba-sector-btn-active,
.ba-appro-btn-active {
  background: linear-gradient(90deg, rgba(217,183,95,.16), rgba(217,183,95,.04));
  border-left-color: var(--gold);
  color: var(--gold);
}
.ba-sector-btn-active:hover,
.ba-appro-btn-active:hover {
  color: var(--gold);
}

/* Checkboxes */
.ba-check-row {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 4px 0;
  font-size: 11px;
  color: rgba(237,241,255,.65);
  cursor: pointer;
  transition: color .12s;
}
.ba-check-row:hover { color: rgba(255,255,255,.9); }
.ba-check-row input[type="checkbox"] {
  accent-color: var(--gold);
  width: 13px;
  height: 13px;
  flex-shrink: 0;
  cursor: pointer;
}

/* FY selector */
.ba-select {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 3px;
  color: var(--text);
  font: inherit;
  font-size: 11.5px;
  padding: 5px 8px;
  width: 100%;
  cursor: pointer;
  transition: border-color .14s;
  appearance: auto;
}
.ba-select:hover, .ba-select:focus {
  border-color: rgba(217,183,95,.5);
  outline: none;
}
.ba-select option { background: #162035; }

/* Legend */
.ba-legend-row {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 10px;
  color: rgba(255,255,255,.5);
  padding: 2px 0;
}
.ba-delta { font-family: 'DM Mono', monospace; font-size: 9.5px; font-weight: 600; }
.ba-delta-up   { color: #4ade80; }
.ba-delta-down { color: #ff7b7b; }
.ba-delta-zero { color: var(--muted); }
.ba-pending-pill {
  font-family: 'DM Mono', monospace;
  font-size: 7.5px;
  letter-spacing: .08em;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 2px;
  padding: 1px 5px;
  color: rgba(255,255,255,.5);
}

/* ── Main content area ── */
.ba-main {
  flex: 1;
  min-width: 0;
  padding: 24px 24px 64px;
  overflow-x: auto;
}

/* ── Page header ── */
.ba-page-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 18px;
  padding: 16px 18px;
  background: rgba(255,255,255,.06);
  border: 1px solid var(--line);
  border-left: 3px solid var(--gold);
  border-radius: 4px;
}
.ba-page-eyebrow {
  font-family: 'DM Mono', monospace;
  font-size: 7.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(217,183,95,.7);
  margin-bottom: 5px;
}
.ba-page-title {
  font-family: Manrope, sans-serif;
  font-size: 1.35rem;
  font-weight: 800;
  color: #fff;
  letter-spacing: -.03em;
  margin: 0 0 4px;
}
.ba-page-sub {
  font-size: 11.5px;
  color: var(--muted);
  line-height: 1.5;
  max-width: 540px;
}
.ba-page-header-right {
  display: flex;
  gap: 16px;
  flex-shrink: 0;
  align-items: flex-start;
}
.ba-stat-block {
  text-align: right;
}
.ba-stat-num {
  font-family: Manrope, sans-serif;
  font-size: 1.6rem;
  font-weight: 800;
  color: var(--gold);
  line-height: 1;
}
.ba-stat-lbl {
  font-family: 'DM Mono', monospace;
  font-size: 7px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: rgba(255,255,255,.55);
  margin-top: 3px;
}

/* ── Command bar ── */
.ba-command-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
  flex-wrap: wrap;
}
.ba-search-wrap {
  flex: 1;
  min-width: 200px;
  position: relative;
  display: flex;
  align-items: center;
}
.ba-search-icon {
  position: absolute;
  left: 9px;
  color: rgba(255,255,255,.35);
  pointer-events: none;
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}
.ba-search-input {
  width: 100%;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 3px;
  color: var(--text);
  font: inherit;
  font-size: 12px;
  padding: 7px 30px 7px 30px;
  transition: border-color .14s, background .14s;
}
.ba-search-input::placeholder { color: rgba(255,255,255,.28); }
.ba-search-input:focus {
  outline: none;
  border-color: rgba(217,183,95,.5);
  background: rgba(255,255,255,.09);
}
.ba-search-clear {
  position: absolute;
  right: 8px;
  background: transparent;
  border: none;
  color: rgba(255,255,255,.35);
  cursor: pointer;
  font-size: 11px;
  padding: 2px 4px;
  transition: color .12s;
}
.ba-search-clear:hover { color: rgba(255,255,255,.75); }

.ba-command-right {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}
.ba-sort-label {
  font-family: 'DM Mono', monospace;
  font-size: 8.5px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.38);
  white-space: nowrap;
}
.ba-sort-select {
  width: auto;
  min-width: 180px;
  font-size: 11.5px;
  padding: 6px 8px;
}
.ba-cmd-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 6px 12px;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 3px;
  color: rgba(237,241,255,.75);
  font: inherit;
  font-size: 11.5px;
  font-weight: 500;
  cursor: pointer;
  white-space: nowrap;
  transition: background .14s, border-color .14s, color .14s;
}
.ba-cmd-btn:hover {
  background: rgba(217,183,95,.14);
  border-color: rgba(217,183,95,.4);
  color: var(--gold);
}

/* ── Results bar ── */
.ba-results-bar {
  font-family: 'DM Mono', monospace;
  font-size: 9px;
  letter-spacing: .06em;
  color: rgba(255,255,255,.38);
  margin-bottom: 8px;
  padding: 0 2px;
}
.ba-results-sep { margin: 0 6px; opacity: .5; }

/* ── Table ── */
.ba-table-wrap {
  overflow-x: auto;
  border: 1px solid var(--line);
  border-radius: 4px;
  background: rgba(15,21,37,.8);
  /* Isolate scroll context so sticky cells don't affect the outer layout. */
  contain: paint;
  -webkit-overflow-scrolling: touch;
}
.ba-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 1640px;
}

/* Header row */
.ba-thead-row {
  background: linear-gradient(180deg, rgba(26,38,70,.98), rgba(22,32,58,.98));
  border-bottom: 2px solid var(--gold-brd);
}
.ba-th {
  padding: 10px 12px;
  text-align: left;
  font-family: 'DM Mono', monospace;
  font-size: 8px;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.55);
  white-space: nowrap;
  cursor: pointer;
  user-select: none;
  border-right: 1px solid rgba(255,255,255,.06);
  transition: color .12s, background .12s;
  vertical-align: bottom;
}
.ba-th:last-child { border-right: none; }
.ba-th:hover { color: rgba(255,255,255,.85); background: rgba(255,255,255,.04); }
.ba-th-inner {
  display: flex;
  align-items: center;
  gap: 5px;
  flex-direction: column;
  align-items: flex-start;
}

/* Sticky first column */
.ba-th-sticky {
  position: sticky;
  left: 0;
  z-index: 2;
  background: linear-gradient(180deg, rgba(26,38,70,.99), rgba(22,32,58,.99));
  min-width: 220px;
  max-width: 300px;
  will-change: transform;
}

.ba-th-program { min-width: 220px; }
.ba-th-sector  { min-width: 110px; }
.ba-th-appro   { min-width: 100px; cursor: default; }
.ba-th-lineno  { width: 2.8rem; min-width: 2.8rem; text-align: center; }
.ba-th-pe      { width: 7rem; min-width: 7rem; text-align: left; }
.ba-th-num     { min-width: 118px; text-align: right; }
.ba-th-num .ba-th-inner { align-items: flex-end; }

/* Column color badges */
.ba-col-badge {
  display: inline-block;
  padding: 1px 5px;
  border-radius: 2px;
  font-size: 7px;
  font-weight: 700;
  letter-spacing: .08em;
  margin-bottom: 2px;
}
.ba-col-fy26,
.ba-col-fy26_disc,
.ba-col-fy26_spend,
.ba-col-fy26_total { background: rgba(217,183,95,.22); color: #f3d57a; border: 1px solid rgba(217,183,95,.35); }
.ba-col-pres,
.ba-col-pres_disc,
.ba-col-pres_mand { background: rgba(112,160,255,.25); color: #a8c8ff; border: 1px solid rgba(112,160,255,.35); }
.ba-col-hasc  { background: rgba(67,197,158,.2);   color: #7ee8c9; border: 1px solid rgba(67,197,158,.3); }
.ba-col-sasc  { background: rgba(139,92,246,.22);  color: #c4b5fd; border: 1px solid rgba(139,92,246,.32); }
.ba-col-hdab  { background: rgba(251,146,60,.2);   color: #fdb97e; border: 1px solid rgba(251,146,60,.3); }
.ba-col-sdab  { background: rgba(244,114,182,.2);  color: #f9a8d4; border: 1px solid rgba(244,114,182,.3); }
.ba-col-conf  { background: rgba(217,183,95,.2);   color: var(--gold); border: 1px solid var(--gold-brd); }
.ba-col-final { background: rgba(74,222,128,.2);   color: #86efac; border: 1px solid rgba(74,222,128,.3); }

/* Sort arrow */
.ba-sort-arrow {
  display: inline-block;
  font-size: 8px;
  opacity: .4;
  transition: opacity .12s;
}
.ba-sort-arrow.asc::after  { content: '▲'; }
.ba-sort-arrow.desc::after { content: '▼'; }
.ba-sort-arrow.asc,
.ba-sort-arrow.desc { opacity: 1; color: var(--gold); }

/* Data rows */
.ba-tr {
  border-bottom: 1px solid rgba(255,255,255,.05);
  transition: background .1s;
}
.ba-tr:last-child { border-bottom: none; }
.ba-tr:hover { background: rgba(255,255,255,.04); }
.ba-tr:hover .ba-td-sticky { background: rgba(26,38,70,.99); }
.ba-tr.ba-tr-alt { background: rgba(255,255,255,.018); }
.ba-tr.ba-tr-alt:hover { background: rgba(255,255,255,.05); }

.ba-td {
  padding: 10px 12px;
  font-size: 12px;
  color: var(--text);
  border-right: 1px solid rgba(255,255,255,.04);
  vertical-align: middle;
}
.ba-td:last-child { border-right: none; }

/* Sticky program name cell */
.ba-td-sticky {
  position: sticky;
  left: 0;
  z-index: 1;
  background: rgba(15,21,40,.97);
  transition: background .1s;
  will-change: transform;
}
.ba-td-program {
  font-weight: 600;
  font-size: 12px;
  color: rgba(255,255,255,.9);
  line-height: 1.35;
  cursor: pointer;
}
.ba-td-program:hover { color: var(--gold); text-decoration: underline; text-underline-offset: 3px; }

.ba-td-sector-chip {
  display: inline-flex;
  align-items: center;
  font-family: 'DM Mono', monospace;
  font-size: 8px;
  font-weight: 600;
  letter-spacing: .06em;
  padding: 2px 7px;
  border-radius: 2px;
  white-space: nowrap;
}
.ba-sector-dw   { background: rgba(112,160,255,.15); color: #a8c8ff; border: 1px solid rgba(112,160,255,.28); }
.ba-sector-army { background: rgba(251,146,60,.15);  color: #fdb97e; border: 1px solid rgba(251,146,60,.28); }
.ba-sector-navy { background: rgba(67,197,158,.15);  color: #7ee8c9; border: 1px solid rgba(67,197,158,.28); }
.ba-sector-af   { background: rgba(139,92,246,.15);  color: #c4b5fd; border: 1px solid rgba(139,92,246,.28); }

.ba-td-appro-chip {
  font-family: 'DM Mono', monospace;
  font-size: 8px;
  font-weight: 600;
  letter-spacing: .05em;
  padding: 2px 6px;
  border-radius: 2px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.14);
  color: rgba(255,255,255,.6);
  white-space: nowrap;
}

/* Number cells — right-aligned */
.ba-td-num {
  text-align: right;
  font-family: 'DM Mono', monospace;
  font-size: 11.5px;
  font-weight: 500;
  white-space: nowrap;
}
.ba-td-num-val { color: var(--text); }
.ba-td-pending {
  color: rgba(255,255,255,.25);
  font-style: italic;
  font-size: 10px;
  letter-spacing: .04em;
}
.ba-td-num-delta {
  display: block;
  font-size: 9px;
  margin-top: 2px;
}
.ba-td-delta-up   { color: #4ade80; }
.ba-td-delta-down { color: #ff7b7b; }
.ba-td-delta-zero { color: rgba(255,255,255,.28); }

.ba-adjustments {
  margin-top: 7px;
  text-align: left;
}

.ba-adjustments summary {
  align-items: center;
  background: rgba(217,183,95,.1);
  border: 1px solid rgba(217,183,95,.24);
  border-radius: 3px;
  color: rgba(245,218,145,.92);
  cursor: pointer;
  display: inline-flex;
  font-family: 'Inter', sans-serif;
  font-size: 10px;
  font-weight: 650;
  gap: 5px;
  line-height: 1;
  list-style: none;
  padding: 5px 7px;
  transition: background .15s, border-color .15s, color .15s;
}
.ba-adjustments summary::-webkit-details-marker { display: none; }
.ba-adjustments summary::before {
  content: '+';
  font-family: 'DM Mono', monospace;
  font-size: 12px;
  line-height: 1;
}
.ba-adjustments[open] summary::before { content: '-'; }
.ba-adjustments summary:hover {
  background: rgba(217,183,95,.16);
  border-color: rgba(217,183,95,.42);
  color: #fff;
}

.ba-adjustment-list {
  background: rgba(12,18,34,.96);
  border: 1px solid rgba(217,183,95,.18);
  border-radius: 4px;
  box-shadow: 0 12px 32px rgba(0,0,0,.25);
  margin-top: 6px;
  min-width: 250px;
  padding: 8px;
  transform-origin: top right;
}

.ba-adjustment-head,
.ba-adjustment-net {
  display: grid;
  gap: 10px;
  grid-template-columns: minmax(0, 1fr) auto;
  line-height: 1.2;
}

.ba-adjustment-head {
  align-items: center;
  color: rgba(255,255,255,.72);
  font-family: 'DM Mono', monospace;
  font-size: 8px;
  letter-spacing: .08em;
  margin-bottom: 7px;
  text-transform: uppercase;
}

.ba-adjustment-row {
  display: grid;
  gap: 10px;
  grid-template-columns: minmax(0, 1fr) auto;
  line-height: 1.35;
  padding: 5px 0;
}

.ba-adjustment-row + .ba-adjustment-row {
  border-top: 1px solid rgba(255,255,255,.06);
}

.ba-adjustment-title {
  color: rgba(255,255,255,.78);
  font-family: 'Inter', sans-serif;
  font-size: 10px;
  white-space: normal;
}

.ba-adjustment-amt {
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  white-space: nowrap;
}

.ba-adjustment-net {
  border-top: 1px solid rgba(217,183,95,.2);
  color: rgba(255,255,255,.8);
  font-family: 'Inter', sans-serif;
  font-size: 10px;
  font-weight: 700;
  margin-top: 7px;
  padding-top: 7px;
}

/* Column pending/released states */
.ba-col-pending { opacity: .45; }

/* Pending column header overlay */
.ba-th-pending-label {
  display: block;
  font-size: 7px;
  letter-spacing: .06em;
  color: rgba(255,255,255,.28);
  font-weight: 400;
  font-style: italic;
  margin-top: 2px;
  text-transform: none;
}

/* Group/sector header rows in table */
.ba-tr-group-hd {
  background: linear-gradient(90deg, rgba(217,183,95,.12), rgba(217,183,95,.02));
  border-bottom: 1px solid rgba(217,183,95,.18);
  border-top: 1px solid rgba(255,255,255,.06);
}
.ba-tr-group-hd:first-child { border-top: none; }
.ba-td-group-hd {
  padding: 8px 12px;
  font-family: 'DM Mono', monospace;
  font-size: 8px;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--gold);
  border-right: none;
}

/* ── CH Mark hierarchy rows ─────────────────────────────────────────────── */
.ba-tr-ch-title {
  background: rgba(217,183,95,.18);
  border-top: 1px solid rgba(217,183,95,.35);
}
.ba-td-ch-title {
  padding: 12px 14px 7px;
  color: rgba(255,255,255,.94);
  font-family: Manrope, sans-serif;
  font-size: 0.88rem;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: uppercase;
  border-right: none;
}

.ba-tr-ch-section {
  background: rgba(255,255,255,.055);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.ba-td-ch-section {
  padding: 7px 14px;
  color: rgba(255,255,255,.78);
  font-family: Manrope, sans-serif;
  font-size: 0.76rem;
  font-weight: 750;
  letter-spacing: 0;
  text-transform: uppercase;
  border-right: none;
}

.ba-tr-ch-category {}
.ba-td-ch-category {
  padding: 3px 14px 3px 32px;
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-muted, #8a8a9a);
  background: transparent;
  border-right: none;
}

.ba-tr-ch-adj {}
.ba-td-ch-adj {
  padding: 2px 14px 2px 48px;
  font-size: 0.72rem;
  color: var(--text-muted, #8a8a9a);
  display: flex;
  justify-content: space-between;
  gap: 8px;
  border-right: none;
}
.ba-ch-adj-title { flex: 1; }
.ba-ch-adj-amt { font-variant-numeric: tabular-nums; white-space: nowrap; }
.ba-tr-ch-adj-up .ba-ch-adj-amt { color: #4ade80; }
.ba-tr-ch-adj-dn .ba-ch-adj-amt { color: #f87171; }

.ba-tr-ch-total .ba-td {
  font-weight: 800;
  background: rgba(217,183,95,.07);
  border-top: 1px solid rgba(217,183,95,.28);
}
.ba-tr-ch-total .ba-td-program {
  font-weight: 800;
  text-transform: none;
}
.ba-tr-pbr-supplemental {
  background: linear-gradient(90deg, rgba(130,150,170,.14), rgba(130,150,170,.03));
}

.ba-td-lineno {
  width: 2.8rem;
  min-width: 2.8rem;
  text-align: center;
  font-variant-numeric: tabular-nums;
  font-size: 0.73rem;
  color: var(--text-muted, #8a8a9a);
}
.ba-td-pe {
  width: 7rem;
  min-width: 7rem;
  font-family: 'DM Mono', monospace;
  font-size: 0.70rem;
  color: var(--text-muted, #8a8a9a);
  white-space: nowrap;
}

/* ── Empty / no-data states ── */
.ba-empty-state {
  padding: 60px 20px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}
.ba-empty-icon { font-size: 2.5rem; opacity: .5; margin-bottom: 6px; }
.ba-empty-title {
  font-family: Manrope, sans-serif;
  font-size: 1rem;
  font-weight: 700;
  color: rgba(255,255,255,.65);
  letter-spacing: -.01em;
}
.ba-empty-sub { font-size: 11.5px; color: var(--muted); max-width: 340px; line-height: 1.5; }
.ba-empty-reset {
  margin-top: 10px;
  padding: 6px 16px;
  background: rgba(217,183,95,.15);
  border: 1px solid rgba(217,183,95,.38);
  border-radius: 3px;
  color: var(--gold);
  font: inherit;
  font-size: 11.5px;
  font-weight: 600;
  cursor: pointer;
  transition: background .14s;
}
.ba-empty-reset:hover { background: rgba(217,183,95,.26); }

/* ── Detail drawer (slide-in from right) ── */
.ba-drawer-overlay {
  position: fixed;
  inset: 0;
  z-index: 400;
  background: rgba(0,0,0,.45);
}
.ba-drawer {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  z-index: 401;
  width: min(440px, 92vw);
  background: linear-gradient(180deg, rgba(22,33,65,.99), rgba(15,21,45,.99));
  border-left: 1px solid var(--line);
  box-shadow: -12px 0 40px rgba(0,0,0,.4);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  will-change: transform;
}
.ba-drawer-hd {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 18px 18px 14px;
  border-bottom: 1px solid var(--line);
  flex-shrink: 0;
}
.ba-drawer-title {
  flex: 1;
  font-family: Manrope, sans-serif;
  font-size: .95rem;
  font-weight: 700;
  color: #fff;
  line-height: 1.3;
  letter-spacing: -.01em;
}
.ba-drawer-close {
  background: transparent;
  border: none;
  color: rgba(255,255,255,.4);
  font-size: 13px;
  cursor: pointer;
  padding: 2px 6px;
  border-radius: 2px;
  transition: color .12s, background .12s;
  flex-shrink: 0;
}
.ba-drawer-close:hover { color: #fff; background: rgba(255,255,255,.1); }
.ba-drawer-body {
  flex: 1;
  overflow-y: auto;
  padding: 18px;
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,.12) transparent;
}
.ba-drawer-body::-webkit-scrollbar { width: 4px; }
.ba-drawer-body::-webkit-scrollbar-thumb { background: rgba(255,255,255,.12); border-radius: 2px; }

/* Drawer content blocks */
.ba-drawer-section {
  margin-bottom: 18px;
}
.ba-drawer-section-label {
  font-family: 'DM Mono', monospace;
  font-size: 7.5px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: rgba(217,183,95,.65);
  margin-bottom: 10px;
  border-bottom: 1px solid rgba(217,183,95,.15);
  padding-bottom: 5px;
}
.ba-drawer-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 0;
  border-bottom: 1px solid rgba(255,255,255,.05);
  gap: 12px;
}
.ba-drawer-row:last-child { border-bottom: none; }
.ba-drawer-row-label {
  font-size: 11px;
  color: var(--muted);
  flex: 1;
  line-height: 1.3;
}
.ba-drawer-row-val {
  font-family: 'DM Mono', monospace;
  font-size: 12px;
  font-weight: 600;
  color: var(--text);
  text-align: right;
  white-space: nowrap;
}
.ba-drawer-row-val.pending { color: rgba(255,255,255,.28); font-size: 10px; font-style: italic; font-weight: 400; }
.ba-drawer-row-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.ba-drawer-notes {
  font-size: 11.5px;
  color: var(--muted);
  line-height: 1.6;
  padding: 10px 12px;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--line);
  border-radius: 3px;
  border-left: 2px solid rgba(217,183,95,.3);
}

/* ── Light theme overrides ── */
html[data-theme="light"] .ba-sidebar {
  background: linear-gradient(180deg, rgba(244,240,230,.99), rgba(248,246,242,.99));
  border-right-color: rgba(0,0,0,.1);
}
html[data-theme="light"] .ba-sidebar-title { color: rgba(184,131,42,.85); }
html[data-theme="light"] .ba-filter-group { border-bottom-color: rgba(0,0,0,.07); }
html[data-theme="light"] .ba-filter-group-label { color: rgba(44,53,69,.38); }
html[data-theme="light"] .ba-sector-btn,
html[data-theme="light"] .ba-appro-btn { color: rgba(44,53,69,.65); }
html[data-theme="light"] .ba-sector-btn:hover,
html[data-theme="light"] .ba-appro-btn:hover { color: rgba(44,53,69,.95); background: rgba(184,131,42,.1); }
html[data-theme="light"] .ba-sector-btn-active,
html[data-theme="light"] .ba-appro-btn-active { background: linear-gradient(90deg, rgba(184,131,42,.18), rgba(184,131,42,.04)); color: #b8831a; }
html[data-theme="light"] .ba-check-row { color: rgba(44,53,69,.75); }
html[data-theme="light"] .ba-check-row:hover { color: rgba(44,53,69,.95); }
html[data-theme="light"] .ba-select { background: rgba(255,255,255,.6); border-color: rgba(0,0,0,.16); color: var(--text); }
html[data-theme="light"] .ba-select option { background: #f8f6f2; }
html[data-theme="light"] .ba-page-header {
  background: rgba(244,240,230,.85);
  border-color: rgba(0,0,0,.12);
}
html[data-theme="light"] .ba-page-title { color: var(--text); }
html[data-theme="light"] .ba-page-sub { color: rgba(44,53,69,.7); }
html[data-theme="light"] .ba-command-bar .ba-search-input {
  background: rgba(255,255,255,.65);
  border-color: rgba(0,0,0,.16);
  color: var(--text);
}
html[data-theme="light"] .ba-search-input::placeholder { color: rgba(44,53,69,.35); }
html[data-theme="light"] .ba-cmd-btn {
  background: rgba(0,0,0,.05);
  border-color: rgba(0,0,0,.15);
  color: rgba(44,53,69,.75);
}
html[data-theme="light"] .ba-cmd-btn:hover { background: rgba(184,131,42,.15); border-color: rgba(184,131,42,.4); color: #b8831a; }
html[data-theme="light"] .ba-table-wrap {
  background: rgba(248,246,242,.8);
  border-color: rgba(0,0,0,.1);
}
html[data-theme="light"] .ba-thead-row {
  background: linear-gradient(180deg, rgba(238,235,228,.99), rgba(232,228,218,.99));
  border-bottom-color: rgba(184,131,42,.35);
}
html[data-theme="light"] .ba-th { color: rgba(44,53,69,.6); border-right-color: rgba(0,0,0,.07); }
html[data-theme="light"] .ba-th:hover { color: var(--text); background: rgba(0,0,0,.04); }
html[data-theme="light"] .ba-th-sticky { background: linear-gradient(180deg, rgba(238,235,228,.99), rgba(232,228,218,.99)); }
html[data-theme="light"] .ba-tr { border-bottom-color: rgba(0,0,0,.06); }
html[data-theme="light"] .ba-tr:hover { background: rgba(0,0,0,.03); }
html[data-theme="light"] .ba-tr.ba-tr-alt { background: rgba(0,0,0,.018); }
html[data-theme="light"] .ba-td { color: var(--text); border-right-color: rgba(0,0,0,.04); }
html[data-theme="light"] .ba-td-sticky { background: rgba(248,246,242,.97); }
html[data-theme="light"] .ba-tr:hover .ba-td-sticky { background: rgba(240,237,230,.99); }
html[data-theme="light"] .ba-td-program { color: rgba(44,53,69,.95); }
html[data-theme="light"] .ba-tr-group-hd { background: linear-gradient(90deg, rgba(184,131,42,.1), rgba(184,131,42,.02)); border-bottom-color: rgba(184,131,42,.2); }
html[data-theme="light"] .ba-td-group-hd { color: #b8831a; }
html[data-theme="light"] .ba-tr-ch-title { background: rgba(184,131,42,.14); border-top-color: rgba(184,131,42,.28); }
html[data-theme="light"] .ba-td-ch-title { color: rgba(44,53,69,.95); }
html[data-theme="light"] .ba-tr-ch-section { background: rgba(0,0,0,.035); border-bottom-color: rgba(0,0,0,.07); }
html[data-theme="light"] .ba-td-ch-section { color: rgba(44,53,69,.72); }
html[data-theme="light"] .ba-tr-ch-total .ba-td { background: rgba(184,131,42,.08); border-top-color: rgba(184,131,42,.24); }
html[data-theme="light"] .ba-tr-pbr-supplemental { background: linear-gradient(90deg, rgba(80,98,120,.1), rgba(80,98,120,.02)); }
html[data-theme="light"] .ba-drawer {
  background: linear-gradient(180deg, rgba(244,240,230,.99), rgba(248,246,242,.99));
  border-left-color: rgba(0,0,0,.12);
}
html[data-theme="light"] .ba-drawer-hd { border-bottom-color: rgba(0,0,0,.1); }
html[data-theme="light"] .ba-drawer-title { color: var(--text); }
html[data-theme="light"] .ba-drawer-close { color: rgba(44,53,69,.4); }
html[data-theme="light"] .ba-drawer-close:hover { color: var(--text); background: rgba(0,0,0,.07); }
html[data-theme="light"] .ba-drawer-row { border-bottom-color: rgba(0,0,0,.06); }
html[data-theme="light"] .ba-drawer-row-label { color: rgba(44,53,69,.65); }
html[data-theme="light"] .ba-drawer-row-val { color: var(--text); }
html[data-theme="light"] .ba-drawer-notes { background: rgba(0,0,0,.03); border-color: rgba(0,0,0,.08); }
html[data-theme="light"] .ba-total-card {
  background: linear-gradient(180deg, rgba(255,255,255,.99), rgba(244,247,252,.99));
  border-color: rgba(69,112,190,.28);
  box-shadow: 0 16px 36px rgba(31,45,70,.18);
}
html[data-theme="light"] .ba-total-card-row span { color: rgba(44,53,69,.68); }
html[data-theme="light"] .ba-total-card-row strong { color: rgba(44,53,69,.95); }
html[data-theme="light"] .ba-total-card-title { color: rgba(57,98,171,.95); }
html[data-theme="light"] .ba-total-card-rule { background: rgba(44,53,69,.14); }
html[data-theme="light"] .ba-adjustment-list {
  background: rgba(255,255,255,.98);
  border-color: rgba(184,131,42,.24);
  box-shadow: 0 14px 30px rgba(31,45,70,.14);
}
html[data-theme="light"] .ba-adjustment-title,
html[data-theme="light"] .ba-adjustment-head,
html[data-theme="light"] .ba-adjustment-net { color: rgba(44,53,69,.78); }
html[data-theme="light"] .ba-drawer-adjustments { background: rgba(184,131,42,.055); border-color: rgba(184,131,42,.2); }

.ba-td-has-tooltip {
  cursor: help;
  text-decoration: underline dotted rgba(217,183,95,.45);
  text-underline-offset: 3px;
}

.ba-total-wrap {
  display: inline-flex;
  justify-content: flex-end;
  position: relative;
}

.ba-total-trigger {
  border-bottom: 1px dotted rgba(112,160,255,.55);
  cursor: help;
  outline: none;
  padding-bottom: 1px;
}

.ba-total-trigger:focus-visible {
  border-radius: 2px;
  box-shadow: 0 0 0 2px rgba(112,160,255,.4);
}

.ba-total-card {
  background: linear-gradient(180deg, rgba(18,28,54,.98), rgba(10,15,30,.98));
  border: 1px solid rgba(112,160,255,.32);
  border-radius: 6px;
  box-shadow: 0 18px 45px rgba(0,0,0,.38);
  color: var(--text);
  display: grid;
  gap: 8px;
  max-width: min(310px, 78vw);
  min-width: 260px;
  opacity: 0;
  padding: 12px;
  pointer-events: none;
  position: absolute;
  right: 0;
  text-align: left;
  top: calc(100% + 9px);
  transform: translateY(-4px);
  transition: opacity .16s ease, transform .16s ease;
  white-space: normal;
  z-index: 15;
}

.ba-total-tooltip {
  position: fixed;
  right: auto;
  top: 0;
  visibility: hidden;
  z-index: 1000;
}

.ba-total-tooltip.is-visible {
  opacity: 1;
  transform: translateY(0);
  visibility: visible;
}

.ba-total-wrap:hover .ba-total-card,
.ba-total-wrap:focus-within .ba-total-card {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

.ba-total-card-title {
  color: rgba(168,200,255,.95);
  font-family: 'DM Mono', monospace;
  font-size: 8px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.ba-total-card-row {
  align-items: center;
  display: grid;
  gap: 12px;
  grid-template-columns: minmax(0, 1fr) auto;
}

.ba-total-card-row span {
  color: rgba(255,255,255,.68);
  font-family: 'Inter', sans-serif;
  font-size: 11px;
}

.ba-total-card-row strong {
  color: #fff;
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  white-space: nowrap;
}

.ba-total-card-rule {
  background: rgba(255,255,255,.12);
  display: block;
  height: 1px;
}

.ba-total-card-total span,
.ba-total-card-total strong {
  color: var(--gold);
}

.ba-mand-dot {
  color: #f59e0b;
  display: inline-block;
  height: 6px;
  margin-left: 4px;
  width: 6px;
  background: #f59e0b;
  border-radius: 999px;
  box-shadow: 0 0 0 2px rgba(245,158,11,.18);
  vertical-align: super;
}

.ba-td-tag {
  display: inline-block;
  padding: 2px 6px;
  border-radius: 3px;
}

.ba-td-terminated {
  color: var(--muted);
  font-size: 11px;
  font-style: italic;
}

.ba-drawer-split {
  color: var(--muted);
  display: block;
  font-size: 11px;
  line-height: 1.35;
  margin-top: 3px;
}

.ba-drawer-adjustment {
  display: flex;
  gap: 10px;
  justify-content: space-between;
  white-space: normal;
}

.ba-drawer-adjustment + .ba-drawer-adjustment {
  margin-top: 6px;
}

.ba-drawer-adjustments {
  background: rgba(217,183,95,.055);
  border: 1px solid rgba(217,183,95,.14);
  border-radius: 4px;
  padding: 12px;
}

.ba-drawer-adjustment-net {
  border-top: 1px solid rgba(217,183,95,.2);
  margin-top: 10px;
  padding-top: 8px;
}
