:root {
  --kidlee-green: #58b998;
  --kidlee-blue: #38548d;
  --kidlee-red: #f089a8;
  --kidlee-light-green: #58b998cc;
  --kidlee-light-blue: #38548dcc;
  --kidlee-faded-green: rgba(88, 185, 152, 0.08);
  --kidlee-light-red: #f089a814;
}

/** mission card */
.mission-card {
  padding: 0 15px;
  margin-bottom: 20px;
  cursor: pointer;
}

.card-container {
  width: 100%;
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 24px;
  padding: 0;
  border-radius: 12px;
  border: 1px solid #d9d9d9;
  background: #fff;
}

.card-container.no-mer {
  border-radius: 0 0 12px 12px;
}

.card-container:hover {
  box-shadow: 0px 4px 8px rgba(0, 0, 0, 0.1);
}

.card-header {
  width: 100%;
  display: flex;
  gap: 20px;
  padding: 24px 24px 0 0;
  font-size: 13px;
  color: var(--kidlee-green);
  font-weight: 500;
  line-height: 148%;
  justify-content: space-between;
}

.card-header .date-range {
  font-family: Poppins, sans-serif !important;
  justify-content: center;
  border-radius: 0 8px 8px 0;
  background: linear-gradient(97deg, #58b998 0%, #60a08a 100%);
  align-self: start;
  padding: 8px 32px;
  color: #fff;
}

.card-header .date-range.asap {
  background: rgba(255, 94, 94, 0.1);
  color: #ff5e5e;
}

.card-status {
  font-family: Poppins, sans-serif !important;
  font-weight: 500;
  justify-content: center;
  border-radius: 0 8px 8px 0;
  background: rgba(255, 94, 94, 0.1);
  color: #ff5e5e;
  align-self: start;
  padding: 8px 32px;
}

.card-state {
  font-family: Poppins, sans-serif !important;
  font-weight: 500;
  justify-content: center;
  border-radius: 0 8px 8px 0;
  background: rgb(218 194 194 / 10%);
  color: #5e5498;
  align-self: start;
  padding: 8px 32px;
}

.card-body {
  width: 100%;
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 24px;
}

.card-body .left-section {
  min-width: 330px;
}

.name-container {
  align-self: start;
  color: rgba(5, 18, 45, 0.8);
  font-family: Roboto !important;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
}

.subject-table {
  border-radius: 12px;
  border: 0.64px solid #D9D9D9;
  background: #FFF;
}

.id-text {
  font-weight: 400;
  font-size: 13px;
  line-height: 15px;
}

.activities-list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
  gap: 16px;
  margin-top: 12px;
  font-size: 14px;
  color: var(--kidlee-blue);
  font-weight: 400;
}

.activity-item {
  display: flex;
  justify-content: center;
  padding: 8px 16px;
  border: 1px solid var(--kidlee-green);
  border-radius: 24px;
  font-family: Poppins, sans-serif !important;
}

.card-body .title {
  display: flex;
  align-items: center;
  gap: 8px;
}

.card-body .title span,
.card-body .title p,
.card-body .title div {
  color: var(--kidlee-blue);
  font-weight: 500;
  font-family: Poppins, sans-serif !important;
}

.presentation .title span {
  color: var(--kidlee-green);
}

.details-container .icon-container {
  width: 57px;
  height: 57px;
  flex-shrink: 0;
  border-radius: 7.2px;
  background-color: var(--kidlee-faded-green);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  color: var(--kidlee-blue);
}

.price-container {
  display: flex;
  align-items: flex-start;
  flex-wrap: wrap;
  margin-top: 16px;
  width: 100%;
  gap: 80px;
}

.price-details {
  display: flex;
  gap: 6px;
}

.price-info {
  display: flex;
  flex-direction: column;
  margin: auto 0;
  width: 100%;
}

.pricing {
  color: var(--kidlee-blue);
  font-family: Roboto !important;
  font-size: 13.5px;
  font-style: normal;
  font-weight: 400;
  line-height: normal;
}
.pricing .price-value {
  color: var(--kidlee-green);
  font-size: 18px;
  font-weight: 700;
}

.location-container {
  display: flex;
  gap: 6px;
  white-space: nowrap;
}

.location-details {
  display: flex;
  flex-direction: column;
  margin: auto 0;
}

.location-value {
  color: var(--kidlee-green);
  font: 700 18px Roboto, sans-serif !important;
}

.location-label,
.price-per-hour {
  color: var(--kidlee-light-blue);
  font: 400 13px Poppins, sans-serif !important;
}

.row-section {
  display: flex;
  gap: 80px;
  justify-content: space-between;
}

.schedule-container {
  display: flex;
  flex-direction: column;
  font-size: 14px;
}

.schedule-header {
  display: flex;
  gap: 8px;
  color: var(--kidlee-blue);
  font-weight: 500;
}

.schedule-icon {
  width: 24px;
  aspect-ratio: 1;
  object-fit: cover;
  object-position: center;
}

.schedule-days {
  display: flex;
  flex-wrap: wrap;
  margin-top: 16px;
  gap: 8px;
  color: #fff;
  font-weight: 400;
  white-space: nowrap;
}

.schedule-day {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.schedule-day-inactive {
  color: #646464;
}

.schedule-day-text {
  font-family: Poppins, sans-serif !important;
  border-radius: 50%;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.schedule-day-active .schedule-day-text {
  background: var(--kidlee-green);
  padding: 0 10px;
}

.schedule-day-inactive .schedule-day-text {
  background: var(--kidlee-faded-green);
  padding: 0 13px;
}

.children-section {
  display: flex;
  flex-direction: column;
  color: var(--kidlee-blue);
}

.children-header {
  align-self: start;
  display: flex;
  gap: 8px;
  font-size: 14px;
  font-weight: 500;
  line-height: 114%;
}

.children-list {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  font-size: 13px;
  font-weight: 400;
  white-space: nowrap;
  line-height: 148%;
}

.child {
  display: flex;
  gap: 8px;
  justify-content: center;
  align-items: center;
}

.child-icon {
  width: 32px;
  height: 32px;
  object-fit: cover;
  object-position: center;
  border-radius: 50%;
  border: 1px solid var(--kidlee-green);
}

.child-age {
  font-family: Poppins, sans-serif !important;
  margin: auto 0;
  display: flex;
  flex-direction: column;
  color: var(--kidlee-green);
  text-wrap: auto;
}

.languages-spoken {
  display: flex;
  flex-direction: column;
  color: var(--kidlee-blue);
  font-weight: 500;
}

.languages-spoken__header {
  display: flex;
  gap: 8px;
  font-size: 14px;
  line-height: 114%;
}

.icon {
  width: 24px;
  aspect-ratio: 1;
  object-fit: contain;
  object-position: center;
}

.languages-spoken__title {
  font-family: Poppins, sans-serif;
  margin: auto 0;
}

.languages-spoken__list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  font-size: 14px;
  font-weight: 400;
}

.languages-spoken__item {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--kidlee-faded-green);
  border-radius: 8px;
  padding: 8px;
  height: 46px;
  width: 46px;
  border-radius: 50%;
}

.vacation-needs {
  display: flex;
  flex-direction: column;
  font-size: 14px;
}

.vacation-needs__header {
  display: flex;
  gap: 8px;
  color: var(--kidlee-blue);
  font-weight: 500;
}

.vacation-needs__title {
  font-family: Poppins, sans-serif !important;
  margin: auto 0;
}

.tag-item.disabled {
  color: var(--kidlee-red);
  background: var(--kidlee-light-red);
}

.tag-item.disabled span {
  color: var(--kidlee-red);
}

.tag-item .dot {
  width: 8px;
  height: 8px;
  background: var(--kidlee-light-green);
  border-radius: 50%;
}

.tag-item.disabled .dot {
  background: var(--kidlee-red);
}

.vacation-needs__text {
  font-family: Poppins, sans-serif !important;
}
/** end mission card */

/** marketplace filter card */
.filter-row {
  display: flex;
  padding: 24px;
  flex-direction: column;
  align-items: flex-start;
  border-radius: 12px;
  border: 1px solid #d9d9d9;
  background: #fff;
}

.filter-collapse-area {
  width: 100%;
}

.collapse-href {
  padding: 1.5rem 3rem 1.5rem 3rem;
  cursor: pointer;
  color: var(--kidlee-blue);
  width: 100%;
  font-family: Poppins, sans-serif !important;
  font-size: 20px;
  font-style: normal;
  font-weight: 500;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

#filter-collapse form {
  display: flex;
  flex-wrap: wrap;
  gap: 24px;
}

#filter-collapse form > .filtre-recherche-prestation {
  flex: 1 1 calc(50% - 24px);
  width: calc(50% - 24px);
}

.filtre-recherche-prestation > div {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  width: 100%;
}

.filtre-recherche-prestation > div > * {
  width: 100% !important;
}

.filtre-recherche-prestation .title,
.filtre-recherche-prestation .label {
  display: inline-block;
  color: #38548d;
  font-family: Poppins, sans-serif !important;
  font-size: 14px;
  font-style: normal;
  font-weight: 400;
  text-align: start;
  white-space: unset !important;
}

.filtre-recherche-prestation .title {
  margin-bottom: 12px;
}

.filtre-recherche-prestation input {
  display: flex !important;
  padding: 12px 8px !important;
  color: var(--kidlee-blue) !important;
  justify-content: center;
  align-items: center;
  height: 44px;
  width: 100%;
  gap: 8px;
  align-self: stretch;
  border-radius: 8px !important;
  border: 1px solid #d9d9d9 !important;
  background: #fff;
}

.filtre-recherche-prestation input::placeholder {
  color: rgba(56, 84, 141, 0.8);
  font-family: Poppins, sans-serif !important;
  font-size: 11px;
  font-style: normal;
  font-weight: 400;
  line-height: normal;
}

.filtre-recherche-prestation select {
  display: flex;
  padding: 0px 10px;
  height: 44px;
  width: 100%;
  align-items: center;
  gap: 10px;
  align-self: stretch;
  border-radius: 6px;
  border: 1px solid #d9d9d9;
  box-shadow: 0px 0px 16px 0px rgba(88, 185, 152, 0.06);
  color: rgba(56, 84, 141, 0.8) !important;
  font-family: Poppins, sans-serif;
  font-size: 14px;
  font-style: normal;
  font-weight: 400;
  outline: none;
}

.filtre-recherche-prestation .disponibilities {
  display: flex;
  gap: 30px;
}

.filtre-recherche-prestation .disponibilities > div {
  display: flex;
  flex-direction: column;
}

.selected-language-badge {
  color: var(--kidlee-green) !important;
  border-color: var(--kidlee-green) !important;
}

.selected-language-badge .fa-times-circle {
  color: var(--kidlee-green) !important;
}

.vue-slider-process {
  background-color: var(--kidlee-green) !important;
}

.vue-slider-dot-handle {
  background-color: var(--kidlee-green) !important;
  border-color: var(--kidlee-green) !important;
}

.vue-slider-rail {
  background-color: var(--kidlee-faded-green) !important;
}

.filtre-recherche-prestation .kidlee_checkbox.active {
  background-color: var(--kidlee-green) !important;
  border-color: var(--kidlee-green) !important;
}

.filtre-recherche-prestation .filter-section {
  display: flex;
  flex-wrap: wrap;
}

.filter-actions {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  width: 100%;
  gap: 24px;
}

.filter-actions button {
  display: flex;
  width: 100%;
  padding: 16px 24px;
  justify-content: center;
  align-items: center;
  border-radius: 12px;
  border: 1px solid var(--kidlee-green);
  text-decoration: none;
}

.filter-actions .submit-action {
  background: var(--kidlee-green);
  color: #fff;
}

.filter-actions .submit-action:hover,
.filter-actions .cancel-filter {
  background: #fff;
  color: var(--kidlee-green);
}

.localisation-input {
  position: relative;
}

.localisation-input .icon {
  position: absolute;
  top: 50%;
  left: 8px;
  transform: translateY(-50%);
  font-size: 24px;
}

.localisation-input input {
  padding-left: 29px !important;
}

.chevron-container {
  display: flex;
  width: 24px;
  height: 24px;
  font-size: 16px;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 13.333px;
  border-radius: 69.333px;
  background: rgba(88, 185, 152, 0.1);
  color: #58b998;
}

.chevron-container.select-icon {
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translateY(-50%);
  font-size: 14px;
}

.vue-slider-dot {
  height: 24px !important;
  width: 24px !important;
}

/** end marketplace filter card */
.page-title {
  font-family: Poppins, sans-serif !important;
  font-size: 20px;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
  color: var(--kidlee-blue);
  margin: 20px;
}

.mission-show {
  cursor: unset;
}
.mission-show .card-container:hover {
  box-shadow: none;
}
.mission-show .card-body {
  gap: 32px;
}
.name-section .map-icon {
  font-size: 24px;
  color: var(--kidlee-green);
}

.mission-show .localisation {
  display: flex;
  align-items: center;
  gap: 8px;
}

.localistion span {
  font-family: Roboto, sans-serif !important;
  font-size: 16px;
  font-style: normal;
  font-weight: 500;
}

.testimonial {
  border-radius: 20px;
  background-color: var(--kidlee-green);
  align-self: center;
  display: flex;
  width: 100%;
  flex-direction: column;
  align-items: start;
  color: #fff;
  padding: 25px;
  position: relative;
  overflow: hidden;
}

.author {
  font: 600 16px Poppins, sans-serif !important;
}

.quote {
  text-align: justify;
  margin-top: 14px;
  font: 400 14px Poppins, sans-serif !important;
}

.testimonial #vector {
  position: absolute;
  top: 0;
  right: 0;
}

.presentation {
  border-radius: 8px;
  border: 0.64px solid #d9d9d9;
  background: var(--Colors-Bg-color, #fff);
  box-shadow: -154px 565px 164px 0px rgba(89, 184, 151, 0),
    -99px 361px 150px 0px rgba(89, 184, 151, 0),
    -56px 203px 126px 0px rgba(89, 184, 151, 0.01),
    -25px 90px 94px 0px rgba(89, 184, 151, 0.02),
    -6px 23px 52px 0px rgba(89, 184, 151, 0.02);
}

.presentation-content p {
  color: var(--kidlee-blue);
  text-align: justify;
  font-family: Poppins, sans-serif !important;
  font-size: 13px !important;
  font-style: normal;
  font-weight: 400;
  line-height: normal;
  margin: 0;
}
.schedule-details {
  margin-top: 16px;
}
.schedule-details .day {
  display: flex;
  width: 88px;
  padding: 12px;
  align-items: center;
  border-radius: 4px;
  background: rgba(88, 185, 152, 0.1);
  color: var(--kidlee-green);
  font-family: Poppins, sans-serif !important;
  font-size: 14px;
  font-style: normal;
  font-weight: 400;
}

.schedule-details > div {
  display: flex;
  align-items: center;
  gap: 20px;
  margin-bottom: 10px;
}

.mission-show .price-container {
  gap: 24px;
}

.tag-item {
  display: flex;
  align-items: center;
  gap: 8px;
  border-radius: 8px;
  background: rgba(88, 185, 152, 0.1);
  padding: 8px 16px;
  color: var(--kidlee-green, #58b998);
  font-family: Poppins !important;
  font-style: normal;
  font-weight: 400;
  line-height: normal;
}

.tag-item span, 
.tag-item p,
.tag-item div {
  color: var(--kidlee-green, #58b998);
  font-family: Poppins !important;
  font-style: normal;
  font-weight: 400;
  line-height: normal;

}

.schedule-details .time-text {
  color: var(--kidlee-blue);
  font-family: Poppins, sans-serif !important;
  font-size: 14px;
  font-style: normal;
  font-weight: 400;
  line-height: normal;
}

.distance-duration-calculator {
  border-radius: 20px;
  background-color: #58b998;
  width: 100%;
  padding: 37px 24px 24px 24px;
  position: relative;
}

.calculator-container {
  gap: 20px;
  display: flex;
  position: relative;
  z-index: 1;
}

.calculator-content {
  display: flex;
  flex-direction: column;
  line-height: normal;
  width: 100%;
  margin-left: 0;
}

.calculator-details {
  display: flex;
  flex-direction: column;
}

.calculator-title {
  color: #fff;
  font: 700 28px DM Sans, sans-serif;
}

.calculator-description {
  color: #fff;
  margin-top: 19px;
  font: 400 16px/24px DM Sans, sans-serif;
}

.calculator-icons {
  align-self: start;
  display: flex;
  margin-top: 19px;
  gap: 16px;
}

.calculator-icon {
  aspect-ratio: 1;
  object-fit: auto;
  object-position: center;
  width: 40px;
}

.calculator-input-container {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-radius: 8px;
  border: 1px solid rgba(217, 217, 217, 1);
  background-color: #fff;
  margin-top: 24px;
  gap: 8px;
  font-size: 11px;
  padding: 4px 8px;
}

.calculator-input-icon {
  aspect-ratio: 1;
  object-fit: auto;
  object-position: center;
  width: 20px;
  align-self: stretch;
  margin: auto 0;
}

.calculator-input-label {
  color: rgba(56, 84, 141, 0.8);
  font-family: Poppins, sans-serif;
  font-weight: 400;
  align-self: stretch;
  flex: 1;
  margin: auto 0;
}

.calculator-button {
  justify-content: center;
  border-radius: 6px;
  background-color: var(--kidlee-green);
  align-self: stretch;
  color: #fff;
  white-space: nowrap;
  padding: 8px;
  border: 1px solid var(--kidlee-green);
  min-width: 65px;
}

.calculator-button span {
  font-family: Poppins, sans-serif !important;
  font-weight: 500;
  font-size: 11px;
}

.calculator-button:hover {
  color: var(--kidlee-green);
  background-color: #fff;
}

.calculator-duration {
  color: #fff;
  align-self: start;
  margin-top: 24px;
  font: 400 16px Poppins, sans-serif;
}

.calculator-distance {
  color: #fff;
  align-self: start;
  margin-top: 8px;
  font: 400 16px Poppins, sans-serif;
}

.calculator-map {
  display: flex;
  flex-direction: column;
  line-height: normal;
  width: 24%;
  margin-left: 20px;
}

.calculator-map-placeholder {
  border-radius: 50%;
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.25) 0%,
    rgba(255, 255, 255, 0) 64.89%
  );
  width: 213px;
  height: 105px;
  margin: 219px auto 0;
}

.calculator-input-container .localisation-input {
  flex: 1;
  color: var(--kidlee-blue);
}

.calculator-input-container .localisation-input input {
  border: none !important;
}

.message-section {
  width: 100%;
}

.message-section textarea {
  width: 100%;
  margin-top: 12px;
  padding: 12px 8px 32px 12px;
  border-radius: 12px;
  border: 1px solid #d9d9d9;
  color: var(--kidlee-blue);
  font-family: Poppins, sans-serif !important;
  font-size: 14px;
  font-weight: 400;
  outline: none;
}

.message-section textarea::placeholder {
  font-size: 13px;
  color: var(--kidlee-light-blue);
}

.calculator-icons .icon {
  height: 32px;
  width: 32px;
  background: #ffffffcc;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}

.calculator-icons .icon.active {
  background: #fff;
}

.bg-circle.bottom-right {
  position: absolute;
  bottom: -7px;
  right: 0;
  z-index: 0;
}

.bg-circle.top-left {
  position: absolute;
  top: -7px;
  left: -38px;
  transform: rotate(180deg);
  z-index: 0;
}

.submit-action.red-btn {
  background: var(--kidlee-red);
  border-color: var(--kidlee-red);
  color: #fff;
}
.submit-action.red-btn:hover {
  background: #fff;
  color: var(--kidlee-red);
}

.info-msg,
.success-msg,
.warning-msg,
.error-msg {
  margin: 10px 0;
  padding: 10px;
  border-radius: 3px 3px 3px 3px;
}
.info-msg {
  color: #059;
  background-color: #bef;
}
.success-msg {
  color: #270;
  background-color: #dff2bf;
}
.warning-msg {
  color: #9f6000;
  background-color: #feefb3;
}
.error-msg {
  color: #d8000c;
  background-color: #ffbaba;
}

.pagination > li > a,
.pagination > li > span {
  cursor: pointer !important;
}

.pagination > .active > span {
  background-color: var(--kidlee-green);
  border-color: var(--kidlee-green);
}
.pagination > .active > a,
.pagination > .active > a:focus,
.pagination > .active > a:hover,
.pagination > .active > span,
.pagination > .active > span:focus,
.pagination > .active > span:hover {
  background-color: var(--kidlee-green) !important;
  border-color: var(--kidlee-green) !important;
}

.page-item img {
  background: var(--kidlee-green) !important;
  height: 100%;
}

.total-results-count {
  color: var(--kidlee-green);
}

.popup-container {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 99;
  overflow: hidden;
  -webkit-overflow-scrolling: touch;
  outline: 0;
  background: rgba(0, 0, 0, 0.12);
  backdrop-filter: blur(2px);
}

.popup-container .popup-body {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background-color: #fff;
  border-radius: 12px;
  display: flex;
  flex-direction: column;
  width: 700px;
  max-height: 90vh;
  overflow-x: hidden;
  overflow-y: auto;
  padding: 32px;
}

.popup-container .header {
  color: #38548d;
  display: flex;
  font-size: 15px;
  font-weight: 500;
  gap: 20px;
  justify-content: space-between;
  align-items: center;
  line-height: 26px;
}

.popup-container .content #icon {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 110px;
  min-width: 110px;
  background: #58b99826;
  border-radius: 25px;
}

.confirmation-input .geocomplete {
  min-height: 48px !important;
  border-radius: 8px !important;
  border: 0.64px solid #d9d9d9 !important;
  background: #fff !important;
}

.error-message {
  color: red;
  display: block;
  text-align: left;
}

/** media queries */
@media (max-width: 991px) {
  .row-section {
    flex-direction: column;
    gap: 24px;
    width: 100%;
  }
  .price-container {
    gap: 24px;
  }

  .filtre-recherche-prestation .disponibilities {
    gap: 0;
  }

  .filter-actions {
    flex-direction: column;
  }

  .filter-actions button {
    width: 100%;
  }
}

@media (max-width: 831px) {
  #filter-collapse form {
    flex-direction: column;
  }

  #filter-collapse form > .filtre-recherche-prestation {
    flex: 1 1 100%;
    width: 100%;
  }
  .filtre-recherche-prestation .disponibilities {
    gap: 30px;
  }
}

@media (max-width: 768px) {
  .collapse-href {
    padding: 1.5rem;
  }
  .dev-section .section-body {
    padding: 0 !important;
  }
}

@media (max-width: 500px) {
  .card-header {
    flex-direction: column;
  }
  .child {
    flex-direction: column;
    gap: 2px;
  }
  .card-body .left-section {
    min-width: 100%;
  }
}
