* { box-sizing: border-box; }

body {
  margin: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
  background: #f5f6f8;
  color: #1d2330;
  line-height: 1.45;
}

.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: #101727;
  color: #fff;
  padding: 14px 24px;
}
.brand {
  color: #fff;
  text-decoration: none;
  font-weight: 700;
  font-size: 1.25rem;
  letter-spacing: 0.5px;
}
.topbar nav { display: flex; align-items: center; }
.nav-link {
  color: #c4cbda;
  text-decoration: none;
  margin-left: 18px;
  font-size: 0.95rem;
}
.nav-link:hover { color: #fff; }
.nav-email { color: #8a93a8; margin-left: 18px; font-size: 0.85rem; }
.logout-form { margin: 0 0 0 18px; }
.logout-btn {
  background: none;
  border: none;
  color: #c4cbda;
  cursor: pointer;
  padding: 0;
  font: inherit;
}
.logout-btn:hover { color: #fff; }

/* first-time hide/apply notice */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(16, 23, 39, 0.55);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 100;
}
.modal-overlay[hidden] { display: none; }
.modal {
  background: #fff;
  border-radius: 14px;
  padding: 24px 26px;
  max-width: 440px;
  margin: 0 16px;
  box-shadow: 0 12px 40px rgba(16, 23, 39, 0.3);
}
.modal h2 { margin: 0 0 10px; font-size: 1.15rem; }
.modal p { margin: 0 0 18px; color: #3c4658; font-size: 0.95rem; }
.modal-actions { display: flex; gap: 10px; justify-content: flex-end; }
.modal-warn {
  background: #fdebd2;
  border: 1px solid #f0c674;
}
.modal-warn h2 { color: #8a5a00; }
.modal-warn p { color: #6b4d10; }

/* auth pages */
.auth {
  max-width: 380px;
  margin: 8vh auto 0;
  text-align: center;
}
.auth h1 { font-size: 1.5rem; margin-bottom: 22px; }
.auth-form { display: flex; flex-direction: column; gap: 14px; text-align: left; }
.auth-form label { font-size: 0.9rem; font-weight: 600; color: #3c4658; }
.auth-form input {
  width: 100%;
  font: inherit;
  padding: 10px;
  margin-top: 5px;
  border: 1px solid #c9cfdd;
  border-radius: 8px;
}
.auth-form button { margin-top: 6px; }
.auth-alt { margin-top: 18px; font-size: 0.9rem; color: #5a6376; }
.hint-inline { font-weight: 400; color: #8a93a8; }

.container { max-width: 920px; margin: 24px auto; padding: 0 16px; }

.notice {
  padding: 10px 14px;
  border-radius: 8px;
  margin-bottom: 16px;
  font-size: 0.95rem;
}
.notice.warn { background: #fff4e0; border: 1px solid #f0c674; }
.notice.ok { background: #e5f6e8; border: 1px solid #8fd19e; }
.notice.info {
  background: #e8f0fe;
  border: 1px solid #9cb8f0;
  display: flex;
  align-items: center;
  gap: 12px;
}
.notice-dismiss {
  margin-left: auto;
  background: transparent;
  border: none;
  font-size: 1.4rem;
  line-height: 1;
  color: #3c4658;
  cursor: pointer;
  padding: 0 4px;
}
.notice-dismiss:hover { color: #101727; }

.toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
  margin-bottom: 18px;
}
.toolbar .scan { margin-left: auto; display: flex; align-items: center; gap: 10px; }
#scan-status { font-size: 0.85rem; color: #5a6376; max-width: 380px; }
.scan-meta {
  display: flex;
  gap: 16px;
  margin: -6px 0 16px;
  font-size: 0.82rem;
  color: #69718a;
}

.pill {
  display: inline-block;
  padding: 6px 14px;
  border-radius: 999px;
  text-decoration: none;
  color: #3c4658;
  background: #e8eaf0;
  font-size: 0.9rem;
  margin-right: 4px;
}
.pill.active { background: #101727; color: #fff; }

button, .btn {
  font: inherit;
  border: none;
  border-radius: 8px;
  padding: 8px 16px;
  cursor: pointer;
  text-decoration: none;
  display: inline-block;
}
.btn-primary, #refresh-btn { background: #2456e6; color: #fff; }
#scan-btn { background: #e8eaf0; color: #3c4658; }
#scan-btn:disabled, #refresh-btn:disabled { background: #97a8d8; color: #fff; cursor: wait; }
.btn-small { padding: 5px 12px; font-size: 0.85rem; }
.btn-ghost { background: #e8eaf0; color: #3c4658; }
.btn:hover, button:hover:not(:disabled) { filter: brightness(1.08); }

.empty {
  text-align: center;
  padding: 60px 0;
  color: #69718a;
}

/* onboarding welcome (new users, blank profile) */
.welcome { max-width: 640px; margin: 24px auto; }
.welcome h1 { font-size: 1.9rem; margin-bottom: 10px; }
.welcome-lead { color: #3c4658; font-size: 1.02rem; margin-bottom: 28px; }
.welcome-steps { display: flex; flex-direction: column; gap: 16px; }
.welcome-step {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  background: #fff;
  border: 1px solid #e3e6ee;
  border-radius: 14px;
  padding: 20px 22px;
  box-shadow: 0 1px 2px rgba(16, 23, 39, 0.05);
}
.step-num {
  flex: 0 0 auto;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: #2456e6;
  color: #fff;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
}
.welcome-step h2 { font-size: 1.1rem; margin: 2px 0 6px; }
.welcome-step p { color: #5a6376; font-size: 0.95rem; margin: 0 0 12px; }
.welcome-step p:last-child { margin-bottom: 0; }

/* category chooser (landing page) */
.chooser {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 70vh;
}
.chooser h1 { font-size: 2rem; margin-bottom: 36px; }
.chooser-cards {
  display: flex;
  gap: 24px;
  justify-content: center;
  flex-wrap: wrap;
}
.chooser-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  width: 300px;
  padding: 28px 22px;
  background: #fff;
  border: 1px solid #e3e6ee;
  border-radius: 14px;
  text-decoration: none;
  color: #1d2330;
  box-shadow: 0 1px 2px rgba(16, 23, 39, 0.05);
  transition: transform 0.12s, box-shadow 0.12s, border-color 0.12s;
}
.chooser-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 6px 18px rgba(16, 23, 39, 0.12);
  border-color: #2456e6;
}
.chooser-emoji { font-size: 2.4rem; }
.chooser-title { font-weight: 700; font-size: 1.2rem; margin: 12px 0 8px; }
.chooser-desc { color: #5a6376; font-size: 0.92rem; }
.chooser-count {
  margin-top: 16px;
  font-weight: 600;
  font-size: 0.85rem;
  color: #2456e6;
  background: #eef2fe;
  padding: 4px 12px;
  border-radius: 999px;
}

/* category bar on the dashboard */
.cat-bar {
  display: flex;
  align-items: baseline;
  gap: 14px;
  margin-bottom: 14px;
}
.cat-heading { font-size: 1.4rem; margin: 0; }
.cat-switch { font-size: 0.9rem; color: #2456e6; text-decoration: none; }
.cat-switch:hover { text-decoration: underline; }

.cards { display: flex; flex-direction: column; gap: 14px; }

.card, .job-page {
  background: #fff;
  border: 1px solid #e3e6ee;
  border-radius: 12px;
  padding: 16px 18px;
  box-shadow: 0 1px 2px rgba(16, 23, 39, 0.05);
}

.card-head { display: flex; align-items: flex-start; gap: 14px; }
.card-title { flex: 1; }
.card-title a { color: #1d2330; text-decoration: none; font-weight: 600; font-size: 1.05rem; }
.card-title a:hover { color: #2456e6; }
.card-title h1 { margin: 0; font-size: 1.3rem; }
.card-sub { color: #5a6376; font-size: 0.9rem; margin-top: 2px; }

.score {
  min-width: 46px;
  text-align: center;
  font-weight: 700;
  font-size: 1.1rem;
  border-radius: 10px;
  padding: 8px 0;
  color: #fff;
  align-self: flex-start;
}
.score-high { background: #1e9e50; }
.score-mid { background: #d99a1b; }

.found-chip {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-width: 56px;
  padding: 4px 6px;
  border: 2px solid #101727;
  border-radius: 10px;
  background: #fff;
  align-self: flex-start;
}
.found-date { font-weight: 700; font-size: 0.85rem; color: #101727; }
.found-time { font-size: 0.75rem; color: #5a6376; }

.card-side {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 8px;
}
.card-buttons { display: flex; gap: 6px; }
.btn-applied { background: #1e9e50; color: #fff; }

.badges { display: flex; gap: 6px; }
.badge {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 6px;
}
.badge-new { background: #2456e6; color: #fff; }
.badge-verified { background: #e5f6e8; color: #19763c; }
.badge-lead { background: #fff4e0; color: #9a6b06; }

.proscons { list-style: none; padding: 0; margin: 12px 0 4px; }
.proscons li { font-size: 0.92rem; padding: 2px 0; }
.pro { color: #19763c; }
.con { color: #b96a08; }

.card-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 10px;
  font-size: 0.83rem;
  color: #69718a;
}
.found { font-weight: 600; color: #3c4658; }
.deadline { color: #b3261e; font-weight: 600; }

.card-actions { margin-top: 12px; display: flex; gap: 8px; }

.back { display: inline-block; margin-bottom: 14px; color: #2456e6; text-decoration: none; }
.job-page h2 { font-size: 1rem; margin: 18px 0 6px; color: #3c4658; }
.reason { font-style: italic; color: #3c4658; margin-top: 14px; }
.analysis { margin: 4px 0; }
.snippet { color: #5a6376; font-size: 0.92rem; }
.job-actions { margin-top: 20px; display: flex; gap: 10px; }

.hint { color: #5a6376; font-size: 0.95rem; }
.form-section { font-size: 1rem; margin: 22px 0 8px; color: #3c4658; }

/* structured profile form */
.profile-form label {
  display: block;
  font-size: 0.9rem;
  font-weight: 600;
  color: #3c4658;
  margin: 10px 0;
}
.profile-form label input[type="text"],
.profile-form label input[type="number"] {
  display: block;
  width: 100%;
  font: inherit;
  font-weight: 400;
  padding: 9px 10px;
  margin-top: 5px;
  border: 1px solid #c9cfdd;
  border-radius: 8px;
}
.field-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0 16px;
}
.check-label {
  display: flex !important;
  align-items: flex-start;
  gap: 8px;
  font-weight: 400 !important;
}
.check-label input { width: auto; margin-top: 3px; }

/* smarter-matching box on the profile page */
.tune-box {
  margin-top: 28px;
  background: #fff;
  border: 1px solid #e3e6ee;
  border-radius: 12px;
  padding: 16px 18px;
}
.tune-box h2 { font-size: 1.05rem; margin: 0 0 6px; }
.tune-actions { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
#rescore-status { font-size: 0.85rem; color: #5a6376; }

/* tune (clarifying questions) page */
.tune-page h1 { font-size: 1.4rem; }
.tune-question { margin-bottom: 4px; }
.tune-question label {
  display: block;
  font-weight: 600;
  font-size: 0.95rem;
  color: #1d2330;
  margin-bottom: 6px;
}
.tune-question textarea { width: 100%; }
.profile-form textarea {
  width: 100%;
  font: inherit;
  padding: 12px;
  border: 1px solid #c9cfdd;
  border-radius: 10px;
  resize: vertical;
}
.min-score-label { display: block; margin: 14px 0; font-size: 0.95rem; }
.notify-label {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 14px 0;
  font-size: 0.95rem;
}
.notify-label input { width: auto; }
.min-score-label input {
  width: 70px;
  font: inherit;
  padding: 6px;
  border: 1px solid #c9cfdd;
  border-radius: 6px;
  margin-left: 8px;
}

/* ---------- mobile (phones, ~375px) ---------- */
@media (max-width: 560px) {
  .container { padding: 0 12px; margin-top: 16px; }
  .topbar { padding: 12px 14px; }
  .nav-link { margin-left: 14px; }
  .nav-email { display: none; }            /* email crowds the bar on phones */
  .logout-form { margin-left: 14px; }

  /* scan/refresh controls: full-width, share a row, status below */
  .toolbar .scan { margin-left: 0; width: 100%; flex-wrap: wrap; }
  #refresh-btn, #scan-btn { flex: 1 1 auto; }
  #scan-status { width: 100%; max-width: none; }
  .scan-meta { flex-wrap: wrap; gap: 6px 16px; }

  /* card header: title beside the score/date, badges + actions wrap below */
  .card-head { flex-wrap: wrap; gap: 10px; }
  .card-title { flex: 1 1 55%; min-width: 55%; }
  .card-side {
    width: 100%;
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
    flex-wrap: wrap;
    gap: 8px;
  }
  .card-buttons { flex-wrap: wrap; }
  .btn-small { padding: 8px 14px; }        /* bigger tap targets */

  /* category chooser + job actions stack full width */
  .chooser-card { width: 100%; }
  .job-actions { flex-wrap: wrap; }
  .job-actions .btn { flex: 1 1 auto; text-align: center; }
  .welcome h1 { font-size: 1.6rem; }
}
