/*
 * Estimating Command — styles.css
 * Dashboard-specific styles only.
 *
 * Brand tokens : ../_shared/tokens.css  (already loaded)
 * Global resets: ../_shared/global.css  (already loaded)
 */

/* estimating-command overrides — intentional differences from _shared/tokens.css */
:root {
  --radius-sm: 6px;   /* estimating uses slightly rounder corners than the other dashboards */
  --radius:    9px;
  --shadow:    0 1px 3px rgba(44,62,80,.07), 0 4px 12px rgba(44,62,80,.08);
  --info-bg:   #EAF4FB;  /* solid bg vs rgba — estimating uses info-bg on colored surfaces */
}
*{box-sizing:border-box}html,body{margin:0;height:100%}
body{background:var(--stone-bg);color:var(--text-primary);font-family:var(--font-body);font-size:14px;display:grid;grid-template-rows:auto 1fr auto;min-height:100vh}
.header{display:flex;align-items:center;justify-content:space-between;background:var(--slate);color:#fff;padding:12px 20px;gap:12px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:#fff;cursor:pointer;flex-shrink:0}
.brand-mark{height:34px}.brand-mark polygon{fill:var(--copper)}
.brand-divider{width:1px;height:30px;background:rgba(255,255,255,.2)}
.brand-name{font-family:var(--font-display);font-weight:800;font-size:16px;display:block}
.brand-sub{font-size:11px;color:rgba(255,255,255,.6);letter-spacing:.06em;text-transform:uppercase}
.header-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.conn-pill{display:flex;align-items:center;gap:6px;padding:5px 11px;border-radius:99px;font:600 12px var(--font-body);cursor:pointer;border:1px solid rgba(255,255,255,.2);color:#fff;background:rgba(255,255,255,.08);transition:.15s}
.conn-pill:hover{background:rgba(255,255,255,.16)}
.conn-dot{width:7px;height:7px;border-radius:50%;background:var(--text-muted);flex-shrink:0}
.conn-dot.live{background:#4ade80;box-shadow:0 0 6px rgba(74,222,128,.6)}
.conn-dot.warn{background:#fbbf24}
.btn{border:0;border-radius:999px;padding:8px 14px;font:600 12px var(--font-body);cursor:pointer;background:var(--copper);color:#fff;white-space:nowrap;transition:.15s}
.btn:hover{filter:brightness(1.12)}.btn.slate{background:var(--slate2)}.btn.ghost{background:rgba(255,255,255,.12);color:#fff}
.app{display:grid;grid-template-columns:210px 1fr;min-height:0}
.sidebar{background:var(--bg-elevated);border-right:1px solid var(--border);padding:14px 8px;overflow-y:auto}
.sidebar-title{font:700 10px var(--font-display);letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted);padding:0 10px 8px}
.cat-list{list-style:none;margin:0;padding:0}
.cat-item{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:var(--radius-sm);cursor:pointer;font-weight:600;font-size:13px;color:var(--text-secondary);transition:all .12s}
.cat-item:hover{background:var(--bg-card)}.cat-item.active{background:var(--bg-card);color:var(--copper);box-shadow:inset 3px 0 0 var(--copper)}
.cat-glyph{font-size:15px;width:20px;text-align:center;flex-shrink:0}
.cat-badge{margin-left:auto;font:700 10px var(--font-mono);background:var(--copper);color:#fff;border-radius:99px;padding:1px 6px;min-width:18px;text-align:center}
.cat-badge.warn{background:var(--warning)}.cat-badge.ok{background:var(--success)}
.cat-link{text-decoration:none}.cat-link:hover{color:var(--copper)}.cat-ext{margin-left:auto;font-size:12px;opacity:.55}
.main{padding:20px;overflow:auto}
.grid{display:grid;gap:16px}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}
.card-title{font-family:var(--font-display);font-weight:700;font-size:14px;margin:0 0 12px;color:var(--slate);display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.ct-badge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:99px;background:var(--copper-soft);color:var(--copper);border:1px solid var(--copper-border);font-family:var(--font-body)}
.tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}
.tile{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow)}
.tile .tl{font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted);font-weight:600}
.tile .tn{font-family:var(--font-display);font-weight:800;font-size:24px;color:var(--slate);margin-top:4px;line-height:1}
.tile .tn.copper{color:var(--copper)}.tile .tn.success{color:var(--success)}.tile .tn.warn{color:var(--warning)}.tile .tn.danger{color:var(--danger)}
.flag{border-radius:var(--radius-sm);padding:10px 12px;font-size:12.5px;line-height:1.5;display:flex;gap:8px;align-items:flex-start;margin-bottom:8px}
.flag:last-child{margin-bottom:0}
.flag.red{background:var(--danger-bg);border:1px solid rgba(169,61,51,.2)}.flag.amber{background:var(--copper-soft);border:1px solid var(--copper-border)}.flag.green{background:var(--success-bg);border:1px solid rgba(31,122,79,.2)}.flag.info{background:var(--info-bg);border:1px solid rgba(36,113,163,.2)}
.flag-icon{flex-shrink:0;font-size:14px;margin-top:1px}
.job-link{color:var(--copper);text-decoration:none;border-bottom:1px solid var(--copper-border);font-weight:600}.job-link:hover{border-bottom-color:var(--copper)}.job-link .ext{font-size:9px;margin-left:3px;opacity:.6;vertical-align:super}
table.tbl{width:100%;border-collapse:collapse;font-size:13px}
table.tbl th{text-align:left;color:var(--text-muted);font-weight:600;border-bottom:2px solid var(--border);padding:7px 10px;font-size:11px;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}
table.tbl td{border-bottom:1px solid var(--border);padding:7px 10px;vertical-align:middle}
table.tbl tr:last-child td{border-bottom:0}table.tbl tr:hover td{background:var(--stone-bg)}
.mono{font-family:var(--font-mono)}.bid-id{font-family:var(--font-mono);font-size:11px;color:var(--text-muted);font-weight:600}.job-name{font-weight:600}.job-gc{font-size:12px;color:var(--text-muted);margin-top:1px}
.status{display:inline-flex;align-items:center;gap:4px;font:600 11px var(--font-body);padding:3px 8px;border-radius:99px;white-space:nowrap}
.s-intake{background:#E8F0FE;color:#1a56a5}.s-rfq{background:#FEF9E7;color:#856404;border:1px solid rgba(133,100,4,.2)}.s-waiting{background:#FEF3CD;color:#7D4A00}.s-ready{background:#D1FAE5;color:#065F46}.s-bidding{background:#E0E7FF;color:#3730A3}.s-proposal{background:#F3E8FF;color:#6B21A8}.s-won{background:#DCFCE7;color:#166534}.s-lost{background:#FEE2E2;color:#991B1B}.s-hold{background:#F1F5F9;color:#475569;border:1px solid var(--border)}
.q-item{background:var(--stone-bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;display:grid;grid-template-columns:1fr auto;gap:4px 12px;align-items:start;margin-bottom:6px}
.q-item:last-child{margin-bottom:0}.q-item.urgent{border-left:3px solid var(--danger);background:var(--danger-bg)}.q-item.pending{border-left:3px solid var(--warning)}.q-item.sent{border-left:3px solid var(--info)}.q-item.received{border-left:3px solid var(--success)}
.q-job{font-weight:600;font-size:13px}.q-meta{font-size:11px;color:var(--text-muted);margin-top:2px}
.q-tag{font:700 10px var(--font-body);padding:2px 7px;border-radius:99px;white-space:nowrap}
.qt-rfq{background:#DBEAFE;color:#1D4ED8}.qt-chase{background:#FEF3C7;color:#92400E}.qt-waiting{background:#E0E7FF;color:#3730A3}.qt-received{background:#D1FAE5;color:#065F46}.qt-overdue{background:#FEE2E2;color:#991B1B}
.pipeline-stages{display:flex;gap:0;overflow-x:auto;padding-bottom:4px}
.ps{flex:1;min-width:100px;background:var(--bg-card);border:1px solid var(--border);padding:12px 8px;text-align:center;position:relative}
.ps:first-child{border-radius:var(--radius) 0 0 var(--radius)}.ps:last-child{border-radius:0 var(--radius) var(--radius) 0}.ps:not(:first-child){border-left:0}
.ps:not(:last-child)::after{content:"▶";position:absolute;right:-9px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:9px;z-index:1}
.ps-glyph{font-size:18px;display:block;margin-bottom:3px}.ps-label{font:700 9px var(--font-display);text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.ps-count{font:800 20px var(--font-display);color:var(--slate);margin-top:2px}
.ps.active-stage{background:var(--copper-soft);border-color:var(--copper)}.ps.active-stage .ps-label{color:var(--copper)}.ps.active-stage .ps-count{color:var(--copper)}
/* Calendar */
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.cal-dow{text-align:center;font:700 10px var(--font-display);text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding:4px 0}
.cal-day{min-height:64px;background:var(--stone-bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:4px 5px;transition:.12s}
.cal-day:hover{background:var(--bg-card)}.cal-day.today{background:var(--copper-soft);border-color:var(--copper)}.cal-day.other-month .cd-num{color:var(--warmStone)}
.cd-num{font:700 11px var(--font-display);color:var(--text-secondary)}.cal-day.today .cd-num{color:var(--copper)}
.cal-event{font-size:9.5px;font-weight:600;padding:2px 4px;border-radius:3px;margin-top:2px;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ce-bid{background:#FEE2E2;color:#991B1B}.ce-chase{background:#FEF3C7;color:#92400E}.ce-due{background:#FEE2E2;color:#991B1B}.ce-rfq{background:#D1FAE5;color:#065F46}
/* Vendor cards */
.vc-row{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--border)}.vc-row:last-child{border-bottom:0}
.vc-avatar{width:34px;height:34px;border-radius:50%;background:var(--copper-soft);border:1px solid var(--copper-border);display:flex;align-items:center;justify-content:center;font:700 13px var(--font-display);color:var(--copper);flex-shrink:0}
.vc-name{font-weight:600;font-size:13px}.vc-meta{font-size:11px;color:var(--text-muted)}
.vc-stat{margin-left:auto;text-align:right;flex-shrink:0}.vc-rate{font:700 13px var(--font-display);color:var(--success)}.vc-rate.low{color:var(--warning)}.vc-last{font-size:10px;color:var(--text-muted)}
/* Forms */
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
.form-row.full{grid-template-columns:1fr}
label.fl{font:600 11px var(--font-body);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;display:block;margin-bottom:3px}
input.fi,select.fi,textarea.fi{width:100%;padding:8px 10px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);font:400 13px var(--font-body);color:var(--text-primary);background:var(--bg-card);outline:none;transition:.15s}
input.fi:focus,select.fi:focus,textarea.fi:focus{border-color:var(--copper);box-shadow:0 0 0 3px var(--copper-soft)}
textarea.fi{resize:vertical;min-height:70px}
.form-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}
.btn-sm{border:0;border-radius:var(--radius-sm);padding:7px 14px;font:600 12px var(--font-body);cursor:pointer;background:var(--copper);color:#fff;transition:.15s}.btn-sm:hover{filter:brightness(1.1)}.btn-sm.ghost{background:var(--stone-bg);color:var(--text-secondary);border:1px solid var(--border)}.btn-sm.danger{background:var(--danger)}
/* Email compose */
.email-compose{background:var(--stone-bg);border:1px solid var(--border);border-radius:var(--radius);padding:14px;margin-top:10px}
.email-compose .subj{font:600 13px var(--font-body);color:var(--slate);padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);margin-bottom:8px;width:100%}
.email-to-row{display:flex;gap:8px;align-items:center;margin-bottom:6px}
.email-label{font:700 11px var(--font-body);color:var(--text-muted);width:28px;flex-shrink:0}
.email-chips{display:flex;gap:4px;flex-wrap:wrap;flex:1}
.chip{display:inline-flex;align-items:center;gap:4px;background:var(--copper-soft);border:1px solid var(--copper-border);border-radius:99px;padding:2px 8px;font:600 11px var(--font-body);color:var(--copper)}
.chip .xc{cursor:pointer;font-size:13px;line-height:1;color:var(--text-muted)}.chip .xc:hover{color:var(--danger)}
.email-body-area{width:100%;border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px;font:400 13px var(--font-body);background:var(--bg-card);min-height:120px;resize:vertical;outline:none;transition:.15s}
.email-body-area:focus{border-color:var(--copper);box-shadow:0 0 0 3px var(--copper-soft)}
/* Gmail auth banner */
.auth-banner{background:linear-gradient(135deg,var(--slate) 0%,var(--slate2) 100%);border-radius:var(--radius);padding:20px;color:#fff;display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.auth-icon{font-size:32px;flex-shrink:0}
.auth-text .at-title{font:700 15px var(--font-display);margin-bottom:4px}
.auth-text .at-desc{font-size:12px;opacity:.75;line-height:1.5}
/* Poll indicator */
.poll-bar{display:flex;align-items:center;gap:8px;background:var(--stone-bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 12px;font-size:12px}
.poll-spinner{width:12px;height:12px;border:2px solid var(--border);border-top-color:var(--copper);border-radius:50%;animation:spin 1s linear infinite;flex-shrink:0}
@keyframes spin{to{transform:rotate(360deg)}}
.poll-bar.idle .poll-spinner{animation:none;border-top-color:var(--text-muted)}
/* Execute Launch Buttons */
.exec-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border-radius:var(--radius-sm);border:0;font:700 11px var(--font-body);cursor:pointer;white-space:nowrap;transition:.15s}
.exec-btn:hover{filter:brightness(1.1)}
.exec-hvac{background:#1a56a5;color:#fff}
.exec-plmb{background:#065F46;color:#fff}
.exec-both{background:var(--copper);color:#fff}
.exec-proposal{background:var(--slate);color:#fff}
.exec-btn.dim{opacity:.4;cursor:default;pointer-events:none}
.exec-btn:hover:not(.dim){transform:translateY(-1px);box-shadow:0 3px 8px rgba(0,0,0,.2)}
/* Launch Prompt Modal */
.launch-modal{background:#fff;border-radius:14px;max-width:640px;width:96%;padding:0;box-shadow:0 24px 60px rgba(0,0,0,.45);overflow:hidden}
.lm-header{padding:18px 22px 14px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.lm-trade-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:99px;font:700 11px var(--font-display);letter-spacing:.04em;text-transform:uppercase;margin-bottom:8px}
.lm-trade-hvac{background:#DBEAFE;color:#1a56a5}
.lm-trade-plmb{background:#D1FAE5;color:#065F46}
.lm-trade-both{background:var(--copper-soft);color:var(--copper-deep);border:1px solid var(--copper-border)}
.lm-trade-proposal{background:#EDE9E2;color:var(--slate)}
.lm-title{font:800 17px var(--font-display);color:var(--slate);margin-bottom:3px}
.lm-sub{font-size:12px;color:var(--text-muted)}
.lm-body{padding:18px 22px}
.lm-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px;margin-bottom:16px}
.lm-info-row{background:var(--stone-bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px}
.lm-info-label{font:700 10px var(--font-display);text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:3px}
.lm-info-val{font:600 13px var(--font-body);color:var(--text-primary);word-break:break-all}
.lm-info-val a{color:var(--copper);text-decoration:none}.lm-info-val a:hover{text-decoration:underline}
.prompt-box{background:var(--slate);border-radius:var(--radius);padding:14px 16px;font:400 12.5px var(--font-mono);color:#e8e8e8;line-height:1.65;white-space:pre-wrap;word-break:break-word;position:relative;margin-bottom:14px;max-height:260px;overflow-y:auto}
.prompt-copy-btn{position:absolute;top:10px;right:10px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:var(--radius-sm);padding:4px 10px;font:600 11px var(--font-body);cursor:pointer;transition:.15s}
.prompt-copy-btn:hover{background:rgba(255,255,255,.22)}
.lm-target{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--info-bg);border:1px solid rgba(36,113,163,.2);border-radius:var(--radius-sm);margin-bottom:14px;font-size:12.5px}
.lm-target .lmt-icon{font-size:18px;flex-shrink:0}
.lm-target .lmt-label{font-weight:600;color:var(--info)}
.lm-target .lmt-sub{font-size:11px;color:var(--text-muted);margin-top:1px}
.lm-allowances{background:var(--warning-bg);border:1px solid rgba(201,155,69,.3);border-radius:var(--radius-sm);padding:10px 12px;margin-bottom:14px;font-size:12.5px}
.lm-footer{padding:14px 22px;border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap}
/* Readiness bar */
.readiness-bar{height:6px;background:var(--border);border-radius:99px;overflow:hidden;margin-top:6px}
.readiness-fill{height:100%;border-radius:99px;transition:.4s}
.rf-green{background:var(--success)}.rf-yellow{background:var(--warning)}.rf-red{background:var(--danger)}

.step{display:flex;align-items:flex-start;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);background:var(--stone-bg);border:1px solid var(--border);margin-bottom:6px}
.step.done{background:var(--success-bg);border-color:rgba(31,122,79,.2)}.step.active{background:#EEF2FF;border-color:rgba(55,48,163,.2)}.step.blocked{background:var(--danger-bg);border-color:rgba(169,61,51,.2)}
.step-icon{font-size:15px;flex-shrink:0;margin-top:1px}.step-name{font-weight:600;font-size:13px}.step-desc{font-size:11px;color:var(--text-muted);margin-top:1px}
.phase-label{font:700 10px var(--font-display);text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);padding:12px 0 4px;border-bottom:1px solid var(--border);margin-bottom:8px}
/* Modal */
.scrim{position:fixed;inset:0;background:rgba(44,62,80,.55);display:flex;align-items:center;justify-content:center;z-index:999;overflow-y:auto;padding:20px}
.modal{background:var(--stone-bg);border-radius:14px;max-width:560px;width:100%;padding:22px;box-shadow:0 18px 50px rgba(0,0,0,.4)}
.modal-title{font:700 16px var(--font-display);color:var(--slate);margin-bottom:16px;display:flex;align-items:center;justify-content:space-between}
.x{border:0;background:none;font-size:22px;cursor:pointer;color:var(--text-muted);padding:2px 6px}.x:hover{color:var(--text-primary)}
/* launcher */
.launcher{background:var(--stone-bg);border-radius:16px;max-width:680px;width:92%;padding:22px;box-shadow:0 18px 50px rgba(0,0,0,.4)}
.lx-head{display:flex;align-items:center;gap:12px;margin-bottom:16px}.lx-mark{height:30px}.lx-mark polygon{fill:var(--copper)}
.lx-eyebrow{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--copper);font-weight:700}.lx-title{font-size:19px;font-weight:800;color:var(--slate)}
.lx-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}
.lx-tile{border:1px solid var(--border);border-radius:12px;padding:16px;background:#fff;cursor:pointer;transition:.12s}.lx-tile:hover{border-color:var(--copper);background:var(--copper-soft)}.lx-tile.here{opacity:.65;cursor:default}
.lx-glyph{font-size:22px;color:var(--copper);font-weight:700}.lx-name{font-weight:700;color:var(--slate);margin-top:5px;font-size:13px}.lx-desc{font-size:11.5px;color:var(--text-secondary);line-height:1.4;margin-top:3px}
.lx-badge{margin-left:8px;font-size:10px;font-weight:700;color:#1f3a2e;background:#9BE7B4;padding:2px 7px;border-radius:99px}.lx-foot{font-size:12px;color:var(--text-muted);margin-top:16px}
.footer{background:var(--slate);color:rgba(255,255,255,.65);font-size:11px;padding:10px 20px;display:flex;justify-content:space-between;align-items:center;gap:8px;flex-wrap:wrap}
::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--warmStone);border-radius:99px}
@media(max-width:700px){.app{grid-template-columns:1fr}.sidebar{display:flex;flex-direction:row;overflow-x:auto;padding:8px;gap:4px;border-right:0;border-bottom:1px solid var(--border)}.sidebar-title{display:none}.cat-item{padding:6px 10px;font-size:12px;white-space:nowrap}.grid2{grid-template-columns:1fr}.sidebar-links{display:flex;gap:4px;flex-shrink:0}.cat-ext{display:none}}

/* ===== CLICKABLE DUE BOARD (v3.2.0) ===== */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:22px}
.kpi{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:15px 16px;box-shadow:var(--shadow)}
.kpi .n{font-family:var(--font-display);font-weight:800;font-size:30px;line-height:1;color:var(--slate)}
.kpi .n.danger{color:var(--danger)}.kpi .n.warn{color:var(--warning)}.kpi .n.ok{color:var(--success)}.kpi .n.info{color:var(--info)}
.kpi .l{font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted);margin-top:7px}
.bucket{margin-bottom:20px}
.bucket-head{display:flex;align-items:center;gap:10px;margin:0 2px 11px;cursor:pointer;user-select:none}
.bucket-head h2{font-family:var(--font-display);font-weight:700;font-size:14px;margin:0;color:var(--slate);display:flex;align-items:center;gap:8px}
.bucket-count{font:700 11px var(--font-mono);color:#fff;border-radius:99px;padding:2px 9px;min-width:22px;text-align:center}
.bucket-rule{flex:1;height:1px;background:var(--border)}
.bucket-chev{font-size:12px;color:var(--text-muted);transition:transform .15s}
.bucket.collapsed .bucket-chev{transform:rotate(-90deg)}.bucket.collapsed .cards{display:none}
.cards{display:flex;flex-direction:column;gap:10px}
.bid{background:var(--bg-card);border:1px solid var(--border);border-left:4px solid var(--border-strong);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow);display:grid;grid-template-columns:1fr auto;gap:10px 16px;align-items:start}
.bid.d-over,.bid.d-today{border-left-color:var(--danger)}
.bid.d-week{border-left-color:var(--warning)}.bid.d-next{border-left-color:var(--success)}
.bid.d-wait{border-left-color:var(--text-muted)}.bid.d-later{border-left-color:var(--info)}
.bid-main{min-width:0}
.bid-title{font-family:var(--font-display);font-weight:700;font-size:15px;color:var(--slate);margin:0 0 3px;line-height:1.25}
.bid-title a{color:var(--slate);text-decoration:none;border-bottom:2px solid var(--copper-border)}
.bid-title a:hover{border-bottom-color:var(--copper);color:var(--copper-deep)}
.bid-title .ext{font-size:11px;color:var(--copper);margin-left:3px;vertical-align:super}
.bid-meta{font-size:12.5px;color:var(--text-secondary);display:flex;flex-wrap:wrap;gap:4px 12px;margin-top:5px}
.bid-meta .mi{display:inline-flex;align-items:center;gap:5px}
.bid-meta .mi .k{color:var(--text-muted);font-size:11px;text-transform:uppercase;letter-spacing:.03em}
.addr-link{color:var(--text-secondary);text-decoration:none;border-bottom:1px dotted var(--border-strong)}
.addr-link:hover{color:var(--info);border-bottom-color:var(--info)}
.tag{display:inline-block;font:600 10px var(--font-body);padding:2px 8px;border-radius:99px;border:1px solid}
.tag.tr{background:var(--copper-soft);color:var(--copper-deep);border-color:var(--copper-border)}
.tag.ps{background:var(--info-bg);color:var(--info);border-color:rgba(36,113,163,.25)}
.bid-right{display:flex;flex-direction:column;align-items:flex-end;gap:8px;text-align:right}
.due{font-family:var(--font-display);font-weight:800;font-size:14px;white-space:nowrap}
.due.over,.due.today{color:var(--danger)}.due.week{color:var(--warning)}.due.next{color:var(--success)}
.due.wait{color:var(--text-muted)}.due.later{color:var(--info)}
.due small{display:block;font-family:var(--font-body);font-weight:600;font-size:11px;color:var(--text-muted);margin-top:2px}
.row-btns{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}
.minibtn{font:600 11px var(--font-body);padding:5px 10px;border-radius:99px;border:1px solid var(--border-strong);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:4px;transition:.12s}
.minibtn:hover{border-color:var(--copper);color:var(--copper-deep);background:var(--copper-soft)}
.minibtn.disabled{opacity:.4;pointer-events:none}
.bflags{grid-column:1/-1;display:flex;flex-wrap:wrap;gap:6px;margin-top:2px}
.bflag{display:inline-flex;align-items:center;gap:5px;font:600 11px var(--font-body);padding:3px 9px;border-radius:99px}
.bflag.red{background:var(--danger-bg);color:var(--danger)}
.bflag.amber{background:var(--warning-bg);color:var(--copper-deep)}
.exec-row{grid-column:1/-1;display:flex;gap:6px;flex-wrap:wrap;align-items:center;margin-top:10px;padding-top:10px;border-top:1px dashed var(--border)}
.empty{text-align:center;color:var(--text-muted);padding:40px 20px;font-size:13px}
@media(max-width:640px){.bid{grid-template-columns:1fr}.bid-right{align-items:flex-start;text-align:left}.row-btns{justify-content:flex-start}}

/* ---- logo-as-refresh + LL snake ---- */
.brand-logo-btn{background:none;border:0;padding:0;margin:0;cursor:pointer;display:inline-flex;line-height:0}
.brand-logo-btn:focus{outline:none}
.brand-mark .ll-fill{fill:var(--copper,#B87333);transition:opacity .25s}
.brand-mark .ll-snake{fill:none;stroke:none}
.brand-logo-btn:hover .ll-fill{fill:#9A5F26}
.brand-logo-btn.refreshing .ll-fill{opacity:.20}
.brand-logo-btn.refreshing .ll-snake{stroke:#EBB079;stroke-width:7;stroke-linejoin:round;stroke-linecap:round;animation:llsnake 1.05s linear infinite}
