
/* .home__section-1 */

.home__section-1 {
  padding:0;
  margin:0;
}

.home__gallery {
  position: relative;
  width: 100%;
  height: 100%;
  padding: 0 40px;
  box-sizing: border-box;
  touch-action: pan-y;
  user-select: none;
  -webkit-user-select: none;
  aspect-ratio: 1366 / 428;
}

.home__gallery-track {
  display: flex;
  width: 100%;
  height: 100%;
  will-change: transform;
  transform: translate3d(0, 0, 0);
  transition: transform 420ms cubic-bezier(0.22, 0.61, 0.36, 1);
}

.home__gallery-slide {
  flex: 0 0 100%;
  width: 100%;
  height: 100%;
  display: grid;
  grid-template-columns: 1fr 366px;
  align-items: center;
  gap: clamp(16px, 2.5vw, 36px);
  padding: clamp(18px, 3vw, 44px) clamp(27px, 3vw, 45px);
}

.home__gallery-content h1,
.home__gallery-content h2 {
  font-size: 50px;
  font-weight: 700;
  line-height: 1.15;
  margin-bottom: clamp(8px, 1vw, 14px);
  text-align: left;
  max-width: 800px;
}

.home__gallery-content {
  height: 310px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  text-align: left;
}

.home__gallery-content p {
  font-size: 30px;
  font-weight: 500;
  line-height: 1.15;
  max-width: 800px;
  margin-bottom: clamp(12px, 1.6vw, 22px);
}

.home__gallery-content button {
  background: #009cbd;
  color: #ffffff;
  border-radius: 8px;
  font-weight: 500;
  font-size: 16px;
  padding: 10px 20px;
  box-shadow: none;
  align-self: flex-end;
}

.home__gallery-content button:hover {
  background: #0088a4;
}

.home__gallery-content button:active {
  background: #00778f;
}

.home__gallery-media {
  width: 366px;
  height: 369px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.home__gallery-media img {
  width: 366px;
  height: 369px;
  object-fit: contain;
  pointer-events: none;
  -webkit-user-drag: none;
}

.home__gallery-control {
  position: absolute;
  top: 0;
  width: 40px;
  height: 100%;
  border: 0;
  background: transparent;
  opacity: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity 220ms ease;
  z-index: 8;
  pointer-events: none;
  padding:0;
}

.home__gallery-control--left {
  left: 0;
}

.home__gallery-control--right {
  right: 0;
}

.home__gallery-control img {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.42);
  transition: background-color 180ms ease;
}

.home__section-1:hover .home__gallery-control,
.home__section-1:focus-within .home__gallery-control {
  opacity: 1;
  pointer-events: auto;
}

.home__gallery.is-dragging .home__gallery-control {
  opacity: 1;
}

.home__gallery-control:hover img,
.home__gallery-control:focus-visible img {
  background: rgba(0, 0, 0, 0.78);
}

/* home__section-2 */

.home__section-2 {
    display: flex;
    margin-top: clamp(32px, 5vw, 80px);
    flex-direction: row;
    flex-wrap: nowrap;
    gap: 45px;
    align-content: center;
    justify-content: center;
    align-items: center;
}

.home__section-2 > div {
  position: relative;
  min-height: 120px;
  display: grid;
  place-items: center;
  cursor:pointer;
  width:366px;
  height: 135px;
}

.home__section-2 > div > img {
  width: 100%;
  max-width: 366px;
  height: auto;
  object-fit: contain;
  transition: opacity 260ms ease;
}

.home__section-2 > div > img:nth-child(1) {
  opacity: 1;
}

.home__section-2 > div > img:nth-child(2) {
  position: absolute;
  inset: 0;
  margin: auto;
  opacity: 0;
}

.home__section-2 > div:hover > img:nth-child(1),
.home__section-2 > div:focus-within > img:nth-child(1),
.home__section-2 > div.is-tapped > img:nth-child(1) {
  opacity: 0;
}

.home__section-2 > div:hover > img:nth-child(2),
.home__section-2 > div:focus-within > img:nth-child(2),
.home__section-2 > div.is-tapped > img:nth-child(2) {
  opacity: 1;
}

/* home__section-3 */
.home__section-3 {
    margin-top: clamp(16px, 2.5vw, 40px);
    display: grid;
    grid-template-columns: minmax(0, 356px) minmax(0, 550px) minmax(0, 260px);
    align-items: center;
    width: calc(100% - 150px);
    gap: 40px;
}

.home__section-3 > div:nth-child(1) {
  font-size: clamp(30px, 3.2vw, 50px);
  font-weight: 700;
  line-height: 1.05;
  text-align: right;
}

.home__section-3 > div:nth-child(2) {
  font-size: clamp(16px, 1.6vw, 26px);
  font-weight: 300;
  line-height: 1.2;
  text-align: left;
}

.home__section-3 > div:nth-child(3) {
  display: flex;
  justify-content: flex-end;
}

.home__section-3 > div:nth-child(3) button {
  background-color: #5b5b5f;
}


/* home__section-4 */

.home__section-4{    
    margin-top: clamp(16px, 2.5vw, 40px);
  display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-content: center;
    justify-content: center;
    align-items: center;
    gap: 50px;
}

/* home__section-5 */
.home__section-5 {
  margin-top: clamp(16px, 2.5vw, 40px);
  display: grid;
  grid-template-columns: repeat(3, 367px);
  justify-content: center;
  gap: 50px;
}

.home__section-5 > div {
  width: 367px;
  height: 506px;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  padding: 26px 50px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  gap: 20px;
  overflow: hidden;
}

.home__section-5 > div:nth-child(1) {
  background-image: url("home/section-5-card-blue.png");
}

.home__section-5 > div:nth-child(2) {
  background-image: url("home/section-5-card-red.png");
}

.home__section-5 > div:nth-child(3) {
  background-image: url("home/section-5-card-green.png");
}

.home__section-5 > div > img {
  display: none;
}

.home__section-5 > div > h3 {
  position:relative;
  top:40px;
  display: block;
  font-size: 30px;
  line-height: 1.1;
  font-weight: 700;
  color: #ffffff;
}

.home__section-5 > div > p {
  position:relative;
  display: block;
  font-size: 18px;
  line-height: 1.35;
  color: #ffffff;
  top:40px;
  font-weight: 500;
}

/* home__section-6 */
.home__section-6 {
  margin-top: 100px;
  position: relative;
  min-height: clamp(300px, 34vw, 480px);
  padding: 0 0 54px;
  overflow: visible;
}

.home__section-6-top {
  width: 100%;
  background-color: #6ba539;
  background-image: url("../asstes/images/bg-mozaico-1.png");
  background-repeat: repeat;
  background-size: 140px auto;
}

.home__section-6-top-inner,
.home__section-6-bottom-inner {
  --inpesa-inner-width: 1366px;
  --inpesa-inner-gutter: clamp(24px, 5vw, 70px);
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(300px, 0.85fr);
  column-gap: clamp(24px, 4vw, 56px);
}

.home__section-6-top-inner {
  position: relative;
  align-items: end;
  overflow: visible;
}

.home__section-6-title {
  padding-top: clamp(18px, 3vw, 32px);
  padding-bottom: clamp(18px, 3vw, 32px);
  align-self: center;
}

.home__section-6 h1 {
  color: #ffffff;
  font-size: clamp(30px, 3vw, 55px);
  margin: 0;
}

.home__section-6-media {
  position: relative;
  min-height: 100%;
}

.home__section-6-media > img {
  position: absolute;
  right: 0;
  top: -65px;
  width: auto;
  height: auto;
  object-fit: contain;
  display: block;
  z-index: 2;
  pointer-events: none;
}

.home__section-6-bottom {
  width: 100%;
}

.home__section-6-bottom-inner {
  align-items: start;
  padding-top: 36px;
}

.home__section-6-copy {
  max-width: 760px;
}

.home__section-6 p {
  font-size: clamp(24px, 2.6vw, 38px);
  font-weight: 300;
  line-height: 1.1;
  color: #5b5b5f;
  margin: 0;
}

.home__section-6 .btn.primary {
  margin-top: 40px;
}

.home__section-6-spacer {
  min-height: 1px;
}

/* home__section-7, home__section-8, home__section-9 */
.home__catalog-section {
  margin-top: clamp(26px, 4.2vw, 72px);
  position: relative;
  padding: 95px 0;
  background-image: url("../asstes/images/bg-mozaico-1.png");
  background-repeat: repeat;
  background-size: 140px auto;
}

.home__section-8.home__catalog-section,
.home__section-9.home__catalog-section {
  margin-top: 0;
}

.home__catalog-wrap {
  --inpesa-inner-width: 1260px;
  --inpesa-inner-gutter: 50px;
  display: grid;
  grid-template-columns: minmax(0, 455px) minmax(0, 1fr);
  gap: clamp(26px, 3vw, 44px);
  align-items: start;
  padding-top: 50px;
  padding-bottom: 50px;
  background-color: #ffffff;
  border-radius: 15px;
}

.home__section-7 {
  margin-top: 10px;
  background-color: #009cbd;
  --catalog-accent: #005f83;
}

.home__section-8 {
  background-color: #d0006f;
  --catalog-accent: #73204b;
}

.home__section-9 {
  background-color: #6ba539;
  --catalog-accent: #517f31;
}

.home__section-9 .home__catalog-left .btn.primary {
  margin-top: 30px;
}

.home__section-9 .home__catalog-right--text {
  border: 0;
}

.home__catalog-left {
  display: flex;
  flex-direction: column;
  gap: 18px;
  padding-top: 12px;
}

.home__catalog-left > img {
  width: auto;
  height: 90px;
  object-fit: contain;
  align-self: flex-start;
}

.home__catalog-left > h3 {
  font-size: clamp(30px, 4vw, 54px);
  font-weight: 700;
  line-height: 1;
  color: var(--catalog-accent);
}

.home__catalog-left > p {
  font-size: 21px;
  font-weight: 300;
  line-height: 1.15;
  color: var(--catalog-accent);
}

.home__catalog-left > p strong {
  font-weight: 700;
}

.home__catalog-left .btn.primary {
  align-self: flex-end;
}

.btn-blue {
  background-color: #009cbd;
}

.btn-pink {
  background-color: #d0006f;
}

.btn-green {
  background-color: #6ba539;
}

.home__catalog-right {
  min-width: 0;
}

.home__catalog-right-heading {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 18px;
  color: var(--catalog-accent);
}

.home__catalog-right-heading > img {
  width: 30px;
  height: 30px;
  object-fit: contain;
}

.home__catalog-right-heading > strong {
  font-size: 21px;
  line-height: 1.1;
  font-weight: 700;
}

.home__catalog-gallery-viewport {
  width: min(538px, 100%);
  margin: 0 auto;
}

.home__catalog-gallery {
  gap: 18px;
  align-items: start;
  width: fit-content;
  padding: 6px 2px 16px;
}

.home__catalog-item {
  flex: 0 0 260px;
  width: 260px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.home__catalog-item.is-placeholder {
  min-height: 230px;
}

.home__catalog-item > img {
  width: 260px;
  height: 196px;
  object-fit: contain;
  border-radius: 10px;
  display: block;
  margin: 0 auto;
  background: #ffffff;
}

.home__section-8 .home__catalog-item > img {
  object-fit: contain;
  border: 0;
  background: #ffffff;
}

.home__section-7 .home__catalog-item > img,
.home__section-8 .home__catalog-item > img {
  border-radius: 5px;
}

.home__catalog-item > h4 {
  font-size: 18px;
  line-height: 1.15;
  font-weight: 700;
  color: var(--catalog-accent);
  text-align: center;
}

.home__catalog-carousel-controls {
  width: min(538px, 100%);
  margin: 6px auto 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 18px;
}

.home__catalog-right--text {
  border: 2px solid var(--catalog-accent);
  border-radius: 18px;
  padding: clamp(18px, 2vw, 30px);
}

.home__services-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 20px;
}

.home__services-list ul {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.home__services-list li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 21px;
  line-height: 1.2;
  font-weight: 700;
  color: var(--catalog-accent);
}

.home__services-list li > img {
  width: 18px;
  height: 18px;
  object-fit: contain;
  margin-top: 2px;
  flex: 0 0 auto;
}

/* home__section-10 */
.home__section-10 {
  margin-top: 0;
  padding-top: 50px;
  padding-bottom: 10px;
}

.home__section-10,
.home__section-11,
.home__section-12,
.home__section-13,
.home__section-14 {
  background-color: #ffffff;
}

.home__section-11,
.home__section-12,
.home__section-13,
.home__section-14 {
  margin-top: 0;
}

.home__section-10-inner,
.home__section-11-inner,
.home__section-12-inner,
.home__section-14-inner {
  --inpesa-inner-width: 1180px;
  --inpesa-inner-gutter: 0px;
}

.home__section-10-inner > h2,
.home__section-11-inner > h2,
.home__section-12-inner > h2 {
  margin: 0;
  font-size: 30px;
  text-transform: uppercase;
  color: #5b5b5f;
  text-align: left;
}

.home__section-10-inner > p {
  margin: 14px 0 0;
  text-align: left;
  font-size: 30px;
  line-height: 1.2;
  color: #707070;
}

.home__brands-carousel {
  margin: 26px auto 0;
  max-width: 1180px;
  width: 100%;
}

.home__brands-viewport {
  width: 100%;
}

.home__brands-track {
  width: max-content;
  transition: none;
}

.home__brands-slide {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 24px;
  padding: 10px 8px;
}

.home__brands-slide > img {
  width: auto;
  height: auto;
  max-width: 180px;
  max-height: 80px;
  object-fit: contain;
  margin: 0;
  flex: 0 0 auto;
}

.home__section-11,
.home__section-12 {
  padding-top: 8px;
  padding-bottom: 12px;
}

.home__section-13 {
  padding:0;
}

/* home__section-13 video */

.home__section-13 .home__catalog-wrap {
  align-items: stretch;
  grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
  gap: 0;
}

.home__section-13 .home__catalog-left {
  border-right: 2px solid #707070;
  padding-right: 64px;
  padding-bottom: 20px;
  align-items: center;
  justify-content: center;
}

.home__section-13 .home__catalog-right {
  padding-left: 24px;
}

.home__section-13 .home__catalog-right--testimonials {
  display: flex;
  align-items: center;
  justify-content: center;
}

.home__section-13 .home__catalog-carousel {
  width: min(560px, 100%);
}

.home__section-13 .home__catalog-gallery-viewport {
  width: min(560px, 100%);
}

.home__section-13 .home__catalog-gallery--text {
  gap: 34px;
  padding: 0 2px 16px;
}

.home__section-13 .home__catalog-item--text {
  width: 260px;
  min-width: 260px;
  height: 340px;
  min-height: 340px;
  padding: 24px 18px;
  border: 0;
  border-radius: 5px;
  background-color: #ffffff;
  background-image: url("../asstes/images/mozaico-clientes.png");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 16px;
}

.home__section-13 .home__catalog-item--text p {
  color: #5b5b5f;
  font-size: 22px;
  line-height: 1.35;
  font-weight: 300;
  margin: 0;
  text-align: center;
}

.home__section-13 .home__catalog-item--text strong {
  color: #5b5b5f;
  font-size: 20px;
  line-height: 1.2;
  font-weight: 700;
  margin: 0;
  text-align: center;
}

.home__section-13 .home__catalog-item.is-placeholder {
  min-height: 340px;
  height: 340px;
}

.home__section-13 .home__catalog-carousel-controls {
  width: min(560px, 100%);
}

.home__section-13-video-title {
  width: 100%;
  max-width: 100%;
  text-align: center;
  font-size: 28px;
  line-height: 1.2;
  font-weight: 700;
  color: #5b5b5f;
  margin: 8px 0 20px;
}

.home__section-13-video-frame {
  width: 100%;
  height: auto;
  aspect-ratio: 470 / 340;
  max-width: 100%;
  border-radius: 15px;
  overflow: hidden;
}

.home__section-13-video-frame > iframe {
  width: 100%;
  height: 100%;
  display: block;
  border: 0;
}

/* home__section-14 mosaic */
.home__section-14 {
  padding-top: 14px;
  padding-bottom: 100px;
}

.home__section-14-head {
  max-width: 1180px;
  margin: 0 auto;
  text-align: center;
}

.home__section-14-head > h3{
  text-align: center;
  color: #5b5b5f;
  font-size:30px;
  margin-bottom:20px;
}

.home__section-14-head > p {
text-align: center;
    color: #5b5b5f;
    font-size: 28px;
    width: 720px;
    margin: auto;
    line-height: 32px;
  margin-bottom:70px;
}

.home__section-14-grid {
    max-width: 1180px;
    margin: 24px auto 0;
    display: grid;
    grid-template-columns: repeat(3, 366px);
    justify-content: center;
    gap: 50px;
}

.home__section-14-card {
  width: 366px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
}

.home__section-14-media-box {
    width: 366px;
    height: 275px;
    display: flex;
    align-items: flex-start;
    justify-content: center;
}

.home__section-14-media {
  width: 366px;
  height: 275px;
  position: relative;
}

.home__section-14-image {
  width: 366px;
  height: 275px;
  object-fit: cover;
  border-radius: 15px;
  display: block;
}

.home__section-14-watermark {
  width: 38px;
  height: 38px;
  position: absolute;
  right: 20px;
  bottom: 20px;
  object-fit: contain;
}

.home__section-14-card h3 {
  font-size: 16px;
  line-height: 1.2;
  font-weight: 700;
  color: #5b5b5f;
  text-align: center;
  margin: 20px 0 0;
  padding: 0;
}

.home__section-14-card p {
  font-size: 16px;
  line-height: 1.2;
  font-weight: 300;
  color: #5b5b5f;
  text-align: center;
  margin: 0;
  padding: 0;
}

.home__section-14-card h3 + p {
  margin-top: 6px;
}

.home__section-14-card p + p {
  margin-top: 2px;
}

/* home__section-15 contact */
.home__section-15 {
  margin-top: 0;
  background-color: #eaeaea;
  background-image: url("../asstes/images/bg-mozaico-1.png");
  background-repeat: repeat;
  background-size: 140px auto;
  padding: 46px 0;
}

.home__section-15-wrap {
  --inpesa-inner-width: 1180px;
  --inpesa-inner-gutter: 50px;
  display: grid;
  grid-template-columns: minmax(0, 40%) minmax(0, 60%);
  gap: 40px;
  align-items: start;
  padding-top: 50px;
  padding-bottom: 50px;
  background: #ffffff;
  border-radius: 15px;
  box-sizing: border-box;
}

.home__section-15-left {
  display: flex;
  flex-direction: column;
  gap: 0;
  color: #5b5b5f;
  text-align: center;
}

.home__section-15-left h2 {
  margin: 0 0 45px;
  font-size: 25px;
  line-height: 1.1;
  font-weight: 700;
}

.home__section-15-left p {
  margin: 0 0 45px;
  font-size: 20px;
  line-height: 1.2;
  font-weight: 300;
}

.home__section-15-contact-list {
  display: grid;
  gap: 0;
}

.home__section-15-contact-list > div:nth-child(1) {
  margin-bottom: 10px;
}

.home__section-15-contact-list > div:nth-child(2) {
  margin-bottom: 45px;
}

.home__section-15-contact-list > div {
  font-size: 20px;
  line-height: 1.2;
  color: #5b5b5f;
}

.home__section-15-contact-list > div > strong {
  font-weight: 700;
  margin-right: 6px;
}

.home__section-15-right {
  min-width: 0;
}

.home__section-15-form {
  display: grid;
  gap: 14px;
}

.home__section-15-form input,
.home__section-15-form textarea {
  width: 100%;
  border: 1px solid #707070;
  border-radius: 15px;
  background: #ffffff;
  color: #464545;
  font-size: 16px;
  line-height: 1.2;
  padding: 14px 16px;
  box-sizing: border-box;
  font-family: "Helvetica Neue INPESA", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-weight: 300;
}

.home__section-15-form input::placeholder,
.home__section-15-form textarea::placeholder {
  color: #464545;
  opacity: 1;
}

.home__section-15-form textarea {
  min-height: 130px;
  resize: vertical;
}

.home__section-15-form .btn.primary {
  width: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  justify-self: stretch;
  background-color: #009cbd;
  color: #ffffff;
  border: 0;
  text-align: center;
  font-family: "Helvetica Neue INPESA", "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-weight: 500;
}

.home__section-15-form .btn.primary > img {
  width: 16px;
  height: 16px;
  object-fit: contain;
}
