/*===================== REUSABLE  CSS AREA START =====================*/
@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@100..900&family=Rubik:ital,wght@0,300..900;1,300..900&display=swap');
@import url('variables.css');

/* font-family: "Rubik", sans-serif;
font-family: "Outfit", sans-serif; */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}


ul,ol {
  padding: 0;
  margin: 0;
  list-style: none;
}

button,
input,
textarea {
  border: none;
  outline: none;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0;
  padding: 0;
  font-family: "Outfit", sans-serif;

}
h1 {
  font-size: var(--f36);
}
h2 {
  font-size: var(--f32);
  font-weight: 600;
}
h3 {
  font-size: var(--f28);
}

h4 {
  font-size: var(--f25);
}

h5 {
  font-size: var(--f20);
  margin-bottom: 6px;
  font-weight: 600;
}

h6 {
  font-size: var(--f16);
  margin-bottom: 4px;
}
p {
  margin: 0;
  padding: 0;
}

a {
  text-decoration: none;
}
a:hover {
  color: initial !important;
}
.mb {
  overflow: hidden !important;
  margin-bottom: 80px;

}
.new-mb-main{
  overflow: hidden;
  padding-left: 9px;
}
.btns {
  text-decoration: none;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--theme_color);
  border-radius: 35px;
  color: var(--white);
  font-family: "Rubik", sans-serif;
  transition: .3s ease-in-out;
}
.btns:hover {
  color: var(--theme_color) !important;
  background-color: transparent !important;
  border: 1px solid var(--theme_color);
}
.btns.disabled {
  background-color: #cccccc !important;
  color: #666666 !important;
  cursor: not-allowed !important;
  pointer-events: none !important;
  opacity: 0.6 !important;
}
.btns.disabled:hover {
  background-color: #cccccc !important;
  color: #666666 !important;
  border: none !important;
}
img {
  width: 100%;
  height: auto;
  object-fit: cover;
}

.play-center {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
}
.owl-carousel .owl-stage {
  transition-timing-function: linear !important;
}
.hero__single__slide a:hover img,.enrich__single__slide a:hover img {
  filter: brightness(0.7);
}
main {
  overflow: hidden !important;
}
.modal.show .modal-dialog {
  padding: 20px 18px !important;
}
.modal {
  z-index: 999999999;
}

.container,
.container-lg,
.container-md,
.container-sm,
.container-xl,
.container-xxl {
  max-width: 1698px;
  margin: 0 auto;
  padding: 0px 26px;
}
/*===================== REUSABLE CSS AREA END =====================*/
.display__bottom {
  position: fixed;
  bottom: 0px;
  left: 0px;
  background-color: var(--bgGrayLight);
  height: 82px !important;
  width: 100%;
  padding: 20px 30px 28px;
  display: flex;
  align-items: center;
  justify-content: space-around;
  z-index: 999999999;
}
.display__bottom> a {
  font-family: Rubik;
  background-color: var(--theme_color);
  border-radius: 45px;
  height: 54px;
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--white);
}

.display__bottom a:hover {
  color: var(--white) !important;
  opacity: 0.9;
}
.display__bottom a:first-child {
  font-size: var(--f25);
  padding: 0px 41px;
}
.display__bottom a:last-child {
  background-color: var(--theme_color);
  border-radius: 45px;
  gap: 6px;
  padding: 0px 12px;
  font-size: var(--f20);

}

/*===================== HEADER CONTACT MOBILE BUTTONS =====================*/
.header__contact-mobile {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

.header__contact-btn {
  background-color: var(--white);
  border: 1px solid var(--gray-E3E3E3);
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  transition: all 0.2s;
}

.header__contact-btn:hover {
  background-color: var(--gray-E3E3E3);
}

.header__contact-btn img {
  width: 16px;
  height: 16px;
}

/*===================== HEADER CSS AREA START =====================*/
.header__area {
  position: sticky;
  top: 0;
  background-color: var(--white);
  z-index: 1000;
  transition: all 0.3s ease-in-out;
  box-shadow: 0 2px 10px var(--black-opacity-10) !important;
}
.header__wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-bottom: 10px;
  font-family: "Rubik", sans-serif;
  transition: all 0.3s ease-in-out;
}

/* Scrolled state - compact layout */
.header__area.scrolled {
  padding-top: 5px;
}

.header__area.scrolled .header__wrap {
  padding-bottom: 5px;
}

.header__area.scrolled .logo {
  display: flex !important;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
}

.header__area.scrolled .logo span {
  display: inline-block !important;
  margin-bottom: 0;
  font-size: var(--f12);
  white-space: nowrap;
}

.header__area.scrolled .logo br {
  display: none;
}

.header__area.scrolled .logo a img {
  width: 120px;
  margin-top: 0;
  flex-shrink: 0;
}

.header__area.scrolled .logo2 {
  flex-direction: row;
  gap: 12px;
  margin-left: 30px;
  align-items: center;
  flex-wrap: nowrap;
  flex-shrink: 1;
  min-width: 0;
}

.header__area.scrolled .org-header-desktop {
  gap: 8px;
  order: 2;
  min-width: 0;
  flex-shrink: 1;
}

.header__area.scrolled .org-logo-desktop {
  width: 50px;
  max-height: 50px;
  flex-shrink: 0;
}

.header__area.scrolled .org-name-desktop {
  font-size: var(--f16);
  white-space: nowrap;
}

.header__area.scrolled .org-info-icon {
  margin-left: 6px;
}

.header__area.scrolled .org-info-icon img {
  width: 16px;
  height: 16px;
}

.header__area.scrolled .logo2 > img {
  width: 100px;
  order: 2;
}

.header__area.scrolled .logo2 > h3 {
  order: 2;
  font-size: var(--f16);
  margin: 0;
  white-space: nowrap;
}

.header__area.scrolled .header__btns .btns {
  transform: scale(0.9);
}

.header__area.scrolled .header__btns .h-btn {
  transform: scale(0.9);
}

.venoratio.venoratio-16x9.vbox-child {
  background-color: transparent !important;
}

/* Maximize video display - AGGRESSIVE MODE for all videos */

/* Override ALL venobox max-width constraints */
.vbox-overlay {
  --vbox-max-width: 100vw !important;
}

/* Force container to take up almost full screen */
.vbox-container {
  padding: 0 !important;
}

.vbox-content {
  padding: 0 !important;
  min-height: 100vh !important;
}

/* FORCE all video containers to be LARGE - applies to ALL videos */
.vbox-child,
.vbox-child.venoratio,
.venoratio,
.vbox-inline {
  min-width: 85vw !important;
  min-height: 85vh !important;
  width: 90vw !important;
  max-width: 95vw !important;
  max-height: 95vh !important;
  position: relative !important;
  margin: auto !important;
}

/* Landscape videos (16:9, 21:9) - prioritize WIDTH */
.venoratio-16x9.vbox-child,
.venoratio-16x9,
.venoratio-21x9.vbox-child,
.venoratio-21x9 {
  width: 90vw !important;
  height: calc(90vw * 9 / 16) !important;
  max-height: 85vh !important;
  min-width: 85vw !important;
}

/* If height constraint is hit, recalculate width */
@supports (aspect-ratio: 16 / 9) {
  .venoratio-16x9.vbox-child,
  .venoratio-16x9 {
    aspect-ratio: 16 / 9 !important;
    width: min(90vw, calc(85vh * 16 / 9)) !important;
    height: auto !important;
    max-width: 95vw !important;
    max-height: 85vh !important;
  }
}

/* Portrait videos (9:16) - prioritize HEIGHT */
.venoratio-9x16.vbox-child,
.venoratio-9x16 {
  height: 85vh !important;
  width: calc(85vh * 9 / 16) !important;
  max-width: 90vw !important;
  min-height: 80vh !important;
}

@supports (aspect-ratio: 9 / 16) {
  .venoratio-9x16.vbox-child,
  .venoratio-9x16 {
    aspect-ratio: 9 / 16 !important;
    height: min(85vh, calc(90vw * 16 / 9)) !important;
    width: auto !important;
    max-width: 90vw !important;
    max-height: 90vh !important;
  }
}

/* 4:3 videos */
.venoratio-4x3.vbox-child,
.venoratio-4x3,
.venoratio-1x1.vbox-child,
.venoratio-1x1 {
  width: 85vw !important;
  height: calc(85vw * 3 / 4) !important;
  max-height: 85vh !important;
}

/* CRITICAL: Make iframe fill its container */
.vbox-child > iframe,
.venoratio > iframe,
.vbox-inline > iframe {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 100% !important;
  border: none !important;
}

/* Mobile: Even more aggressive */
@media (max-width: 768px) {
  .vbox-child,
  .vbox-child.venoratio,
  .venoratio {
    min-width: 95vw !important;
    min-height: 50vh !important;
  }

  .venoratio-16x9.vbox-child,
  .venoratio-16x9 {
    width: 95vw !important;
    height: calc(95vw * 9 / 16) !important;
  }

  .venoratio-9x16.vbox-child,
  .venoratio-9x16 {
    height: 80vh !important;
    width: calc(80vh * 9 / 16) !important;
  }
}

.logo a img {
  width: 199px;
  margin-top: 7px;
}

.logo span {
  font-size: var(--f14);
  font-weight: 300;
}
.logo__campaign img {
  width: 95px;
}

.logo__campaign {
  align-items: center;
  gap: 5px;
  font-size: var(--f12);
  font-weight: 300;
  margin-top: -5px;
  flex-wrap: nowrap;
}

.logo__campaign span {
  white-space: nowrap;
}
.logo2 {
  display: flex;
  flex-direction: column;
  gap: 7px;
  align-items: center;
  margin-left: 100px;
}

.logo2 > img {
  width: 177px;
}

.org-header-desktop {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 15px;
  flex-wrap: nowrap;
}

.org-logo-desktop {
  width: 100px;
  max-height: 80px;
  object-fit: contain;
  flex-shrink: 0;
  padding-top: 5px;
}

.org-name-desktop {
  margin: 0;
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--black);
  line-height: 1.2;
}

.org-name-clickable {
  cursor: pointer;
  transition: color 0.2s;
}

.org-name-clickable:hover {
  color: var(--theme_color);
}

.org-info-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-left: 8px;
  flex-shrink: 0;
  align-self: flex-start;
  margin-top: 2px;
}

.org-info-icon img {
  width: 20px;
  height: 20px;
  transition: opacity 0.2s;
}

.org-info-icon:hover img {
  opacity: 0.7;
}

/* Hide mobile org info by default (shown only on mobile via media query) */
.org-info-mobile {
  display: none;
}

.org-header-mobile {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 12px;
}

.org-logo-mobile {
  max-width: 80px;
  max-height: 50px;
  object-fit: contain;
  flex-shrink: 0;
  padding-top: 5px;
}

.org-name-mobile {
  margin: 0;
  font-size: 1rem;
  font-weight: 600;
  color: var(--black);
  line-height: 1.3;
}

.logo__campaign-mobile {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 5px;
  margin-top: 8px;
  white-space: nowrap;
}

.logo__campaign-mobile span {
  font-size: var(--f11);
  color: var(--gray-dark);
}

.logo__campaign-mobile img {
  max-width: 80px;
}

.header__btns {
  display: flex;
  align-items: center;
  justify-content: end;
  gap: 11px;
  flex-shrink: 0;
}

/* Reduced gap for scrolled state on desktop */
@media (min-width: 992px) {
  .header__area.scrolled .header__btns {
    gap: 6px;
  }

  /* Ensure header stays in one line on all desktop screens */
  .header__area.scrolled .header__wrap {
    flex-wrap: nowrap;
    gap: 8px;
  }
}
.header__btns button {
  font-size: var(--f14);
  width: 84px;
  align-items: center;
  justify-content: center;
  padding: 0px 12px;
}
.h-btn {
  border: 1px solid var(--textGrayLight);
  border-radius: 30px;
  padding: 0px;
  height: 40px;
  position: relative;
}

a.btns.h-btn {
  background: transparent;
  color: var(--black);
  gap: 10px;
  font-size: var(--f14);
  align-items: center;
}
.h-lang .nice-select {
  line-height: 40px;
  padding: 0px 16px 0px 45px;
  background-color: transparent;
  position: relative;
  z-index: 2;
}
.header__btns div.h-btn > img {
  width: 28px;
  height: 15px;
  flex-shrink: 0;
  position: absolute;
  top: 50%;
  left: 12px;
  transform: translateY(-50%);
}
.nice-select:after {
  display: none;
}
.nice-select .list {
  width: 100%;
}
.monthly__installment .h-btn .nice-select .list {
  width: auto !important;
}
.nice-select {
  padding: 0px;
  border: none;
  font-size: var(--f17);
  height: 100%;
  border-radius: 40px;
  width: 100%;
  display: flex;
  align-items: center;
  position: relative;
  z-index: 2;
  background-color: transparent !important;
}
.header__wrap > .h-btn {
  flex-shrink: 0;
  width: 67px;
  height: 40px;
  position: relative;
}
.header__wrap > .h-btn .select__marker {
  right: 13px;
  width: 13px;
}
.header__btns div.h-btn {
  width: 103px;
  position: relative;
}

.nice-select ~ .select__marker {
  position: absolute;
  top: 50%;
  right: 14px;
  transform: translateY(-50%);
  width: 13px;
  z-index: 0;
}
/* 
.nice-select.open ~ .select__marker {
  transform: translateY(-50%) rotate(180deg);
} */

a.btns.donate-btn {
  height: 40px;
  width: 189px;
  font-size: var(--f17);
}
/*===================== HEADER CSS AREA END =====================*/

/*===================== DONATIONS CSS AREA START =====================*/
.skill-wrrap {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.skill-wrrap .skill-name {
  color: var(--white);
  font-size: var(--f18);
  font-weight: 500;
}
.skill-wrrap .skill-bar {
  height: 20px;
  background-color: var(--blue-dark);
  border-radius: 8px;
}
.skill-wrrap .skill-per {
  height: 100%;
  background: var(--theme_color);
  border-radius: 8px;
  width: 0;
  transition: 1s linear;
  position: relative;
}
.skill-wrrap .skill-per:before {
  content: attr(per);
  position: absolute;
  padding: 4px 6px;
  font-size: var(--f16);
  border-radius: 4px;
  right: 8px;
  bottom: -32px;
  transform: translateX(50%);
}
.skill-wrrap .skill-per:after {
  content: "";
  position: absolute;
  width: 21px;
  height: 21px;
  background-color: var(--secondaryColor);
  top: 50%;
  right: -10.5px; /* Center the circle on the progress bar edge (half of 21px) */
  transform: translateY(-50%) rotate(45deg);
  border-radius: 50%;
}

/* Disabled progress bar styles when there's no goal */
.skill-wrrap--disabled .skill-bar {
  background-color: #e8e8e8 !important;
  opacity: 0.6;
}

.skill-wrrap--disabled .skill-per--disabled {
  background: #d0d0d0 !important;
  width: 0 !important;
}

.skill-wrrap--disabled .skill-per--disabled:before,
.skill-wrrap--disabled .skill-per--disabled:after {
  display: none;
}

.donations__wrap {
  padding: 17px 0px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0;
}
.donations__wrap *,.contribute__title *,.contribute__wrap * {
  font-family: "Outfit", sans-serif;
}
.days__load1 {
  max-width: 203px;
  width: 100%;
  position: relative;
}
.days__load1 > span {
  position: absolute;
  top: 24%;
  left: 31%;
  width: 54px;
  height: 40px;
  border-radius: 7px;
  background-color: var(--secondaryColor);
  color: var(--white);
  font-weight: 600;
  text-align: center;
  line-height: 40px;
}
.days__load1 > span:after {
  content: '';
  position: absolute;
  top: 50%;
  right: -10px;
  width: 18px;
  height: 18px;
  transform: translateY(-50%);
  clip-path: polygon(0 0, 0% 100%, 100% 50%);
  background-color: var(--secondaryColor);
}
.days__load svg {
  max-width: 203px;
}
section.donations__area {
	background: var(--bgGrayLight);
	overflow: hidden;
}

/* Ambassador/Team profile styles (generic names) */
.ambassador__info {
  display: flex;
  align-items: start;
  gap: 20px;
  flex-shrink: 0;
  margin-right: 84px;
  position: relative;
}

.ambassador__info img {
  width: 130px;
}
.ambassador__details button {
  width: 12px;
  position: absolute;
  right: 10px;
  bottom: 21px;
  background: transparent;
}
.ambassador__details button img {
  width: 12px;
}
.ambassador__message {
  display: block;
  overflow: hidden;
}
.ambassador__message.active {
  margin-top: 15px;
}
.ambassador__message.active ~ button {
  bottom: 0px;
}

/* Ambassador message truncation styles */
.ambassador-message-container {
  margin-top: 10px;
}

.ambassador-message-wrapper {
  position: relative;
}

.ambassador-message-wrapper p {
  margin: 0;
  line-height: 1.5;
  word-wrap: break-word;
  word-break: break-word;
}

.ambassador-message-preview,
.ambassador-message-full {
  white-space: pre-wrap;
}

.ambassador-message-toggle {
  display: inline-block;
  margin-top: 5px;
  font-size: 0.9em;
  cursor: pointer;
  color: var(--theme_color, #6c757d);
  text-decoration: underline;
  user-select: none;
}

.ambassador-message-toggle:hover {
  opacity: 0.8;
}

/* Mobile and tablet responsive adjustments */
@media (max-width: 1094px) {
  .ambassador-message-container {
    margin-top: 8px;
  }

  .ambassador-message-wrapper p {
    font-size: 0.95em;
  }

  .ambassador-message-toggle {
    font-size: 0.85em;
    margin-top: 8px;
  }
}

@media (max-width: 767px) {
  .ambassador-message-container {
    margin-top: 6px;
  }

  .ambassador-message-wrapper {
    text-align: center;
  }

  .ambassador-message-wrapper p {
    font-size: 0.9em;
    text-align: left;
  }

  .ambassador-message-toggle {
    display: block;
    font-size: 0.8em;
    margin-top: 8px;
    margin-bottom: 12px;
    text-align: center;
  }
}

.ambassador__details {
  max-width: 427px;
}
.ambassador__details p {
  color: var(--black);
  font-family: Outfit;
  font-size: var(--f16);
  font-weight: 300;
  line-height: 24px;
}
.ambassador__details span {
  font-size: var(--f17);
  font-weight: 300;
}

.ambassador__details h2 {
  font-size: var(--f30);
  color: var(--secondaryColor);
}

/* Legacy class names for backward compatibility */
.laurie {
  display: flex;
  align-items: start;
  flex-shrink: 0;
  position: relative;
}

.laurie img {
  width: 130px;
}
.laurie__text {
  display: block;
  margin-top: 15px;
}
.about__laurie {
  max-width: 427px;
}
.about__laurie p {
  color: var(--black);
  font-family: Outfit;
  font-size: var(--f16);
  font-weight: 300;
  line-height: 24px;
}
.about__laurie span {
  font-size: var(--f17);
  font-weight: 300;
}

.about__laurie h2 {
  font-size: var(--f30);
  color: var(--secondaryColor);
}

.donation__time {
  flex-shrink: 0;
  width: 100%;
}

.goal__donations {
  max-width: 425px;
  width: 100%;
}

.goal__donations__title {
  display: flex;
  align-items: start;
  justify-content: space-between;
  margin-bottom: 4px;
}

.goal__donations__title h2 {
  font-size: var(--f30);
  line-height: 23px;
  margin-right: 10px;
}

.goal__donations__title h2 span {
  font-size: var(--f16);
}

.goal__donations__title h2:last-child {
  text-align: end;
}

.skill-bar {
  height: 13px !important;
  background: var(--gray-light) !important;
}


.donation__goal__time {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0;
  width: 100%;
  flex-wrap: nowrap;
}

/* When there's no goal, keep same equal spacing */
.donation__goal__time.no-goal {
  gap: 15px; /* SAME gap as with goal */
}

.donation__times {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  flex-wrap: nowrap;
  gap: 0;
  width: 100%;
}

/* Always align donors section to the right */
.donors5 {
  margin-left: auto;
}

/* Visit main page button styling */
.visit-main-page-btn {
  background-color: var(--theme_color);
  color: var(--white);
  padding: 12px 30px;
  text-decoration: none;
  border-radius: 5px;
  font-weight: 600;
}

/* Style for goal__donations when there's no goal */
.goal__donations--no-goal {
  max-width: 200px;
}

.goal__donations--no-goal .goal__donations__title {
  justify-content: flex-start;
}

.goal__donations--no-goal .goal__donations__title h2 {
  text-align: start;
}

.days__clock {
  position: relative;
}

.days__clock1 {
  display: flex;
  align-items: center;
  gap: 10px;
  width: auto;
  flex-shrink: 0;
  max-width: 338px; /* Limit countdown width */
  margin-left: clamp(15px, 3vw, 60px); /* RESPONSIVE margin */
}

/* When there's a goal with progress bar, need more margin */
.donation__goal__time:has(.goal__donations:not(.goal__donations--no-goal)) .days__clock1 {
  margin-left: clamp(30px, 5vw, 100px); /* RESPONSIVE margin when progress bar is present */
}

.days__clock1 .clock #hrs, .days__clock1 .clock #min, .days__clock1 .clock #sec {
  font-size: var(--f34) !important;
  font-weight: bold;
  display: inline-block;
  text-align: center;
  position: relative;
  margin: 0px !important;
}

.days__clock1 .clock span {font-size: var(--f25);}

.days__clock1 .clock span::after {
  font-size: var(--f12) !important;
  font-weight: 300;
}
.separator1 {
  width: 0px;
}
.countdown1 #js-days:after, .countdown1 #js-hours:after, .countdown1 #js-minutes:after, .countdown1 #js-seconds:after {
  color: var(--black);
  font-family: Outfit;
  font-size: var(--f12_184);
  font-style: normal;
  font-weight: 500;
  bottom: -24px;
}
.number.numbers {
  color: var(--black);
  text-align: center;
  font-family: Outfit;
  font-size: var(--f34_484) !important;
  font-style: normal;
  font-weight: 600;
}
.days__clock1 .countdown {
  display: flex;
  max-width: 250px;
  width: 100%;
  margin: 0px;
}
/* Ambassador profile container */
.ambassador__profile {
  flex-shrink: 0;
}
.ambassador__progress {
  /* Inherits from parent styles */
}

/* Legacy class names */
.laurie__liam {
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.view-donors-btn {
  background: transparent;
  align-self: center;
  margin-top: auto;
  padding: 0;
  cursor: pointer;
}


.donation__times button span:last-child {
  text-decoration: underline;
}

.donation__times button {
  background: transparent;
}

.days__clock1 img {
  width: 95px;
}
.btn-close1 {
  box-sizing: content-box;
  width: auto;
  height: auto;
  padding: .25em .25em;
  color: var(--black);
  background: none !important;
  border: 0;
  /* border-radius: .375rem; */
  opacity: 1;
}
.donation__times > button {
  margin-top: 18px;
}

.donors5 {
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 0;
}

.goal__donations {
  flex-shrink: 0;
  min-width: 0;
}

/* Mobile View Donors button */
.view-donors-mobile-btn {
  background-color: transparent;
  font-family: "Rubik", sans-serif;
  font-size: 14px;
  margin-top: 12px;
}


/*===================== DONATIONS CSS AREA END =====================*/

/*===================== HERO CSS AREA START =====================*/
.mfp-iframe-holder .mfp-content {
  line-height: 0;
  width: 98% !important;
  max-width: 98% !important;
}

section.hero__area {
  background-image: var(--bannerGradient);
  padding: 69px 0px 53px;
  position: relative;
  margin-bottom: 17px;
}
.hero__single__slide,.enrich__single__slide {
  position: relative;
}
.hero__single__slide,.hero__single__slide img {
  border-radius: 10px !important;
}
.hero__slider  .owl-stage-outer {
  padding: 12px 0px;
}
.hero__slider .owl-stage-outer .owl-stage .owl-item.active {
  border-radius: 10px;
  overflow: hidden;
  transform: scale(1.2);
}

.hero__slider .owl-stage-outer .owl-stage {
  padding: 55px 0px;
}
.hero__single__slide.slick-slide.slick-current.slick-active.slick-center {
  transform: scale(1.2);
  /* padding: 30px 0px; */
  /* border-radius: 10px; */
  padding: 0px 140px;
}







.slick .hero__single__slide {
  display: block;
  background: var(--black);
  color: var(--white);
  font-size: var(--f36);
  height: 10wh;
  line-height: 30vh;
	  line-height: 120px;
  position: relative;
  text-align: center;
  transform: translate(0, 0) scale(0.4);
  transition: all 0.4s ease;
  opacity: 0.8;
/*   background: url('https://i.picsum.photos/id/174/536/354.jpg?hmac=BfySTNvwCB_IZZueijD4RPBFgdEyPtIJRFTotFQ7Bz0'); */
  background-repeat: no-repeat;
  background-size: 40vw 40vh;
  border-radius: 10px;
}

/* .slick-slide {
  border: solid 1px var(--success-2dc37f);
}
 */
.slick-slide.lt2 .hero__single__slide{
  transform: translate(10%, 0) scale(0.6);
}

.slick-slide.lt1 .hero__single__slide{
  opacity: 0.7;
  transform: translate(5%, 0) scale(0.8);
}

.slick-slide.gt1 .hero__single__slide{
  opacity: 0.7;
  transform: translate(-5%, 0) scale(0.8);
}

.slick-slide.gt2 .hero__single__slide{
  transform: translate(-10%, 0) scale(0.6);
}

.slick-slide.slick-center .hero__single__slide{
  z-index: 1;
  transform: scale(1);
  opacity: 1;
  border-radius: 10px !important;
}


/* Custom added CSS */
.main-wrapper-box {
  position:relative; 
  width: 100%;
  
}




/*===================== HERO CSS AREA END =====================*/

/*===================== OTHER-MEDIA CSS AREA START =====================*/
.enrich__area {
  margin-bottom: 32px;
}
.enrich__single__slide a {
  width: 54px !important;
}
.enrich__btn > .btns {
  height: 58px;
  border-radius: 35px;
  background-color: var(--theme_color);
  color: var(--white);
  font-size: var(--f20);
  font-weight: 500;
  max-width: 336px;
  width: 100%;
  margin: 15px auto 17px;
}
.modal-dialog-380 {
  max-width: 100% !important;
}

.modal-dialog-380 .modal-content {
  background: var(--bgGrayLight) !important;
}

.modal-dialog-380 .modal-content .modal-body {
  padding: 0px 22px 39px !important;
}
.modal__body.modals__bodys {
  margin: 32px 0px -40px;
}
.empower__content h2 {
  color: var(--black);
  font-size: var(--f35);
  font-weight: 600;
  line-height: 120%; /* 42px */
  margin-bottom: 18px;
}

.empower__content p {
  color: var(--black);
  font-size: var(--f16);
  font-weight: 300;
  line-height: 158.9%; /* 25.424px */
}

.empower__content {
  margin-bottom: 45px;
}

.modal__body > .btns {
  width: 189px;
  padding: 10px;
}
/*===================== OTHER-MEDIA CSS AREA END =====================*/

/*===================== PRESET-DONATIONATIONS CSS AREA START =====================*/
.sponsor__child__area {
  text-align: center;
}

.sponsor__child__slider {
  padding: 0px 60px;
}

.sponsor__child__slider .owl-stage-outer {
  display: flex;
  justify-content: center;
}

.sponsor__child__slider .owl-stage {
  display: flex !important;
  justify-content: center;
}

.sponsor__child__single__slide {
  background: var(--bgGrayLight);
  display: flex;
  flex-direction: column;
  text-align: center;
  align-items: center;
  justify-content: center;
  padding: 18px 24px 28px;
  border-radius: 10px;
  font-family: "Rubik", sans-serif;
  height: 272px;
}
.sponsor__child__single__slide h4 {
  color: var(--black);
  font-size: var(--f25);
  font-weight: 600;
  line-height: 136.935%;
}
.sponsor__child__single__slide img {
  width: 87px !important;
}

.sponsor__child__single__slide span {
  font-size: var(--f17);
  margin: 16px 0px 10px;
  min-height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.sponsor__child__single__slide a {
  height: 40px;
  width: 100% !important;
  max-width: 150px;
  margin-top: 20px;
  font-size: var(--f17);
  display: inline-block;
  text-align: center;
  line-height: 40px;
  padding: 0 20px;
}

.sponsor__child__slider .owl-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}

.sponsor__child__slider .owl-nav button.owl-prev {
  left: 0px;
}

.sponsor__child__slider .owl-nav button.owl-next {
  right: 0px;
}

.sponsor__child__slider .owl-nav button {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}
.owl-theme .owl-nav [class*=owl-]:hover {
  background: transparent !important;
}
/*===================== PRESET-DONATIONATIONS CSS AREA END =====================*/

/*===================== MATCHER CSS AREA START =====================*/
.matcher__wrap {
  padding: 0px 38px;
}
.matcher__content {
  font-family: "Outfit", sans-serif;
}
.matcher__content span {
  text-transform: uppercase;
  font-size: var(--f20);
  font-weight: 600;
  color: var(--secondaryColor);
}

.matcher__content h2 {
  font-size: var(--f40);
  margin-top: 7px;
  font-weight: 600;
}
.matcher__slider {
  display: flex !important;
  flex-direction: column-reverse;
  align-items: start;
  gap: 35px;
}
.owl-nav {
  margin-top: 0px !important;
}
/*===================== MATCHER CSS AREA END =====================*/

/*===================== DONATION CSS AREA START =====================*/
.contribute__area {
  position: relative;
}
.contribute__title {
  margin-bottom: 29px;
  text-align: center;
}

.contribute__title a {
  max-width: 524px;
  height: 65px;
  margin: 29px auto 0px;
  font-size: var(--f31);
  font-weight: 600;
}

.contribute__wrap {
  background: var(--bgGrayLight);
  max-width: 1450px;
  margin: 0 auto;
  padding: 44px;
  border-radius: 10px;
  position: relative;
}

.contribute__wrap::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
  width: 1px;
  height: 85%;
  background: var(--gray-medium);
}

/* Hide divider line when countdown is not shown */
.contribute__wrap--no-countdown::after {
  display: none;
}

/* Reduce container width when countdown is not shown */
.contribute__wrap--no-countdown {
  max-width: 900px;
}

/* Center content when countdown is not shown */
.contribute__wrap--no-countdown .contribute__load {
  max-width: 700px;
  margin: 0 auto;
}

.contribute__wrap--no-countdown .donate__received__title {
  justify-content: center;
  gap: 60px;
}

/* ===================== ABOUT CAMPAIGN SECTION STYLING ===================== */
/* Match contribute__wrap--no-countdown styling exactly */
.about-campaign__wrap {
  background: var(--bgGrayLight);
  max-width: 900px;
  margin: 0 auto;
  padding: 44px;
  border-radius: 10px;
  position: relative;
}

.about-campaign__content {
  max-width: 700px;
  margin: 0 auto;
}

.about-campaign__content .team__single__content:first-child {
  margin-bottom: 38px;
}

/* ===================== SUMMARY DONATION SECTION STYLING ===================== */
/* Always center summary donation section */
.summary-donation__wrap {
  max-width: 100%;
  margin: 0 auto;
}

.days__counts {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
}

.days__clock {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 34px;
  width: 100%;
}

.days__clock img {
  width: auto;
}

.donate__received__title {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 80px;
  margin-bottom: 34px;
  padding-left: 0;
}

.donate__received {
  color: var(--secondaryColor);
}

.donate__received span,.donor-5 span {
  font-size: var(--f20);
}

.donate__received h2, .donor-5 h2 {
  font-size: var(--f46);
  font-weight: 600;
  line-height: 100%;
}





.donor-5 {
  text-align: end;
}

/* Center donor count when it's the only child (when show_raised_amount is false) */
.donate__received__title .donor-5:only-child {
  text-align: center;
  width: 100%;
}

.section2__progressBarContainer h4 {
  margin-bottom: 10px;
  text-align: center;
  color: var(--black);
  font-size: var(--f25);
  font-weight: 400;
  line-height: 136.935%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 3px;
  white-space: nowrap;
}
.goal__original {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 8px;
}

.goal__original span {
  color: var(--black);
  font-size: var(--f18);
  font-weight: 400;
  line-height: 136.935%; /* 24.648px */
}

.section2__progressBarContainer h4 img {
  width: auto;
}
.contribute__load > .section2__progressBarContainer {
  max-width: 400.696px;
  margin: 0 auto;
}

.clock {
  display: flex;
  align-items: end;
  gap: 5px;
}
.clock span {
  font-size: var(--f31);
  font-weight: 300;
  margin-bottom: 6px;
}

.clock #secs {
  font-weight: 400 !important;
}
.clock #hrss,.clock #mins,.clock #secs,.number {
  font-size: var(--f50);
  font-weight: bold;
  display: inline-block;
  text-align: center;
  position: relative;
  margin: 0px !important;
}
.separator {
  color: var(--black);
  text-align: center;
  font-family: Outfit;
  font-size: var(--f31_71);
  font-style: normal;
  font-weight: 300;
}
.clock span::after {
  font-size: var(--f15);
  font-weight: 500;
  position: absolute;
  bottom: -7px;
  left: 50%;
  transform: translateX(-50%);
}
#hrs::after {
  content: "HOURS";
}
#min::after {
  content: "MINS";
}
#sec::after {
  content: "SECS";
}
#hrss::after {
  content: "HOURS";
}
#mins::after {
  content: "MINS";
}
#secs::after {
  content: "SECS";
}
/*===================== DONATION CSS AREA END =====================*/

/*===================== OTHER-MEDIA CSS AREA START =====================*/
/* .mind__slider .owl-stage-outer {
  margin-left: -128px;
} */

.mind__slider .owl-stage-outer .owl-stage {
  margin-left: 480px;
}
.mind__slider {
  max-width: 94%;
  margin: 0 auto;
}

.mind__slider .owl-stage-outer {
  margin-left: -90px;
  margin-right: -110px;
}
.mind__slider .owl-dots {
  display: none;
}
.issue__receipt {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
}

.name__company__select,.nc__select {
  display: flex;
  align-items: center;
}

.name__company__select {
  gap: 15px;
}
.issue__receipt h6 {
  margin: 0px;
}
.nc__select {
  gap: 6px;
}
.nc__select label{
  font-weight: 400;
}
.nc__radio {
  position: relative;
  width: 19px;
  height: 19px;
  border: 0.75px solid var(--gray-8E8D8D);
  border-radius: 50%;
  flex-shrink: 0;
}

.nc__radio input {
  position: absolute;
  inset: 0;
  opacity: 0;
}
.nc__radio span {
  position: absolute;
  inset: 3px;
  border: 2px solid var(--gray-medium-dark);
  border-radius: 50%;
  background: var(--black);
  display: none;
}

.nc__radio input:checked ~ span {
  display: block;
}
/*===================== OTHER-MEDIA CSS AREA END =====================*/

/*===================== ABOUT CAMPAIGN CSS START =====================*/
.team__content {
  background: var(--bgGrayLight);
  border-radius: 10px;
  padding: 39px 40px 47px 29px;
  margin-right: 7px;
}

.team__single__content h2 {
  margin-bottom: 12px;
  color: var(--black);
  font-size: var(--f40);
  font-weight: 600;
  line-height: 120%;
}
.team__single__content p {
  font-size: var(--f18);
  font-weight: 300;
  line-height: 158.9%;
  font-family: "Rubik", sans-serif;
}

.team__content .team__single__content:first-child {
  margin-bottom: 38px;
}
/*===================== ABOUT CAMPAIGN CSS START =====================*/

/*===================== SUMMARY DONATION CSS START =====================*/

.team__all__cards * {
  font-family: "Rubik", sans-serif;
}
.team__single__content a {
  width: 189px;
  height: 40px;
  text-transform: uppercase;
  margin-top: 15px;
}

.creat__team {
  margin-bottom: 27px;
  text-align: end;
}

.creat__team button {
  text-decoration: underline;
  color: var(--black);
  font-size: var(--f20);
  background-color: transparent;
}

.team__btns,.team__donors__btn {
  display: grid;
  grid-template-columns: repeat(2,1fr);
  gap: 22px;
}
.team__btns {
  margin-bottom: 18px;
}
.team__donors__btn li {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
}
.team__donors__btn .btns {
  width: 100%;
  border: 1px solid var(--gray-E3E3E3);
  background: var(--white) !important;
  color: var(--black) !important;
  height: 50px;
  font-size: var(--f20);
}

.team__donors__btn .btns.active {
  background: var(--theme_color) !important;
  color: var(--white) !important;
}

/* When only one tab button exists, make it full width */
.team__donors__btn li:only-child {
  grid-column: 1 / -1;
}

.team__donors__search .search__teams img {
  width: 16px;
}
.search__teams {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 0px 10px 0px 24px !important;
  width: 100%;
}
.search__teams input {
  width: 100%;
}
.team__donors__search a,.team__donors__search .search__teams,.team__donors__search .h-btn {
  height: 50px;
  border: 1px solid var(--textGrayLight);
  border-radius: 30px;
  padding: 0px 12px;
}
 
.team__donors__search a {
  display: flex;
  align-items: center;
  padding: 0px 30px;
  gap: 16px;
  font-size: var(--f20);
  color: var(--black);
  width: 100%;
}

.team__donors__search {
  display: flex;
  align-items: center;
  gap: 20px;
}

.team__donors__search .h-btn {
  flex-shrink: 0;
}

.team__donors__search .h-btn {
  width: 190px;
  padding: 0px;
}
.team__donors__search .h-btn .nice-select {
  padding: 0px 10px 0px 16px;
}
button.btns.h-btn {
  background-color: var(--white);
  color: var(--black);
  gap: 7px;
}
.team__donors__search .h-btn * {
  font-size: var(--f20);
}
.team__donors__search .h-btn .select__marker {
  margin-top: -2px;
  margin-right: 4px;
  position: absolute;
  z-index: 0;
}
.team__donors__search .h-btn .select__marker {
  margin-top: -2px;
  margin-right: 4px;
}

/* Custom Sort Buttons Styles */
.team__donors__search .sort-donors,
.team__donors__search .sort-teams {
  position: relative;
  width: 190px;
  flex-shrink: 0;
  height: 50px;
  border: 1px solid var(--textGrayLight);
  border-radius: 30px;
}

.sort-option-btn {
  width: 100%;
  height: 100%;
  background: var(--white);
  border: none;
  border-radius: 30px;
  padding: 0px 40px 0px 16px;
  font-size: var(--f20);
  color: var(--black);
  text-align: left;
  cursor: pointer;
  display: flex;
  align-items: center;
  position: relative;
}

.sort-option-btn::after {
  content: '';
  position: absolute;
  right: 16px;
  top: 50%;
  transform: translateY(-50%);
  width: 0;
  height: 0;
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
  border-top: 6px solid var(--black);
}

.sort-dropdown {
  position: absolute;
  top: 55px;
  left: 0;
  right: 0;
  background: var(--white);
  border: 1px solid var(--textGrayLight);
  border-radius: 15px;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
  z-index: 1000;
  overflow: hidden;
}

.sort-option-item {
  width: 100%;
  padding: 12px 16px;
  background: var(--white);
  border: none;
  font-size: var(--f18);
  color: var(--black);
  text-align: left;
  cursor: pointer;
  transition: background-color 0.2s;
  display: block;
}

.sort-option-item:hover {
  background: var(--lightGray);
}

.sort-option-item.active {
  background: var(--lightGray);
  font-weight: 500;
}

.sort-option-item:first-child {
  border-top-left-radius: 15px;
  border-top-right-radius: 15px;
}

.sort-option-item:last-child {
  border-bottom-left-radius: 15px;
  border-bottom-right-radius: 15px;
}

.team__btns, .team__donor__cards__area {
  padding-right: 24px;
}
.team__all__cards {
  margin-left: 24px;
}
.team__donor__cards__area {
  position: relative;
}
.team__donor__cards__all {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding-bottom: 30px;
}
#readCampaign {
  text-align: center;
  margin-top: 20px;
  width: 100%;
  background: transparent;
}
.team__donor__cards__all > button {
  position: sticky;
  bottom: 0;
  background-color: var(--white);
  color: var(--black);
  text-decoration: underline;
  padding: 10px 0;
  z-index: 10;
  width: 100%;
  border: none;
  box-shadow: 0 -2px 10px var(--black-opacity-10);
  grid-column: 1 / -1;
  text-align: center;
}
.loadMore.active,.readMore.active {
  display: none;
}
.loadLess,.readLess {
  display: none;
}
.loadLess.active,.readLess.active {
  display: block;
}
/* Scrollable Container Styles */
.team__donor__cards__scrollable {
  overflow-x: hidden;
  padding-right: 8px;
  max-height: 1000px;
  overflow-y: auto;
  scrollbar-width: thin; /* Firefox - thin scrollbar */
  scrollbar-color: var(--theme_color) var(--bootstrap-gray-light); /* Firefox - thumb and track */
}

/* Scrollbar styles */
.team__donor__cards__scrollable::-webkit-scrollbar {
  width: 8px;
  -webkit-appearance: none;
}

.team__donor__cards__scrollable::-webkit-scrollbar-track {
  background: var(--bootstrap-gray-light);
  border-radius: 4px;
}

.team__donor__cards__scrollable::-webkit-scrollbar-thumb {
  background: var(--theme_color);
  border-radius: 4px;
  min-height: 40px;
}

.team__donor__cards__scrollable::-webkit-scrollbar-thumb:hover {
  background: var(--theme_color);
  opacity: 0.8;
}

.team__donor__cards__scrollable::-webkit-scrollbar-corner {
  background: transparent;
}

/* View More Button Container */
.view-more-container {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 20px auto 0;
  padding: 15px 20px;
  max-width: fit-content;
}

/* View More Button Styles */
.view-more-btn {
  background: var(--theme_color);
  border: 2px solid var(--theme_color);
  color: var(--white);
  padding: 12px 32px;
  border-radius: 8px;
  cursor: pointer;
  font-size: 14px;
  font-weight: 600;
  transition: all 0.3s ease;
  min-width: 150px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.view-more-btn:hover {
  background: var(--white);
  color: var(--theme_color);
  transform: translateY(-2px);
  box-shadow: 0 6px 16px var(--theme_color-opacity-30);
}

.view-more-btn:active {
  transform: translateY(0);
  box-shadow: 0 2px 8px var(--theme_color-opacity-20);
}

/* Loading state for View More button */
.view-more-btn.loading {
  pointer-events: none;
  opacity: 0.8;
}

.view-more-btn.loading:hover {
  transform: none;
  box-shadow: 0 4px 12px var(--theme_color-opacity-20);
}

/* Spinner animation */
.view-more-spinner {
  display: inline-block;
  width: 14px;
  height: 14px;
  margin-right: 8px;
  border: 2px solid transparent;
  border-top-color: currentColor;
  border-radius: 50%;
  animation: view-more-spin 0.6s linear infinite;
}

@keyframes view-more-spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}

/* Responsive View More Button */
@media (max-width: 768px) {
  .team__donor__cards__scrollable {
    max-height: 800px;
  }

  .view-more-container {
    padding: 12px 15px;
    margin: 15px auto 0;
  }

  .view-more-btn {
    padding: 10px 24px;
    font-size: 13px;
    min-width: 130px;
  }
}

@media (max-width: 480px) {
  .team__donor__cards__scrollable {
    max-height: 600px;
  }

  .view-more-container {
    padding: 10px;
  }

  .view-more-btn {
    width: 100%;
    max-width: 200px;
    padding: 12px 20px;
  }
}

.team__donor__side__cards {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 22px;
}
.team__donor__side__cards .team__donor__single__card {
  flex: 0 0 calc(50% - 11px);
}
.team__donor__single__card {
  background: var(--bgGrayLight);
  border-radius: 14px;
  padding: 17px 22px;
  display: flex;
  flex-direction: column;
}

/* Modal-specific donor cards - always single column */
.modal__donor__cards {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 22px;
  align-items: flex-start;
}
.modal__donor__single__card {
  background: var(--bgGrayLight);
  border-radius: 14px;
  padding: 17px 22px;
  display: flex;
  flex-direction: column;
  flex: 0 0 100%;
}
.team__donor__card__img {
  display: flex;
  align-items: center;
  gap: 15px;
  margin-bottom: 16px;
}

.donor__card__img {
  width: 55px;
  height: 55px;
  border-radius: 50%;
  overflow: hidden;
  background: var(--gray-light);
  flex-shrink: 0;
}

.team__donor__card__img span {
  font-size: var(--f20);
}

.team__member__message {
  font-size: var(--f14);
  color: var(--gray-dark);
  margin-bottom: 12px;
  line-height: 1.5;
}

.donor__bonuses {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 7px 0px 21px;
}

.donor__bonus__amount h5 {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 0px;
  font-weight: 600;
}
.give__love__title h5 {
  font-weight: 600;
  margin-bottom: 0px;
  color: var(--black);
  font-family: Rubik;
  font-size: var(--f20);
  line-height: 136.935%; /* 27.387px */
}
.donor__bonus__amount h5 img {
  width: auto;
}

.donor__bonus__amount:last-child:not(:first-child) {
  text-align: end;
}
.team__modal__card> h5 {
  color: var(--black);
  font-size: var(--f20);
  font-weight: 400;
  line-height: 136.935%;
  margin-bottom: 10px;
}
.team__donor__card__btn {
  display: flex;
  align-items: center;
  gap: 15px;
  margin-top: auto;
}

.team__donor__card__btn a {
  height: 40px;
  font-size: var(--f14);
  width: 100%;
}

.team__donor__card__btn a:nth-child(2) {
  background: var(--white);
  border: 1px solid var(--gray-medium-dark);
  color: var(--black);
  gap: 10px;
  width: auto;
  flex: 0 0 auto;
  white-space: nowrap;
  padding: 0 15px;
}
.team__donor__card__btn a:nth-child(2):hover {
  border: 1px solid var(--theme_color);
}
.team__donor__card__btn a:nth-child(2) img {
  width: 22px;
}

.team__donor__card__btn a:first-child {
  max-width: 134px;
}

.team__donor__card__btn a:last-child {
  text-align: end;
  display: flex;
  justify-content: end;
  align-items: center;
  color: var(--black);
  text-decoration: underline;
}
h5#exampleModalLabel {
  margin-bottom: 19px;
}
.give__love__title img {
  width: auto;
}

.give__love__title {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 7px;
}
.team__modal__card .give__love__title {
  margin-top: 20px;
}
.give__love__title p {
  text-align: end;
  margin-left: auto;
  font-size: var(--f14);
  line-height: 136.9%;
}

.give__love__title p span {
  color: var(--secondaryColor);
  font-weight: 500;
}

.give__love__title p span[data-i18n="summary_donors.time_label"] {
  color: var(--black);
}

.give__love__title p span.donor-time-ago {
  color: var(--black);
}

.team__donor__single__card.donor__single__card__team > p {
  font-size: var(--f14);
  margin-top: 10px;
}

.team__donor__single__card p span.spn {
  text-decoration: underline !important;
  color: var(--blue-primary) !important;
  cursor: pointer;
}

p.given__with {
  text-align: end;
  position: absolute;
  bottom: 17px;
  right: 22px;
}

p.given__with a{
  color: var(--theme_color) !important;
}
/* =====new-code-end======= */
.givelove__more__txt{
  font-size: var(--f14);
  margin-top: 10px;
  
}

.givelove__read{
  font-size: var(--f14);
  text-decoration: underline !important;
  color: var(--theme_color) !important;
  cursor: pointer;
  display: block;
  margin-top: 5px;
  margin-bottom: 25px;
}
.read-ln-rt{
  text-align: right;
}
.p-read-{
  display: inline !important;
}

.givelove__more__txt {
  display: none;
}
/* =============// */

.donor__single__card__team,.donor__single__card__team2 {
  min-height: 192px;
  position: relative;
}
.donor__single__card__team.donorSingleCardTeam1,.donor__single__card__team2.donorSingleCardTeam2 {
  height: auto;
}
.givelove__read.giveloveRead {
  display: none;
}
.section2__progressBarContainer {
  margin-top: 15px;
  position: relative;
}
.section2__progressBarContainer > span {
  color: var(--black);
  text-align: right;
  font-size: var(--f14);
  line-height: 120%;
  margin-bottom: 8px;
  display: block;
}

.team__donor__single__card .modal-body {
  padding: 16px 8px 0px !important;
}

.team__modal__card p {
  margin-bottom: 13px;
  color: var(--black);
  font-size: var(--f14);
  font-weight: 300;
  line-height: normal;
}

.modal-dialog-494 {
  max-width: 494px !important;
}

.modal-dialog-494 .team__donor__single__card {
  height: 402px;
}

.team__modal__card > p:last-child {
  margin-bottom: 0px;
  bottom: 0px;
}
.section2__progressBar {
  background-color: var(--gray-light);
  width: 100%;
  height: 9px;
  border-radius: 50px;

  display: flex;
  justify-content: flex-start;
  align-items: center;
}
.section2__progressBarRect,.section2__progressBarRect2,.section2__progressBarRect3 {
  background-color: var(--theme_color);
  height: 100%;
  border-radius: inherit;
  position: relative;
  min-width: 0;
}
.section2__progressBarRect {
  animation: progressLineTransmission 2.5s 0.3s ease-in-out both !important;
}
.section2__progressBarRect2 {
  animation: progressLineTransmission2 2.5s 0.3s ease-in-out both !important;
}
.section2__progressBarRect3 {
  animation: progressLineTransmission3 2.5s 0.3s ease-in-out both !important;
}
.section2__progressBarCircle {
  position: absolute;
  right: -6.5px;
  top: 50%;
  transform: translateY(-50%);
  background-color: var(--secondaryColor);
  height: 13px;
  width: 13px;
  border-radius: 50%;
}
/* Dynamic progress bar for JS-rendered cards (uses transition instead of fixed keyframe animations) */
.section2__progressBarDynamic {
  background-color: var(--theme_color);
  height: 100%;
  border-radius: inherit;
  position: relative;
  width: 0%;
  min-width: 0;
  transition: width 1.5s ease-in-out;
}

@keyframes progressLineTransmission {
  from {
      width: 0%;
  }

  to {
      width: 100%;
  }
}
@keyframes progressLineTransmission2 {
  from {
      width: 0%;
  }

  to {
      width: 70%;
  }
}
@keyframes progressLineTransmission3 {
  from {
      width: 0%;
  }
}
/*===================== SUMMARY DONATION AREA END =====================*/

/*===================== SPONSOR CSS AREA START =====================*/
.company__title h2 {
  font-size: var(--f40);
  line-height: 136.935%;
}

.company__title {
  text-align: center;
  margin-bottom: 30px;
}
/*===================== SPONSOR CSS AREA END =====================*/

/*===================== FOOTER CSS AREA START =====================*/
footer.footer__area {
  background: var(--darkGray);
  position: relative;
  overflow: hidden;
}
footer.footer__area > img {
  position: absolute;
  z-index: 0;
}
img.footer-arrow-bg {
  top: 0px;
  max-width: 1200px;
  right: 0px;
}
.footer__area .container {
  position: relative;
  z-index: 2;
}
.footer__wrap {
  padding: 186px 0px 136px;
}

.footer__wrap * {
  color: var(--white);
}

.footer__logo a img {
  filter: brightness(90) !important;
  margin-top: 7px;
}

.footer__logo {
  max-width: 343px;
}

.footer__list ul li a img {
  width: auto;
}

.footer__contact__list {
  display: flex;
  align-items: start;
  justify-content: start;
  gap: 177px;
}

.footer__list h6 {
  font-size: 17px;
  font-weight: 800;
  margin-bottom: 14px;
}

.footer__list ul {
  display: flex;
  flex-direction: column;
  gap: 15px;
  font-size: 17px;
}

.footer__list ul li a {
  display: flex;
  align-items: center;
  gap: 7px;
  text-align: start;
}
.footer__list ul li a:hover,.copyright p a:hover {
  color: var(--grayWhite) !important;
}
.footer__list ul li a:hover img {
  filter: brightness(0.7);
}
.copyright {
  padding: 21px 0px 36px;
  border-top: 1px solid var(--gray-707070);
  display: flex;
  align-items: center;
  justify-content: space-between;
  text-align: center;
  color: var(--white);
}

.copyright p {
  display: flex;
  align-items: center;
  gap: 7px;
}
.copyright p a {
  text-decoration: underline;
  color: var(--white);
}
.copyright p img {
  width: auto;
}
/*===================== FOOTER CSS AREA END =====================*/
.counter button {
  background-color: transparent;
}

.modal-content {
  font-family: "Rubik", sans-serif;
  padding-bottom: 44px;
}
.modal-body {
  padding-top: 35px;
  padding-left: 43px !important;
  padding-right: 43px !important;
}
.modal-dialog.modal-dialog-centered {
  max-width: 606px;
}
.modal-dialog {
  margin: 0 auto;
}
.modal-header {
  border: 0px;
  padding-bottom: 2px;
  position: absolute;
  padding: 0px;
  top: 18px;
  right: 22px;
  z-index: 9;
}

.modal__body__title {
  text-align: center;
  margin-bottom: 15px;
}
.modal__body__title2 {
  margin-bottom: 54px;
}
.modal__body__title h5 {
  color: var(--darkGray);
}
.contribution__loaded {
  margin: 22px auto 0px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 13px;
  width: 95px;
  position: relative;
}

.contribution__dot {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  border: 1px solid var(--textGrayLight);
  position: relative;
  background: var(--white);
  z-index: 1;
}

.contribution__loaded:after {
  content: '';
  position: absolute;
  top: 50%;
  left: 0px;
  transform: translateY(-50%);
  width: 100%;
  height: 1px;
  background: var(--textGrayLight);
  z-index: 0;
}

.contribution__loaded .contribution__dot:first-child {
  border: 4px solid var(--theme_color);
}

ul#pills-tab {
  justify-content: center;
  gap: 20px;
}

li.nav-item button {
  height: 29px;
  padding: 0px;
  width: 129px;
  border-radius: 30px !important;
  border: 1px solid var(--darkGray) !important;
  color: var(--darkGray);
}

.nav-pills .nav-link.active, .nav-pills .show>.nav-link {
  background: var(--black) !important;
}

li.nav-item button:hover {
  color: var(--black);
}

/* Center the donation type buttons */
#donation-type-tabs {
  display: flex;
  justify-content: center;
  gap: 10px;
}


table {
  width: 100%;
  max-width: 426px;
  margin: 0 auto 11px;
  table-layout: fixed;
}

/* Optimize table column widths for donation modal */
#DonationProcessModal1 table thead th:nth-child(1) {
  width: 40%;
}
#DonationProcessModal1 table thead th:nth-child(2) {
  width: 25%;
}
#DonationProcessModal1 table thead th:nth-child(3) {
  width: 20%;
}
#DonationProcessModal1 table thead th:nth-child(4) {
  width: 15%;
  padding-right: 10px;
}

/* Product name truncation and styling */
tbody tr td:first-child {
  font-weight: 600;
  max-width: 150px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  padding-right: 10px;
}

tbody tr td.product-name {
  max-width: 300px;
  overflow: visible;
  white-space: normal;
  padding-right: 10px;
}

/* Product name and description styling within modal */
.product-name-text {
  font-weight: 600;
  font-size: inherit;
  overflow: visible;
  white-space: normal;
  display: block;
}

.product-description-text {
  font-size: 0.75em;
  font-weight: 400;
  color: #888;
  margin-top: 4px;
  line-height: 1.4;
  display: block !important;
  white-space: normal;
  word-wrap: break-word;
  min-height: 1em;
  cursor: pointer;
  position: relative;
  padding-right: 20px;
  transition: all 0.3s ease;
}

.product-description-text.collapsed {
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box !important;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.product-description-text .chevron-icon {
  position: absolute;
  right: 2px;
  top: 4px;
  width: 8px;
  height: 8px;
  transition: transform 0.3s ease;
}

.product-description-text .chevron-icon::before {
  content: '';
  display: inline-block;
  width: 8px;
  height: 8px;
  border-right: 2px solid #666;
  border-bottom: 2px solid #666;
  transform: rotate(45deg);
}

.product-description-text.collapsed .chevron-icon {
  transform: rotate(0deg);
}

.product-description-text:not(.collapsed) .chevron-icon {
  transform: rotate(180deg);
}

/* Don't hide empty descriptions - let JavaScript handle visibility */

/* Product description in carousel/home page - truncated to 26 chars */
.sponsor__child__single__slide .product-description {
  font-size: 0.75em;
  font-weight: 400;
  color: #666;
  margin: 4px 0 2px 0;
  line-height: 1.2;
  text-align: center;
}

tbody tr td:nth-child(2) span {
  height: 53px;
  display: flex;
  text-align: center;
  align-items: center;
  justify-content: center;
  border: 0.5px solid var(--textGrayLight);
  border-radius: 10px;
  font-size: var(--f20);
}

/* Non-modifiable product prices get a distinct gray background */
tbody tr td:nth-child(2) span.product-price:not(.modifiable-price) {
  background-color: #e9e9e9;
  border-color: #d5d5d5;
}
tbody tr td {
  padding-bottom: 10px;
}
tbody tr td:nth-child(2) span input {
  width: 78px;
  color: var(--darkGray);
  text-align: center;
  font-size: var(--f17);
  font-style: normal;
  font-weight: 400;
  line-height: normal;
}
tbody tr td:nth-child(2) span input::placeholder {
  color: var(--darkGray-opacity-30);
}
thead tr th {
  text-align: center;
  padding-bottom: 7px;
  font-size: var(--f14);
  color: var(--darkGray);
  font-weight: 500;
}

tbody tr td:last-child {
  text-align: right;
  font-size: var(--f20);
  padding-right: 10px;
}

.counter-container input.counter-value {
  text-align: center;
  width: 25px;
}

.counter-container {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  align-items: center;
  justify-content: center;
  color: var(--gray-text-dark);
  text-align: center;
  font-family: Rubik;
  font-size: var(--f20);
  font-style: normal;
  font-weight: 400;
  line-height: normal;
  width: 52px;
  place-items: center;
  margin: auto;
}

.counter-container button {
  background: transparent !important;
  color: var(--black) !important;
}

/* Product checkbox styling */
.product-checkbox {
  width: 20px;
  height: 20px;
  cursor: pointer;
  accent-color: var(--theme_color);
  margin-left: auto;
  margin-right: 10px;
  display: block;
}

.product-checkbox:checked {
  background-color: var(--theme_color);
  border-color: var(--theme_color);
}

/* Empty cell placeholders when controls are hidden */
.no-quantity,
.no-checkbox {
  display: block;
  text-align: center;
  color: #ccc;
  font-size: 14px;
  user-select: none;
}

/* Fixed quantity products - checkbox controls selection, +/- buttons hidden */
/* The counter displays the fixed quantity from API (or 1 if not set) */

/* Fixed quantity products - hide buttons but maintain layout */
.counter-container.fixed-quantity button {
  visibility: hidden;
  cursor: not-allowed;
}

/* Counter input is readonly for fixed quantity */
.counter-container.fixed-quantity .counter-value {
  cursor: default;
  text-align: center;
}

/* Ensure proper centering when buttons are hidden */
.counter-container.fixed-quantity {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  align-items: center;
  justify-content: center;
  place-items: center;
}

/* Visual feedback when any product is selected */
tbody tr:has(.product-checkbox:checked) .counter-value {
  font-weight: 600;
}

/* Adjust column widths when quantity column is hidden */
#DonationProcessModal1 table:not(:has(thead th:nth-child(3))) thead th:nth-child(1) {
  width: 50%;
}
#DonationProcessModal1 table:not(:has(thead th:nth-child(3))) thead th:nth-child(2) {
  width: 30%;
}
#DonationProcessModal1 table:not(:has(thead th:nth-child(3))) thead th:nth-child(3) {
  width: 20%;
}

/* Improve spacing in modal body */
.modal__body__content {
  padding-top: 10px;
}

/* Ensure price column has consistent alignment */
tbody tr td:nth-child(2) {
  text-align: center;
}

/* Add hover effect for product rows */
tbody tr:hover {
  background-color: rgba(0, 0, 0, 0.03);
  transition: background-color 0.2s ease;
}

/* Modifiable price input styling */
.modifiable-price {
  position: relative;
  display: inline-flex;
  align-items: center;
  width: 100%;
  background-color: #ffffff !important;
  border-color: #a0a0a0;
}

.modifiable-price .price-input {
  width: 90px;
  border: none;
  background: transparent;
  text-align: center;
  font-size: var(--f20);
  font-weight: inherit;
  padding: 0 2px;
  margin: 0;
  color: var(--darkGray);
}

.modifiable-price .price-input:focus {
  outline: none;
  background: rgba(0, 0, 0, 0.05);
  border-radius: 4px;
}

.modifiable-price .price-input::-webkit-inner-spin-button,
.modifiable-price .price-input::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* Hover effect for modifiable prices to indicate editability */
.modifiable-price:hover {
  box-shadow: 0 0 0 1px var(--theme_color);
  cursor: text;
}

.modifiable-price:hover .price-input {
  cursor: text;
}

/* Clickable price area - makes entire div clickable */
.clickable-price {
  cursor: pointer;
  display: inline-block;
  padding: 4px 8px;
  border-radius: 4px;
  transition: background 0.2s ease;
}

.clickable-price:hover {
  background: rgba(0, 0, 0, 0.02);
}

.total {
  text-align: center;
}
.total h5 {
  color: var(--darkGray);
  text-align: center;
  font-family: Rubik;
  font-size: var(--f20);
  font-weight: 600;
}
.total h5 span {
  color: var(--darkGray);
  font-family: Rubik;
  font-size: var(--f20);
  font-weight: 600;
}
.total span {
  color: var(--black);
  font-family: Rubik;
  font-size: var(--f13);
  font-weight: 300;
  line-height: 136.935%; /* 17.802px */
}

.modal-footer {
  justify-content: center;
  text-align: center;
  border: none;
  padding-top: 0px;
  padding-bottom: 0px;
}

.modal__footer button {
  width: 289px;
  height: 53px;
  border-radius: 30px;
  background: var(--theme_color);
  font-size: var(--f20);
  font-weight: 600;
  margin-bottom: 14px;
}

.modal__footer p a {
  display: flex;
  align-items: center;
  color: var(--secondaryColor);
}

.modal__footer p a img {
  width: auto;
}
.canadian-dolors {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  position: relative;
  justify-content: center;
}

.canadian-dolors > span {
  flex-shrink: 0;
}

.canadian-dolors * {
  color: var(--black);
  font-size: var(--f15);
  font-weight: 400;
  line-height: 136.935%; /* 20.54px */
}

.canadian-dolors .nice-select span {
  color: var(--secondaryColor);
}

.canadian-dolors .nice-select ul {
  bottom: 119% !important;
  z-index: 999;
  top: auto;
  width: 160px;
}
.canadian-dolors .nice-select ~ .select__marker {
  right: 0px !important;
  z-index: 0;
}

.canadian-dolors .nice-select {
  /* width: auto !important; */
  padding-right: 18px;
  background-color: transparent !important;
  position: relative;
  z-index: 0;
}
.modal__footer p {
  display: flex;
  gap: 5px;
  justify-content: center;
}

.monthly__installment {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 30px;
  margin-top: 14px;
  z-index: 1001;
}

.h-btn.h-btn2 {border-radius: 10px;}

.monthly__installment .h-btn.h-btn2 .nice-select {
  line-height: 33px;
  color: var(--darkGray);
  padding: 0px 47px 0px 24px;
}

.monthly__installment .h-btn.h-btn2 .nice-select .list {
  z-index: 1000;
}

.h-btn.h-btn2 .nice-select .current {
  font-size: var(--f17);
  font-weight: 400;
}

.h-btn.h-btn2 .select__marker {
  top: 48%;
}

.text__field__card .input__field, .text__field__card input, .select__country {
  width: 100%;
  border: 0.75px solid var(--gray-AEACAC);
  border-radius: 6px;
  padding: 13px 25px;
  font-size: var(--f14);
}
.text__field__card.city__state .h-btn .nice-select {
  font-size: var(--f14);
}
.text__field__card {
  margin-bottom: 17px;
  display: flex;
  flex-direction: column;
}

/* Character counter styling */
.character-counter {
  text-align: right;
  font-size: var(--f12);
  color: var(--gray-AEACAC);
  margin-top: 4px;
  padding-right: 5px;
}

.receipt__detail,.issue__receipt {
  margin-bottom: 17px;
}

form .text__field__card:nth-child(4) {
  display: flex;
  gap: 17px;
}

/* Receipt fields styling */
.receipt-personal-fields {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 17px;
}

.receipt-personal-fields .input-wrapper {
  display: flex;
  flex-direction: column;
}

.receipt-personal-fields input {
  width: 100%;
}

.receipt-personal-fields .input-hint {
  width: 100%;
  margin-bottom: 6px;
  padding: 0;
}

.receipt-company-field {
  display: none !important;
}

.receipt-company-field.show {
  display: block !important;
}

.receipt-personal-fields.hide {
  display: none !important;
}

.donate__anonymously {
  display: flex;
  align-items: center;
  gap: 4px;
  margin-top: -5px;
  margin-bottom: 17px;
}

.donate__anonymously * {
  margin: 0;
}

.donate__anonymously input[type="checkbox"] {
  width: 20px;
  height: 20px;
  border: 2px solid var(--theme_color);
  border-radius: 4px;
  cursor: pointer;
  position: relative;
  flex-shrink: 0;
  transition: all 0.3s ease;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
}

.donate__anonymously input[type="checkbox"]:checked {
  background-color: var(--theme_color);
  border-color: var(--theme_color);
}

.donate__anonymously input[type="checkbox"]:checked::after {
  content: '✓';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: white;
  font-size: 14px;
  font-weight: bold;
}

/* Input hints styling - shown above inputs when user types */
.input-hint {
  display: none;
  font-size: var(--f14);
  color: var(--textGray);
  font-weight: 300;
  margin-bottom: 6px;
  padding: 0 25px;
  line-height: 1.4;
  order: -1; /* Places hint above input in flex containers */
}

/* Show hint when input has value (handled by JavaScript, this is fallback) */
.input-hint.show {
  display: block;
}

.receipt__detail {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  margin-top: 43px;
  margin-bottom: 10px;
  column-gap: 12px;
}

.receipt__detail p {
  font-weight: 300;
}

.login {
  text-decoration: underline;
  color: var(--black);
  background-color: transparent;
}

.payment__method__cards {
  display: flex;
  flex-wrap: wrap;
  gap: 24px;
}

.payment__method__card {
  padding: 13px 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border: 0.75px solid var(--gray-969393);
  border-radius: 6px;
  height: 45px;
  cursor: pointer;
}
.bankcard {
  justify-content: start !important;
  gap: 5px !important;
}
li.nav-item button.card__tab {
  background: transparent;
  border: 1px solid transparent !important;
  border-radius: 0px !important;
  height: auto !important;
  width: auto !important;
}
.payment__method__card .radio-indicator {
  width: 13px;
  height: 13px;
  border-radius: 50%;
  border: 2px solid var(--gray-medium-dark);
}
.payment__method__card input[type="radio"]:checked + .radio-indicator {
  background-color: var(--black);
}

.payment__method {
  margin-top: 27px;
  margin-bottom: 37px;
}

.credit__card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 11px;
}

.credit__card h6 {
  margin-bottom: 0px !important;
}

.credit__card .card-logos {
  display: flex;
  gap: 10px;
  align-items: center;
}

.credit__card .card-logo {
  width: 50px;
  height: auto;
  opacity: 0.3;
  transition: all 0.3s ease;
  filter: grayscale(100%);
}

.credit__card .card-logo.active {
  opacity: 1;
  filter: grayscale(0%);
  transform: scale(1.1);
}

.card-number-input.invalid {
  border-color: var(--danger) !important;
}

.card-number-input.valid {
  border-color: var(--success) !important;
}

.card-error-message {
  color: var(--danger);
  font-size: 12px;
  margin-top: 4px;
  display: block;
}

.text__field__card.dateofbirth {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.text__field__card.dateofbirth .input-wrapper {
  display: flex;
  flex-direction: column;
}

.text__field__card.dateofbirth .input-hint {
  width: 100%;
  margin-bottom: 6px;
  padding: 0;
}

.text__field__card.city__state .input-wrapper {
  display: flex;
  flex-direction: column;
}

.text__field__card.city__state .input-hint {
  margin-bottom: 6px;
  padding: 0;
}

.text__field__card.city__state {
  display: grid;
  grid-template-columns: repeat(2,1fr);
  gap: 14px;
}

.h-btn3 {
  border-radius: 6px;
  height: 45px;
}

.payment__method h6,.credit__card h6 {
  margin-bottom: 16px;
  font-weight: 500;
}

.donate__anonymously.donate__anonymously2 p {
  margin-left: auto;
  text-align: end;
  font-size: 15px;
  font-weight: 300;
  line-height: 17.78px;
  margin-bottom: 15px;
}

.donate__anonymously.donate__anonymously2 {
  align-items: start;
}
/* .switch__donate class removed - no longer needed with checkbox implementation */
.platform__switch {
  width: 35px;
  height: 18px;
  border-radius: 32px;
  padding: 2px 3px;
  background: var(--textGrayLight);
  position: relative;
}

.platform__switch:after {
  content: '';
  position: absolute;
  top: 2px;
  left: 3px;
  width: 13px;
  height: 13px;
  border-radius: 50%;
  background: var(--white);
  z-index: 2;
  transition: .3s ease-in-out;
}

.platform__switch.active:after {
  left: 57%;
}

.platform__switch.active {
  background: var(--theme_color);
}

.modal__footer__finis {
  display: flex;
  align-items: center;
  gap: 32px;
  width: 100%;
  padding: 0px 30px;
}

.modal__footer__finis button {
  width: 50%;
  border-radius: 30px;
  font-size: 20px;
  font-weight: 600;
  height: 53px;
}

.modal__footer__finis button:first-child {
  border: 1px solid var(--theme_color);
  background: var(--white);
  color: var(--theme_color);
}

.modal__footer__finis button:last-child {
  background: var(--theme_color);
}

.modal__footer__finis button.back-only-btn {
  border: 1px solid var(--theme_color);
  background: var(--white);
  color: var(--theme_color);
  width: auto;
  padding: 0 40px;
}

.modal__footer__finis button.back-only-btn:hover {
  background: var(--theme_color);
  color: var(--white);
}

.proceeding {
  text-align: center;
}

.proceeding p {
  padding: 29px 0px 17px;
  font-size: var(--f20);
  line-height: 23.7px;
}

.proceeding span {
  font-size: 15px;
  font-weight: 300;
}
.modal__body__thanks span {
  color: var(--textGray);
  text-align: center;
  font-family: Rubik;
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: normal;
  display: block;
  margin-bottom: 12px;
}

/* Social Share Buttons */
.social__contacts {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  margin: 26px 0px;
  flex-wrap: wrap;
}

.social__icon {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  cursor: pointer;
  text-decoration: none;
  overflow: hidden;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
}

.social__icon::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0));
  opacity: 0;
  transition: opacity 0.3s ease;
}

.social__icon img {
  width: 24px;
  height: 24px;
  position: relative;
  z-index: 1;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Mobile - Colored Icons by Default */
.social__icon {
  background: #e0e0e0;
}

.social__icon img {
  filter: grayscale(1) brightness(0.5);
}

/* Mobile Platform Colors */
@media (hover: none) {
  .social__icon[data-share="facebook"] {
    background: linear-gradient(135deg, #1877f2 0%, #0d5dbf 100%);
  }

  .social__icon[data-share="twitter"] {
    background: linear-gradient(135deg, #1da1f2 0%, #0d8bd9 100%);
  }

  .social__icon[data-share="email"] {
    background: linear-gradient(135deg, #ea4335 0%, #c1351d 100%);
  }

  .social__icon[data-share="sms"] {
    background: linear-gradient(135deg, #34c759 0%, #28a745 100%);
  }

  .social__icon[data-share="messenger"] {
    background: linear-gradient(135deg, #00b2ff 0%, #006aff 100%);
  }

  .social__icon[data-share="whatsapp"] {
    background: linear-gradient(135deg, #25d366 0%, #128c7e 100%);
  }

  .social__icon img {
    filter: brightness(0) invert(1);
  }
}

/* Desktop Hover Effects - Gray to Color */
@media (hover: hover) and (pointer: fine) {
  .social__icon:hover {
    transform: translateY(-4px) scale(1.08);
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.2);
  }

  .social__icon:hover::before {
    opacity: 1;
  }

  .social__icon:hover img {
    transform: scale(1.1);
    filter: brightness(0) invert(1);
  }

  /* Desktop Hover Colors */
  .social__icon[data-share="facebook"]:hover {
    background: linear-gradient(135deg, #1877f2 0%, #0d5dbf 100%);
  }

  .social__icon[data-share="twitter"]:hover {
    background: linear-gradient(135deg, #1da1f2 0%, #0d8bd9 100%);
  }

  .social__icon[data-share="email"]:hover {
    background: linear-gradient(135deg, #ea4335 0%, #c1351d 100%);
  }

  .social__icon[data-share="sms"]:hover {
    background: linear-gradient(135deg, #34c759 0%, #28a745 100%);
  }

  .social__icon[data-share="messenger"]:hover {
    background: linear-gradient(135deg, #00b2ff 0%, #006aff 100%);
  }

  .social__icon[data-share="whatsapp"]:hover {
    background: linear-gradient(135deg, #25d366 0%, #128c7e 100%);
  }
}

/* Active/Click Effect */
.social__icon:active {
  transform: translateY(-2px) scale(1.02);
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
}

/* Ripple effect on click */
.social__icon::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.5);
  transform: translate(-50%, -50%);
  transition: width 0.6s, height 0.6s;
}

.social__icon:active::after {
  width: 100%;
  height: 100%;
}

.modal__body__thanks {
  text-align: center;
}

.modal__body__thanks > img {
  width: 104px;
}

.modal__body__thanks h2 {
  font-size: var(--f40);
  margin: 19px 0px 20px;
  line-height: 130%;
  color: var(--black);
  text-align: center;
  font-family: Outfit;
  /* font-size: 40px; */
  font-style: normal;
  font-weight: 600;
  line-height: 130%; /* 52px */
}

p.another__team {
  margin: 30px 0px 39px;
  line-height: normal;
}

p.another__team button {
  color: var(--black);
  text-decoration: underline;
  background-color: transparent !important;
}

.modal__body__thanks p {
  color: var(--textGray);
  text-align: center;
  font-family: Rubik;
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: normal;
  margin-bottom: 0;
}
.modal__body__thanks p a {
  text-decoration: underline;
  color: var(--textGray);
}

/* Payment Accepted Message Styling */
.payment-accepted-message {
  margin: 15px 0 20px;
  padding: 12px 20px;
  background: linear-gradient(135deg, #e8f5e9 0%, #f1f8f4 100%);
  border-radius: 10px;
  border-left: 4px solid #4caf50;
  color: #2e7d32;
  font-size: 16px;
  font-weight: 500;
  text-align: center;
  box-shadow: 0 2px 8px rgba(76, 175, 80, 0.1);
}

.payment-accepted-message strong {
  font-weight: 600;
  display: block;
}
.logos img {
  width: 155px;
}

.logos {
  display: flex;
  justify-content: center;
  width: 100%;
  margin-bottom: 22px;
}

.modal__body__login .text__field__card {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.modal__body__login2 {
  margin-bottom: -64px;
}
.login__card {
  max-width: 411px !important;
}
.modal__body__login a,
.modal__body__login .btns {
  width: 250px;
  height: 53px;
  font-weight: 600;
  font-size: var(--f20);
  margin: 20px auto 10px;
}

/* Login Modal Styles */
.modal__body__login .login-subtitle {
  color: var(--gray-666);
  font-size: var(--f14);
  margin-bottom: 20px;
  text-align: center;
}

.modal__body__login .login-form-fields {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 8px;
}

.modal__body__login .login-form-fields .input-wrapper {
  position: relative;
}

.modal__body__login .login-form-fields input {
  width: 100%;
  padding: 14px 16px;
  border: 1px solid var(--gray-E3E3E3);
  border-radius: 8px;
  font-size: var(--f14);
  transition: border-color 0.2s ease;
}

.modal__body__login .login-form-fields input:focus {
  border-color: var(--theme_color);
  outline: none;
}

/* Login Status Messages */
.login-status {
  text-align: center;
  padding: 10px;
  border-radius: 6px;
  font-size: var(--f14);
  margin-top: 12px;
}

.login-status-info {
  color: var(--theme_color);
  background-color: rgba(var(--theme_color_rgb), 0.1);
}

.login-status-success {
  color: var(--success);
  background-color: rgba(40, 167, 69, 0.1);
}

.login-status-error {
  color: var(--danger);
  background-color: rgba(220, 53, 69, 0.1);
}

/* Login Actions */
.login-actions {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  margin-top: 20px;
  margin-bottom: 30px;
}

.login-actions .login-submit-btn {
  margin: 0;
}

.login-actions .btn-cancel {
  background: transparent;
  border: none;
  color: var(--gray-666);
  font-size: var(--f14);
  cursor: pointer;
  text-decoration: underline;
  padding: 8px 16px;
  transition: color 0.2s ease;
}

.login-actions .btn-cancel:hover {
  color: var(--theme_color);
}

/* Loading Spinner in Button */
.spinner-small {
  display: inline-block;
  width: 16px;
  height: 16px;
  border: 2px solid rgba(255, 255, 255, 0.3);
  border-radius: 50%;
  border-top-color: #fff;
  animation: spin 0.8s linear infinite;
  margin-right: 8px;
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

/* Receipt Detail Login Section */
.receipt__detail .login-section {
  display: flex;
  align-items: center;
  gap: 5px;
  flex-wrap: wrap;
}

.receipt__detail .login {
  background: transparent;
  border: none;
  color: var(--theme_color);
  font-weight: 600;
  cursor: pointer;
  text-decoration: underline;
  padding: 0;
  font-size: inherit;
}

.receipt__detail .login:hover {
  color: var(--dark-theme_color);
}

/* Logged In State */
.receipt__detail .logged-in-as {
  color: var(--gray-666);
}

.receipt__detail .logged-in-name {
  color: var(--darkGray);
  margin-left: 4px;
}

.receipt__detail .logout-btn {
  background: transparent;
  border: none;
  color: var(--danger);
  font-size: var(--f14);
  cursor: pointer;
  text-decoration: underline;
  padding: 0;
  margin-left: 8px;
}

.receipt__detail .logout-btn:hover {
  color: var(--dark-danger);
}

/* Logged In Field Style */
.logged-in-field {
  background-color: var(--bgGrayLight) !important;
  cursor: not-allowed;
}

.text__field__card h6 {
  color: var(--darkGray);
  font-weight: 500;
}






.f-dropdown {
  --max-scroll: 3;
  position: relative;
  z-index: 10;
}
.f-dropdown select {
  display: none;
}
.f-dropdown > span {
  cursor: pointer;
  border-radius: 6px;
  display: flex;
  align-items: center;
  position: relative;
  color: var(--gray-bbb);
  transition: color 0.2s ease, border-color 0.2s ease;
}
.f-dropdown > span > span {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  padding-right: 12px;
  color: var(--black);
  font-family: Inter;
  font-size: 16px;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
}
.f-dropdown > span img {
  width: 20px;
}
.f-dropdown > span:before, .f-dropdown > span:after {
  content: "";
  display: block;
  position: absolute;
  width: 8px;
  height: 2px;
  border-radius: 1px;
  top: 50%;
  right: 12px;
  background: var(--black);
  transition: all 0.3s ease;
}

.f-group > img {
  position: absolute;
  width: 7px;
  top: 4px;
  right: 0px;
  filter: brightness(0);
}

.f-dropdown > span:before {
  display: none;
}
.f-dropdown > span:after {
  display: none;
}
.f-dropdown ul {
  margin: 0;
  padding: 0;
  list-style: none;
  opacity: 0;
  visibility: hidden;
  position: absolute;
  width: 88px;
  max-height: calc(var(--max-scroll) * 46px);
  top: 20px;
  z-index: 1;
  left: 0px;
  background: var(--white);
  border: 1px solid var(--gray-border);
  border-radius: 6px;
  overflow-x: hidden;
  overflow-y: auto;
  transform-origin: 0 0;
  transition: opacity 0.2s ease, visibility 0.2s ease, transform 0.3s cubic-bezier(0.4, 0.6, 0.5, 1.32);
  transform: translate(0, 5px);
}
.f-dropdown ul li {
  padding: 0;
  margin: 0;
}
.f-dropdown ul li a {
  cursor: pointer;
  display: block;
  padding: 8px 12px;
  color: var(--black);
  text-decoration: none;
  outline: none;
  position: relative;
  transition: all 0.2s ease;
  display: flex;
  align-items: center;
}
.f-dropdown ul li a img {
  width: 25px;
  margin-right: 6px;
}
.f-dropdown ul li a:hover {
  color: var(--blue-indigo);
}
.f-dropdown ul li.active a {
  color: var(--white);
  background: var(--blue-indigo-dark);
}
.f-dropdown ul li.active a:before, .f-dropdown ul li.active a:after {
  --scale: 0.6;
  content: "";
  display: block;
  width: 10px;
  height: 2px;
  position: absolute;
  right: 12px;
  top: 50%;
  opacity: 0;
  background: var(--white);
  transition: all 0.2s ease;
  display: none;
}
.f-dropdown ul li.active a:before {
  transform: rotate(45deg) scale(var(--scale));
}
.f-dropdown ul li.active a:after {
  transform: rotate(-45deg) scale(var(--scale));
}
.f-dropdown ul li.active a:hover:before, .f-dropdown ul li.active a:hover:after {
  --scale: 0.9;
  opacity: 1;
}
.f-dropdown ul li:first-child a {
  border-radius: 6px 6px 0 0;
}
.f-dropdown ul li:last-child a {
  border-radius: 0 0 6px 6px;
}
.f-dropdown.disabled {
  opacity: 0.7;
}
.f-dropdown.disabled > span {
  cursor: not-allowed;
}
.f-dropdown.filled > span {
  color: var(--white);
}
.f-dropdown.open {
  z-index: 15;
}
.f-dropdown.open > span {
  border-color: var(--gray-aaa);
}
.f-dropdown.open > span:before, .f-dropdown.open > span:after {
  background: var(--black);
}
.f-dropdown.open > span:before {
  transform: scale(0.96, 0.8) rotate(-50deg);
}
.f-dropdown.open > span:after {
  transform: scale(0.96, 0.8) rotate(50deg);
}
.f-dropdown.open ul {
  opacity: 1;
  visibility: visible;
  transform: translate(0, 12px);
  transition: opacity 0.3s ease, visibility 0.3s ease, transform 0.3s cubic-bezier(0.4, 0.6, 0.5, 1.32);
}
.profile-pic {
  background: var(--bgGrayLight);
  color: transparent;
  transition: all 0.3s ease;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  transition: all 0.3s ease;
  width: 93px;
  height: 93px;
  border-radius: 50%;
  margin: 0 auto;
}
.profile-pic input {
  display: none;
}
.profile-pic img {
  position: absolute;
  object-fit: cover;
  width: 93px;
  height: 93px;
  box-shadow: 0 0 10px 0 var(--white-opacity-35);
  border-radius: 50%;
  z-index: 0;
}
.profile-pic .-label {
  cursor: pointer;
  height: 93px;
  width: 93px;
  border-radius: 50%;
  overflow: hidden;
}
.profile-pic:hover .-label {
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 10000;
  color: var(--fafafa);
  transition: background-color 0.2s ease-in-out;
  border-radius: 100px;
  margin-bottom: 0;
}
.profile-pic span {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.2em;
  height: 100%;
  color: var(--darkGray-opacity-70);
  font-size: var(--f14);
  font-weight: 300;
  line-height: 16.59px;
}
/* --------------------------- */
.f-group {
  max-width: 122px;
  margin: 0 auto;
  text-align: left;
  position: relative;
}

.hero__single__form__select {
  margin-right: 11px;
  border-right: 1px solid var(--gray-AEACAC);
  height: 100%;
  display: flex;
  align-items: center;
  padding-right: 11px;
}

.f-group select {
  width: 100%;
}
.donate__anonymously h6 label {
  text-align: start;
}
.f-control {
  font-size: 14px;
  line-height: normal;
  color: var(--black);
  display: inline-block;
  background-color: var(--white);
  border: var(--gray-border) 1px solid;
  border-radius: 6px;
  padding: 8px 12px;
  outline: none;
  max-width: 250px;
}

label {
  width: 100%;
  display: block;
  font-weight: bold;
  text-align: center;
}
label.-label .glyphicon {
  display: none !important;
}
.selectDropdown .nice-select {
  display: none;
}

.text__field__card input {
  height: 45px;
}
.h-btn3 .nice-select {
  padding: 0px 36px 0px 25px;
  color: var(--gray-text);
  text-align: center;
  font-size: var(--f16);
  font-weight: 300;
  z-index: 1000;
  position: relative;
}

.h-btn3 .nice-select ~ .select__marker {
  right: 36px;
  z-index: 1001;
}

.h-btn3 .nice-select .list {
  z-index: 1002;
  max-height: 260px;
  overflow-y: auto;
}

/* Allow country dropdown list to float over modal content */
#DonationProcessModal3 .modal-content,
#DonationProcessModal3 .modal-body {
  overflow: visible;
}

#DonationProcessModal3 .h-btn3 .nice-select .list {
  z-index: 9999;
}

/* Team Selector Styles */
.team-header-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
}

.team-header-row h6 {
  margin: 0;
}

.donation-total-display {
  font-size: 14px;
  font-weight: 500;
  color: var(--theme_color);
}

.donation-total-display #modal_donation_total {
  font-weight: 600;
  color: var(--theme_color);
}

.team-selector-wrapper {
  border: 1px solid var(--gray-border);
  border-radius: 6px;
  overflow: hidden;
  background: var(--white);
}

.team-instruction-text {
  font-size: 13px;
  color: var(--gray-text);
  line-height: 1.6;
  margin: 10px 0;
  padding: 0;
}

.team-toggle-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}

.team-toggle-btn {
  display: flex;
  align-items: center;
  gap: 8px;
  background: none;
  border: none;
  color: var(--theme_color);
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  padding: 8px 0;
  transition: opacity 0.2s ease;
}

.team-toggle-btn:hover {
  opacity: 0.8;
}

.team-toggle-btn .toggle-icon {
  transition: transform 0.3s ease;
}

.team-toggle-btn.expanded .toggle-icon {
  transform: rotate(180deg);
}

.team-search-box {
  padding: 12px;
  border-bottom: 1px solid var(--gray-border);
}

.team-search-input {
  width: 100%;
  padding: 10px 15px;
  border: 1px solid var(--gray-border);
  border-radius: 4px;
  font-size: var(--f14);
  font-weight: 300;
  color: var(--gray-text);
  outline: none;
  transition: border-color 0.3s ease;
}

.team-search-input:focus {
  border-color: var(--theme_color);
}

.team-list-scrollable {
  max-height: 200px;
  overflow-y: auto;
  overflow-x: hidden;
  padding: 8px 0;
}

.team-list-scrollable::-webkit-scrollbar {
  width: 6px;
}

.team-list-scrollable::-webkit-scrollbar-track {
  background: #f1f1f1;
  border-radius: 3px;
}

.team-list-scrollable::-webkit-scrollbar-thumb {
  background: #888;
  border-radius: 3px;
}

.team-list-scrollable::-webkit-scrollbar-thumb:hover {
  background: #555;
}

.team-item {
  padding: 8px 15px;
  display: flex;
  align-items: center;
  cursor: pointer;
  transition: background-color 0.2s ease;
}

.team-item:hover {
  background-color: #f5f5f5;
}

.team-checkbox {
  width: 14px !important;
  height: 14px !important;
  min-width: 14px;
  min-height: 14px;
  margin: 0 0 0 10px !important;
  cursor: pointer;
  accent-color: var(--theme_color);
  flex-shrink: 0;
  order: 3;
}

.team-item .other__amount {
  margin-left: auto;
  margin-right: 10px;
  flex-shrink: 0;
  order: 2;
}

.team-label {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  margin: 0 !important;
  padding: 0 !important;
  order: 1;
}

.team-avatar-wrapper {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background-color: #f0f0f0;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  overflow: hidden;
  border: 1px solid #e0e0e0;
}

.team-avatar {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  object-fit: cover;
}

.team-avatar-default {
  width: 24px;
  height: 24px;
  padding: 4px;
  opacity: 0.7;
}

.team-name {
  font-size: 14px;
  font-weight: 400;
  color: var(--gray-text);
  line-height: 1.5;
  white-space: normal;
  word-wrap: break-word;
  max-height: 3em;
  overflow: hidden;
  text-overflow: ellipsis;
}

.team-item.hidden {
  display: none;
}

/* Single team selection - disabled state for unselected teams */
.team-item.team-disabled {
  opacity: 0.5;
}

.team-item.team-disabled:hover {
  background-color: #f5f5f5;
}

/* Selected team highlight */
.team-item.team-selected {
  background-color: #f0f7ff;
  border-left: 3px solid var(--theme_color);
}

/* Team loading, error, and empty states */
.team-loading,
.team-error,
.team-empty {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 30px 20px;
  text-align: center;
  color: #666;
  font-size: 14px;
}

.team-loading {
  color: var(--theme_color, #007bff);
}

.team-error {
  color: #dc3545;
}

.team-empty {
  color: #999;
  font-style: italic;
}

.creat__team__title {
  text-align: center;
}

.creat__team__title p {
  margin: 13px 0px 22px;
  font-size: var(--f14);
  font-weight: 300;
}

.creat__team__title h6 {
  margin: 23px 0px 36px;
}

.select__country {
  margin-bottom: 17px;
  display: flex;
  align-items: center;
  padding: 0px 23px;
  height: 45px;
}

.select__country input {
  width: 100%;
}

.text-link {
  font-size: var(--f14);
  font-weight: 300;
  color: var(--black);
}


.frame {
  border-radius: 3px;
  font-family: 'montserrat', Helvetica, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  display: flex;
  justify-content: center;
  align-items: center;
}

.headline {
  font-size: 2rem;
  text-transform: uppercase;
  text-align: center;
}

.circle-big {
  position: relative;
  width: 114px;
  height: 114px;
  margin: 30px auto 25px auto;
}

.circle-big svg {
  width: 114px;
  height: 114px;
}

.circle-big .bg {
  fill: transparent;
  stroke-width: 9px;
  stroke: var(--gray-light);
}

.circle-big .progress {
  fill: none;
  stroke-width: 9px;
  stroke: var(--theme_color);
  stroke-linecap: round;
  transform: rotate(-3deg);
  transform-origin: 50% 50%;
}

.circle-big .text {
  position: absolute;
  width: 100%;
  top: 53%;
  left: 50%;
  transform: translate(-50%,-50%);
  font-size: var(--f24);
  text-align: center;
  font-weight: 400;
  line-height: 22px;
}

.circle-big .text .small {
  font-size: var(--f14);
  color: var(--white);
}

.circles-small {
  margin: 0 auto;
  width: 400px;
  height: 80px;
  text-align: center;
}

.circle-small {
  display: inline-block;
  position: relative;
  width: 80px;
  height: 80px;
  margin: 0 20px;
}

.circle-small svg {
  width: 80px;
  height: 80px;
}

.circle-small .bg {
  fill: none;
  stroke-width: 6px;
  stroke: var(--black-dark);
}

.circle-small .progress {
  fill: none;
  stroke-width: 6px;
  stroke: var(--purple-bright);
  stroke-linecap: round;
  stroke-dasharray: 232.36;
          transform: rotate(-90deg);
          transform-origin: 50% 50%;
}

.circle-small .progress.one {
  stroke-dashoffset: 80;
          animation: one 2.5s ease-in-out, appear 1s;
}

.circle-small .progress.two {
  stroke-dashoffset: 140;
          animation: two 3.5s ease-in-out, appear 2s;
}

.circle-small .text {
  position: absolute;
  width: 100%;
  top: 26px;
  font-size: 17px;
  text-align: center;
  font-weight: 400;
  line-height: 16px;
}

.circle-small .text .small {
  font-size: 12px;
  color: var(--white);
}
.circle-big .text h2 {
  font-size: var(--f50);
  line-height: 31px;
}

.circle-big .text span {
  font-size: var(--f15);
}

.timers-container {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.timer {
  display: flex;
  justify-content: center;
  margin: 10px 0;
}

.time-unit {
  margin: 0 10px;
  text-align: center;
}

.value {
  font-size: 3rem;
  display: block;
  transition: color 0.5s ease;
}

.time-unit small {
  font-size: 1rem;
  color: var(--gray-aaa);
}

/* Add different styles for active countdown */
.counting .value {
  color: var(--blue-react);
}
.counting .value1 {
  color: var(--black);
  text-align: center;
  font-size: var(--f34_484);
  font-weight: 600;
  margin-bottom: -14px;
}
.value2 {
  color: var(--black) !important;
  text-align: center;
  font-family: Outfit;
  font-size: var(--f50);
  font-style: normal;
  font-weight: 600;
  margin-bottom: -15px;
}
.time-unit small {
  color: var(--black);
  font-family: Outfit;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
  text-transform: uppercase;
  display: inline-block;
}
.timer.timer1 .time-unit small {
  font-size: var(--f12_184);
}
.timer.timer2 .time-unit small {
  font-size: var(--f15);
}
.time-unit {
  position: relative;
}
.timer.timer1 .time-unit:last-child span,.timer.timer2 .time-unit:last-child span {
  font-weight: 400 !important;
}
.timer.timer1 .time-unit:nth-child(2)::after,.timer.timer2 .time-unit:nth-child(2)::after {
  content: ":";
  position: absolute;
  right: -13px;
  bottom: 14px;
  color: var(--black);
  text-align: center;
  font-size: var(--f25_758);
  font-weight: 300;
}
.timer.timer2 .time-unit:nth-child(2)::after,.timer.timer2 .time-unit:nth-child(2)::after {
  font-size: var(--f31);
}
.timer.timer1 .time-unit:nth-child(2)::before,.timer.timer2 .time-unit:nth-child(2)::before {
  content: ":";
  position: absolute;
  left: -13px;
  bottom: 14px;
  color: var(--black);
  text-align: center;
  font-size: var(--f25_758);
  font-weight: 300;
}

.timer.timer2 .time-unit:nth-child(2)::after,.timer.timer2 .time-unit:nth-child(2)::before {
  font-size: var(--f31) !important;
}
.givelove__more__txt,.givelove__more__txt2 {
  display: none;
  padding-bottom: 30px;
}

.givelove__more__txt.givelovemoretxt,.givelove__more__txt2.givelovemoretxt2 {
  display: block;
}


/* ===== new code======== */

/* Full height modal styles - keep original width */
#exampleModall .modal-dialog {
  height: 100vh;
  margin: 0 auto;
  display: flex;
  align-items: center;
}

#exampleModall .modal-content {
  height: 100vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

#exampleModall .modal-header {
  flex-shrink: 0;
}

#exampleModall .modal-body {
  flex: 1;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  padding-top: 35px;
  padding-left: 43px;
  padding-right: 43px;
  padding-bottom: 0;
}

#exampleModall .modal__donats__cards {
  display: flex;
  flex-direction: column;
  flex: 1;
  overflow: hidden;
  min-height: 0;
}

#exampleModall .modal-title {
  flex-shrink: 0;
}

.donor-pop-up-scrolls {
  overflow-y: scroll;
  flex: 1;
  scrollbar-width: thin;
  scrollbar-color: var(--theme_color) var(--bgGrayLight);
}

.donor-pop-up-scrolls::-webkit-scrollbar {
  width: 8px;
}

.donor-pop-up-scrolls::-webkit-scrollbar-track {
  background: var(--bgGrayLight);
  border-radius: 10px;
}

.donor-pop-up-scrolls::-webkit-scrollbar-thumb {
  background: var(--theme_color);
  border-radius: 10px;
}

.donor-pop-up-scrolls::-webkit-scrollbar-thumb:hover {
  background: var(--theme_color);
  opacity: 0.8;
}



/* Toggle switch styles removed - replaced with checkbox implementation */

/* Platform Fee Checkbox Styling */
.platform-fee-checkbox {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  width: 20px;
  height: 20px;
  border: 2px solid var(--theme_color);
  border-radius: 4px;
  cursor: pointer;
  position: relative;
  flex-shrink: 0;
  margin-top: 2px;
  transition: all 0.3s ease;
}

.platform-fee-checkbox:checked {
  background-color: var(--theme_color);
  border-color: var(--theme_color);
}

.platform-fee-checkbox:checked::after {
  content: '✓';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: white;
  font-size: 14px;
  font-weight: bold;
}

.platform-fee-checkbox:hover {
  opacity: 0.8;
}

.platform-fee-section label {
  font-size: 16px;
  line-height: 1.4;
}

/* iOS-style Segmented Control */
.ios-segmented-control {
  position: relative;
  display: inline-flex;
  background-color: var(--theme_color);
  border-radius: 8px;
  padding: 2px;
  width: 100%;
  overflow: hidden;
}

.ios-segmented-control input[type="radio"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.ios-segmented-control label {
  position: relative;
  flex: 1;
  padding: 8px 10px;
  text-align: center;
  cursor: pointer;
  color: var(--white);
  font-size: var(--f14);
  font-weight: 500;
  z-index: 2;
  transition: color 0.3s ease;
  user-select: none;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  word-break: break-word;
  hyphens: auto;
}

/* Selected label - purple text and bold */
.ios-segmented-control.company-selected label[for*="company"],
.ios-segmented-control.personal-selected label[for*="personal"] {
  color: var(--theme_color);
  font-weight: 600;
}

/* Unselected label - white text with lighter appearance */
.ios-segmented-control.company-selected label[for*="personal"],
.ios-segmented-control.personal-selected label[for*="company"] {
  color: var(--white);
  font-weight: 500;
  opacity: 0.6;
}

.ios-segmented-control .segmented-control-slider {
  position: absolute;
  top: 2px;
  left: 2px;
  width: calc(50% - 2px);
  height: calc(100% - 4px);
  background-color: var(--white);
  border-radius: 6px;
  transition: transform 0.3s ease;
  z-index: 1;
  box-shadow: 0 2px 4px var(--black-opacity-15);
}

/* Default position for slider (when personal is selected) */
.ios-segmented-control .segmented-control-slider {
  transform: translateX(0);
}

/* Move slider to right when company radio is checked */
.ios-segmented-control.company-selected .segmented-control-slider {
  transform: translateX(100%);
}

/* Move slider to left when personal radio is checked */
.ios-segmented-control.personal-selected .segmented-control-slider {
  transform: translateX(0);
}

/* Mobile responsive styles for segmented control */
@media (max-width: 768px) {
  .ios-segmented-control label {
    padding: 8px 6px !important;
    font-size: var(--f14) !important;
    line-height: 1.4 !important;
    min-height: 60px;
  }

  .ios-segmented-control {
    min-height: 64px;
    padding: 2px;
  }

  .ios-segmented-control .segmented-control-slider {
    min-height: 60px;
  }
}

@media (max-width: 480px) {
  .ios-segmented-control label {
    padding: 8px 4px !important;
    font-size: var(--f14) !important;
    line-height: 1.3 !important;
    min-height: 55px;
  }

  .ios-segmented-control {
    min-height: 59px;
  }

  .ios-segmented-control .segmented-control-slider {
    min-height: 55px;
  }
}

/* ===========================================
   PAYMENT ACCORDION STYLES (Modal 5)
   =========================================== */

.payment-summary-title {
  font-size: var(--f20);
  font-weight: 700;
  color: var(--theme_color);
  margin: 0 0 16px 0;
  padding-bottom: 12px;
  border-bottom: 2px solid var(--theme_color);
  text-align: center;
}

.payment-accordion {
  margin-top: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.pd-accordion-item {
  border: 1px solid #e8e8e8;
  border-radius: 10px;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.05);
}

.pd-accordion-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 20px;
  cursor: pointer;
  font-size: var(--f16);
  font-weight: 600;
  color: var(--black);
  background: var(--white);
  transition: background 0.2s ease, color 0.2s ease;
  user-select: none;
}

.pd-accordion-header:hover {
  background: #f8f8f8;
}

.pd-accordion-header.pd-accordion-open {
  color: var(--theme_color);
  border-bottom: 1px solid #f0f0f0;
}

.pd-accordion-chevron {
  font-size: 20px;
  line-height: 1;
  transition: transform 0.25s ease;
  display: inline-block;
  color: var(--theme_color);
  opacity: 0.7;
}

.pd-accordion-header.pd-accordion-open .pd-accordion-chevron {
  transform: rotate(180deg);
}

.pd-accordion-body {
  padding: 4px 20px 16px;
}

/* ===========================================
   PAYMENT CONFIRMATION MODAL STYLES
   =========================================== */

.payment-summary-card {
  background: #fff;
  border-radius: 12px;
  padding: 0;
  margin-top: 20px;
}

.summary-section {
  padding: 20px;
  border-bottom: 1px solid #f0f0f0;
}

.summary-section:last-child {
  border-bottom: none;
}

.section-title {
  font-size: var(--f18);
  font-weight: 600;
  color: var(--theme_color);
  margin-bottom: 15px;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--theme_color);
}

.summary-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 0;
  border-bottom: 1px solid #f5f5f5;
}

.summary-row:last-child {
  border-bottom: none;
}

.summary-label {
  font-size: var(--f15);
  color: #666;
  font-weight: 500;
}

.summary-value {
  font-size: var(--f15);
  color: #333;
  font-weight: 600;
  text-align: right;
}

/* Discrete platform fee styling */
.platform-fee-discrete {
  margin-top: 2px;
  padding: 2px 0;
  opacity: 0.75;
}

.summary-label-small {
  font-size: 11px;
  color: #888;
  font-weight: 400;
  font-style: italic;
}

.summary-value-small {
  font-size: 12px;
  text-align: right;
}

.platform-fee-row {
  background: rgba(var(--theme_color_rgb, 0, 128, 0), 0.05);
  padding: 12px 10px;
  border-radius: 8px;
  margin-top: 8px;
}

.platform-fee-row .summary-value {
  color: var(--theme_color);
  font-size: var(--f18);
}

/* Modal 5 header styles removed to match other modals */

#DonationProcessModal5 .modal-body {
  padding: 25px;
  background: #fafafa;
}

#DonationProcessModal5 .modal-footer {
  padding: 20px 25px;
  background: #fff;
  border-top: 2px solid #f0f0f0;
}

#DonationProcessModal5 .modal-content {
  border: none;
  border-radius: 12px;
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15);
}

/* Payment Summary Card Styles */
.payment-summary-card {
  background: white;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}

.summary-header {
  background: linear-gradient(135deg, var(--theme_color) 0%, #6a5acd 100%);
  color: white;
  padding: 25px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.summary-header h5 {
  margin: 0;
  font-size: var(--f18);
  font-weight: 600;
  color: white;
}

.summary-amount {
  font-size: var(--f32);
  font-weight: 700;
  color: white;
  letter-spacing: -0.5px;
}

.summary-details {
  padding: 20px;
}

.detail-item {
  display: flex;
  align-items: center;
  gap: 15px;
  padding: 15px;
  margin-bottom: 10px;
  background: #f8f9fa;
  border-radius: 10px;
  transition: all 0.2s ease;
}

.detail-item:hover {
  background: #e9ecef;
  transform: translateX(5px);
}

.detail-item:last-child {
  margin-bottom: 0;
}

.detail-item svg {
  color: var(--theme_color);
  flex-shrink: 0;
  opacity: 0.85;
}

.detail-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.detail-label {
  font-size: 13px;
  color: #6c757d;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.detail-value {
  font-size: var(--f16);
  color: #212529;
  font-weight: 600;
}

.platform-fee-included {
  background: linear-gradient(135deg, #d4edda 0%, #c3e6cb 100%);
  border-left: 4px solid #28a745;
}

.platform-fee-included svg {
  color: #28a745;
}

.platform-fee-included .detail-value {
  color: #155724;
  font-weight: 700;
}

/* Payment Loading Styles */
.payment-loading {
  text-align: center;
  padding: 60px 20px;
}

.payment-loading .spinner-border {
  color: var(--theme_color);
  width: 3rem;
  height: 3rem;
}

.payment-loading p {
  margin-top: 20px;
  font-size: var(--f16);
  font-weight: 500;
  color: #6c757d;
}

/* Responsive styles */
@media (max-width: 768px) {
  .summary-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }

  .summary-amount {
    font-size: var(--f28);
  }

  .detail-item {
    padding: 12px;
    gap: 12px;
  }

  .detail-item svg {
    width: 18px;
    height: 18px;
  }

  .detail-value {
    font-size: var(--f14);
  }

  .detail-label {
    font-size: 12px;
  }
}

/*===================== ORGANIZATION INFO MODAL START =====================*/
.organization-info-modal .modal-content {
  border: none;
  border-radius: 12px;
  box-shadow: 0 10px 40px var(--black-opacity-15);
  overflow: hidden;
}

.organization-info-modal .modal-body {
  padding: 40px;
  background: var(--white);
}

.organization-info {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.organization-info__logo {
  text-align: center;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--gray-E3E3E3);
  margin-bottom: 10px;
}

.organization-info__logo img {
  max-width: 180px;
  max-height: 100px;
  height: auto;
  object-fit: contain;
}

.organization-info__title {
  font-size: var(--f24);
  font-weight: 600;
  color: var(--darkGray);
  margin-bottom: 20px;
  text-align: center;
}

.organization-info__content {
  background: var(--bgGrayLight);
  border-radius: 8px;
  padding: 25px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.organization-info__item {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.organization-info__label {
  font-size: var(--f13);
  font-weight: 600;
  color: var(--textGray);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.organization-info__value {
  font-size: var(--f16);
  color: var(--darkGray);
  font-weight: 500;
  line-height: 1.5;
}

.organization-info__link {
  color: var(--theme_color);
  text-decoration: none;
  transition: color 0.2s ease;
}

.organization-info__link:hover {
  color: var(--secondaryColor);
  text-decoration: underline;
}

.organization-info__address {
  line-height: 1.6;
}

/* Responsive styles for organization modal */
@media (max-width: 576px) {
  .organization-info-modal .modal-body {
    padding: 25px 20px;
  }

  .organization-info__title {
    font-size: var(--f20);
  }

  .organization-info__logo img {
    max-width: 150px;
  }

  .organization-info__content {
    padding: 20px;
    gap: 15px;
  }

  .organization-info__label {
    font-size: var(--f12);
  }

  .organization-info__value {
    font-size: var(--f14);
  }
}
/*===================== ORGANIZATION INFO MODAL END =====================*/

/*===================== ORGANIZATION HEADER RESPONSIVE =====================*/
/* Medium desktop screens */
@media (max-width: 1400px) {
  .org-name-desktop {
    font-size: 1.3rem;
  }

  .header__area.scrolled .org-name-desktop {
    font-size: var(--f16);
  }
}

/* Smaller desktop screens */
@media (max-width: 1200px) {
  .org-name-desktop {
    font-size: 1.2rem;
  }

  .org-logo-desktop {
    width: 80px;
    max-height: 60px;
  }

  .header__area.scrolled .org-logo-desktop {
    width: 45px;
    max-height: 40px;
  }

  .header__area.scrolled .org-name-desktop {
    font-size: var(--f14);
  }
}

/* Tablet screens */
@media (max-width: 768px) {
  .org-header-mobile {
    gap: 10px;
  }

  .org-logo-mobile {
    max-width: 70px;
    max-height: 45px;
  }

  .org-name-mobile {
    font-size: 0.95rem;
  }
}

/* Small mobile screens */
@media (max-width: 480px) {
  .org-header-mobile {
    gap: 8px;
  }

  .org-logo-mobile {
    max-width: 60px;
    max-height: 40px;
  }

  .org-name-mobile {
    font-size: 0.9rem;
  }
}
/*===================== ORGANIZATION HEADER RESPONSIVE END =====================*/

/*===================== CAMPAIGN MESSAGE MODAL START =====================*/
.campaign-message-modal .modal-content {
  border-radius: 15px;
  border: none;
  box-shadow: 0 5px 25px rgba(0, 0, 0, 0.15);
}

.campaign-message-modal .modal-header {
  border-bottom: none;
  padding: 20px 20px 0;
  position: relative;
}

.campaign-message-modal__close {
  position: absolute;
  top: 15px;
  right: 15px;
  width: 35px;
  height: 35px;
  opacity: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}

.campaign-message-modal__body {
  padding: 30px 40px;
  max-height: 70vh;
  overflow-y: auto;
}

.campaign-message-modal__body::-webkit-scrollbar {
  width: 8px;
}

.campaign-message-modal__body::-webkit-scrollbar-track {
  background: var(--gray-F5F5F5);
  border-radius: 10px;
}

.campaign-message-modal__body::-webkit-scrollbar-thumb {
  background: var(--theme_color);
  border-radius: 10px;
}

.campaign-message-modal__body::-webkit-scrollbar-thumb:hover {
  background: var(--theme_color);
  opacity: 0.8;
}

.campaign-message-modal__content {
  font-size: var(--f16);
  line-height: 1.8;
  color: var(--black);
}

.campaign-message-modal__content p {
  margin-bottom: 15px;
}

.campaign-message-modal__content h1,
.campaign-message-modal__content h2,
.campaign-message-modal__content h3,
.campaign-message-modal__content h4,
.campaign-message-modal__content h5,
.campaign-message-modal__content h6 {
  color: var(--theme_color);
  margin-top: 20px;
  margin-bottom: 10px;
}

.campaign-message-modal__content ul,
.campaign-message-modal__content ol {
  margin-bottom: 15px;
  padding-left: 25px;
}

.campaign-message-modal__content li {
  margin-bottom: 8px;
}

/* Responsive adjustments */
@media (max-width: 768px) {
  .campaign-message-modal__body {
    padding: 20px 25px;
    max-height: 60vh;
  }

  .campaign-message-modal__close {
    width: 30px;
    height: 30px;
    top: 12px;
    right: 12px;
  }
}

@media (max-width: 480px) {
  .campaign-message-modal__body {
    padding: 15px 20px;
    max-height: 65vh;
  }

  .campaign-message-modal__content {
    font-size: var(--f14);
  }
}
/*===================== CAMPAIGN MESSAGE MODAL END =====================*/

/* Tablet responsive adjustments (768px - 1094px) */
@media (min-width: 768px) and (max-width: 1094px) {
  /* Hide the desktop view-donors button on tablets */
  .view-donors-mobile-btn.d-none.d-lg-block {
    display: none !important;
  }

  /* Show the mobile view-donors button on tablets */
  .view-donors-mobile-btn.d-block.d-lg-none {
    display: block !important;
  }

  /* Center the donors5 container - override the margin-left: auto */
  .donors5 {
    margin-left: 0;
    margin-right: 0;
    align-items: center;
    width: 100%;
  }

  .visit-main-page-btn {
    align-self: center;
  }

  /* Make progress bar significantly bigger on tablet screens */
  .goal__donations {
    max-width: 600px;
    width: 100%;
  }

  /* Center the entire donation section */
  .donation__times {
    justify-content: center;
  }
}

/*===================== VENOBOX CLOSE BUTTON ENHANCEMENT =====================*/
/* Ensure VenoBox overlay is above all other elements including modals and bottom bar */
.vbox-overlay {
  z-index: 9999999999 !important;
}

/* Make the close button more visible and prominent */
.vbox-close {
  background-color: rgba(255, 255, 255, 0.2) !important;
  border-radius: 50% !important;
  width: 40px !important;
  height: 40px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  top: 15px !important;
  right: 15px !important;
  padding: 0 !important;
  transition: all 0.3s ease !important;
  z-index: 9999999999 !important;
  position: fixed !important;
  opacity: 1 !important;
  visibility: visible !important;
}

.vbox-close:hover {
  background-color: rgba(255, 255, 255, 0.3) !important;
  transform: scale(1.1) !important;
  opacity: 1 !important;
}

.vbox-close-icon {
  width: 24px !important;
  height: 24px !important;
  color: #fff !important;
  display: block !important;
}

/* Mobile responsive adjustments for close button */
@media (max-width: 768px) {
  .vbox-close {
    width: 44px !important;
    height: 44px !important;
    top: 10px !important;
    right: 10px !important;
    background-color: rgba(255, 255, 255, 0.3) !important;
    z-index: 9999999999 !important;
    display: flex !important;
    opacity: 1 !important;
    visibility: visible !important;
  }

  .vbox-close-icon {
    width: 22px !important;
    height: 22px !important;
  }
}

/* Ensure close button is always on top and visible */
.vbox-overlay .vbox-close {
  pointer-events: auto !important;
}
/*===================== VENOBOX CLOSE BUTTON ENHANCEMENT END =====================*/

/*===================== MEDIA TEXT SECTION START =====================*/
.media-text__area {
  padding: 60px 0;
}

.media-text__wrap {
  display: flex;
  justify-content: center;
  align-items: center;
}

.media-text__content {
  max-width: 800px;
  width: 100%;
  text-align: center;
}

.media-text__content p {
  margin-bottom: 1.5rem;
  line-height: 1.8;
  color: rgb(32, 33, 34);
  font-size: 16px;
}

.media-text__content p:empty {
  margin-bottom: 0;
  height: 0;
}

.media-text__content img {
  max-width: 100%;
  height: auto;
  display: block;
  margin: 2rem auto;
  border-radius: 8px;
}

.media-text__content strong {
  font-weight: 700;
}

/* Mobile responsive */
@media (max-width: 768px) {
  .media-text__area {
    padding: 40px 0;
  }
  
  .media-text__content {
    max-width: 100%;
    padding: 0 15px;
  }
  
  .media-text__content p {
    font-size: 14px;
  }
}
/*===================== MEDIA TEXT SECTION END =====================*/
