.fs--montserrat {
  font-family: "Montserrat", serif;
  font-optical-sizing: auto;
  font-style: normal;
}

.form-template-2 {
  /* Optional: Custom arrow for select */
}

.form-template-2 .input-group {
  position: relative;
  margin-bottom: 0.1rem;
}

.form-template-2 .input-group input,
.form-template-2 .input-group textarea,
.form-template-2 .input-group select {
  width: 100%;
  padding: 0.5rem 0.5rem 0.5rem 0.5rem;
  font-size: 0.8rem;
  border: none;
  border-bottom: 2px solid #ccc;
  background: transparent;
  color: white;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

.form-template-2 .input-group textarea {
  resize: vertical;
  min-height: 100px;
}

.form-template-2 .input-group label {
  position: absolute;
  top: 1rem;
  left: 0.5rem;
  color: #aaa;
  font-size: 1rem;
  transition: all 0.2s ease;
  pointer-events: none;
}

.form-template-2 .input-group input:focus,
.form-template-2 .input-group textarea:focus,
.form-template-2 .input-group select:focus {
  border-color: #fff;
  outline: none;
}

.form-template-2 .fancybox__container {
  z-index: 2000 !important;
}

.form-template-2 .input-group input:not(:-moz-placeholder-shown) + label, .form-template-2 .input-group textarea:not(:-moz-placeholder-shown) + label {
  top: -0.5rem;
  left: 0.25rem;
  font-size: 0.75rem;
  color: #fff;
  background-color: #1F1F1F;
  padding: 0 0.2rem;
}

.form-template-2 .input-group input:focus + label,
.form-template-2 .input-group input:not(:placeholder-shown) + label,
.form-template-2 .input-group textarea:focus + label,
.form-template-2 .input-group textarea:not(:placeholder-shown) + label,
.form-template-2 .input-group select:focus + label,
.form-template-2 .input-group select:not([value=""]) + label {
  top: -0.5rem;
  left: 0.25rem;
  font-size: 0.75rem;
  color: #fff;
  background-color: #1F1F1F;
  padding: 0 0.2rem;
}

.form-template-2 .select-group select {
  background-image: url('data:image/svg+xml;charset=UTF-8,<svg fill="white" viewBox="0 0 140 140" xmlns="http://www.w3.org/2000/svg"><polygon points="0,40 70,110 140,40"/></svg>');
  background-repeat: no-repeat;
  background-position: right 0.75rem center;
  background-size: 12px;
  padding-right: 2rem;
}

.bottom-center {
  text-align: center;
}

.border-top {
  border-top: 2px solid black !important;
}

.btn {
  border-radius: 0px;
}

.btn-outline-white {
  border: 2px solid white;
}

.btn-outline-white:hover {
  background-color: white;
  border: 2px solid white;
  color: black;
}

.btn-outline-black {
  border: 2px solid black;
}

.btn-outline-black:hover {
  background-color: black;
  border: 2px solid black;
  color: white;
}

#errorfill {
  display: none;
}

.headerhandbike {
  height: 100vh;
  background-color: black;
  overflow: hidden;
}

.headerhandbike .breadcrumbs {
  margin-top: 40%;
  font-size: 0.7rem;
}

.headerhandbike h1.suptitle {
  font-size: 4rem;
}

.request-info-box {
  width: 100%;
  opacity: 0;
  pointer-events: none;
  height: 100%;
  display: block;
  position: fixed;
  z-index: 1500;
  background-color: #1F1F1F;
  top: 0;
  left: 0;
  min-height: 100vh;
  align-content: center;
  align-items: center;
  justify-content: center;
}

.request-info-box .active {
  opacity: 1;
  pointer-events: auto;
}

.request-info-box .content {
  max-width: 65vw;
  margin: 0 auto;
}

.request-info-box .close {
  position: fixed;
  top: 15px;
  right: 15px;
  width: 25px;
  height: 25px;
  cursor: pointer;
}

#js--submit-success {
  display: none;
}

.border-bottom {
  border-bottom: 2px solid black !important;
}

.fw--normal {
  font-weight: 400;
}

.fw--medium {
  font-weight: 500;
}

.font-footer {
  font-size: 0.6rem;
}

.fw--bold {
  font-weight: 700;
}

.fw--medium {
  font-weight: 600;
}

.bg--black {
  background-color: black;
}

.bg--grey {
  background-color: #151313;
}

.bg--white {
  background-color: white;
}

.support a {
  text-decoration: none;
  color: black;
}

.bloccoprodotto img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.bloccoprodotto.bg--black {
  background-color: black;
}

.bloccoprodotto.bg--black p {
  color: white;
}

.bloccoprodotto.bg--white {
  background-color: white;
}

.bloccoprodotto.bg--white p {
  color: black;
}

.text--lg {
  font-size: 1.6rem;
}

.text--xl {
  font-size: 3rem;
}

.text--xxl {
  font-size: 3.5rem;
}

.text--md {
  font-size: 1rem;
}

.text--sm {
  font-size: 0.9rem;
}

.outline--black {
  text-shadow: -1px -1px 0 black, 1px -1px 0 black, -1px  1px 0 black, 1px  1px 0 black;
  color: white;
}

.outline--white {
  text-shadow: -1px -1px 0 white, 1px -1px 0 white, -1px  1px 0 white, 1px  1px 0 white;
  color: black;
}

.text--xs {
  font-size: 0.7rem;
}

.fc--white {
  color: white;
}

.fc--black {
  color: black;
}

.menu-box {
  width: 100vw;
  height: 100vh;
  background: white;
  color: black;
  display: none;
  opacity: 0;
  position: fixed;
  top: 0;
  left: 0;
}

.menu-box .menu-container {
  padding-top: 8%;
}

.menu-box .menu-container .submenu {
  display: none;
}

.menu-box .menu-container .submenu .containermodel {
  display: none;
}

.menu-box .menu-container .breadcrumbs {
  font-size: 0.8rem;
}

.menu-box .menu-container .line {
  font-size: 3rem;
  line-height: 4rem;
  display: block;
  text-align: left;
  text-decoration: none;
  color: black;
}

.menu-box .menu-container .line.handbike {
  cursor: pointer;
}

.menu-box .menu-container .linemodel {
  font-size: 2rem;
  display: block;
  text-align: left;
  text-decoration: none;
  color: black;
  cursor: pointer;
}

.containerfotohomehalf {
  width: 100vw;
  height: 100vh;
  background-size: cover;
  background-repeat: no-repeat;
}

.containerfotohomehalf .breadcrumbs {
  margin-top: 60%;
  font-size: 0.7rem;
}

.containerfotohomehalf h1.suptitle {
  font-size: 2.4rem;
}

.containerfotohomehalf .scrolling {
  top: 65vh;
}

.containerfotohandbike {
  width: 100vw;
  height: 100vh;
  background-color: black;
  background-size: cover;
  background-repeat: no-repeat;
}

.containerfotohandbike .breadcrumbs {
  margin-top: 60%;
  font-size: 0.7rem;
}

.containerfotohandbike h1.suptitle {
  font-size: 2.4rem;
}

.containerfotohandbike .scrolling {
  top: 65vh;
}

.containerfotohome {
  width: 100vw;
  height: 100vh;
  background-size: cover;
  background-repeat: no-repeat;
}

.containerfotohome .breadcrumbs {
  margin-top: 20%;
  font-family: 1rem;
}

.containerfotohome h1.suptitle {
  font-size: 4rem;
}

header {
  position: absolute;
  top: 0px;
  width: 100vw;
  z-index: 1150;
}

#sliderhome {
  height: 100vh;
}

.footerlink {
  font-size: 0.8rem;
  text-decoration: none;
}

.shorttitles {
  padding-top: 17vh;
}

.menu__side__hamburger {
  width: 70px;
  height: 50px;
  cursor: pointer;
  position: absolute;
  right: 0;
}

.linguamobile {
  width: 62px;
  height: 37px;
  cursor: pointer;
  position: absolute;
  right: 35px;
  margin-top: 6px;
  z-index: 1200;
}

.linguamobile .langblock {
  background-color: transparent;
  float: left;
  position: relative;
  text-decoration: none;
}

.menu__side__hamburger svg line {
  stroke: black;
}

.menu__side__hamburger.white svg line {
  stroke: white;
}

#js--hamburger {
  position: absolute;
  right: 0;
  top: 3px;
}

/* Mobile menu overlay */
.mobile-menu {
  position: fixed;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
  background: black;
  display: none;
  padding-top: 9vh;
  opacity: 0;
  transition: opacity 0.3s ease;
  z-index: 110;
}

.mobile-menu.show {
  display: block;
  opacity: 1;
}

.mobile-menu a {
  color: #fff;
  text-decoration: none;
  font-size: 24px;
  margin: 20px 0;
}

.mobile-menu a.small {
  color: #fff;
  text-decoration: none;
  font-size: 16px;
  margin: 10px 0;
}

.mobile-submenu {
  display: none;
}

.mobile-submenu.show {
  display: block;
}

.mobile-submenu a {
  color: #fff;
  text-decoration: none;
  font-size: 24px;
  cursor: pointer;
  margin: 20px 0;
}

.back {
  color: #fff;
  font-size: 12px;
  margin-bottom: 20px;
  cursor: pointer;
  text-decoration: none;
  display: block;
}

@media (min-width: 481px) {
  /* portrait e-readers (Nook/Kindle), smaller tablets @ 600 or @ 640 wide. */
}

@media (min-width: 1281px) {
  .shorttitles {
    padding-top: 20vh;
  }
  .text--xl {
    font-size: 5rem;
  }
  .scrolling {
    position: absolute;
    top: 80vh;
  }
  p {
    font-family: "Montserrat", serif;
    font-size: 1rem;
  }
  .menu-box {
    width: 100vw;
    height: 100vh;
    background: white;
    color: black;
    display: none;
    opacity: 0;
    position: fixed;
    top: 0;
    left: 0;
  }
  .menu-box .menu-container {
    padding-top: 8%;
  }
  .menu-box .menu-container .submenu {
    display: none;
  }
  .menu-box .menu-container .submenu .containermodel {
    display: none;
  }
  .menu-box .menu-container .breadcrumbs {
    font-size: 0.8rem;
  }
  .menu-box .menu-container .line {
    font-size: 3rem;
    line-height: 4rem;
    display: block;
    text-align: left;
    text-decoration: none;
    color: black;
  }
  .menu-box .menu-container .line.handbike {
    cursor: pointer;
  }
  .menu-box .menu-container .linemodel {
    font-size: 2rem;
    display: block;
    text-align: left;
    text-decoration: none;
    color: black;
    cursor: pointer;
  }
  .menudesktop .link {
    font-size: 1em;
    text-decoration: none;
    cursor: pointer;
  }
  .headerhandbike {
    height: 100vh;
    background-color: black;
    overflow: hidden;
  }
  .headerhandbike .breadcrumbs {
    margin-top: 10%;
    font-size: 0.7rem;
  }
  .headerhandbike h1.suptitle {
    font-size: 4rem;
  }
  h2 {
    font-size: 3.5rem;
    font-weight: 400;
  }
  .componentihandbike h4 {
    font-size: 0.8rem;
  }
  .componentihandbike p {
    font-family: "Montserrat", serif;
    font-size: 1rem;
  }
  h5 {
    font-size: 0.8rem;
  }
  .footerlink {
    font-size: 0.73rem;
    cursor: pointer;
    text-decoration: none;
  }
  .copyrights {
    font-size: 0.7rem;
  }
  .fasciatop {
    position: absolute;
    z-index: 1001;
  }
  .fasciatop .langblock {
    background-color: transparent;
    float: left;
    position: relative;
    text-decoration: none;
  }
  .containerfotohome {
    width: 100vw;
    height: 100vh;
    background-size: 100%;
    background-repeat: no-repeat;
  }
  .containerfotohome .breadcrumbs {
    margin-top: 20%;
    font-family: 1rem;
  }
  .containerfotohome h1.suptitle {
    font-size: 4rem;
  }
  .containerfotohomehalf {
    width: 100vw;
    height: 80vh;
    background-size: 100%;
    background-repeat: no-repeat;
  }
  .containerfotohomehalf .breadcrumbs {
    margin-top: 20%;
    font-family: 1rem;
  }
  .containerfotohomehalf h1.suptitle {
    font-size: 4rem;
  }
  .containerfotohomehalf .scrolling {
    top: 65vh;
  }
}

