﻿.vialem-job-fit {
  overflow: hidden;
}

.vialem-job-fit__header {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  padding: 28px 30px 18px;
  border-bottom: 1px solid #dbe8e4;
}

.vialem-job-fit__eyebrow,
.vialem-job-fit-limits-card__eyebrow,
.vialem-job-fit-results__eyebrow {
  font-size: 0.86rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-weight: 800;
  color: #0c6270;
}

.vialem-job-fit__title {
  margin: 10px 0 12px;
  color: #0a5863;
  font-size: clamp(2rem, 3.3vw, 3rem);
  line-height: 1.06;
}

.vialem-job-fit__intro,
.vialem-job-fit__meta,
.vialem-job-fit__upload-meta,
.vialem-job-fit__status,
.vialem-job-fit-limits-card__hint,
.vialem-job-fit-results__hero p,
.vialem-job-fit-block p,
.vialem-job-fit__empty p {
  font-size: 1.02rem;
  line-height: 1.65;
  color: #31505b;
}

.vialem-job-fit__meta-wrap {
  min-width: 180px;
  text-align: right;
  display: flex;
  align-items: flex-end;
  justify-content: flex-end;
}

.vialem-job-fit__panel {
  display: grid;
  grid-template-columns: minmax(0, 1.8fr) minmax(300px, 0.9fr);
  gap: 18px;
  padding: 24px 30px 18px;
}

.vialem-job-fit__intake,
.vialem-job-fit-limits-card,
.vialem-job-fit-results__hero,
.vialem-job-fit-block,
.vialem-job-fit__empty {
  background: #ffffff;
  border: 1px solid #d6e4df;
  border-radius: 22px;
  box-shadow: 0 14px 30px rgba(12, 85, 113, 0.06);
}

.vialem-job-fit__intake {
  padding: 22px;
}

.vialem-job-fit__intake-header {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: flex-start;
  margin-bottom: 16px;
}

.vialem-job-fit__intake-header h4,
.vialem-job-fit-block h5 {
  margin: 0 0 8px;
  color: #0a5863;
  font-size: 1.25rem;
}

.vialem-job-fit__upload-button {
  appearance: none;
  background: #0c6270;
  border: 1px solid #0c6270;
  border-radius: 999px;
  box-shadow: none;
  color: #ffffff;
  cursor: pointer;
  min-height: 44px;
  padding: 0 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  transition: background-color 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

.vialem-job-fit__upload-button:hover,
.vialem-job-fit__upload-button:focus-within {
  background: #094f5a;
  border-color: #094f5a;
  color: #ffffff;
}

.vialem-job-fit__upload-button input[type="file"] {
  display: none;
}

.vialem-job-fit__source-options {
  display: block;
}

.vialem-job-fit__source-choice {
  display: block;
  margin: 0;
  color: #0a5863;
  font-weight: 700;
  padding: 12px 14px;
  border: 1px solid #c8ddd7;
  border-radius: 16px;
  background: #f3faf8;
  cursor: pointer;
  transition: border-color 0.18s ease, background-color 0.18s ease, box-shadow 0.18s ease;
}

.vialem-job-fit__source-choice.is-active {
  border-color: #0c6270;
  background: #e8f4f2;
  box-shadow: 0 0 0 2px rgba(12, 98, 112, 0.08);
}

.vialem-job-fit__source-choice input {
  margin-right: 8px;
}

.vialem-job-fit__source-pane {
  display: none;
  margin-top: 10px;
}

.vialem-job-fit__source-pane.is-active {
  display: block;
}

.vialem-job-fit__source-sep {
  margin: 14px 0;
  text-align: center;
  color: #577079;
  font-weight: 700;
  text-transform: lowercase;
}

.vialem-job-fit__textarea-wrap {
  display: block;
}

.vialem-job-fit__textarea-wrap > span {
  display: block;
  font-weight: 700;
  color: #0e5156;
  margin-bottom: 10px;
}

.vialem-job-fit__textarea-wrap textarea {
  width: 100%;
  min-height: 320px;
  border-radius: 18px;
  border: 1px solid #b8d3cc;
  background: #fbfdfd;
  padding: 16px 18px;
  font-size: 1rem;
  line-height: 1.6;
  color: #23343a;
}

.vialem-job-fit__controls {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  margin-top: 18px;
}

.vialem-job-fit__controls .button {
  min-height: 48px;
  border-radius: 999px;
  padding: 0 22px;
  font-weight: 800;
}

.vialem-job-fit__analyze.button {
  background: #0c6270;
  border-color: #0c6270;
  color: #fff;
}

.vialem-job-fit__clear.button {
  background: #edf7f4;
  border-color: #d5e3df;
  color: #0e5156;
}

.vialem-job-fit__upload-meta,
.vialem-job-fit__status {
  min-height: 1.6em;
  margin-top: 12px;
}

.vialem-job-fit__upload-meta.is-error,
.vialem-job-fit__status.is-error {
  color: #9b2f2f;
}

.vialem-job-fit__upload-meta.is-success,
.vialem-job-fit__status.is-success {
  color: #1d6f4f;
}

.vialem-job-fit-limits-card {
  padding: 22px;
}

.vialem-job-fit-limits-card__message {
  margin-top: 10px;
  font-weight: 700;
  color: #16333a;
}

.vialem-job-fit-limits-card__stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin: 18px 0 16px;
}

.vialem-job-fit-limits-card__stats div {
  padding: 14px 10px;
  border-radius: 16px;
  background: #eff8f6;
  text-align: center;
}

.vialem-job-fit-limits-card__stats strong {
  display: block;
  color: #0a5863;
  font-size: 1.3rem;
}

.vialem-job-fit-limits-card__stats span {
  display: block;
  margin-top: 4px;
  color: #51707a;
  font-size: 0.9rem;
}

.vialem-job-fit-limits-card__upsell {
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid #dbe8e4;
}

.vialem-job-fit-limits-card__upsell-title {
  font-weight: 800;
  color: #0a5863;
  margin-bottom: 8px;
}

.vialem-job-fit-limits-card__offers {
  display: grid;
  gap: 10px;
  margin-top: 14px;
}

.vialem-job-fit-offer.button {
  min-height: 44px;
  border-radius: 999px;
  border-color: #0c6270;
  color: #0c6270;
  background: #ffffff;
}

.vialem-job-fit__body {
  padding: 8px 30px 30px;
}

.vialem-job-fit__empty {
  padding: 22px;
}

.vialem-job-fit-results {
  display: grid;
  gap: 18px;
}

.vialem-job-fit-results__hero {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  padding: 24px;
  background: linear-gradient(135deg, #f4fbfd 0%, #ffffff 62%);
}

.vialem-job-fit-results__hero h4 {
  margin: 10px 0 10px;
  color: #0a5863;
  font-size: 1.6rem;
}

.vialem-job-fit-summary-points {
  display: grid;
  gap: 10px;
  margin: 10px 0 0 18px;
  padding: 0;
}

.vialem-job-fit-summary-points li {
  color: #24363c;
  line-height: 1.6;
}

.vialem-job-fit-summary-points li::marker {
  color: #0c6270;
}

.vialem-job-fit-summary-points strong,
.vialem-job-fit-block li strong {
  color: #0a5863;
  font-weight: 900;
}

.vialem-job-fit-summary-points em,
.vialem-job-fit-block li em {
  color: #31505b;
  font-style: italic;
}

.vialem-job-fit-summary-points--hero {
  max-width: 920px;
}

.vialem-job-fit-results__scores {
  display: grid;
  gap: 12px;
  min-width: 240px;
}

.vialem-job-fit-results__scores div {
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: flex-end;
  text-align: right;
  color: #31505b;
  font-weight: 700;
}

.vialem-job-fit-score {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 92px;
  padding: 8px 14px;
  border-radius: 999px;
  font-weight: 900;
}

.vialem-job-fit-score--high {
  background: #e9f7f0;
  color: #1d6f4f;
}

.vialem-job-fit-score--medium {
  background: #fff4df;
  color: #946300;
}

.vialem-job-fit-score--low {
  background: #fde9e9;
  color: #9b2f2f;
}

.vialem-job-fit-results__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.vialem-job-fit-gate {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 18px 22px;
  border-radius: 18px;
  border: 1px solid #dce7e6;
  background: #f8fcfc;
}

.vialem-job-fit-gate--strong {
  border-color: #b8e0c8;
  background: #edf8f1;
}

.vialem-job-fit-gate--bridge {
  border-color: #ecd39c;
  background: #fff9ec;
}

.vialem-job-fit-gate--weak {
  border-color: #efb6b6;
  background: #fff3f3;
}

.vialem-job-fit-gate__icon {
  width: 38px;
  height: 38px;
  object-fit: contain;
  flex: 0 0 38px;
}

.vialem-job-fit-gate__content {
  min-width: 0;
}

.vialem-job-fit-gate__label {
  font-weight: 800;
  color: #0a5863;
}

.vialem-job-fit-gate--strong .vialem-job-fit-gate__label {
  color: #1d6f4f;
}

.vialem-job-fit-gate--bridge .vialem-job-fit-gate__label {
  color: #946300;
}

.vialem-job-fit-gate--weak .vialem-job-fit-gate__label {
  color: #9b2f2f;
}

.vialem-job-fit-gate__message {
  margin-top: 8px;
  line-height: 1.6;
  color: #294048;
}

.vialem-job-fit-block {
  padding: 22px;
}

.vialem-job-fit-block .vialem-job-fit-block {
  margin-top: 18px;
  padding: 22px 24px;
  border-radius: 18px;
  box-shadow: none;
}

.vialem-job-fit-block--success {
  border-color: #b8e0c8;
  background: #f1faf4;
}

.vialem-job-fit-block--warning {
  border-color: #ecd39c;
  background: #fff9ec;
}

.vialem-job-fit-block--error {
  border-color: #efb6b6;
  background: #fff3f3;
}

.vialem-job-fit-block--info {
  border-color: #b9dbe4;
  background: #f4fbfd;
}

.vialem-job-fit-block--wide {
  grid-column: 1 / -1;
}

.vialem-job-fit-apply-strategy {
  background: linear-gradient(135deg, #f4fbfd 0%, #ffffff 68%);
  border-color: #c8dde4;
  padding: 26px;
}

.vialem-job-fit-apply-strategy__header {
  max-width: 980px;
  margin-bottom: 20px;
}

.vialem-job-fit-apply-strategy__header h5 {
  margin-bottom: 10px;
}

.vialem-job-fit-apply-strategy__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  align-items: stretch;
}

.vialem-job-fit-apply-strategy__grid > .vialem-job-fit-block {
  margin-top: 0;
  min-height: 100%;
}

.vialem-job-fit-feedback {
  padding: 24px;
  border: 1px solid #d6e4df;
  border-radius: 22px;
  background:
    linear-gradient(135deg, rgba(239, 248, 246, 0.92) 0%, rgba(255, 255, 255, 0.98) 58%, rgba(255, 249, 236, 0.62) 100%);
  box-shadow: 0 14px 30px rgba(12, 85, 113, 0.05);
}

.vialem-job-fit-feedback__header {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 18px;
}

.vialem-job-fit-feedback__eyebrow {
  margin-bottom: 8px;
  color: #0c6270;
  font-size: 0.8rem;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.vialem-job-fit-feedback h5 {
  margin: 0 0 8px;
  color: #0a5863;
  font-size: 1.32rem;
}

.vialem-job-fit-feedback h6 {
  margin: 0 0 10px;
  color: #0a5863;
  font-size: 0.92rem;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.vialem-job-fit-feedback__header p,
.vialem-job-fit-feedback-result__hero p,
.vialem-job-fit-feedback-result__next p,
.vialem-job-fit-feedback__empty {
  margin: 0;
  color: #31505b;
  font-size: 0.98rem;
  line-height: 1.58;
}

.vialem-job-fit-feedback__form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.vialem-job-fit-feedback__form label {
  display: grid;
  gap: 9px;
  margin: 0;
}

.vialem-job-fit-feedback__form span {
  color: #0e5156;
  font-weight: 800;
}

.vialem-job-fit-feedback__form textarea {
  width: 100%;
  min-height: 150px;
  padding: 14px 16px;
  border: 1px solid #b8d3cc;
  border-radius: 16px;
  background: #fbfdfd;
  color: #23343a;
  font-size: 0.98rem;
  line-height: 1.55;
}

.vialem-job-fit-feedback__form textarea:focus {
  border-color: #0c6270;
  box-shadow: 0 0 0 2px rgba(12, 98, 112, 0.1);
  outline: none;
}

.vialem-job-fit-feedback__actions {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-top: 16px;
}

.vialem-job-fit-feedback__analyze.button {
  min-height: 44px;
  padding: 0 20px;
  border-radius: 999px;
  background: #0c6270;
  border-color: #0c6270;
  color: #ffffff;
  font-weight: 900;
}

.vialem-job-fit-feedback__status {
  min-height: 1.5em;
  color: #31505b;
  font-size: 0.95rem;
  line-height: 1.5;
}

.vialem-job-fit-feedback__status.is-error {
  color: #9b2f2f;
}

.vialem-job-fit-feedback__status.is-success {
  color: #1d6f4f;
}

.vialem-job-fit-feedback__result {
  margin-top: 18px;
}

.vialem-job-fit-feedback__empty {
  padding: 16px 18px;
  border: 1px dashed #b8d3cc;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.72);
}

.vialem-job-fit-feedback-result {
  display: grid;
  gap: 14px;
}

.vialem-job-fit-feedback-result__hero {
  padding: 16px 18px;
  border: 1px solid #d6e4df;
  border-radius: 16px;
  background: #ffffff;
}

.vialem-job-fit-feedback-result__hero--actionable {
  border-color: #b8e0c8;
  background: #f1faf4;
}

.vialem-job-fit-feedback-result__hero--mixed {
  border-color: #ecd39c;
  background: #fff9ec;
}

.vialem-job-fit-feedback-result__hero--generic {
  border-color: #cddbe0;
  background: #f7fafb;
}

.vialem-job-fit-feedback-result__badge {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  margin-bottom: 10px;
  padding: 6px 12px;
  border-radius: 999px;
  background: #0c6270;
  color: #ffffff;
  font-size: 0.82rem;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.vialem-job-fit-feedback-result__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.vialem-job-fit-feedback-result__card,
.vialem-job-fit-feedback-result__next {
  padding: 16px 18px;
  border: 1px solid #d6e4df;
  border-radius: 16px;
  background: #ffffff;
}

.vialem-job-fit-feedback-result__card--success {
  border-color: #b8e0c8;
  background: #f4fbf6;
}

.vialem-job-fit-feedback-result__card--warning {
  border-color: #ecd39c;
  background: #fffaf0;
}

.vialem-job-fit-feedback-result__card--error {
  border-color: #efb6b6;
  background: #fff6f6;
}

.vialem-job-fit-feedback-result__card ul,
.vialem-job-fit-feedback-result__next ul {
  display: grid;
  gap: 9px;
  margin: 0 0 0 20px;
  padding: 0;
}

.vialem-job-fit-feedback-result__next p + ul {
  margin-top: 10px;
}

.vialem-job-fit-feedback-result__card li,
.vialem-job-fit-feedback-result__next li {
  color: #24363c;
  line-height: 1.5;
}

.vialem-job-fit-feedback-result__next {
  border-color: #b9dbe4;
  background: #f4fbfd;
}

.vialem-job-fit-block__header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
}

.vialem-job-fit-block__icon {
  width: 30px;
  height: 30px;
  object-fit: contain;
  flex: 0 0 30px;
}

.vialem-job-fit-block__header h5 {
  margin: 0;
}

.vialem-job-fit-block--success > .vialem-job-fit-block__header h5 {
  color: #1d6f4f;
}

.vialem-job-fit-block--warning > .vialem-job-fit-block__header h5 {
  color: #946300;
}

.vialem-job-fit-block--error > .vialem-job-fit-block__header h5 {
  color: #9b2f2f;
}

.vialem-job-fit-block--info > .vialem-job-fit-block__header h5 {
  color: #0c6270;
}

.vialem-job-fit-block ul {
  margin: 0 0 0 42px;
  padding: 0;
  display: grid;
  gap: 11px;
}

.vialem-job-fit-block li {
  color: #24363c;
  line-height: 1.55;
}

.vialem-job-fit-block--success li::marker {
  color: #1d6f4f;
}

.vialem-job-fit-block--warning li::marker {
  color: #946300;
}

.vialem-job-fit-block--error li::marker {
  color: #9b2f2f;
}

.vialem-job-fit-block--info li::marker {
  color: #0c6270;
}

@media (max-width: 980px) {
  .vialem-job-fit__panel,
  .vialem-job-fit-results__grid {
    grid-template-columns: 1fr;
  }

  .vialem-job-fit-apply-strategy__grid {
    grid-template-columns: 1fr;
  }

  .vialem-job-fit-feedback__form,
  .vialem-job-fit-feedback-result__grid {
    grid-template-columns: 1fr;
  }

  .vialem-job-fit-results__hero {
    flex-direction: column;
  }

  .vialem-job-fit-results__scores div,
  .vialem-job-fit__meta-wrap {
    align-items: flex-start;
    text-align: left;
    justify-content: flex-start;
  }
}

@media (max-width: 720px) {
  .vialem-job-fit__header,
  .vialem-job-fit__panel,
  .vialem-job-fit__body {
    padding-left: 18px;
    padding-right: 18px;
  }

  .vialem-job-fit__header,
  .vialem-job-fit__intake-header,
  .vialem-job-fit__controls {
    flex-direction: column;
  }

  .vialem-job-fit__controls .button,
  .vialem-job-fit__upload-button,
  .vialem-job-fit-feedback__analyze.button {
    width: 100%;
    justify-content: center;
  }

  .vialem-job-fit-feedback__actions {
    align-items: stretch;
    flex-direction: column;
  }

  .vialem-job-fit-limits-card__stats {
    grid-template-columns: 1fr;
  }
}

/* 2026 backend normalization for the Job Fit workspace. */
.vialem-job-fit {
  --vlm-jobfit-ink: #073f44;
  --vlm-jobfit-teal: #0d7c78;
  --vlm-jobfit-mint: #4fb8a4;
  --vlm-jobfit-gold: #e8b83d;
  --vlm-jobfit-line: #d8e5df;
  --vlm-jobfit-muted: #536a6d;
  --vlm-jobfit-soft: #e8f4f1;
  border-color: var(--vlm-jobfit-line) !important;
  border-radius: 8px !important;
  color: var(--vlm-jobfit-ink);
  font-family: var(--vl-font-body, Inter, "Segoe UI", Arial, sans-serif);
}

.vialem-job-fit h1,
.vialem-job-fit h2,
.vialem-job-fit h3,
.vialem-job-fit h4 {
  color: var(--vlm-jobfit-ink) !important;
  font-family: var(--vl-font-display, "Space Grotesk", Inter, "Segoe UI", Arial, sans-serif);
  letter-spacing: 0;
}

.vialem-job-fit__panel,
.vialem-job-fit__body,
.vialem-job-fit__upload,
.vialem-job-fit__result,
.vialem-job-fit-results__hero,
.vialem-job-fit-results__card,
.vialem-job-fit-feedback__panel,
.vialem-job-fit-limits-card {
  border-color: var(--vlm-jobfit-line) !important;
  border-radius: 8px !important;
  box-shadow: 0 16px 42px rgba(7, 63, 68, .1);
}

.vialem-job-fit .button-primary,
.vialem-job-fit button.button-primary,
.vialem-job-fit-feedback__analyze.button {
  border-color: var(--vlm-jobfit-gold) !important;
  background: var(--vlm-jobfit-gold) !important;
  color: #12383a !important;
  box-shadow: 0 10px 24px rgba(232, 184, 61, .2) !important;
}
