  :root {
    --main-icon-color: #fff;
    --main-icon-color2: #000;
  }

  html, body {
    position: relative;
    height: 100vh;
    width: 100vw;
  }

  body {
    background: #fff;
    font-family: 'Noto Sans JP', Helvetica Neue, Helvetica, Arial, sans-serif;
    font-size: 0.6em;
    color: #000;
    margin: 0;
    padding: 0;
    overflow-x: hidden;
  }

  h1 {
    font-size: 40px;
    margin-bottom: 24px;
  }

  p {
    font-size: 18px;
  }

  .swiper-container {
    width: 100%;
    height: 100vh;
  }

  .swiper-slide {
    font-size: 18px;
    background: #fff;
    max-width: 1280px !important;
    width: 90vwx;
    /* Center slide text vertically */
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    -webkit-justify-content: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    -webkit-align-items: center;
    align-items: center;
  }

  /* .swiper-slide:nth-child(2n) {
      width: 60%;
    }

    .swiper-slide:nth-child(3n) {
      width: 40%;
    } */

  .menu-inner {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100vh;
  }

  .menu-inner ul {
    color: white;
    font-size: 38px;
    list-style: none;
    text-align: center;
  }

  .menu-inner ul li {
    margin-bottom: 30px;
  }

  .menu-inner ul a {
    color: white;
    text-decoration: none;
    padding: 15px;
    border-radius: 12px;
  }

  .menu-inner ul a:hover {
    color: white;
    text-decoration: none;
    background: #4cb69c;
    color: #353535;
  }

  .menu-button {
    position: absolute;
    top: 0px;
    right: 15px;
    cursor: pointer;
    -webkit-transition: .3s;
    transition: .3s;
    /*margin: 14px;
			border-radius: 5px;*/
    z-index: 999;
  }

  .hamburger {
    padding: 0px 15px!important;
  }

  .hamburger {
    color: black;
  }

  .hamburger-inner, .hamburger-inner::before, .hamburger-inner::after {
    width: 25px;
  }

  .hamburger-inner::before {
    right: 5px;
  }

  .hamburger-inner::after {
    left: 5px;
  }

  .hamburger.is-active .hamburger-inner::after {
    left: 0px;
  }

  .hamburger.is-active .hamburger-inner, .hamburger.is-active .hamburger-inner::before, .hamburger.is-active .hamburger-inner::after {
    background-color: var(--main-icon-color);
  }

  .swiper-button-next, .swiper-button-prev {
    top: calc(100% - 50px)
  }

  .icoinito {
    margin-right: 5px;
    width: 35px;
  }

  #footer {
    background: #353535;
    color: white;
    padding-top: 80px;
    margin-top: 40px;
  }

  #subfooter {
    background: #4a4a4a;
    margin-top: 30px;
    min-height: 100px;
    padding: 50px
  }

  #subfooter p {
    font-size: 12px;
    color: gray;
  }

  #subfooter ul {
    list-style: none;
  }

  #subfooter ul li a, #subfooter h4 {
    color: #353535;
    font-size: 20px;
    font-size: 20px;
    text-transform: uppercase;
  }

  #subfooter ul li a:hover {
    color: #4cb69c;
    text-decoration: none;
  }

  .imagenes {
    align-self: center;
    position: absolute;
    right: -100px;
    z-index: 1000;
  }

  .shadowt {
    -webkit-filter: drop-shadow(0px 0px 18px rgba(50, 50, 50, 0.80));
    filter: drop-shadow(0px 0px 18px rgba(50, 50, 50, 0.80));
  }

  .shadow2 {
    -webkit-filter: drop-shadow(0px 0px 2px rgba(50, 50, 50, 0.80));
    filter: drop-shadow(0px 0px 2px rgba(50, 50, 50, 0.80));
    -ms-filter: "progid:DXImageTransform.Microsoft.Dropshadow(OffX=0, OffY=1, Color='#666')";
    filter: "progid:DXImageTransform.Microsoft.Dropshadow(OffX=0, OffY=1, Color='#666')";
  }

  .cuerpo {
    background: #fff;
    margin-top: 50px
  }

  #header {
    height: 70px;
    background: #eee;
    width: 100vw;
  }

  .wrapper {
    display: grid;
    grid-template-columns: 14% 40% 44%;
    grid-gap: 1%;
  }

  .wrapper2 {
    display: grid;
    grid-template-columns: 6% 40% 14%;
    grid-gap: 1%;
  }

  .box {
    border-radius: 5px;
    padding: 20px;
    font-size: 150%;
  }

  .light-slide {
    background: #f7f7f7;
    color: #2f2f2f
  }

  .swiper-button-next, .swiper-container-rtl .swiper-button-prev {
    background-image: none !Important;
    right: 30px !important;
    left: auto;
    font-size: 35px;
  }

  .swiper-button-prev, .swiper-container-rtl .swiper-button-next {
    background-image: none !Important;
    left: 30px !important;
    font-size: 35px;
  }

  .ion-md-arrow-forward {
    color: black;
    text-shadow: rgb(255, 255, 255) 0 0 3px;
  }

  .ion-md-arrow-back {
    color: white;
    text-shadow: rgb(20, 20, 20) 0 0 3px;
  }

  .loader {
    width: 250px;
    height: 250px;
    border: 0px !important;
    border-radius: 0 !important;
    position: absolute;
    transform: 0 !important;
    -webkit-animation: 0 !important;
    -o-animation: 0 !important;
    animation: 0 !important;
    background: url(./assets/img/loading.gif);
  }

  .button {
    background: #4cb69c;
    color: white;
    border: none;
    padding: 10px 30px;
    border-radius: 4px;
    font-size: 0.5em;
    font-weight: 400;
    text-transform: uppercase;
    min-width: 150px;
    text-decoration: none;
  }

  .button span {
    font-size: 1.5em;
    margin-left: 10px;
  }

  input, textarea {
    color: white;
    background: #4a4a4a;
  }

  .min600, .min700 {
    min-height: 600px
  }

  .min700 {
    min-height: 700px
  }

  .bg-sw {
    background-image: url('../img/Path 41.png');
    background-position-x: -78vh;
    background-repeat: no-repeat;
    background-size: contain;
  }

  .bg-sw1 {
    background-image: url('../img/Path 41.png');
    background-position-x: 90vh;
    background-repeat: no-repeat;
  }

  @media only screen and (min-width: 768px) {
    .mb-8 {
      margin-bottom: 10rem !important;
    }
  }

  @media only screen and (max-width: 1200px) {
    .bg-sw {
      background-position-x: 0vh;
    }
    .bg-sw1 {
      background-size: contain;
      background-position-x: 80vh;
    }
    .min600, .min700 {
      min-height: 5px!important;
    }
    .menu-inner ul {
      font-size: 20px;
    }
    .menu-inner ul li {
      margin-bottom: 15px;
    }
    .menu-inner {
      display: block;
      margin-top: 70px;
    }
  }

  @media only screen and (max-width: 991px) {
    .bg-sw {
      background-position-x: -1550vh;
    }
    .bg-sw1 {
      background-position-x: -1550vh;
    }
  }

  @media only screen and (max-width: 768px) {
    .bg-sw {
      background-position-x: -1000vh;
    }
    .swiper-container {
      width: 100%;
      height: auto !important;
      min-height: 560px;
    }
    .swiper-wrapper {
      height: 100vh;
    }
    .modal-content {
      max-width: 80vw !important;
      min-width: 300px !important;
      margin: auto !important;
      margin-top: 25px !important;
    }
    .myForm, .footerform {
      display: block !important;
    }
    .myForm>label {
      width: 200px;
      display: block;
    }
    .myForm>input, .myForm>textarea, .footerform>button, .footerform>input, .footerform>textarea, .footerform>button {
      padding: 0.5em;
      font-size: 2em;
      margin-bottom: 10px;
      display: block !important;
      width: 250px;
    }
    h1 {
      font-size: 36px;
    }
    p {
      font-size: 18px;
    }
    .imagenes {
      z-index: 0;
      opacity: 0.3;
    }
    .wrapper {
      display: block;
      z-index: 100;
    }
    .wrapper2 {
      display: block;
      z-index: 100;
    }
  }

  .modal {
    display: none;
    /* Hidden by default */
    position: fixed;
    /* Stay in place */
    z-index: 9;
    /* Sit on top */
    left: 0;
    top: 0;
    width: 100%;
    /* Full width */
    height: 100%;
    /* Full height */
    overflow: auto;
    /* Enable scroll if needed */
    background-color: rgb(0, 0, 0);
    /* Fallback color */
    background-color: rgba(0, 0, 0, 0.8);
    /* Black w/ opacity */
  }

  /* Modal Content/Box */

  .modal-content {
    background: #eee;
    border-radius: 4px;
    margin: 15% auto;
    /* 15% from the top and centered */
    padding: 20px;
    border: 1px solid #888;
    width: 80%;
    max-width: 800px;
    /* Could be more or less, depending on screen size */
  }

  /* The Close Button */

  .close {
    color: #aaa;
    float: right;
    font-size: 28px;
    font-weight: bold;
  }

  .close:hover, .close:focus {
    color: black;
    text-decoration: none;
    cursor: pointer;
  }

  .myForm, .footerform {
    display: grid;
    grid-template-columns: [labels] auto [controls] 1fr;
    grid-auto-flow: row;
    grid-gap: .8em;
    padding: 1.2em;
  }

  .myForm>label, .footerform>label {
    grid-column: labels;
    grid-row: auto;
  }

  .myForm>input, .myForm>textarea, .footerform>button, .footerform>input, .footerform>textarea, .footerform>button {
    grid-column: controls;
    grid-row: auto;
    border: none;
    padding: 0.5em;
    font-size: 2em;
  }

  input, label {
    font-size: 2em;
  }

  textarea {
    min-height: 80px;
  }

  #logo {
    position: absolute;
    left: 0;
    top: 0;
    z-index: 555;
    padding: 15px;
  }

  @media only screen and (max-width: 767px) {
    .bg-sw {
      background-position-x: -1000vh;
    }
    .bg-sw1 {
      background-size: contain;
      background-position-x: -1550vh;
    }
  }