.title1 {
  font-size: clamp(4.25rem, 6.20399579vw + 2.72614353rem, 7.9375rem);
  line-height: clamp(4.75rem, 7.9915878vw + 2.78706625rem, 9.5rem);
  color: var(--textColor);
  font-weight: bold;
  text-transform: lowercase;
}
.title2 {
  font-size: clamp(2.625rem, 4.83701367vw + 1.43690852rem, 5.5rem);
  line-height: clamp(3.0625rem, 5.04731861vw + 1.82275237rem, 6.0625rem);
  color: var(--textColor);
  font-weight: bold;
  text-transform: lowercase;
}
.title3 {
  font-size: clamp(2rem, 1.89274448vw + 1.53509464rem, 3.125rem);
  line-height: clamp(2.5rem, 1.78759201vw + 2.06092271rem, 3.5625rem);
  color: var(--textColor);
  font-weight: bold;
  text-transform: lowercase;
}
.title4 {
  font-size: clamp(1.5rem, 0.7360673vw + 1.31920347rem, 1.9375rem);
  line-height: clamp(2rem, 1.05152471vw + 1.74171924rem, 2.625rem);
  color: var(--textColor);
  font-weight: bold;
}
.title5 {
  font-size: clamp(0.875rem, 0.42060988vw + 0.7716877rem, 1.125rem);
  line-height: clamp(1.5rem, 0.42060988vw + 1.3966877rem, 1.75rem);
  color: var(--textColor);
  font-weight: bold;
}
.lead {
  font-size: clamp(1.375rem, 0.63091483vw + 1.22003155rem, 1.75rem);
  line-height: clamp(2rem, 1.26182965vw + 1.69006309rem, 2.75rem);
  color: var(--textColor);
}
.small {
  font-size: clamp(0.625rem, 0.21030494vw + 0.57334385rem, 0.75rem);
  line-height: clamp(1rem, 0.42060988vw + 0.8966877rem, 1.25rem);
  color: var(--textColor);
  font-weight: bold;
}
.button {
  display: inline-block;
  position: relative;
  background-color: var(--btnBackground);
  font-size: clamp(0.875rem, 0.21030494vw + 0.82334385rem, 1rem);
  line-height: clamp(1.5rem, 0.21030494vw + 1.44834385rem, 1.625rem);
  font-family: inherit;
  font-weight: bold;
  cursor: pointer;
  color: var(--btnColor);
  padding-top: 14px;
  padding-bottom: 10px;
  padding-right: 20px;
  padding-left: 45px;
  appearance: none;
  border-radius: 0;
  box-sizing: border-box;
  text-align: center;
  text-decoration: none;
  border: none;
  background-size: 0 100%;
  background-position: 0 50%;
  background-repeat: no-repeat;
  background-image: linear-gradient(var(--btnBackgroundHover), var(--btnBackgroundHover));
  transition: all 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}
.button:before {
  content: '';
  position: absolute;
  left: 20px;
  top: 50%;
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
  -webkit-mask-size: 100% 100%;
          mask-size: 100% 100%;
  -webkit-mask-position: 50% 50%;
          mask-position: 50% 50%;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-image: url(/images/arrow-curved-right.svg);
          mask-image: url(/images/arrow-curved-right.svg);
  background-color: var(--btnColor);
  transition: all 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}
.button:after {
  content: '';
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
  width: 15px;
  height: 15px;
  -webkit-mask-size: 100% 100%;
          mask-size: 100% 100%;
  -webkit-mask-position: 50% 50%;
          mask-position: 50% 50%;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-image: url(/images/arrow-right.svg);
          mask-image: url(/images/arrow-right.svg);
  background-color: var(--btnColor);
  opacity: 0;
  translate: -15px 0;
  transition: all 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}
@media (min-width: 768px) {
  .button:hover,
  .button:focus {
    padding-left: 20px;
    padding-right: 45px;
    background-size: 100% 100%;
    color: var(--btnColorHover);
  }
  .button:hover:before,
  .button:focus:before {
    opacity: 0;
    translate: 16px 0;
  }
  .button:hover:after,
  .button:focus:after {
    opacity: 1;
    translate: 0 0;
    background-color: var(--btnColorHover);
  }
}
@media (max-width: 767px) {
  .button {
    padding-top: 10px;
    padding-bottom: 6px;
    padding-left: 40px;
    padding-right: 16px;
  }
  .button:before {
    left: 16px;
    width: 14px;
    height: 14px;
  }
}
.textlink2 {
  float: left;
  font-family: inherit;
  font-size: clamp(0.75rem, 0.21030494vw + 0.69834385rem, 0.875rem);
  line-height: clamp(1.125rem, 0.21030494vw + 1.07334385rem, 1.25rem);
  background-size: 0 1px;
  background-position: left bottom;
  background-repeat: no-repeat;
  background-image: linear-gradient(to right, var(--linkColor), var(--linkColor));
  cursor: pointer;
  color: var(--linkColor);
  font-weight: bold;
  transition: all 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}
@media (min-width: 768px) {
  .textlink2:hover,
  .textlink2:focus {
    background-size: 100% 1px;
  }
}
.textlink3 {
  float: left;
  font-family: inherit;
  font-size: 14px;
  line-height: 1.71428571;
  background-size: 100% 1px;
  background-position: left bottom;
  background-repeat: no-repeat;
  background-image: linear-gradient(to right, var(--linkColor), var(--linkColor));
  cursor: pointer;
  color: var(--linkColor);
  font-weight: bold;
  transition: all 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}
@media (min-width: 768px) {
  .textlink3:hover,
  .textlink3:focus {
    animation-name: lineAnimation1;
    animation-duration: 0.4s;
    animation-iteration-count: 1;
    animation-timing-function: ease-in-out;
  }
}
@keyframes lineAnimation1 {
  0% {
    background-size: 100% 1px;
    background-position: right bottom;
  }
  60% {
    background-size: 0 1px;
    background-position: right bottom;
  }
  60.1% {
    background-size: 0 1px;
    background-position: left bottom;
  }
  100% {
    background-size: 100% 1px;
    background-position: left bottom;
  }
}
@keyframes lineAnimation2 {
  0% {
    background-size: 100% 2px;
    background-position: right bottom;
  }
  60% {
    background-size: 0 2px;
    background-position: right bottom;
  }
  60.1% {
    background-size: 0 2px;
    background-position: left bottom;
  }
  100% {
    background-size: 100% 2px;
    background-position: left bottom;
  }
}
.clearfix {
  *zoom: 1;
}
.clearfix:before,
.clearfix:after {
  display: table;
  content: '';
}
.clearfix:after {
  clear: both;
}
.logo--head {
  width: 168px;
  height: 114px;
}
.logo--foot {
  height: 161px;
}
.layout2 #head,
.layout3 #head,
.layout4 #head,
.layout6 #head {
  margin-top: 190px;
  margin-bottom: var(--spaceTotal);
}
.layout2 #head {
  margin-bottom: 160px;
}
.container--head {
  padding: var(--deskSpace) var(--deskSpace) 0;
}
.footarea {
  gap: 110px;
  margin-top: 138px;
  margin-bottom: 40px;
}
.footunit--one {
  flex-direction: row;
  align-items: flex-start;
  justify-content: space-between;
}
.footunit--two {
  padding-top: 22px;
}
.footpart {
  width: auto;
}
.footunit--one .footpart--one {
  gap: 30px;
}
.footunit--two .footpart--one {
  gap: 40px;
}
.area--one {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 0 var(--gridGap);
}
.area--one .unit {
  grid-column: span 12;
}
.area--one .unitOne--1-2 {
  grid-column: span 6;
}
.area--one .unitOne--1-3 {
  grid-column: span 6;
}
.area--one .unitOne--1-1 .part--1-2,
.area--one .unitOne--1-1indentLeft .part--1-2 {
  grid-column: span 3;
}
.area--one .unitOne--1-1 .part--1-3,
.area--one .unitOne--1-1indentLeft .part--1-3 {
  grid-column: span 2;
}
.area--one .uniTwo .unit__body {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 0 var(--gridGap);
}
.area--one .uniTwo .part--1-2 {
  grid-column: span 3;
}
.area--one .uniTwo .part--1-3 {
  grid-column: span 2;
}
.area--one .unitThree .unit__body {
  grid-template-columns: repeat(6, 1fr);
}
.area--one .unitThree .part {
  grid-column: 3 / span 4;
}
.area--one .unitThree .part:first-child {
  grid-column: span 6;
}
.area--one .unitFour {
  --spaceUnit: calc(26px + 8px);
  grid-column: span 6;
}
.area--one .unitFour .part.pict:first-child {
  margin-bottom: calc(40px - var(--spacePart));
}
@media (max-width: 1023px) {
  .area--one .unitFour + .unitFour + .unitFour {
    margin-top: 0;
  }
}
.area--one .unitFolding {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 0 var(--gridGap);
}
.area--one .unitFolding .unit__content {
  grid-column: span 12;
}
.area--one .unitFolding div.more {
  padding-right: 143px;
  padding-left: 40px;
}
.area--one .unitFolding .fold-toggle {
  min-height: 48px;
  padding-right: 88px;
  padding-left: 40px;
}
.area--one .unitFolding .fold-toggle:after {
  width: 48px;
  height: 48px;
}
.area--one .unitTeam {
  grid-column: span 6;
}
.area--one .unitTeam div.more {
  padding: calc(32px - var(--spacePart)) 20px 48px;
}
.area--one .unitTeam div.ctrl {
  --fluidSize: clamp(25.0625rem, 67.84313725vw + -7.50220588rem, 35.875rem);
  top: calc(var(--js-elementHeight) + var(--spacePart) - 48px);
}
.area--one .unitTeam div.ctrl .link {
  width: 48px;
  height: 48px;
}
@media (max-width: 1023px) {
  .area--one.area--masonry .unitTeam:nth-child(2n+2) {
    margin-top: calc(var(--spaceUnit) + var(--masonryOffset));
    margin-bottom: calc((var(--spaceUnit) + var(--masonryOffset)) * -1);
  }
}
.area--one .unitGallery .unit__body {
  display: flex;
  flex-wrap: wrap;
}
.area--one .unitGallery .part--1-1 {
  aspect-ratio: 0.69628286;
}
@supports not (aspect-ratio: 768 /  1103) {
  .area--one .unitGallery .part--1-1:before {
    float: left;
    padding-top: 143.61979167%;
    content: '';
  }
  .area--one .unitGallery .part--1-1:after {
    display: block;
    content: '';
    clear: both;
  }
}
.area--one .unitGallery .part--1-2 {
  width: 50%;
}
/*# sourceMappingURL=./screen-medium.css.map */