/**
 * @file
 * Styles for the Quote Request webform (quote_request).
 *
 * Design reference: /var/www/docs/design/Human-Certified AI Translation.html
 * Section: .finalcta > .contact-form
 *
 * IMPORTANT: Drupal webform renders form items as direct children of <form>,
 * there is NO .webform-elements wrapper div. The grid must be applied to the
 * <form> element itself.
 */
/* =========================================================================
   Design tokens (scoped to the webform wrapper)
   ========================================================================= */
.webform-submission-quote-request-form {
  --al-navy: #003050;
  --al-navy-900: #001f36;
  --al-navy-800: #002942;
  --al-navy-700: #003a60;
  --al-navy-600: #1e4a6e;
  --al-navy-500: #4a6b87;
  --al-navy-300: #98add3;
  --al-navy-100: #e4ecf3;
  --al-navy-50: #f3f6fa;
  --al-orange: #e09030;
  --al-orange-700: #b9701a;
  --al-orange-600: #cd7e22;
  --al-orange-300: #f3c483;
  --al-orange-100: #fbecd5;
  --al-orange-50: #fff7eb;
  --al-white: #ffffff;
  --al-off-white: #f6f7f8;
  --al-paper: #fbfcfd;
  --al-gray-50: #f6f7f8;
  --al-gray-100: #ebeef2;
  --al-gray-200: #d9dee4;
  --al-gray-300: #b8c0ca;
  --al-gray-400: #8b94a1;
  --al-gray-500: #5e6776;
  --font-sans: 'Open Sans', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --font-display: 'Montserrat', 'Open Sans', system-ui, sans-serif;
  --radius-xs: 2px;
  --radius-sm: 4px;
  --radius-md: 6px;
  --radius-lg: 10px;
  --radius-xl: 14px;
  --radius-2xl: 20px;
  --radius-pill: 999px;
  --shadow-focus: 0 0 0 3px rgba(224, 144, 48, 0.35);
  --status-error: #b53127;
  --tracking-caps: 0.08em;
  --tracking-wide: 0.02em;
  --ease-out: cubic-bezier(0.16, 0.84, 0.44, 1);
  --dur-1: 120ms;
  --dur-2: 200ms;
}
/* =========================================================================
   FORM CARD + GRID CONTAINER
   The <form> is both the styled card and the CSS grid container.
   ========================================================================= */
.webform-submission-quote-request-form {
  background: var(--al-paper);
  border-radius: var(--radius-2xl);
  padding: 32px;
  box-shadow: 0 24px 60px rgba(0, 16, 32, 0.32), 0 4px 14px rgba(0, 16, 32, 0.18);
  position: relative;
  color: var(--al-navy);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.webform-submission-quote-request-form fieldset {
  border: 0;
  padding: 0;
  margin: 0;
}
/* =========================================================================
   FORM ITEMS
   ========================================================================= */
.webform-submission-quote-request-form .js-form-item,
.webform-submission-quote-request-form .form-item {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin: 0 !important;
}
/* =========================================================================
   FULL-WIDTH GRID ITEMS
   ========================================================================= */
.webform-submission-quote-request-form .js-form-type-textarea,
.webform-submission-quote-request-form .js-form-type-managed-file,
.webform-submission-quote-request-form .captcha,
.webform-submission-quote-request-form .form-actions,
.webform-submission-quote-request-form .webform-actions {
  grid-column: 1 / -1;
}
/* =========================================================================
   HIDDEN FIELDS — not visible but still in the DOM
   ========================================================================= */
.webform-submission-quote-request-form .js-form-type-webform-computed-twig {
  display: none !important;
}
.webform-submission-quote-request-form .js-form-item-phone.js-form-item,
.webform-submission-quote-request-form .form-item-phone.js-form-item,
.webform-submission-quote-request-form [data-drupal-selector="edit-phone-wrapper"].js-form-item,
.webform-submission-quote-request-form [data-drupal-selector="edit-phone"].js-form-item,
.webform-submission-quote-request-form .js-form-item-phone.form-item,
.webform-submission-quote-request-form .form-item-phone.form-item,
.webform-submission-quote-request-form [data-drupal-selector="edit-phone-wrapper"].form-item,
.webform-submission-quote-request-form [data-drupal-selector="edit-phone"].form-item {
  display: none !important;
}
/* =========================================================================
   LABELS
   ========================================================================= */
.webform-submission-quote-request-form label:not(.visually-hidden):not([for^="edit-captcha"]),
.webform-submission-quote-request-form .js-form-required,
.webform-submission-quote-request-form .form-required {
  font-family: var(--font-display) !important;
  font-weight: 700 !important;
  font-size: 11px !important;
  letter-spacing: var(--tracking-caps) !important;
  text-transform: uppercase !important;
  color: var(--al-navy) !important;
}
.webform-submission-quote-request-form .form-required::after {
  display: inline;
  content: '*';
  color: var(--al-orange);
  margin-left: 2px;
  font-size: 11px;
}
/* =========================================================================
   INPUTS / SELECTS / TEXTAREAS
   ========================================================================= */
.webform-submission-quote-request-form input[type="text"],
.webform-submission-quote-request-form input[type="email"],
.webform-submission-quote-request-form input[type="tel"],
.webform-submission-quote-request-form select,
.webform-submission-quote-request-form textarea {
  width: 100%;
  max-width: 100%;
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.5;
  color: var(--al-navy);
  background: #fff;
  padding: 12px 14px;
  border: 1px solid var(--al-gray-200);
  border-radius: var(--radius-md);
  outline: none;
  box-shadow: none;
  transition: border-color var(--dur-1) var(--ease-out), box-shadow var(--dur-1) var(--ease-out);
}
.webform-submission-quote-request-form input::placeholder,
.webform-submission-quote-request-form textarea::placeholder {
  color: var(--al-gray-400);
}
.webform-submission-quote-request-form input:focus,
.webform-submission-quote-request-form select:focus,
.webform-submission-quote-request-form textarea:focus {
  border-color: var(--al-orange);
  box-shadow: var(--shadow-focus);
}
.webform-submission-quote-request-form textarea {
  resize: vertical;
  min-height: 120px;
  font-family: var(--font-sans);
  line-height: 1.5;
}
/* =========================================================================
   SELECT — custom chevron
   ========================================================================= */
.webform-submission-quote-request-form select {
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none' stroke='%231e4a6e' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='1 1.5 6 6.5 11 1.5'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 36px;
}
/* =========================================================================
   FILE UPLOAD — styled as dropzone
   ========================================================================= */
.webform-submission-quote-request-form {
  /* --- Enhanced dropzone: when #file_placeholder is rendered --- */
  /* When placeholder exists, hide native elements and make dropzone the overlay trigger */
  /* When placeholder exists, remove the base dropzone styling from wrapper */
}
.webform-submission-quote-request-form .js-form-type-managed-file > label:not(.visually-hidden) {
  font-family: var(--font-display) !important;
  font-weight: 700 !important;
  font-size: 11px !important;
  letter-spacing: var(--tracking-caps) !important;
  text-transform: uppercase !important;
  color: var(--al-navy) !important;
  margin-bottom: 6px;
}
.webform-submission-quote-request-form .js-form-managed-file {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 14px 16px;
  border: 1px dashed var(--al-gray-300);
  border-radius: var(--radius-md);
  background: var(--al-navy-50);
  cursor: pointer;
  transition: border-color var(--dur-1) var(--ease-out), background var(--dur-1) var(--ease-out);
}
.webform-submission-quote-request-form .js-form-managed-file:hover {
  border-color: var(--al-orange);
  background: var(--al-orange-50);
}
.webform-submission-quote-request-form .js-form-managed-file input[type="file"] {
  font-family: var(--font-sans);
  font-size: 14px;
  color: var(--al-navy);
  cursor: pointer;
}
.webform-submission-quote-request-form .js-form-managed-file .button,
.webform-submission-quote-request-form .js-form-managed-file .form-submit:not(.webform-button--submit) {
  background: var(--al-navy);
  color: #fff;
  border: 0;
  padding: 8px 16px;
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: 13px;
  border-radius: var(--radius-md);
  cursor: pointer;
}
.webform-submission-quote-request-form .js-form-managed-file .description,
.webform-submission-quote-request-form .js-form-managed-file .form-managed-file__size-info {
  flex-basis: 100%;
  font-family: var(--font-sans);
  font-size: 12px;
  color: var(--al-gray-500);
  line-height: 1.4;
}
.webform-submission-quote-request-form .js-form-managed-file .file {
  flex-basis: 100%;
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-sans);
  font-size: 13.5px;
  color: var(--al-navy);
  background: var(--al-navy-50);
  border: 1px solid var(--al-navy-100);
  border-radius: var(--radius-sm);
  padding: 7px 10px;
  margin-top: 6px;
}
.webform-submission-quote-request-form .webform-managed-file-placeholder {
  display: grid;
  grid-template-columns: 38px 1fr;
  grid-template-rows: auto auto;
  gap: 2px 12px;
  align-items: center;
  width: 100%;
  padding: 14px 16px;
  border: 1px dashed var(--al-gray-300);
  border-radius: var(--radius-md);
  background: var(--al-navy-50);
  cursor: pointer;
  transition: border-color var(--dur-1) var(--ease-out), background var(--dur-1) var(--ease-out);
}
.webform-submission-quote-request-form .webform-managed-file-placeholder:hover {
  border-color: var(--al-orange);
  background: var(--al-orange-50);
}
.webform-submission-quote-request-form .webform-managed-file-placeholder::before {
  content: '';
  grid-column: 1;
  grid-row: 1 / 3;
  align-self: center;
  width: 38px;
  height: 38px;
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--al-navy-100) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23003050' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4'/%3E%3Cpolyline points='17 8 12 3 7 8'/%3E%3Cline x1='12' y1='3' x2='12' y2='15'/%3E%3C/svg%3E") no-repeat center center;
}
.webform-submission-quote-request-form .webform-managed-file-placeholder b {
  grid-column: 2;
  grid-row: 1;
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: 14.5px;
  color: var(--al-navy);
}
.webform-submission-quote-request-form .webform-managed-file-placeholder b u {
  color: var(--al-orange);
  text-decoration: none;
  border-bottom: 1.5px solid currentColor;
}
.webform-submission-quote-request-form .webform-managed-file-placeholder .dropzone-hint {
  grid-column: 2;
  grid-row: 2;
  font-family: var(--font-sans);
  font-size: 12.5px;
  color: var(--al-gray-500);
  line-height: 1.4;
}
.webform-submission-quote-request-form .webform-managed-file-placeholder ~ input[type="file"] {
  position: absolute !important;
  width: 100% !important;
  height: 100% !important;
  top: 0 !important;
  left: 0 !important;
  opacity: 0 !important;
  cursor: pointer !important;
  z-index: 2 !important;
}
.webform-submission-quote-request-form .webform-managed-file-placeholder ~ .button,
.webform-submission-quote-request-form .webform-managed-file-placeholder ~ .form-submit:not(.webform-button--submit) {
  display: none !important;
}
.webform-submission-quote-request-form .webform-managed-file-placeholder ~ .description,
.webform-submission-quote-request-form .webform-managed-file-placeholder ~ .form-managed-file__size-info {
  display: none !important;
}
.webform-submission-quote-request-form .js-form-managed-file:has(.webform-managed-file-placeholder) {
  border: 0;
  padding: 0;
  background: transparent;
}
.webform-submission-quote-request-form .js-form-managed-file:has(.webform-managed-file-placeholder):hover {
  background: transparent;
}
.webform-submission-quote-request-form .js-form-type-managed-file > .description,
.webform-submission-quote-request-form .js-form-type-managed-file > .webform-element-description {
  display: none;
}
/* =========================================================================
   CAPTCHA
   ========================================================================= */
.webform-submission-quote-request-form .captcha {
  grid-column: 1 / -1;
  margin-top: 6px;
}
.webform-submission-quote-request-form .g-recaptcha {
  margin: 0 auto;
}
/* =========================================================================
   DESCRIPTION / HINT TEXT
   ========================================================================= */
.webform-submission-quote-request-form .description,
.webform-submission-quote-request-form .webform-element-description {
  font-size: 12px;
  color: var(--al-gray-500);
  line-height: 1.5;
  margin: 4px 0 0;
}
/* =========================================================================
   ACTIONS
   ========================================================================= */
.webform-submission-quote-request-form .form-actions,
.webform-submission-quote-request-form .webform-actions {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  margin-top: 4px;
}
.webform-submission-quote-request-form .webform-button--submit,
.webform-submission-quote-request-form .form-actions .form-submit,
.webform-submission-quote-request-form input[type="submit"].webform-button--submit,
.webform-submission-quote-request-form input[type="submit"].button.webform-button--submit {
  background: #013753;
  color: #fff;
  border: 0;
  padding: 14px 36px;
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 15px;
  border-radius: var(--radius-md);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  transition: background var(--dur-1) var(--ease-out), transform var(--dur-1) var(--ease-out);
}
.webform-submission-quote-request-form .webform-button--submit:hover,
.webform-submission-quote-request-form .form-actions .form-submit:hover,
.webform-submission-quote-request-form input[type="submit"].webform-button--submit:hover,
.webform-submission-quote-request-form input[type="submit"].button.webform-button--submit:hover {
  background: #002438;
}
.webform-submission-quote-request-form .webform-button--submit:active,
.webform-submission-quote-request-form .form-actions .form-submit:active,
.webform-submission-quote-request-form input[type="submit"].webform-button--submit:active,
.webform-submission-quote-request-form input[type="submit"].button.webform-button--submit:active {
  transform: translateY(1px);
}
.webform-submission-quote-request-form .webform-button--submit:focus-visible,
.webform-submission-quote-request-form .form-actions .form-submit:focus-visible,
.webform-submission-quote-request-form input[type="submit"].webform-button--submit:focus-visible,
.webform-submission-quote-request-form input[type="submit"].button.webform-button--submit:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
}
/* =========================================================================
   ERROR STATES
   ========================================================================= */
.webform-submission-quote-request-form .form-item--error-message strong {
  font-size: 12px;
  color: var(--status-error);
  font-weight: 400;
}
.webform-submission-quote-request-form input.error,
.webform-submission-quote-request-form select.error,
.webform-submission-quote-request-form textarea.error {
  border-color: var(--status-error) !important;
}
/* =========================================================================
   CONFIRMATION / SUCCESS
   ========================================================================= */
.webform-confirmation {
  text-align: center;
  padding: 24px 8px;
}
.webform-confirmation .webform-confirmation__message {
  font-family: var(--font-display);
  color: var(--al-navy);
  font-size: 22px;
  font-weight: 700;
  margin: 0 0 8px;
}
.webform-confirmation .webform-confirmation__back {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin-top: 16px;
  padding: 14px 28px;
  background: var(--al-orange);
  color: #fff;
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 15px;
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: background var(--dur-2) var(--ease-out);
}
.webform-confirmation .webform-confirmation__back:hover {
  background: var(--al-orange-700);
  color: #fff;
  text-decoration: none;
}
/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media (max-width: 640px) {
  .webform-submission-quote-request-form {
    padding: 24px 20px;
    grid-template-columns: 1fr;
  }
}
@media (max-width: 560px) {
  .webform-submission-quote-request-form .form-actions,
  .webform-submission-quote-request-form .webform-actions {
    flex-direction: column;
    align-items: center;
  }
}
