.feed-wrap{max-width:900px;margin:0 auto;padding:100px 24px 60px}
.feed-head{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;margin-bottom:28px;flex-wrap:wrap}
.feed-head h1{font-family:'Syne',sans-serif;font-size:30px;font-weight:800}
.feed-filters{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.credit-pill{display:inline-flex;align-items:center;gap:6px;background:rgba(200,241,53,0.12);color:var(--saffron);border:1px solid rgba(200,241,53,0.3);padding:7px 14px;border-radius:100px;font-size:13px;font-weight:700;margin-right:8px}
.jobs-list{display:flex;flex-direction:column;gap:14px}
.feed-loading,.feed-empty{text-align:center;color:var(--muted);padding:60px 20px}
.feed-empty i{font-size:40px;display:block;margin-bottom:12px;color:var(--muted)}
.job-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:22px;transition:var(--t)}
.job-card:hover{border-color:var(--muted)}
.jc-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;flex-wrap:wrap;gap:8px}
.jc-cat{display:inline-block;background:rgba(200,241,53,0.12);color:var(--saffron);font-size:11px;font-weight:700;padding:4px 12px;border-radius:100px;text-transform:uppercase;letter-spacing:.5px;margin-right:10px}
.jc-loc{font-size:13px;color:var(--muted)}
.jc-live{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--teal);font-weight:600}
.jc-live .dot{width:7px;height:7px;border-radius:50%;background:var(--teal);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.jc-title{font-family:'Syne',sans-serif;font-size:19px;font-weight:700;margin-bottom:8px}
.jc-desc{font-size:14px;color:var(--muted);line-height:1.6;margin-bottom:16px}
.jc-foot{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.jc-meta{display:flex;gap:18px;font-size:13px;color:var(--muted)}
.jc-meta i{color:var(--saffron);margin-right:4px}
/* modal */
.modal-overlay{position:fixed;inset:0;background:rgba(5,8,25,0.8);backdrop-filter:blur(6px);z-index:200;display:none;align-items:center;justify-content:center;padding:20px}
.modal-overlay.show{display:flex}
.modal-card{background:#fff;border:1px solid var(--border);border-radius:20px;padding:28px;max-width:520px;width:100%;max-height:90vh;overflow-y:auto;position:relative}
.modal-close{position:absolute;top:16px;right:16px;background:var(--cream2);border:none;color:var(--ink);width:34px;height:34px;border-radius:50%;cursor:pointer;font-size:18px}
.bid-job-summary .bjs-cat{color:var(--saffron);font-size:12px;font-weight:700;text-transform:uppercase}
.bid-job-summary h2{font-family:'Syne',sans-serif;font-size:22px;font-weight:800;margin:6px 0}
.bjs-loc{font-size:13px;color:var(--muted);margin-bottom:8px}
.lowest-banner{display:flex;align-items:center;gap:8px;background:rgba(200,241,53,0.08);border:1px solid rgba(200,241,53,0.25);border-radius:10px;padding:12px 14px;font-size:13px;color:var(--ink);margin-top:8px}
.lowest-banner i{color:var(--saffron)}
.bid-prefix{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--muted)}
.bid-cost-note{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--muted);margin-top:14px;padding:10px;background:var(--cream2);border-radius:8px}
.bid-cost-note i{color:var(--saffron)}

/* ── Responsive ── */
@media(max-width:600px){
  .feed-wrap{padding:84px 16px 48px}
  .feed-filters{flex-wrap:wrap;gap:8px}
  .feed-filters .filter-chip{font-size:12px;padding:7px 12px}
  .job-card{padding:16px}
  .jc-head{flex-direction:column;align-items:flex-start;gap:8px}
  .jc-foot{flex-direction:column;align-items:stretch;gap:10px}
  .jc-foot .btn-saffron,.jc-foot button{width:100%;justify-content:center}
  .jc-title{font-size:17px}
  .modal-card{padding:22px 18px;max-height:92vh;overflow-y:auto}
}

/* Already-bid state */
.btn-bid-placed{background:var(--cream2);color:var(--muted);border:1px solid var(--border);border-radius:100px;padding:10px 18px;font-weight:600;font-size:14px;cursor:not-allowed;display:inline-flex;align-items:center;gap:6px}
.job-card.has-my-bid{opacity:.85}
.job-card.has-my-bid .jc-title{color:var(--muted)}
