@import url(variables.css);

@media screen and (max-width: 63.9375em) {
  .header,
  .header.header-ip {
    padding: 15px 0;
  }
  .header .logo img {
    width: auto;
    max-height: 48px;
  }
}



@media screen and (max-width: 47.9375em) {
  /* Margin */
  .m-sm-20 { margin: 20px; }
  .m-sm-40 { margin: 40px; }
  .m-sm-60 { margin: 60px; }
  .m-sm-80 { margin: 80px; }
  .m-sm-100 { margin: 100px; }
  .m-sm-120 { margin: 120px; }
  .m-sm-140 { margin: 140px; }

  .mt-sm-20 { margin-top: 20px; }
  .mt-sm-40 { margin-top: 40px; }
  .mt-sm-60 { margin-top: 60px; }
  .mt-sm-80 { margin-top: 80px; }
  .mt-sm-100 { margin-top: 100px; }
  .mt-sm-120 { margin-top: 120px; }
  .mt-sm-140 { margin-top: 140px; }

  .mb-sm-20 { margin-bottom: 20px; }
  .mb-sm-40 { margin-bottom: 40px; }
  .mb-sm-60 { margin-bottom: 60px; }
  .mb-sm-80 { margin-bottom: 80px; }
  .mb-sm-100 { margin-bottom: 100px; }
  .mb-sm-120 { margin-bottom: 120px; }
  .mb-sm-140 { margin-bottom: 140px; }

  .ms-sm-20 { margin-inline-start: 20px; }
  .ms-sm-40 { margin-inline-start: 40px; }
  .ms-sm-60 { margin-inline-start: 60px; }
  .ms-sm-80 { margin-inline-start: 80px; }
  .ms-sm-100 { margin-inline-start: 100px; }
  .ms-sm-120 { margin-inline-start: 120px; }
  .ms-sm-140 { margin-inline-start: 140px; }

  .me-sm-20 { margin-inline-end: 20px; }
  .me-sm-40 { margin-inline-end: 40px; }
  .me-sm-60 { margin-inline-end: 60px; }
  .me-sm-80 { margin-inline-end: 80px; }
  .me-sm-100 { margin-inline-end: 100px; }
  .me-sm-120 { margin-inline-end: 120px; }
  .me-sm-140 { margin-inline-end: 140px; }

  .mx-sm-20 { margin-left: 20px; margin-right: 20px; }
  .mx-sm-40 { margin-left: 40px; margin-right: 40px; }
  .mx-sm-60 { margin-left: 60px; margin-right: 60px; }
  .mx-sm-80 { margin-left: 80px; margin-right: 80px; }
  .mx-sm-100 { margin-left: 100px; margin-right: 100px; }
  .mx-sm-120 { margin-left: 120px; margin-right: 120px; }
  .mx-sm-140 { margin-left: 140px; margin-right: 140px; }

  .my-sm-20 { margin-top: 20px; margin-bottom: 20px; }
  .my-sm-40 { margin-top: 40px; margin-bottom: 40px; }
  .my-sm-60 { margin-top: 60px; margin-bottom: 60px; }
  .my-sm-80 { margin-top: 80px; margin-bottom: 80px; }
  .my-sm-100 { margin-top: 100px; margin-bottom: 100px; }
  .my-sm-120 { margin-top: 120px; margin-bottom: 120px; }
  .my-sm-140 { margin-top: 140px; margin-bottom: 140px; }

  /* Padding */
  .p-sm-20 { padding: 20px; }
  .p-sm-40 { padding: 40px; }
  .p-sm-60 { padding: 60px; }
  .p-sm-80 { padding: 80px; }
  .p-sm-100 { padding: 100px; }
  .p-sm-120 { padding: 120px; }
  .p-sm-140 { padding: 140px; }

  .pt-sm-20 { padding-top: 20px; }
  .pt-sm-40 { padding-top: 40px; }
  .pt-sm-60 { padding-top: 60px; }
  .pt-sm-80 { padding-top: 80px; }
  .pt-sm-100 { padding-top: 100px; }
  .pt-sm-120 { padding-top: 120px; }
  .pt-sm-140 { padding-top: 140px; }

  .pb-sm-20 { padding-bottom: 20px; }
  .pb-sm-40 { padding-bottom: 40px; }
  .pb-sm-60 { padding-bottom: 60px; }
  .pb-sm-80 { padding-bottom: 80px; }
  .pb-sm-100 { padding-bottom: 100px; }
  .pb-sm-120 { padding-bottom: 120px; }
  .pb-sm-140 { padding-bottom: 140px; }

  .ps-sm-20 { padding-inline-start: 20px; }
  .ps-sm-40 { padding-inline-start: 40px; }
  .ps-sm-60 { padding-inline-start: 60px; }
  .ps-sm-80 { padding-inline-start: 80px; }
  .ps-sm-100 { padding-inline-start: 100px; }
  .ps-sm-120 { padding-inline-start: 120px; }
  .ps-sm-140 { padding-inline-start: 140px; }

  .pe-sm-20 { padding-inline-end: 20px; }
  .pe-sm-40 { padding-inline-end: 40px; }
  .pe-sm-60 { padding-inline-end: 60px; }
  .pe-sm-80 { padding-inline-end: 80px; }
  .pe-sm-100 { padding-inline-end: 100px; }
  .pe-sm-120 { padding-inline-end: 120px; }
  .pe-sm-140 { padding-inline-end: 140px; }

  .px-sm-20 { padding-left: 20px; padding-right: 20px; }
  .px-sm-40 { padding-left: 40px; padding-right: 40px; }
  .px-sm-60 { padding-left: 60px; padding-right: 60px; }
  .px-sm-80 { padding-left: 80px; padding-right: 80px; }
  .px-sm-100 { padding-left: 100px; padding-right: 100px; }
  .px-sm-120 { padding-left: 120px; padding-right: 120px; }
  .px-sm-140 { padding-left: 140px; padding-right: 140px; }

  .py-sm-20 { padding-top: 20px; padding-bottom: 20px; }
  .py-sm-40 { padding-top: 40px; padding-bottom: 40px; }
  .py-sm-60 { padding-top: 60px; padding-bottom: 60px; }
  .py-sm-80 { padding-top: 80px; padding-bottom: 80px; }
  .py-sm-100 { padding-top: 100px; padding-bottom: 100px; }
  .py-sm-120 { padding-top: 120px; padding-bottom: 120px; }
  .py-sm-140 { padding-top: 140px; padding-bottom: 140px; }


  .button {
    padding: 0.8125rem 1.375rem;
  }


  h1 span {
    font-size: 0.8125rem;
  }


  .breadcrumbs li {
    font-size: 0.75rem;
  }


  .section {
    padding: 60px 0;
  }
  .section-small {
    padding: 40px 0;
  }
  .section-title {
    padding-bottom: 30px;
  }
  .section-buttons {
    padding-top: 25px;
  }
  .section-buttons.section-buttons-center {
    padding-top: 40px;
  }
  .section-img {
    margin: 5px 0 20px 0;
  }


  .loop-spacing {
    padding-top: 60px;
  }
  .loop-1-1-1 .cell:nth-child(n+2),
  .loop-1-1-2 .cell:nth-child(n+2),
  .loop-1-1-3 .cell:nth-child(n+2),
  .loop-1-2-2 .cell:nth-child(n+2),
  .loop-1-2-3 .cell:nth-child(n+2),
  .loop-1-2-4 .cell:nth-child(n+2),
  .loop-1-3-3 .cell:nth-child(n+2),
  .loop-1-3-4 .cell:nth-child(n+2) {
    padding-top: 30px;
  }
  .loop-2-2-2 > .cell:nth-child(n+3),
  .loop-2-2-3 .cell:nth-child(n+3),
  .loop-2-2-4 .cell:nth-child(n+3),
  .loop-2-3-3 .cell:nth-child(n+3),
  .loop-2-3-4 .cell:nth-child(n+3) {
    padding-top: 30px;
  }


  .banner-container.banner-container-ip .banner {
    padding: 9vh 0;
  }
  .banner-container.banner-container-ip .banner.banner-news .banner-title {
    padding-bottom: 20px;
  }


  .offcanvas-full-screen-menu .drilldown li {
    padding: 0.5rem 0;
  }
  .offcanvas-full-screen-menu .drilldown a {
    font-size: 1.5rem;
  }


  .menu-button-container span {
    margin-right: 15px;
    font-size: 1rem;
    font-weight: var(--global-weight-medium);
    color: var(--color-white);
    line-height: 1;
    text-transform: uppercase;
  }


  .footer {
    padding: 60px 0 20px 0;
    font-size: 0.9375rem;
  }
  .footer-col-title {
    margin-bottom: 5px;
    font-size: 1.125rem;
  }
  .footer ul li {
    line-height: 1.45;
  }
  .footer .grid-x .cell:nth-child(n+2) {
    padding-top: 20px;
  }


  .copyright {
    padding: 0 0 20px 0;
    font-size: 0.8125rem;
    line-height: 1.5;
  }


  .carousel-slider-controls-nav,
  .carousel-slider-controls.products-slider-controls {
    margin-top: 30px;
  }
  .carousel-slider-controls-nav .carousel-slider-nav {
    display: none;
  }
  .carousel-slider-controls-nav .carousel-slider-controls span,
  .carousel-slider-controls.products-slider-controls span,
  .carousel-slider-container.carousel-slider-controls-inside .carousel-slider-controls span {
    width: 40px;
    height: 40px;
    font-size: 1rem;
  }
  .carousel-slider-container.carousel-slider-controls-inside {
    max-width: calc(100% - 100px);
  }
  .carousel-slider-container.carousel-slider-controls-inside .carousel-slider-controls {
    width: calc(100% + 100px);
  }


  .contact-details {
    padding: 20px 15px;
    margin-bottom: 40px;
  }
  .contact-details span {
    font-size: 1.0625rem;
  }
  .contact-form h1 {
    margin-bottom: 30px;
  }


  .custom-tabs .tabs-panel-title {
    font-size: 1.3125rem;
  }
  .custom-tabs.custom-tabs-horizontal .tabs-panel-text {
    padding-top: 0;
  }
  .custom-tabs.custom-tabs-horizontal .tabs-panel-title {
    padding-bottom: 15px;
  }
  .custom-tabs.custom-tabs-horizontal .tabs-panel-img {
	max-width: 70%;
    margin-top: 30px;
  }


  .register-box,
  .value-box {
    padding: 90px 30px 40px 30px;
  }
  .register-box .svg-shape-img,
  .value-box .svg-shape-img {
    top: -65px;
    width: auto;
    height: 130px;
  }
	
	.svg-shape-img-mirror {
	 height: 130px;	
	}


  .counters {
    padding-top: 60px;
    grid-template-columns: repeat(1, 1fr);
  }
  .counter-box:nth-child(odd) {
    transform: none; 
  }
  .counter-box:nth-child(even) {
    transform: none; 
  }


  .projects {
    gap: 50px;
    padding-top: 60px;
  }
  .project-box {
    padding: 150px 30px 30px 30px;
    margin: 40px 0 0 0;
  }
  .project-box:nth-child(odd) {
    padding-left: 30px;
  }
  .project-box:nth-child(even) {
    padding-right: 30px;
  }
  .project-box .svg-shape-img {
    position: absolute;
    width: auto;
    height: 170px;
    top: -40px;
    transform: none;
  }
  .project-box:nth-child(odd) .svg-shape-img {
    left: 30px;
  }
  .project-box:nth-child(even) .svg-shape-img {
    left: 30px;
    right: auto;
  }
  .projects.projects-columns {
    grid-template-columns: repeat(1, 1fr);
    row-gap: 40px;
    padding-top: 0;
  }


  .cta {
    padding: 200px 0;
  }


  .timeline {
    padding-top: 60px;
  }
  .timeline-item {
    margin: 80px 0;
  }
  .timeline-item-img {
    padding: 0 0 20px 0;
  }
  .timeline-item-img img {
    border-radius: var(--global-radius);
  }
  .timeline-item-title {
    font-size: 1.25rem;
    line-height: 1.3;
  }
  .timeline-date::before,
  .timeline-date::after {
    top: 30px;
    transform: translate(-50%, none);
  }
  .timeline-left .timeline-date span,
  .timeline-right .timeline-date span {
    top: 30px;
    transform: translateY(none);
  }
  .timeline-right .timeline-date span {
    left: 50px;
    right: auto;
  }
  .timeline-right .timeline-date span::before {
    left: -10px;
    right: auto;
    border-width: 20px 20px 20px 0;
    border-color: transparent var(--color-secondary) transparent transparent;
  }
}



@media screen and (min-width: 48em) and (max-width: 63.9375em) {
  /* Margin */
  .m-md-20 { margin: 20px; }
  .m-md-40 { margin: 40px; }
  .m-md-60 { margin: 60px; }
  .m-md-80 { margin: 80px; }
  .m-md-100 { margin: 100px; }
  .m-md-120 { margin: 120px; }
  .m-md-140 { margin: 140px; }

  .mt-md-20 { margin-top: 20px; }
  .mt-md-40 { margin-top: 40px; }
  .mt-md-60 { margin-top: 60px; }
  .mt-md-80 { margin-top: 80px; }
  .mt-md-100 { margin-top: 100px; }
  .mt-md-120 { margin-top: 120px; }
  .mt-md-140 { margin-top: 140px; }

  .mb-md-20 { margin-bottom: 20px; }
  .mb-md-40 { margin-bottom: 40px; }
  .mb-md-60 { margin-bottom: 60px; }
  .mb-md-80 { margin-bottom: 80px; }
  .mb-md-100 { margin-bottom: 100px; }
  .mb-md-120 { margin-bottom: 120px; }
  .mb-md-140 { margin-bottom: 140px; }

  .ms-md-20 { margin-inline-start: 20px; }
  .ms-md-40 { margin-inline-start: 40px; }
  .ms-md-60 { margin-inline-start: 60px; }
  .ms-md-80 { margin-inline-start: 80px; }
  .ms-md-100 { margin-inline-start: 100px; }
  .ms-md-120 { margin-inline-start: 120px; }
  .ms-md-140 { margin-inline-start: 140px; }

  .me-md-20 { margin-inline-end: 20px; }
  .me-md-40 { margin-inline-end: 40px; }
  .me-md-60 { margin-inline-end: 60px; }
  .me-md-80 { margin-inline-end: 80px; }
  .me-md-100 { margin-inline-end: 100px; }
  .me-md-120 { margin-inline-end: 120px; }
  .me-md-140 { margin-inline-end: 140px; }

  .mx-md-20 { margin-left: 20px; margin-right: 20px; }
  .mx-md-40 { margin-left: 40px; margin-right: 40px; }
  .mx-md-60 { margin-left: 60px; margin-right: 60px; }
  .mx-md-80 { margin-left: 80px; margin-right: 80px; }
  .mx-md-100 { margin-left: 100px; margin-right: 100px; }
  .mx-md-120 { margin-left: 120px; margin-right: 120px; }
  .mx-md-140 { margin-left: 140px; margin-right: 140px; }

  .my-md-20 { margin-top: 20px; margin-bottom: 20px; }
  .my-md-40 { margin-top: 40px; margin-bottom: 40px; }
  .my-md-60 { margin-top: 60px; margin-bottom: 60px; }
  .my-md-80 { margin-top: 80px; margin-bottom: 80px; }
  .my-md-100 { margin-top: 100px; margin-bottom: 100px; }
  .my-md-120 { margin-top: 120px; margin-bottom: 120px; }
  .my-md-140 { margin-top: 140px; margin-bottom: 140px; }

  /* Padding */
  .p-md-20 { padding: 20px; }
  .p-md-40 { padding: 40px; }
  .p-md-60 { padding: 60px; }
  .p-md-80 { padding: 80px; }
  .p-md-100 { padding: 100px; }
  .p-md-120 { padding: 120px; }
  .p-md-140 { padding: 140px; }

  .pt-md-20 { padding-top: 20px; }
  .pt-md-40 { padding-top: 40px; }
  .pt-md-60 { padding-top: 60px; }
  .pt-md-80 { padding-top: 80px; }
  .pt-md-100 { padding-top: 100px; }
  .pt-md-120 { padding-top: 120px; }
  .pt-md-140 { padding-top: 140px; }

  .pb-md-20 { padding-bottom: 20px; }
  .pb-md-40 { padding-bottom: 40px; }
  .pb-md-60 { padding-bottom: 60px; }
  .pb-md-80 { padding-bottom: 80px; }
  .pb-md-100 { padding-bottom: 100px; }
  .pb-md-120 { padding-bottom: 120px; }
  .pb-md-140 { padding-bottom: 140px; }

  .ps-md-20 { padding-inline-start: 20px; }
  .ps-md-40 { padding-inline-start: 40px; }
  .ps-md-60 { padding-inline-start: 60px; }
  .ps-md-80 { padding-inline-start: 80px; }
  .ps-md-100 { padding-inline-start: 100px; }
  .ps-md-120 { padding-inline-start: 120px; }
  .ps-md-140 { padding-inline-start: 140px; }

  .pe-md-20 { padding-inline-end: 20px; }
  .pe-md-40 { padding-inline-end: 40px; }
  .pe-md-60 { padding-inline-end: 60px; }
  .pe-md-80 { padding-inline-end: 80px; }
  .pe-md-100 { padding-inline-end: 100px; }
  .pe-md-120 { padding-inline-end: 120px; }
  .pe-md-140 { padding-inline-end: 140px; }

  .px-md-20 { padding-left: 20px; padding-right: 20px; }
  .px-md-40 { padding-left: 40px; padding-right: 40px; }
  .px-md-60 { padding-left: 60px; padding-right: 60px; }
  .px-md-80 { padding-left: 80px; padding-right: 80px; }
  .px-md-100 { padding-left: 100px; padding-right: 100px; }
  .px-md-120 { padding-left: 120px; padding-right: 120px; }
  .px-md-140 { padding-left: 140px; padding-right: 140px; }

  .py-md-20 { padding-top: 20px; padding-bottom: 20px; }
  .py-md-40 { padding-top: 40px; padding-bottom: 40px; }
  .py-md-60 { padding-top: 60px; padding-bottom: 60px; }
  .py-md-80 { padding-top: 80px; padding-bottom: 80px; }
  .py-md-100 { padding-top: 100px; padding-bottom: 100px; }
  .py-md-120 { padding-top: 120px; padding-bottom: 120px; }
  .py-md-140 { padding-top: 140px; padding-bottom: 140px; }


  .section {
    padding: 90px 0;
  }
  .section-small {
    padding: 60px 0;
  }
  .section-img {
    margin: 10px 0 30px 0;
  }


  .loop-1-1-1 .cell:nth-child(n+2),
  .loop-1-1-2 .cell:nth-child(n+2),
  .loop-1-1-3 .cell:nth-child(n+2) {
    padding-top: 30px;
  }
  .loop-1-2-2 .cell:nth-child(n+3),
  .loop-1-2-3 .cell:nth-child(n+3),
  .loop-1-2-4 .cell:nth-child(n+3),
  .loop-2-2-2 .cell:nth-child(n+3),
  .loop-2-2-3 .cell:nth-child(n+3),
  .loop-2-2-4 .cell:nth-child(n+3) {
    padding-top: 30px;
  }
  .loop-1-3-3 .cell:nth-child(n+4),
  .loop-1-3-4 .cell:nth-child(n+4),
  .loop-2-3-3 .cell:nth-child(n+4),
  .loop-2-3-4 .cell:nth-child(n+4) {
    padding-top: 30px;
  }
  

  .banner-container.banner-container-ip .banner {
    padding: 9vh 0;
  }


  .footer {
    padding: 50px 0 20px 0;
  }
  .footer .grid-x:first-child .cell:nth-child(n+3) {
    padding-top: 60px;
  }


  .copyright {
    padding: 0 0 20px 0;
  }


  .custom-tabs .tabs-panel-title {
    font-size: 1.625rem;
  }
  .custom-tabs.custom-tabs-horizontal .tabs-panel-text {
    padding-top: 0;
  }
  .custom-tabs.custom-tabs-horizontal .tabs-panel-title {
    padding-bottom: 15px;
  }
  .custom-tabs.custom-tabs-horizontal .tabs-panel-img {
	max-width: 70%;
    margin-top: 30px;
  }


  .counters {
    padding-top: 60px;
  }


  .cta {
    padding: 300px 0 350px 0;
  }


  .projects {
    padding-top: 100px;
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 90px;
  }
  .projects.projects-columns {
    grid-template-columns: repeat(1, 1fr);
    row-gap: 100px;
    padding-top: 0;
  }
}



@media screen and (min-width: 64em) {
  .banner-btn a.button {
	font-size: 1.125rem;
	padding: 1.125rem 2rem;
  }
  .footer > .grid-container > .grid-x:first-child > .cell:not(:last-child) {
    max-width: 330px;
  }
  .footer > .grid-container > .grid-x:first-child > .cell:last-child {
    max-width: 40%;
  }
}