/* BASE */
html,
body {
  height: 100vh;
  scroll-behavior: smooth;
}

body.swal2-shown.swal2-height-auto {
  height: inherit !important;
  padding-right: inherit !important;
  overflow-y: auto !important;
}

body {
  font-size: 16px;
  font-family: Archivo, sans-serif;
  display: flex;
  flex-direction: column;
  position: relative;
}

section.content {
  flex-grow: 2;
}

footer {
  display: flex;
}

a:not(.nav-link):not(.dropdown-item) {
  font-weight: bold;
}

.fw-600 {
  font-weight: 600 !important;
}

.ff-neuton {
  font-family: Neuton, serif;
}

.ff-archivo {
  font-family: Archivo, sans-serif;
}

.ff-source-sans-pro {
  font-family: "Source Sans Pro", sans-serif;
}

.fs-small {
  font-size: 0.75rem;
}

.fs-4-5 {
  /* 22.4px */
  font-size: 1.4rem;
}

.fs-7 {
  /* 12px */
  font-size: 0.75rem;
}

.fs-6-7 {
  /* 14px */
  font-size: 0.875rem;
}

.mt-4-5 {
  margin-top: 2rem;
}

.mb-2-3 {
  margin-bottom: 0.75rem;
}

.mb-4-5 {
  margin-bottom: 2rem;
}

.me-2-3 {
  margin-right: 0.75rem;
}

.me-3-4 {
  margin-right: 1.25rem;
}

.me-4-5 {
  margin-right: 2rem;
}

.pe-4-5 {
  padding-right: 2rem;
}

.rounded-10 {
  border-radius: 1rem !important;
}

.rounded-5 {
  border-radius: 0.5rem;
}

.rounded-4 {
  border-radius: 0.4rem;
}

.border-solid {
  border-style: solid !important;
}

.btn-group.rounded-pill > .btn:first-child {
  border-top-left-radius: 50rem;
  border-bottom-left-radius: 50rem;
}

.btn-group.rounded-pill > .btn:last-child {
  border-top-right-radius: 50rem;
  border-bottom-right-radius: 50rem;
}

.mw-max-content {
  max-width: max-content;
}

.bi-x-lg {
  content: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 16 16"><path fill="none" stroke="currentColor" stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M14.964 1.051 1.026 14.967m0-13.916 13.924 13.93"/></svg>');
}

.bi-check-circle-fill {
  content: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="currentColor" class="bi bi-check-circle-fill" viewBox="0 0 16 16"><path d="M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zm-3.97-3.03a.75.75 0 0 0-1.08.022L7.477 9.417 5.384 7.323a.75.75 0 0 0-1.06 1.06L6.97 11.03a.75.75 0 0 0 1.079-.02l3.992-4.99a.75.75 0 0 0-.01-1.05z"/></svg>');
}

.filter-red {
  filter: invert(26%) sepia(76%) saturate(1367%) hue-rotate(336deg)
    brightness(109%) contrast(79%);
}

.filter-green {
  filter: invert(40%) sepia(89%) saturate(1458%) hue-rotate(86deg)
    brightness(111%) contrast(88%);
}

.escriba-text-field {
  border: 0;
  border-bottom: 1px solid var(--purple);
  border-radius: 0;
  padding: 0.125rem 0;
}

.escriba-clock-icon {
  position: relative;
}

.escriba-clock-icon::after {
  content: "";
  position: absolute;
  background-image: url("../images/clock.svg");
  width: 1rem;
  height: 1rem;
  left: 0;
  top: 0.375rem;
  filter: var(--filter-purple);
}

.escriba-clock-icon input {
  padding-left: 1.5rem !important;
}

/* PALETTE */
:root {
  --white: white;
  --black: black;
  --light-gray: #e8e8e8;
  --lighter-gray: #f9fafb;
  --gray: #aaa;
  --dark-gray: #707070;
  --purple: #3d23ff;
  --red: #c43d3d;
  --yellow: #f9a51a;
  --balance-warning: #f44336;
  --live-error: #ff0033;
  --primary-color: var(--purple);
  --secondary-color: var(--black);
  --secondary-fg: var(--white);
  --balance-warning-color: var(--balance-warning);
  --live-error-color: var(--live-error);
  --filter-purple: brightness(0) saturate(100%) invert(26%) sepia(38%)
    saturate(2697%) hue-rotate(239deg) brightness(92%) contrast(93%);
  --filter-red: invert(33%) sepia(35%) saturate(1986%) hue-rotate(331deg)
    brightness(97%) contrast(84%);
}

.btn-light {
  --bs-btn-bg: var(--light-gray);
  --bs-btn-border-color: var(--light-gray);

  --bs-btn-hover-bg: var(--gray);
  --bs-btn-hover-border-color: var(--gray);

  --bs-btn-active-bg: var(--lighter-gray);
  --bs-btn-active-border-color: var(--lighter-gray);
}

.btn-outline-light {
  color: var(--dark-gray);
  border-color: var(--gray);
}

.btn-outline-light:hover {
  color: var(--black);
  background-color: var(--gray);
  border-color: var(--gray);
}

.background-dotted-image::before {
  content: "";
  width: 100%;
  height: 100%;
  background-image: radial-gradient(
    var(--secondary-color) 1%,
    rgba(255, 255, 255, 0) 20%
  );
  background-size: 0.5em 0.5em;
  position: absolute;
  z-index: -1;
  top: 0;
}

a,
a:hover,
button {
  color: var(--bs-black-rgb);
}

body .navbar-light .navbar-nav .nav-link,
body .navbar-light .navbar-toggler {
  color: black;
}

footer {
  background-color: #f8f8f8;
}

footer,
footer .nav-link:hover {
  color: #aaa;
}

.color-black {
  color: var(--black);
}

.color-gray {
  color: var(--gray);
}

.color-light-gray {
  color: var(--light-gray);
}

.color-dark-gray {
  color: var(--dark-gray);
}

.color-yellow {
  color: var(--yellow);
}

.color-red {
  color: var(--red);
}

.color-primary {
  color: var(--primary-color);
}

.current-accent-color {
  accent-color: currentColor;
}

.placeholder-gray::placeholder {
  color: var(--gray);
}

.bg-primary {
  background-color: var(--primary-color) !important;
}

.bg-light-gray {
  background-color: var(--light-gray);
}

.bg-gray {
  background-color: var(--gray);
}

.bg-dark-gray {
  background-color: var(--dark-gray);
}

.border-primary {
  border-color: var(--primary-color) !important;
}

.border-primary-on-focus:focus {
  border-color: var(--primary-color) !important;
}

.border-color-light-gray {
  border-color: var(--light-gray);
}

.box-shadow-none {
  box-shadow: none !important;
}

.btn-primary,
.btn-primary:hover,
.btn-primary:focus,
.btn-primary:first-child:active {
  color: white !important;
  background-color: var(--primary-color) !important;
  border-color: var(--primary-color) !important;
}

.btn-gray,
.btn-gray:hover,
.btn-gray:focus,
.btn-gray:first-child:active {
  color: white !important;
  background-color: var(--gray) !important;
  border-color: var(--gray) !important;
}

.btn-outline-primary {
  color: var(--primary-color) !important;
  border: 1px solid var(--primary-color) !important;
  background-color: white !important;
}

.btn-outline-primary:hover {
  color: white !important;
  background-color: var(--primary-color) !important;
}

.btn-outline-balance-warning {
  color: var(--balance-warning-color) !important;
  border: 1px solid var(--balance-warning-color) !important;
  background-color: white !important;
}

.btn-outline-live-error {
  color: var(--live-error-color) !important;
  border: 1px solid var(--live-error-color) !important;
  background-color: white !important;
}

.btn-outline-balance-warning:hover {
  color: white !important;
  background-color: var(--balance-warning-color) !important;
}

.btn-secondary,
.btn-secondary:hover {
  color: var(--secondary-fg);
  background-color: var(--secondary-color);
  border-color: var(--secondary-color);
}

.offcanvas-top {
  height: 22rem;
}

.navbar-dark .navbar-nav .nav-link {
  color: var(--bs-white);
}

.navbar-light .navbar-nav .nav-link.active {
  color: var(--secondary-color);
  font-weight: bold;
}

@media screen and (width < 768px) {
  .navbar-collapse.show {
    background-color: #e9e9e9;
  }
}

/* GENERAL */
.chip-field {
  position: relative;
}

.chip-field input {
  position: absolute;
  z-index: -1;
  opacity: 0;
}

.chip-field label {
  margin: 0 8px 8px 0;
  padding: 0.25rem 1rem;
  border-radius: 2rem;
  border-width: 1px;
  border-style: solid;
  border-color: var(--primary-color);
  color: var(--primary-color);
}

.chip-field input:checked + label {
  background-color: var(--primary-color);
  color: white;
}

.generic-tip {
  position: relative;
  cursor: pointer;
}

.generic-tip::before {
  content: attr(data-text);
  font-family: "Source Sans Pro";
  font-weight: normal;
  font-size: 0.75rem;
  color: white;
  background-color: black;
  max-width: 20rem;
  width: max-content;
  display: none;
  position: absolute;
  padding: 0.25rem 0.5rem;
  border-radius: 0.25rem;
  left: calc(100% + 0.25rem);
  bottom: 50%;
}

.generic-tip:hover:before {
  display: block;
}

.error-container {
  max-width: 48rem;
  margin: auto auto;
}

.error-container h1 {
  font-size: 3rem;
}

.error-container img {
  width: 100%;
}

.escriba-container {
  display: flex;
  justify-content: center;
  margin: 2rem auto 0;
  width: 100%;
}

.escriba-content {
  max-width: 45rem;
  width: 100%;
  margin: 0 0.5em;
}

.escriba-large-content {
  max-width: 72rem;
  width: 100%;
  margin: 0 3rem;
}

.no-select {
  -webkit-user-select: none;
  -khtml-user-select: none;
  -moz-user-select: -moz-none;
  -o-user-select: none;
  user-select: none;
}

body .navbar-light .navbar-toggler {
  padding-left: 0;
  padding-right: 0;
  margin-left: -0.5rem;
  border-width: 0;
}

.navbar-brand span {
  font-size: 2.75rem;
  margin-top: -0.75rem;
}

.container-fluid {
  padding: 0;
}

.navbar-toggler:focus,
button:focus:not(:focus-visible) {
  text-decoration: none;
  outline: none;
  box-shadow: none;
}

.img-cover {
  object-fit: cover;
  aspect-ratio: 16/9;
}

.z-index-3 {
  z-index: 3;
}

.z-index-n1 {
  z-index: -1;
}

.mirror-x {
  transform: scaleX(-1);
}

.escriba-form {
  --color: black;
  --background-color: white;
  --border-color: var(--primary-color);
  --error-color: var(--red);
  --font-size: 1rem;
  --font-weight: normal;
  color: var(--color);
}

.escriba-form label {
  font-size: var(--font-size);
  font-weight: var(--font-weight);
}

.escriba-form input,
.escriba-form input:focus {
  border-bottom-color: var(--border-color);
  background-color: var(--background-color);
  color: var(--color);
}

.escriba-form input::placeholder {
  color: var(--gray);
}

.escriba-form .required-field::after {
  content: "*";
  color: var(--error-color);
}

.escriba-form input[type="checkbox"],
.escriba-form input[type="radio"] {
  color: var(--primary-color);
  accent-color: currentColor;
  vertical-align: middle;
  width: 1rem;
  height: 1rem;
  margin-bottom: 0.25rem;
}

.escriba-form input {
  border-top: none;
  border-left: none;
  border-right: none;
  border-radius: 0;
  padding: 0.15rem 0 0.5rem;
}

.escriba-form input:focus {
  box-shadow: none;
}

.errorlist {
  padding-left: 0;
  list-style: none;
  margin-top: 0.25rem;
  color: var(--error-color);
}

.escriba-form > .form-group {
  margin-bottom: 2rem;
}

.content-mobile {
  display: none;
}

.background-dotted-content {
  padding: 3rem 5rem;
}

.cursor-pointer {
  cursor: pointer;
}

@media screen and (width < 480px) {
  .background-dotted-content {
    max-width: 100%;
    padding-left: 0.5rem;
    padding-right: 0.5rem;
    margin-left: 0;
    margin-right: 0;
  }
}

@media (width >= 768px) {
  .navbar {
    height: 6rem;
  }

  .navbar-expand-md .navbar-nav .nav-link {
    padding-left: 1.75rem;
    padding-right: 0;
  }

  .navbar-expand-md .navbar-nav .nav-item:last-child .nav-link {
    padding-right: 0;
  }

  .text-start-on-desktop {
    text-align: start;
  }

  .align-items-center-on-desktop {
    align-items: center;
  }

  .flex-row-on-desktop {
    flex-direction: row;
  }

  .display-none-on-desktop {
    display: none;
  }

  .me-2-on-desktop {
    margin-right: 0.5rem;
  }

  .me-3-on-desktop {
    margin-right: 1rem;
  }

  .me-4-on-desktop {
    margin-right: 1.5rem;
  }

  .me-auto-on-desktop {
    margin-right: auto;
  }

  .px-0-on-desktop {
    padding-left: 0;
    padding-right: 0;
  }

  .px-4-on-desktop {
    padding-right: 1.5rem;
    padding-left: 1.5rem;
  }

  .ps-0-on-desktop {
    padding-left: 0;
  }

  .pe-4-on-desktop {
    padding-right: 1.5rem;
  }

  .text-center-on-desktop {
    text-align: center;
  }

  .col-on-desktop {
    flex: 1 0 0%;
  }

  .w-75-on-desktop {
    width: 75%;
  }

  .w-50-on-desktop {
    width: 50%;
  }

  .mw-75-on-desktop {
    max-width: 75%;
  }

  .mw-50-on-desktop {
    max-width: 50%;
  }

  .mw-60-on-desktop {
    max-width: 60%;
  }

  .mw-40-on-desktop {
    max-width: 40%;
  }
}

/* start .account-links */

@media (width < 48rem) {
  .account-links .col:nth-child(1),
  .account-links .col:nth-child(2) {
    border-right: var(--bs-border-width) var(--bs-border-style)
      var(--bs-border-color);
  }

  .account-links .card-body {
    padding: 16px 10px;
  }

  .icon-link-spacing {
    gap: 6px;
  }

  .mobile-min-width {
    min-width: 100%;
  }
}

@media (width >= 48rem) {
  .account-links .card-body {
    padding: 0 17px;
  }

  .account-links .card-body .col {
    padding: 12px 0;
  }

  .account-links {
    max-width: 16rem;
  }

  .account-links .col:nth-child(1),
  .account-links .col:nth-child(2) {
    border-right: none;
    border-bottom: var(--bs-border-width) var(--bs-border-style)
      var(--bs-border-color);
  }
}

.account-links .col:last-child {
  border-right: none;
  border-bottom: none;
}

/* end .account-links */

@media screen and (width < 768px) {
  .text-center-on-mobile {
    text-align: center;
  }

  .flex-column-on-mobile {
    flex-direction: column;
  }

  .display-none-on-mobile {
    display: none;
  }

  .justify-content-between-on-mobile {
    justify-content: space-between;
  }

  .me-2-on-mobile {
    margin-right: 0.5rem;
  }

  .right-0-on-mobile {
    right: 0;
  }

  .mx-auto-on-mobile {
    margin-left: auto;
    margin-right: auto;
  }

  .w-100-on-mobile {
    width: 100%;
  }

  .content-mobile {
    display: unset;
  }

  .content-desktop {
    display: none;
  }

  .escriba-large-content {
    margin: 0 1rem;
  }

  .error-container img {
    display: none;
  }

  .navbar .navbar-brand {
    font-size: 0.75rem;
    flex-grow: 1;
    text-align: center;
    margin-right: 1.5rem;
  }

  .navbar-collapse.show {
    position: absolute;
    top: 5rem;
    z-index: 10;
    width: 100%;
    margin-left: -0.5rem;
  }

  .navbar-collapse.show .nav-link {
    padding: 0;
  }

  .navbar-collapse.show .nav-item {
    padding: 0.5rem 1.25rem;
  }

  .mb-3-on-mobile {
    margin-bottom: 1rem;
  }

  .mb-4-on-mobile {
    margin-bottom: 1.5rem;
  }
}

.navbar-light .navbar-nav .nav-link::before {
  display: block;
  content: attr(title);
  font-weight: bold;
  height: 0;
  overflow: hidden;
  visibility: hidden;
}

.cookie-banner {
  position: fixed !important;
  bottom: 0;
  left: 0;
  width: 100%;
  background-color: rgba(0, 0, 0, 0.7);
  color: #fff;
  padding: 15px;
  box-sizing: border-box;
  display: none;
  justify-content: center;
  align-items: center;
  text-align: center;
  z-index: 9999;
}

.cookie-banner p {
  margin: 0;
  padding-right: 20px;
}

.cookie-banner a {
  color: #fff;
  text-decoration: underline;
}

.accept-btn {
  background-color: #3d23ff;
  color: #fff;
  border: none;
  padding: 10px 20px;
  border-radius: 20px;
  cursor: pointer;
}

.accept-btn:hover {
  background-color: #0056b3;
}

.hide-language {
    display: none;
}
