@charset "UTF-8";
/**
 * @file layout-application.scss
 * @description Point d'entrée SCSS spécifique au layout App
 */
/**
 * @file _tokens.scss
 * @description Variables de design (couleurs, typo, espacements, breakpoints)
 */
/**
 * @file layout-application.scss
 * @description Point d'entrée SCSS spécifique au layout App
 */
/**
 * @file _header.scss
 * @description Styles pour l'en-tête du site
 */
.main-header {
  background-color: #ffffff;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  padding: 0.5rem 0;
  position: fixed;
  left: 0;
  right: 0;
  top: 0;
  z-index: 100;
  height: 4.5rem;
}
@media (min-width: 768px) {
  .main-header {
    padding-block: 1rem;
  }
}
.main-header .container {
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: center;
  max-width: 1024px;
  margin: 0 auto;
  padding: 0 1rem;
}
.main-header .header-section {
  display: flex;
  gap: 1rem;
  align-items: center;
}
.main-header .header-section--left .menu-toggle.always-show {
  display: block;
}
@media (min-width: 768px) {
  .main-header .header-section--left .menu-toggle {
    display: none;
  }
}
.main-header .header-section--center {
  display: none;
}
@media (min-width: 768px) {
  .main-header .header-section--center {
    display: block;
  }
}
.main-header .header-section--center ul {
  display: flex;
  gap: 0.5rem 2vw;
  margin-inline: 2vw;
  flex-wrap: wrap;
}
.main-header .header-section--center ul a {
  font-size: clamp(1rem, 2.15vw, 1.25rem);
  color: #323232;
}
.main-header .header-section--center ul a:hover, .main-header .header-section--center ul a.active {
  color: #F48C34;
}
.main-header .header-section--center ul li.button--download {
  display: none;
}
.main-header .header-section--right .button--text {
  min-width: unset;
  padding-inline: 1.5em;
  padding-block: 0.25em;
}
.main-header .header-section--right .button--icon img {
  width: 20px;
}

/**
 * @file layout-application.scss
 * @description Point d'entrée SCSS spécifique au layout App
 */
/**
 * @file _appfooter.scss
 * @description Styles pour le bas de page de l'application
 */
.app-footer {
  background-color: #ffffff;
  padding: 0.25rem 0;
  position: fixed;
  bottom: 0;
  height: 75px;
  width: 100%;
  border-top: 1px solid #CDCDCD;
  z-index: 100;
}
.app-footer .container {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: 2rem;
}
.app-footer a.button--icon {
  display: grid;
  height: 100%;
  gap: 0.25rem;
  align-items: stretch;
  font-size: 0.6875rem;
  color: #9B9B9C;
  line-height: 1.2;
}
.app-footer a.button--icon img {
  height: 25px;
  margin-inline: auto;
}
.app-footer a.button--icon.is-active {
  color: #72C6F0;
}
.app-footer .button-messages__icon-wrapper {
  position: relative;
  display: flex;
  justify-content: center;
}
.app-footer .button-messages__badge {
  position: absolute;
  top: -2px;
  right: calc(50% - 22px);
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background-color: #F48C34;
  border: 1.5px solid #ffffff;
}

/**
 * @file layout-application.scss
 * @description Point d'entrée SCSS spécifique au layout App
 */
/**
 * @file _offcanvasmenu.scss
 * @description Styles pour le menu mobile off canvas
 */
.offcanvas {
  position: fixed;
  top: 0;
  right: 0;
  left: auto;
  width: 100%;
  height: 100%;
  overflow: hidden;
  overflow-y: scroll;
  background: rgba(255, 255, 255, 0.4);
  z-index: 1000;
  visibility: hidden;
  opacity: 0;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}
@media (min-width: 768px) {
  .offcanvas {
    right: auto;
    left: auto;
  }
}
.offcanvas__header {
  display: flex;
  gap: 1rem;
  align-items: center;
}
.offcanvas__content {
  position: absolute;
  display: grid;
  justify-items: left;
  gap: 2rem;
  top: 0;
  left: -23ch;
  width: 23ch;
  height: max-content;
  background: #ffffff;
  padding: 1rem;
  border-bottom-left-radius: 24px;
  border-bottom-right-radius: 24px;
  transition: left 0.3s ease;
  box-shadow: -2px 0 5px rgba(0, 0, 0, 0.2);
}
.offcanvas__content nav ul li {
  margin-bottom: 1rem;
}
.offcanvas__content nav ul li a {
  color: #323232;
  font-weight: 500;
}
.offcanvas__content nav ul li a:hover, .offcanvas__content nav ul li a.active {
  color: #F48C34;
}
.offcanvas__content nav ul li a.button--download {
  background-color: #CDCDCD;
  color: #323232;
  margin-top: 1rem;
  text-align: center;
  border-radius: 10px;
}
.offcanvas__content nav ul li a.button--download:hover {
  background-color: #9B9B9C;
  color: #ffffff;
}
.offcanvas[aria-hidden=false] {
  visibility: visible;
  opacity: 1;
}
.offcanvas[aria-hidden=false] .offcanvas__content {
  left: 0;
}
.offcanvas__close-btn {
  align-self: start;
  justify-self: end;
}
.offcanvas--credit {
  background: rgba(255, 255, 255, 0.8);
  left: auto;
  right: 0;
  width: 100%;
  position: absolute;
  overflow: visible;
}
.offcanvas--credit .offcanvas__content {
  background: #DDE3E3;
  left: auto;
  right: auto;
  top: 0;
  width: 80%;
  padding-right: 2rem;
  background: #F2F2F2;
  border-radius: 0;
  border-bottom-left-radius: 24px;
  box-shadow: -4px 0 12px rgba(0, 0, 0, 0.15);
  justify-items: end;
  text-align: right;
  transform: translateX(100%);
  transition: transform 0.3s ease;
}
.offcanvas--credit[aria-hidden=false] {
  visibility: visible;
  opacity: 1;
}
.offcanvas--credit[aria-hidden=false] .offcanvas__content {
  left: auto;
  right: 0;
  transform: translateX(0);
}
.offcanvas--credit .offcanvas__close-btn {
  position: absolute;
}
.offcanvas--credit nav ul li {
  margin-bottom: 0;
}
.offcanvas--credit nav ul li a {
  font-size: 1.125rem;
  font-weight: 700;
  color: #323232;
  display: block;
  padding-block: 0.5rem;
}
.offcanvas--credit nav ul li a:hover {
  color: #323232;
}
.offcanvas--credit .offcanvas-credit__item--disabled {
  font-size: 1.125rem;
  color: #9B9B9C;
  font-weight: 400;
  display: block;
  padding-block: 1rem;
}

/**
 * @file layout-application.scss
 * @description Point d'entrée SCSS spécifique au layout App
 */
/**
 * @file _appintro.scss
 * @description Styles pour l'entête de l'application et les pages de la section Votre crédit
 */
.app-intro {
  display: grid;
  gap: 1rem;
  grid-template-columns: 1fr 1fr;
  grid-auto-rows: auto auto;
  align-items: center;
  position: relative;
}
@media (min-width: 768px) {
  .app-intro {
    min-width: 768px;
    max-width: 1024px;
  }
}
.app-intro .card {
  grid-area: 2/1/3/3;
  background: #72C6F0;
  padding: 1rem;
  color: #ffffff;
  border-radius: 0.5rem;
}
.app-intro .card header {
  display: flex;
  gap: 1rem;
  margin-bottom: 1rem;
  align-items: center;
  justify-content: space-between;
}
.app-intro .card__content {
  display: flex;
  gap: 2rem;
  justify-content: space-between;
  align-items: end;
}
.app-intro .card .button {
  border: 1px solid #ffffff;
  margin-inline: auto;
}
.app-intro .card__alert {
  background: #ffffff;
  color: #323232;
  padding: 1rem;
}
.app-intro .app-intro__label {
  font-size: 0.81rem;
  margin-bottom: 0;
}
.app-intro .solde__value {
  font-size: 1.9375rem;
  font-weight: bold;
}
.app-intro .montant__value {
  font-size: 1.125rem;
  font-weight: bold;
}
.app-intro--credit-page {
  position: relative;
  padding-block: 2rem;
  align-items: end;
}
.app-intro--credit-page .app-intro__menu-btn {
  position: absolute;
  top: 0;
  right: 0;
  background: none;
  border: 1px solid transparent;
  padding: 0.5rem;
  cursor: pointer;
}
.app-intro--credit-page .app-intro__menu-btn:hover {
  border-color: #ffffff;
}
.app-intro--credit-page .intro {
  align-self: start;
  display: grid;
  gap: 2rem;
}
.app-intro--credit-page .app-intro__bonidollars, .app-intro--credit-page .app-intro__montant {
  display: grid;
  justify-content: right;
}
.app-intro--credit-page .app-intro__bonidollars {
  text-align: center;
}
.app-intro--credit-page .app-intro__montant {
  text-align: right;
}

/**
 * @file layout-application.scss
 * @description Point d'entrée SCSS spécifique au layout App
 */
/**
 * @file _bonidollars.scss
 * @description Styles pour le composant Bonidollars
 */
#bonidollars-wheel {
  position: relative;
  font-size: 0.6875rem;
  padding: 1.5em 2.25em;
  margin: 0 auto;
  width: min-content;
}
#bonidollars-wheel .wheel {
  position: relative;
  height: 80px;
  width: 80px;
}
#bonidollars-wheel .wheel--frame {
  position: relative;
}
#bonidollars-wheel .wheel__center {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  transform-origin: center;
}
#bonidollars-wheel .wheel__pointer {
  transform-origin: center;
  width: 100px;
  height: 100px;
}
#bonidollars-wheel .wheel__pointer--5 {
  transform: rotate(18deg);
}
#bonidollars-wheel .wheel__pointer--10 {
  transform: rotate(36deg);
}
#bonidollars-wheel .wheel__pointer--15 {
  transform: rotate(54deg);
}
#bonidollars-wheel .wheel__pointer--20 {
  transform: rotate(72deg);
}
#bonidollars-wheel .wheel__pointer--25 {
  transform: rotate(90deg);
}
#bonidollars-wheel .wheel__pointer--30 {
  transform: rotate(108deg);
}
#bonidollars-wheel .wheel__pointer--35 {
  transform: rotate(126deg);
}
#bonidollars-wheel .wheel__pointer--40 {
  transform: rotate(144deg);
}
#bonidollars-wheel .wheel__pointer--45 {
  transform: rotate(162deg);
}
#bonidollars-wheel .wheel__pointer--50 {
  transform: rotate(180deg);
}
#bonidollars-wheel .wheel__pointer--55 {
  transform: rotate(198deg);
}
#bonidollars-wheel .wheel__pointer--60 {
  transform: rotate(216deg);
}
#bonidollars-wheel .wheel__pointer--65 {
  transform: rotate(234deg);
}
#bonidollars-wheel .wheel__pointer--70 {
  transform: rotate(252deg);
}
#bonidollars-wheel .wheel__pointer--75 {
  transform: rotate(270deg);
}
#bonidollars-wheel .wheel__pointer--80 {
  transform: rotate(288deg);
}
#bonidollars-wheel .wheel__pointer--85 {
  transform: rotate(306deg);
}
#bonidollars-wheel .wheel__pointer--90 {
  transform: rotate(324deg);
}
#bonidollars-wheel .wheel__pointer--95 {
  transform: rotate(342deg);
}
#bonidollars-wheel .wheel__pointer--100 {
  transform: rotate(360deg);
}
#bonidollars-wheel .dollars {
  position: absolute;
}
#bonidollars-wheel .dollars--100 {
  top: 0;
  left: 43%;
}
#bonidollars-wheel .dollars--25 {
  top: 45%;
  right: 0;
}
#bonidollars-wheel .dollars--50 {
  bottom: 0;
  left: 43%;
}
#bonidollars-wheel .dollars--75 {
  top: 45%;
  left: 0%;
}
#bonidollars-wheel.bonidollars-wheel--large {
  font-size: 1.25rem;
}
#bonidollars-wheel.bonidollars-wheel--large .wheel {
  height: 200px;
  width: 200px;
}

#layout-application #main-content {
  display: grid;
  gap: 2rem;
  justify-items: left;
  align-items: center;
  padding-bottom: calc(75px + 2rem);
}
#layout-application #main-content.main-content--credit {
  padding-top: 0;
  overflow: hidden;
}
#layout-application #main-content .container {
  min-width: 100%;
}
@media (min-width: 768px) {
  #layout-application #main-content .container {
    min-width: 768px;
    max-width: 1024px;
  }
}
#layout-application h2 {
  font-size: 1.25rem;
}
#layout-application .ui {
  display: grid;
  gap: 2rem;
  justify-content: left;
}
@media (min-width: 768px) {
  #layout-application .ui {
    padding-bottom: 1rem;
  }
}

.app-message {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  border: 2px solid #72C6F0;
  border-radius: 0.75rem;
  padding: 1rem;
}
.app-message__input {
  flex: 1;
  border: none;
  background: transparent;
  padding: 0;
  font-size: 1rem;
  color: #2F3335;
  width: 100%;
  min-width: 0;
  border-radius: 0;
}
.app-message__input::placeholder {
  color: #9B9B9C;
}
.app-message__input:focus {
  outline: none;
}