.gsp-wrapper {
  background: #fff;
  padding: 60px 40px 80px;
  color: #000;
  overflow: hidden;
}

.gsp-content {
  max-width: 1180px;
  margin: 0 auto;
  text-align: center;
}

.gsp-top-mark {
  width: 14px;
  height: 62px;
  background: #CE0E09;
  transform: skew(-20deg);
  margin: 0 auto 28px;
}

.gsp-intro {
	max-width: 757px;
	margin: 0 auto 70px;
	color: #000;
	font-weight: 400;
	font-size: 24px;
	line-height: 1.2;
	letter-spacing: 0%;
	text-align: center;
}

.gsp-title {
	margin: 0 0 22px;
	font-weight: 700;
	font-size: 67px;
	line-height: 1;
	letter-spacing: 0%;
	text-align: center;
	text-transform: capitalize;
}
.gsp-description {
	max-width: 995px;
	margin: 0 auto 55px;
	color: #000;
	font-weight: 300;
	font-size: 24px;
	line-height: 1.2;
	letter-spacing: 0%;
	text-align: center;
}

.gsp-rating-row {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 90px;
  flex-wrap: wrap;
  margin-bottom: 35px;
}

.gsp-rating-card {
  text-align: center;
}

.gsp-stars {
  display: flex;
  justify-content: center;
  gap: 4px;
  margin-bottom: -10px;
  align-items: baseline;
}

.gsp-stars .star {
 position: relative;
}
.gsp-stars .star2 {
 top: -18px;
}
.gsp-stars .star3 {
 top: -32px;
}
.gsp-stars .star4 {
 top: -8px;
}

.gsp-number {
	color: #CE0E09;
	font-weight: 900;
	font-size: 80px;
	line-height: 1;
	letter-spacing: 0%;
	text-align: center;
	text-transform: uppercase;
}

.gsp-rating-label {
	font-weight: 900;
	font-size: 24px;
	line-height: 1;
	letter-spacing: 0%;
	text-align: center;
}

.gsp-rating-label small {
  display: block;
  margin-top: 8px;
  font-size: 18px;
  font-weight: 800;
}

.gsp-badge {
	width: 174px;
	height: 174px;
	border-radius: 50%;
	position: relative;
	top: -10px;
}
.gsp-certification {
	font-weight: 700;
	font-size: 24px;
	line-height: 1.2;
	letter-spacing: 0%;
	text-transform: capitalize;
	margin-bottom: 55px;
}
.gsp-divider {
  position: relative;
  margin: 0 auto 70px;
  max-width: 620px;
  height: 1px;
  background: #E8E8E8;
}

.gsp-divider span {
  position: absolute;
  left: 50%;
  top: 0px;
  transform: translateX(-50%);
  width: 200px;
  height: 1px;
  background: #333;
}

.gsp-journey-heading {
	margin-bottom: 8px;
	font-weight: 700;
	font-size: 37px;
	line-height: 1.4;
	letter-spacing: 0%;
	text-transform: capitalize;
}

.gsp-company {
	color: #CE0E09;
	margin: 0 0 60px;
	font-weight: 800;
	font-size: 96px;
	line-height: 100%;
	letter-spacing: 0%;
	text-transform: uppercase;
}

.gsp-timeline {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 8px;
}

.gsp-timeline-card {
  position: relative;
  background: #F0F0F0;
  padding: 30px 25px;
  text-align: left;
  transform: skewX(-12deg);
  /* clip-path: polygon(12% 0, 100% 0, 88% 100%, 0 100%); */
}
.gsp-timeline-card::before {
    content: "";
  position: absolute;
  top: -8px;
  left: -8px;
  background: #D9D9D9;
  width: 100%;
  height: 1px;
}
.gsp-timeline-card::after {
	content: "";
	position: absolute;
	top: -22px;
	left: 8px;
	background: #D9D9D9;
	width: 1px;
	height: 75%;
}

.gsp-year {
    transform: skewX(12deg);
 }
.gsp-year span {
    display: block;
	color: #6C992F;
	font-weight: 800;
	font-size: 36px;
	line-height: 1;
	letter-spacing: 0%;
	text-transform: uppercase;
    margin-bottom: 6px;
}

.gsp-month {
    display: block;
	margin-bottom: 55px;
	font-weight: 400;
	font-size: 22px;
	line-height: 1;
	letter-spacing: 0%;
	text-transform: uppercase;
}

.gsp-timeline-card p {
	transform: skewX(12deg);
	font-weight: 400;
	font-size: 16px;
	line-height: 1.1;
	letter-spacing: 0%;
	text-transform: capitalize;
}

.gsp-timeline-card p small {
  display: block;
  font-size: 12px;
  line-height: 1.2;
  font-weight: 700;
  margin-top: 8px;
  max-width: 165px;
}

.gsp-card-accent {
	position: absolute;
	right: 8px;
	bottom: 22px;
	width: 10px;
	height: 42px;
	background: #CE0E09;
	transform: skew(-4deg);
}
.gsp-section {
  position: relative;
  padding: 120px 40px 80px;
  background: #fff;
  overflow: hidden;
}

.gsp-container {
  position: relative;
  max-width: 1180px;
  margin: 0 auto;
}

.gsp-matrix-text {
	position: absolute;
	top: -147px;
	left: 50%;
	transform: translateX(-50%);
	font-size: 246px;
	line-height: 0.9;
	font-weight: 900;
	color: #ededed;
	text-transform: capitalize;
	white-space: nowrap;
	pointer-events: none;
	user-select: none;
	z-index: 0;
}

.gsp-grid {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 16px;
}

.gsp-card1 {
  background: #f0f0f0;
  overflow: hidden;
}

.gsp-image1 {
  height: 190px;
  overflow: hidden;
}

.gsp-image1 img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.gsp-content1 {
  padding: 20px 16px 24px;
}

.gsp-title1 {
	margin: 0 0 14px;
	font-size: 18px;
	line-height: 1.15;
	font-weight: 700;
	color: #000;
	height: 60px;
}

.gsp-description1 {
  margin: 0;
  font-size: 14px;
  line-height: 1.4;
  font-weight: 400;
  color: #000;
}
.gsb-section {
  padding: 70px 40px;
  background: #fff;
}

.gsb-container {
  max-width: 1280px;
  margin: 0 auto;
}

.gsb-layout {
	display: grid;
	grid-template-columns: 1fr 1.12fr;
	align-items: center;
	gap: 0;
	margin-bottom: 136px;
}
.gsb-layout.odd {
	grid-template-columns: 1.12fr 1fr;
}
/* .gsb-layout.one .gsb-rating {
	margin-left: -42px;
} */
.gsb-layout:last-child {
	margin-bottom: 0;
}

/* LEFT SIDE */


.gsb-card-top {
	background: #F8F8F8;
	padding: 0px 20px 24px 60px;
	margin-bottom: 16px;
	position: relative;
	z-index: 0;
}
.gsb-card-top::after {
	content: "";
	background: #F8F8F8;
	position: absolute;
	width: 130%;
	left: 0;
	top: -50px;
	z-index: -1;
	bottom: 0;
}
.gsb-layout.odd .gsb-card-top::after {
	left: unset;
    right:0;
}
.gsb-rating {
	margin-bottom: 22px;
	display: inline-flex;
	flex-direction: column;
	align-items: center;
}
.gsb-heading-wrap {
	/* padding-left: 44px; */
}

.gsb-title {
	margin: 0 0 8px;
	font-size: 52px;
	line-height: 0.95;
	font-weight: 700;
	color: #000;
}

.gsb-subtitle {
  margin: 0;
  font-size: 28px;
  line-height: 1.2;
  font-weight: 500;
  color: #000;
}

/* INFO */

.gsb-info-list {
	max-width: 303px;
	margin-left: 94px;
}
.gsb-layout.odd .gsb-info-list {
	margin-left: 60px;
}
.gsb-info-item {
  padding: 10px 0;
  border-bottom: 1px solid #D9D9D9;
}
.gsb-info-item:nth-child(3) {
  border-bottom:none;
}

.gsb-label {
	display: block;
	font-size: 14px;
    margin-bottom: 4px;
	line-height: 1.2;
	font-weight: 400;
	color: #8B8B8B;
}

.gsb-value {
	margin: 0;
	font-size: 18px;
	line-height: 1.135;
	font-weight: 700;
	color: #000;
}

/* BUTTON */

.gsb-btn {
	width: fit-content;
	margin-top: 18px;
	padding: 12px 24px;
	background: #252525;
	color: #fff;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 18px;
	font-weight: 400;
	transition: 0.3s ease;
}

.gsb-btn:hover {
  background: #000;
}

.gsb-btn-icon {
  font-size: 24px;
  line-height: 1;
}

/* IMAGE */

.gsb-image-wrap {
  position: relative;
  height: 100%;
  z-index: 1;
}

.gsb-image-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* RESPONSIVE */
.gsc-section {
  padding: 80px 40px 70px;
  background: #fff;
}

.gsc-container {
  max-width: 1074px;
  margin: 0 auto;
}

/* HEADING */

.gsc-heading-wrap {
  text-align: center;
  margin-bottom: 65px;
}

.gsc-heading {
	margin: 0;
	color: #000;
	font-weight: 700;
	font-size: 34px;
	line-height: 1.2;
	letter-spacing: 0%;
	text-align: center;
}

/* GRID */

.gsc-grid {
  display: grid;
  grid-template-columns: 1fr 1fr .9fr;
  gap: 20px;
  margin-bottom: 110px;
}

.gsc-card {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  opacity: 1;
  transition: opacity 1.5s ease;
}

.gsc-line {
  width: 8px;
  min-width: 8px;
  height: 100%;
  border: solid 2px #6C992F;
  border-top: none;
  position: relative;
  overflow: hidden;
}

.gsc-line::before {
  content: "";
  position: absolute;
  inset: 0;
  background: #7ea549;

  /* START FULL */
  transform: scaleY(1);
  transform-origin: bottom;

  transition: transform 1.5s ease;
}

/* ACTIVE ANIMATION */
.gsc-card.active .gsc-line::before {
  /* GO TO 0 */
  transform: scaleY(0);
}

/* ACTIVE STEP */

.gsc-card.active {
  opacity: 1;
}

.gsc-content {
  padding-top: 2px;
}

.gsc-title {
	margin: 0 0 14px;
	font-size: 19px;
	line-height: 1.1;
	font-weight: 700;
	color: #000;
}

.gsc-description {
  margin: 0;
  font-size: 22px;
  line-height: 1.1;
  font-weight: 300;
  color: #000;
}

.gsc-card-muted .gsc-title,
.gsc-card-muted .gsc-description {
  /* color: #B8B8B8; */
}

/* BANNER */

.gsc-banner {
  background: #6C992F;
  padding: 50px 40px;
  text-align: center;
  margin-top: 95px;
}

.gsc-banner p {
  margin: 0;
  font-size: 28px;
  line-height: 1.1;
  font-weight: 600;
  color: #fff;
}
.gsr-section {
	padding: 0 12px 26px 29px;
}

.gsr-label {
	display: block;
	margin-bottom: 10px;
	font-size: 12px;
	line-height: 1;
	font-weight: 400;
	letter-spacing: 0.1em;
	color: #AFAFAF;
	text-transform: capitalize;
}

.gsr-radio-group {
	display: flex;
	align-items: center;
	gap: 30px;
	flex-wrap: wrap;
}
/* CARD */

.gsr-radio-card {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 18px;
  cursor: pointer;
  user-select: none;
}

/* HIDE INPUT */

.gsr-radio-card input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

/* RADIO */

.gsr-radio-ui {
  position: relative;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  border: 3px solid#212121;
  background: transparent;
  transition: 0.25s ease;
}

.gsr-radio-ui::before {
	content: "";
	position: absolute;
	inset: 50%;
	width: 11px;
	height: 11px;
	border-radius: 50%;
	background: #2C2C2C;
	transform: translate(-50%, -50%);
	transition: 0.25s ease;
}

/* TEXT */

.gsr-text {
	font-size: 18px;
	line-height: 1;
	font-weight: 600;
	color: #626262;
	transition: 0.25s ease;
}

/* ACTIVE */

.gsr-radio-card input:checked + .gsr-radio-ui {
  background: #ffffff;
  border-color: #ffffff;
}

.gsr-radio-card input:checked + .gsr-radio-ui::before {
  background: #000000;
}

.gsr-radio-card input:checked ~ .gsr-text {
  color: #ffffff;
}

/* HOVER */

.gsr-radio-card:hover .gsr-text {
  color: rgba(255, 255, 255, 0.7);
}
.contttxblk {
	margin-bottom: 180px;
}
.contttx {
	margin-bottom: 245px;
}

.contimgblk.green {
	transform: translateY(-17%);
}
/* RESPONSIVE */

@media (max-width: 768px) {
  .contimgblk.green {
	transform: translateY(-3%);
}
  .gsr-section {
    padding: 28px 20px;
  }
.contttxblk {
	margin-bottom: 60px;
}
.contttx {
	margin-bottom: 12vw;
}
  .gsr-radio-group {
    gap: 8px;
    align-items: flex-start;
  }

  .gsr-text {
    font-size: 14px;
  }
.gsr-radio-card {
	gap: 2px;
}
  .gsr-radio-ui {
    width: 14px;
    height: 14px;
  }
  .gsr-radio-ui::before {
	width: 6px;
	height: 6px;
}
.gsr-section {
    padding: 28px 10px;
  }
  .contactSecBlocl-left {
	align-items: flex-start;
	padding: 30px 0 0 13px;
}
}
/* RESPONSIVE */

@media (max-width: 1200px) {
  .gsc-grid {
    gap: 50px;
  }

  .gsc-heading {
    font-size: 48px;
  }

  .gsc-description {
    font-size: 22px;
  }
}

@media (max-width: 900px) {
  .gsc-grid {
    grid-template-columns: 1fr;
    gap: 40px;
  }

  .gsc-line {
    height: 140px;
  }

  .gsc-banner p {
    font-size: 26px;
  }
}

@media (max-width: 768px) {
  .gsc-section {
    padding: 60px 20px;
  }

  .gsc-heading {
    font-size: 36px;
  }

  .gsc-title {
    font-size: 24px;
  }

  .gsc-description {
    font-size: 18px;
  }

  .gsc-banner {
    padding: 35px 24px;
  }

  .gsc-banner p {
    font-size: 22px;
  }
}
@media (max-width: 1280px) {
  .gsb-layout, .gsb-layout.odd {
    grid-template-columns: 1fr;
    margin-bottom: 60px;
    gap: 40px;
  }
.gsb-layout.odd {
	display: flex;
	flex-direction: column-reverse;
}
  .gsb-image-wrap {
    min-height: 560px;
  }
.gsb-layout.one .gsb-rating {
	margin-left: 0;
}
  .gsb-content {
    padding: 0;
  }
}

@media (max-width: 768px) {
  .gsb-section {
    padding: 40px 20px;
  }

  .gsb-card-top {
    padding: 28px;
  }

  .gsb-title {
    font-size: 36px;
    line-height: 1;
  }

  .gsb-subtitle {
    font-size: 18px;
  }

  .gsb-number {
    font-size: 72px;
  }

  .gsb-stars span {
    font-size: 40px;
  }

  .gsb-info-list,
  .gsb-btn {
    margin-left: 0;
  }

  .gsb-image-wrap {
    min-height: 340px;
  }
}
@media (max-width: 1200px) {
  .gsp-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .gsp-matrix-text {
    font-size: 220px;
    top: -70px;
  }
}

@media (max-width: 768px) {
  .gsp-section {
    padding: 80px 20px 60px;
  }

  .gsp-grid {
    grid-template-columns: 1fr;
  }

  .gsp-matrix-text {
    font-size: 112px;
    top: -80px;
  }

  .gsp-image {
    height: 240px;
  }
}
@media (max-width: 1200px) {
  .gsp-timeline {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .gsp-wrapper {
    padding: 40px 20px 60px;
  }

  .gsp-title {
    font-size: 42px;
  }

  .gsp-description {
    font-size: 16px;
  }

  .gsp-company {
    font-size: 56px;
  }

  .gsp-journey-heading {
    font-size: 30px;
  }

  .gsp-timeline {
    grid-template-columns: 1fr;
    gap: 45px;
  }

  .gsp-timeline-card {
    min-height: auto;
    width: 90%;
    margin-inline: auto;
  }

  .gsp-year {
    font-size: 40px;
  }

  .gsp-month {
    font-size: 22px;
  }

  .gsp-timeline-card p {
    font-size: 18px;
  }

  .gsp-certification {
    font-size: 18px;
  }
}