:root{
  --purple:#230939; --purple-d:#160521; --purple-l:#4a2270;
  --green:#00b6b4; --pink:#d6249f; --ink:#2b2b2b; --muted:#6b6b6b;
  --line:#e6e6ea; --bg:#f4f4f6;
}
*{box-sizing:border-box}
body{margin:0;font-family:'Segoe UI',Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--bg)}

/* login gate */
.gate{position:fixed;inset:0;background:linear-gradient(135deg,var(--purple-d),var(--purple));display:flex;align-items:center;justify-content:center;z-index:60;padding:20px}
.gate[hidden]{display:none}
.gate-card{background:#fff;border-radius:12px;padding:34px 30px;width:min(360px,100%);box-shadow:0 24px 70px rgba(0,0,0,.4);display:flex;flex-direction:column;gap:12px}
.gate-brand{display:flex;align-items:center;justify-content:center;gap:9px}
.gate-brand .logo-img{height:30px;width:auto}
.gate-sub{margin:0 0 6px;text-align:center;color:var(--muted);font-size:14px}
.gate-card input{border:1px solid var(--line);border-radius:6px;padding:12px 14px;font-size:15px}
.gate-card input:focus{outline:none;border-color:var(--purple-l)}
.gate-btn{background:var(--pink);color:#fff;border:none;border-radius:6px;padding:13px;font-weight:700;font-size:15px;letter-spacing:.5px;cursor:pointer}
.gate-btn:hover{filter:brightness(1.08)}
.gate-btn:disabled{opacity:.6;cursor:not-allowed}
.gate-msg{color:#c0392b;font-size:13px;text-align:center;min-height:16px}
#app[hidden]{display:none}
.popup-card{width:min(460px,100%)}
.popup-body{padding:22px 20px;font-size:15px;line-height:1.55;color:#333;white-space:pre-wrap}

/* top nav */
.topnav{display:flex;align-items:center;gap:32px;padding:0 28px;height:60px;background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10}
.brand{display:flex;align-items:center;gap:8px;color:var(--purple)}
.logo-img{height:28px;width:auto;display:block;color:inherit}
.brand-accent{color:var(--green)}
.pro{font-size:12px;font-weight:700;color:#fff;background:var(--pink);padding:2px 7px;border-radius:4px;letter-spacing:1px}
.nav-links{display:flex;gap:22px;flex:1}
.nav-links a{font-size:14px;color:#444;cursor:pointer;padding:6px 12px;border-radius:18px}
.nav-links a.active{background:var(--purple);color:#fff}
.account{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--muted)}
.credits{font-size:13px;color:#444;background:#f4eef8;border:1px solid var(--line);border-radius:14px;padding:4px 12px}
.credits b{color:var(--purple)}
.credits[hidden]{display:none}
.dot{width:9px;height:9px;border-radius:50%;display:inline-block}
.dot.off{background:#c9c9c9}.dot.on{background:var(--green)}.dot.busy{background:#f5a623}

/* hero / search */
.hero{background:linear-gradient(135deg,var(--purple-d),var(--purple));color:#fff;padding:34px 28px 40px}
.hero h1{margin:0 0 22px;font-size:26px;font-weight:600}
.search-bar{display:flex;gap:14px;align-items:flex-end;background:#fff;padding:14px;border-radius:8px;box-shadow:0 6px 24px rgba(0,0,0,.2)}
.field{display:flex;flex-direction:column;gap:5px}
.field.grow{flex:1}
.field label{font-size:11px;font-weight:700;color:var(--purple);letter-spacing:.5px}
.field input,.field select{border:1px solid var(--line);border-radius:5px;padding:0 12px;height:42px;font-size:14px;min-width:190px}
.field.grow input{width:100%}
.btn-search{background:var(--pink);color:#fff;border:none;border-radius:5px;padding:0 34px;height:42px;font-weight:700;font-size:14px;letter-spacing:1px;cursor:pointer;align-self:flex-end}
.btn-search:hover{filter:brightness(1.08)}
.btn-search:disabled{opacity:.6;cursor:not-allowed}
.citizenship{display:flex;align-items:center;gap:18px;margin-top:16px;flex-wrap:wrap}
.cit-label{font-size:11px;font-weight:700;letter-spacing:.5px;opacity:.9}
.cit-options{display:flex;gap:18px;flex-wrap:wrap}
.cit-options label{font-size:13px;display:flex;align-items:center;gap:6px;cursor:pointer}

.btn-ghost{background:transparent;border:1px solid var(--purple);color:var(--purple);border-radius:18px;padding:6px 16px;font-size:13px;cursor:pointer}
.btn-ghost:hover{background:var(--purple);color:#fff}

/* advanced filters (disabled / coming soon) */
.advanced{max-width:920px;margin:18px auto 0;padding:0 20px}
.adv-toggle{background:none;border:none;color:var(--purple);font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;padding:4px 0}
.adv-toggle:hover{text-decoration:underline}
.soon{font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;background:#eee;color:#888;padding:2px 7px;border-radius:10px}
.adv-panel{margin-top:12px;background:#fff;border:1px solid var(--line);border-radius:8px;padding:18px}
.adv-grid{border:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:14px 18px}
.adv-grid[disabled]{opacity:.6}
.adv-field{display:flex;flex-direction:column;gap:5px}
.adv-field.adv-wide{grid-column:1/-1}
.adv-field>label{font-size:11px;font-weight:700;color:var(--purple);letter-spacing:.4px}
.adv-field input[type=text],.adv-field select{border:1px solid var(--line);border-radius:5px;padding:9px 10px;font-size:13px;background:#f7f7f9;cursor:not-allowed}
.adv-checks{display:flex;flex-wrap:wrap;gap:8px 18px}
.adv-checks label{font-size:13px;color:#555;display:flex;align-items:center;gap:6px;cursor:not-allowed}

/* results */
main{max-width:920px;margin:24px auto;padding:0 20px}
.results-head{display:flex;align-items:baseline;gap:12px;margin-bottom:14px}
.results-head h2{margin:0;font-size:20px}
#results-meta{color:var(--muted);font-size:14px}
.results{display:flex;flex-direction:column;gap:14px}
.empty{color:var(--muted);text-align:center;padding:50px 0}

/* pagination */
.pagination{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:6px;margin:22px 0 8px}
.pagination:empty{display:none}
.pg-btn{min-width:38px;height:38px;padding:0 12px;border:1px solid var(--line);background:#fff;border-radius:6px;font-size:14px;color:var(--purple-l);cursor:pointer;font-weight:600}
.pg-btn:hover:not(:disabled){background:var(--purple);color:#fff;border-color:var(--purple)}
.pg-btn.active{background:var(--purple);color:#fff;border-color:var(--purple);cursor:default}
.pg-btn:disabled{opacity:.45;cursor:default}
.pg-gap{color:var(--muted);padding:0 2px}

.card{background:#fff;border:1px solid var(--line);border-radius:8px;padding:18px 20px;display:flex;gap:16px;transition:box-shadow .15s,border-color .15s;cursor:pointer}
.card:hover{box-shadow:0 4px 16px rgba(0,0,0,.1);border-color:var(--purple-l)}
.match{flex:0 0 64px;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:4px}
.match .pct{font-size:18px;font-weight:800;color:var(--purple);background:#f1e6f6;border-radius:50%;width:54px;height:54px;display:flex;align-items:center;justify-content:center}
.match .lbl{font-size:9px;color:var(--muted);letter-spacing:1px}
.card-body{flex:1;min-width:0}
.card-name{font-size:17px;font-weight:700;color:var(--ink)}
.card-name a{color:inherit;text-decoration:none}
.card-name a:hover{text-decoration:none}
.card-sub{font-size:14px;color:#333;margin-top:2px}
.card-loc{font-size:13px;color:var(--muted)}
.card-meta{font-size:13px;color:#444;margin-top:8px;line-height:1.5}
.card-meta b{color:#222}
.card-skills{margin-top:8px;display:flex;flex-wrap:wrap;gap:6px}
.skill{font-size:12px;background:#f0f0f3;border-radius:12px;padding:3px 10px;color:#444}
.updated{font-size:12px;color:var(--muted);margin-top:6px}

/* resume modal */
.modal{position:fixed;inset:0;background:rgba(20,10,30,.55);display:none;align-items:flex-start;justify-content:center;padding:40px 16px;z-index:40;overflow:auto}
.modal.show{display:flex}
.modal-card{background:#fff;border-radius:10px;width:min(820px,100%);box-shadow:0 20px 60px rgba(0,0,0,.35);overflow:hidden}
.modal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;background:var(--purple);color:#fff;font-weight:600;font-size:15px;position:sticky;top:0}
.modal-close{background:transparent;border:none;color:#fff;font-size:26px;line-height:1;cursor:pointer;padding:0 4px}
.modal-note{padding:7px 18px;font-size:12px;color:var(--muted);background:#faf7fc;border-bottom:1px solid var(--line)}
.modal-note:empty{display:none}
.modal-body{padding:0;min-height:200px;background:#f0f0f3}
.resume-img{display:block;width:100%;border-bottom:1px solid #ddd}
.resume-pdf{display:block;width:100%;height:78vh;border:none}
.resume-dl{display:block;padding:12px 18px;background:var(--pink);color:#fff;text-decoration:none;font-weight:600;font-size:14px;text-align:center}
.resume-dl:hover{filter:brightness(1.08)}
.docx-view{background:#e9e9ee;padding:16px;max-height:78vh;overflow:auto}
.docx-view .docx-wrapper{background:#e9e9ee;padding:0}
.docx-view .docx{box-shadow:0 2px 10px rgba(0,0,0,.15);margin:0 auto}
.modal-loading{display:flex;align-items:center;justify-content:center;gap:10px;color:var(--muted);padding:60px 0;font-size:15px}
.spinner.dark{border-color:var(--purple);border-top-color:transparent}

.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:#222;color:#fff;padding:12px 22px;border-radius:6px;font-size:14px;opacity:0;pointer-events:none;transition:opacity .25s;z-index:50}
.toast.show{opacity:1}
.spinner{display:inline-block;width:14px;height:14px;border:2px solid #fff;border-top-color:transparent;border-radius:50%;animation:spin .7s linear infinite;vertical-align:-2px;margin-right:6px}
@keyframes spin{to{transform:rotate(360deg)}}
