/*!*******************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ../node_modules/css-loader/dist/cjs.js??clonedRuleSet-2.use[1]!../node_modules/vue-loader/dist/stylePostLoader.js!../node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-2.use[2]!../node_modules/sass-loader/dist/cjs.js??clonedRuleSet-2.use[3]!../node_modules/vue-loader/dist/index.js??ruleSet[0].use!./components/async/contact-us/contact-us.vue?vue&type=style&index=0&id=719c395e&lang=scss ***!
  \*******************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
/**
 * Config: Configuration
 * -----------------------------------------------------------------------------
 * Master import that's included in all Vue components.
 * - No code should be output from the configuration files as they're reused.
 *
 */
/**
 * Config: SASS variables
 * -----------------------------------------------------------------------------
 * Automatically generated by `design` command, do not edit.
 *
 */
/**
 * Base: Classes
 * -----------------------------------------------------------------------------
 * Automatically generated by `design` command, do not edit.
 *
 */
/**
 * Config: Mixins
 * -----------------------------------------------------------------------------
 * Global and reusable utility functions to reduce common styling.
 * - Add in alphabetical order.
 *
 */
/**
 * Resets form buttons to appear as a standard text link.
 */
/**
 * Sets container properties.
 */
/**
 * Reset container properties.
 */
/**
 * Sets custom scrollbar on element.
 * - Add to element with overflow.
 */
/**
 * Default focus styling for browsers.
 */
/**
 * Resets input elements.
 */
/**
 * Resets list elements to appear as a stacked text links.
 */
/**
 * Loading/skeleton animation.
 */
/**
 * Reset text style to default.
 * - Used for preview bar and Storybook styles.
 */
/**
 * Outputs list of transition properties.
 *
 * Accepts:
 * - $transitions: {String} List of transition properties to set
 *
 * Usage:
 * .selector {
 *   @include transition(width, height var(--timing-quick);
 * }
 */
/**
 * Returns the transition properties in the correct format.
 * This function is used by @mixin transition($transitions...).
 */
/**
 * Hide element but make it accessible to screen readers.
 */
/**
 * Reverse the properties applied by @mixin visually-hidden.
 * @param {String} $position - Positioning method for element.
 */
/**
 * Button background color swipe on hover.
 * @param {String} $background - Background colour for swipe.
 */
/**
 * Styles: Contact us (contact-us)
 * -----------------------------------------------------------------------------
 * Base styles for contact us component.
 *
 */
.contact-us {
  margin: var(--spacing-m);
  /**
   * Media queries.
   */
}
.contact-us.critical-component-hide {
  display: block;
}
.contact-us.critical-component-clear {
  opacity: 1;
}
.contact-us__hero {
  display: flex;
  flex-direction: column-reverse;
}
.contact-us__hero-content, .contact-us__hero-image {
  flex: 1;
}
.contact-us__hero-content {
  align-items: center;
  display: flex;
}
.contact-us__hero-content .grid {
  width: 100%;
}
.contact-us__contact {
  display: flex;
  gap: var(--spacing-xs);
}
.contact-us__contact p, .contact-us__contact a {
  font-size: var(--font-size-3);
}
.contact-us__content-wrapper .button {
  max-width: 360px;
}
.contact-us__content p:not(:last-child) {
  margin-block-end: var(--spacing-m);
}
.contact-us .contact-icon {
  height: 24px;
  width: 24px;
}
.contact-us a {
  font-family: var(--font-family-ft-aktual);
  font-size: var(--font-size-3);
  font-weight: var(--font-weight-ft-aktual-2);
  letter-spacing: var(--letter-spacing-1);
  line-height: var(--line-height-1);
  text-decoration: none;
  text-indent: var(--text-indent-0);
  text-transform: none;
  padding: 0;
  position: relative;
  transition: opacity var(--timing-normal) ease-in-out;
}
.contact-us a:hover {
  opacity: 0.7;
}
.contact-us a:hover::after {
  opacity: 0.7;
}
.contact-us a::after {
  border-bottom: 1px solid var(--color-neutral-1);
  bottom: 0;
  content: "";
  left: 0;
  opacity: 1;
  position: absolute;
  transition: opacity var(--timing-normal) ease-in-out;
  width: 100%;
}
@media (min-width: 64em) {
.contact-us__hero {
    flex-direction: row;
}
}

/**
 * Styles: Contact form modal
 * -----------------------------------------------------------------------------
 * Base styles for contact us modal.
 *
 */
.contact-form {
  bottom: 0;
  height: 80%;
  top: auto;
}
.contact-form__container {
  max-width: 692px;
  width: 100%;
}
.contact-form__cta-wrapper {
  align-items: center;
  display: flex;
  flex-direction: column;
}
.contact-form__cta-wrapper .submit,
.contact-form__cta-wrapper .button {
  width: 100%;
}
.contact-form__inquiry, .contact-form__countries {
  position: relative;
}
.contact-form__inquiry .icon, .contact-form__countries .icon {
  height: 4px;
  position: absolute;
  right: var(--spacing-l);
  top: calc(var(--spacing-2xl) + var(--spacing-3xs));
  width: auto;
}
.contact-form form .contact-form__field {
  border: 1px solid var(--color-neutral-1);
  border-radius: 24px;
  color: var(--color-neutral-1);
  padding: var(--spacing-xs) var(--spacing-m);
  width: 100%;
}
.contact-form form .contact-form__field::-moz-placeholder {
  color: var(--color-neutral-1);
}
.contact-form form .contact-form__field::placeholder {
  color: var(--color-neutral-1);
}
.contact-form form .contact-form__fieldtextarea {
  padding-block: var(--spacing-m);
}
.contact-form form .contact-form__field:hover {
  border-color: var(--color-neutral-2);
}
.contact-form form select::-moz-placeholder {
  color: var(--color-neutral-1);
}
.contact-form form select::placeholder {
  color: var(--color-neutral-1);
}
.contact-form .form-group {
  gap: var(--spacing-s);
}
.contact-form .form-group + .form-group {
  margin-block-start: 0;
}
@media (min-width: 64em) {
.contact-form {
    height: 100%;
}
.contact-form__names {
    display: flex;
    gap: var(--spacing-m);
}
.contact-form__names .first-name,
  .contact-form__names .last-name {
    flex: 1;
}
}
@media (max-width: 63.99em) {
.contact-form {
    height: 100%;
}
.contact-form__container {
    background-color: transparent;
    height: 100%;
    max-height: 600px;
    overflow: visible;
    overflow: initial;
    padding: 0;
}
.contact-form__header {
    padding: var(--spacing-m);
}
.contact-form__body {
    background-color: var(--color-neutral-5);
    height: 100%;
    overflow-y: auto;
    padding: var(--spacing-xl) var(--spacing-m);
}
.contact-form__close {
    background-color: var(--color-neutral-5);
    border-radius: 50%;
    position: fixed;
}
.contact-form__close-container {
    margin-inline-end: calc(var(--spacing-m) + var(--spacing-2xs));
}
.contact-form__cta-wrapper {
    padding-block-end: var(--spacing-xl);
}
}
