/* ==========================================================================
   Components — Buttons, Cards, Accordion, Progress Bars, Counters
   ========================================================================== */

/* ---- Primary Button ---- */

.btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-heading);
  font-size: var(--fs-button);
  font-weight: var(--fw-medium);
  text-transform: uppercase;
  padding: 14px 34px;
  border-radius: var(--radius-button);
  border: 2px solid transparent;
  transition: all var(--transition-fast);
  cursor: pointer;
  text-decoration: none;
  line-height: 1.4;
}

.btn--filled {
  background: var(--color-dark);
  color: var(--color-white);
  border-color: var(--color-dark);
}

.btn--filled:hover {
  background: var(--color-green);
  border-color: var(--color-green);
  color: var(--color-white);
}

.btn--outline {
  background: transparent;
  color: var(--color-dark);
  border-color: var(--color-dark);
}

.btn--outline:hover {
  background: var(--color-dark);
  color: var(--color-white);
}

.btn--outline-white {
  background: transparent;
  color: var(--color-white);
  border-color: var(--color-white);
}

.btn--outline-white:hover {
  background: var(--color-white);
  color: var(--color-dark);
}

.btn--gold {
  background: var(--color-gold);
  color: var(--color-dark);
  border-color: var(--color-gold);
}

.btn--gold:hover {
  background: var(--color-dark);
  border-color: var(--color-dark);
  color: var(--color-white);
}

.btn--small {
  padding: 10px 24px;
  font-size: 16px;
}

.btn .arrow {
  font-size: 14px;
  transition: transform var(--transition-fast);
}

.btn:hover .arrow {
  transform: translateX(4px);
}


/* ---- Icon Box (Service Card) ---- */

.icon-box {
  border: 2px solid var(--color-gold);
  border-radius: var(--radius-card);
  padding: var(--card-padding);
  text-align: left;
  transition: all var(--transition-fast);
}

.icon-box:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-4px);
}

.icon-box__icon {
  width: 70px;
  height: 70px;
  margin-bottom: 20px;
  color: var(--color-gold);
}

.icon-box__icon svg {
  width: 100%;
  height: 100%;
}

.icon-box__icon i {
  font-size: 48px;
  color: var(--color-gold);
}

.icon-box__title {
  font-family: var(--font-heading);
  font-size: var(--fs-card-title);
  font-weight: var(--fw-semibold);
  color: var(--color-gold);
  text-transform: uppercase;
  margin-bottom: 14px;
}

.icon-box__text {
  font-size: var(--fs-body);
  color: var(--color-body);
  line-height: var(--lh-body);
}


/* ---- Event/Cause Card ---- */

.cause-card {
  background: var(--color-white);
  border-radius: var(--radius-card);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  transition: all var(--transition-fast);
}

.cause-card:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-4px);
}

.cause-card__image {
  position: relative;
  overflow: hidden;
  aspect-ratio: 16/10;
}

.cause-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-medium);
}

.cause-card:hover .cause-card__image img {
  transform: scale(1.06);
}

.cause-card__category {
  position: absolute;
  top: 20px;
  left: 20px;
  background: var(--color-gold);
  color: var(--color-dark);
  font-family: var(--font-heading);
  font-size: 14px;
  font-weight: var(--fw-medium);
  padding: 6px 16px;
  border-radius: var(--radius-button);
  text-transform: uppercase;
}

.cause-card__body {
  padding: 30px var(--card-padding);
}

.cause-card__title {
  font-family: var(--font-heading);
  font-size: clamp(22px, 2vw, 32px);
  font-weight: var(--fw-semibold);
  color: var(--color-dark);
  text-transform: uppercase;
  margin-bottom: 14px;
  line-height: var(--lh-heading);
}

.cause-card__title a:hover {
  color: var(--color-gold);
}

.cause-card__text {
  font-size: 16px;
  color: var(--color-muted);
  line-height: var(--lh-body);
  margin-bottom: 20px;
}

.cause-card__meta {
  display: flex;
  flex-direction: column;
  gap: 8px;
  font-size: 15px;
  color: var(--color-muted);
  margin-bottom: 16px;
}

.cause-card__meta-item {
  display: flex;
  align-items: center;
  gap: 8px;
}

.cause-card__meta-item svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  fill: var(--color-gold);
}

.cause-card__read-more {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-heading);
  font-size: 16px;
  font-weight: var(--fw-medium);
  color: var(--color-dark);
  text-transform: uppercase;
  transition: color var(--transition-fast);
}

.cause-card__read-more:hover {
  color: var(--color-gold);
}

.cause-card__read-more svg {
  width: 18px;
  height: 18px;
  transition: transform var(--transition-fast);
}

.cause-card__read-more:hover svg {
  transform: translateX(4px);
}


/* ---- Donation Card ---- */

.donation-card {
  background: var(--color-white);
  border-radius: var(--radius-card);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  transition: all var(--transition-fast);
}

.donation-card:hover {
  box-shadow: var(--shadow-hover);
}

.donation-card__image {
  position: relative;
  overflow: hidden;
  aspect-ratio: 16/10;
}

.donation-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-medium);
}

.donation-card:hover .donation-card__image img {
  transform: scale(1.06);
}

.donation-card__tag {
  position: absolute;
  top: 20px;
  left: 20px;
  background: var(--color-gold);
  color: var(--color-dark);
  font-family: var(--font-heading);
  font-size: 14px;
  font-weight: var(--fw-medium);
  padding: 6px 16px;
  border-radius: var(--radius-button);
  text-transform: uppercase;
}

.donation-card__body {
  padding: 28px var(--card-padding);
}

.donation-card__title {
  font-family: var(--font-heading);
  font-size: clamp(20px, 1.6vw, 26px);
  font-weight: var(--fw-semibold);
  color: var(--color-dark);
  text-transform: uppercase;
  margin-bottom: 16px;
}

.donation-card__title a:hover {
  color: var(--color-gold);
}

/* Progress Bar */
.progress-wrap {
  margin-bottom: 16px;
}

.progress-bar {
  height: 10px;
  background: var(--color-border);
  border-radius: 10px;
  overflow: hidden;
  position: relative;
}

.progress-bar__fill {
  height: 100%;
  border-radius: 10px;
  background: var(--gradient-progress);
  width: 0%;
  transition: width 1.5s ease-out;
}

.progress-stats {
  display: flex;
  justify-content: space-between;
  margin-top: 12px;
  font-size: 15px;
}

.progress-stats__raised {
  font-weight: var(--fw-medium);
  color: var(--color-dark);
}

.progress-stats__raised span {
  color: var(--color-gold);
  font-weight: var(--fw-semibold);
}

.progress-stats__goal {
  color: var(--color-muted);
}

.progress-stats__goal span {
  color: var(--color-dark);
  font-weight: var(--fw-medium);
}


/* ---- Counter Badge ---- */

.counter-badge {
  background: var(--color-dark);
  border-radius: var(--radius-counter);
  padding: 30px 40px;
  text-align: center;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-width: 180px;
  min-height: 180px;
}

.counter-badge__number {
  font-family: var(--font-body);
  font-size: 60px;
  font-weight: var(--fw-bold);
  color: var(--color-white);
  line-height: 1;
  margin-bottom: 4px;
}

.counter-badge__label {
  font-family: var(--font-body);
  font-size: 16px;
  color: rgba(255, 255, 255, 0.7);
  text-transform: uppercase;
}


/* ---- Accordion ---- */

.accordion {
  display: flex;
  flex-direction: column;
}

.accordion__item {
  border-bottom: 1px solid var(--color-border);
}

.accordion__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 24px 0;
  cursor: pointer;
  transition: color var(--transition-fast);
  gap: 16px;
}

.accordion__title {
  font-family: var(--font-heading);
  font-size: clamp(18px, 1.4vw, 22px);
  font-weight: var(--fw-semibold);
  color: var(--color-dark);
  text-transform: uppercase;
  flex: 1;
}

.accordion__icon {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
  color: var(--color-dark);
  transition: all var(--transition-fast);
}

.accordion__item.is-active .accordion__header {
  color: var(--color-orange);
}

.accordion__item.is-active .accordion__title {
  color: var(--color-orange);
}

.accordion__item.is-active .accordion__icon {
  color: var(--color-orange);
}

.accordion__body {
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--transition-medium);
}

.accordion__content {
  padding: 0 0 24px 0;
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  color: var(--color-muted);
}


/* ---- Pie / Circle Chart ---- */

.circle-chart {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.circle-chart__svg {
  width: 140px;
  height: 140px;
  transform: rotate(-90deg);
  margin-bottom: 14px;
}

.circle-chart__bg {
  fill: none;
  stroke: var(--color-border);
  stroke-width: 6;
}

.circle-chart__fill {
  fill: none;
  stroke: var(--color-gold);
  stroke-width: 6;
  stroke-linecap: round;
  stroke-dasharray: 408;
  stroke-dashoffset: 408;
  transition: stroke-dashoffset 1.5s ease-out;
}

.circle-chart__value {
  font-family: var(--font-heading);
  font-size: 28px;
  font-weight: var(--fw-semibold);
  color: var(--color-dark);
  margin-bottom: 4px;
}

.circle-chart__label {
  font-size: 15px;
  color: var(--color-muted);
}


/* ---- Team Card ---- */

.team-card {
  text-align: center;
  transition: transform var(--transition-fast);
}

.team-card:hover {
  transform: translateY(-6px);
}

.team-card__image {
  border-radius: var(--radius-card);
  overflow: hidden;
  margin-bottom: 20px;
  aspect-ratio: 4/5;
}

.team-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.team-card__name {
  font-family: var(--font-heading);
  font-size: clamp(22px, 1.8vw, 30px);
  font-weight: var(--fw-semibold);
  color: var(--color-dark);
  text-transform: uppercase;
  margin-bottom: 6px;
}

.team-card__role {
  font-size: var(--fs-body);
  color: var(--color-muted);
  text-transform: capitalize;
}


/* ---- Blog Card ---- */

.blog-card {
  background: var(--color-white);
  border-radius: var(--radius-card);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  transition: all var(--transition-fast), opacity 0.3s ease, display 0s;
}

.blog-card:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-4px);
}

.blog-card__image {
  overflow: hidden;
  aspect-ratio: 16/10;
}

.blog-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-medium);
}

.blog-card:hover .blog-card__image img {
  transform: scale(1.06);
}

.blog-card__body {
  padding: 28px var(--card-padding);
}

.blog-card__meta {
  display: flex;
  align-items: center;
  gap: 16px;
  font-size: 14px;
  color: var(--color-muted);
  margin-bottom: 14px;
}

.blog-card__meta span {
  display: flex;
  align-items: center;
  gap: 6px;
}

.blog-card__category {
  color: var(--color-gold);
  font-weight: var(--fw-medium);
}

.blog-card__title {
  font-family: var(--font-heading);
  font-size: clamp(20px, 1.6vw, 26px);
  font-weight: var(--fw-semibold);
  color: var(--color-dark);
  text-transform: uppercase;
  margin-bottom: 12px;
  line-height: var(--lh-heading);
}

.blog-card__title a:hover {
  color: var(--color-gold);
}

.blog-card__excerpt {
  font-size: 16px;
  color: var(--color-muted);
  line-height: var(--lh-body);
  margin-bottom: 18px;
}

.blog-card__read-more {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-heading);
  font-size: 16px;
  font-weight: var(--fw-medium);
  color: var(--color-dark);
  text-transform: uppercase;
}

.blog-card__read-more:hover {
  color: var(--color-gold);
}

.blog-card__read-more svg {
  width: 18px;
  height: 18px;
  transition: transform var(--transition-fast);
}

.blog-card__read-more:hover svg {
  transform: translateX(4px);
}
