:root{
  --bg:#f4f4f7; --bg2:#ffffff; --card:#ffffff; --card2:#f7f7fa;
  --ink:#23252d; --ink2:#4c4f5a; --muted:#9499a5; --line:#ececf1;
  --like:#1fd86f; --nope:#fd4f6a; --maybe:#28c6ff; --rewind:#ffb02e;
  --flame1:#fe3c72; --flame2:#ff7854;
  --grad:linear-gradient(135deg,#fe3c72 0%,#ff7854 100%);
  --shadow:0 14px 36px rgba(40,30,60,.14);
  --safe-b:env(safe-area-inset-bottom,0px); --safe-t:env(safe-area-inset-top,0px);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;height:100%}
body{
  background:var(--bg); color:var(--ink);
  font:15px/1.45 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,system-ui,sans-serif;
  overscroll-behavior:none; -webkit-user-select:none; user-select:none;
}
.app{display:flex;flex-direction:column;height:100dvh;max-width:560px;margin:0 auto;position:relative;background:var(--bg)}

/* App bar */
.appbar{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:calc(10px + var(--safe-t)) 16px 10px; background:var(--bg2);
  border-bottom:1px solid var(--line); position:sticky;top:0;z-index:5;
}
.brand{display:flex;align-items:center;gap:10px}
.brand-mark{
  width:34px;height:34px;border-radius:11px;display:grid;place-items:center;
  font-weight:800;font-size:15px;color:#fff;background:var(--grad);
}
.brand-text b{font-size:16px;display:block;letter-spacing:-.2px;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.brand-text small{color:var(--muted);font-size:11px}
.appbar-right{display:flex;align-items:center;gap:12px}
.appbar-stat{text-align:right;line-height:1.05}
.appbar-stat strong{font-size:20px;color:var(--flame1)}
.appbar-stat span{display:block;color:var(--muted);font-size:9.5px;text-transform:uppercase;letter-spacing:.6px}
.help-btn{width:30px;height:30px;border-radius:50%;border:1px solid var(--line);background:var(--bg2);
  color:var(--muted);font-size:15px;font-weight:700;display:grid;place-items:center}

/* Screens */
.screen-wrap{flex:1;overflow:hidden;position:relative}
.view{display:none;height:100%;overflow-y:auto;-webkit-overflow-scrolling:touch}
.view.active{display:block}
.view:not(#swipe){padding:14px 14px calc(92px + var(--safe-b))}

/* ---------- SWIPE ---------- */
#swipe{display:none;flex-direction:column}
#swipe.active{display:flex}
.swipe-stage{flex:1;position:relative;margin:14px 14px 4px;min-height:0}
.card-back{position:absolute;inset:14px 10px;border-radius:20px;background:var(--bg2);
  box-shadow:0 6px 18px rgba(40,30,60,.08);transform:scale(.965) translateY(10px)}
.job-card{
  position:absolute;inset:0;background:var(--card);border:1px solid var(--line);
  border-radius:20px;padding:18px;overflow:hidden;box-shadow:var(--shadow);
  display:flex;flex-direction:column;gap:10px;touch-action:none;will-change:transform;cursor:grab;
}
.job-card.dragging{transition:none;cursor:grabbing}
.job-card.animate{transition:transform .32s cubic-bezier(.2,.7,.3,1),opacity .32s}
.clamp4{display:-webkit-box;-webkit-line-clamp:4;line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}
.clamp3{display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.card-row{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.badge{display:inline-block;font-size:11px;font-weight:600;color:var(--muted);
  background:var(--card2);border:1px solid var(--line);border-radius:999px;padding:3px 9px}
.badge.status-rejected{color:var(--nope)} .badge.status-interested,.badge.status-maybe{color:var(--like)}
.badge.status-backburner{color:var(--rewind)}
.job-card .title{font-size:25px;font-weight:800;line-height:1.12;margin:2px 0 0;letter-spacing:-.4px}
.job-card .company{color:var(--flame1);font-weight:700;margin:0}
.deadline{display:inline-block;align-self:flex-start;font-size:12.5px;font-weight:700;
  padding:5px 11px;border-radius:999px;border:1px solid;margin:0}
.dl-open{color:var(--muted);border-color:var(--line);background:var(--card2)}
.dl-ok{color:#13a85a;border-color:#bff0d4;background:#eafaf1}
.dl-soon{color:#b9791a;border-color:#ffe6b3;background:#fff7e8}
.dl-urgent{color:var(--nope);border-color:#ffd3da;background:#fff0f2}
.dl-past{color:var(--muted);border-color:var(--line);background:var(--card2);text-decoration:line-through}
.list-card .deadline{margin:2px 0 6px}
.kv{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:2px}
.kv .cell{background:var(--card2);border:1px solid var(--line);border-radius:12px;padding:8px 10px}
.kv .cell label{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}
.kv .cell b{font-size:13px;color:var(--ink)}
.card-note{font-size:13.5px;color:var(--ink2);margin:2px 0 0}
.card-note strong{color:var(--ink)}
.fit{background:linear-gradient(180deg,rgba(254,60,114,.06),rgba(255,120,84,.03));
  border:1px solid #ffe0e8;border-radius:12px;padding:10px;font-size:13px;color:var(--ink2)}
.fit strong{color:var(--ink)}
.empty-card{display:grid;place-items:center;text-align:center;height:100%}
.empty-card h2{margin:0 0 6px}.empty-card p{color:var(--muted);margin:0}

/* Stamps */
.stamp{position:absolute;top:26px;z-index:3;font-weight:900;font-size:30px;letter-spacing:2px;
  text-transform:uppercase;padding:6px 14px;border-radius:12px;border:4px solid;opacity:0;
  pointer-events:none;transition:opacity .08s;background:rgba(255,255,255,.7)}
.stamp-yes{right:22px;color:var(--like);border-color:var(--like);transform:rotate(14deg)}
.stamp-nope{left:22px;color:var(--nope);border-color:var(--nope);transform:rotate(-14deg)}
.stamp-maybe{left:50%;transform:translateX(-50%) rotate(-4deg);color:var(--maybe);border-color:var(--maybe)}

/* Action buttons (Tinder row) */
.swipe-controls{padding:4px 16px calc(12px + var(--safe-b))}
.note-input{width:100%;background:var(--bg2);border:1px solid var(--line);color:var(--ink);
  border-radius:12px;padding:10px 12px;font-size:13.5px;margin-bottom:10px}
.note-input::placeholder{color:var(--muted)}
.action-row{display:flex;justify-content:center;align-items:center;gap:14px}
.fab{border-radius:50%;background:var(--bg2);border:0;display:grid;place-items:center;
  box-shadow:0 6px 16px rgba(40,30,60,.16);transition:transform .12s;line-height:1}
.fab:active{transform:scale(.88)}
.fab.big{width:64px;height:64px;font-size:30px}
.fab.small{width:50px;height:50px;font-size:22px}
.fab-rewind{color:var(--rewind)}
.fab-nope{color:var(--nope)}
.fab-maybe{color:var(--maybe)}
.fab-yes{color:var(--like)}
.fab:disabled{opacity:.4}
.hint{text-align:center;color:var(--muted);font-size:11.5px;margin:11px 0 0}

/* ---------- LISTS ---------- */
.list-head{position:sticky;top:0;background:var(--bg);padding-bottom:10px;margin-bottom:4px;z-index:2}
.list-head h2{margin:0 0 8px;font-size:21px;letter-spacing:-.3px}
.search{width:100%;background:var(--bg2);border:1px solid var(--line);color:var(--ink);
  border-radius:12px;padding:11px 13px;font-size:14px}
.search::placeholder{color:var(--muted)}
.job-list{display:flex;flex-direction:column;gap:12px}
.list-card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:14px;box-shadow:0 4px 14px rgba(40,30,60,.05)}
.list-top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:4px}
.list-card h3{margin:6px 0 2px;font-size:16px}
.list-card .muted{font-size:12.5px}
.mini-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin:8px 0}
.mini{background:var(--card2);border:1px solid var(--line);border-radius:10px;padding:6px 9px;font-size:12.5px;color:var(--muted)}
.mini b{display:block;color:var(--ink);font-size:13px;margin-top:1px}
.list-card p{font-size:13px;margin:6px 0;color:var(--ink2)}
.cover{white-space:pre-wrap;background:var(--card2);border:1px solid var(--line);border-radius:10px;
  padding:10px;font-size:12.5px;color:var(--ink2);max-height:140px;overflow:auto;margin-top:6px}
.list-card ul{margin:6px 0;padding-left:18px;color:var(--muted);font-size:12.5px}
.card-actions{display:flex;flex-wrap:wrap;gap:7px;margin-top:10px}
.small-btn{background:var(--card2);border:1px solid var(--line);color:var(--ink);
  border-radius:10px;padding:8px 11px;font-size:12.5px;font-weight:600;text-decoration:none;display:inline-block}
.small-btn:active{background:#eee}
a.small-btn{color:#fff;background:var(--grad);border:0}

/* ---------- SETUP ---------- */
.panel{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:16px;margin-bottom:14px;box-shadow:0 4px 14px rgba(40,30,60,.05)}
.panel h2{margin:0 0 10px;font-size:17px}
.panel .muted{font-size:13px;margin:0 0 10px}
.form-grid{display:flex;flex-direction:column;gap:9px}
.form-grid input,.form-grid textarea{background:var(--bg2);border:1px solid var(--line);color:var(--ink);
  border-radius:11px;padding:11px 12px;font-size:14px;font-family:inherit;width:100%}
.form-grid textarea{min-height:64px;resize:vertical}
.btn-row{display:flex;flex-wrap:wrap;gap:8px}
button.primary{background:var(--grad);color:#fff;border:0;border-radius:999px;padding:14px;font-size:15px;font-weight:800;box-shadow:0 8px 20px rgba(254,60,114,.3)}
.ghost{background:var(--card2);border:1px solid var(--line);color:var(--ink);border-radius:11px;padding:11px 13px;font-size:13.5px;font-weight:600}
.ghost.danger{color:var(--nope);border-color:#ffd3da}
.checklist{margin:0;padding-left:18px;color:var(--ink2);font-size:13.5px;display:flex;flex-direction:column;gap:6px}
.muted{color:var(--muted)} .version{text-align:center;color:var(--muted);font-size:12px;margin:4px 0 0}

/* ---------- TAB BAR ---------- */
.tabbar{display:flex;background:var(--bg2);border-top:1px solid var(--line);padding-bottom:var(--safe-b);position:sticky;bottom:0;z-index:6}
.tab{flex:1;background:none;border:0;color:var(--muted);padding:9px 2px;display:flex;flex-direction:column;align-items:center;gap:3px;font-size:10.5px;font-weight:600}
.tab .ti{font-size:18px;line-height:1}
.tab.active{color:var(--flame1)}

/* ---------- ONBOARDING ---------- */
.onboard{position:fixed;inset:0;z-index:50;background:rgba(20,12,24,.55);backdrop-filter:blur(3px);
  display:grid;place-items:end center;padding:0}
.onboard[hidden]{display:none}
.onboard-card{background:var(--bg2);width:100%;max-width:560px;border-radius:22px 22px 0 0;
  padding:26px 22px calc(26px + var(--safe-b));text-align:center;box-shadow:0 -10px 40px rgba(0,0,0,.3);
  animation:slideup .28s ease}
@keyframes slideup{from{transform:translateY(40px);opacity:.6}to{transform:none;opacity:1}}
.onboard-flame{font-size:42px;line-height:1}
.onboard-card h2{margin:8px 0 4px;font-size:22px;letter-spacing:-.3px;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.onboard-sub{color:var(--muted);font-size:13px;margin:0 0 16px}
.onboard-list{list-style:none;margin:0 0 14px;padding:0;display:flex;flex-direction:column;gap:11px;text-align:left}
.onboard-list li{display:flex;align-items:center;gap:12px;font-size:14.5px;color:var(--ink)}
.ob-ic{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;font-size:19px;color:#fff;flex:0 0 auto}
.ob-like{background:var(--like)} .ob-nope{background:var(--nope)} .ob-maybe{background:var(--maybe)} .ob-rewind{background:var(--rewind)}
.onboard-note{font-size:12.5px;color:var(--muted);margin:0 0 16px}
.onboard .primary{width:100%}
