/*
  1. Use a more-intuitive box-sizing model.
*/
*,
*::before,
*::after {
  box-sizing: border-box;
}
/*
  2. Remove default margin
*/
* {
  margin: 0;
}
/*
  Typographic tweaks!
  3. Add accessible line-height
  4. Improve text rendering
*/
body {
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}
/*
  5. Improve media defaults
*/
img,
picture,
video,
canvas,
svg {
  display: block;
  max-width: 100%;
}
/*
  6. Remove built-in form typography styles
*/
input,
button,
textarea,
select {
  font: inherit;
}
/*
  7. Avoid text overflows
*/
p,
h1,
h2,
h3,
h4,
h5,
h6 {
  overflow-wrap: break-word;
}
/*
  8. Create a root stacking context
*/
#root,
#__next {
  isolation: isolate;
}

.poppins-thin {
  font-family: "Poppins", sans-serif;
  font-weight: 100;
  font-style: normal;
}

.poppins-extralight {
  font-family: "Poppins", sans-serif;
  font-weight: 200;
  font-style: normal;
}

.poppins-light {
  font-family: "Poppins", sans-serif;
  font-weight: 300;
  font-style: normal;
}

.poppins-regular {
  font-family: "Poppins", sans-serif;
  font-weight: 400;
  font-style: normal;
}

.poppins-medium {
  font-family: "Poppins", sans-serif;
  font-weight: 500;
  font-style: normal;
}

.poppins-semibold {
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  font-style: normal;
}

.poppins-bold {
  font-family: "Poppins", sans-serif;
  font-weight: 700;
  font-style: normal;
}

.poppins-extrabold {
  font-family: "Poppins", sans-serif;
  font-weight: 800;
  font-style: normal;
}

.poppins-black {
  font-family: "Poppins", sans-serif;
  font-weight: 900;
  font-style: normal;
}

.poppins-thin-italic {
  font-family: "Poppins", sans-serif;
  font-weight: 100;
  font-style: italic;
}

.poppins-extralight-italic {
  font-family: "Poppins", sans-serif;
  font-weight: 200;
  font-style: italic;
}

.poppins-light-italic {
  font-family: "Poppins", sans-serif;
  font-weight: 300;
  font-style: italic;
}

.poppins-regular-italic {
  font-family: "Poppins", sans-serif;
  font-weight: 400;
  font-style: italic;
}

.poppins-medium-italic {
  font-family: "Poppins", sans-serif;
  font-weight: 500;
  font-style: italic;
}

.poppins-semibold-italic {
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  font-style: italic;
}

.poppins-bold-italic {
  font-family: "Poppins", sans-serif;
  font-weight: 700;
  font-style: italic;
}

.poppins-extrabold-italic {
  font-family: "Poppins", sans-serif;
  font-weight: 800;
  font-style: italic;
}

.poppins-black-italic {
  font-family: "Poppins", sans-serif;
  font-weight: 900;
  font-style: italic;
}

:root {
  --white: #ffffff;
  --font-primary-strong-colour: #11181c;
  --font-primary-base-colour: #687076;
  --font-libre: "Libre Franklin", sans-serif;
  --font-circe: "Circe", sans-serif;
  --font-poppins: "Poppins", sans-serif;

  --faded-bg-colour: #fbfcfd;
  --border-default-colour: #c1c8cd;
  --border-danger-colour: #cd2b31;
  --pale-grey-colour: #eceef0;
  --danger-colour: #cd2b31;
  --danger-tint-colour: #ffefef;
  --danger-shade-colour: #381316;
  --success-colour: #18794e;
  --success-shade-colour: #153226;
  --success-tint-colour: #e9f9ee;
  --warning-shade-colour: #451e11;
  --warning-colour: #bd4b00;
  --warning-tint-colour: #fff1e7;
}

/* 1rem = 10px */
html {
  font-size: 62.5%;
  font-family: var(--font-poppins);
  color: var(--font-primary-strong-colour);
}

@font-face {
  font-family: circe;
  src: url("../fonts/Circe-Regular.woff") format("woff");
}

p {
  font-family: var(--font-poppins);
  font-size: 1.6rem;
  color: var(--font-primary-strong-colour);
  line-height: 2.4rem;
}

.circe {
  font-family: var(--font-circe);
}

.font-header {
  font-size: 2.03rem;
  font-family: var(--font-poppins);
  color: var(--header-colour);
  font-weight: 600;
}

.button {
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.8rem;
  line-height: 1.25;
  letter-spacing: 0.45px;
  outline: none;
  border: none;
  background: var(--primary-colour);
  color: white;
  padding: 0 2.4rem;
  height: 5.6rem;
  gap: 1.2rem;
  text-decoration: none;
  cursor: pointer;
  font-family: var(--font-libre);
}

.button:disabled {
  cursor: default;
}

.button.sm {
  height: 4rem;
}

.button img {
  width: 1.9rem;
  height: 1.9rem;
}

.button.secondary {
  background: none;
  border: solid 1px var(--border-default-colour);
  color: var(--font-primary-base-colour);
}

.button:focus-visible,
.button.secondary:focus-visible {
  border: solid 1px var(--primary-focus);
}

.headline-and-subtitle {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}

.headline-and-subtitle span:nth-child(2) {
  font-size: 0.8em;
  opacity: 0.75;
}

.link {
  color: var(--font-primary-strong-colour);
  font-family: var(--font-poppins);
  font-size: 1.6rem;
  line-height: 1.5;
}

.link:focus-visible {
  outline: solid 1px var(--primary-focus);
}

.divider {
  width: 100%;
  font-size: 1.6rem;
  color: var(--font-primary-strong-colour);
  text-align: center;
  display: flex;
  align-items: center;
  gap: 1.6rem;
  margin: 4rem 0;
}

.divider::before {
  content: "";
  display: inline-block;
  width: 100%;
  height: 1px;
  background: var(--pale-grey-colour);
}

.divider::after {
  content: "";
  display: inline-block;
  width: 100%;
  height: 1px;
  background: var(--pale-grey-colour);
}

.field {
  background: var(--faded-bg-colour);
  border-radius: 6px;
  display: flex;
  flex-direction: column;
  width: 100%;
  height: 5.6rem;
  padding: 0.7rem 1rem;
  border: solid 1px var(--border-default-colour);
}

.checkbox-field {
  background: none;
  border: none;
  padding: 0;
  margin: 0;
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;

  font-size: 1.6rem;
  color: var(--font-primary-strong-colour);
  line-height: 1.25;
  font-weight: 500;
}

.checkbox-field > label {
  flex-grow: 1;
}

.field.error {
  border: solid 1px var(--border-danger-colour);
}

.field-group {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.field:focus-within {
  border: solid 1px var(--primary-focus);
}

.field label {
  font-size: 1.6rem;
  color: var(--font-primary-strong-colour);
  line-height: 1.25;
  font-weight: 500;
}

.field input {
  border: none;
  outline: none;
  padding: 0;
  color: var(--font-primary-strong-colour);
  font-size: 1.8rem;
  line-height: 1.22;
}

.field-line {
  width: 100%;
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 0.4rem;
}

.field-line input {
  flex-grow: 1;
}

.field-line button {
  border: none;
  background: none;
  width: 1.8rem;
  height: 1.8rem;
  display: flex;
  padding: 0;
}

.field-line button svg {
  width: 100%;
  height: 100%;
}

.field__validation-error {
  background-color: var(--danger-tint-colour);
  border-radius: 4px;
  border: solid 1px var(--danger-tint-colour);
  padding: 0.8rem;
  color: var(--danger-shade-colour);
  font-size: 1.2rem;
  letter-spacing: 0.15px;
  line-height: 1.63;
  font-family: var(--font-poppins);
  width: 100%;
  display: flex;
  align-items: center;
  gap: 0.8rem;
}

.field__validation-error.general {
  font-size: 1.6rem;
  text-align: center;
}

.form-fields-collection {
  display: flex;
  width: 100%;
  flex-direction: column;
  gap: 1.6rem;
}

.recaptcha-container {
  display: flex;
  gap: 0.8rem;
  align-items: center;
  justify-content: between;
  width: 100%;
}

.flash {
  font-size: 1.6rem;
  font-family: var(--font-poppins);
  line-height: 1.5;
  padding: 0.8rem 1.2rem;
  width: 100%;
  display: flex;
  border-radius: 4px;
  word-break: break-all;
}

.flash.success {
  color: var(--success-shade-colour);
  border: solid 1px var(--success-colour);
  background: var(--success-tint-colour);
}

.flash.warning {
  color: var(--warning-shade-colour);
  border: solid 1px var(--warning-colour);
  background: var(--warning-tint-colour);
}

.flash.error {
  color: var(--danger-shade-colour);
  border: solid 1px var(--danger-colour);
  background: var(--danger-tint-colour);
}

.flash-container {
  display: flex;
  width: 100%;
  flex-direction: column;
  gap: 0.8rem;
}

.loader {
  width: 2rem;
  height: 2rem;
  border: 0.3rem solid #fff;
  border-bottom-color: transparent;
  border-radius: 50%;
  display: none;
  box-sizing: border-box;
  animation: rotation 1s linear infinite;
}

.loader.inverse {
  border: 0.3rem solid var(--font-primary-strong-colour);
  border-bottom-color: transparent;
}

@keyframes rotation {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

.htmx-request .loader, .htmx-request.loader {
  display: inline-block;
}
