/* SECTION */
.cta-video-section {
  width: 100%;
  margin-top: 100px;
}

/* ROUNDED FULL BLOCK */
.cta-shell {
  width: 100%;
  border-radius: 80px;
  overflow: hidden;
  position: relative;
  z-index: 2;
}

/* TOP */
.cta-top {
  background: #9FBE00;
  padding-top: 48px;
  position: relative;
}

/* BOTTOM */
.cta-bottom {
  background: #DFE8C7;
  padding: 140px 0 50px;
}

/* INNER WIDTH = FAQ */
.cta-inner {
  max-width: 1300px;
  margin: 0 auto;
  padding: 0 24px;
}

/* HEADER */
.cta-sub {
  font-size: 84px;
  font-weight: 600;
  color: #fff;
}

.cta-year {
  font-size: 84px;
  font-weight: 900;
  color: #1E1F1C;
}

/* VIDEO */
.cta-video {
 
  margin: 50px auto 0;
  margin-bottom: 100px;
  border-radius: 75px;
  overflow: hidden;
  position: relative;
  cursor: pointer;
}

.cta-video img {
  width: 100%;
  display: block;
}

.play-btn {
  position: absolute;
  inset: 0;
  margin: auto;
  width: 76px;
  height: 76px;
  background: url("images/player-icon.png") center/contain no-repeat;
}

/* BIG IMAGE TEXT */
.cta-bigtext {
  width: 100%;
  overflow: hidden;
}

.cta-line {
  width: 100%;
  display: block;
  opacity: 0;
  transition: transform 0.9s ease, opacity 0.4s ease;
}

/* start positions */
.cta-line-1 {
  transform: translateX(12%);
}

.cta-line-2 {
  transform: translateX(-12%);
}

/* active */
.cta-bigtext.is-active .cta-line {
  opacity: 1;
  transform: translateX(0);
}

/* POINT BOXES */
.cta-points {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.cta-point {
  height: 142px;
  background: #fff;
  border-radius: 16px;
  padding: 0 52px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.cta-point span {
  font-size: 33px;
  font-weight: 600;
  color: #1E1F1C;
}

.cta-point img {
  width: 54px;
}

/* BUTTON */
.cta-actions {
  display: flex;
  justify-content: flex-end;
  margin-top: 20px;
}

.cta-btn {
  background: #7FA800;
  color: #fff;
  padding: 20px 22px;
  border-radius: 19px;
  font-size: 23px;
  font-weight: 800;
  text-transform: uppercase;
  text-decoration: none;
}

/* MODAL */
.video-modal {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.85);
  display: none;
  place-items: center;
  z-index: 9999;
}

.video-modal.active {
  display: grid;
}

.video-box {
  width: min(900px, 92vw);
  aspect-ratio: 16/9;
  position: relative;
}

.video-box iframe {
  width: 100%;
  height: 100%;
  border: 0;
}

.video-close {
  position: absolute;
  top: -42px;
  right: 0;
  font-size: 34px;
  color: #fff;
  background: none;
  border: none;
  cursor: pointer;
}

/* RESPONSIVE */
/* SECTION */
.cta-video-section {
  width: 100%;
  margin-top: 100px;
}

/* ROUNDED FULL BLOCK */
.cta-shell {
  width: 100%;
  border-radius: 80px;
  overflow: hidden;
}

/* TOP */
.cta-top {
  background: #9FBE00;
  padding-top: 48px;
  position: relative;
}

/* BOTTOM */
.cta-bottom {
  background: #DFE8C7;
  padding: 140px 0 50px;
}

/* INNER WIDTH = FAQ */
.cta-inner {
  max-width: 1300px;
  margin: 0 auto;
  padding: 0 24px;
}

/* HEADER */
.cta-sub {
  font-size: 84px;
  font-weight: 600;
  color: #fff;
}

.cta-year {
  font-size: 84px;
  font-weight: 900;
  color: #1E1F1C;
}

/* VIDEO */
.cta-video {
 
  margin: 50px auto 0;
  margin-bottom: 100px;
  border-radius: 75px;
  overflow: hidden;
  position: relative;
  cursor: pointer;
}

.cta-video img {
  width: 100%;
  display: block;
}

.play-btn {
  position: absolute;
  inset: 0;
  margin: auto;
  width: 76px;
  height: 76px;
  background: url("images/player-icon.png") center/contain no-repeat;
}

/* BIG IMAGE TEXT */
.cta-bigtext {
  width: 100%;
  overflow: hidden;
}

.cta-line {
  width: 100%;
  display: block;
  opacity: 0;
  transition: transform 0.9s ease, opacity 0.4s ease;
}

/* start positions */
.cta-line-1 {
  transform: translateX(12%);
}

.cta-line-2 {
  transform: translateX(-12%);
}

/* active */
.cta-bigtext.is-active .cta-line {
  opacity: 1;
  transform: translateX(0);
}

/* POINT BOXES */
.cta-points {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.cta-point {
  height: 142px;
  background: #fff;
  border-radius: 16px;
  padding: 0 52px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.cta-point span {
  font-size: 33px;
  font-weight: 600;
  color: #1E1F1C;
}

.cta-point img {
  width: 54px;
}

/* BUTTON */
.cta-actions {
  display: flex;
  justify-content: flex-end;
  margin-top: 20px;
}

.cta-btn {
  background: #7FA800;
  color: #fff;
  padding: 20px 22px;
  border-radius: 19px;
  font-size: 23px;
  font-weight: 800;
  text-transform: uppercase;
  text-decoration: none;
}

/* MODAL */
.video-modal {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.85);
  display: none;
  place-items: center;
  z-index: 9999;
}

.video-modal.active {
  display: grid;
}

.video-box {
  width: min(900px, 92vw);
  aspect-ratio: 16/9;
  position: relative;
}

.video-box iframe {
  width: 100%;
  height: 100%;
  border: 0;
}

.video-close {
  position: absolute;
  top: -42px;
  right: 0;
  font-size: 34px;
  color: #fff;
  background: none;
  border: none;
  cursor: pointer;
}

@media (max-width: 768px) {
  .cta-shell {
    border-radius: 42px;
  }

  .cta-top {
    padding-top: 36px;
  }

  .cta-sub,
  .cta-year {
    font-size: 44px;
  }

  .cta-video {
    margin: 40px auto 60px;
    border-radius: 32px;
  }

  .play-btn {
    width: 56px;
    height: 56px;
  }

  .cta-bottom {
    padding: 70px 0 32px;
  }

  .cta-point {
    height: auto;
    min-height: 96px;
    padding: 18px 24px;
  }

  .cta-point span {
    font-size: 20px;
  }

  .cta-point img {
    width: 36px;
  }

  .cta-actions {
    justify-content: center;
  }

  .cta-btn {
    width: 100%;
    max-width: 320px;
    text-align: center;
    font-size: 18px;
  }
}
@media (max-width: 480px) {
  .cta-shell {
    border-radius: 28px;
  }

  .cta-sub,
  .cta-year {
    font-size: 32px;
  }

  .cta-video {
    margin-bottom: 48px;
    border-radius: 24px;
  }

  .cta-bottom {
    padding: 56px 0 28px;
  }

  .cta-point {
    padding: 16px 18px;
  }

  .cta-point span {
    font-size: 17px;
  }

  .cta-point img {
    width: 30px;
  }

  .cta-btn {
    font-size: 16px;
    padding: 14px 18px;
    border-radius: 14px;
  }
}

