@charset "UTF-8";
@media screen and (max-width: 767px) {
    .pc{ display: none !important; }
    .sp{ display: block !important; }


h1, h2, h3, h4, h5, h6,p,a{
    letter-spacing: 1px;
}

main{
    margin-top: 13vw;
}

/* btn */
.btn01 {
    min-width: 60vw;
    position: relative;
    color: #fff;
    background-color: #C7312D;
    padding: 4vw 15vw;
    line-height: 1;
    font-size: 4vw;
    text-align: center;
    display: inline-block;
    border-radius: 10vw;
    transition: background-color 0.3s ease;
    letter-spacing: 0;
    font-weight: 600;
}
.btn01::after {
    position: absolute;
    content: "";
    width: 3.5vw;
    height: 3.5vw;
    background-image: url(../images/common/arrow.png);
    background-size: contain;
    background-repeat: no-repeat;
    margin-left: 2.5vw;
    top: 50%;
    right: 1.5vw;
    transform: translateY(-50%) translateX(0);
    transition: transform 0.3s ease;
}
.btn01:hover::after {
  transform: translateY(-50%) translateX(5px);
}
.btn02{
    min-width: 60vw;
    position: relative;
    color: #fff;
    background-color: #C7312D;
    border: solid 1px #FFF;
    padding: 4vw 0vw;
    line-height: 1;
    font-size: 3.8vw;
    text-align: center;
    display: inline-block;
    border-radius: 6vw;
    transition: background-color 0.3s 
    ease;
    letter-spacing: 0.3rem;
    font-weight: 600;
}
.btn02::after {
    position: absolute;
    content: "";
    width: 3vw;
    height: 3vw;
    background-image: url(../images/common/arrow.png);
    background-size: contain;
    background-repeat: no-repeat;
    margin-left: 2vw;
    top: 50%;
    right: 3vw;
    transform: translateY(-50%) translateX(0);
    transition: transform 0.3s ease;
}
.btn02:hover::after {
    transform: translateY(-50%) translateX(5px);
}
.btn02_{
    min-width: 60vw;
    position: relative;
    color: #C7312D;
    background-color: #FFF;
    border: solid 0px #FFF;
    padding: 4vw 0vw;
    line-height: 1;
    font-size: 3.8vw;
    text-align: center;
    display: inline-block;
    border-radius: 6vw;
    transition: background-color 0.3s 
    ease;
    letter-spacing: 0.3rem;
    font-weight: 600;
}
.btn02_::after {
    position: absolute;
    content: "";
    width: 3vw;
    height: 3vw;
    background-image: url(../images/common/arrow03.png);
    background-size: contain;
    background-repeat: no-repeat;
    margin-left: 2vw;
    top: 50%;
    right: 3vw;
    transform: translateY(-50%) translateX(0);
    transition: transform 0.3s ease;
}
.btn02_:hover::after {
    transform: translateY(-50%) translateX(5px);
}
.btn03{
    min-width: 60vw;
    position: relative;
    color: #fff;
    background-color: #000;
    padding: 4vw 0vw;
    line-height: 1;
    font-size: 3.8vw;
    text-align: center;
    display: inline-block;
    border-radius: 6vw;
    transition: background-color 0.3s ease;
    letter-spacing: 0.5rem;
    font-weight: 600;
}
.btn03::after {
    position: absolute;
    content: "";
    width: 3vw;
    height: 3vw;
    background-image: url(../images/common/arrow.png);
    background-size: contain;
    background-repeat: no-repeat;
    margin-left: 2vw;
    top: 50%;
    right: 3vw;
    transform: translateY(-50%) translateX(0);
    transition: transform 0.3s ease;
}
.btn03:hover::after {
    transform: translateY(-50%) translateX(5px);
}
.btn04{
    min-width: 60vw;
    position: relative;
    color: #FFF;
    background-color: #C7312D;
    padding: 2.608vw 13.038vw;
    line-height: 1;
    font-size: 3.8vw;
    text-align: center;
    display: inline-block;
    border-radius: 3.911vw;
    transition: background-color 0.3s ease;
    letter-spacing: 0.5rem;
    font-weight: 600;
    box-shadow: 0 6px 0 rgba(0, 0, 0, 1);
}
.btn04::after {
    position: absolute;
    content: "";
    width: 3.5vw;
    height: 3.5vw;
    background-image: url(../images/common/arrow.png);
    background-size: contain;
    background-repeat: no-repeat;
    margin-left: 2.608vw;
    top: 50%;
    right: 1.304vw;
    transform: translateY(-50%) translateX(0);
    transition: transform 0.3s ease;
}
.btn04:hover::after {
    transform: translateY(-50%) translateX(5px);
}
.btn05{
    min-width: 60vw;
    position: relative;
    color: #000;
    background-color: #fff;
    border: solid 1px #000;
    padding: 2.608vw 13.038vw;
    line-height: 1;
    font-size: 3.8vw;
    text-align: center;
    display: inline-block;
    border-radius: 3.911vw;
    transition: background-color 0.3s ease;
    letter-spacing: 0.5rem;
    font-weight: 600;
}
.btn05::after {
    position: absolute;
    content: "";
    width: 3.5vw;
    height: 3.5vw;
    background-image: url(../images/common/arrow03.png);
    background-size: contain;
    background-repeat: no-repeat;
    margin-left: 2.608vw;
    top: 50%;
    right: 1.304vw;
    transform: translateY(-50%) translateX(0);
    transition: transform 0.3s ease;
}
.btn05:hover::after {
    transform: translateY(-50%) translateX(5px);
}
.btn06{
    min-width: 60vw;
    position: relative;
    color: #000;
    background-color: #fff;
    border: solid 1px #000;
    padding: 2.608vw 13.038vw;
    line-height: 1;
    font-size: 3.8vw;
    text-align: center;
    display: inline-block;
    transition: background-color 0.3s ease;
    letter-spacing: 0.5rem;
    font-weight: 400;
    min-width: 49.544vw;
}
.btn06::after {
    position: absolute;
    content: "";
    width: 3.5vw;
    height: 3.5vw;
    background-image: url(../images/common/arrow03.png);
    background-size: contain;
    background-repeat: no-repeat;
    margin-left: 2.608vw;
    top: 50%;
    right: 1.304vw;
    transform: translateY(-50%) translateX(0);
    transition: transform 0.3s ease;
}
.btn06:hover::after {
    transform: translateY(-50%) translateX(5px);
}
.btn07{
    position: relative;
    color: #fff;
    background-color: #000;
    border-radius: 50px;
    padding: 20px 100px;
    line-height: 1;
    font-size: 20px;
    text-align: center;
    display: inline-block;
    transition: background-color 0.3s ease;
    letter-spacing: 0.5rem;
    font-weight: 400;
    min-width: 380px;
    left: 50%;
    transform: translate(-50%, -50%);
}
.btn07::after {
    position: absolute;
    content: "";
    width: 20px;
    height: 20px;
    background-image: url(../images/common/arrow.png);
    background-size: contain;
    background-repeat: no-repeat;
    margin-left: 20px;
    top: 50%;
    right: 10px;
    transform: translateY(-50%) translateX(0);
    transition: transform 0.3s ease;
}
.btn07:hover::after {
    transform: translateY(-50%) translateX(5px);
}
.btn08{
    position: relative;
    margin-right: 5vw;
    margin-bottom: 2vw;
    color: #000;
    line-height: 1;
    font-size: 3vw;
    text-align: center;
    display: inline-block;
    letter-spacing: 0.5rem;
    font-weight: 400;
    height: 100%;
}
.btn08::after {
    position: absolute;
    content: "";
    width: 1.5vw;
    height: 2vw;
    background-image: url(../images/common/arrow02.png);
    background-size: contain;
    background-repeat: no-repeat;
    margin-left: 5vw;
    top: 50%;
    right: -5vw;
    transform: translateY(-50%) translateX(0);
    transition: transform 0.3s ease;
}


/* header */
/* header{
    position: absolute;
    width: 100vw;
    background-color: #FFF;
    display: flex;
    margin: 0 auto;
    justify-content: space-between;
    align-items: center;
    z-index: 1;
} */
body.menu-open {
    overflow: hidden;
}

header .pc{
    display: none !important;
}

header .sp{
    display: flex !important;
    justify-content: space-between;
    align-items: center;
    width: 95%;
    margin: 1vw auto;
    z-index: 1001;
}

.logo{
    width: 35vw;
    margin: 1.5vw 0;
    z-index: 2;
}

.header_con ul img{
    width: auto;
    height: 9vw;
}

/* ★ navはデフォルト非表示、is-openで表示 */
header .sp nav.header_con{
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: #fff;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    padding-top: 20vw; /* ロゴ＋ハンバーガー分、適宜調整 */
    z-index: 1000;
        background-color:  #F5F5F5;
}

header .sp nav.header_con.is-open{
    display: block;
}

.header_con{
    width: 100%;
    text-align: right;
}

.header_con ul{
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    padding: 0 5vw 5vw;
    text-align: left;
}

.header_con .head_con02 li:first-child{
    border-left: 0px solid #B2B2B2 ;
}

.header_con .head_con02 li{
    font-size: 3.8vw;
    font-weight: bold;
    border-right: 0px solid #B2B2B2;
}

.header_con .head_con02 li a {
    display: block;
    padding: 3vw 3vw;
    font-size: 3.8vw;
    font-weight: bold;
    color: #000;
    text-decoration: none;
    transition: background-color 0.5s ease, color 0.5s ease;
}
.header_con .head_con02 .submenu li a {
    display: block;
    padding: 0 3vw;
    font-size: 3.2vw;
    font-weight: 400;
    color: #000;
    text-decoration: none;
    transition: background-color 0.5s ease, color 0.5s ease;
}
.header_con li::after {
    height: 0;
}


.header_con .head_con01 li:first-child{
    margin-right: 3.911vw;
}

/* アコーディオン */
.sp .head_con02 .submenu {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease;
    padding-left: 16px;
}

.sp .head_con02 .acc-item.acc-open .submenu {
    max-height: 500px;
}


.sp .head_con02 .acc-item > a {
    position: relative;
    display: block;
    padding-right: 32px;
}

.sp .head_con02 .acc-item:has(.submenu) > a::after {
    content: "＋";
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 14px;
}


.sp .head_con02 .acc-item.acc-open > a::after {
    content: "－";
}
header .sp nav.header_con{
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: #F5F5F5;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    padding-top: 3vw;
    z-index: 1000;
    background-color:  #F5F5F5;
}

header .sp nav.header_con.is-open{
    display: block;
}

.sp .head_con02 .submenu {
  display: none !important;
  padding-left: 4vw;
}

.sp .head_con02 .acc-item.acc-open > .submenu {
  display: block !important;
}

/* ハンバーガー本体 */
.hamburger {
  position: relative;
  width: 8vw;      /* お好みで調整 */
  height: 6vw;     /* お好みで調整 */
  cursor: pointer;
  z-index: 1002;   /* メニューより前に出しておく */
}

/* 三本線の共通スタイル */
.hamburger span {
  position: absolute;
  left: 0;
  right: 0;
  height: 2px;
  background: #000;
  border-radius: 2px;
  transition: transform 0.3s ease, top 0.3s ease, opacity 0.3s ease;
}

/* 上・真ん中・下の位置 */
.hamburger span:nth-child(1) {
  top: 0;
}
.hamburger span:nth-child(2) {
  top: 50%;
  transform: translateY(-50%);
}
.hamburger span:nth-child(3) {
  bottom: 0;
}

/* ▼ メニューオープン時（.is-open が付いたとき）の変形 */
.hamburger.is-open span:nth-child(1) {
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
}

.hamburger.is-open span:nth-child(2) {
  opacity: 0;
}

.hamburger.is-open span:nth-child(3) {
  bottom: auto;
  top: 50%;
  transform: translateY(-50%) rotate(-45deg);
}


.sp .head_con02 .submenu {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease;
    padding-left: 16px;
}

.sp .head_con02 .acc-item.acc-open .submenu {
    max-height: 500px;
}
/* ▼ SPメニューのアコーディオン表示 */
.sp .head_con02 .submenu {
  display: none;
  padding-left: 4vw;
}

.sp .head_con02 .acc-item.acc-open > .submenu {
  display: block;
}



  /* ハンバーガーメニュー開いたときのエリアをスクロール可能にする */
header .sp nav.header_con {
  display: none;
  position: fixed;
  top: 13vw;
  left: 0;
  right: 0;
  bottom: 0;
  background: #fff;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding-top: 0;
  z-index: 1000;
    padding-bottom: 20vw;
        background-color:  #F5F5F5;
}


/* ハンバーガーアイコン */
.hamburger {
  display: none;
  flex-direction: column;
  justify-content: space-between;
  width: 30px;
  height: 21px;
  cursor: pointer;
  z-index: 1;
}
.hamburger span {
  display: block;
  height: 3px;
  background: #D224E2;
}
.header_con {
  position: fixed;
  top: 0;
  right: 0;
  width: 100%;
  max-width: 100%;
  height: 100vh;
  background: #fff;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  transform: translateX(100%);
  transition: transform 0.4s ease;
  z-index: 999;
}
.header_con .btn01{
    width: 60vw;
    height: 12vw;
    margin: 0 auto;
    display: block;
}
.header_con.active {
  transform: translateX(0);
}
.hamburger {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    width: 8vw;
    height: 6vw;
    cursor: pointer;
    z-index: 1;
}
.hamburger span {
  height: 0.7vw;
  background: #C7312D;
  display: block;
}
.head_con02 {
  flex-direction: column;
  text-align: center;
  padding: 0;
  margin: 0;
  width: 100%;
}
.head_con02 li {
  list-style: none;
  padding: 15px 0;
  border-top: 0.5vw solid #ddd;
  width: 100%;
}
.head_con02 li:first-child {
  border-top: 0 solid #ddd;
}
.head_con02 li a {
  display: block;
  color: #C7312D;
  text-decoration: none;
}
.close_btn {
  position: absolute;
  top: 20px;
  right: 20px;
  font-size: 30px;
  cursor: pointer;
  color: #C7312D;
}
header .hum{
    display: flex;
    align-items: center;
}
header .hum p{
    font-size: 2.5vw;
    margin-right: 3vw;
    color: #919191;
}
/* footer */
.fotter_contact{
    display: flex;
    align-items: center;
    justify-content: space-between;
    color: #FFF;
    height: 40vw;
    background-color: #C7322C;
}
.fotter_contact_inner{
    width: 92vw;
    margin: 0 auto;
}
.fotter_contact div{
        display: flex;
        align-items: center;
        line-height: 1;
        justify-content: space-between;
        flex-direction: column;
}
.fotter_contact h2{
    font-size: 12vw;
    font-weight: bold;
    margin-right: 0;
    margin-bottom: 3vw;
}
.fotter_contact p{
    font-size: 2.608vw;
}
.fotter_contact_inner a{
    position: relative;
    display: flex;
    background-color: #C7322C;
    font-size: 3.4vw;
    color: #FFF;
    width: 30vw;
    height: 8vw;
    align-items: center;
    justify-content: center;
}
.fotter_con{
    width: 92vw;
    margin: 5vw auto 6vw;
    padding-bottom: 5vw;
    border-bottom: solid 1px #ccc;
    display: flex;
    justify-content: space-between;
    flex-direction: column;
}
.footer_adress{
    width: 100vw;
    order: 2;
}
.footer_logo{
    width: 60vw;
    height: auto;
    margin-bottom: 6vw;
}
.fotter_adress .title{
    font-size: 2.6vw;
    font-weight: bold;
    line-height: 1.2;
    margin-bottom: 0.5vw;
}
.fotter_adress .adress{
    font-size: 2.6vw;
    font-weight: 400;
    line-height: 1.2;
    margin-bottom: 2vw;
}
.fotter_link{
    width: 92vw;
    margin: 0 auto 5vw;
    padding-bottom: 0;
    border-bottom: solid 0px #ccc;
    display: flex;
    flex-direction: column;
    order: 1;
}
.fotter_link ul{
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 3vw;
    padding-bottom: 2vw;
    border-bottom: 1px solid #CCCCCC;
}
.fotter_link ul:nth-child(4){
    width: 100%;
}
.fotter_link ul:nth-child(8){
    width: 100%;
}
.fotter_contact_inner a:first-child{
    margin-right: 2.608vw;
}
.fotter_contact_inner a::after{
    position: absolute;
    content: "";
    width: 2.5vw;
    height: 2.5vw;
    background-image: url(../images/common/arrow.png);
    background-size: contain;
    background-repeat: no-repeat;
    margin-left: 2vw;
    top: 50%;
    right: 3vw;
    transform: translateY(-50%) translateX(0);
    transition: transform 0.3s ease;
}
.fotter_link ul li:first-child{
    width: 100%;
    font-size: 4vw;
    font-weight: bold;
    color: #000;
    margin-right: 0;
    margin-bottom: 2vw;
    color: #000;
}
.fotter_link ul li{
    position: relative;
    font-size: 3.2vw;
    margin-right: 8vw;
    margin-bottom: 1vw;
    color: #888888;
}
.fotter_link ul li:first-child::after{
    position: absolute;
    content: "";
    right: 0;
}
.fotter_link ul li:last-child::after{
    position: absolute;
    content: "";
    right: 0;
}
.fotter_link ul li::after{
    position: absolute;
    content: "/";
    right: -4vw;
}
.fotter_other{
    display: flex;
    width: 92vw;
    margin: 0 auto 5vw;
    align-items: flex-start;
    justify-content: space-between;
    flex-direction: column;
}
.fotter_other_left{
    display: flex;
    font-size: 2.4vw;
    gap: 2vw;
    flex-direction: column;
    order: 2;
}
.fotter_other_left div{
    display: flex;
    gap: 5vw;
}

.fotter_other_right{
    width: 100%;
    margin-bottom: 5vw;
    order: 1;
}

.fotter_adress{
    font-size: 2.4vw;
    font-weight: bold;
    line-height: 1.2;
}
.fotter_adress p:nth-child(2){
    margin-bottom: 2vw;
}
.fotter_quality{
    width: 39.113vw;
    display: flex;
    justify-content: space-between;
}
.fotter_quality li{
    width: 10.43vw;
    text-align: center;
    margin: 0 auto;
}
.fotter_quality li div{
    width: 10.43vw;
    height: 9.126vw;
}
.fotter_quality li img{
    width: 60%;
    height: auto;
}
.fotter_quality li:first-child img{
    width: 100%;
    height: auto;
}
.fotter_quality li p{
    font-size: 1.304vw;
    white-space: nowrap;
    height: 6.519vw;
}
.fotter_copy{
    width: 100%;
    background-color: #000;
    color: #FFF;
    padding: 1.956vw;
}
.fotter_copy_con{
    display: flex;
    width: 137.549vw;
    margin: 0 auto;
    align-items: center;
    justify-content: space-between;
}
.fotter_copy ul{
    display: flex;
    font-size: 1.825vw;
    font-weight: 200;
}
.fotter_copy ul li{
    margin-right: 3.911vw;
}
.copyright{
    font-size: 1.304vw;
    margin-right: 1.304vw;
    font-weight: 200;
}
/* /footer */


/*==================================================
スライダーのためのcss
===================================*/

.slider {/*横幅94%で左右に余白を持たせて中央寄せ*/
    width: 172.099vw;
     margin:0 -5.215vw;
 }

 .slider img {
    width: 51.108vw;/*スライダー内の画像を横幅100%に*/
     height:auto;
 }

.slider p{
    width: 45.632vw; 
    font-size: 3.3vw;
    padding-top: 1.956vw;
    margin: 0 auto;
}
 
 /*slickのJSで書かれるタグ内、スライド左右の余白調整*/
 
 .slider .slick-slide {
     margin: 0px;
     width: 392px!important;
     height: 51.76vw;
     margin-right: 6.519vw;
 }
 
 /*矢印の設定*/
 
 /*戻る、次へ矢印の位置*/
 .slick-prev,
 .slick-next {
     position: absolute;/*絶対配置にする*/
     top: 35%;
     cursor: pointer;/*マウスカーソルを指マークに*/
     outline: none;/*クリックをしたら出てくる枠線を消す*/
     border-top: 0px solid #666;/*矢印の色*/
     border-right: 0px solid #666;/*矢印の色*/
     height: 1.956vw;
     width: 1.956vw;
 }
 
 .slick-prev {/*戻る矢印の位置と形状*/
    /* background-image: url("../images/article_img/slick-prev.png"); */
    background-size: cover;
    top: 50%;
    transform: translateY(-50%);
    left: 2vw;
    width: 2vw;
    height: 4vw;
    transition: 0.5s;
    z-index: 5;
 }

.slick-prev:hover {
    transition: 0.5s;
   left: 2vw;
}

 .slick-next {/*次へ矢印の位置と形状*/
    /* background-image: url("../images/article_img/slick-next.png"); */
    background-size: cover;
    top: 50%;
    transform: translateY(-50%);
    right: 2vw;
    width: 2vw;
    height: 4vw;
    transition: 0.5s;
    z-index: 5;
 }

.slick-next:hover {
    transition: 0.5s;
    right: 2vw;
}

 /*ドットナビゲーションの設定*/
 .slick-dots {
    display: none;
    text-align:center;
    margin:0;
}

.slick-dots li {
    display: none;
    display:inline-block;
    margin:0 1.304vw;
}

.slick-dots button {
    display: none!important;
    color: transparent;
    outline: none;
    width:1.304vw;/*ドットボタンのサイズ*/
    height:1.565vw;/*ドットボタンのサイズ*/
    display:block;
    border-radius:50%;
    background:#000c17;/*ドットボタンの色*/
    border: none;
}

.slick-dots .slick-active button{
    display: none;
    background:#20374A;/*ドットボタンの現在地表示の色*/
}


.slick-track{
    display: flex!important;
}



/*==================================================
スライダーのためのcss
===================================*/
.slider_bussinesscontent {/*横幅94%で左右に余白を持たせて中央寄せ*/
    width: 138.201vw;
     margin:0 -5.215vw 19.557vw;
 }
 .slider_bussinesscontent img {
    width: 43.286vw;/*スライダー内の画像を横幅100%に*/
     height:auto;
 }
.slider_bussinesscontent p{
    width: 45.632vw;
    font-size: 2.086vw;
    padding-top: 1.956vw;
    margin: 0 auto;
}
 /*slickのJSで書かれるタグ内、スライド左右の余白調整*/
 .slider_bussinesscontent .slick-slide {
     width: 332px!important;
     height: auto;
     margin-right: 3.129vw;
}
 /*矢印の設定*/
 .slider_bussinesscontent .slick-prev {/*戻る矢印の位置と形状*/
    position: absolute;
    background-image: url(../images/bussinesscontent/arrow_prev.png);
    background-size: cover;
    top: auto;
    bottom: -6.519vw;
    right: 0;
    left: 49.544vw;
    width: 2.216vw;
    height: 3.259vw;
    transition: 0.5s;
    z-index: 2;
}
.slider_bussinesscontent .slick-next {/*次へ矢印の位置と形状*/
    position: absolute;
    background-image: url("../images/bussinesscontent/arrow_next.png");
    background-size: cover;
    top: auto;
    bottom: -6.519vw;
    right: 49.544vw;
    width: 2.216vw;
    height: 3.259vw;
    transition: 0.5s;
    z-index: 2;
}
/*ドットナビゲーションの設定*/
.slider_bussinesscontent .slick-dots {
    display: block;
    text-align: center;
    margin: 0;
    position: relative;
    top: 7.171vw;
}
.slider_bussinesscontent .slick-dots li {
    display: none;
    display:inline-block;
    margin:0 1.304vw;
    border: solid 0px #000000;
}
.slider_bussinesscontent .slick-dots button {
    display: block;
    color: transparent;
    outline: none;
    width:1.304vw;/*ドットボタンのサイズ*/
    height:1.565vw;/*ドットボタンのサイズ*/
    display:block;
    border-radius:50%;
    background:#A69F9A;/*ドットボタンの色*/
    border: none;
}
.slider_bussinesscontent .slick-dots .slick-active button{
    display: block;
    background:#C7322C;/*ドットボタンの現在地表示の色*/
}
.slider_bussinesscontent .slick-track{
    display: flex!important;
}

/*==================================================
スライダーのためのcss
===================================*/
.office_slider {/*横幅94%で左右に余白を持たせて中央寄せ*/
    width: 177.314vw;
     margin:0 -5.215vw 19.557vw;
 }
 .office_slider img {
    width: 61.278vw;/*スライダー内の画像を横幅100%に*/
     height:auto;
 }
.office_slider p{
    width: 45.632vw;
    font-size: 2.086vw;
    padding-top: 1.956vw;
    margin: 0 auto;
}
 /*slickのJSで書かれるタグ内、スライド左右の余白調整*/
 .office_slider .slick-slide {
     width: 470px!important;
     height: auto;
     margin-right: 3.129vw;
}
 /*矢印の設定*/
 .office_slider .slick-prev {/*戻る矢印の位置と形状*/
    position: absolute;
    background-image: url(../images/bussinesscontent/arrow_prev.png);
    background-size: cover;
    top: auto;
    bottom: -6.519vw;
    right: 0;
    left: 62.581vw;
    width: 2.216vw;
    height: 3.259vw;
    transition: 0.5s;
    z-index: 2;
}
.office_slider .slick-next {/*次へ矢印の位置と形状*/
    position: absolute;
    background-image: url("../images/bussinesscontent/arrow_next.png");
    background-size: cover;
    top: auto;
    bottom: -6.519vw;
    right: 62.581vw;
    width: 2.216vw;
    height: 3.259vw;
    transition: 0.5s;
    z-index: 2;
}
/*ドットナビゲーションの設定*/
.office_slider .slick-dots {
    display: block;
    text-align: center;
    margin: 0;
    position: relative;
    top: 7.171vw;
}
.office_slider .slick-dots li {
    display: none;
    display:inline-block;
    margin:0 1.304vw;
    border: solid 0px #000000;
}
.office_slider .slick-dots button {
    display: block;
    color: transparent;
    outline: none;
    width:1.304vw;/*ドットボタンのサイズ*/
    height:1.565vw;/*ドットボタンのサイズ*/
    display:block;
    border-radius:50%;
    background:#A69F9A;/*ドットボタンの色*/
    border: none;
}
.office_slider .slick-dots .slick-active button{
    display: block;
    background:#C7322C;/*ドットボタンの現在地表示の色*/
}
.office_slider .slick-track{
    display: flex!important;
}



/* 下層ページ */
.lower_title{
    position: relative;
    width: 100vw;
    height: 98vw;
}
.lower_title picture{
    position: absolute;
    top: 40vw;
    right: 0;
    display: block;
    width: 95vw;
    height: 58vw;
    overflow: hidden;
    z-index: 1;
}
.lower_title picture img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.lower_title .main_copy{
    width: 95vw;
    height: 55vw;
    background-color: #C7312D;
    position: relative;
}
.lower_title .main_copycon{
    width: 95vw;
    padding: 0 0 0 10vw;
}
.lower_title .main_copyconin{
    position: absolute;
    top: 40%;
    transform: translateY(-50%);
    line-height: 1;
    color: #FFF;
}
.lower_title .main_copy h1{
    position: relative;
    font-size: 6.5vw;
    letter-spacing: 0.5vw;
    padding-left: 5vw;
    margin-bottom: 3.5vw;
    font-weight: 500;
}
.lower_title .main_copy h1::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 0.75vw;
  height: 100%;
  background-color: #fff;
}
.main_copyconin .en{
    font-style: normal;
}
.lower_title .main_copy p{
    font-size: 3vw;
    letter-spacing: 0.13vw;
}

/* 下層ページ縮小 */
.lower_title_low{
    position: relative;
    width: 100vw;
    height: 35vw;
}
.lower_title_low .main_copy{
    width: 100vw;
    height: 35vw;
    background-color: #C7312D;
    position: relative;
}
.lower_title_low .main_copycon{
    position: absolute;
    top: 50%;
    padding: 0 0 0 10vw;
    transform: translateY(-50%);
    line-height: 1;
    color: #FFF;
}
.lower_title_low .main_copycon_{
    top: 55%;
}
.lower_title_low .main_copy h1{
    position: relative;
    font-size: 6.5vw;
    letter-spacing: 0.5vw;
    padding-left: 5vw;
    margin-bottom: 2vw;
    font-weight: 500;
    line-height: 1.2;
}
.lower_title_low .main_copy_ h1::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
width: 0.75vw;
  height: 100%;
  background-color: #fff;
}
.lower_title_low .main_copy h1::before{
    content: "";
    position: absolute;
    top: 1.5vw;
    left: 0;
    width: 0.75vw;
    height: 90%;
    background-color: #fff;
}
.lower_title_low .main_copy .en{
    font-style: normal;
}
.lower_title_low .main_copy p{
        font-size: 3vw;
        letter-spacing: 0.13vw;
}
.lower_title_low .main_copy .pan a {
    color: #FFF;
}
.lower_title_low .main_copy .pan{
    width: 90vw;
    height: fit-content;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    margin: 0 auto;
    bottom: 0;
    color: #FFF;
    font-size: 2.3vw;
}

/* 下層ページ縮小写真付き */
.lower_title_lowp{
    position: relative;
    width: 100vw;
    height: 50vw;
}
.lower_title_lowp picture{
    position: absolute;
    top: 0;
    right: 0;
    display: block;
    width: 45vw;
    height: 50vw;
    overflow: hidden;
    z-index: 1;
}
.lower_title_lowp picture img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.lower_title_lowp .main_copy{
    width: 100vw;
    height: 50vw;
    background-color: #C7312D;
    position: relative;
}
.lower_title_lowp .main_copycon{
    position: absolute;
    top: 45%;
    padding: 0 0 0 7vw;
    transform: translateY(-50%);
    line-height: 1;
    color: #FFF;
}
.lower_title_lowp .main_copy h1{
    position: relative;
    font-size: 6vw;
    letter-spacing: 0.5vw;
    padding-left: 3.5vw;
    margin-bottom: 2vw;
    font-weight: 500;
    line-height: 1.2;
}
.lower_title_lowp .main_copy h1::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
width: 0.75vw;
  height: 100%;
  background-color: #fff;
}
.lower_title_lowp .main_copy .en{
    font-style: normal;
}
.lower_title_lowp .main_copy p{
    font-size: 2.3vw;
    letter-spacing: 0.13vw;
}
.lower_title_lowp .main_copy .pan a {
    color: #FFF;
}
.lower_title_lowp .main_copy .pan{
    width: 90vw;
    height: fit-content;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    margin: 0 auto;
    bottom: 0;
    color: #FFF;
    font-size: 2.3vw;
}
/* 下層ページ縮小パンクズのみ */
.lower_title_pan{
    position: relative;
    width: 100vw;
    height: 16.297vw;
}
.lower_title_pan{
    width: 100vw;
    position: relative;
}
.lower_title_pan .pan{
    width: 90vw;
    height: fit-content;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    margin: 0 auto;
    top:0;
    color: #FFF;
    font-size: 2.3vw;
}

/* 下層ページコピー付き */
.lower_title_copy{
    position: relative;
    width: 100vw;
    height: auto;
}
.lower_title_copy picture{
    position: static;
    top: 0;
    right: 0;
    display: block;
    width: 100%;
    height: 55vw;
    overflow: hidden;
    z-index: 1;
}
.lower_title_copy picture img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.lower_title_copy .main_copy{
    width: 100vw;
    height: auto;
    background-color: #C7312D;
    position: relative;
}
.lower_title_copy .main_copycon{
    width: 90vw;
    margin: 0 auto;
    padding: 5vw 0 6vw;
}
.lower_title_copy .main_copyconin{
    position: static;
    width: 90vw;
    top: 21vw;
    transform: translateY(0);
    line-height: 1;
    color: #FFF;
    display: flex;
    flex-direction: column;
}
.lower_title_copy .main_copy h1{
    width: 100%;
    position: relative;
    font-size: 6vw;
    letter-spacing: 0.5vw;
    margin-bottom: 2vw;
    font-weight: 500;
    padding-left: 3vw;
    order: 1;
}
.lower_title_copy .main_copy h1::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 0.75vw;
  height: 100%;
  background-color: #fff;
}
.main_copyconin .en{
    font-style: normal;
}
.lower_title_copy .main_copy p{
    width: 90vw;
    font-size: 2.8vw;
    font-weight: 300;
    line-height: 1.8;
    letter-spacing: 0.13vw;
    margin-bottom: 1vw;
    order: 2;
}
.lower_title_copy .sp{
    width: 90vw;
    font-size: 3.8vw;
    margin: 10vw auto;
}

.lower_title_copy .sp.lower_title_copy_main{
    width: 100vw;
    margin: 0 auto;
}




/* パンクズ */
.pan{
    font-size: 2.3vw;
    font-weight: 300;
    margin: 0 auto;
    display: flex;
    color: #FFF;
    top: 3vw;
    position: relative;
}
.pan_service{
    top: -57vw;
}
/* .pan_service li a{
    box-shadow: 0 8px 24px rgba(0,0,0,0.7);
} */
.pan li{
    margin-right: 1.5vw;
}
.pan a{
    text-decoration: underline;
}



.fadein_top {
  opacity: 0;
  transform: translateY(0px);
  transition: opacity 1s ease, transform 1s ease;
}

.fadein_top.active {
  opacity: 1;
  transform: translateY(0);
}


.fadein {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 1s ease, transform 1s ease;
}

.fadein.active {
  opacity: 1;
  transform: translateY(0);
}



}


