/* ═══════════════════════════════════════════════════════
   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-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}
.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:flex;min-height:calc(100vh - 99px);padding:0;background:transparent;align-items:stretch}
.news-page .left-nav{position:sticky;top:99px;height:calc(100vh - 99px)}
.news-page .main-content{padding-bottom:64px}
.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-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}

  /* 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}
}

/* ═══════════════════════════════════════════════════════
   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;
}

/* ── 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;height:180px;animation:skelPulse 1.4s ease-in-out infinite}
@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 on a white background so the logo is readable */
.news-img--logo{object-fit:contain!important;background:#fff!important}
.news-headliner-img.news-img--logo{padding:20px!important}
.news-secondary-img.news-img--logo{padding:14px!important}
.news-tertiary-img.news-img--logo{padding:10px!important;height:150px}
/* 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.news-img--logo{padding:4px!important}
.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}

/* ── Send to Client button ── */
.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}

/* ── 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-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: 1200px;
  margin: 0 auto;
}
.cover-header {
  text-align: center;
  margin-bottom: clamp(32px, 5vw, 56px);
}
.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: 10px;
}
.cover-sub {
  font-size: .9rem;
  color: var(--muted);
}
.cover-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}
@media(max-width:1100px) {
  .cover-grid { grid-template-columns: repeat(2, 1fr); }
}
@media(max-width:600px) {
  .cover-grid { grid-template-columns: 1fr; 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="staff-portal"]:hover { border-top-color: #38bdf8; }
.cover-card[data-tab="staff-portal"]:hover .cover-card-eyebrow,
.cover-card[data-tab="staff-portal"]:hover .cover-card-cta { color: #38bdf8; }
/* 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:5px;color:#3fb950;height:28px;padding:0 12px;margin-top:-2px;font-size:9px;letter-spacing:.12em}
.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-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}

/* ═══════════════════════════════════════════════════════
   STAFF PORTAL
   ═══════════════════════════════════════════════════════ */

/* Portal header */
.sp-portal-header{padding:24px 28px 20px;background:rgba(22,32,58,.97);border-bottom:1px solid var(--line);position:sticky;top:96px;z-index:150;backdrop-filter:blur(12px)}
.sp-portal-eyebrow{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.sp-portal-title{font-family:Manrope,sans-serif;font-size:1.6rem;font-weight:800;color:#fff;letter-spacing:-.03em;margin-top:2px}
.sp-portal-sub{font-size:11px;color:var(--muted);margin-top:4px;max-width:640px}

/* Module card grid on portal home */
.sp-module-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;padding:28px 28px 60px;max-width:1200px}
.sp-module-card{background:linear-gradient(180deg,rgba(22,32,58,.98),rgba(16,22,40,1));border:1px solid var(--line);border-top:3px solid rgba(56,189,248,.35);border-radius:12px;padding:22px 22px 18px;cursor:pointer;transition:transform .18s,box-shadow .18s,border-top-color .18s;position:relative}
.sp-module-card:hover{transform:translateY(-3px);box-shadow:0 8px 32px rgba(0,0,0,.45);border-top-color:#38bdf8}
.sp-module-card-icon{font-size:28px;margin-bottom:10px}
.sp-module-card-title{font-family:Manrope,sans-serif;font-size:1.05rem;font-weight:800;color:#fff;letter-spacing:-.02em;margin-bottom:6px}
.sp-module-card-desc{font-size:.82rem;color:var(--muted);line-height:1.65;margin-bottom:14px}
.sp-module-card-cta{font-family:'DM Mono',monospace;font-size:9px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:rgba(56,189,248,.8);display:flex;align-items:center;gap:4px;transition:color .15s}
.sp-module-card:hover .sp-module-card-cta{color:#38bdf8}
.sp-cta-arrow{transition:transform .18s;display:inline-block}
.sp-module-card:hover .sp-cta-arrow{transform:translateX(4px)}

/* Module topbar */
.sp-module-topbar{background:rgba(22,32,58,.97);border-bottom:1px solid var(--line);position:sticky;top:96px;z-index:150;backdrop-filter:blur(12px)}
.sp-module-topbar-inner{display:flex;align-items:center;gap:14px;padding:14px 24px;flex-wrap:wrap}
.sp-module-icon{font-size:24px;flex-shrink:0}
.sp-module-eyebrow{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.sp-module-heading{font-family:Manrope,sans-serif;font-size:1.1rem;font-weight:800;color:#fff;letter-spacing:-.02em}
.sp-module-actions{margin-left:auto;display:flex;gap:6px;align-items:center;flex-wrap:wrap}

/* Module body */
.sp-module-body{padding:22px 24px 60px;max-width:1200px}

/* Back button */
.sp-back-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 14px 6px 10px;border-radius:999px;border:1px solid rgba(56,189,248,.4);background:rgba(56,189,248,.08);color:#38bdf8;font-size:12px;font-weight:600;cursor:pointer;transition:background .2s,border-color .2s,color .2s,transform .15s;white-space:nowrap;margin-bottom:18px}
.sp-back-btn:hover{background:rgba(56,189,248,.2);border-color:rgba(56,189,248,.7);color:#fff;transform:translateX(-2px)}
.sp-back-btn svg{flex-shrink:0}

/* Section heading */
.sp-section-hd{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:rgba(217,183,95,.85);margin-bottom:12px;display:flex;align-items:center;gap:10px}

/* Tables */
.sp-table-wrap{overflow-x:auto;border-radius:8px;border:1px solid var(--line)}
.sp-table{width:100%;border-collapse:collapse;font-size:12px}
.sp-table thead tr{background:rgba(255,255,255,.06)}
.sp-table th{padding:9px 12px;font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:600;text-align:left;border-bottom:1px solid var(--line);white-space:nowrap}
.sp-table td{padding:8px 12px;border-bottom:1px solid rgba(255,255,255,.06);color:var(--text);vertical-align:middle}
.sp-table tbody tr:last-child td{border-bottom:none}
.sp-table tbody tr:hover{background:rgba(255,255,255,.03)}

/* Expense report table cells */
.sp-er-cell{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:4px;padding:5px 8px;color:#fff;font-size:11px;font-family:inherit;width:100%;min-width:80px;outline:none;transition:border-color .15s}
.sp-er-cell:focus{border-color:var(--gold)}
.sp-er-del-btn{background:rgba(255,123,123,.1);border:1px solid rgba(255,123,123,.3);color:#ff7b7b;border-radius:4px;padding:3px 7px;font-size:11px;cursor:pointer;transition:all .15s}
.sp-er-del-btn:hover{background:rgba(255,123,123,.25);border-color:#ff7b7b}

/* ER stat strip */
.sp-er-stat-strip{display:flex;align-items:center;gap:24px;margin-bottom:16px;padding:12px 16px;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:8px}
.sp-er-stat{display:flex;flex-direction:column;gap:2px}
.sp-er-stat-lbl{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.sp-er-stat-val{font-family:Manrope,sans-serif;font-size:1.2rem;font-weight:800;color:var(--gold)}
.sp-er-clear-btn{margin-left:auto}

/* Drop zone for import */
.sp-drop-zone{border:2px dashed rgba(255,255,255,.2);border-radius:8px;padding:24px;text-align:center;color:var(--muted);font-size:12px;transition:border-color .2s,background .2s;margin-bottom:12px}
.sp-drop-hover{border-color:var(--gold);background:rgba(217,183,95,.05)}

/* Period input */
.sp-period-input{background:rgba(255,255,255,.09);border:1px solid var(--line);border-radius:5px;padding:5px 10px;color:#fff;font-size:12px;font-family:inherit;height:32px;outline:none}
.sp-period-input:focus{border-color:var(--gold)}

/* Score pills (Scorecard) */
.sp-score-pills{display:flex;gap:5px}
.sp-score-pill{width:32px;height:32px;border-radius:6px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.06);color:rgba(255,255,255,.65);font-size:12px;font-weight:700;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}
.sp-score-pill:hover{border-color:var(--gold);color:var(--gold);background:rgba(217,183,95,.1)}
.sp-score-pill.active{background:linear-gradient(135deg,#d9b75f,#f3d380);border-color:#d9b75f;color:#191919}
.sp-sc-comment-input{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:4px;padding:5px 8px;color:#fff;font-size:11px;font-family:inherit;width:100%;min-width:160px;outline:none}
.sp-sc-comment-input:focus{border-color:var(--gold)}
.sp-sc-table th:first-child{width:35%}

/* Type pills (WS) */
.sp-type-pill-row{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:4px}
.sp-type-pill{padding:5px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.05);color:rgba(255,255,255,.6);font-size:11px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap}
.sp-type-pill:hover{border-color:rgba(56,189,248,.6);color:#38bdf8;background:rgba(56,189,248,.08)}
.sp-type-pill.active{background:rgba(56,189,248,.18);border-color:#38bdf8;color:#38bdf8}

/* Workshop history rows */
.sp-history-row{background:rgba(255,255,255,.04);border:1px solid var(--line);border-left:3px solid rgba(56,189,248,.4);border-radius:7px;padding:10px 14px;font-size:12px}
.sp-history-type{font-weight:700;color:#fff;margin-bottom:2px}
.sp-history-meta{color:var(--muted);font-size:11px}
.sp-history-sub{color:var(--muted);font-size:11px;margin-top:1px}

/* Two-col layout for WS */
.sp-two-col{display:grid;grid-template-columns:1fr 340px;gap:28px;align-items:start}
@media(max-width:900px){.sp-two-col{grid-template-columns:1fr}}

/* Add row button */
.sp-add-row-btn{background:rgba(56,189,248,.12);border:1px solid rgba(56,189,248,.35);color:#38bdf8;border-radius:4px;padding:3px 9px;font-size:10px;font-family:'DM Mono',monospace;font-weight:600;letter-spacing:.06em;cursor:pointer;transition:all .15s;margin-left:8px}
.sp-add-row-btn:hover{background:rgba(56,189,248,.25);border-color:#38bdf8}

/* Delete (danger) button */
.btn-d{padding:9px 18px;background:rgba(255,123,123,.15);color:#ff7b7b;font-weight:700;font-size:12px;cursor:pointer;border-radius:6px;border:1px solid rgba(255,123,123,.35);font-family:inherit;transition:all .15s}
.btn-d:hover{background:rgba(255,123,123,.3);border-color:#ff7b7b;color:#fff}

/* Toast */
.sp-toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);background:rgba(22,32,58,.97);border:1px solid var(--line-2);border-radius:8px;padding:10px 22px;font-size:13px;color:#fff;font-weight:600;box-shadow:0 4px 20px rgba(0,0,0,.5);z-index:9999;opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;white-space:nowrap}
.sp-toast-show{opacity:1;transform:translateX(-50%) translateY(0)}
.sp-toast-ok{border-color:rgba(67,197,158,.45);color:#6ee7c7}
.sp-toast-err{border-color:rgba(255,123,123,.45);color:#fca5a5}

/* CI conflict result */
#ci-conflict-result{font-size:12px;line-height:1.6}

/* Responsive adjustments */
@media(max-width:768px){
  .sp-module-grid{padding:16px 14px 50px;grid-template-columns:1fr}
  .sp-module-topbar-inner{padding:12px 14px}
  .sp-module-body{padding:16px 14px 50px}
  .sp-portal-header{padding:16px 14px 14px}
  .sp-module-actions{gap:4px}
  .sp-two-col{grid-template-columns:1fr}
}

/* Work Status badge */
.sp-wkst-badge{display:inline-block;padding:3px 10px;border-radius:999px;border:1px solid;font-size:10px;font-weight:700;font-family:'DM Mono',monospace;letter-spacing:.04em;white-space:nowrap}

/* Work Status card accent */
.sp-module-card-wkst{border-top-color:rgba(251,146,60,.35)}
.sp-module-card-wkst:hover{border-top-color:#fb923c}
.sp-module-card-wkst:hover .sp-module-card-cta{color:#fb923c}
