/*********************************************************************************
* 26. Training & Donation Pages
*********************************************************************************/

/* ---- Fix bullet lists inside .single-service content ---- */
.single-service .content ul:not(.gallery):not(.checklist) {
  list-style: disc;
  margin-left: 1.5rem;
  margin-bottom: 1rem;
}
.single-service .content ul:not(.gallery):not(.checklist) li {
  margin-bottom: 0.4rem;
  color: #6c757d;
}

/* ---- btn-outline-primary theme match ---- */
.btn.btn-outline-primary {
  color: #F25624 !important;
  border-color: #F25624 !important;
  background-color: transparent !important;
}
.btn.btn-outline-primary::before {
  background: #F25624;
}
.btn.btn-outline-primary:hover {
  color: #ffffff !important;
  border-color: #F25624 !important;
}

/* ---- btn-outline-secondary theme match ---- */
.btn.btn-outline-secondary {
  color: #0c0c0c !important;
  border-color: #0c0c0c !important;
  background-color: transparent !important;
}
.btn.btn-outline-secondary::before {
  background: #0c0c0c;
}
.btn.btn-outline-secondary:hover {
  color: #ffffff !important;
  border-color: #0c0c0c !important;
}

/* ---- Accordion (Mission Statement) ---- */
.accordion-item {
  border: 1px solid #dee2e6;
  border-radius: 8px !important;
  overflow: hidden;
}
.accordion-button {
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  font-size: 16px;
  color: #0c0c0c;
  background-color: #fff;
  padding: 1rem 1.25rem;
}
.accordion-button:not(.collapsed) {
  color: #F25624;
  background-color: #fef5f2;
  box-shadow: none;
}
.accordion-button:focus {
  border-color: #F25624;
  box-shadow: 0 0 0 0.15rem rgba(242, 86, 36, 0.25);
}
.accordion-button::after {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23F25624'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
}
.accordion-button:not(.collapsed)::after {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23F25624'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
}
.accordion-body {
  font-size: 18px;
  color: #6c757d;
  line-height: 1.8;
  font-style: italic;
  border-top: 2px solid #F25624;
}

/* ---- Impact Area Cards (Training Page) ---- */
.impact-card {
  background-color: #ffffff;
  border-radius: 10px;
  padding: 2rem 1.5rem;
  text-align: center;
  height: 100%;
  border-top: 4px solid #F25624;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.impact-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
}
.impact-card .impact-icon {
  font-size: 2.5rem;
  color: #F25624;
  margin-bottom: 1rem;
}
.impact-card h5 {
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  color: #0c0c0c;
  margin-bottom: 0.75rem;
}
.impact-card p {
  color: #6c757d;
  font-size: 16px;
  margin-bottom: 0;
}

/* ---- Vision List Styling ---- */
.vision-list {
  list-style: none !important;
  margin-left: 0 !important;
  padding: 0;
}
.vision-list li {
  position: relative;
  padding: 0.6rem 0 0.6rem 2rem;
  border-bottom: 1px solid #eee;
  font-size: 18px;
}
.vision-list li:last-child {
  border-bottom: none;
}
.vision-list li::before {
  content: "\f058";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  color: #F25624;
  position: absolute;
  left: 0;
  top: 0.65rem;
}

/* ---- Sponsor Cards (Donation Page) ---- */
.sponsor-card {
  border: none;
  border-radius: 10px;
  overflow: hidden;
  height: 100%;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.sponsor-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.15);
}
.sponsor-card .card-header {
  border-radius: 0;
  border-bottom: none;
  padding: 1.5rem 1rem;
  text-align: center;
}
.sponsor-card .card-header i {
  display: block;
  margin-bottom: 0.5rem;
}
.sponsor-card .card-header h5 {
  color: #ffffff;
  margin-bottom: 0.25rem;
}
.sponsor-card .card-header small {
  color: rgba(255, 255, 255, 0.85);
  font-size: 15px;
  font-weight: 600;
}
.sponsor-card .card-body {
  padding: 1.25rem;
}
.sponsor-card .card-body ul {
  list-style: none !important;
  margin-left: 0 !important;
  padding: 0;
}
.sponsor-card .card-body ul li {
  padding: 0.5rem 0;
  border-bottom: 1px solid #eee;
  font-size: 15px;
  color: #6c757d;
}
.sponsor-card .card-body ul li:last-child {
  border-bottom: none;
}
.sponsor-card .card-body ul li i {
  color: #28a745;
  margin-right: 8px;
}

/* Tier Colors */
.tier-bronze .card-header {
  background: linear-gradient(135deg, #cd7f32, #a0622e);
}
.tier-silver .card-header {
  background: linear-gradient(135deg, #b0b3b8, #8a8d91);
}
.tier-gold .card-header {
  background: linear-gradient(135deg, #d4a017, #b8860b);
}
.tier-platinum .card-header {
  background: linear-gradient(135deg, #2c3e50, #1a252f);
}

/* ---- Expansion Features List (Donation Page) ---- */
.expansion-list {
  list-style: none !important;
  margin-left: 0 !important;
  padding: 0;
}
.expansion-list li {
  position: relative;
  padding: 0.5rem 0 0.5rem 2rem;
  font-size: 18px;
  color: #6c757d;
}
.expansion-list li::before {
  content: "\f00c";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  color: #F25624;
  position: absolute;
  left: 0;
  top: 0.55rem;
}

/* ---- Call to Action Box ---- */
.cta-box {
  background: linear-gradient(135deg, #fef5f2 0%, #ffffff 100%);
  border: 2px solid #F25624;
  border-radius: 12px;
  padding: 2.5rem;
}

/* ---- Mail Info Card ---- */
.mail-info {
  background-color: #ffffff;
  border-left: 4px solid #F25624;
  border-radius: 8px;
  padding: 1.5rem 2rem;
  display: inline-block;
}

/* ---- Nonprofit Badge ---- */
.nonprofit-badge {
  background-color: #ffffff;
  border: 2px solid #dee2e6;
  border-radius: 10px;
  padding: 1.5rem 2rem;
  text-align: center;
}
.nonprofit-badge i {
  font-size: 2rem;
  color: #F25624;
  margin-bottom: 0.75rem;
  display: block;
}

/* ---- Location Tags (Join Our Team) ---- */
.location-tags {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
}
.location-tag {
  display: inline-block;
  background-color: #ffffff;
  border: 2px solid #F25624;
  color: #F25624;
  padding: 0.5rem 1.25rem;
  border-radius: 50px;
  font-weight: 600;
  font-size: 15px;
  transition: all 0.3s ease;
}
.location-tag:hover {
  background-color: #F25624;
  color: #ffffff;
}


/*********************************************************************************
* 27. Meet Our Team - Arrow Banners & Parallax Hero
*********************************************************************************/

/* ---- Parallax Hero Section ---- */
.team-parallax-hero {
  background: url("img/team-hero.jpg") no-repeat center center;
  background-size: cover;
  background-attachment: fixed;
  min-height: 500px;
  position: relative;
}
.team-parallax-overlay {
  background: rgba(12, 12, 12, 0.6);
  min-height: 500px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 60px 0;
}
.team-parallax-content {
  max-width: 700px;
  margin: 0 auto;
}
.team-hero-logo {
  max-width: 80px;
  height: auto;
}
.team-parallax-content h2 {
  font-family: "Poppins", sans-serif;
  font-weight: 700;
  font-size: 48px;
}
.team-parallax-content p {
  font-size: 17px;
  line-height: 1.8;
  color: rgba(255, 255, 255, 0.9);
}

/* ---- Team Profiles Section ---- */
.team-profiles-section {
  background-color: #f0f0f0;
}

/* ---- Section Headings ---- */
.staff-section-heading h3 {
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  color: #0c0c0c;
  font-size: 28px;
}
.staff-divider {
  border: none;
  height: 3px;
  background: linear-gradient(to right, #F25624, transparent);
  margin-top: 0.5rem;
  opacity: 1;
}

/* ---- Arrow Banner Wrapper ---- */
.arrow-banner-wrapper {
  max-width: 850px;
  position: relative;
}

/* ---- Arrow Banner (the chevron/arrow shaped card) ---- */
.arrow-banner {
  display: flex;
  align-items: center;
  padding: 0;
  position: relative;
  border-radius: 12px;
  overflow: visible;
  min-height: 110px;
  clip-path: polygon(0% 0%, 92% 0%, 100% 50%, 92% 100%, 0% 100%);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.arrow-banner:hover {
  transform: translateX(5px);
}

/* ---- Banner Color Variants (matching PDF) ---- */
.arrow-banner.color-1 {
  background: linear-gradient(135deg, #d44a1c, #F25624);
}
.arrow-banner.color-2 {
  background: linear-gradient(135deg, #c9a020, #ddb837);
}
.arrow-banner.color-3 {
  background: linear-gradient(135deg, #3a1e14, #5c3524);
}

/* ---- Hexagonal Photo Frame ---- */
.hex-photo {
  flex-shrink: 0;
  width: 105px;
  height: 105px;
  margin: 0 20px 0 8px;
  position: relative;
}
.hex-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
  border: none;
}
.hex-placeholder {
  width: 100%;
  height: 100%;
  background: rgba(255, 255, 255, 0.2);
  clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255, 255, 255, 0.7);
  font-size: 2rem;
}

/* ---- Arrow Info (Name, Divider, Details) ---- */
.arrow-info {
  flex: 1;
  padding: 15px 60px 15px 0;
  min-width: 0;
}
.arrow-name {
  font-family: "Poppins", sans-serif;
  font-weight: 700;
  color: #ffffff;
  font-size: 20px;
  margin-bottom: 6px;
  line-height: 1.3;
}
.arrow-divider {
  width: 80%;
  max-width: 280px;
  height: 2px;
  background-color: rgba(255, 255, 255, 0.5);
  margin-bottom: 8px;
}
.arrow-details {
  font-size: 14px;
  color: rgba(255, 255, 255, 0.9);
  line-height: 1.6;
  margin-bottom: 0;
  font-style: italic;
}

/* ---- Bio Toggle Button (positioned on wrapper, outside clip-path) ---- */
.arrow-bio-btn {
  position: absolute;
  right: 45px;
  top: 48px;
  z-index: 2;
  background: transparent;
  border: 2px solid rgba(255, 255, 255, 0.7);
  border-radius: 50%;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #ffffff;
  font-size: 14px;
  cursor: pointer;
  transition: all 0.3s ease;
  padding: 0;
}
.arrow-bio-btn:hover {
  background: rgba(255, 255, 255, 0.2);
  border-color: #ffffff;
}
.arrow-bio-btn[aria-expanded="true"] i {
  transform: rotate(180deg);
}
.arrow-bio-btn i {
  transition: transform 0.3s ease;
}

/* ---- Expanded Bio Content ---- */
.arrow-bio-collapse {
  max-width: 850px;
}
.arrow-bio-content {
  background-color: #ffffff;
  border: 1px solid #dee2e6;
  border-top: 3px solid #F25624;
  border-radius: 0 0 10px 10px;
  padding: 2rem 2rem 1.5rem 2rem;
  margin-top: 6px;
}
.arrow-bio-content p {
  font-size: 15px;
  line-height: 1.7;
  color: #6c757d;
  margin-bottom: 1.5rem;
}
.arrow-bio-content p:last-child {
  margin-bottom: 0;
}

/* ---- Bio Coming Soon ---- */
.arrow-bio-coming-soon {
  max-width: 850px;
  text-align: left;
  padding: 0.75rem 1.5rem;
  font-size: 14px;
  font-style: italic;
  color: #adb5bd;
}
.arrow-bio-coming-soon i {
  color: #F25624;
  opacity: 0.5;
  margin-right: 6px;
}


/* ---- Responsive: Parallax & Arrow Banners ---- */
@media all and (max-width: 992px) {
  .team-parallax-content h2 {
    font-size: 36px;
  }
  .arrow-banner {
    clip-path: polygon(0% 0%, 90% 0%, 100% 50%, 90% 100%, 0% 100%);
  }
  .arrow-name {
    font-size: 17px;
  }
}

@media all and (max-width: 768px) {
  /* Parallax fallback for mobile (fixed attachment not supported) */
  .team-parallax-hero {
    background-attachment: scroll;
    min-height: 400px;
  }
  .team-parallax-overlay {
    min-height: 400px;
  }
  .team-parallax-content h2 {
    font-size: 30px;
  }
  .staff-section-heading h3 {
    font-size: 22px;
  }
  /* Arrow banner adjustments */
  .arrow-banner {
    clip-path: none;
    border-radius: 10px;
    flex-wrap: nowrap;
    min-height: 100px;
  }
  .hex-photo {
    width: 75px;
    height: 75px;
    margin: 0 12px 0 10px;
  }
  .hex-placeholder {
    font-size: 1.5rem;
  }
  .arrow-info {
    padding: 12px 40px 12px 0;
  }
  .arrow-name {
    font-size: 15px;
  }
  .arrow-details {
    font-size: 12px;
  }
  .arrow-bio-btn {
    width: 30px;
    height: 30px;
    right: 10px;
    top: 35px;
    font-size: 12px;
  }
  .arrow-bio-content {
    padding: 1.25rem;
  }
  /* Other page responsive */
  .impact-card {
    margin-bottom: 1rem;
  }
  .sponsor-card {
    margin-bottom: 1rem;
  }
  .cta-box {
    padding: 1.5rem;
  }
  .mail-info {
    display: block;
  }
  .location-tag {
    font-size: 13px;
    padding: 0.4rem 1rem;
  }
}

@media all and (max-width: 480px) {
  .arrow-name {
    font-size: 14px;
  }
  .hex-photo {
    width: 60px;
    height: 60px;
    margin: 0 10px 0 8px;
  }
}
