/* IPS custom styling for WP Job Openings listing + filters */
.awsm-job-wrap {
  width: 100%;
}
.awsm-job-wrap .ips-awsm-jobs__layout {
  display: flex;
  align-items: flex-start;
}

.awsm-filter-toggle {
  padding: 0 0 10px;
}

.awsm-job-wrap .ips-awsm-jobs__filters {
  display: none;
}

.awsm-job-wrap .ips-awsm-jobs__results {
  flex: 1 1 auto;
  min-width: 0;
  width: 100%;
}

/* Filter form */
.awsm-job-wrap .ips-awsm-jobs__filters .awsm-filter-wrap {
  margin: 0;
}
.awsm-job-wrap .ips-awsm-jobs__filters .awsm-filter-wrap form {
  display: block;
}
.awsm-job-wrap .ips-awsm-jobs__filters .awsm-filter-item-search,
.awsm-job-wrap .ips-awsm-jobs__filters .awsm-filter-wrap .awsm-filter-item {
  width: 100%;
  padding: 0 0 14px;
}
.awsm-job-wrap .ips-awsm-jobs__filters .awsm-filter-item-search .awsm-job-form-control,
.awsm-job-wrap .ips-awsm-jobs__filters .awsm-filter-wrap .awsm-job-form-control,
.awsm-job-wrap .ips-awsm-jobs__filters .awsm-filter-wrap select {
  width: 100%;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 8px;
  color: #e9eef5;
}
.awsm-job-wrap .ips-awsm-jobs__filters .awsm-filter-item-search .awsm-job-form-control::placeholder {
  color: rgba(233, 238, 245, 0.65);
}
.awsm-job-wrap .ips-awsm-jobs__filters .awsm-filter-item-search .awsm-job-search-icon-wrapper {
  filter: invert(1);
  opacity: 0.8;
}

/* List cards */
.awsm-job-wrap .awsm-lists {
  border: none;
}

.awsm-job-wrap .awsm-list-item .awsm-job-item {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: center;
  padding: 22px 22px;
  border-bottom: 1px solid #D7D8E0;
  margin-bottom: 14px;
  background: #fff;
  text-decoration: none !important;
}
.awsm-job-wrap .awsm-list-item .awsm-job-item:hover,
.awsm-job-wrap .awsm-list-item .awsm-job-item:focus {
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.08);
  border-color: rgba(17, 24, 39, 0.18);
}

.awsm-job-wrap .awsm-list-left-col,
.awsm-job-wrap .awsm-list-right-col {
  float: none;
  width: auto;
  text-align: left;
}

.awsm-job-wrap .ips-awsm-job-card__main {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.awsm-job-wrap .ips-awsm-job-card__meta {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  gap: 16px;
}

.awsm-job-wrap .awsm-list-item h2.awsm-job-post-title {
  margin: 0;
  font-size: 22px;
  line-height: 1.2;
  font-weight: 700;
  color: var(--dark-color);
}

.awsm-job-wrap .awsm-list-item .awsm-job-specification-wrapper {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 18px;
}
.awsm-job-wrap .awsm-list-item .awsm-job-specification-item {
  margin: 0;
  color: var(--dark-color);
}

/* Hide individual location and job type items when combined format is used */
.awsm-job-wrap .awsm-list-item .awsm-job-specification-item.awsm-job-specification-job-location,
.awsm-job-wrap .awsm-list-item .awsm-job-specification-item.awsm-job-specification-job-type {
  display: none;
}
.awsm-job-wrap .awsm-list-item .awsm-job-specification-item.awsm-job-specification-combined {
  display: flex;
  align-items: center;
  gap: 6px;
}

.awsm-job-wrap .ips-awsm-job-card__arrow {
  font-size: 22px;
  line-height: 1;
  color: var(--dark-color);
  align-self: center;
  flex-shrink: 0;
}

/* Responsive */
@media (max-width: 992px) {
  .awsm-job-wrap .ips-awsm-jobs__layout {
    flex-direction: column;
  }
  .awsm-job-wrap .ips-awsm-jobs__filters {
    width: 100%;
    flex-basis: auto;
  }
}

.awsm-application-submit-btn {
  padding: 0.75rem 1.25rem !important;
}

.awsm-application-submit-btn {
  padding: 0.75rem 1.25rem !important;
}

.awsm-application-submit-btn {
  padding: 0.75rem 1.25rem !important;
}

.awsm-application-submit-btn {
  padding: 0.75rem 1.25rem !important;
}

.awsm-filter-toggle {
  border-radius: none !important;
  margin: 0 0 10px 0 !important;
}

/* Job post content styling */
.awsm-job-content .awsm-job-entry-content p.has-x-large-font-size {
  font-family: var(--display-sm-bold-font-family);
  font-weight: var(--display-sm-bold-font-weight);
  font-size: var(--display-sm-bold-font-size);
  letter-spacing: var(--display-sm-bold-letter-spacing);
  line-height: var(--display-sm-bold-line-height);
  font-style: var(--display-sm-bold-font-style);
  color: var(--primary-color-900);
  margin-bottom: 1rem;
}

.awsm-job-content .awsm-job-entry-content p.has-large-font-size {
  font-family: var(--display-xs-bold-font-family);
  font-weight: var(--display-xs-bold-font-weight);
  font-size: var(--display-xs-bold-font-size);
  letter-spacing: var(--display-xs-bold-letter-spacing);
  line-height: var(--display-xs-bold-line-height);
  font-style: var(--display-xs-bold-font-style);
  color: var(--primary-color-900);
  margin-bottom: 1rem;
}

.awsm-job-content .awsm-job-entry-content p:not(.has-x-large-font-size):not(.has-large-font-size) {
  font-family: var(--text-md-regular-font-family);
  font-weight: var(--text-md-regular-font-weight);
  font-size: var(--text-md-regular-font-size);
  letter-spacing: var(--text-md-regular-letter-spacing);
  line-height: var(--text-md-regular-line-height);
  font-style: var(--text-md-regular-font-style);
  color: var(--dark-color);
  margin-bottom: 1rem;
}

/* Desktop styles */
@media screen and (min-width: 768px) {
  .awsm-job-content .awsm-job-entry-content p.has-x-large-font-size {
    font-family: var(--display-lg-extra-bold-font-family);
    font-weight: var(--display-lg-extra-bold-font-weight);
    font-size: var(--display-lg-extra-bold-font-size);
    letter-spacing: var(--display-lg-extra-bold-letter-spacing);
    line-height: var(--display-lg-extra-bold-line-height);
    font-style: var(--display-lg-extra-bold-font-style);
  }

  .awsm-job-content .awsm-job-entry-content p.has-large-font-size {
    font-family: var(--display-sm-bold-font-family);
    font-weight: var(--display-sm-bold-font-weight);
    font-size: var(--display-sm-bold-font-size);
    letter-spacing: var(--display-sm-bold-letter-spacing);
    line-height: var(--display-sm-bold-line-height);
    font-style: var(--display-sm-bold-font-style);
  }

  .awsm-job-content .awsm-job-entry-content p:not(.has-x-large-font-size):not(.has-large-font-size) {
    font-family: var(--text-lg-regular-font-family);
    font-weight: var(--text-lg-regular-font-weight);
    font-size: var(--text-lg-regular-font-size);
    letter-spacing: var(--text-lg-regular-letter-spacing);
    line-height: var(--text-lg-regular-line-height);
    font-style: var(--text-lg-regular-font-style);
  }
}

/* ---------------------------------------------------------
 * AWSM Job Openings – Custom upload box
 * Styles the CV/Resume upload input to match the modern UI
 * ------------------------------------------------------ */
.awsm-job-form .ips-file-upload-group {
  position: relative;
}

.awsm-job-form .ips-file-upload-wrapper {
  position: relative;
  margin-top: 8px;
}

.awsm-job-form .ips-file-upload-dropzone {
  border: 1px dashed #8A8CA6;
  background-color: white;
  background-color: white;
  background-color: white;
  padding: 28px 18px;
  text-align: center;
  cursor: pointer;
  transition:
    border-color 0.15s ease,
    background-color 0.15s ease,
    box-shadow 0.15s ease;
  color: var(--dark-color);
  color: var(--dark-color);
  color: var(--dark-color);
  font-family: var(--text-md-regular-font-family, system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif);
}

.awsm-job-form .ips-file-upload-dropzone .ips-file-upload-primary {
  display: block;
  font-weight: 600;
  font-size: 14px;
  margin-bottom: 4px;
}

.awsm-job-form .ips-file-upload-dropzone .ips-file-upload-secondary {
  display: block;
  font-size: 12px;
  color: #6B7280;
}

.awsm-job-form .ips-file-upload-dropzone.is-dragover {
  border-color: var(--primary-color-600, #4F46E5);
  background-color: #EEF2FF;
  box-shadow: 0 0 0 1px rgba(79, 70, 229, 0.35);
}

/* Native input: visually hidden but still accessible and clickable */
.awsm-job-form .ips-file-upload-input {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  cursor: pointer;
}

/* ---------------------------------------------------------
 * AWSM Job Openings – Custom form input styles
 * Minimalist underline design matching the design spec
 * ------------------------------------------------------ */

/* Form group spacing */
.awsm-job-form .awsm-job-form-group {
  margin-bottom: 22px;
}

.awsm-job-form .awsm-job-form-group:last-of-type {
  margin-bottom: 0;
}

/* Extra space between last form control and submit button */
.awsm-job-form .awsm-job-form-group:has(.awsm-application-submit-btn) {
  margin-top: 28px;
}

/* Labels: smaller than input value (text-sm on mobile, 14px on desktop) */
.awsm-job-form .awsm-job-form-group label {
  display: block;
  color: var(--dark-color, #111827);
  font-family: var(--text-md-regular-font-family);
  font-weight: 400;
  font-size: 14px;
  letter-spacing: 0;
  line-height: 1.35;
  font-style: normal;
}

/* 10px space between label and input (not for inline checkbox group) */
.awsm-job-form .awsm-job-form-group:not(.awsm-job-inline-group) label {
  margin-bottom: 10px;
}

@media screen and (min-width: 768px) {
  .awsm-job-form .awsm-job-form-group label {
    font-size: 14px;
  }
}

/* Error message text: smaller than input value, same as labels, red color only */
.awsm-job-form .awsm-job-form-group .awsm-job-form-error {
  font-family: var(--text-md-regular-font-family);
  font-weight: 400;
  font-size: 13px;
  letter-spacing: 0;
  line-height: 1.35;
  font-style: normal;
  color: rgba(229, 21, 32, 1);
}

@media screen and (min-width: 768px) {
  .awsm-job-form .awsm-job-form-group .awsm-job-form-error {
    font-size: 13px;
  }
}

/* Keep asterisk in label same color as label */
.awsm-job-form .awsm-job-form-group label .awsm-job-form-error {
  color: inherit;
}

/* Text, email, and tel inputs: text-md-regular on mobile, text-lg-regular on desktop */
/* Text, email, and tel inputs: text-md-regular on mobile, text-lg-regular on desktop */
.awsm-job-form .awsm-job-form-control[type="text"],
.awsm-job-form .awsm-job-form-control[type="email"],
.awsm-job-form .awsm-job-form-control[type="tel"] {
  margin: 0;
  width: 100%;
  padding: 12px;
  border-width: 1px;
  border-style: solid;
  border-color: rgba(211, 218, 228, 1);
  border-radius: 0;
  background-color: #EAF0F6;
  color: #212d3a;
  font-family: var(--text-md-regular-font-family);
  font-weight: var(--text-md-regular-font-weight);
  font-size: var(--text-md-regular-font-size);
  letter-spacing: var(--text-md-regular-letter-spacing);
  line-height: var(--text-md-regular-line-height);
  font-style: var(--text-md-regular-font-style);
  font-family: var(--text-md-regular-font-family);
  font-weight: var(--text-md-regular-font-weight);
  font-size: var(--text-md-regular-font-size);
  letter-spacing: var(--text-md-regular-letter-spacing);
  line-height: var(--text-md-regular-line-height);
  font-style: var(--text-md-regular-font-style);
  box-sizing: border-box;
  outline: none;
  transition: box-shadow 0.2s ease;
}

@media screen and (min-width: 768px) {
  .awsm-job-form .awsm-job-form-control[type="text"],
  .awsm-job-form .awsm-job-form-control[type="email"],
  .awsm-job-form .awsm-job-form-control[type="tel"] {
    font-family: var(--text-lg-regular-font-family);
    font-weight: var(--text-lg-regular-font-weight);
    font-size: var(--text-lg-regular-font-size);
    letter-spacing: var(--text-lg-regular-letter-spacing);
    line-height: var(--text-lg-regular-line-height);
    font-style: var(--text-lg-regular-font-style);
  }
}

@media screen and (min-width: 768px) {
  .awsm-job-form .awsm-job-form-control[type="text"],
  .awsm-job-form .awsm-job-form-control[type="email"],
  .awsm-job-form .awsm-job-form-control[type="tel"] {
    font-family: var(--text-lg-regular-font-family);
    font-weight: var(--text-lg-regular-font-weight);
    font-size: var(--text-lg-regular-font-size);
    letter-spacing: var(--text-lg-regular-letter-spacing);
    line-height: var(--text-lg-regular-line-height);
    font-style: var(--text-lg-regular-font-style);
  }
}

.awsm-job-form .awsm-job-form-control[type="text"]:focus,
.awsm-job-form .awsm-job-form-control[type="email"]:focus,
.awsm-job-form .awsm-job-form-control[type="tel"]:focus {
  border-color: rgba(211, 218, 228, 1);
  outline: none;
  box-shadow: 0 0 0 1px rgba(211, 218, 228, 1);
}

.awsm-job-form .awsm-job-form-control[type="text"]::placeholder,
.awsm-job-form .awsm-job-form-control[type="email"]::placeholder,
.awsm-job-form .awsm-job-form-control[type="tel"]::placeholder {
  color: rgba(138, 140, 166, 0.6);
  opacity: 1;
}

/* Textarea: text-md-regular on mobile, text-lg-regular on desktop */
/* Textarea: text-md-regular on mobile, text-lg-regular on desktop */
.awsm-job-form .awsm-job-form-control[type="textarea"],
.awsm-job-form textarea.awsm-job-form-control {
  margin: 0;
  width: 100%;
  min-height: 52px;
  padding: 12px;
  border-width: 1px;
  border-style: solid;
  border-color: rgba(211, 218, 228, 1);
  padding: 12px;
  border-width: 1px;
  border-style: solid;
  border-color: rgba(211, 218, 228, 1);
  padding: 12px;
  border-width: 1px;
  border-style: solid;
  border-color: rgba(211, 218, 228, 1);
  border-radius: 0;
  background-color: #EAF0F6;
  color: #212d3a;
  font-family: var(--text-md-regular-font-family);
  font-weight: var(--text-md-regular-font-weight);
  font-size: var(--text-md-regular-font-size);
  letter-spacing: var(--text-md-regular-letter-spacing);
  line-height: var(--text-md-regular-line-height);
  font-style: var(--text-md-regular-font-style);
  font-family: var(--text-md-regular-font-family);
  font-weight: var(--text-md-regular-font-weight);
  font-size: var(--text-md-regular-font-size);
  letter-spacing: var(--text-md-regular-letter-spacing);
  line-height: var(--text-md-regular-line-height);
  font-style: var(--text-md-regular-font-style);
  box-sizing: border-box;
  resize: vertical;
  outline: none;
  transition: box-shadow 0.2s ease;
}

@media screen and (min-width: 768px) {
  .awsm-job-form .awsm-job-form-control[type="textarea"],
  .awsm-job-form textarea.awsm-job-form-control {
    font-family: var(--text-lg-regular-font-family);
    font-weight: var(--text-lg-regular-font-weight);
    font-size: var(--text-lg-regular-font-size);
    letter-spacing: var(--text-lg-regular-letter-spacing);
    line-height: var(--text-lg-regular-line-height);
    font-style: var(--text-lg-regular-font-style);
  }
}

@media screen and (min-width: 768px) {
  .awsm-job-form .awsm-job-form-control[type="textarea"],
  .awsm-job-form textarea.awsm-job-form-control {
    font-family: var(--text-lg-regular-font-family);
    font-weight: var(--text-lg-regular-font-weight);
    font-size: var(--text-lg-regular-font-size);
    letter-spacing: var(--text-lg-regular-letter-spacing);
    line-height: var(--text-lg-regular-line-height);
    font-style: var(--text-lg-regular-font-style);
  }
}

.awsm-job-form .awsm-job-form-control[type="textarea"]:focus,
.awsm-job-form textarea.awsm-job-form-control:focus {
  border-color: rgba(211, 218, 228, 1);
  border-color: rgba(211, 218, 228, 1);
  border-color: rgba(211, 218, 228, 1);
  outline: none;
  box-shadow: 0 0 0 1px rgba(211, 218, 228, 1);
  box-shadow: 0 0 0 1px rgba(211, 218, 228, 1);
  box-shadow: 0 0 0 1px rgba(211, 218, 228, 1);
}

.awsm-job-form .awsm-job-form-control[type="textarea"]::placeholder,
.awsm-job-form textarea.awsm-job-form-control::placeholder {
  color: rgba(138, 140, 166, 0.6);
  opacity: 1;
}

/* Error states: only when error class is set (not on :invalid so fields are not red on first load) */
.awsm-job-form .awsm-job-form-control.awsm-job-form-error {
  border-color: rgba(229, 21, 32, 1);
}

/* Inline group (checkbox) – same line, label wraps with first line aligned to checkbox */
.awsm-job-form .awsm-job-inline-group {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-top: 10px;
}

.awsm-job-form .awsm-job-inline-group input[type="checkbox"] {
  margin: 0;
  margin-top: 2px; /* align first line of label with checkbox */
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  opacity: 1;
  border: 1.5px solid #8A8CA6;
  border-radius: 0px;
  box-sizing: border-box;
  appearance: none;
  -webkit-appearance: none;
  background: #fff;
  cursor: pointer;
  vertical-align: top;
}

.awsm-job-form .awsm-job-inline-group input[type="checkbox"]:hover {
  background: #D7D8E0;
}

.awsm-job-form .awsm-job-inline-group input[type="checkbox"]:checked {
  background: var(--secondary-color-700) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 10'%3E%3Cpath fill='none' stroke='%23fff' stroke-width='2' d='M1 5l3 3 7-7'/%3E%3C/svg%3E") center/10px 8px no-repeat;
  border-color: #8A8CA6;
}

.awsm-job-form .awsm-job-inline-group label {
  margin: 0;
  flex: 1;
  min-width: 0;
  display: block;
  cursor: pointer;
  line-height: 1.35;
}

/* Privacy policy label: underline the "here" link */
.awsm-job-form label[for="awsm_form_privacy_policy"] a,
.awsm-job-form label[for^="awsm_form_privacy_policy-"] a {
  text-decoration: underline;
}

/* File upload group - keep existing styles but adjust spacing */
.awsm-job-form .ips-file-upload-group {
  margin-bottom: 10px;
}

.awsm-job-form .ips-file-upload-group small {
  display: block;
  margin-top: 8px;
  font-size: 12px;
  color: rgba(138, 140, 166, 0.8);
}

/* Success/error message after form submit: add space above so it doesn't touch the Submit button */
.awsm-job-form-inner .awsm-application-message {
  margin-top: 1.5rem;
}