/* ============================================================
   Klepify board design (v3) — "Safe jobs. Searchable."
   Shared by the landing safe-jobs section AND /jobs. Day-shift
   paper look (mockup Klepify_Jobsboard-Working_v1): row-based
   board, counted filter chips, segmented controls, hover popover.
   All selectors .kb-* ; color/font tokens come from styles.css.
   ============================================================ */
.klep-safeboard{position:relative;padding:64px clamp(20px,5vw,88px) 72px;background:var(--paper);color:var(--ink)}
.klep-safeboard *{box-sizing:border-box}

/* ── header ── */
.kb-head{display:flex;align-items:baseline;justify-content:space-between;gap:18px;flex-wrap:wrap}
.kb-title{font-size:clamp(28px,3.4vw,44px);font-weight:700;letter-spacing:-.025em;color:var(--ink);margin:0}
.kb-title em{font-family:var(--font-display);font-style:italic;font-weight:400;background:var(--acid);padding:0 .12em}
.kb-live{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;color:var(--muted);
  display:flex;align-items:center;gap:8px;text-transform:uppercase}
.kb-live i{width:8px;height:8px;border-radius:50%;background:var(--acid-deep);animation:kb-pulse 1.8s infinite;flex:none}
.kb-live b{color:var(--ink)}
.kb-sub{font-size:15px;color:#3a3833;max-width:54em;margin:10px 0 22px;line-height:1.5}
.kb-sub b{font-weight:600}
@keyframes kb-pulse{0%,100%{opacity:1}50%{opacity:.25}}
@keyframes kb-rowin{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ── search bar ── */
.kb-searchbar{display:flex;gap:12px;align-items:stretch}
.kb-searchbox{flex:1;display:flex;align-items:center;gap:12px;background:#FFFDF7;border:2px solid var(--ink);
  border-radius:14px;padding:0 18px;box-shadow:5px 6px 0 rgba(14,14,12,.85)}
.kb-searchbox svg{width:17px;height:17px;color:var(--muted);flex:none}
.kb-searchbox input{flex:1;border:none;outline:none;background:none;font-family:var(--font-mono);font-size:15px;
  color:var(--ink);padding:15px 0;letter-spacing:.02em;min-width:0}
.kb-searchbox input::placeholder{color:rgba(14,14,12,.38)}
.kb-searchbox kbd{font-family:var(--font-mono);font-size:10px;border:1.5px solid rgba(14,14,12,.14);
  border-bottom-width:3px;border-radius:6px;padding:3px 8px;color:var(--muted)}
.kb-alert{font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:.1em;background:var(--ink);
  color:var(--paper);border:2px solid var(--ink);border-radius:14px;padding:0 20px;cursor:pointer;
  white-space:nowrap;display:inline-flex;align-items:center;text-decoration:none;text-transform:uppercase}
.kb-alert:hover{background:var(--acid);color:var(--ink)}

/* ── toolbar ── */
.kb-toolbar{padding:16px 0 12px;margin-top:14px;border-bottom:1.5px solid rgba(14,14,12,.14)}
.kb-trow{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.kb-trow + .kb-trow{margin-top:9px}
.kb-tlabel{font-family:var(--font-mono);font-size:8.5px;font-weight:700;letter-spacing:.2em;color:var(--muted);
  margin-right:2px;width:54px;text-transform:uppercase;flex:none}
.kb-chip{font-family:var(--font-mono);font-size:10.5px;font-weight:700;letter-spacing:.08em;
  border:1.5px solid rgba(14,14,12,.6);border-radius:999px;padding:7px 13px;background:none;color:#3a3833;
  cursor:pointer;transition:all .12s;text-transform:uppercase}
.kb-chip:hover{border-color:var(--ink)}
.kb-chip[aria-pressed="true"]{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.kb-chip[aria-pressed="true"] b{color:var(--acid)}
.kb-chip b{font-weight:600;color:var(--muted);margin-left:5px}
.kb-seg{display:inline-flex;border:1.5px solid rgba(14,14,12,.6);border-radius:999px;overflow:hidden}
.kb-seg button{font-family:var(--font-mono);font-size:10.5px;font-weight:700;letter-spacing:.08em;border:none;
  background:none;color:#3a3833;padding:7px 14px;cursor:pointer;border-right:1.5px solid rgba(14,14,12,.14);
  text-transform:uppercase}
.kb-seg button:last-child{border-right:none}
.kb-seg button[aria-pressed="true"]{background:var(--acid);color:var(--ink)}
.kb-ghostlock{margin-left:auto;font-family:var(--font-mono);font-size:9.5px;font-weight:700;letter-spacing:.12em;
  color:var(--ink);display:flex;align-items:center;gap:7px;text-transform:uppercase}
.kb-ghostlock i{width:30px;height:16px;border-radius:99px;background:var(--acid);outline:1.5px solid var(--ink);
  position:relative;display:inline-block;flex:none}
.kb-ghostlock i::after{content:"";position:absolute;right:2px;top:2px;width:12px;height:12px;border-radius:50%;background:var(--ink)}

/* ── meta line ── */
.kb-meta{display:flex;justify-content:space-between;align-items:baseline;padding:16px 2px 10px;flex-wrap:wrap;gap:8px}
.kb-count{font-family:var(--font-mono);font-size:12px;letter-spacing:.06em;color:#3a3833}
.kb-count b{font-size:18px;letter-spacing:0;color:var(--ink)}
.kb-blocked{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.1em;color:#C84B2C;font-weight:700;text-transform:uppercase}
.kb-blocked a{color:inherit}

/* ── the board ── */
.kb-board{background:#FFFDF7;border:2px solid var(--ink);border-radius:16px;overflow:hidden;
  box-shadow:0 26px 50px -28px rgba(14,14,12,.45)}
.kb-row{display:grid;grid-template-columns:44px minmax(0,2fr) 150px 92px 90px 100px 92px;gap:14px;
  align-items:center;padding:15px 20px;border-bottom:1.5px dashed rgba(14,14,12,.14);
  animation:kb-rowin .35s cubic-bezier(.22,1,.36,1) both;cursor:pointer}
.kb-row:last-child{border-bottom:none}
.kb-row:hover{background:rgba(212,255,61,.13)}
.kb-logo{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;font-family:var(--font-mono);
  font-weight:700;font-size:15px;color:#fff}
.kb-who{min-width:0}
.kb-who b{display:block;font-size:15.5px;font-weight:700;letter-spacing:-.01em;line-height:1.2;color:var(--ink);
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.kb-who span{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.08em;color:var(--muted);display:block;
  margin-top:3px;text-transform:uppercase;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.kb-pay{font-family:var(--font-mono);font-size:12.5px;font-weight:700;letter-spacing:-.01em;color:var(--ink)}
.kb-pay small{display:block;font-size:8.5px;font-weight:700;letter-spacing:.06em;margin-top:3px;color:var(--muted)}
.kb-pay.kb-pay--none{color:rgba(14,14,12,.35);font-weight:500}
.kb-mode{font-family:var(--font-mono);font-size:8.5px;font-weight:700;letter-spacing:.1em;
  border:1.5px solid rgba(14,14,12,.6);border-radius:99px;padding:5px 0;text-align:center;color:#3a3833;
  text-transform:uppercase}
.kb-mode--none{border-color:rgba(14,14,12,.18);color:rgba(14,14,12,.35)}
.kb-fresh{font-family:var(--font-mono);font-size:10px;letter-spacing:.04em;color:var(--muted);
  display:flex;align-items:center;gap:7px}
.kb-fresh i{width:7px;height:7px;border-radius:50%;background:var(--acid-deep);animation:kb-pulse 1.8s infinite;flex:none}
.kb-gscore{font-family:var(--font-mono);font-size:9px;font-weight:700;letter-spacing:.08em;text-align:center;
  border-radius:8px;padding:6px 0;background:rgba(212,255,61,.25);outline:1.5px solid rgba(14,14,12,.35);color:var(--ink)}
.kb-apply{font-family:var(--font-mono);font-size:10px;font-weight:700;letter-spacing:.1em;text-align:center;
  background:var(--acid);outline:2px solid var(--ink);border-radius:999px;padding:8px 0;color:var(--ink);
  text-decoration:none;display:block;text-transform:uppercase}
.kb-apply:hover{background:var(--acid-deep)}

/* skeleton rows */
.kb-row.kb-skel{cursor:default;animation:none}
.kb-skel .kb-sk{background:rgba(14,14,12,.08);border-radius:8px;animation:kb-pulse 1.6s infinite}

/* ── description popover ── */
#kb-pop{position:absolute;z-index:60;width:380px;background:#FFFDF7;border:2px solid var(--ink);
  border-radius:14px;box-shadow:8px 10px 0 rgba(14,14,12,.55);padding:16px 18px 14px;
  opacity:0;transform:translateY(4px) scale(.985);transition:opacity .14s,transform .14s;pointer-events:none}
#kb-pop.show{opacity:1;transform:none}
#kb-pop .pt{font-size:15px;font-weight:700;letter-spacing:-.01em;color:var(--ink)}
#kb-pop .pc{font-family:var(--font-mono);font-size:9px;letter-spacing:.1em;color:var(--muted);margin:3px 0 10px;text-transform:uppercase}
#kb-pop .plbl{font-family:var(--font-mono);font-size:8px;font-weight:700;letter-spacing:.22em;color:var(--muted);
  border-top:1px solid rgba(14,14,12,.14);padding-top:9px;margin-bottom:5px}
#kb-pop .pd{font-size:13px;line-height:1.5;color:#2e2c27}
#kb-pop .pv{margin-top:11px;font-family:var(--font-mono);font-size:8.5px;font-weight:700;letter-spacing:.1em;
  background:rgba(212,255,61,.3);outline:1.5px solid rgba(14,14,12,.5);border-radius:8px;padding:7px 10px;
  line-height:1.8;color:var(--ink);text-transform:uppercase}
#kb-pop .pv i{font-style:normal;color:#5d7a1a}
@media (hover:none){#kb-pop{display:none}}

/* ── stale banner + see-all + empty ── */
.kb-stale{font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;border:1.5px solid rgba(14,14,12,.55);
  border-radius:10px;padding:9px 14px;margin:0 0 14px;background:var(--cream);color:#3a3833}
.kb-more{margin:14px 2px 0;font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;color:#3a3833}
.kb-more a{color:var(--ink);font-weight:700}
.kb-empty{text-align:center;padding:70px 30px}
.kb-empty .kb-klep{width:74px;height:74px;border-radius:18px;background:var(--ink);margin:0 auto 18px;position:relative}
.kb-empty .kb-klep::before{content:"";position:absolute;left:19px;top:27px;width:10px;height:10px;border-radius:50%;background:var(--paper)}
.kb-empty .kb-klep::after{content:"";position:absolute;right:16px;top:30px;width:16px;height:6px;border-radius:99px;border-bottom:4px solid var(--paper)}
.kb-empty .kb-klepmouth{position:absolute;left:50%;top:48px;width:22px;height:8px;border:3.5px solid var(--paper);
  border-top:none;border-radius:0 0 18px 18px;transform:translateX(-50%)}
.kb-empty h3{font-size:22px;font-weight:700;letter-spacing:-.01em;color:var(--ink);margin:0}
.kb-empty p{font-size:14px;color:var(--muted);max-width:36em;margin:8px auto 18px;line-height:1.55}
.kb-empty p b{color:#C84B2C}
.kb-empty .kb-savebtn{font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:.1em;
  background:var(--acid);border:2px solid var(--ink);border-radius:999px;padding:11px 24px;cursor:pointer;
  box-shadow:3px 4px 0 rgba(14,14,12,.8);color:var(--ink);text-decoration:none;display:inline-block;text-transform:uppercase}

/* ── pager + foot ── */
.kb-pager{display:flex;justify-content:center;align-items:center;gap:18px;margin-top:20px;font-family:var(--font-mono)}
.kb-pager[hidden]{display:none}
.kb-pager button{font-family:var(--font-mono);font-size:10.5px;font-weight:700;letter-spacing:.1em;
  border:1.5px solid rgba(14,14,12,.6);border-radius:999px;background:none;color:var(--ink);
  padding:9px 18px;cursor:pointer;text-transform:uppercase}
.kb-pager button:disabled{opacity:.35;cursor:default}
.kb-pager button:not(:disabled):hover{background:var(--ink);color:var(--paper)}
.kb-pageinfo{font-size:11px;letter-spacing:.08em;color:var(--muted)}
.kb-foot{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-family:var(--font-mono);
  font-size:9.5px;letter-spacing:.12em;color:var(--muted);padding:18px 4px 0;text-transform:uppercase}
.kb-foot a{color:#C84B2C;font-weight:700}

/* ── responsive ── */
@media (max-width:980px){
  .kb-row{grid-template-columns:44px minmax(0,1fr) 110px;row-gap:10px}
  .kb-mode,.kb-fresh,.kb-gscore{display:none}
  .kb-apply{grid-column:3}
  .kb-ghostlock{margin-left:0}
  .kb-searchbar{flex-direction:column}
  .kb-alert{justify-content:center;padding:13px 20px}
}
@media (prefers-reduced-motion: reduce){
  .kb-row{animation:none}
  .kb-live i,.kb-fresh i,.kb-skel .kb-sk{animation:none}
}
