/* ==========================================================================
   Content Card Styles (/css/content-card.css)
   ==========================================================================

   TABLE OF CONTENTS
   --------------------------------------------------------------------------
   1. MAIN WRAPPER (.content-cards)
   2. GENERAL CARD STRUCTURE (.content-card)
   3. CARD TEXT CONTENT (.card-text, h2, p, a)
   4. CARD IMAGE CONTENT (.card-image)
   5. PLEDGE COUNTER COMPONENT (#pledge-counter)

========================================================================== */


/* ==========================================================================
   1. MAIN WRAPPER (.content-cards)
   ========================================================================== */

.content-cards {
  padding: 0;
  margin-top: 0;
}

#content-cards-one {
  margin-top: 5rem;
}

#content-cards-two {
  margin-top: -2rem;
  position: relative;
  z-index: 6;
}

#content-cards-two .image-left {
  margin-bottom: 0;
}

/* --- Breakpoints for Wrappers --- */
@media screen and (min-width: 1200px) {
  #content-cards-two {
    margin-top: 0;
  }
}


/* ==========================================================================
   2. GENERAL CARD STRUCTURE (.content-card)
   ========================================================================== */

.content-card {
  display: flex;
  flex-direction: column;
  max-width: 280px;
  margin: 5rem auto;
}

/* --- Breakpoints for .content-card --- */
@media screen and (min-width: 768px) {
  .content-card {
    min-width: 650px;
  }
}
@media screen and (min-width: 1200px) {
  .content-card {
    flex-direction: row;
    max-width: 90%;
    gap: 2.5rem;
    margin-bottom: 20rem;
  }
}
@media screen and (min-width: 1920px) {
  .content-card {
    max-width: 1600px;
    gap: 3.5rem;
  }
}


/* ==========================================================================
   3. CARD TEXT CONTENT (.card-text, h2, p, a)
   ========================================================================== */

.card-text {
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
}

.content-card-event-bar {
  width: 100%;
  display: flex;
  height: 0.6rem;
}

.content-card-event-bar > div {
  height: 0.6rem;
  flex: 1;
}

.blue { background-color: #8f99c8; }
.green { background-color: #9abeb0; }
.purple { background-color: #a592c7; }
.yellow { background-color: #f0cb8e; }

.card-text h2 {
  color: #192147;
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
  margin: 1.25rem 0;
  font-size: 2.1rem;
  line-height: normal;
  width: 100%;
}

.card-text p {
  font-family: "Montserrat", sans-serif;
  font-weight: 600;
  line-height: 1.6;
  font-size: 1.4rem;
}

.card-text a {
  /* --- Positioning & Box Model --- */
  display: inline-flex;
  justify-content: center;
  align-items: center;
  height: 53px;
  margin: 1.5rem 0 2.5rem 0;
  padding: 1.5rem 2rem;
  border: 2px solid #192147;
  border-radius: 20.909px;

  /* --- Typography --- */
  color: #192147;
  font-family: "Barlow Condensed", sans-serif;
  font-size: 2.1rem !important;
  font-weight: 400;
  letter-spacing: 0.385px;
  text-decoration: none;
  text-transform: uppercase;

  /* --- Transitions --- */
  transition: background-color 0.2s, color 0.2s;
}

.card-text a:hover {
  background-color: #192147;
  color: #fff;
}

.community-button,
.card-button {
  box-sizing: border-box;
  width: fit-content;
}

/* --- Breakpoints for Card Text Content --- */
@media screen and (min-width: 768px) {
  .card-text h2,
  .card-text a {
    font-size: 2.5rem !important;
  }
  .card-text p {
    font-size: 1.65rem;
  }
}
@media screen and (min-width: 1200px) {
  .card-text {
    flex: 0 0 35%;
    align-items: flex-start;
  }
  .card-text h2, 
  .card-text a {
    font-size: 2.75rem !important;
  }
  .card-text a {
    padding: 2.5rem 1.5rem;
  }
  .card-text p {
    font-size: 1.85rem;
  }
}
@media screen and (min-width: 1400px) {
  .card-text {
    flex: 0 0 29%;
  }
}
@media screen and (min-width: 1920px) {
  .card-text {
    flex: 0 0 42%;
  }
  .card-text h2,
  .card-text a {
    font-size: 3.5rem !important;
  }
  .card-text a {
    margin-top: 2.5rem;
  }
  .card-text p {
    font-size: 2.35rem;
  }
}


/* ==========================================================================
   4. CARD IMAGE CONTENT (.card-image)
   ========================================================================== */

.card-image {
  width: 100%;
}

.card-image img {
  max-width: 100%;
  height: auto;
  display: block;
  margin: 0;
  padding: 0;
}

/* --- Breakpoints for Card Image Content --- */
@media screen and (min-width: 768px) {
  .card-image img {
    min-width: 650px;
  }
}
@media screen and (min-width: 1200px) {
  .card-image {
    flex: 1;
    width: 50%;
  }
  .card-image img {
    height: 500px;
    min-width: 500px;
    margin: 0 auto;
  }
  .image-left .card-image {
    order: -1;
  }
  #framework-img {
    margin: -1rem auto 0 auto;
  }
}


/* ==========================================================================
   5. PLEDGE COUNTER COMPONENT (#pledge-counter)
   ========================================================================== */

#pledge-counter {
  display: flex;
  width: 100%;
  height: auto;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  border-radius: 10px;
  border: 1px solid #202335;
  background: linear-gradient(
    180deg,
    rgba(32, 35, 53, 0.06) 0%,
    rgba(32, 35, 53, 0.02) 100%
  );
  margin: 0 auto;
}

#pledge-counter h3 {
  color: #202335;
  text-align: center;
  font-family: "Montserrat", sans-serif;
  font-size: 30px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
  letter-spacing: 1.5px;
  margin-top: 0.5rem;
  margin-bottom: 0;
}

#pledge-counter p {
  color: #202335;
  text-align: center;
  font-family: "Montserrat", sans-serif;
  font-size: 14px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
  letter-spacing: 0.7px;
  padding: 0 0.5rem;
}

/* --- Breakpoints for Pledge Counter --- */
@media screen and (min-width: 768px) {
  #pledge-counter h3 {
    font-size: 2.925rem;
  }
  #pledge-counter p {
    font-size: 1.4rem;
  }
}
@media screen and (min-width: 1200px) {
  #pledge-counter {
    width: 100%;
  }
  #pledge-counter h3 {
    font-size: 4rem;
  }
  #pledge-counter p {
    font-size: 2rem;
  }
}
@media screen and (min-width: 1920px) {
  #pledge-counter h3 {
    margin-top: 1rem;
  }
  #pledge-counter p {
    margin-top: 0rem;
  }
}