:root{
  --bg:#f5f7fb; --card:#ffffff; --ink:#17233b; --muted:#5b6b85; --line:#e3e8f2;
  --accent:#4353ff; --accent-soft:#e8ebff; --good:#0f8a4d; --warn:#b7791f; --bad:#c0392b;
  --radius:14px; --shadow:0 2px 10px rgba(23,35,59,.06);
}
*{box-sizing:border-box}
body{margin:0;font:16px/1.55 -apple-system,BlinkMacSystemFont,"Segoe UI",Inter,Roboto,sans-serif;background:var(--bg);color:var(--ink)}
code{background:var(--accent-soft);padding:1px 6px;border-radius:6px;font-size:.85em}

.top{position:sticky;top:0;z-index:10;display:flex;align-items:center;gap:24px;padding:14px 28px;background:#fff;border-bottom:1px solid var(--line)}
.brand{font-weight:800;font-size:1.15rem;letter-spacing:.2px}
.tabs{display:flex;gap:8px}
.tab{border:1px solid var(--line);background:#fff;color:var(--muted);padding:8px 16px;border-radius:99px;cursor:pointer;font-size:.95rem}
.tab.active{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}

.view{display:none;max-width:1000px;margin:0 auto;padding:28px 20px 80px}
.view.active{display:block}
.hero h1{margin:.2em 0 .3em;font-size:1.7rem}
.hero p{color:var(--muted);max-width:70ch}

.toolbar{display:flex;gap:10px;margin:18px 0}
.toolbar input,.toolbar select{padding:10px 14px;border:1px solid var(--line);border-radius:10px;font-size:.95rem;background:#fff}
.toolbar input{flex:1}

.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:8px}
.card .co{font-weight:700}
.card .role{font-size:1.05rem;font-weight:600}
.card .meta{color:var(--muted);font-size:.87rem}
.card .note{font-size:.88rem}
.badges{display:flex;gap:6px;flex-wrap:wrap}
.badge{font-size:.75rem;padding:3px 9px;border-radius:99px;background:var(--accent-soft);color:var(--accent);font-weight:600}
.badge.direct{background:#e2f7ec;color:var(--good)}
.badge.program{background:#fff4e0;color:var(--warn)}
.badge.portal{background:#fdeceb;color:var(--bad)}
.badge.hot{background:#ffe9e9;color:#d33}
.card a.apply{margin-top:auto;display:inline-block;text-align:center;background:var(--accent);color:#fff;text-decoration:none;padding:9px 0;border-radius:10px;font-weight:600}
.card a.apply:hover{filter:brightness(1.08)}
.foot{color:var(--muted);font-size:.85rem;margin-top:26px}

/* status chips + per-job selection */
.statusbar{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin:0 0 16px}
.schip{border:1px solid var(--line);background:#fff;color:var(--muted);padding:6px 13px;border-radius:99px;cursor:pointer;font-size:.86rem}
.schip b{font-weight:700}
.schip.active{background:var(--ink);border-color:var(--ink);color:#fff}
#updated{margin-left:auto}
.badge.new{background:#e2f7ec;color:var(--good)}
.card.done{opacity:.72}
.actions{display:flex;gap:6px;flex-wrap:wrap}
.abtn{border:1px solid var(--line);background:#fff;color:var(--muted);font-size:.8rem;padding:5px 10px;border-radius:8px;cursor:pointer}
.abtn:hover{border-color:var(--accent);color:var(--accent)}
.abtn.on{background:var(--accent-soft);border-color:var(--accent);color:var(--accent);font-weight:600}
.abtn.tailor{margin-left:auto}

.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px 20px;margin:16px 0}
.panel h2{margin:0 0 10px;font-size:1.05rem}
.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin:8px 0}
.row.center{justify-content:center;margin:22px 0}
input[type=text],input[type=password],input[type=search],select,textarea{
  padding:10px 14px;border:1px solid var(--line);border-radius:10px;font-size:.95rem;font-family:inherit;background:#fff;color:var(--ink)}
#key{flex:1;min-width:240px}
textarea{width:100%;resize:vertical;margin-top:8px}
#job-title{width:100%;margin-bottom:4px}
.hint{color:var(--muted);font-size:.83rem}
.btn{border:1px solid var(--line);background:#fff;color:var(--ink);padding:9px 18px;border-radius:10px;cursor:pointer;font-size:.95rem}
.btn:hover{border-color:var(--accent);color:var(--accent)}
.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:700}
.btn.primary:hover{filter:brightness(1.08);color:#fff}
.btn.big{padding:13px 34px;font-size:1.05rem}
.btn.ghost{background:transparent}
.btn:disabled{opacity:.5;cursor:wait}

.status{text-align:center;color:var(--muted);padding:12px;background:var(--accent-soft);border-radius:10px;margin:10px 0}
.status.err{background:#fdeceb;color:var(--bad)}

.result h3{margin:22px 0 8px}
.score-row{display:flex;gap:22px;align-items:center}
.ring-bg{fill:none;stroke:var(--line);stroke-width:10}
.ring-fg{fill:none;stroke:var(--accent);stroke-width:10;stroke-linecap:round;
  stroke-dasharray:326.7;stroke-dashoffset:326.7;transform:rotate(-90deg);transform-origin:60px 60px;transition:stroke-dashoffset .8s ease}
#ring-num{font-size:30px;font-weight:800;fill:var(--ink)}
.verdict{color:var(--muted);max-width:52ch}
.chips{display:flex;gap:7px;flex-wrap:wrap}
.chip{font-size:.83rem;padding:4px 12px;border-radius:99px;font-weight:600}
.chip.ok{background:#e2f7ec;color:var(--good)}
.chip.miss{background:#fdeceb;color:var(--bad)}
#suggestions li{margin:6px 0}
pre#tailored{white-space:pre-wrap;background:#fbfcff;border:1px solid var(--line);border-radius:10px;padding:18px;font:14px/1.6 ui-monospace,Menlo,monospace}

@media print{
  .top,.toolbar,.panel:not(.result),.row,.hint,.hero,.status{display:none!important}
  .view{display:block!important;padding:0}
  pre#tailored{border:none;padding:0}
}
@media (max-width:640px){
  .top{flex-direction:column;gap:10px;padding:12px}
  .score-row{flex-direction:column;text-align:center}
}
