@charset "utf-8";

/* The new CSS reset - version 1.11.3 */
*:where(:not(html,iframe,canvas,img,svg,video,audio):not(svg *,symbol *)) {
  all: unset;
  display: revert;
}

*, *::before, *::after {
  box-sizing: border-box;
}

html {
  -moz-text-size-adjust: none;
  -webkit-text-size-adjust: none;
  text-size-adjust: none;
  scroll-padding-top: 90px;
  font-feature-settings: "palt";
}

a, button {
  cursor: revert;
}

ol, ul, menu, summary {
  list-style: none;
}

img {
  max-inline-size: 100%;
  max-block-size: 100%;
}

table {
  border-collapse: collapse;
}

input, textarea {
  -webkit-user-select: auto;
}

textarea {
  white-space: revert;
}

::placeholder {
  color: unset;
}

* {
  margin: 0;
  padding: 0;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
html { 
  font-size: 62.5%;
  scroll-behavior: smooth;
}

:root {
  --color-black: #222;
  --color-blue: #4d91e3;
  --color-bg: #f0f3f6;
  --color-bgfooter: #c7d3df;
  --color-bgpurple: #d3c1fc;
  --color-bgblue: #c1dbfc;
  --color-bgred: #fcc1c1;
  --color-bggreen: #b7efac;
  --color-orange: #fe8921;
  --color-purple: #8c6cd6;
  --color-red: #d76262;
  --color-green: #69d154;
  
  --font-mid: min(1.4vw,18px); 
  --font-toujour: min(1.8vw,22px);
  --font-24: min(2vw,24px);
  --font-26: min(2.1vw,26px);
  --font-28: min(2.2vw,28px);
  --font-30: min(2.4vw,30px);
  --font-34: min(2.7vw,34px);
  --font-36: min(2.9vw,36px);
  --font-42: min(3.4vw,42px);
  --font-ttl: min(3.6vw,45px);
  --font-ttlsub: min(1.6vw,20px);

  --font-mid_sp: 2.6vw; 
  --font-toujour_sp: 3.2vw;
  --font-28_sp: 4.26vw;
  --font-30_sp: 4.6vw;
  --font-34_sp: 5.3vw;
  --font-ttl_sp: 5.3vw;
  --font-ttlsub_sp: 2.6vw;
}



/*
 body
=====================================================================================*/
body {
  font-family: 'Roboto','Noto Sans JP', sans-serif;
  font-style: normal;
  font-weight: 500;
  font-weight: 400;font-weight: 300;
  font-size: var(--font-toujour);
  -webkit-font-smoothing: subpixel-antialiased;
  background: var(--color-bg);
  color: var(--color-black);
}
.wrapper {
  width: 100%;
  margin: 0 auto;
  overflow: hidden;
}
a {
  color: inherit;
  text-decoration: none;
  cursor: pointer;
  -webkit-transition: 0.5s;
  -o-transition: 0.5s;
  transition: 0.5s;
}
img {
	display: block;
	max-width: 100%;
	height: auto;
}
picture{
	display: block;
	max-width: 100%;
	height: auto;
}
small {
  font-size: 100%;
}

@media screen and (min-width: 768px) {
  a[href^="tel:"] {
    pointer-events: none;
  }
}
@media screen and (max-width: 767px) {
  body {
    font-size: var(--font-toujour_sp);
  }
}

/*
 common
=====================================================================================*/
.l_contents {
  width: min(93.7%,1220px);
	margin-inline: auto;
}

/* .el_ttlwrap */
.el_ttlwrap{
  position: relative;
  padding-block: 50px;

  &::before{
    position: absolute;
    display: block;
    top: 0;
    width: 250px;
    height: 3px;
    content: "";
    background: var(--color-blue);
  }

  h2{
    font-size: var(--font-ttl);
    font-weight: 600;
  }
  p{
    padding-top: 10px;
    font-size: var(--font-ttlsub);
    font-weight: 500;
    font-weight: 400;font-weight: 300;
    color: var(--color-blue);
  }
}

/* .el_ttlwrap */
.l_bnrArea{
  background: #fff;
  padding-block: 100px;
  .l_list{
    display: flex;
    gap: 40px;
  }
    li{
      width: calc((100% - 40px) / 2);
      a{
        position: relative;
        display: block;
        height: min(20vw,260px);

        &:hover .el_link{
          color: var(--color-blue);
        }
        .l_img{
          position: absolute;
          top: 0;
          left: 0;
          z-index: 0;
        }
        .l_txt{
          position: absolute;

          left: 0;
          height: min(20vw, 260px);
          z-index: 10;
          padding: 0 10px 30px 30px;
          color: #fff;
          display: flex;
          flex-direction: column;
          justify-content: flex-end;


          h3{
            padding-bottom: 10px;
            font-size: var(--font-34);
            font-weight: 600;font-weight: 400;
            letter-spacing: .075em;
          }

          p{
            width: 17em;
            font-size: var(--font-toujour);
            line-height: 1.6;
          }

        }
        .el_link{
          position: absolute;
          bottom: 15px;
          right: 10px;
          font-size: var(--font-ttlsub);
          font-weight: 600;font-weight: 400;
          letter-spacing: .075em;
          display: flex;
          align-items: center;

          &::after{
            display: block;
            position: relative;
            right: -5px;
            content: "";
            background: url(../images/icon_arrow_bl.png);
            background-size: contain;
            width: min(1.6vw,20px);
            height: min(1.6vw,20px);
          }
        }
      }
    }
}

/* .l_btnBtm */
.l_btnBtm a,.l_btnBtm div{
  position: relative;
  width: min(87.4vw,576px);
  height: 90px;
  margin-inline: auto;
  margin-top: 50px;
  padding-right: 30px;
  font-size: var(--font-26);
  font-weight: 600;font-weight: 400;
  letter-spacing: .075em;
  background: var(--color-blue);
  color: #fff;
  border-radius: 20px;
  display: flex;
  justify-content: center;
  align-items: center;

  &::after{
  display: block;
  position: absolute;
  right: 30px;
  content: "";
  background: url(../images/icon_arrow_wh_r.png);
  background-size: contain;
  width: 45px;
  height: 45px;
  }
}
.l_btnBtm div{
  &:hover{
  cursor: pointer;
  filter: brightness(115%) contrast(90%);
  }
  &::after{
  background: url(../images/icon_modal.png);
  background-size: contain;
  }
}
/* .l_btnS */
.l_btnS a{
  position: relative;
  width: min(30.6vw,230px);
  height: 60px;
  margin-top: 20px;
  padding-right: 30px;
  font-size: var(--font-toujour);
  font-weight: 600;font-weight: 400;
  letter-spacing: .075em;
  background: var(--color-blue);
  color: #fff;
  border-radius: 20px;
  display: flex;
  justify-content: center;
  align-items: center;

  &::after{
  display: block;
  position: absolute;
  right: 20px;
  content: "";
  background: url(../images/icon_arrow_wh_r.png);
  background-size: contain;
  width: 29px;
  height: 29px;
  }
}
/* .l_mapBtn */
.l_mapBtn a{
  position: relative;
  width: min(12.2vw,150px);
  height: 54px;
  padding-left: 30px;
  font-size: var(--font-toujour);
  font-weight: 600;font-weight: 400;
  letter-spacing: .075em;
  background: var(--color-blue);
  color: #fff;
  border-radius: 5px;
  display: flex;
  justify-content: center;
  align-items: center;

  &::before{
  display: block;
  position: absolute;
  left: 1.5em;
  content: "";
  background: url(../images/icon_map.png);
  background-size: contain;
  width: 16px;
  height: 24px;
  }
}



.bg_wh{
  background: #fff;
}
.dp_pc{
  display: block;
}
.dp_sp{
  display: none;
}
a:hover{
  filter: brightness(115%) contrast(90%);
}


@media screen and (max-width: 767px) {
  .l_contents {
    width: 92vw;
  }

  /* .el_ttlwrap */
  .el_ttlwrap{
    padding-block: 5.3vw 8vw;

    &::before{
      width: 33.3vw;
      height: 2px;
    }

    h2{
      font-size: var(--font-ttl_sp);
    }
    p{
      padding-top: 1.3vw;
      font-size: var(--font-ttlsub_sp);
    }
  }

  /* .el_ttlwrap */
  .l_bnrArea{
    padding-block: 13.3vw;
    .l_list{
      flex-direction: column;
      flex-wrap: wrap;
      gap: 5.3vw;
    }
      li{
        width: 100%;
        a{
          height: 40.6vw;
          .l_txt{
            height: 100%;
            padding: 0 0 4vw 4vw;

            h3{
              padding-bottom: 4vw;
              font-size: var(--font-34_sp);
            }

            p{
              width: 19em;
              font-size: var(--font-toujour_sp);
            }

          }
          .el_link{
            bottom: 2.6vw;
            right: 1.3vw;
            font-size: var(--font-toujour_sp);

            &::after{
              right: -2px;
              width: 3.2vw;
              height: 3.2vw;
            }
          }
        }
      }
  }

  /* .l_btnBtm */
  .l_btnBtm a,.l_btnBtm div{
    width: min(87.4vw,576px);
    height:  min(12vw,90px);
    margin-top: 6.6vw;
    padding-right: 2.6vw;
    font-size: 4vw;
    border-radius: 2.6vw;

    &::after{
    right: 4vw;
    width: 6vw;
    height: 6vw;
    }
  }

  /* .l_btnS */
  .l_btnS a{
    width: min(68vw,510px);
    height:  min(12vw,90px);
    margin-inline: auto;
    margin-top: 6.6vw;
    padding-right: 2.6vw;
    font-size: 4vw;
    border-radius: 2.6vw;

    &::after{
    right: 4vw;
    width: 6vw;
    height: 6vw;
    }
  }

  /* .l_mapBtn */
  .l_mapBtn a{
    width: 21.3vw;
    height: 8.5vw;
    padding-left: 2vw;
    font-size: 3.2vw;
    border-radius: .6vw;

    &::before{
    left: 5.3vw;
    width: 2.1vw;
    height: 3.2vw;
    }
  }
  

  .dp_pc{
    display: none;
  }
  .dp_sp{
    display: block;
  }
}

/* anime */
.inview,
.inv,
.fadein,
.fadeinD,
.fadeinL,
.fiL,
.fiR,
.bgRLextendAnime{
  opacity: 0;
}
.inv{
  animation-delay: 0;
  animation-duration: 1.5s;
  animation-timing-function: ease-in-out;
}

.fadein{
  /*animation-delay: 1.2s;*/
  animation-timing-function: ease;
}

/*
 header
=====================================================================================*/
header{
  position: sticky;
  top: 0;
  z-index: 30;
  
	background: #fff;
  height: min(7vw,96px);

  .l_headerContents{
    display: flex;
    align-items: center;
    height: min(7vw,96px);
  }

  .l_header_logo{
    width: min(12.4vw,200px);
    margin-right: auto;
    margin-left: min(1.5vw,30px);
  }
  nav > ul{
    margin-right: min(1.1vw,20px);
    display: flex;
    align-items: center;
    gap: min(1.1vw,30px);
    font-size: min(1.1vw,18px);
    font-weight: 600;font-weight: 400;
    letter-spacing: .01em;
  }

  .menu > li a {
    text-decoration: none;
    transition: color .4s;
    padding-bottom: 15px;
  }
  .menu-line .menu-item.current > a::after{
    scale: 1;
  }
  .menu-line .menu-item > a {
    position: relative;
  }
  .menu-line .menu-item > a::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 3px;
    background-color: var(--color-blue);
    transition: scale .4s;
    scale: 0;
  }
  .menu-line .menu-item > a:hover {
  }
  .menu-line .menu-item > a:hover::after {
    scale: 1;
  }
  .nav_menu{

  }
  .menu-item {
    position: relative;
  }
  .menu-item:hover .drop-menu-list{
    opacity: 1;
    transition: opacity .3s, visibility .4s; 
    visibility: visible;
    text-align: left;
  }
  .drop-menu-list {
    transform: translateX(0);
    margin-top: 15px;
    background-color: rgba(193, 219, 252, 0.98);
    left: 0;
    opacity: 0;
    position: absolute;
    top: 100%;
    transition: opacity .3s, visibility .4s; 
    visibility: hidden;
    width: max-content;
    z-index: 1;
  }
  .drop-menu-list li a{
    display: block;
    padding: 15px 20px;
    border-bottom: 2px solid var(--color-bg);

    span{
      color: #555;
      margin-right: 15px;
    }

  }
  .drop-menu-list li:last-child a{
    border-bottom: none;
  }

  .l_tel{
    background: var(--color-bgblue);
    position: relative;
    padding-left: min(3vw,58px);
    padding-right: min(1vw,20px);
    text-align: center;
    font-weight: 500;
    height: min(7vw,96px);
    display: flex;
    flex-direction: column;
    justify-content: center;

    &::before{
      position: absolute;
      top: 50%;
      left: min(1vw,20px);
      content: "";
      background: url(../images/icon_tel.png);
      background-size: contain;
      width: min(1.6vw,31px);
      height: min(2vw,39px);
      transform: translateY(-50%);
    }

    a{    
      font-size: min(1.6vw,30px);
      font-weight: 600;
    }

    p{
      font-size: min(.8vw,13px);
      letter-spacing: 0em;
      margin-top: -5px;
    }
  }

  .l_inq a{
    background: var(--color-blue);
    position: relative;
    padding-top: .8em;
    padding-left: min(.7vw,15px);
    padding-right: min(.7vw,15px);
    text-align: center;
    height: min(7vw,96px);
    display: flex;
    flex-direction: column;
    justify-content: center;
    color: #fff;
    font-size: min(1.1vw,18px);
    font-weight: 600;font-weight: 400;

    &::before{
      position: absolute;
      top: calc(50% - 1.5em);
      left: 50%;
      content: "";
      background: url(../images/icon_inq.png);
      background-size: contain;
      width: min(1.5vw,30px);
      height: min(1.1vw,22px);
      transform: translateX(-50%);
    }
  }
}

@media screen and (max-width: 1200px) {
  header{
    .l_header_logo{
      width: min(15.4vw,200px);
    }
    nav ul{
      font-size: min(1.3vw,18px);
    }
    .l_tel{
      display: none;
    }
  }
}

@media screen and (max-width: 767px) {
  header{
    width: 100vw;
    height: 12.6vw;

    .l_headerContents{
      height: 12.6vw;
    }

    .l_header_logo{
      width: 27.3vw;
      margin-left: 4vw;
      position: relative;
      z-index: 26;
    }
  .menu-item:hover .drop-menu-list{
    display: none;
    margin-top: 0;
    text-align: left;
    width: 100%;
    height: auto;
    margin-left: 12vw;

    & li {
      &::after {
        background: none;
      }
    }
    
    }
    .menu-line .menu-item > a::after {
      bottom: 0;
    }
    .l_tel{
      display: flex;
      background: none;
      padding-left: 6vw;
      padding-right: 3.7vw;
      height: 12.6vw;

      &::before{
        position: absolute;
        top: 50%;
        left: min(1vw,20px);
        content: "";
        background: url(../images/icon_tel_sp.png);
        background-size: contain;
        width: 4.1vw;
        height: 5.2vw;
      }
      a{    
        font-size: 4vw;
      }
      p{
        font-size: 1.8vw;
        letter-spacing: 0em;
        margin-top: -3px;
      }
    }

  .l_inq a{
    display: none;
    }
  }
}

/* nav sp */
@media (min-width: 768px) {
	.navbtn {
		display: none;
	}
}
@media (max-width: 767px) {
  .navbtn {
    padding: 0;
    outline: none;
    border: none;
    background: transparent;
    cursor: pointer;
    color: var(--color-blue);
    font-size: 4.9vw;
    background: var(--color-bgblue);
    width: 11.6vw;
    height: 12.6vw;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .open .navbtn {
    z-index: 100;
    background: none;
    width: 11.6vw;
  }
  .navbtn .fa-bars {
    display: revert;
  }
  .open .navbtn .fa-bars {
    display: none;
  }
  .navbtn .fa-times {
    display: none;
  }
  .open .navbtn .fa-times {
    display: revert;
  }

	.nav_menu {
		position: fixed;
		inset: 0 -100% 0 100%;
		z-index: 25;
		background-color: rgba(240, 243, 246, 0.98);
    background-color: rgba(255, 255, 255, 0.98);
		transition: transform 0.4s;
    height: 100%;
    z-index: 2;
	}
	.open .nav_menu {
		transform: translate(-100%, 0);
	}
	.open body {
		position: fixed;
		overflow: hidden;
    z-index: 2;
	}
	.nav_menu ul {
		display: flex;
		flex-direction: column;
		align-items: flex-start;
		align-items: flex-start;
		height: 100%;
		color: var(--color-black);
    font-size: min(3.7vw,20px);
    overflow-y: scroll;
    margin-top: 12.5vw;
    padding-bottom: 30vw;

    li{
      display: block;
      width: 100%;

      &::after{
        position: absolute;
        top: 50%;
        right: 20px;
        content: "";
        background: url(../images/icon_arrow_bl.png);
        background-size: contain;
        width: 2.6vw;
        height: 2.6vw;
        transform: translateY(-50%);
       }
      

      &:first-child{
      border-top: 1px solid var(--color-bgfooter);
      
      }

      a{
      border-bottom: 1px solid var(--color-bgfooter);
      width: 100%;
      padding: 4vw;
      display: block;
      position: relative;

      
      }
    }
	}
}



.l_pankuzu{
  margin-left: min(1.5vw,30px);
  padding-block: 5px 8px;
  font-size: var(--font-mid);
  font-weight: 400;font-weight: 300;
  overflow-x: scroll;
  word-break: keep-all;
  white-space: nowrap;

  ul{
    display: flex;
    align-items: center;
    a{
      position: relative;
      margin-right: 20px;

      &:hover{
        color: var(--color-blue);
        &::after{
          color: var(--color-black);
        }

      }
      &::after{
        position: absolute;
        content: ">";
        right: -15px;
        top: 50%;
        transform: translateY(-50%);
        color: var(--color-black);
      }
    }
  }
}

@media screen and (max-width: 767px) {
  .l_pankuzu{
    margin-left: 4vw;
    padding-block: 0.6vw 1vw;
    font-size: var(--font-mid_sp);


    &::-webkit-scrollbar {
      display: none;
    }
  }
}

/*
 l_floatBnr
=====================================================================================*/
.l_floatBnr {
  position: fixed;
  top: 200px;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  height: min(49vw,560px);
  border-radius: 30px 0 0 30px;
  z-index: 20;
  background: var(--color-orange);
  font-size: var(--font-24);
  color: #fff;
  writing-mode: vertical-rl;
  transition: transform .3s ease;

  &::before{
    position: absolute;
    top: 2em;
    left: calc(50% + 2px);
    content: "";
    background: url(../images/icon_inq.png);
    background-size: contain;
    width: min(1.5vw,30px);
    height: min(1.1vw,22px);
    transform: translateX(-50%);
  }

  &:hover{
    filter: brightness(115%) contrast(90%);
   }

  a{
    display: block;
    height: 100%;
    margin: 0;
    padding-block: 35px;
    padding-block: 32px;
    padding-top: 1.5em;
    line-height: 1;
    display: flex;
    justify-content: center;
  }
  span{
    transform: translateX(.25em);
  }
}

@media screen and (max-width: 767px) {
  .l_floatBnr {
    top: inherit;
    right: inherit;
    left: 50%;
    bottom: 0;
    transform: translateX(-50%);
    width: 100%;
    height: inherit;
    border-radius: 0;
    font-size: 4.2vw;
    writing-mode: horizontal-tb;

    &::before{
      position: absolute;
      top: 50%;
      left: 4vw;
      content: "";
      background: url(../images/icon_inq.png) no-repeat;
      background-size: contain;
      width: 6.6vw;
      height: 5vw;
      transform: translateX(0) translateY(-50%);
    }

    &:hover{
      filter: brightness(115%) contrast(90%);
    }

    a{
      margin: 0;
      padding-block: 6vw;
      padding-left: 4vw;
    }
    span{
      transform: translateX(0);
    }
  }
}

/*
 l_hero
=====================================================================================*/
.l_hero{
  height: min(40vw,740px);
  position: relative;

  .l_txt{
    position: absolute;
    bottom: 0;
    left: 0;
    background: rgba(255,255,255,.75);
    border-radius: 0 50px 0 0;
    opacity: 1;
    z-index: 10;
    padding: min(2.6vw,50px) min(1.5vw,30px) min(1.5vw,30px) min(4.2vw,80px);
  }
  h1 {
    font-size: min(3.75vw,72px);
    font-size: min(3.3vw,50px);
    font-weight: 600;
    line-height: 1.38;

    .tel_txtblue{
      color: var(--color-blue);
      font-size: min(2.5vw,48px);
      font-size: min(2.5vw,38px);
      font-weight: 500;
      padding-bottom: 0px;
    }
  }
}
.top_mainswiper{
  position: relative;
  width: 100%;
  height: min(40vw,740px);
  overflow: hidden;
  margin: 0 auto;
}

.slider{
  position: relative;
  width: 100%;
  height: min(40vw,740px);
  overflow: hidden;
  margin: 0 auto;
}
.slider div {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-position: center center;
	background-size: cover;
	background-repeat: no-repeat;
	z-index: 10;
	opacity: 0;
	animation-name: slide-fade;
	animation-duration: 30s; /* 30秒に変更 */
	animation-iteration-count: infinite;
	transform: scale(1.05); /* 最初に画像を大きくしておく */
}

@keyframes slide-fade {
	0%{
		opacity: 0;
	}
	20%{
		opacity: 1;
	}
	80%{
		opacity: 0;
		transform: scale(1); /* ここで画像サイズを1に戻す */
	}
	100%{
		opacity: 0;
		z-index: 0;
	}
}
.slider div:first-of-type{
	background-image: url(../../images/hero01.png);
  animation-delay: -2s;
}
.slider div:nth-of-type(2){
	background-image: url(../../images/hero03.png);
	animation-delay: 11s; /* 秒数を変更 */
}
.slider div:last-of-type{
	background-image: url(../../images/hero02.png);
	animation-delay: 22s; /* 秒数を変更 */
}



@media screen and (max-width: 767px) {
.l_hero{
  height: 107.6vw;

  .l_txt{
    position: absolute;
    bottom: 0;
    left: 0;
    background: none;
    border-radius: 0;
    
    padding: 0;
  }
  h1 {
    margin-bottom: 8.6vw;
    font-size: 7.3vw;
    font-weight: 700;

    .tel_txtblue{
      font-size: 4.8vw;
      margin-bottom: 3.7vw;
      padding: 1.7vw 2.6vw 1.7vw 4vw;
    }
    span{
      display: inline-block;
      line-height: 1;
      background: rgba(255,255,255,.88);
      padding: 1.7vw 2.6vw 1.7vw 4vw;
    }
  }
}

  .top_mainswipersp{
    position: relative;
    width: 100%;
    height: 107.6vw;
    overflow: hidden;
    margin: 0 auto;
  }
  .slider{
    height: 107.6vw;
  }

  .slider div:first-of-type{
    background-image: url(../../images/hero01_sp.png);
  }
  .slider div:nth-of-type(2){
    background-image: url(../../images/hero03_sp.png);
  }
  .slider div:last-of-type{
    background-image: url(../../images/hero02_sp.png);
  }
}

/*
 l_topAbout
=====================================================================================*/
.l_topAbout{
  background: #e9f3fe;
  background: linear-gradient(90deg,#ebf4ff 0%, #c1dbfc 100%);
  .l_contents{
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 80px;
  }
  p{
    font-size: min(2vw,40px);
    font-weight: 600;
    letter-spacing: .075em;

    span{
      color: var(--color-blue);
      font-weight: 500;

      display: block;
      padding-bottom: 0px;
    }
  }
  figure{
    width: min(11.8vw,228px);
    padding-top: 3px;
  }
}

@media screen and (max-width: 767px) {
  .l_topAbout{
    background: #c1dbfc;
    height: 33vw;
    position: relative;
    .l_contents{
      justify-content: inherit;
      height: 33vw;
      gap: 0;
      
    }
    p{
      font-size: 4.26vw;
      padding-left: 0;
    }
    figure{
      width: 29.8vw;
      padding-top: 0;
      position: absolute;
      top: -4vw;
      right: 0;
      z-index: 10;
    }
  }
}

/*
 l_topAdvantage
=====================================================================================*/
.l_topAdvantage{
  padding-bottom: 100px;
  .l_list{
    display: flex;
    justify-content: center;
    gap: 20px;
    
    li{
      width: calc((100% - 20px * 3) / 4);
      h3{
        padding-block: 40px 30px;
        font-size: var(--font-28);
        font-weight: 600;font-weight: 400;
        text-align: center;
      }
      p{
        line-height: 1.6;
      }

    }
  }
}

@media screen and (max-width: 767px) {
.l_topAdvantage{
  padding-bottom: 13.3vw;
  .l_list{
    gap: 6.6vw 6.6vw;
    flex-wrap: wrap;
    
    li{
      width: calc((100% - 9.3vw) / 2);
      figure{
       width: 38.5vw; 
       margin-inline: auto;
      }
      h3{
        padding-block: 4vw;
        font-size: var(--font-28_sp);
      }
    }
  }
}
}


/*
 l_topProduct
=====================================================================================*/
.l_topProduct{
  padding-bottom: 100px;
  .l_list{
    display: flex;
    flex-wrap: wrap;
    gap: 40px 40px;
    
    li{
      width: calc((100% - 40px) / 2);
      border-radius: 15px;
      background: #fff;

      a{
        display: block;
        &:hover .l_img{
          transform: scale(1.05);
        }
        .l_imgArea{
          position: relative;
          height: min(14.7vw,180px);
          height: 100%;
          overflow: hidden;
          border-radius: 15px 15px 0 0;
          .l_img{
            transition: transform .3s ease;
          }
        }
        h3{
          position: absolute;
          top: 50%;
          left: 40px;
          transform: translateY(-50%);
          padding: 0 10px;
          font-size: var(--font-30);
          font-weight: 600;font-weight: 400;
          letter-spacing: .075em;
          background: #fff;
        }
        p{
          position: relative;
          line-height: 1.6;
          padding: 30px 75px 30px 40px;
          &::after{
            position: absolute;
            top: 50%;
            right: 20px;
            content: "";
            background: url(../images/icon_arrow_bl_r.png);
            background-size: contain;
            width: min(2.7vw,34px);
            height: min(2.7vw,34px);
            transform: translateY(-50%);
          }

        }
      }
    }
  }
}

@media screen and (max-width: 767px) {
  .l_topProduct{
    padding-bottom: 13.3vw;
    .l_list{
      flex-direction: column;
      gap: 5.3vw;
      
      li{
        width: 100%;
        border-radius: 2vw;

        a{
          display: block;

          .l_imgArea{
            height: 28vw;
            border-radius: 2vw 2vw 0 0;
          }
          h3{
            left: 5.3vw;
            padding: 0 1.3vw;
            font-size: var(--font-30_sp);
          }
          p{
            padding: 4vw 12vw 5.3vw 5.3vw;
            &::after{
              right: 3vw;
              width: 6.6vw;
              height: 6.6vw;
            }
          }
        }
      }
    }
  }
}

/*
 l_topInstallation
=====================================================================================*/
.l_topInstallation{
  padding-bottom: 100px;
  .l_list{
     /*display: flex;*/
    
    li{
      /*width: calc((100% - 40px * 2) / 3) !important;*/
      border-radius: 15px;
      background: #fff;
      
      a{
        display: block;
        color: var(--color-black);
        
      
        &:hover .l_img img{
          transform: scale(1.05);
          transition: transform .3s ease;
        }
        .l_img{
          position: relative;
          height: min(18.8vw,230px);
          overflow: hidden;
          border-radius: 15px 15px 0 0;
          height: auto;

          img{
            transition: transform .3s ease;
            width: 100%;
          }
        }
        .el_category{
          padding-block: 7px;
          font-size: var(--font-ttlsub);
          font-weight: 600;font-weight: 400;
          text-align: center;
          &.el_dansa{
            background: var(--color-bgpurple);
          }
          &.el_kaidan{
            background: var(--color-bgblue);
          }
          &.el_chair{
            background: var(--color-bgred);
          }
        }
        h3{
          padding-bottom: 20px;
          font-size: var(--font-toujour);
          font-weight: 600;font-weight: 400;
        }
        .l_txt{
          padding: 20px 30px 30px;
          font-size: var(--font-ttlsub);

        }
      }
    }
  }
}

@media screen and (max-width: 767px) {
  .l_topInstallation{
    padding-bottom: 13.3vw;
    .swiper{
        margin-inline: -4vw;
        padding-left: 4vw;
        width: 100vw;
      }
    .l_list{
      /*display: flex;*/
      
      li{
        /*width: calc((100% - 40px * 2) / 3) !important;*/
        border-radius: 2vw;
        
        a{
          .l_img{
            border-radius: 2vw 2vw 0 0;
          }
          .el_category{
            padding-block: 1.3vw;
            font-size: 3vw;
          }
          h3{
            padding-bottom: 2.6vw;
            font-size: 3.7vw;
          }
          .l_txt{
            padding: 2.6vw 4vw 5.3vw;
            font-size: var(--font-toujour_sp);
          }
        }
      }
    }
  }
}

/*
 l_topFlow
=====================================================================================*/
.l_scroll{
  display: block;
  overflow-x: auto;
  width: 100vw;
}
.l_topFlow{
  padding-bottom: 100px;
  .l_list{
    display: flex;
    gap: 28px;
    width: auto;

    li{
     /*width: calc((100% - 28px * 5) / 6);*/
      width: min(18vw,180px);
      padding-top: 30px;
      position: relative;
      display: flex;
      justify-content: center;

      &:not(:last-child)::after{
        position: absolute;
        top: 50%;
        right: -30px;
        content: "";
        background: url(../images/icon_flow_arrow.png);
        background-size: contain;
        width: 14px;
        height: 16px;
        transform: translateX(-50%);
      }

      div{
        display: flex;
        flex-direction: column;
        align-items: center;
        width: min(18vw,180px);
        padding: 0 10px 20px;
        padding-top: min(6.1vw,75px);
        background: var(--color-bgblue);
        border-radius: 20px;

        span{
          display: block;
          font-size: min(3.9vw,48px);
          font-weight: 600;font-weight: 400;
          letter-spacing: .075em;
          color: var(--color-blue);
        }

        p{
          display: flex;
          align-items: center;
          height: 2.5em;
          font-weight: 600;font-weight: 400;
          text-align: center;
          letter-spacing: .075em;
          
        }
      }
      .l_img{
        position: absolute;
        top: 0px;
        width: min(8.8vw,108px);
      }
    }
  }
}

@media screen and (max-width: 767px) {
  .l_topFlow{
    padding-bottom: 13.3vw;
    .l_list{
      gap: 3.7vw;

      li{
      /*width: calc((100% - 28px * 5) / 6);*/
        width: 24vw;
        padding-top: 3.46vw;

        &:not(:last-child)::after{
          right: -4vw;
          width: 1.8vw;
          height: 2.1vw;
        }

        div{
          width: 24vw;
          padding: 0 1.3vw 2.6vw;
          padding-top: 10vw;
          background: var(--color-bgblue);
          border-radius: 2.6vw;

          span{
            font-size: 6.4vw;
          }

          p{
            height: 2.5em;
          }
        }
        .l_img{
          width: 14.4vw;
        }
      }
    }
  }
}

/*
 l_topFacilities
=====================================================================================*/
.l_topFacilities{
  background: #fff;
  padding-bottom: 100px;
}

@media screen and (max-width: 767px) {
  .l_topFacilities{
    padding-bottom: 13.3vw;
  }
}
/* animation scroll*/
@keyframes infinity-scroll-left {
  from {
    transform: translateX(0);
  }
    to {
    transform: translateX(-100%);
  }
}
.scroll-infinity__wrap {
  display: flex;
  /*overflow: hidden;*/
  height: 258px;
}
.scroll-infinity__list {
  display: flex;
  list-style: none;
  padding: 0;
  width: auto;
}
.scroll-infinity__list--left {
  animation: infinity-scroll-left 160s infinite linear 0.5s both;
}
.scroll-infinity__item {
  width:5768px;
  margin-left: -200px;
}
.scroll-infinity__item > img {
  width: 100%;
}

@media screen and (max-width: 767px) {
  .scroll-infinity__wrap {
    height: 34.4vw;
  }
  .scroll-infinity__item {
    width:769vw;
    margin-left: -26vw;
  }
}

/*
 l_footerFaq
=====================================================================================*/
.l_footerFaq{
  padding-bottom: 100px;

  .l_list{
    display: flex;
  }
  dt{
    position: relative;
    padding: 5px 0 15px 40px;
    font-size: var(--font-26);
    font-weight: 600;font-weight: 400;
    line-height: 1.35;
    border-bottom: 5px solid currentColor;
    &::before{
      position: absolute;
      top: 0;
      left: 0;
      content: "Q";
     font-size: var(--font-34);
    }
  }
  dd{
    padding-top: 15px;
    font-size: var(--font-toujour);
    font-weight: 600;font-weight: 400;
    line-height: 1.6;
  }
/*.swiper-button-prev,.swiper-button-next{
  display: none;
}*/

}

@media screen and (max-width: 767px) {
  .l_footerFaq{
    padding-bottom: 13.3vw;

    .swiper{
      margin-inline: -3vw;
    }
    .swiper-slide{
      padding-inline: 8.4vw;
    }
    dt{
      padding: .6vw 0 2vw 5.3vw;
      font-size: 4vw;
      border-bottom: .6vw solid currentColor;
      &::before{
      font-size: 4.8vw;
      }
    }
    dd{
      padding-top: 2vw;
      font-size: var(--font-toujour_sp);
    }
  }
}

/*
 l_newsList
=====================================================================================*/
.l_newsList{
  background: #fff;
  padding-bottom: 100px;

  .l_list{
    border-top: 1px solid var(--color-bg);
    a{
      cursor: pointer;
      
      &:hover dd{
        color: #4d91e3;
        
      } 
    }
    dl{
      position: relative;
      display: flex;
      align-items: center;
      gap: 60px;
      padding: 30px 30px 30px 0;
      border-bottom: 1px solid var(--color-bg);
      
      
      &::after{
        display: block;
        position: relative;
        right: -5px;
        content: "";
        background: url(../images/icon_arrow_bl.png);
        background-size: contain;
        width: min(1.6vw,20px);
        height: min(1.6vw,20px);
      }

    }
    dt{
      display: flex;
      align-items: center;
      gap: 40px;
      
      .el_date{
        font-size: var(--font-ttlsub);
        color: var(--color-blue);
      }
      .el_category{
        width: 110px;
        text-align: center;
        padding: 3px 15px 5px;
        background: var(--color-blue);
        border-radius: 5px;
        font-size: var(--font-mid);
        color: #fff;
      }
    }
    dd{
      flex: 1;
      transition: transform .3s ease;
    }
    
  }
}

@media screen and (max-width: 767px) {
  .l_newsList{
    padding-bottom: 13.3vw;

    .l_list{

      dl{
        flex-direction: column;
        align-items: flex-start;
        justify-content: center;
        gap: 2.6vw;
        padding: 4vw 0;
        
        &::after{
          position: absolute;
          right: 2vw;
          width: 2.6vw;
          height: 2.6vw;
        }

      }
      dt{
        gap: 4vw;
        
        .el_date{
          font-size: 2.9vw;
        }
        .el_category{
          width: inherit;
          padding: 3px 2.6vw 5px;
          border-radius: .6vw;
          font-size: 2.6vw;
        }
      }
      dd{
        flex: 1;
        padding-right: 6.6vw;
        font-size: var(--font-toujour_sp);
      }
    }
  }
}

/*
 l_footerInq
=====================================================================================*/
.l_footerInq{
  background: url(../images/bg_footerinq.png);
  background-size: cover;
  padding-block: 100px;

  .l_contents{
    padding: 60px 40px 50px;
    background: rgba(255,255,255,0.95);
    border-radius: 30px;
  }
  .l_footerInqUpper{
    margin-bottom: 50px;
    text-align: center;
    .el_inqttl{
      position: relative;
      margin-bottom: 40px;
      padding-bottom: 30px;
      font-size: var(--font-42);
      font-weight: 600;

      &::after{
        position: absolute;
        bottom: 0;
        left: 50%;
        content: "";
        width: 250px;
        height: 5px;
        background: var(--color-blue);
        transform: translateX(-50%);
      }      
    }
    .l_lead{
      margin-bottom: 50px;
      font-size: var(--font-26);
      font-weight: 600;font-weight: 400;
      line-height: 1.46;
      letter-spacing: .075em;
    }
    .l_telArea{
      margin-bottom: 50px;
    }
    .l_telNumber{
      color: var(--color-blue);
      letter-spacing: .025em;
      p{
        font-size: var(--font-28);
        font-weight: 600;
      }
      a{
        font-size: min(6.9vw,85px);
        font-weight: 900; 
      }
    }
    .l_telTime{
      font-size: var(--font-26);
    }
    .l_btnBtm{
       width: min(100%,576px);
       margin-inline: auto;
    }

  }
  .l_footerInqBtm{
    h3{
      margin-inline: -40px;
      margin-bottom: 40px;
      padding-block: 10px;
      background: var(--color-bgblue);
      font-size: var(--font-28);
      font-weight: 600;font-weight: 400; 
      text-align: center;
    }
    .l_salesOffice{
      display: flex;
      flex-wrap: wrap;
      justify-content: center;
      gap: 40px 30px;

      dl{
        
        
      }
      dt{
        position: relative;
        padding-bottom: 10px;
        font-size: var(--font-toujour);
        font-weight: 600;font-weight: 400;
        &::after{
          position: absolute;
          bottom: 0;
          left: 50%;
          content: "";
          width: 100%;
          height: 3px;
          background: var(--color-blue);
          transform: translateX(-50%);
        }
      }
      dd{
        margin-top: 5px;
        display: flex;
        justify-content: space-between;
        align-items: flex-end;
        gap: 20px;
        font-size: min(3.2vw,40px);
        font-weight: 600;font-weight: 400;
        span{
          font-size: var(--font-28);
          color: var(--color-blue);
          padding-bottom: 3px;
        }
      }
    }
  }
}

@media screen and (max-width: 767px) {
  .l_footerInq{
    background: url(../images/bg_footerinq.png);
    background-size: cover;
    padding-block: 12vw;

    .l_contents{
      padding: 6.6vw 5.3vw;
      border-radius: 4vw;
    }
    .l_footerInqUpper{
      margin-bottom: 6.6vw;
      .el_inqttl{
        margin-bottom: 4vw;
        padding-bottom: 4vw;
        font-size: 5.3vw;

        &::after{
          width: 33.3vw;
          height: .6vw;
        }      
      }
      .l_lead{
        margin-bottom: 6.6vw;
        font-size: 3.46vw;
        line-height: 1.5;
      }
      .l_telArea{
        margin-bottom: 6.6vw;
      }
      .l_telNumber{
        p{
          font-size: 3.46vw;
        }
        a{
          font-size: 10.5vw;
        }
      }
      .l_telTime{
        font-size: 3.7vw;
      }
      .l_btnBtm{
        width: 74.1vw;
        a{
          width: 100%;
          padding-right: 6vw;
          font-size: 3.7vw;
        }
        div{
          width: 100%;
          padding-right: 6vw;
          font-size: 3.7vw;
        }
      }
    }
    .l_footerInqBtm{
      h3{
        margin-inline: -5.3vw;
        margin-bottom: 5.3vw;;
        padding-block: 1.3vw;
        font-size: 3.7vw;
      }
      .l_salesOffice{
        gap: 3.3vw 4vw;

        dl{

        }
        dt{
          padding-bottom: 1.3vw;
          font-size: var(--font-toujour_sp);
          &::after{
            height: .3vw;
            background: var(--color-blue);
            transform: translateX(-50%);
          }
        }
        dd{
          margin-top: .6vw;
          gap: 2.6vw;
          font-size: 4.5vw;
          span{
            font-size: 2.9vw;
          }
        }
      }
    }
  }
}

/*
 l_footer
=====================================================================================*/
.l_footer{
  background: var(--color-bgfooter);

  .l_contents{
    padding-block: 70px;
    display: flex;
    flex-direction: row-reverse;
    justify-content: space-between;
  }

  .l_footerLogo{
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: flex-end;

    h2{
      width: min(15.7vw,192px);
      width: min(12.2vw,150px);
      margin-left: auto;
    }
    .l_footerInner{
      display: flex;
      flex-direction: row-reverse;
      gap: 30px;
    }
    .l_footerImg{
      width: min(10.2vw,130px);
    }
    .l_footerSns{
      height: 40px;
      display: flex;
      gap: 30px;

      li a:hover {
        filter: opacity(70%);
      }
    }
  }
  .l_footerLink{
    display: flex;
    gap: 80px;
    font-size: var(--font-toujour);
    line-height: 2;
    a:hover{
      color: var(--color-blue);
    }
  }

  .l_copy{
    padding-block: 40px;
    background-color: #000;
    font-size: 12px;
    font-weight: 500;
    font-weight: 400;font-weight: 300;
    color: #fff;
    text-align: center;
  }
}

@media screen and (max-width: 767px) {
  .l_footer{
    .l_contents{
      padding-block: 5.3vw;
      flex-direction: column-reverse;
      gap: 13.3vw;  
    }

    .l_footerLogo{
      flex-direction: row;
      align-items: flex-end;
      justify-content: space-between;

      h2{
        width: 25.6vw;
        margin-left: inherit;
      }
      .l_footerInner{
        flex-direction: row;
        align-items: flex-end;
        gap: 5vw;
      }
      .l_footerImg{
        width: min(16.2vw,130px);
      }
      .l_footerSns{
        height: 6.6vw;
        gap: 4vw;

        img{
          height: 6.6vw;
        }
      }
    }
    .l_footerLink{
      gap: 0;
      font-size: 3.7vw;

      & > *{
        width: 50%;
      }
    }

    .l_copy{
      padding-block: 6.6vw;
      font-size: 2.1vw;
    }
  }
}

/*
 swiper
=====================================================================================*/
.swiper_some {
  width: 100%;
  position: relative;
  display: block;
}
.swiper-button-prev,
.swiper-button-next {
  width: 45px;
  height: 45px;
  background-size: contain; /* 表示したいサイズ */
  transform: translateY(-50%);
  margin-top: 0;
}
.swiper-button-prev:after,
.swiper-button-next:after {
 display: none;
}

.swiper-button-next{
  background: url(../images/icon_arrow_wh_r.png) no-repeat;
  background-size: contain;
}
.swiper-button-prev{
  background: url(../images/icon_arrow_wh_l.png) no-repeat;
  background-size: contain;
  left: 5px !important;
}
.swiper{
  img{
    width: 100%;
  }
}

@media screen and (max-width: 767px) {
  .swiper-button-prev,
  .swiper-button-next {
    width: 6vw !important;
    height: 6vw !important;
  }
}

/*
 第二階層
=====================================================================================*/
.l_secondContents{

}
/*
 main
=====================================================================================*/
.l_main{
  height: min(37.7vw,460px);
  height: min(30vw,400px);

  .l_contents{
    width: 100%;
    height: min(37.7vw,460px);
    height: min(30vw,400px);
    display: flex;
    align-items: center;
  }
  .l_mainTtl{
    position: relative;
    padding: 15px 0 10px 30px;
    font-size: min(3.9vw,45px);
    font-weight: 600;
    color: #fff;
    z-index: 1;
    display: flex;
    align-items: center;
    line-height: 1.5;
  
    &::before{
      background: rgba(38, 119, 217,.8);
      content: "";
      position: absolute;
      width: calc(100% + 20em);
      height: calc(100% + 10px);
      margin-left: -20em;
      z-index: -1;
    }
  }
}

.l_product .l_main{
  background: url(../../product/images/main_pc.png) ;
  background-position: center;
  background-size: cover;
}
.l_maintenance .l_main{
  background: url(../../maintenance/images/main_pc.png) ;
  background-position: center;
  background-size: cover;
}
.l_lease .l_main{
  background: url(../../lease/images/main_pc.png) ;
  background-position: center;
  background-size: cover;
}
.l_casestudy .l_main{
  background: url(../../casestudy/images/main_pc.png) ;
  background-position: center;
  background-size: cover;
}
.l_partner .l_main{
  background: url(../../partner/images/main_pc.png) ;
  background-position: center;
  background-size: cover;
}
.l_news .l_main{
  background: url(../../news/images/main_pc.png) ;
  background-position: center;
  background-size: cover;
}
.l_privacy .l_main{
  background: url(../../privacy/images/main_pc.png) ;
  background-position: center;
  background-size: cover;
}
.l_company .l_main{
  background: url(../../company/images/main_pc.png) ;
  background-position: center;
  background-size: cover;
}
.l_faq .l_main{
  background: url(../../faq/images/main_pc.png) ;
  background-position: center;
  background-size: cover;
}
.l_sitemap .l_main{
  background: url(../../sitemap/images/main_pc.png) ;
  background-position: center;
  background-size: cover;
}
.l_contact .l_main{
  background: url(../../contact/images/main_pc.png) ;
  background-position: center;
  background-size: cover;
}
.l_labo .l_main{
  background: url(../../labo/images/main_pc.png) ;
  background-position: center;
  background-size: cover;
}

@media screen and (max-width: 767px) {
  .l_main{
    height: 47.8vw;

    .l_contents{
      height: 47.8vw;
    }
    .l_mainTtl{
      width: auto;
      padding: 10px 0 0px 6.6vw;
      font-size: 6.4vw;

      &::before{
        width: calc(100% + 6.6vw);
        height: calc(100% + 10px);
        margin-left: -7vw;
      }
    }
  }
  .l_product .l_main .l_mainTtl{
   width: 13em;
   &::before{
        width: 100%;
   }
  }

  .l_product .l_main{
    background: url(../../product/images/main_sp.png) ;
    background-position: center;
    background-size: cover;
  }
  .l_maintenance .l_main{
    background: url(../../maintenance/images/main_sp.png) ;
    background-position: center;
    background-size: cover;
  }
  .l_lease .l_main{
    background: url(../../lease/images/main_sp.png) ;
    background-position: center;
    background-size: cover;
  }
  .l_casestudy .l_main{
    background: url(../../casestudy/images/main_sp.png) ;
    background-position: center;
    background-size: cover;
  }
  .l_partner .l_main{
    background: url(../../partner/images/main_sp.png) ;
    background-position: center;
    background-size: cover;
  }
  .l_news .l_main{
    background: url(../../news/images/main_sp.png) ;
    background-position: center;
    background-size: cover;
  }
  .l_privacy .l_main{
    background: url(../../privacy/images/main_sp.png) ;
    background-position: center;
    background-size: cover;
  }
  .l_company .l_main{
    background: url(../../company/images/main_sp.png) ;
    background-position: center;
    background-size: cover;
  }
  .l_faq .l_main{
    background: url(../../faq/images/main_sp.png) ;
    background-position: center;
    background-size: cover;
  }
  .l_sitemap .l_main{
    background: url(../../sitemap/images/main_sp.png) ;
    background-position: center;
    background-size: cover;
  }
  .l_contact .l_main{
    background: url(../../contact/images/main_sp.png) ;
    background-position: center;
    background-size: cover;
  }
  .l_labo .l_main{
    background: url(../../labo/images/main_sp.png) ;
    background-position: center;
    background-size: cover;
  }
}



/*
 第二階層 common
=====================================================================================*/
.l_leadArea{
  padding-block: 50px;
  font-size: var(--font-24);
  line-height: 1.58;
  letter-spacing: .075em;
  background: #fff;

  p:not(:nth-of-type(1)){
    margin-top: 40px;
  }
  a{
    color: var(--color-blue);
    &:hover{
      text-decoration: underline;
    }
  }
}
.l_h3bgttl{
  margin-bottom: 90px;
  padding-block: 10px 15px;
  font-size: var(--font-34);
  font-weight: 600;font-weight: 400;
  text-align: center;
  letter-spacing: .025em;

  &.el_bgblue{
    background: var(--color-bgblue);
  }
}
.l_h4barttl{
  position: relative;
  display: block;
  margin-bottom: 50px;
  padding-bottom: 20px;
  font-size: var(--font-36);
  font-weight: 600;font-weight: 400;
  text-align: center;
  letter-spacing: .025em;

  &.el_bgblue:after{
      background: var(--color-blue);
  }
  &.el_bgpurple:after{
      background: var(--color-purple);
  }
  &.el_bgred:after{
      background: var(--color-red);
  }
  &.el_bggreen:after{
      background: var(--color-green);
  }
  &:after{
    position: absolute;
    content: "";
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 250px;
    height: 3px;
  }
}
.l_contentsSmall{
  .l_lead{
    text-align: center;
    margin-bottom: 50px;
    letter-spacing: .075em;
    
    p:not(:nth-of-type(1)){
    margin-top: 40px;
    }
  }

}

.l_pageAnchor{
  margin-bottom: 80px;
  ul{
    display: flex;
    justify-content: center;
    gap: 20px;

    li{
      width: calc((100% - 20px * 3) / 4);
      background: #fff;
      box-shadow: 0 0 8px 0 rgba(0, 0, 0, 0.1);
      border-radius: 5px;
      overflow: hidden;


      &:nth-of-type(1) a::before{
        background: var(--color-bgblue);
      }
      &:nth-of-type(2) a::before{
        background: var(--color-bgpurple);
      }
      &:nth-of-type(3) a::before{
        background: var(--color-bgred);
      }
      &:nth-of-type(4) a::before{
        background: var(--color-bggreen);
      }

      a{
        position: relative;
        display: flex;
        height: 150px;
        justify-content: center;
        align-items: center;
        margin-top: -19px;
        padding-bottom: 19px;
        font-size: var(--font-26);
        font-weight: 600;font-weight: 400;
        letter-spacing: .05em;
        text-align: center;

        &::before{
          position: absolute;
          content: "";
          bottom: 0;
          width: 100%;
          height: 39px;

        }
        &::after{
          position: absolute;
          background: url(../images/icon_arrow_wh.png);
          background-size: cover;
          content: "";
          bottom: 13px;
          width: 20px;
          height: 20px;
        }

      }
    }
  }
}

.el_h2bgttlwrap{
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  height: min(20.4vw,250px);
  margin-bottom: 50px;
  margin-right: calc(50% - 50vw);
  margin-left: calc(50% - 50vw);

  h2{
    position: relative;
    padding-block: 20px;
    font-size: var(--font-36);
    font-weight: 600;
    letter-spacing: .1em;

    &::before{
    position: absolute;
    display: block;
    bottom: 0;
    left: 50%;
    width: 250px;
    height: 3px;
    content: "";
    background: #fff;
    transform: translateX(-50%);
    }
  }
}

.el_borderTtl{
  position: relative;
  padding-block: 20px;
  font-size: min(2.6vw,32px);
  font-weight: 600;font-weight: 400;
  text-align: center;

  &::before{
    position: absolute;
    display: block;
    bottom: 0;
    left: 50%;
    width: 250px;
    height: 3px;
    content: "";
    background: #fff;
    transform: translateX(-50%);
    }
  }

.l_subheadingArea{
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 40px 40px;

  li{
    width: calc((100% - 40px) / 2);
    padding: 20px min(3.2vw,40px) 40px;
    background: #fff;
    border-radius: 20px;

    display: flex;

    &:has(.l_subheadingFull){
      width: 100%;
      background: var(--color-bgpurple);
    }

    .l_subheading {
    display: flex;
    flex-direction: column;
    flex: 1;
    }
    .l_btnBtm{
      margin-top: auto;
    }
  }

  .el_borderTtl{
    margin-bottom: 30px;
    letter-spacing: .03em;

    &::before{
    background: var(--color-blue);
  }

    span{
      font-size: min(1.4vw,18px);
      letter-spacing: 0;
    }
  }
  .l_btnBtm a,.l_btnBtm div{
    margin-top: 30px;
    width: 100%;
  }

}
.l_contentsSmall:nth-of-type(1) .l_subheadingArea{
  .el_borderTtl::before{
    background: var(--color-blue);
  }
}
.l_contentsSmall:nth-of-type(2) .l_subheadingArea{
  .el_borderTtl::before{
    background: var(--color-purple);
  }

  .l_subheadingFull{
    .el_borderTtl::before{
    background: #fff;
  }
  }
}
.l_contentsSmall:nth-of-type(3) .l_subheadingArea{
  .el_borderTtl::before{
    background: var(--color-red);
  }
}

@media screen and (max-width: 767px) {
  .l_leadArea{
    padding-block: 6.6vw;
    font-size: 3.4vw;

    p:not(:nth-of-type(1)){
      margin-top: 5.3vw;
    }
  }
  .l_h3bgttl{
    margin-bottom: 12vw;
    margin-inline: -4vw;
    padding-block: 1.3vw 1.6vw;
    font-size: 5.3vw;
  }
  .l_h4barttl{
    margin-bottom: 6.6vw;
    padding-bottom: 2.6vw;
    font-size: 5vw;
    font-weight: 600;font-weight: 400;

    &:after{
      width: 33.3vw;
      height: .4vw;
    }
  }
  .l_contentsSmall{
    .l_lead{
      margin-bottom: 6.6vw;

      p:not(:nth-of-type(1)){
      margin-top: 5.3vw;
      }
    }

  }

  .l_pageAnchor{
    margin-bottom: 10.6vw;
    ul{
      flex-wrap: wrap;
      gap: 2.6vw 2.6vw;

      li{
        width: calc((100% - 2.6vw) / 2);
        border-radius: .6vw;

        a{
          height: 17.7vw;
          margin-top: 0;
          padding-bottom: 5vw;
          font-size: 3.4vw;

          &::before{
            height: 5.2vw;
          }
          &::after{
            bottom: 1.73vw;
            width: 2.6vw;
            height: 2.6vw;
          }
        }
      }
    }
  }

  .el_h2bgttlwrap{
    height: 33.3vw;
    margin-bottom: 5.5vw;
    
    h2{
      margin-bottom: 2.6vw;
      padding-block: 2.6vw;
      font-size: 5.3vw;

      &::before{
      width: 33.3vw;
      height: .5vw;
      }
    }
  }

  .l_subheadingArea{
    flex-direction: column;
    gap: 5.3vw;

    li{
      width: 100%;
      padding: 2.6vw 5.3vw 5.3vw;
      border-radius: 2.6vw;
    }

    .el_borderTtl{
      margin-bottom: 4vw;
      padding-block: 2.6vw;
      font-size: 4.2vw;
      letter-spacing: 0.03em;
      span{
        font-size: 2.9vw;
      }
      &::before{
      width: 33.3vw;
      height: .5vw;
      }
    }
    .l_btnBtm a,.l_btnBtm div{
      margin-top: 5.3vw;
      width: 73.2vw;
    }
  }
}





/*
 l_product
=====================================================================================*/
.l_productClassification{

}

.l_productList{
  padding-bottom: 100px;
  .l_list{
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 40px 40px;
    
    li{
      width: calc((100% - 40px) / 2);
      box-shadow: 0 0 8px 0 rgba(0, 0, 0, 0.1);
      border-radius: 15px;
      background: #fff;

      a{
        display: block;
        display: flex;
        flex-direction: column;
        height: 100%;
        &:hover .l_img{
          transform: scale(1.05);
        }
        .l_imgArea{
          position: relative;
          height: min(21.3vw,260px);
          overflow: hidden;
          border-radius: 15px 15px 0 0;
        }
        .l_img{
          transition: transform .3s ease;
          img{
            height: min(21.3vw,260px);
            }
          }
        h3{
          position: absolute;
          top: 50%;
          left: 40px;
          transform: translateY(-50%);
          padding: 0 10px;
          font-size: var(--font-30);
          font-weight: 600;font-weight: 400;
          letter-spacing: .075em;
          background: #fff;
        }
        .l_txt{
          position: relative;
          line-height: 1.6;
          padding: 30px;
          flex-grow:1;
        }
        .l_feature{
          width: 100%;
          margin-top: auto;
          display: block;
          padding: 0 30px 40px;
          h4{
            margin-bottom: 15px;
            padding-block: 3px 5px;
            background: var(--color-bgblue);
            font-size: min(1.6vw,20px);
            font-weight: 600;font-weight: 400;
            text-align: center;
          }
        }
        .l_feature_inner{
          display: flex;
          flex-direction: column;
          gap: 15px;      

          dl{
            display: flex;
            gap: 20px;
            align-items: center;

            dt{
              background: var(--color-blue);
              color: #fff;
              font-size: var(--font-mid);
              font-weight: 500;
              font-weight: 400;font-weight: 300;
              padding: 0 10px;
              display: flex;
              align-items: center;
              line-height: 1;
              height: 30px;
              &.el_typeS{
                background: #4bdef8;
                font-size: var(--font-toujour);
                padding: 0 5px;
              }
              &.el_typeR{
                background: #f8804b;
                font-size: var(--font-toujour);
                padding: 0 5px;
              }
            }
            strong{
              font-size: var(--font-28);
              font-weight: normal;
            }
          }
        }
      }
    }
  }
}
.el_bgpurple.l_productList{
  .l_list{
    li{
      a{
        .l_feature{
          h4{
            background: var(--color-bgpurple);
          }
        }
        .l_feature_inner{
          dl{
            dt{
              background: var(--color-purple);
            }
          }
        }
      }
    }
  }
}
.el_bgred.l_productList{
  .l_list{
    li{
      a{
        .l_feature{
          h4{
            background: var(--color-bgred);
          }
        }
        .l_feature_inner{
          dl{
            dt{
              background: var(--color-red);
            }
          }
        }
      }
    }
  }
}  
.el_bggreen.l_productList{
  .l_list{
    li{
      a{
        .l_feature{
          h4{
            background: var(--color-bggreen);
          }
        }
        .l_feature_inner{
          dl{
            dt{
              background: var(--color-green);
            }
          }
        }
      }
    }
  }
}  
.l_fullbnrArea{
  width: 100%;
  margin-bottom: 100px;
}

@media screen and (max-width: 767px) {
  .l_productList{
    padding-bottom: 13.3vw;
    .l_list{
      flex-direction: column;
      gap: 5.3vw;
      
      li{
        width: 100%;
        border-radius: 2vw;

        a{
          .l_imgArea{
            height: 40.5vw;
            border-radius: 2vw 2vw 0 0;
          }
        .l_img{
          img{
            height: 40.5vw;
            object-fit: cover;
            }
          }
          h3{
            left: 5.3vw;
            padding: 0 1.3vw;
            font-size: var(--font-30_sp);
          }
          .l_txt{
            padding: 4vw 5.3vw 5.3vw;
            font-size: 3.4vw;
          }

          .l_feature{
            padding: 0 5.3vw 6.6vw;
            h4{
              margin-bottom: 2.4vw;
              padding-block: .3vw .5vw;
              font-size: 3.2vw;
            }
          }
          .l_feature_inner{
            gap: 2.4vw;      

            dl{
              gap: 2.6vw;

              dt{
                font-size: 2.9vw;
                padding: 0 .7vw;
                height: 4.6vw;
                &.el_typeS{
                  font-size: 3.3vw;
                  padding: 0 .4vw;
                }
                &.el_typeR{
                  font-size: 3.3vw;
                  padding: 0 .4vw;
                }
              }
              strong{
                font-size: 4.8svw;
              }
            }
        }
        }
      }
    }
  }

  .l_fullbnrArea{
    margin-bottom: 13.3vw;
  }
}

/* l_installation*/
.l_installation{
  padding-bottom: 100px;
.l_lead{
  margin-bottom: 90px;
  text-align: center;
}

  .l_list{
     /*display: flex;*/
    
    li{
      position: relative;
      display: flex;
      gap: 50px;

      &:not(:last-child){
        margin-bottom: 90px;
      }

      &::after{
        position: absolute;
        bottom: -50px;
        left: 50%;
        content: "";
        background: url(../../product/images/icon_flow_arrow.png) no-repeat;
        background-size: contain;
        width: 30px;
        height:26px;
        transform: translateX(-50%);
      }
       &:last-child::after{
       background: none;
      }
      
      .l_img{
        width: min(27.8vw,340px);
        margin-left: 40px;
        position: relative;
        .el_number{
          position: absolute;
          width: min(8.8vw,108px);
          top: -40px;
          left: -40px;
        }
      }
      .l_txt{
        flex: 1;
        h3{
          padding-bottom: 20px;
          font-size: min(2.6vw,32px);
          font-weight: 600;font-weight: 400;
        }
        p{
          line-height: 1.6;
        }
        dl{
          display: flex;
          align-items: center;
          gap: 20px;
          margin-top: 20px;
          padding: 10px 20px 15px;
          background: var(--color-bgblue);
          border-radius: 20px;
          font-size: var(--font-ttlsub);
        }
        dt{
          color: var(--color-blue);
          font-weight: 600;font-weight: 400;
        }
        dd{
          flex: 1;
        }
      }
    }
  }
}

@media screen and (max-width: 767px) {
  .l_installation{
    padding-bottom: 13.3vw;

    .l_lead{
      margin-bottom: 13.3vw;
    }

    .l_list{
      
      li{
        flex-direction: column;
        gap: 4vw;

        &:not(:last-child){
          margin-bottom: 24vw;
        }

        &::after{
          bottom: -13.3vw;
          width: 6vw;
          height:5.3vw;
        }
        
        .l_img{
          width: 100%;
          margin-left: 0;
          .el_number{
            width: 19.8vw;
            top: -6.6vws;
            left: -1.3vw;
          }
        }
        .l_txt{
          h3{
            padding-bottom: 4vw;
            font-size: 5vw;
          }
          dl{
            align-items: flex-start;
            flex-direction: column;
            gap: 1.3vw;
            margin-top: 5.3vw;
            padding: 2.6vw 2.6vw 4vw;
            border-radius: 2.6vw;
          }
          dt{
            color: var(--color-blue);
            font-size: 3.2vw;
            font-weight: 600;font-weight: 400;
          }
          dd{
            font-size: 3.2vw;
          }
        }
      }
    }
  }
}

/*
 l_maintenance
=====================================================================================*/
.l_maintenanceContents{
  .l_pageAnchor{
    margin-top: 80px;
  }

  .l_contentsSmall{
    margin-bottom: 100px;
  }

  .l_contentsSmall:nth-of-type(1) .el_h2bgttlwrap{
    background: url(../../maintenance/images/bg_h2_01.png);
    background-position: center;
    background-size: cover;
  }
  .l_contentsSmall:nth-of-type(2) .el_h2bgttlwrap{
    background: url(../../maintenance/images/bg_h2_02.png);
    background-position: center;
    background-size: cover;
  }
  .l_contentsSmall:nth-of-type(3) .el_h2bgttlwrap{
    background: url(../../maintenance/images/bg_h2_03.png);
    background-position: center;
    background-size: cover;
  }
}
.l_maintenanceBlueCont{
  position: relative;
  z-index: -2;
  margin-bottom: 50px;
  padding: 40px 40px 50px;
  background: #dfedff;
  border-radius: 15px;

  .el_borderTtl{
    margin-bottom: 100px;
    font-size: var(--font-36);
  }
  .l_list{
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 90px 30px;

    h4{
      margin-bottom: 20px;
      font-size: var(--font-28);
      font-weight: 600;font-weight: 400;
      text-align: center;
    }

    li{
      position: relative;
      width: calc((100% - 30px * 2) / 3);
      padding: 30px 20px;
      background: #fff;
      border-radius: 20px;
      font-size: var(--font-toujour);
      &::before{
        display: block;
        position: absolute;
        content: "";
        width: 160px;
        height: 160px;
        top: -60px;
        left: 50%;
        transform: translateX(-50%);
        background: #fff;
        border-radius: 100px;
        z-index: -1;
      }
      &::after{
        display: block;
        position: absolute;
        content: "";
        width: 47px;
        height: 47px;
        top: -35px;
        left: 50%;
        transform: translateX(-50%);
        z-index: 1;
      }
    }
    li:nth-of-type(1){
      &::after{
        transform: translateX(-60%);
        background: url(../../maintenance/images/icon_bluecont01.png) no-repeat;
        background-size: contain;
      }
    }
    li:nth-of-type(2){
      &::after{
        background: url(../../maintenance/images/icon_bluecont02.png) no-repeat;
        background-size: contain;
      }
    }
    li:nth-of-type(3){
      &::after{
        background: url(../../maintenance/images/icon_bluecont03.png) no-repeat;
        background-size: contain;
      }
    }
    li:nth-of-type(4){
      &::after{
        background: url(../../maintenance/images/icon_bluecont04.png) no-repeat;
        background-size: contain;
      }
    }
    li:nth-of-type(5){
      &::after{
        transform: translateX(-40%);
        background: url(../../maintenance/images/icon_bluecont05.png) no-repeat;
        background-size: contain;
      }
    }

  }
  
}


@media screen and (max-width: 767px) {
.l_maintenanceContents{
  .l_pageAnchor{
    margin-top: 8vw;
      ul{
        li{
          width: calc((100% - 2.6vw * 2) / 3);
        }
      }
    }

    .l_contentsSmall{
      margin-bottom: 13.3vw;
    }

    .l_contentsSmall:nth-of-type(1) .el_h2bgttlwrap{
      background: url(../../maintenance/images/bg_h2_01_sp.png);
      background-position: center;
      background-size: cover;
    }
    .l_contentsSmall:nth-of-type(2) .el_h2bgttlwrap{
      background: url(../../maintenance/images/bg_h2_02_sp.png);
      background-position: center;
      background-size: cover;
    }
    .l_contentsSmall:nth-of-type(3) .el_h2bgttlwrap{
      background: url(../../maintenance/images/bg_h2_03_sp.png);
      background-position: center;
      background-size: cover;
    }
  }

  .l_maintenanceBlueCont{
    margin-bottom: 6.6vw;
    padding: 2.6vw 5.3vw 6.6vw;
    border-radius: 2vw;

    .el_borderTtl{
      margin-bottom: 4vw;
      padding-block: 2.6vw;
      font-size: 5.3vw;
      letter-spacing: 0.03em;

      &::before{
      width: 33.3vw;
      height: .5vw;
      }
    }

  .l_list{
    flex-direction: column;
    gap: 2.6vw;

    h4{
      margin-bottom: 0;
      font-size: 4.2vw;
      font-weight: 600;font-weight: 400;
      text-align: center;
    }

    li{
      display: flex;
      align-items: center;
      gap: 3vw;
      width: calc(100% - 6.6vw);
      margin-left: 6.6vw;
      padding: 5.3vw 4vw 5.3vw 5.3vw;
      border-radius: 2.6vw;
      font-size: 3.2vw;
      &::before{
        width: 12.8vw;
        height: 12.8vw;
        top: 50%;
        left: -6.6vw;
        transform: translateX(0) translateY(-50%);
      }
      &::after{
        display: block;
        position: absolute;
        content: "";
        width: 6.2vw;
        height: 6.2vw;
        top: 50%;
        left: -2.6vw;
        transform: translateX(0) translateY(-50%) !important;
        z-index: 1;
      }
      p{
        flex: 1;
      }
    }
    }   
  }
}

/* modal */
.modal{
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  text-align: center;
  background: rgba(0,0,0,50%);
  padding: 30px 15px;
  padding: 0;
  overflow: auto;
  opacity: 0;
  visibility: hidden;
  transition: .3s;
  box-sizing: border-box;
  z-index: 99;
}
.modal:before{
  content: "";
  display: inline-block;
  vertical-align: middle;
  height: 100%;
  margin-left: -0.2em;
}
.modal.is-active{
  opacity: 1;
  visibility: visible;
}
.modal-container{
  position: relative;
  display: inline-block;
  vertical-align: middle;
  max-width: 640px;
  width: 90%;
}

.modal-content{
  background: #fff;
  border-radius: 20px;
  padding: 0;
}
.l_modalContents{
  .l_subheadingArea{
    flex-direction: column;
    gap: 0;
    li{
      width: 100%;
      p{
        text-align: left;

        &:not(:first-child){
          margin-top: 20px;
        }
      }  
    }
  }
}
.js-modal-close{
  position: absolute;
  right: -10px;
  top: -10px;
  width: 45px;
  height: 45px;
  background: url(../images/icon_close.png);
  background-size: contain;
  text-indent: -9999px;
}

@media screen and (max-width: 767px) {
  .modal{
    padding: 0;
  }
  .modal-content{
    padding: 0;
  }
  .js-modal-close{
    right: -1.3vw;
    top: -1.3vw;
    width: 6vw;
    height: 6vw;
  }
}

/*
 l_lease
=====================================================================================*/
.l_leaseContents{
  .l_pageAnchor{
    margin-top: 80px;
  }

  .l_contentsSmall{
    margin-bottom: 100px;
  }

  .l_contentsSmall:nth-of-type(1) .el_h2bgttlwrap{
    background: url(../../lease/images/bg_h2_01.png);
    background-position: center;
    background-size: cover;
  }
  .l_contentsSmall:nth-of-type(2) .el_h2bgttlwrap{
    background: url(../../lease/images/bg_h2_02.png);
    background-position: center;
    background-size: cover;
  }
  .l_contentsSmall:nth-of-type(3) .el_h2bgttlwrap{
    background: url(../../lease/images/bg_h2_03.png);
    background-position: center;
    background-size: cover;
  }

  /* l_installation*/
  .l_installation{
    .l_list{
      li{
        &::after{
          background: url(../../lease/images/icon_flow_arrow.png) no-repeat;
          background-size: contain;
        }
        &:last-child::after{
        background: none;
        }
        
        .l_txt{
          dl{
            background: #ffdfdf;
          }
          dt{
            color: #df4444;
          }
        }
      }
    }
  }

  /* .l_btnS */
  .l_btnS a{
    background: #df4444;
    
    &::after{
    background: url(../images/icon_arrow_rd_r.png);
    background-size: contain;
    }
  }
}

@media screen and (max-width: 767px) {
.l_leaseContents{
  .l_pageAnchor{
    margin-top: 8vw;
      ul{
        li{
          width: calc((100% - 2.6vw * 2) / 3);
        }
      }
    }

    .l_contentsSmall{
      margin-bottom: 13.3vw;
    }

    .l_contentsSmall:nth-of-type(1) .el_h2bgttlwrap{
      background: url(../../lease/images/bg_h2_01_sp.png);
      background-position: center;
      background-size: cover;
    }
    .l_contentsSmall:nth-of-type(2) .el_h2bgttlwrap{
      background: url(../../lease/images/bg_h2_02_sp.png);
      background-position: center;
      background-size: cover;
    }
    .l_contentsSmall:nth-of-type(3) .el_h2bgttlwrap{
      background: url(../../lease/images/bg_h2_03_sp.png);
      background-position: center;
      background-size: cover;
    }
  }
}

/*
 l_casestudy
=====================================================================================*/
.l_casestudyContents{
  margin-top: 60px;

  .l_casestudySmall{
    display: flex;
    flex-direction: row-reverse;
    gap: 50px;
    margin-bottom: 100px;

    .l_txt{
      flex: 1;
      .l_casestudyPlace{
        margin-bottom: 30px;
        font-size: min(4.2vw,32px);
        font-weight: 600;font-weight: 400;
        line-height: 1.5;
      }
      .l_casestudyProduct{
        h2{
          padding-block: 3px 5px;
          font-size: var(--font-ttlsub);
          font-weight: 600;font-weight: 400;
          text-align: center;
          
          &.el_dansa{
            background: var(--color-bgpurple);
          }
          &.el_shoko{
            background: var(--color-bgblue);
          }
          &.el_chair{
            background: var(--color-bgred);
          }
        }
        p{
          padding-block: 15px 30px;
          font-size: var(--font-28);
          font-weight: 600;font-weight: 400;
        }
      }
      .l_casestudyDesc{
        line-height: 1.6;
      }
      .l_btnBtm a{
        margin-top: 40px;
      }

    }

    .l_img{
      width: min(51.6vw,630px);
    }
  }


  .swiper-pagination-bullet{
    width: 20px;
    height: 20px;
  }

  .swiper-pagination-bullet{
    background: #fff;
    opacity: 1;
  }
  .swiper-pagination-bullet-active{
    background: var(--color-blue);
  }
  .swiper-horizontal>.swiper-pagination-bullets, .swiper-pagination-bullets.swiper-pagination-horizontal, .swiper-pagination-custom, .swiper-pagination-fraction {
      bottom: 0px;
  }
  .swiper{
    padding-bottom: 40px;
  }
  .swiper-button-next, .swiper-button-prev {
      width: 45px;
      height: 45px;
  }
}

@media screen and (max-width: 767px) {
  .l_casestudyContents{
    margin-top: 8vw;

    .l_casestudySmall{
      flex-direction: column-reverse;
      gap: 5.3vw;
      margin-bottom: 13.3vw;

      .l_txt{
        flex: 1;
        .l_casestudyPlace{
          margin-bottom: 5.3vw;
          font-size: 4.8vw;
          line-height: 1.4;
        }
        .l_casestudyProduct{
          h2{
            padding-block: .2vw .6vw;
            font-size: 3.2vw;
          }
          p{
            padding-block: 2.6vw 4vw;
            font-size: 4.2vw;
          }
        }
        .l_casestudyDesc{
          font-size: var(--font-toujour_sp);
        }
        .l_btnBtm a{
          margin-top: 5.3vw;
        }

      }

      .l_img{
        width: 100%;
      }
    }

    .swiper{
      padding-bottom: 5.3vw;
    }
    .swiper-pagination-bullet{
      width: 2.6vw;
      height: 2.6vw;
    }
    .swiper-button-next, .swiper-button-prev {
      margin-top: 2.6vw;
        width: 6vw;
        height: 6vw;
    }
  }
}

/*
 l_partner
=====================================================================================*/
.l_partner{
  .l_topFacilities{
    background: none;
    .scroll-infinity{
      background: #fff;
      margin-right: calc(50% - 50vw);
      margin-left: calc(50% - 50vw);
      padding-block: 10px;
    }
    .l_lead{
      margin-bottom: 50px;
    }
  }
}

.l_partnerContents{
  padding-bottom: 100px;

  .l_lead{
    margin-bottom: 50px;
  }
  .l_list{
    display: flex;
    gap: 40px;
    width: auto;

    li{
     /*width: calc((100% - 28px * 5) / 6);*/
      width: calc((100% - 40px * 2) / 2);
      padding-top: 30px;
      position: relative;
      display: flex;
      justify-content: center;

      &:not(:last-child)::after{
        position: absolute;
        top: 50%;
        right: -30px;
        content: "";
        background: url(../images/icon_flow_arrow.png);
        background-size: contain;
        width: 14px;
        height: 16px;
        transform: translateX(-50%);
      }

      div{
        display: flex;
        flex-direction: column;
        align-items: center;
        width: 100%;
        padding: 0 10px 50px;
        padding-top: min(6.1vw,75px);
        background: var(--color-bgblue);
        border-radius: 20px;

        span{
          display: block;
          font-size: min(3.9vw,48px);
          font-weight: 600;font-weight: 400;
          letter-spacing: .075em;
          color: var(--color-blue);
        }

        h3{
          margin-bottom: 5px;
          font-size: min(2.1vw,26px);
          font-weight: 600;font-weight: 400;
          letter-spacing: .075em;
        }
        p{
          font-weight: 500;
          font-weight: 400;font-weight: 300;
          text-align: center;
        } 
      }
      .l_img{
        position: absolute;
        top: 0px;
        width: min(8.8vw,108px);
      }
    }
  }
}

@media screen and (max-width: 767px) {
  .l_partner{
    .l_topFacilities{
      .l_lead{
        margin-bottom: 6.6vw;
      }
    }
  }
  .l_partnerContents{
    padding-bottom: 13.3vw;

    .l_lead{
      margin-bottom: 6.6vw;
    }
    .l_list{
      align-items: center;
      flex-direction: column;
      gap: 13.3vw;

      li{
        width: 70.6vw;
        padding-top: 8vw;

        &:not(:last-child)::after{
          right: inherit;
          top: inherit;
          bottom: -8.5vw;
          left: 50%;
          width: 4.5vw;
          height: 4.1vw;
          background-repeat: no-repeat;
          transform: translateX(-50%) rotate(90deg);
        }

        div{
          padding: 0 1.3vw 5.3vw;
          padding-top: 13.3vw;
          border-radius: 2.6vw;

          span{
            font-size: 7.7vw;
          }
          h3{
            font-size: 4.5vw;
          }
          p{
            font-size: 3.4vw;
          }
        }
        .l_img{
          width: 21.6vw;
        }
      }
    }
  }
}

/*
 l_news
=====================================================================================*/
.l_news{
  .l_serchBox{
    display: flex;
    margin-bottom: 70px;
    padding: 40px;
    border-radius: 15px;
    background: var(--color-bg);
    .l_serchBox_inner{
      position: relative;
      display: flex;
      align-items: center;
      gap: 30px;
      width: 50%;
      h3{
        color: var(--color-blue);
      }
      .l_serchBox_inner_select{
        position: relative;
        display: block;
        background: #fff;
        width: min(29vw,360px);
        padding: 15px;
        z-index: 1;

        select{
          position: relative;
          z-index: 10;
        width: min(29vw,360px);
        }

        &::before{
        display: block;
        position: absolute;
        top: 50%;
        right: 40px;
        content: "";
        background: url(../images/icon_arrow_bl.png);
        background-size: contain;
        width: min(1.6vw,20px);
        height: min(1.6vw,20px);
        transform: rotate(90deg) translateX(-65%);
       }
      }
    }
  }
  .l_newsList {
    padding-top: 90px;
  }
}
.l_newsList {
  /**/
  & .l_list {
  dl {
    &.d-none {
      display: none;
     }
    }
  }
}
.l_newsDetail{
  h2{
    margin-bottom: 50px;
    font-size: var(--font-30);
    font-weight: 600;font-weight: 400;
  }
  h3{
    margin-bottom: 30px;
    padding: 5px 10px;
    font-size: var(--font-24);
    font-weight: 600;font-weight: 400;
    background: var(--color-bg);
  }  
  .l_tag{
    margin-bottom: 40px;
    display: flex;
    align-items: center;
    gap: 40px;

    .el_date{
      font-size: var(--font-ttlsub);
      color: var(--color-blue);
    }
    .el_category{
      padding: 3px 15px 5px;
      background: var(--color-blue);
      border-radius: 8px;
      font-size: var(--font-mid);
      color: #fff;
    }
  }
  p{
    &:not(:first-child){
    margin-bottom: 40px;
    }
    a{
      color: var(--color-blue);
      text-decoration: none;
      &:hover{
        text-decoration: underline;
      }
    }
  }
  dl{
    margin-bottom: 50px;
  }
  dt{
    font-weight: 400;
    &:not(:first-child){
    margin-top: 20px;
    }
  }
  .l_img{
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 40px;
  }
}

@media screen and (max-width: 767px) {
  .l_news{
    padding-top: 8vw;
    .l_serchBox{
      flex-direction: column;
      margin-bottom: 8vw;
      padding: 5.3vw;
      border-radius: 2vw;
      gap: 3.3vw;
      .l_serchBox_inner{
        gap: 5.3vw;
        width: 100%;
        h3{
          width: 20vw;
          text-align: right;
        }
        .l_serchBox_inner_select{
          width: 53.3vw;
          padding: 2vw;
          z-index: 1;

          select{
          width: 53.3vw;
          }

          &::before{
          top: 50%;
          right: 4vw;
          width: 2.6vw;
          height: 2.6vw;
        }
        }
      }
    }
    .l_newsList {
      padding-top: 8vw;
    }
  }
  .l_newsList {
    & .l_list {
    dl {
      &.d-none {
        display: none;
      }
      }
    }
  }
.l_newsDetail{
  h2{
    margin-bottom: 6.6vw;
    font-size:4vw;
  }
  h3{
    margin-bottom: 5.3vw;
    font-size:3vw;
  }  
  .l_tag{
    margin-bottom: 5.3vw;
    gap: 4vw;

   .el_date{
      font-size: 2.9vw;
    }
    .el_category{
      width: inherit;
      padding: 3px 2.6vw 5px;
      border-radius: .6vw;
      font-size: 2.6vw;
    }
  }
  p{
    &:not(:first-child){
    margin-bottom: 5.3vw;
    }
    a{
      color: var(--color-blue);
      text-decoration: none;
      &:hover{
        text-decoration: underline;
      }
    }
  }
  dl{
    margin-bottom: 7.6vw;
  }
  dt{
    &:not(:first-child){
    margin-top: 2.6vw;
    }
  }
  .l_img{
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 40px;
  }
}

}

/*
 l_news
=====================================================================================*/
.l_privacyContents{
  padding-bottom: 100px;
  .l_privacyContents_inner{
    padding-bottom: 100px;
  }
}
.l_tbl{
  dl{
    display: flex;
    gap: 4px;
    &:not(:last-child){
      margin-bottom: 4px;
    }
  }
  dt{
    width: min(24vw,295px);
    padding: 30px;
    background: var(--color-bgblue);
    font-weight: 600;font-weight: 400;
  }
  dd{
    flex: 1;
    padding: 30px;
    background: #fff;
  }
  .l_year{
    width: 100%;
    margin-bottom: 4px;
    padding: 30px;
    background: var(--color-blue);
    color: #fff;
    font-size: var(--font-24);
    font-weight: 600;font-weight: 400;
  }
}

@media screen and (max-width: 767px) {
.l_privacyContents{
  padding-bottom: 13.3vw;
  .l_privacyContents_inner{
    padding-bottom: 13.3vw;
  }
}
.l_tbl{
    dl{
      flex-direction: column;
      gap: .5vw;
      &:not(:last-child){
        margin-bottom: .5vw;
      }
    }
    dt{
      width: 100%;
      padding: 4vw;
    }
    dd{
      width: 100%;
      padding: 4vw;
    }
    .l_year{
      width: 100%;
      margin-bottom: .5vw;
      padding: 4vw;
      font-size: 3.7vw;
      &:not(:first-child){
        margin-top: 13.3vw;
      }
    }
  }
}


/*
 l_company
=====================================================================================*/
.l_companyLead{
  background: linear-gradient(#4d91e3 0%, #c1ebfc 100%);
  .l_contents{
    padding: 50px 120px;
  }
}
.l_companyContents{
  padding-bottom: 100px;

  .l_tbl{
    dt{
      padding-block: 20px;
    }
    dd{
      display: flex;
      align-items: center;
      justify-content: space-between;

      padding-block: 20px;
    }
    p{
      line-height: 1.4;
    }
    p:not(:first-child){
      margin-top: 20px;
    }
  }
}
.l_tblList{
  li{
    width: 100%;
    padding: 30px;
    background: #fff;
    &:not(:last-child){
      margin-bottom: 4px;
    }
  }
}

@media screen and (max-width: 767px) {
  .l_companyLead{
    background: none;
  }
  .l_companyContents{
    padding-bottom: 13.3vw;
    .l_tbl{
      p:not(:first-child){
        margin-top: 4vw;
      }
    }
  }
  .l_tblList{
    li{
      padding: 4vw;
    }
  }
}


/*
 l_faq
=====================================================================================*/
.l_faqArea{
  padding-bottom: 100px;

  .l_pageAnchor{
    padding-top: 80px;
  }

  dl{
    &:first-of-type{
      border-top: 2px solid #fff;
    }
    width: 100%;
    padding: 30px 0;
    border-bottom: 2px solid #fff;
  }
  dt{
    position: relative;
    padding-inline: 40px;
    font-size: var(--font-22);
    font-weight: 500;
    font-weight: 400;font-weight: 300;
    line-height: 1.35;
    &::before{
      position: absolute;
      top: -4px;
      left: 0;
      content: "Q";
     font-size: var(--font-28);
    }
    &::after{
      position: absolute;
      top: 50%;
      right: 40px;
      content: "";
      background: url(../images/icon_arrow_bl.png);
      background-size: contain;
      width: min(1.6vw,20px);
      height: min(1.6vw,20px);
      transform: rotate(90deg) translateX(-65%);
    }
    &.active{
      &::after{
        margin-top: -10px;
        transform: rotate(270deg);
      }
    }
  }
  dd{
    padding-top: 15px;
    padding-inline: 40px;
    font-size: var(--font-toujour);
    font-weight: 400;font-weight: 300;
    line-height: 1.6;
    display: none;
  }
}
.l_leadArea{
  .l_h4barttl{
      margin-top: 80px;
    }
  .l_faqHeader{
    display: flex;
    gap: 40px;

    .l_faqArea_inner{
      width: calc((100% - 40px) / 2);

      dl{
        &:first-of-type{
          border-top: 2px solid var(--color-bg);
        }
        border-bottom: 2px solid var(--color-bg);
      }
    }
  }
}
.l_faqContents{
  margin-top: 80px;

  .l_pageAnchor {
      & ul {
          & li {
              &:nth-of-type(-n+4) a::before {
                  background: var(--color-bgblue);
              }
          }
      }
  }

}

@media screen and (max-width: 767px) {
  .l_faqArea{
    padding-bottom: 13.3vw;

    dl{
      padding: 4vw 0;
    }
    dt{
      padding-inline: 5.3vw;
      font-size: 3.2vw;
      &::before{
        position: absolute;
        top: -1.3vw;
        left: 0;
        content: "Q";
      font-size: 5.3vw;
      }
      &::after{
        right: 5.3vw;
        width: 2.6vw;
        height: 2.6vw;
      }
      &.active{
        &::after{
          margin-top: -1.3vw;
        }
      }
    }
    dd{
      padding-top: 2vw;
      padding-inline: 5.3vw;
      font-size: 3.2vw;
    }
  }

  .l_leadArea{
    .l_h4barttl{
        margin-top: 10.6vw;
      }
    .l_faqHeader{
      flex-direction: column;
      gap: 0;

      .l_faqArea_inner{
        width: 100%;

        &:nth-of-type(2){
          dl:first-of-type{
            border-top: none;
          }
        }
      }
    }
  }
  .l_faqContents{
    margin-top: 10.6vw;
  }
}


/*
 l_sitemap
=====================================================================================*/
.l_sitemapContents{
  padding-bottom: 100px;

  /* .el_ttlwrap */
  .el_ttlwrap{
    h2{
      font-size: min(2.6vw,32px);
    }
  }
}
.l_sitemapList{
  ul{
    display: flex;
    flex-wrap: wrap;
    gap: 40px 40px;
  }
  li{
    width: calc((100% - 40px * 2) / 3);

    a{
      width: 100%;
      display: block;
      width: 100%;
      padding: 30px;
      background: #fff;
    }
  }
}

.l_sitemapContents_inner{
  display: flex;
  flex-wrap: wrap;
  gap: 40px 40px; 

  .el_ttlwrap{
    width: calc((100% - 40px * 2) / 3);
  }
}

@media screen and (max-width: 767px) {
  .l_sitemapContents{
    padding-bottom: 13.3vw;

    /* .el_ttlwrap */
    .el_ttlwrap{
      h2{
        font-size: 5.3vw;
      }
    }
  }
  .l_sitemapList{
    ul{
      gap: .6vw;
    }
    li{
      width: 100%;

      a{
        padding: 4vw;
      }
    }
  }

  .l_sitemapContents_inner{
    gap: 0; 

    .el_ttlwrap{
      width: 100%;
      margin-bottom: 5.3vw;
    }
  }
}

/*
 l_product 下層
 l_productDetail
=====================================================================================*/
/*.product_mainswiper{
  position: relative;
    padding-top: unquote("min((100vh - 85px),75%)");
    .swiper-wrapper {
        position: absolute;
        top: 0;
        left: 0;
    }
}*/
.product_mainswiper.l_main{
  background: none;
  position: relative;
  height: calc(min(37.7vw,460px) + 40px);
  display: flex;
  align-items: center;
  background: #fff;
  padding-bottom: 40px;

  .l_mainTtl{
    position: absolute;
    z-index: 10;
  }
  .swiper-container,
  .swiper-slide {
   
  }
  .swiper-slide > img {
    object-fit: cover; /* IE: not support */
    width: 100%;
    height: 100%;
  }

.swiper-pagination-bullet{
    width: 20px;
    height: 20px;
  }

  .swiper-pagination-bullet{
    background: var(--color-bg);
    opacity: 1;
  }
  .swiper-pagination-bullet-active{
    background: var(--color-blue);
  }
  .swiper-horizontal>.swiper-pagination-bullets, .swiper-pagination-bullets.swiper-pagination-horizontal, .swiper-pagination-custom, .swiper-pagination-fraction {
      bottom: 0px;
  }
}
.l_productDetail{
  .l_main{
    .l_mainTtl{
      flex-direction: column;
      align-items: flex-start;
      justify-content: center;
      line-height: 1.3;
      span{
        display: block;
        padding-top: 5px;
        font-size: min(2.4vw,34px);
      }
    }
  }
}
.l_productDetailContents{
  margin-bottom: 100px;
  .l_lead{
    margin-bottom: 50px;
  }
  .l_list{
    display: flex;
    flex-wrap: wrap;
    gap: 100px 40px;

    li{
      width: calc((100% - 40px) / 2);
    }

    .l_img{
      width: min(48.3vw,590px);
      height: min(27vw,330px);
      img{
        object-fit: cover;
        width: 100%;
        height: 100%;
      }
    }
    .l_txt{
      h3{
        margin-block: 30px;
        font-size: var(--font-26);
        font-weight: 600;font-weight: 400;
      }
    }
  }
}

@media screen and (max-width: 767px) {
  .product_mainswiper.l_main{
   padding-bottom: 5.3vw;
    .swiper-pagination-bullet{
      width: 2.6vw;
      height: 2.6vw;
    }
    .swiper-button-next, .swiper-button-prev {
      margin-top: 2.6vw;
        width: 6vw;
        height: 6vw;
    }
  }

  .l_productDetail{
    .l_main{
      .l_mainTtl{
        span{
          display: block;
          padding-top: 0;
          font-size: 4.5vw;
        }
      }
    }
  }

  .l_productDetailContents{
    margin-bottom: 13.3vw;
    .l_lead{
      margin-bottom: 6.6vw;
    }
    .l_list{
      display: flex;
      flex-wrap: wrap;
      gap: 12vw;

      li{
        width: 100%;
      }

      .l_img{
        width: 100%;
        height: 51.4vw
      }
      .l_txt{
        h3{
          margin-block: 5.3vw;
          font-size: 4.2vw;
        }
      }
    }
  }
}

/*
 page404
=====================================================================================*/
.l_page404Contents{
  padding-block: 100px 150px;
  text-align: center;

  .l_page404Contents404{
    margin-bottom: 30px;
    font-size: 90px;
    font-weight: 600;font-weight: 400;
    color: var(--color-blue);
    text-align: center;
  }
  h1{
    margin-bottom: 30px;
    font-size: var(--font-36);
    font-weight: 600;font-weight: 400;
  }
}

@media screen and (max-width: 767px) {
  .l_page404Contents{
    padding-block: 13.3vw 20vw;

    .l_page404Contents404{
      margin-bottom: 4vw;
      font-size: 12vw;
    }
    h1{
      margin-bottom: 4vw;
      font-size: 4.8vw;
    }
  }
}


/*
 l_contact
=====================================================================================*/
  /*カスタマイズ
  .sf-form-cover{
    display: none !important;
  }
  h2.title.multi-line.sf-text-center {
      display: none !important;
  }
  #sf-form-page{
    background: none !important;
  }
  .sf-footer[data-v-1f3320d0]{
    display: none !important;
  }
  .pc-slideup-cta-board{
    display: none !important;
  }*/

.l_contactContents.bg_wh{
  margin-bottom: -250px;
  margin-bottom: 0;
  position: relative;
  z-index: 1;
}
.l_contact .l_footer{
  position: relative;
  z-index: 2;
}

.l_contactContents.l_upper{
  padding-block: 50px;
  .l_contactContentsTel{    
    margin-inline: 40px;
    padding: 60px 40px 50px;
    background: rgba(255,255,255,1);
    border-radius: 30px;
    .el_inqttl{
      position: relative;
      margin-bottom: 40px;
      padding-bottom: 30px;
      font-size: var(--font-42);
      font-weight: 600;font-weight: 400;
      text-align: center;

      &::after{
        position: absolute;
        bottom: 0;
        left: 50%;
        content: "";
        width: 250px;
        height: 5px;
        background: var(--color-blue);
        transform: translateX(-50%);
      }      
    }
    .l_telArea{
      margin-bottom: 50px;
      text-align: center;
    }
    .l_telNumber{
      color: var(--color-blue);
      letter-spacing: .025em;
      text-align: center;
      p{
        font-size: var(--font-28);
        font-weight: 600;
      }
      a{
        font-size: min(6.9vw,85px);
        font-weight: 900; 
      }
    }
    .l_telTime{
      font-size: var(--font-26);
    }
  }
}

@media screen and (max-width: 767px) {
  .l_contactContents.l_upper{
    padding-block: 6.6vw;
    .l_contactContentsTel{    
      margin-inline: 0;
      padding: 7vw 5.5vw 6vw;
      border-radius: 4vw;
      .el_inqttl{
        margin-bottom: 4vw;
        padding-bottom: 4vw;
        font-size: 5.3vw;

        &::after{
          width: 33.3vw;
          height: .6vw;
        }      
      }
      .l_telArea{
        margin-bottom: 6.6vw;
      }
      .l_telNumber{
        p{
          font-size: 3.46vw;
        }
        a{
          font-size: 10.5vw;
        }
      }
      .l_telTime{
        font-size: 3.7vw;
      }
    }
  }
}
