@charset "UTF-8";
/*-----------------------------------------
リセット情報
------------------------------------------*/
html, body, div, span, iframe,
h1, h2, h3, p, img, ol, ul,
li, form, label, figure, footer,
header, section, time {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-style: normal;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
  box-sizing: border-box;
}

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
  text-decoration: none;
}

html {
  width: 100%;
  height: 100%;
}

body {
  font-family: "ヒラギノ角ゴ Pro", sans-serif;
  line-height: 1;
  overflow: auto;
  -webkit-text-size-adjust: 100%;
}

@font-face {
  font-family: "Cera Basic Bold";
  src: url("../font/cshh0-h1fk0.woff") format("woff"), url("../font/cera-130.otf") format("opentype");
}

ul, ol {
  list-style-type: none;
}

input, textarea {
  border: none;
  -webkit-appearance: none;
  font-family: "ヒラギノ角ゴ Pro", sans-serif;
}

input, select {
  vertical-align: middle;
}

/*-----------------------------------------
色情報
------------------------------------------*/
/*-----------------------------------------
width情報
------------------------------------------*/
/*-----------------------------------------
共通パーツを@mixin
------------------------------------------*/
/*-----------------------------------------
LOGO ANIMATION
------------------------------------------*/
.path01 {
  stroke-dasharray: 1005.79px;
  stroke-dashoffset: 1005.79px;
  animation: strokePathAnime01 3s forwards;
}

.path02 {
  stroke-dasharray: 24.545px;
  stroke-dashoffset: 24.545px;
  animation: strokePathAnime02 3s forwards;
}

.path03 {
  stroke-dasharray: 137.15px;
  stroke-dashoffset: 137.15px;
  animation: strokePathAnime03 3s forwards;
}

.path04 {
  stroke-dasharray: 143.4px;
  stroke-dashoffset: 143.4px;
  animation: strokePathAnime04 3s forwards;
}

.path05 {
  stroke-dasharray: 142.2px;
  stroke-dashoffset: 142.2px;
  animation: strokePathAnime05 3s forwards;
}

.path06 {
  stroke-dasharray: 146.1px;
  stroke-dashoffset: 146.1px;
  animation: strokePathAnime06 3s forwards;
}

.path07 {
  stroke-dasharray: 68px;
  stroke-dashoffset: 68px;
  animation: strokePathAnime07 3s forwards;
}

.path08 {
  stroke-dasharray: 176.237px;
  stroke-dashoffset: 176.237px;
  animation: strokePathAnime08 3s forwards;
}

.path09 {
  stroke-dasharray: 119.474px;
  stroke-dashoffset: 119.474px;
  animation: strokePathAnime09 3s forwards;
}

polygon {
  animation: polygonAnime 3s forwards;
  stroke-dashoffset: 135px;
  stroke-dasharray: 135px;
}

@keyframes polygonAnime {
  0% {
    stroke-dashoffset: 135px;
  }
  100% {
    stroke-dashoffset: 0;
  }
}

@keyframes strokePathAnime01 {
  0% {
    stroke-dashoffset: 1005.79px;
  }
  100% {
    stroke-dashoffset: 0;
  }
}

@keyframes strokePathAnime02 {
  0% {
    stroke-dashoffset: 24.545px;
  }
  100% {
    stroke-dashoffset: 0;
  }
}

@keyframes strokePathAnime03 {
  0% {
    stroke-dashoffset: 137.15px;
  }
  100% {
    stroke-dashoffset: 0;
  }
}

@keyframes strokePathAnime04 {
  0% {
    stroke-dashoffset: 143.4px;
  }
  100% {
    stroke-dashoffset: 0;
  }
}

@keyframes strokePathAnime05 {
  0% {
    stroke-dashoffset: 142.2px;
  }
  100% {
    stroke-dashoffset: 0;
  }
}

@keyframes strokePathAnime06 {
  0% {
    stroke-dashoffset: 146.1px;
  }
  100% {
    stroke-dashoffset: 0;
  }
}

@keyframes strokePathAnime07 {
  0% {
    stroke-dashoffset: 68px;
  }
  100% {
    stroke-dashoffset: 0;
  }
}

@keyframes strokePathAnime08 {
  0% {
    stroke-dashoffset: 176.237px;
  }
  100% {
    stroke-dashoffset: 0;
  }
}

@keyframes strokePathAnime09 {
  0% {
    stroke-dashoffset: 119.474px;
  }
  100% {
    stroke-dashoffset: 0;
  }
}

.disabled-scroll {
  overflow: hidden;
  background-color: #000000;
}

.logo-animation-container {
  width: 100%;
  height: 100%;
  animation: containerAnime 7s forwards;
}

.logo-animation-container .keyvisual-logo-animation {
  position: absolute;
  top: 300px;
  left: 100px;
  fill: #000000;
  width: 150px;
  height: 150px;
  transform: translate(-50%, -50%);
  animation: logoAnime 7s forwards;
  z-index: 5;
  stroke-width: 1.5px;
}

@media screen and (min-width: 769px) {
  .logo-animation-container .keyvisual-logo-animation {
    top: 100px;
    left: 65px;
    width: 211px;
    height: 211px;
    transform: none;
    animation: logoAnimeSm 7s forwards;
  }
}

@media screen and (min-width: 1025px) {
  .logo-animation-container .keyvisual-logo-animation {
    top: 130px;
    left: 93px;
    animation: logoAnimeMd 7s forwards;
  }
}

@media screen and (min-width: 1300px) {
  .logo-animation-container .keyvisual-logo-animation {
    top: 165px;
    left: 163px;
    width: 246px;
    height: 246px;
    animation: logoAnimeLg 7s forwards;
  }
}

@media screen and (min-width: 1600px) {
  .logo-animation-container .keyvisual-logo-animation {
    top: 220px;
    left: 185px;
    width: 286px;
    height: 286px;
    animation: logoAnimeXl 7s forwards;
  }
}

@media all and (-ms-high-contrast: none) {
  .logo-animation-container .keyvisual-logo-animation {
    position: absolute;
    top: 300px;
    left: 95px;
    stroke: none;
    width: 150px;
    height: 150px;
    transform: translate(-50%, -50%);
    animation: logoAnime2 7s forwards;
  }
}

@media all and (-ms-high-contrast: none) and (min-width: 769px) {
  .logo-animation-container .keyvisual-logo-animation {
    position: absolute;
    top: 100px;
    left: 60px;
    stroke: none;
    width: 211px;
    height: 211px;
    transform: none;
    animation: logoAnimeSm2 7s forwards;
  }
}

@media all and (-ms-high-contrast: none) and (min-width: 1025px) {
  .logo-animation-container .keyvisual-logo-animation {
    position: absolute;
    top: 130px;
    left: 90px;
    width: 211px;
    height: 211px;
    stroke: none;
    transform: none;
    animation: logoAnimeMd2 7s forwards;
  }
}

@media all and (-ms-high-contrast: none) and (min-width: 1300px) {
  .logo-animation-container .keyvisual-logo-animation {
    position: absolute;
    top: 165px;
    left: 158px;
    stroke: none;
    width: 246px;
    height: 246px;
    transform: none;
    animation: logoAnimeLg2 7s forwards;
  }
}

@media all and (-ms-high-contrast: none) and (min-width: 1600px) {
  .logo-animation-container .keyvisual-logo-animation {
    position: absolute;
    top: 220px;
    left: 183px;
    stroke: none;
    width: 286px;
    height: 286px;
    transform: none;
    animation: logoAnimeXl2 7s forwards;
  }
}

@keyframes containerAnime {
  0% {
    position: fixed;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background-color: #000000;
    visibility: visible;
    z-index: 50;
  }
  30% {
    position: fixed;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background-color: #000000;
    visibility: visible;
    opacity: 1;
    z-index: 50;
  }
  50% {
    position: static;
    visibility: none;
    background-color: #FFFFFF;
  }
  100% {
    position: static;
    visibility: none;
  }
}

@keyframes logoAnime {
  0% {
    top: 50%;
    left: 50%;
    opacity: 0;
    stroke-width: 1px;
    transform: translate(-50%, -50%);
  }
  2% {
    opacity: 1;
    stroke: #FFFFFF;
    transform: translate(-50%, -50%);
  }
  31% {
    stroke: #FFFFFF;
  }
  40% {
    top: 50%;
    left: 50%;
    stroke: transparent;
    transform: translate(-50%, -50%);
  }
  65% {
    top: 50%;
    left: 100px;
    stroke: none;
  }
  80% {
    top: 300px;
    left: 100px;
  }
  100% {
    top: 300px;
    left: 100px;
    opacity: 1;
    stroke: none;
  }
}

@keyframes logoAnimeSm {
  0% {
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  2% {
    opacity: 1;
    stroke: #FFFFFF;
  }
  31% {
    stroke: #FFFFFF;
  }
  40% {
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    stroke: transparent;
  }
  65% {
    top: 50%;
    left: 65px;
    transform: translate(0, -50%);
    stroke: none;
  }
  80% {
    top: 100px;
    transform: none;
  }
  100% {
    top: 100px;
    left: 65px;
    transform: none;
    stroke: none;
  }
}

@keyframes logoAnimeMd {
  0% {
    opacity: 0;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  2% {
    opacity: 1;
    stroke: #FFFFFF;
  }
  31% {
    stroke: #FFFFFF;
  }
  40% {
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    stroke: transparent;
  }
  65% {
    position: absolute;
    top: 50%;
    left: 93px;
    transform: translate(0, -50%);
  }
  80% {
    top: 130px;
    transform: none;
  }
  100% {
    top: 130px;
    left: 93px;
    transform: none;
    stroke: none;
    opacity: 1;
    position: absolute;
  }
}

@keyframes logoAnimeLg {
  0% {
    opacity: 0;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  2% {
    opacity: 1;
    stroke: #FFFFFF;
  }
  31% {
    stroke: #FFFFFF;
  }
  40% {
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    stroke: transparent;
  }
  65% {
    top: 50%;
    left: 163px;
    transform: translate(0, -50%);
    stroke: none;
  }
  80% {
    top: 165px;
    transform: none;
  }
  100% {
    top: 165px;
    left: 163px;
    transform: none;
    stroke: none;
    opacity: 1;
  }
}

@keyframes logoAnimeXl {
  0% {
    opacity: 0;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  2% {
    opacity: 1;
    stroke: #FFFFFF;
  }
  31% {
    stroke: #FFFFFF;
  }
  40% {
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    stroke: transparent;
  }
  65% {
    top: 50%;
    left: 185px;
    transform: translate(0, -50%);
    stroke: none;
  }
  80% {
    top: 220px;
    transform: none;
  }
  100% {
    top: 220px;
    left: 185px;
    transform: none;
    stroke: none;
    opacity: 1;
  }
}

@keyframes logoAnime2 {
  0% {
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    opacity: 0;
  }
  2% {
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    opacity: 1;
    stroke: #FFFFFF;
  }
  32% {
    stroke: #FFFFFF;
  }
  40% {
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    opacity: 1;
    stroke: #FFFFFF;
  }
  65% {
    top: 50%;
    left: 95px;
    transform: translate(0, -50%);
    stroke: none;
    opacity: 1;
  }
  80% {
    top: 300px;
    left: 95px;
    transform: translate(-50%, -50%);
    opacity: 1;
  }
  100% {
    top: 300px;
    left: 95px;
    transform: translate(-50%, -50%);
    stroke: none;
    opacity: 1;
  }
}

@keyframes logoAnimeSm2 {
  0% {
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  2% {
    top: 50%;
    left: 50%;
    opacity: 1;
    stroke: #FFFFFF;
    transform: translate(-50%, -50%);
  }
  35% {
    top: 50%;
    left: 50%;
    stroke: #FFFFFF;
    transform: translate(-50%, -50%);
  }
  40% {
    stroke: none;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  65% {
    top: 50%;
    left: 60px;
    transform: translateY(-50%);
    stroke: none;
  }
  80% {
    top: 100px;
    left: 60px;
    transform: none;
    stroke: none;
  }
  100% {
    top: 100px;
    left: 60px;
    transform: none;
    stroke: none;
  }
}

@keyframes logoAnimeMd2 {
  0% {
    opacity: 0;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  2% {
    opacity: 1;
  }
  35% {
    stroke: #FFFFFF;
  }
  40% {
    stroke: none;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  65% {
    top: 50%;
    left: 90px;
    transform: translate(0, -50%);
    stroke: none;
  }
  80% {
    top: 130px;
    transform: none;
  }
  100% {
    top: 130px;
    left: 90px;
    transform: none;
    stroke: none;
    opacity: 1;
  }
}

@keyframes logoAnimeLg2 {
  0% {
    opacity: 0;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  2% {
    opacity: 1;
  }
  35% {
    stroke: none;
  }
  40% {
    stroke: #FFFFFF;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  65% {
    top: 50%;
    left: 158px;
    transform: translateY(-50%);
    stroke: none;
  }
  80% {
    top: 165px;
    left: 158px;
    transform: none;
  }
  100% {
    top: 165px;
    left: 158px;
    transform: none;
    stroke: none;
    opacity: 1;
  }
}

@keyframes logoAnimeXl2 {
  0% {
    opacity: 0;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  2% {
    opacity: 1;
    stroke: #FFFFFF;
  }
  35% {
    stroke: none;
  }
  40% {
    stroke: #FFFFFF;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  65% {
    top: 50%;
    left: 183px;
    transform: translateY(-50%);
    stroke: none;
  }
  80% {
    top: 220px;
    left: 183px;
    transform: none;
  }
  100% {
    top: 220px;
    left: 183px;
    transform: none;
    stroke: none;
    opacity: 1;
  }
}

/*-----------------------------------------
IntersectionObserverを用いたアニメーション
------------------------------------------*/
.jsc-intersection-item,
.jsc-accordion-item,
.jsc-intersection-slash01,
.jsc-intersection-slash02,
.jsc-intersection-slash03 {
  opacity: 0;
}

.active {
  animation: fadeActive 0.8s forwards;
  opacity: 0;
  z-index: 1;
}

@keyframes fadeActive {
  0% {
    opacity: 0;
    transform: scale(0.75);
    transform-origin: 50%;
  }
  100% {
    opacity: 1;
    transform: scale(1);
    transform-origin: 50%;
  }
}

.slash01 {
  position: relative;
  opacity: 1;
}

.slash01::before {
  position: absolute;
  height: 3px;
  transform: skewY(127deg) scale(0, 1);
  transform-origin: right top;
  background-color: #000000;
  animation: drawSlash 1s linear;
  content: "";
  top: -180px;
  left: 31.25%;
  width: 230px;
  animation-delay: 7s;
  z-index: 6;
}

.slash01::after {
  position: absolute;
  height: 3px;
  transform: skewY(127deg) scale(0, 1);
  transform-origin: left bottom;
  background-color: #000000;
  animation: drawSlash02 1s linear;
  animation-delay: 1s;
  content: "";
  top: 125px;
  left: 31.25%;
  width: 230px;
  animation-delay: 8s;
  z-index: 6;
}

.slash02 {
  position: relative;
  opacity: 1;
}

.slash02::before {
  position: absolute;
  height: 3px;
  transform: skewY(127deg) scale(0, 1);
  transform-origin: right top;
  background-color: #000000;
  animation: drawSlash 1s linear;
  content: "";
  top: -120px;
  left: -100px;
  width: 230px;
}

.slash02::after {
  position: absolute;
  height: 3px;
  transform: skewY(127deg) scale(0, 1);
  transform-origin: left bottom;
  background-color: #000000;
  animation: drawSlash02 1s linear;
  animation-delay: 1s;
  content: "";
  top: 186px;
  left: -100px;
  width: 230px;
}

.slash03 {
  position: relative;
  opacity: 1;
}

.slash03::before {
  position: absolute;
  height: 3px;
  transform: skewY(127deg) scale(0, 1);
  transform-origin: right top;
  background-color: #000000;
  animation: drawSlash 1s linear;
  content: "";
  top: 185px;
  right: 0;
  width: 230px;
}

.slash03::after {
  position: absolute;
  height: 3px;
  transform: skewY(127deg) scale(0, 1);
  transform-origin: left bottom;
  background-color: #000000;
  animation: drawSlash02 1s linear;
  animation-delay: 1s;
  content: "";
  top: 489px;
  right: 0;
  width: 230px;
}

.slash04 {
  position: relative;
  opacity: 1;
}

.slash04::before {
  position: absolute;
  height: 3px;
  transform: skewY(127deg) scale(0, 1);
  transform-origin: right top;
  background-color: #000000;
  animation: drawSlash 1s linear;
  content: "";
  top: -120px;
  left: 20%;
  width: 230px;
}

@media screen and (min-width: 1600px) {
  .slash04::before {
    left: 45%;
  }
}

.slash04::after {
  position: absolute;
  height: 3px;
  transform: skewY(127deg) scale(0, 1);
  transform-origin: left bottom;
  background-color: #000000;
  animation: drawSlash02 1s linear;
  animation-delay: 1s;
  content: "";
  top: 186px;
  left: 20%;
  width: 230px;
}

@media screen and (min-width: 1600px) {
  .slash04::after {
    left: 45%;
  }
}

@keyframes drawSlash {
  0% {
    transform: skewY(127deg) scale(0, 1);
  }
  100% {
    transform: skewY(127deg) scale(1, 1);
  }
}

@keyframes drawSlash02 {
  0% {
    transform: skewY(127deg) scale(1, 1);
  }
  100% {
    transform: skewY(127deg) scale(0, 1);
  }
}

/*-----------------------------------------
HEADER
------------------------------------------*/
.main-header {
  position: fixed;
  top: 0;
  left: 0;
  opacity: 0;
  pointer-events: none;
  width: 100%;
  height: 60px;
  background-color: #FFFFFF;
  z-index: 5;
}

@media screen and (min-width: 1025px) {
  .main-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 80px;
    padding: 0 100px;
  }
}

@media screen and (min-width: 1300px) {
  .main-header {
    padding: 0 140px;
  }
}

.main-header a .main-header-logo {
  width: 40px;
  position: absolute;
  top: 13px;
  left: 10px;
}

@media screen and (min-width: 1025px) {
  .main-header a .main-header-logo {
    position: relative;
    top: 0;
    left: 0;
    margin-top: 15px;
    width: 60px;
    height: auto;
  }
}

.main-header .hamburger-menu-open {
  display: none;
}

.main-header .hamburger-menu-open:checked ~ .main-header-list {
  display: block;
  background-color: rgba(0, 0, 0, 0.7);
  padding: 50px;
  width: 100%;
  height: 100vh;
  z-index: 10;
}

.main-header .hamburger-menu-open:checked ~ .main-header-list li {
  display: block;
  margin: 0 auto;
  text-align: center;
}

.main-header .hamburger-menu-open:checked ~ .main-header-list li a {
  color: #FFFFFF;
  font-family: "Cera Basic Bold", "ヒラギノ角ゴ Pro", sans-serif;
  font-size: 20px;
  letter-spacing: 0.15em;
  line-height: 40px;
}

.main-header .hamburger-menu-open:checked ~ .main-header-list li + li {
  margin-top: 20px;
}

.main-header .hamburger-menu-open:checked ~ .hamburger-menu {
  background: transparent;
}

.main-header .hamburger-menu-open:checked ~ .hamburger-menu span {
  background-color: #FFFFFF;
}

.main-header .hamburger-menu-open:checked ~ .hamburger-menu .hamburger-border-top {
  animation: hamburgerBorderTop 0.8s forwards;
}

.main-header .hamburger-menu-open:checked ~ .hamburger-menu .hamburger-border-middle {
  opacity: 0;
}

.main-header .hamburger-menu-open:checked ~ .hamburger-menu .hamburger-border-bottom {
  animation: hamburgerBorderBottom 0.8s forwards;
}

@keyframes hamburgerBorderTop {
  0% {
    transform: translateY(0) rotate(0deg);
  }
  100% {
    transform: translateY(9px) rotate(45deg);
  }
}

@keyframes hamburgerBorderBottom {
  0% {
    transform: translateY(0) rotate(0deg);
  }
  100% {
    transform: translateY(-9px) rotate(-45deg);
  }
}

.main-header .hamburger-menu {
  cursor: pointer;
  position: fixed;
  top: 20px;
  right: 20px;
  display: block;
}

@media screen and (min-width: 1025px) {
  .main-header .hamburger-menu {
    display: none;
  }
}

.main-header .hamburger-menu span {
  display: block;
  width: 22px;
  height: 2px;
  background-color: #000000;
  transform: translate(0);
  transition: 0.2s;
}

.main-header .hamburger-menu span + span {
  margin-top: 7px;
}

.main-header .hamburger-menu .hamburger-border-top {
  top: 20px;
  left: 20px;
  transform: translateY(0);
}

.main-header .hamburger-menu .hamburger-border-bottom {
  top: 40px;
  right: 20px;
  transform: translateY(0);
}

.main-header .main-header-list {
  display: none;
}

@media screen and (min-width: 1025px) {
  .main-header .main-header-list {
    display: block;
    font-size: 0;
    z-index: 10;
  }
  .main-header .main-header-list li {
    display: inline-block;
    margin: 0 auto;
    text-align: center;
    font-weight: 600;
  }
  .main-header .main-header-list li a {
    font-family: "Cera Basic Bold", "ヒラギノ角ゴ Pro", sans-serif;
    font-size: 18px;
    position: relative;
    color: #000000;
    font-size: 18px;
    font-weight: 700;
    backface-visibility: hidden;
    overflow: hidden;
    perspective: 1000;
  }
  .main-header .main-header-list li a::after {
    position: absolute;
    bottom: -4px;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: #000000;
    content: "";
    transform: scale(0, 1);
    transform-origin: right top;
    transition: transform 0.3s;
    backface-visibility: hidden;
    overflow: hidden;
    perspective: 1000;
  }
  .main-header .main-header-list li a:hover::after {
    transform-origin: left top;
    transform: scale(1, 1);
    height: 2px;
    backface-visibility: hidden;
    overflow: hidden;
    perspective: 1000;
  }
  .main-header .main-header-list li + li {
    margin-left: 16px;
  }
}

.no-delay-animation {
  animation: none;
  opacity: 1;
  pointer-events: auto;
}

.disabled-menu-scroll {
  overflow: hidden;
}

/*-----------------------------------------
KEY VISUAL
------------------------------------------*/
main {
  display: block;
  padding-top: 60px;
}

@media screen and (min-width: 1025px) {
  main {
    padding-top: 80px;
  }
}

.section-key-visual {
  position: relative;
  padding: 0 20px 0 40px;
  display: flex;
  align-items: center;
  flex-basis: 100%;
}

@media screen and (min-width: 769px) {
  .section-key-visual {
    height: 510px;
    padding: 0 70px;
  }
}

@media screen and (min-width: 1025px) {
  .section-key-visual {
    padding: 0 100px;
  }
}

@media screen and (min-width: 1300px) {
  .section-key-visual {
    padding: 0 140px;
    height: 600px;
  }
}

@media screen and (min-width: 1600px) {
  .section-key-visual {
    padding: 0 140px;
    height: 760px;
  }
}

.section-key-visual .key-visual-header {
  z-index: 2;
}

@media screen and (min-width: 769px) {
  .section-key-visual .key-visual-header {
    margin-left: 23px;
  }
}

@media screen and (min-width: 1300px) {
  .section-key-visual .key-visual-header {
    margin-left: 50px;
    flex-basis: 50%;
  }
}

@media screen and (min-width: 1600px) {
  .section-key-visual .key-visual-header {
    margin-left: 75px;
  }
}

@media all and (-ms-high-contrast: none) and (min-width: 769px) {
  .section-key-visual .key-visual-header .key-visual-concept {
    margin-top: 500px;
  }
}

@media all and (-ms-high-contrast: none) and (min-width: 1025px) {
  .section-key-visual .key-visual-header .key-visual-concept {
    margin-top: 222px;
  }
}

@media all and (-ms-high-contrast: none) and (min-width: 1300px) {
  .section-key-visual .key-visual-header .key-visual-concept {
    margin-top: 562px;
  }
}

@media all and (-ms-high-contrast: none) and (min-width: 1600px) {
  .section-key-visual .key-visual-header .key-visual-concept {
    margin-top: 572px;
  }
}

.section-key-visual .key-visual-header .key-visual-concept {
  margin-top: 320px;
  background-color: transparent;
}

@media screen and (min-width: 769px) {
  .section-key-visual .key-visual-header .key-visual-concept {
    margin-top: 212px;
  }
}

@media screen and (min-width: 1025px) {
  .section-key-visual .key-visual-header .key-visual-concept {
    margin-top: 222px;
  }
}

@media screen and (min-width: 1300px) {
  .section-key-visual .key-visual-header .key-visual-concept {
    margin-top: 252px;
  }
}

@media screen and (min-width: 1600px) {
  .section-key-visual .key-visual-header .key-visual-concept {
    margin-top: 282px;
  }
}

.section-key-visual .key-visual-header .key-visual-concept .key-visual-heading {
  display: block;
  color: #000000;
  font-size: 26px;
  letter-spacing: 0.2em;
  line-height: 40px;
  opacity: 0;
  margin-bottom: 20px;
  animation: delayHeading 2s forwards;
  animation-delay: 5s;
  z-index: 2;
}

@media screen and (min-width: 769px) {
  .section-key-visual .key-visual-header .key-visual-concept .key-visual-heading {
    margin-bottom: 40px;
  }
}

.section-key-visual .key-visual-header .key-visual-concept .key-visual-sub-heading {
  display: inline-block;
  color: #000000;
  font-size: 14px;
  letter-spacing: 0.26em;
  line-height: 28px;
  opacity: 0;
  animation: delaySubHeading 2s forwards;
  animation-delay: 5.8s;
  z-index: 2;
}

@media screen and (min-width: 769px) {
  .section-key-visual .key-visual-header .key-visual-concept .key-visual-sub-heading {
    background-color: rgba(255, 255, 255, 0.7);
  }
}

.section-key-visual .key-visual-header .key-visual-concept .key-visual-sub-heading:nth-of-type(1) {
  margin: 0;
}

@keyframes delayHeading {
  0% {
    opacity: 0;
  }
  5% {
    opacity: 0;
    transform: translateY(50px);
  }
  35% {
    opacity: 1;
    transform: translateY(0);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes delaySubHeading {
  0% {
    opacity: 0;
  }
  5% {
    opacity: 0;
    transform: translateY(50px);
  }
  35% {
    opacity: 1;
    transform: translateY(0px);
  }
  100% {
    opacity: 1;
    transform: translateY(0px);
  }
}

.section-key-visual .hero-img-list {
  padding-right: 20px;
  z-index: -1;
  width: 90%;
  height: 100%;
  position: absolute;
  overflow: hidden;
  top: 0;
  right: 0;
}

@media screen and (min-width: 769px) {
  .section-key-visual .hero-img-list {
    padding: 0 70px 0 66px;
  }
}

@media screen and (min-width: 1025px) {
  .section-key-visual .hero-img-list {
    padding: 0 100px;
  }
}

@media screen and (min-width: 1300px) {
  .section-key-visual .hero-img-list {
    padding: 0 140px;
  }
}

@media screen and (min-width: 1600px) {
  .section-key-visual .hero-img-list {
    padding: 0 140px;
  }
}

.section-key-visual .hero-img-list li {
  position: relative;
  overflow: hidden;
  height: 226px;
}

@media screen and (min-width: 769px) {
  .section-key-visual .hero-img-list li {
    height: 510px;
  }
}

@media screen and (min-width: 1300px) {
  .section-key-visual .hero-img-list li {
    height: 600px;
  }
}

@media screen and (min-width: 1600px) {
  .section-key-visual .hero-img-list li {
    height: 760px;
  }
}

.section-key-visual .hero-img-list li .key-visual-hero-img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 226px;
  animation: delayHeroImg 25s infinite;
  font-family: "object-fit: cover;";
  object-fit: cover;
  opacity: 0;
}

@media screen and (min-width: 769px) {
  .section-key-visual .hero-img-list li .key-visual-hero-img {
    height: 510px;
  }
}

@media screen and (min-width: 1300px) {
  .section-key-visual .hero-img-list li .key-visual-hero-img {
    height: 600px;
  }
}

@media screen and (min-width: 1600px) {
  .section-key-visual .hero-img-list li .key-visual-hero-img {
    height: 760px;
  }
}

.section-key-visual .hero-img-list li .src1 {
  animation-delay: 6.7s;
}

.section-key-visual .hero-img-list li .src2 {
  animation-delay: 11.7s;
}

.section-key-visual .hero-img-list li .src3 {
  animation-delay: 16.7s;
}

.section-key-visual .hero-img-list li .src4 {
  animation-delay: 21.7s;
}

.section-key-visual .hero-img-list li .src5 {
  animation-delay: 26.7s;
}

@keyframes delayHeroImg {
  0% {
    opacity: 0;
    transform: scale(1);
  }
  4% {
    opacity: 1;
  }
  20% {
    opacity: 1;
  }
  24% {
    opacity: 0;
  }
  100% {
    opacity: 0;
    transform: scale(1.1);
  }
  /*0% {opacity: 0; transform: scale(1.0);}
                7% {opacity: 1;}
                33% {opacity: 1;}
                40% {opacity: 0;}
                100% {opacity: 0; transform: scale(1.1);}*/
}

.section-key-visual .key-visual-vertical-font {
  position: absolute;
  top: 50%;
  left: 10px;
  height: 100%;
  text-align: center;
  transform: translate(0, -50%);
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  font-family: "Cera Basic Bold", "ヒラギノ角ゴ Pro", sans-serif;
  font-size: 10px;
  animation: verticalFontDelay 0.2s forwards;
  animation-delay: 6.6s;
  opacity: 0;
}

@media screen and (min-width: 769px) {
  .section-key-visual .key-visual-vertical-font {
    left: 40px;
    font-size: 12px;
  }
}

@keyframes verticalFontDelay {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

/*-----------------------------------------
MESSAGE
------------------------------------------*/
.section-representative-message {
  position: relative;
  padding: 100px 20px 0;
}

@media screen and (min-width: 769px) {
  .section-representative-message {
    padding: 100px 70px 0;
  }
}

@media screen and (min-width: 1025px) {
  .section-representative-message {
    padding: 100px 100px 0;
  }
}

@media screen and (min-width: 1300px) {
  .section-representative-message {
    padding: 100px 140px 0;
  }
}

.section-representative-message::before {
  position: absolute;
  width: 1px;
  height: calc(100% - 100px);
  content: "";
  background-color: #D6D6D6;
  top: 100px;
  right: 20px;
  height: calc(100% - 100px);
}

@media screen and (min-width: 769px) {
  .section-representative-message::before {
    right: 70px;
    height: calc(100% - 130px);
  }
}

@media screen and (min-width: 1025px) {
  .section-representative-message::before {
    right: 100px;
  }
}

@media screen and (min-width: 1300px) {
  .section-representative-message::before {
    right: 140px;
  }
}

.section-representative-message::after {
  position: absolute;
  width: 1px;
  height: calc(100% - 100px);
  content: "";
  background-color: #000000;
  top: 100px;
  right: 20px;
  height: 200px;
}

@media screen and (min-width: 769px) {
  .section-representative-message::after {
    right: 70px;
  }
}

@media screen and (min-width: 1025px) {
  .section-representative-message::after {
    right: 100px;
  }
}

@media screen and (min-width: 1300px) {
  .section-representative-message::after {
    right: 140px;
  }
}

.section-representative-message .heading-representative-message {
  color: #000000;
  font-family: "Cera Basic Bold", "ヒラギノ角ゴ Pro", sans-serif;
  font-size: 40px;
  font-weight: 700;
  opacity: 0;
  opacity: 0;
  text-align: right;
  margin: 0 20px 32px 0;
}

@media screen and (min-width: 769px) {
  .section-representative-message .heading-representative-message {
    font-size: 50px;
  }
}

@media screen and (min-width: 769px) {
  .section-representative-message .heading-representative-message {
    margin: 0 50px 64px 0;
  }
}

@media screen and (min-width: 1300px) {
  .section-representative-message .heading-representative-message {
    margin: 0 75px 120px 0;
  }
}

.section-representative-message .representative-message-container {
  display: block;
  margin-right: 20px;
  position: relative;
}

@media screen and (min-width: 769px) {
  .section-representative-message .representative-message-container {
    display: flex;
    justify-content: flex-start;
    margin: 0 50px 0 0;
  }
}

@media screen and (min-width: 1025px) {
  .section-representative-message .representative-message-container {
    margin: 0 50px 0 50px;
  }
}

@media screen and (min-width: 1300px) {
  .section-representative-message .representative-message-container {
    margin: 0 50px 0 50px;
  }
}

@media screen and (min-width: 1600px) {
  .section-representative-message .representative-message-container {
    margin: 0 75px 0 75px;
  }
}

.section-representative-message .representative-message-container .representative-figure {
  max-width: 100%;
  opacity: 0;
}

.section-representative-message .representative-message-container .representative-figure .representative-img {
  width: 100%;
}

@media screen and (min-width: 769px) {
  .section-representative-message .representative-message-container .representative-figure .representative-img {
    width: calc(506 * 100vw / 1920);
  }
}

.section-representative-message .representative-message-container .representative-figure + .main-message {
  margin-top: 50px;
}

@media screen and (min-width: 769px) {
  .section-representative-message .representative-message-container .representative-figure + .main-message {
    margin: 0 0 0 50px;
  }
}

@media screen and (min-width: 1025px) {
  .section-representative-message .representative-message-container .representative-figure + .main-message {
    margin: 0 0 0 50px;
  }
}

@media screen and (min-width: 1600px) {
  .section-representative-message .representative-message-container .representative-figure + .main-message {
    width: 100%;
    margin: 0 0 0 100px;
  }
}

.section-representative-message .representative-message-container .main-message {
  position: relative;
}

.section-representative-message .representative-message-container .main-message .main-message-heading {
  margin-bottom: 38px;
  color: #030000;
  font-size: 21px;
  font-weight: 600;
  line-height: 42px;
  white-space: nowrap;
}

@media screen and (min-width: 769px) {
  .section-representative-message .representative-message-container .main-message .main-message-heading {
    font-size: 26px;
  }
}

.section-representative-message .representative-message-container .main-message .main-message-text {
  color: #030000;
  font-size: 13px;
  line-height: 34px;
}

.section-representative-message .representative-message-container .main-message .representative-name {
  margin: 30px 0 40px;
  font-size: 18px;
  font-weight: 600;
  line-height: 34px;
}

@media screen and (min-width: 769px) {
  .section-representative-message .representative-message-container .main-message .representative-name {
    margin-top: 30px;
  }
}

/*-----------------------------------------
SERVICE
------------------------------------------*/
.section-service-contents {
  position: relative;
  padding: 100px 20px 150px 40px;
}

@media screen and (min-width: 769px) {
  .section-service-contents {
    padding: 100px 70px;
  }
}

@media screen and (min-width: 1025px) {
  .section-service-contents {
    padding: 100px;
  }
}

@media screen and (min-width: 1300px) {
  .section-service-contents {
    padding: 100px 140px 320px;
  }
}

.section-service-contents::before {
  position: absolute;
  width: 1px;
  height: calc(100% - 100px);
  content: "";
  background-color: #D6D6D6;
  top: 100px;
  left: 20px;
  height: calc(100% - 250px);
}

@media screen and (min-width: 769px) {
  .section-service-contents::before {
    top: 100px;
    left: 70px;
    height: calc(100% - 200px);
  }
}

@media screen and (min-width: 1025px) {
  .section-service-contents::before {
    top: 100px;
    left: 100px;
    height: calc(100% - 180px);
  }
}

@media screen and (min-width: 1300px) {
  .section-service-contents::before {
    top: 100px;
    left: 140px;
    height: calc(100% - 400px);
  }
}

.section-service-contents::after {
  position: absolute;
  width: 1px;
  height: calc(100% - 100px);
  content: "";
  background-color: #000000;
  top: 100px;
  left: 20px;
  height: 200px;
}

@media screen and (min-width: 769px) {
  .section-service-contents::after {
    top: 100px;
    left: 70px;
  }
}

@media screen and (min-width: 1025px) {
  .section-service-contents::after {
    top: 100px;
    left: 100px;
  }
}

@media screen and (min-width: 1300px) {
  .section-service-contents::after {
    top: 100px;
    left: 140px;
  }
}

.section-service-contents .heading-service-contents {
  color: #000000;
  font-family: "Cera Basic Bold", "ヒラギノ角ゴ Pro", sans-serif;
  font-size: 40px;
  font-weight: 700;
  opacity: 0;
  margin-bottom: 32px;
}

@media screen and (min-width: 769px) {
  .section-service-contents .heading-service-contents {
    font-size: 50px;
  }
}

@media screen and (min-width: 769px) {
  .section-service-contents .heading-service-contents {
    margin: 0 0 40px 50px;
  }
}

@media screen and (min-width: 1600px) {
  .section-service-contents .heading-service-contents {
    margin: 0 0 40px 75px;
  }
}

.section-service-contents .sub-heading-service-contents {
  margin-bottom: 43px;
  font-size: 13px;
  line-height: 28px;
}

@media screen and (min-width: 769px) {
  .section-service-contents .sub-heading-service-contents {
    margin: 0 0 86px 50px;
  }
}

@media screen and (min-width: 1600px) {
  .section-service-contents .sub-heading-service-contents {
    margin: 0 0 86px 75px;
  }
}

.section-service-contents .service-contents-list {
  display: block;
}

@media screen and (min-width: 769px) {
  .section-service-contents .service-contents-list {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
  }
}

@media screen and (min-width: 769px) {
  .section-service-contents .service-contents-list {
    margin-left: 102px;
  }
}

@media screen and (min-width: 1025px) {
  .section-service-contents .service-contents-list {
    margin: 0 128px;
  }
}

@media screen and (min-width: 1300px) {
  .section-service-contents .service-contents-list {
    margin: 0 160px;
  }
}

@media screen and (min-width: 1600px) {
  .section-service-contents .service-contents-list {
    margin: 0 192px;
  }
}

.section-service-contents .service-contents-list li {
  width: 100%;
}

@media screen and (min-width: 769px) {
  .section-service-contents .service-contents-list li {
    flex: 1;
  }
}

.section-service-contents .service-contents-list li a {
  color: #000000;
}

.section-service-contents .service-contents-list li a .service-contents-img {
  margin: 0 0 21px 0;
  width: 100%;
  position: relative;
  opacity: 0;
}

@media screen and (min-width: 769px) {
  .section-service-contents .service-contents-list li a .service-contents-img {
    margin-bottom: 38px;
  }
}

.section-service-contents .service-contents-list li a .service-contents-img::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  content: "";
  transition: opacity 0.2s;
  background: linear-gradient(0deg, transparent, transparent);
  opacity: 0;
  z-index: 5;
}

.section-service-contents .service-contents-list li a .service-contents-img::after {
  position: absolute;
  top: 0;
  left: 0;
  content: "";
}

.section-service-contents .service-contents-list li a .service-contents-img img {
  width: 100%;
}

.section-service-contents .service-contents-list li a .service-contents-img .see-more-infomation {
  position: absolute;
  bottom: 20px;
  right: 20px;
  transition: opacity 0.2s;
  color: #FFFFFF;
  font-family: "Cera Basic Bold", "ヒラギノ角ゴ Pro", sans-serif;
  font-size: 16px;
  opacity: 0;
  z-index: 6;
}

.section-service-contents .service-contents-list li a .service-contents-img .see-more-infomation::before {
  position: absolute;
  top: 50%;
  left: -56px;
  transform: translate(-50%, 0);
  width: 87px;
  height: 1px;
  background-color: #FFFFFF;
  content: "";
}

.section-service-contents .service-contents-list li a .heading-service-contents-item {
  margin: 0 0 21px 0;
  font-family: "Cera Basic Bold", "ヒラギノ角ゴ Pro", sans-serif;
  font-size: 26px;
  font-weight: 700;
}

@media screen and (min-width: 769px) {
  .section-service-contents .service-contents-list li a .heading-service-contents-item {
    margin-bottom: 38px;
  }
}

.section-service-contents .service-contents-list li a .service-contents-item-text {
  font-size: 13px;
  line-height: 23px;
}

@media screen and (min-width: 769px) {
  .section-service-contents .service-contents-list li a:hover .service-contents-img {
    position: relative;
    display: block;
    z-index: 2;
  }
  .section-service-contents .service-contents-list li a:hover .service-contents-img::before {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    content: "";
    background: linear-gradient(0deg, rgba(0, 0, 0, 0.61), rgba(139, 139, 139, 0.2));
    opacity: 1;
    z-index: 5;
  }
  .section-service-contents .service-contents-list li a:hover .see-more-infomation {
    opacity: 1;
  }
}

.section-service-contents .service-contents-list li + li {
  margin-top: 40px;
}

@media screen and (min-width: 769px) {
  .section-service-contents .service-contents-list li + li {
    margin: 40px 0 0 40px;
  }
}

@media screen and (min-width: 1025px) {
  .section-service-contents .service-contents-list li + li {
    margin: 60px 0 0 60px;
  }
}

@media screen and (min-width: 1300px) {
  .section-service-contents .service-contents-list li + li {
    margin: 80px 0 0 80px;
  }
}

.section-service-contents .service-vertical-font {
  position: absolute;
  top: 50%;
  right: 2px;
  transform: translateY(-50%);
  text-align: center;
  height: 100%;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  font-family: "Cera Basic Bold", "ヒラギノ角ゴ Pro", sans-serif;
  font-size: 10px;
}

@media screen and (min-width: 769px) {
  .section-service-contents .service-vertical-font {
    font-size: 12px;
  }
}

@media screen and (min-width: 1025px) {
  .section-service-contents .service-vertical-font {
    right: 100px;
  }
}

@media screen and (min-width: 1300px) {
  .section-service-contents .service-vertical-font {
    right: 140px;
  }
}

@media all and (-ms-high-contrast: none) {
  .section-service-contents .service-vertical-font {
    bottom: 50%;
    right: 10px;
  }
}

@media all and (-ms-high-contrast: none) and (min-width: 769px) {
  .section-service-contents .service-vertical-font {
    bottom: 50%;
  }
}

@media all and (-ms-high-contrast: none) and (min-width: 1025px) {
  .section-service-contents .service-vertical-font {
    top: 50%;
    left: 100px;
    transform: translateY(-50%);
  }
}

@media all and (-ms-high-contrast: none) and (min-width: 1300px) {
  .section-service-contents .service-vertical-font {
    top: 50%;
    left: 140px;
    transform: translateY(-50%);
  }
}

/*-----------------------------------------
COMPANY
------------------------------------------*/
.section-company-overview {
  position: relative;
  padding: 150px 40px 120px 20px;
}

@media screen and (min-width: 769px) {
  .section-company-overview {
    padding: 100px 70px 155px;
  }
}

@media screen and (min-width: 1025px) {
  .section-company-overview {
    padding: 100px 100px 155px;
  }
}

@media screen and (min-width: 1300px) {
  .section-company-overview {
    padding: 100px 140px 155px;
  }
}

.section-company-overview::before {
  position: absolute;
  width: 1px;
  height: calc(100% - 100px);
  content: "";
  background-color: #FFFFFF;
  top: 150px;
  right: 20px;
  height: calc(100% - 260px);
}

@media screen and (min-width: 769px) {
  .section-company-overview::before {
    top: 100px;
    right: 70px;
    height: calc(100% - 240px);
  }
}

@media screen and (min-width: 1025px) {
  .section-company-overview::before {
    top: 100px;
    right: 100px;
    height: calc(100% - 240px);
  }
}

@media screen and (min-width: 1300px) {
  .section-company-overview::before {
    top: 100px;
    right: 140px;
    height: calc(100% - 240px);
  }
}

.section-company-overview .company-checkbox {
  display: none;
}

.section-company-overview .company-checkbox:checked ~ .company-checkbox-heading::after {
  display: none;
}

.section-company-overview .company-checkbox:checked ~ .company-list {
  display: block;
}

.section-company-overview .company-checkbox:checked ~ .company-list li {
  border-top: 1px solid #FFFFFF;
  padding: 20px 0 20px 0;
}

.section-company-overview .company-checkbox:checked ~ .company-list li .company-item-heading {
  width: 100px;
  color: #FFFFFF;
  font-size: 14px;
  font-weight: 600;
  line-height: 30px;
}

@media screen and (min-width: 1300px) {
  .section-company-overview .company-checkbox:checked ~ .company-list li .company-item-heading {
    height: 100%;
    font-size: 18px;
  }
}

.section-company-overview .company-checkbox:checked ~ .company-list li .company-item-text {
  padding-right: 20px;
  position: relative;
  color: #FFFFFF;
  font-size: 14px;
  font-weight: 300;
  line-height: 30px;
}

@media screen and (min-width: 1300px) {
  .section-company-overview .company-checkbox:checked ~ .company-list li .company-item-text {
    font-size: 18px;
  }
}

.section-company-overview .company-checkbox:checked ~ .company-list li .company-item-text .privacy-mark {
  left: 220px;
}

.section-company-overview .company-checkbox:checked ~ .company-list li:nth-of-type(1) {
  margin-top: -1px;
}

@media all and (-ms-high-contrast: none) and (max-width: 678px) {
  .section-company-overview .company-image {
    position: absolute;
    bottom: 60px;
  }
}

.section-company-overview .company-image {
  padding-top: 50px;
  position: absolute;
  top: -70px;
  left: 40px;
  width: calc(344 * 100vw / 768);
  box-sizing: content-box;
  opacity: 0;
}

@media screen and (min-width: 769px) {
  .section-company-overview .company-image {
    padding: 50px 50px 50px 0;
    top: -50px;
    left: 120px;
    width: calc(578 * 100vw / 1920);
  }
}

@media screen and (min-width: 1025px) {
  .section-company-overview .company-image {
    top: -100px;
    left: 150px;
  }
}

@media screen and (min-width: 1300px) {
  .section-company-overview .company-image {
    top: -150px;
    left: 190px;
  }
}

@media screen and (min-width: 1600px) {
  .section-company-overview .company-image {
    top: -300px;
    left: 215px;
  }
}

.section-company-overview .company-image img {
  width: 100%;
}

.section-company-overview .heading-company {
  color: #000000;
  font-family: "Cera Basic Bold", "ヒラギノ角ゴ Pro", sans-serif;
  font-size: 40px;
  font-weight: 700;
  opacity: 0;
  color: #FFFFFF;
  margin-bottom: 32px;
  text-align: right;
}

@media screen and (min-width: 769px) {
  .section-company-overview .heading-company {
    font-size: 50px;
  }
}

@media screen and (min-width: 769px) {
  .section-company-overview .heading-company {
    margin: 0 50px 110px 0;
  }
}

@media screen and (min-width: 1600px) {
  .section-company-overview .heading-company {
    margin: 0 75px 110px 0;
  }
}

.section-company-overview .company-list-container {
  margin-bottom: 32px;
}

@media screen and (min-width: 769px) {
  .section-company-overview .company-list-container {
    margin: 0 50px 32px 0;
  }
}

@media screen and (min-width: 1025px) {
  .section-company-overview .company-list-container {
    display: flex;
    justify-content: space-between;
    margin: 0 50px 100px 0;
  }
}

@media screen and (min-width: 1600px) {
  .section-company-overview .company-list-container {
    margin: 0 75px 100px 0;
  }
}

.section-company-overview .company-list-container .company-checkbox-heading {
  color: #FFFFFF;
  display: block;
  padding: 10px 0;
  position: relative;
  border-top: 1px solid #FFFFFF;
  border-bottom: 1px solid #FFFFFF;
  color: #FFFFFF;
  cursor: pointer;
  font-size: 14px;
  letter-spacing: 0.15em;
  line-height: 32px;
}

@media screen and (min-width: 1025px) {
  .section-company-overview .company-list-container .company-checkbox-heading {
    display: none;
  }
}

.section-company-overview .company-list-container .company-checkbox-heading::before {
  position: absolute;
  top: 50%;
  right: 5%;
  transform: translate(-5%, -50%);
  width: 10px;
  height: 1px;
  background-color: #FFFFFF;
  content: "";
}

.section-company-overview .company-list-container .company-checkbox-heading::after {
  margin-right: 5px;
  position: absolute;
  top: 50%;
  right: 5%;
  transform: translate(-5%, -50%);
  width: 1px;
  height: 10px;
  background-color: #FFFFFF;
  content: "";
}

.section-company-overview .company-list-container .company-list {
  display: none;
}

@media all and (-ms-high-contrast: none) and (min-width: 1025px) {
  .section-company-overview .company-list-container .company-list li {
    display: block !important;
  }
}

.section-company-overview .company-list-container .company-list .privacy-mark {
  position: absolute;
  top: 4px;
  width: 50px;
  height: 50px;
}

@media screen and (min-width: 1025px) {
  .section-company-overview .company-list-container .company-list {
    display: block;
    border-top: 1px solid #FFFFFF;
  }
  .section-company-overview .company-list-container .company-list li {
    display: flex;
    border-bottom: 1px solid #FFFFFF;
    padding: 20px 0;
  }
  .section-company-overview .company-list-container .company-list li .company-item-heading {
    display: inline-block;
    vertical-align: text-top;
    min-width: 100px;
    color: #FFFFFF;
    font-size: 14px;
    font-weight: 600;
    line-height: 30px;
  }
}

@media screen and (min-width: 1025px) and (min-width: 1300px) {
  .section-company-overview .company-list-container .company-list li .company-item-heading {
    font-size: 18px;
  }
}

@media screen and (min-width: 1025px) {
  .section-company-overview .company-list-container .company-list li .company-item-text {
    display: inline-block;
    vertical-align: text-top;
    padding-right: 20px;
    position: relative;
    color: #FFFFFF;
    font-size: 14px;
    font-weight: 300;
    line-height: 30px;
  }
}

@media screen and (min-width: 1025px) and (min-width: 1300px) {
  .section-company-overview .company-list-container .company-list li .company-item-text {
    font-size: 18px;
  }
}

@media screen and (min-width: 1025px) {
  .section-company-overview .company-list-container .company-list li .company-item-text .privacy-mark {
    right: -60px;
    margin: 0 10px;
  }
}

@media screen and (min-width: 1025px) and (min-width: 1025px) {
  .section-company-overview .company-list-container .company-list + .company-list {
    margin-left: 50px;
  }
}

@media screen and (min-width: 1025px) and (min-width: 1300px) {
  .section-company-overview .company-list-container .company-list + .company-list {
    margin-left: 75px;
  }
}

@media screen and (min-width: 1025px) and (min-width: 1600px) {
  .section-company-overview .company-list-container .company-list + .company-list {
    margin-left: 100px;
  }
}

.section-company-overview iframe {
  width: 100%;
  height: 250px;
  cursor: pointer;
}

@media screen and (min-width: 769px) {
  .section-company-overview iframe {
    width: calc(100% - 50px);
    height: 450px;
  }
}

@media screen and (min-width: 1600px) {
  .section-company-overview iframe {
    width: calc(100% - 75px);
  }
}

.black-background {
  background-color: #000000;
  transition: background-color 0.8s;
}

.white-background {
  background-color: #FFFFFF;
  transition: background-color 0.8s;
}

/*-----------------------------------------
沿革・主要取引先
------------------------------------------*/
.section-history-supplier {
  position: relative;
  padding: 140px 20px;
}

@media screen and (min-width: 769px) {
  .section-history-supplier {
    padding: 100px;
  }
}

@media screen and (min-width: 1025px) {
  .section-history-supplier {
    display: flex;
    justify-content: space-between;
  }
}

@media screen and (min-width: 1300px) {
  .section-history-supplier {
    padding: 155px 240px 155px 140px;
    justify-content: flex-start;
  }
}

.section-history-supplier .company-img02 {
  position: absolute;
  top: -80px;
  right: 40px;
  width: calc(344 * 100vw / 768);
}

@media screen and (min-width: 769px) {
  .section-history-supplier .company-img02 {
    width: calc(578 * 100vw / 1920);
    right: 120px;
    padding: 0 0 50px 0;
  }
}

@media screen and (min-width: 1025px) {
  .section-history-supplier .company-img02 {
    right: 150px;
    padding: 0 0 50px 50px;
  }
}

@media screen and (min-width: 1300px) {
  .section-history-supplier .company-img02 {
    right: 190px;
    padding: 0 0 50px 50px;
  }
}

@media screen and (min-width: 1600px) {
  .section-history-supplier .company-img02 {
    right: 215px;
    padding: 0 0 50px 50px;
  }
}

.section-history-supplier .company-img02 img {
  width: 100%;
}

.section-history-supplier .history-info-container {
  margin-top: 50px;
  position: relative;
}

@media screen and (min-width: 1025px) {
  .section-history-supplier .history-info-container {
    margin-right: calc(70 * 100vw / 1920);
  }
}

@media screen and (min-width: 1300px) {
  .section-history-supplier .history-info-container {
    margin-right: calc(346 * 100vw / 1920);
  }
}

.section-history-supplier .history-info-container .input-checkbox01 {
  display: none;
}

.section-history-supplier .history-info-container .sp-history-info-heading {
  display: block;
  padding: 10px 0;
  position: relative;
  border-top: 1px solid #000000;
  border-bottom: 1px solid #000000;
  color: #000000;
  cursor: pointer;
  font-size: 14px;
  line-height: 32px;
}

@media screen and (min-width: 1025px) {
  .section-history-supplier .history-info-container .sp-history-info-heading {
    display: none;
  }
}

.section-history-supplier .history-info-container .sp-history-info-heading::before {
  position: absolute;
  top: 50%;
  right: 5%;
  transform: translate(-5%, -50%);
  width: 10px;
  height: 1px;
  background-color: #333333;
  content: "";
}

.section-history-supplier .history-info-container .sp-history-info-heading::after {
  margin-right: 5px;
  position: absolute;
  top: 50%;
  right: 5%;
  transform: translate(-5%, -50%);
  width: 1px;
  height: 10px;
  background-color: #333333;
  content: "";
}

.section-history-supplier .history-info-container .history-info-heading {
  display: none;
}

@media screen and (min-width: 1025px) {
  .section-history-supplier .history-info-container .history-info-heading {
    display: block;
    position: relative;
    margin-bottom: 30px;
    color: #000000;
    font-size: 18px;
    line-height: 29px;
  }
  .section-history-supplier .history-info-container .history-info-heading::after {
    width: 40px;
    height: 1px;
    position: absolute;
    top: 30px;
    left: 0;
    background-color: #000000;
    content: "";
  }
}

.section-history-supplier .history-info-container .history-info-list {
  display: none;
}

@media screen and (min-width: 1025px) {
  .section-history-supplier .history-info-container .history-info-list {
    display: block;
  }
  .section-history-supplier .history-info-container .history-info-list li {
    display: flex;
  }
  .section-history-supplier .history-info-container .history-info-list li time {
    min-width: 82px;
    font-weight: 700;
    letter-spacing: 0.08em;
    line-height: 29px;
    font-family: "Jost", sans-serif;
    font-size: 14px;
  }
  .section-history-supplier .history-info-container .history-info-list li p {
    letter-spacing: 0.15em;
    font-size: 14px;
    line-height: 29px;
  }
}

@media screen and (min-width: 1025px) and (min-width: 1300px) {
  .section-history-supplier .history-info-container .history-info-list li p {
    font-size: 18px;
  }
}

@media screen and (min-width: 1025px) {
  .section-history-supplier .history-info-container .history-info-list li + li {
    margin-top: 15px;
  }
}

@media screen and (min-width: 1025px) and (min-width: 1300px) {
  .section-history-supplier .history-info-container .history-info-list li + li {
    margin-top: 25px;
  }
}

@media screen and (min-width: 1025px) and (min-width: 1600px) {
  .section-history-supplier .history-info-container .history-info-list li + li {
    margin-top: 35px;
  }
}

.section-history-supplier .history-info-container .input-checkbox01:checked ~ .history-info-list {
  display: block;
  padding: 20px 0;
}

.section-history-supplier .history-info-container .input-checkbox01:checked ~ .history-info-list li {
  display: block;
}

.section-history-supplier .history-info-container .input-checkbox01:checked ~ .history-info-list li time {
  display: block;
  width: 82px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: #000000;
  font-family: "Jost", sans-serif;
  line-height: 29px;
  font-size: 14px;
}

.section-history-supplier .history-info-container .input-checkbox01:checked ~ .history-info-list li p {
  letter-spacing: 0.15em;
  color: #000000;
  font-size: 14px;
  line-height: 29px;
}

@media screen and (min-width: 1300px) {
  .section-history-supplier .history-info-container .input-checkbox01:checked ~ .history-info-list li p {
    font-size: 18px;
  }
}

.section-history-supplier .history-info-container .input-checkbox01:checked ~ .history-info-list li + li {
  padding-top: 20px;
}

.section-history-supplier .history-info-container .input-checkbox01:checked ~ .sp-history-info-heading::after {
  display: none;
}

@media screen and (min-width: 1025px) {
  .section-history-supplier .main-supplier-container {
    margin-top: 290px;
  }
}

.section-history-supplier .main-supplier-container .input-checkbox02 {
  display: none;
}

.section-history-supplier .main-supplier-container .sp-main-supplier-heading {
  margin-top: -1px;
  display: block;
  padding: 10px 0;
  position: relative;
  border-top: 1px solid #000000;
  border-bottom: 1px solid #000000;
  color: #000000;
  cursor: pointer;
  font-size: 14px;
  line-height: 32px;
}

@media screen and (min-width: 1025px) {
  .section-history-supplier .main-supplier-container .sp-main-supplier-heading {
    display: none;
  }
}

.section-history-supplier .main-supplier-container .sp-main-supplier-heading::before {
  position: absolute;
  top: 50%;
  right: 5%;
  transform: translate(-5%, -50%);
  width: 10px;
  height: 1px;
  background-color: #333333;
  content: "";
}

.section-history-supplier .main-supplier-container .sp-main-supplier-heading::after {
  margin-right: 5px;
  position: absolute;
  top: 50%;
  right: 5%;
  transform: translate(-5%, -50%);
  width: 1px;
  height: 10px;
  background-color: #333333;
  content: "";
}

.section-history-supplier .main-supplier-container .main-supplier-heading {
  display: none;
}

@media screen and (min-width: 1025px) {
  .section-history-supplier .main-supplier-container .main-supplier-heading {
    display: block;
    position: relative;
    margin-bottom: 30px;
    color: #000000;
    font-size: 18px;
    line-height: 29px;
  }
  .section-history-supplier .main-supplier-container .main-supplier-heading::after {
    width: 40px;
    height: 1px;
    position: absolute;
    top: 30px;
    left: 0;
    background-color: #000000;
    content: "";
  }
}

.section-history-supplier .main-supplier-container .main-supplier-list {
  display: none;
}

@media screen and (min-width: 1025px) {
  .section-history-supplier .main-supplier-container .main-supplier-list {
    display: block;
  }
  .section-history-supplier .main-supplier-container .main-supplier-list li {
    color: #000000;
    font-size: 14px;
    line-height: 29px;
  }
}

@media screen and (min-width: 1025px) and (min-width: 1300px) {
  .section-history-supplier .main-supplier-container .main-supplier-list li {
    font-size: 18px;
  }
}

@media screen and (min-width: 1025px) {
  .section-history-supplier .main-supplier-container .main-supplier-list li + li {
    margin-top: 15px;
  }
}

@media screen and (min-width: 1025px) and (min-width: 1300px) {
  .section-history-supplier .main-supplier-container .main-supplier-list li + li {
    margin-top: 25px;
  }
}

@media screen and (min-width: 1025px) and (min-width: 1600px) {
  .section-history-supplier .main-supplier-container .main-supplier-list li + li {
    margin-top: 35px;
  }
}

.section-history-supplier .main-supplier-container .input-checkbox02:checked ~ .main-supplier-list {
  display: block;
}

.section-history-supplier .main-supplier-container .input-checkbox02:checked ~ .main-supplier-list li {
  display: block;
  padding-top: 20px;
  color: #000000;
  font-size: 14px;
  line-height: 29px;
}

@media screen and (min-width: 1300px) {
  .section-history-supplier .main-supplier-container .input-checkbox02:checked ~ .main-supplier-list li {
    font-size: 18px;
  }
}

.section-history-supplier .main-supplier-container .input-checkbox02:checked ~ .sp-main-supplier-heading::after {
  display: none;
}

/*-----------------------------------------
CONTACT LINK
------------------------------------------*/
.section-contact-link {
  background-color: #000000;
}

.section-contact-link a {
  display: block;
  padding: 40px 0;
  color: #FFFFFF;
  font-size: 19px;
  text-align: center;
}

@media screen and (min-width: 1300px) {
  .section-contact-link a {
    padding: 60px 0;
    font-size: 24px;
  }
}

.section-contact-link a::before {
  display: inline-block;
  vertical-align: text-top;
  width: 26px;
  height: 19px;
  margin-right: 17px;
  background: url("../img/contact-link-icon.png") no-repeat center/cover;
  content: "";
  text-align: center;
}

@media screen and (min-width: 1300px) {
  .section-contact-link a::before {
    width: 33px;
    height: 25px;
  }
}

/*-----------------------------------------
FOOTER
------------------------------------------*/
.main-footer {
  padding: 47px;
  position: relative;
  background-color: #D6D6D6;
}

@media screen and (min-width: 1300px) {
  .main-footer {
    display: flex;
    justify-content: flex-start;
    align-items: center;
  }
}

@media screen and (min-width: 1600px) {
  .main-footer {
    padding: 47px 0 47px 140px;
  }
}

.main-footer .back-to-top-wrapper {
  position: absolute;
  bottom: 0;
  right: 0;
}

.main-footer .back-to-top-wrapper .back-to-top {
  display: block;
  position: relative;
  width: 82px;
  height: 82px;
  background-color: #666666;
  text-align: center;
}

@media screen and (min-width: 769px) {
  .main-footer .back-to-top-wrapper .back-to-top {
    width: 163px;
    height: 163px;
  }
}

.main-footer .back-to-top-wrapper .back-to-top::before {
  position: absolute;
  left: calc(50% - 1px);
  top: 25px;
  width: 5px;
  height: 5px;
  border-top: 1px solid #FFFFFF;
  border-left: 1px solid #FFFFFF;
  transform: rotate(45deg) translateX(-50%);
  content: "";
}

@media screen and (min-width: 769px) {
  .main-footer .back-to-top-wrapper .back-to-top::before {
    top: 45px;
  }
}

.main-footer .back-to-top-wrapper .back-to-top::after {
  position: absolute;
  top: 23px;
  left: 50%;
  width: 1px;
  height: 40px;
  transform: translateX(-50%);
  background-color: #FFFFFF;
  content: "";
}

@media screen and (min-width: 769px) {
  .main-footer .back-to-top-wrapper .back-to-top::after {
    top: 43px;
  }
}

.main-footer .back-to-top-wrapper .back-to-top p {
  display: none;
}

@media screen and (min-width: 769px) {
  .main-footer .back-to-top-wrapper .back-to-top p {
    display: inline-block;
    margin-top: 100px;
    color: #FFFFFF;
    font-family: "Cera Basic Bold", "ヒラギノ角ゴ Pro", sans-serif;
  }
}

@media screen and (min-width: 1025px) {
  .main-footer .main-footer-contents {
    display: flex;
    align-items: center;
  }
}

.main-footer .main-footer-contents .footer-logo {
  display: block;
  margin: -10px auto 50px;
  width: 69px;
}

@media screen and (min-width: 1025px) {
  .main-footer .main-footer-contents .footer-logo {
    display: inline-block;
    vertical-align: middle;
    margin: 0 20px 0 0;
    width: 69px;
  }
}

@media screen and (min-width: 1300px) {
  .main-footer .main-footer-contents .footer-logo {
    margin: 0;
  }
}

.main-footer .main-footer-contents .main-footer-menu-list {
  display: inline-block;
  vertical-align: text-top;
}

@media screen and (min-width: 1025px) {
  .main-footer .main-footer-contents .main-footer-menu-list {
    vertical-align: text-bottom;
  }
}

@media screen and (min-width: 1300px) {
  .main-footer .main-footer-contents .main-footer-menu-list {
    margin-left: 40px;
  }
}

@media screen and (min-width: 1600px) {
  .main-footer .main-footer-contents .main-footer-menu-list {
    margin-left: 60px;
  }
}

.main-footer .main-footer-contents .main-footer-menu-list ul {
  font-size: 0;
}

.main-footer .main-footer-contents .main-footer-menu-list ul li {
  display: block;
}

@media screen and (min-width: 1025px) {
  .main-footer .main-footer-contents .main-footer-menu-list ul li {
    display: inline-block;
  }
}

.main-footer .main-footer-contents .main-footer-menu-list ul li a {
  font-family: "Cera Basic Bold", "ヒラギノ角ゴ Pro", sans-serif;
  position: relative;
  color: #000000;
  font-size: 18px;
  font-weight: 700;
  backface-visibility: hidden;
  overflow: hidden;
  perspective: 1000;
}

.main-footer .main-footer-contents .main-footer-menu-list ul li a::after {
  position: absolute;
  bottom: -4px;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: #000000;
  content: "";
  transform: scale(0, 1);
  transform-origin: right top;
  transition: transform 0.3s;
  backface-visibility: hidden;
  overflow: hidden;
  perspective: 1000;
}

.main-footer .main-footer-contents .main-footer-menu-list ul li a:hover::after {
  transform-origin: left top;
  transform: scale(1, 1);
  height: 2px;
  backface-visibility: hidden;
  overflow: hidden;
  perspective: 1000;
}

.main-footer .main-footer-contents .main-footer-menu-list ul li + li {
  margin: 16px 0 0;
}

@media screen and (min-width: 1025px) {
  .main-footer .main-footer-contents .main-footer-menu-list ul li + li {
    margin: 0 0 0 16px;
  }
}

.main-footer .main-footer-contents .main-footer-policy-list {
  display: block;
  margin: 52px 0 0;
}

@media screen and (min-width: 769px) {
  .main-footer .main-footer-contents .main-footer-policy-list {
    display: inline-block;
    vertical-align: text-top;
    margin: 0 0 0 52px;
  }
}

@media screen and (min-width: 1025px) {
  .main-footer .main-footer-contents .main-footer-policy-list {
    display: block;
    margin: 20px 0 0;
  }
}

@media screen and (min-width: 1300px) {
  .main-footer .main-footer-contents .main-footer-policy-list {
    display: inline-block;
    vertical-align: text-bottom;
    margin: 0 0 0 32px;
  }
}

.main-footer .main-footer-contents .main-footer-policy-list ul {
  font-size: 0;
}

@media screen and (min-width: 1025px) {
  .main-footer .main-footer-contents .main-footer-policy-list ul li {
    display: inline-block;
    vertical-align: text-top;
  }
}

.main-footer .main-footer-contents .main-footer-policy-list ul li a {
  font-size: 13px;
  color: #000000;
}

.main-footer .main-footer-contents .main-footer-policy-list ul li + li {
  margin: 16px 0 0;
}

@media screen and (min-width: 1025px) {
  .main-footer .main-footer-contents .main-footer-policy-list ul li + li {
    margin: 0 0 0 16px;
  }
}

.main-footer .main-footer-contents .twitter-link {
  margin: 42px 0 0;
}

@media screen and (min-width: 1025px) {
  .main-footer .main-footer-contents .twitter-link {
    margin: 0 0 0 26px;
  }
}

@media screen and (min-width: 1300px) {
  .main-footer .main-footer-contents .twitter-link {
    margin: 0 0 0 40px;
  }
}

.main-footer .main-footer-contents .twitter-link svg {
  display: block;
  margin: 52px auto 0;
  padding: 10px;
}

@media screen and (min-width: 1025px) {
  .main-footer .main-footer-contents .twitter-link svg {
    display: inline-block;
    vertical-align: middle;
    margin: 0;
  }
}

@media all and (-ms-high-contrast: none) and (min-width: 1300px) {
  .main-footer {
    padding: 0 47px;
    height: 163px;
  }
}

@media all and (-ms-high-contrast: none) and (min-width: 1600px) {
  .main-footer {
    padding: 0 0 0 140px;
  }
}

/*-----------------------------------------
CONTACT入力ページ
------------------------------------------*/
.section-contact {
  position: relative;
  padding: 70px 20px;
}

@media screen and (min-width: 769px) {
  .section-contact {
    padding: 70px 70px 100px;
  }
}

@media screen and (min-width: 1025px) {
  .section-contact {
    padding: 70px 100px 100px;
  }
}

@media screen and (min-width: 1300px) {
  .section-contact {
    padding: 70px 140px 50px;
  }
}

.section-contact::before {
  position: absolute;
  width: 1px;
  height: calc(100% - 100px);
  content: "";
  background-color: #D6D6D6;
  top: 70px;
  left: 20px;
  height: calc(100% - 150px);
}

@media screen and (min-width: 769px) {
  .section-contact::before {
    left: 70px;
    height: calc(100% - 200px);
  }
}

@media screen and (min-width: 1025px) {
  .section-contact::before {
    left: 100px;
    height: calc(100% - 210px);
  }
}

@media screen and (min-width: 1300px) {
  .section-contact::before {
    left: 140px;
  }
}

.section-contact::after {
  position: absolute;
  width: 1px;
  height: calc(100% - 100px);
  content: "";
  background-color: #000000;
  top: 70px;
  left: 20px;
  height: 200px;
}

@media screen and (min-width: 769px) {
  .section-contact::after {
    left: 70px;
  }
}

@media screen and (min-width: 1025px) {
  .section-contact::after {
    left: 100px;
  }
}

@media screen and (min-width: 1300px) {
  .section-contact::after {
    left: 140px;
  }
}

.section-contact .contact-vertical-font {
  position: absolute;
  top: 257px;
  left: 4px;
  text-align: center;
  font-family: "Cera Basic Bold", "ヒラギノ角ゴ Pro", sans-serif;
  font-size: 10px;
  font-weight: 700;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
}

@media screen and (min-width: 769px) {
  .section-contact .contact-vertical-font {
    left: 40px;
    font-size: 12px;
  }
}

@media screen and (min-width: 1300px) {
  .section-contact .contact-vertical-font {
    top: 257px;
  }
}

.section-contact .contact-container {
  padding-left: 20px;
}

@media screen and (min-width: 769px) {
  .section-contact .contact-container {
    padding: 0 50px;
  }
}

.section-contact .contact-container .heading-contact {
  font-family: "Cera Basic Bold", "ヒラギノ角ゴ Pro", sans-serif;
  font-size: 50px;
  margin-bottom: 40px;
}

.section-contact .contact-container .sub-text-contact {
  margin-bottom: 28px;
  font-size: 13px;
  font-weight: 300;
  line-height: 28px;
}

.section-contact .contact-container .sub-text-contact span {
  color: #FF0000;
}

.section-contact .contact-container .transition-to-privacy {
  display: block;
  margin-bottom: 43px;
  position: relative;
  max-width: 530px;
  width: 100%;
  background-color: #666666;
  border-radius: 6px;
  color: #FFFFFF;
  font-size: 12px;
  font-weight: 300;
  line-height: 20px;
  text-align: center;
}

@media screen and (min-width: 1600px) {
  .section-contact .contact-container .transition-to-privacy {
    margin-bottom: 46px;
  }
}

.section-contact .contact-container .transition-to-privacy::before, .section-contact .contact-container .transition-to-privacy::after {
  position: absolute;
  top: 50%;
  right: 17px;
  transform: translateY(-50%);
  height: 1px;
  background-color: #FFFFFF;
  content: "";
}

.section-contact .contact-container .transition-to-privacy::before {
  width: 17px;
}

.section-contact .contact-container .transition-to-privacy::after {
  top: calc(50% - 2px);
  right: 16px;
  width: 5px;
  transform: rotate(45deg);
}

.section-contact .contact-container .transition-to-privacy p {
  padding: 10px 40px 10px 20px;
}

@media screen and (min-width: 769px) {
  .section-contact .contact-container .contact-form {
    padding: 0 50px;
  }
}

@media screen and (min-width: 1025px) {
  .section-contact .contact-container .contact-form {
    padding: 0 78px;
  }
}

@media screen and (min-width: 1300px) {
  .section-contact .contact-container .contact-form {
    padding: 0 140px;
  }
}

.section-contact .contact-container .contact-form .contact-form-list {
  margin-bottom: 16px;
}

.section-contact .contact-container .contact-form .contact-form-list li {
  position: relative;
  padding-bottom: 20px;
}

@media screen and (min-width: 1025px) {
  .section-contact .contact-container .contact-form .contact-form-list li {
    display: flex;
    align-items: center;
  }
}

.section-contact .contact-container .contact-form .contact-form-list li .contact-item-heading {
  display: block;
  padding-bottom: 10px;
  font-weight: 600;
  cursor: pointer;
}

@media screen and (min-width: 1025px) {
  .section-contact .contact-container .contact-form .contact-form-list li .contact-item-heading {
    display: inline-block;
    padding-bottom: 0;
    flex-basis: 1;
    width: 170px;
  }
}

.section-contact .contact-container .contact-form .contact-form-list li .contact-item-heading span {
  color: #FF0000;
  font-size: 10px;
}

.section-contact .contact-container .contact-form .contact-form-list li .contact-type-heading {
  display: block;
  padding-top: 20px;
}

@media screen and (min-width: 1025px) {
  .section-contact .contact-container .contact-form .contact-form-list li .contact-type-heading {
    display: inline-block;
  }
}

@media screen and (min-width: 1025px) {
  .section-contact .contact-container .contact-form .contact-form-list li .add-error-message-name {
    width: 100%;
  }
  .section-contact .contact-container .contact-form .contact-form-list li .add-error-message-name .text-input {
    width: calc(100% - 23px);
  }
}

.section-contact .contact-container .contact-form .contact-form-list li .text-input {
  position: relative;
  display: inline-block;
  padding: 10px;
  width: calc(100% - 23px);
  border: 1px solid #E7E7E7;
}

.section-contact .contact-container .contact-form .contact-form-list li .error-message {
  display: block;
  margin-top: 5px;
  color: #FF0000;
}

.section-contact .contact-container .contact-form .contact-form-list li .contact-radio-item {
  width: 100%;
}

.section-contact .contact-container .contact-form .contact-form-list li .contact-radio-item li {
  display: inline-block;
  position: relative;
  padding: 20px 0 0;
  border: none;
}

.section-contact .contact-container .contact-form .contact-form-list li .contact-radio-item li .contact-type-radio-input {
  display: none;
}

.section-contact .contact-container .contact-form .contact-form-list li .contact-radio-item li .contact-type-radio-input + .contact-type-heading {
  position: relative;
  padding: 6px 30px 0 38px;
  font-size: 14px;
  font-weight: 300;
  cursor: pointer;
}

.section-contact .contact-container .contact-form .contact-form-list li .contact-radio-item li .contact-type-radio-input + .contact-type-heading::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 28px;
  height: 28px;
  background-color: #F5F5F5;
  border-radius: 50%;
  cursor: pointer;
  content: "";
}

.section-contact .contact-container .contact-form .contact-form-list li .contact-radio-item li .contact-type-radio-input:checked ~ .contact-type-heading::after {
  position: absolute;
  top: 8px;
  left: 8px;
  width: 12px;
  height: 12px;
  background-color: #20C3EB;
  border-radius: 50%;
  content: "";
}

.section-contact .contact-container .contact-form .contact-form-list li .contact-main-message {
  display: inline-block;
  padding: 10px;
  width: calc(100% - 35px);
  height: 200px;
  border: 1px solid #E7E7E7;
}

@media screen and (min-width: 769px) {
  .section-contact .contact-container .contact-form .contact-form-list li .contact-main-message {
    width: calc(100% - 35px);
  }
}

.section-contact .contact-container .contact-form .contact-form-list li + li {
  padding-top: 20px;
  border-top: 1px solid #E7E7E7;
}

.section-contact .contact-container .contact-form .concent-checkbox {
  display: none;
}

.section-contact .contact-container .contact-form .concent-checkbox:checked + .concent-text::after {
  opacity: 1;
}

.section-contact .contact-container .contact-form .concent-text {
  display: block;
  padding-left: 36px;
  position: relative;
  font-size: 13px;
  font-weight: 300;
  line-height: 22px;
  cursor: pointer;
}

.section-contact .contact-container .contact-form .concent-text::before, .section-contact .contact-container .contact-form .concent-text::after {
  position: absolute;
  content: "";
}

.section-contact .contact-container .contact-form .concent-text::before {
  top: 0;
  left: 0;
  width: 22px;
  height: 22px;
  background-color: #FFFFFF;
  border: 1px solid #707070;
  cursor: pointer;
}

.section-contact .contact-container .contact-form .concent-text::after {
  top: 8px;
  left: 3px;
  width: 6px;
  height: 10.5px;
  border-right: 3px solid #20C3EB;
  border-bottom: 3px solid #20C3EB;
  -webkit-transform: rotate(45deg) translateY(-50%);
  -ms-transform: rotate(45deg) translateY(-50%);
  transform: rotate(45deg) translateY(-50%);
  opacity: 0;
}

.section-contact .contact-container .contact-form .contact-form-submit {
  position: relative;
  width: 100px;
  height: 50px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 16px;
  font-weight: 600;
  text-align: center;
  display: block;
  margin: 46px auto 0;
  background-color: #666666;
  color: #FFFFFF;
}

@media screen and (min-width: 769px) {
  .section-contact .contact-container .contact-form .contact-form-submit {
    width: 140px;
    height: 69px;
    font-size: 20px;
  }
}

.section-contact .contact-container .contact-form .submit-is-disabled {
  background-color: #999999;
  cursor: auto;
}

/*-----------------------------------------
CONTACT確認ページ
------------------------------------------*/
.confirm-sub-text {
  margin-bottom: 66px;
  font-size: 13px;
  font-weight: 300;
  line-height: 28px;
}

.confirm-list li {
  display: block;
}

@media screen and (min-width: 1025px) {
  .confirm-list li {
    display: flex;
    align-items: center;
  }
}

.confirm-list li .confirm-item-heading {
  display: block;
  padding-bottom: 10px;
  font-weight: 600;
}

@media screen and (min-width: 769px) {
  .confirm-list li .confirm-item-heading {
    display: inline-block;
    padding-bottom: 10px;
    width: 170px;
  }
}

@media screen and (min-width: 1025px) {
  .confirm-list li .confirm-item-heading {
    padding-bottom: 0;
  }
}

.confirm-list li .confirm-output {
  display: block;
  width: 100%;
  font-size: 13px;
  font-weight: 300;
  line-height: 20px;
}

@media screen and (min-width: 1025px) {
  .confirm-list li .confirm-output {
    display: inline-block;
  }
}

.confirm-list li + li {
  margin-top: 40px;
}

@media screen and (min-width: 1300px) {
  .confirm-list li + li {
    margin-top: 60px;
  }
}

@media screen and (min-width: 1600px) {
  .confirm-list li + li {
    margin-top: 80px;
  }
}

.confirm-list li:nth-of-type(1) {
  margin: 0;
}

.contact-done-box {
  margin: 0 auto;
  width: 100%;
  padding: 116px 0 130px;
}

.contact-done-heading {
  margin-bottom: 25px;
  font-weight: 600;
  line-height: 40px;
  text-align: center;
}

.contact-done-text {
  font-size: 14px;
  font-weight: 300;
  line-height: 21px;
  text-align: center;
}

.confirm-button {
  display: block;
  margin: 116px auto 50px;
  text-align: center;
}

.confirm-button .contact-back-button,
.confirm-button .contact-confirm-submit {
  display: inline-block;
  position: relative;
  width: 100px;
  height: 50px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 16px;
  font-weight: 600;
  text-align: center;
}

@media screen and (min-width: 769px) {
  .confirm-button .contact-back-button,
  .confirm-button .contact-confirm-submit {
    width: 140px;
    height: 69px;
    font-size: 20px;
  }
}

.confirm-button .contact-back-button {
  background-color: #FFFFFF;
  border: 2px solid #666666;
  color: #666666;
}

.confirm-button .contact-confirm-submit {
  margin-left: 15px;
  background-color: #666666;
  color: #FFFFFF;
}

@media screen and (min-width: 769px) {
  .confirm-button .contact-confirm-submit {
    margin-left: 40px;
  }
}

.contact-page-footer {
  width: 100%;
  position: relative;
  bottom: 0;
}

/*-----------------------------------------
PrivacyPolicy
------------------------------------------*/
#privacy-policy {
  margin-bottom: 100px;
}

#privacy {
  padding-top: 60px;
  margin-top: -60px;
}

@media screen and (min-width: 1025px) {
  #privacy {
    padding-top: 90px;
    margin-top: -90px;
  }
}

.section-privacy-policy {
  position: relative;
  padding: 70px 20px;
}

@media screen and (min-width: 769px) {
  .section-privacy-policy {
    padding: 70px 70px 100px;
  }
}

@media screen and (min-width: 1025px) {
  .section-privacy-policy {
    padding: 70px 100px 100px;
  }
}

@media screen and (min-width: 1300px) {
  .section-privacy-policy {
    padding: 70px 140px 140px;
  }
}

.section-privacy-policy::before {
  position: absolute;
  width: 1px;
  height: calc(100% - 100px);
  content: "";
  background-color: #D6D6D6;
  top: 70px;
  left: 20px;
  height: calc(100% - 140px);
}

@media screen and (min-width: 769px) {
  .section-privacy-policy::before {
    left: 70px;
    height: calc(100% - 130px);
  }
}

@media screen and (min-width: 1025px) {
  .section-privacy-policy::before {
    left: 100px;
    height: calc(100% - 120px);
  }
}

@media screen and (min-width: 1300px) {
  .section-privacy-policy::before {
    left: 140px;
    height: calc(100% - 210px);
  }
}

.section-privacy-policy::after {
  position: absolute;
  width: 1px;
  height: calc(100% - 100px);
  content: "";
  background-color: #000000;
  top: 70px;
  left: 20px;
  height: 70px;
}

@media screen and (min-width: 769px) {
  .section-privacy-policy::after {
    left: 70px;
  }
}

@media screen and (min-width: 1025px) {
  .section-privacy-policy::after {
    left: 100px;
  }
}

@media screen and (min-width: 1300px) {
  .section-privacy-policy::after {
    left: 140px;
  }
}

.section-privacy-policy .privacy-vertical-font {
  position: absolute;
  top: 257px;
  left: 4px;
  text-align: center;
  font-family: "Cera Basic Bold", "ヒラギノ角ゴ Pro", sans-serif;
  font-size: 10px;
  font-weight: 700;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
}

@media screen and (min-width: 769px) {
  .section-privacy-policy .privacy-vertical-font {
    left: 40px;
    font-size: 12px;
  }
}

@media screen and (min-width: 1300px) {
  .section-privacy-policy .privacy-vertical-font {
    top: 257px;
  }
}

.section-privacy-policy .privacy-policy-container {
  padding-left: 20px;
}

@media screen and (min-width: 1025px) {
  .section-privacy-policy .privacy-policy-container {
    padding-left: 50px;
  }
}

@media screen and (min-width: 1300px) {
  .section-privacy-policy .privacy-policy-container {
    padding: 0 50px;
  }
}

.section-privacy-policy .privacy-policy-container .heading-privacy-policy {
  font-family: "Cera Basic Bold", "ヒラギノ角ゴ Pro", sans-serif;
  font-size: 50px;
  margin-bottom: 55px;
}

@media screen and (min-width: 769px) {
  .section-privacy-policy .privacy-policy-container .heading-privacy-policy {
    margin-bottom: 110px;
  }
}

@media screen and (min-width: 769px) {
  .section-privacy-policy .privacy-policy-container .privacy-policy-list,
  .section-privacy-policy .privacy-policy-container .disclaimer-main-text {
    padding-left: 50px;
  }
}

@media screen and (min-width: 1025px) {
  .section-privacy-policy .privacy-policy-container .privacy-policy-list,
  .section-privacy-policy .privacy-policy-container .disclaimer-main-text {
    padding: 0 70px;
  }
}

@media screen and (min-width: 1300px) {
  .section-privacy-policy .privacy-policy-container .privacy-policy-list,
  .section-privacy-policy .privacy-policy-container .disclaimer-main-text {
    padding: 0 105px;
  }
}

@media screen and (min-width: 1600px) {
  .section-privacy-policy .privacy-policy-container .privacy-policy-list,
  .section-privacy-policy .privacy-policy-container .disclaimer-main-text {
    padding: 0 140px;
  }
}

.section-privacy-policy .privacy-policy-container .privacy-policy-list .privacy-policy-list-heading {
  font-weight: 600;
  line-height: 28px;
}

@media screen and (min-width: 1025px) {
  .section-privacy-policy .privacy-policy-container .privacy-policy-list .privacy-policy-list-heading {
    display: inline-block;
    vertical-align: text-top;
    min-width: 230px;
    margin-top: -6px;
  }
}

.section-privacy-policy .privacy-policy-container .privacy-policy-list .privacy-policy-list-heading .privacy-policy-list-down-heading {
  display: none;
}

@media screen and (min-width: 1025px) {
  .section-privacy-policy .privacy-policy-container .privacy-policy-list .privacy-policy-list-heading .privacy-policy-list-down-heading {
    display: block;
  }
}

.section-privacy-policy .privacy-policy-container .privacy-policy-list li {
  display: block;
}

@media screen and (min-width: 1025px) {
  .section-privacy-policy .privacy-policy-container .privacy-policy-list li {
    display: flex;
  }
}

.section-privacy-policy .privacy-policy-container .privacy-policy-list li .disclaimer-text {
  display: inline-block;
  vertical-align: text-top;
  font-size: 13px;
  font-weight: 300;
  line-height: 20px;
}

.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-heading {
  font-size: 14px;
  font-weight: 600;
  padding-bottom: 6px;
  line-height: 20px;
}

.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li {
  display: block;
}

.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li p {
  font-size: 13px;
  font-weight: 300;
  line-height: 20px;
}

.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list01 li,
.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list02 li,
.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list03 li,
.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list04 li,
.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list05 li {
  font-size: 13px;
  font-weight: 300;
  line-height: 20px;
}

.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list01 li .privacy-policy-item-heading,
.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list01 li .privacy-policy-inner-heading,
.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list02 li .privacy-policy-item-heading,
.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list02 li .privacy-policy-inner-heading,
.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list03 li .privacy-policy-item-heading,
.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list03 li .privacy-policy-inner-heading,
.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list04 li .privacy-policy-item-heading,
.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list04 li .privacy-policy-inner-heading,
.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list05 li .privacy-policy-item-heading,
.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list05 li .privacy-policy-inner-heading {
  font-size: 13px;
  font-weight: 300;
  line-height: 20px;
}

.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list01 li .privacy-policy-inner-heading,
.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list02 li .privacy-policy-inner-heading,
.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list03 li .privacy-policy-inner-heading,
.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list04 li .privacy-policy-inner-heading,
.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list05 li .privacy-policy-inner-heading {
  margin: 0;
}

.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list01 li .privacy-policy-inner-item,
.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list02 li .privacy-policy-inner-item,
.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list03 li .privacy-policy-inner-item,
.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list04 li .privacy-policy-inner-item,
.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list05 li .privacy-policy-inner-item {
  margin-bottom: 13px;
}

.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list01 li + li,
.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list02 li + li,
.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list03 li + li,
.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list04 li + li,
.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list05 li + li {
  margin-top: 25px;
}

.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list02 li + li {
  margin-top: 25px;
}

.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list02 li ul li + li {
  margin-top: 0;
}

.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list02 li ul li p {
  padding-left: 1em;
  text-indent: -1em;
}

.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list03 li + li,
.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list04 li + li,
.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list05 li + li {
  margin: 0;
}

.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li .privacy-policy-inner-list05 li {
  padding-left: 1em;
  text-indent: -1em;
}

.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox li + li {
  margin-top: 25px;
}

.section-privacy-policy .privacy-policy-container .privacy-policy-list li .privacy-policy-item-textbox .that-is-all {
  margin-top: 22px;
  font-size: 13px;
}

.section-privacy-policy .privacy-policy-container .privacy-policy-list li + li {
  margin-top: 100px;
}

.section-privacy-policy .privacy-policy-container .disclaimer-main-text p {
  font-size: 13px;
  font-weight: 300;
  line-height: 20px;
}

.section-privacy-policy .privacy-policy-container .disclaimer-main-text p + p {
  margin-top: 25px;
}

.section-privacy-policy .privacy-policy-container .disclaimer-main-text p:nth-of-type(1) {
  text-align: right;
}

.section-privacy-policy .privacy-policy-container .disclaimer-main-text + .privacy-policy-list {
  margin-top: 100px;
}

.br1753{
  display: none;
}

@media screen and (max-width: 1753px) {
  .br1753{
    display: block;
  }
}