@charset "UTF-8";
/*!
Theme Name: Cocoon Child
Description: Cocoon専用の子テーマ
Theme URI: https://wp-cocoon.com/
Author: わいひら
Author URI: https://nelog.jp/
Template:   cocoon-master
Version:    1.1.2
*/
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;700;900&family=Noto+Serif+JP:wght@400;700&display=swap");
/* font-family: 'Noto Sans JP', sans-serif; */


html { overflow-x: hidden; scroll-behavior: smooth; }
body{ margin:0px; padding:0px; font-family: 'Noto Sans JP', sans-serif; font-weight:400; color: #000000; overflow-x:hidden; background-color: #fff; }
ul {padding: 0; margin: 0;}
h1,h2,h3,h4,h5,h6{ margin:0px; padding:0px; font-weight:normal; line-height: auto;}
p{ margin:0px; padding:0px; }
a{ text-decoration:none; -webkit-transition: all 0.3s linear; -moz-transition: all 0.3s linear; -o-transition: all 0.3s linear; -ms-transition: all 0.3s linear; transition: all 0.3s linear;} 
a:hover, a:focus, a:active{ outline:none; text-decoration:none; }
input{ -webkit-transition: all 0.3s linear; -moz-transition: all 0.3s linear; -o-transition: all 0.3s linear; -ms-transition: all 0.3s linear; transition: all 0.3s linear;} 
button { outline: none; border: none; cursor: pointer; font-family: 'Noto Sans JP', sans-serif; }

.wrapper{ margin:0px auto;}
.container-fluid { max-width: 1136px; margin: auto; position: relative; z-index: 1; }
.pc_show { display: block !important; }
.pc_show_inline { display: inline-block !important; }
.sp_show { display: none !important; }
.sp_show_inline { display: none !important; }
.sp_show_flex { display: none !important; }
:root {
  --fs_menu: 16px
}

p { font-size: 15px; line-height: 29px; }
h1 { font-size: 38px; line-height: 65px; font-weight: 900; color: #0F4539; }
h2 { font-size: 37px; line-height: 65px; font-weight: 900; color: #0F4539; }
h3 { font-size: 31px; line-height: 45px; font-weight: 700; color: #0F4539; }
h4 { font-size: 26px; font-weight: 900; color: #0F4539; }
h5 { font-size: 20px; font-weight: 900; color: #0F4539; }

.bg-green { background-color: #ECF5E3; }
.fc-main { color: #1A1A1A; }
.fc-w { color: #fff; }
.fc-black { color: #000000; }
.fc-dark-grey { color: #666666 !important; }
.fc-grey { color: #333; }
.fc-grey1 { color: #333; }
.fc-grey2 { color: #333333 !important; }
.fc-pink { color: #813771; }
.fc-green { color: #0F4539; }

.title-decor { padding: 0 20px; margin-bottom: 35px; position: relative; background-color: #0F4539; width: fit-content; }
.title-decor p { font-size: 16px; font-weight: 900; color: #fff; }
.title-decor::after { width: 5000px; height: 1px; left: 100%; top: 50%; content: ''; position: absolute; background-color: #0F4539; }
.title { padding-bottom: 40px; }
.title p { font-size: 15px; font-weight: 900; color: #ADB1AA; }
.sub-title { display: flex; align-items: center; margin-bottom: 25px; padding-bottom: 10px; border-bottom: 1px solid #0F4539; }
.sub-title img { width: 45px; height: 37px; }
.sub-title h3 { padding-left: 10px; }
.pdbt-60 { padding-bottom: 60px; }
.pdbt-75 { padding-bottom: 75px; }
.pdbt-30 { padding-bottom: 30px; }
.pdbt-10 { padding-bottom: 10px; }
.pdbt-0 { padding-bottom: 0 !important; }
.pdv20 { padding: 20px 0; }
.wd49 { width: 49%; }
.wd48 { width: 48%; }
.wd45 { width: 45%; }
.wd20 { width: 20%; }
.wd23 { width: 22.75%; }
.wd24 { width: 24%; }
.wd30 { width: 30%; }
.wd60 { width: 60%; }
.fs19 { font-size: 19px; font-weight: 500; }
.fs16 { font-size: 16px; }
.fs13 { font-size: 13px; line-height: 20px; }
.fs25 { font-size: 25px; line-height: 45px; }
.fs28 { font-size: 28px; }
.fwb { font-weight: 700; }
.fwr { font-weight: 400 !important; }
.fac { text-align: center; }
.lh22 { line-height: 22px; }
.pr { position: relative; }
.alc { align-items: center !important; }
.separate { border-bottom: 1px solid #333333; }
.ls05 { letter-spacing: -0.1px; }

.owl-theme .owl-dots .owl-dot { display: none; }
.owl-carousel .owl-stage-outer { overflow: visible; }
.carousel { padding: 75px 0; }
.carousel .item { padding: 20px; border: 1px solid #000; box-sizing: border-box; }
.carousel .item .item-title { width: 146px; height: 46px; top: -5px; left: 50%; position: absolute; opacity: 0.5; background-color: #0F4539; position: absolute; display: flex; align-items: center; justify-content: center; transform-origin: 50% 50%; }
.item-title.r1 { transform: rotate(3.83deg) translateX(-50%); }
.item-title.r2 { top: -17px !important; transform: rotate(-5.35deg) translateX(-50%); }
.item-title.r3 { transform: rotate(7.44deg) translateX(-50%); }
.item-title.r4 { transform: rotate(3.83deg) translateX(-50%); }
.item-title.r5 { transform: rotate(-5.35deg) translateX(-50%); }

.common-button { width: 329px; height: 63px;  margin: auto; display: flex; align-items: center; justify-content: center; position: relative; background-color: #813771; z-index: 2; }
.common-button p { font-size: 16px; font-weight: 500; color: #fff; }
.common-button img { width: 11px; height: 14px; top: 50%; left: 22px; position: absolute; transform: translateY(-50%); }
/*--------------- HEADER_START --------------*/
#header{ margin:0px; position:fixed; width:100%; top:0; z-index:9999; background-color: #fff; }
.header-in-hp{ display: block; align-items: center; padding: 0;}
.header_middle_hp{ padding:17px 0 17px 28px; height: 100px; box-sizing: border-box; display: flex; align-items: center; justify-content: space-between; }
.header-logo-pc img { width: 365px; height: 74px; }

.navigation{ display: flex; align-items: center; justify-content: center; position: relative; } 
.navigation .nav-text { width: 546px; top: 5px; right: 210px; position: absolute; }
.navigation .nav-text p { font-size: 14px; line-height: 25px; font-weight: 500; }
.navbar{padding:0px; position:static; align-items:center;}
.navbar-nav{ display: flex; align-items:center; justify-content: space-between; }
.navbar-nav .nav-item{ margin-top: 30px; font-weight:500; font-size:14px; line-height:19px; display:inline-block; padding:0 15px ; }
.navbar-nav .nav-link{ padding:0; position:relative; text-align:center; display: flex; align-items: center; }
.navbar-nav .nav-link img { width: 4px; height: 20px; }
.navbar-nav .nav-link p { font-size: var(--fs_menu); font-weight: 500; line-height: 28px; padding-left: 16px; color: #1A1A1A; }
.navbar-nav .nav-item:nth-child(5) .nav-link { width: 180px; height: 100px; margin-top: -17px; margin-bottom: -17px; display: flex; justify-content: center; background-color: #813771; }
.navbar-nav .nav-item:nth-child(5) .nav-link p { color: #fff; padding-left: 0; }
.navbar-nav .nav-item:nth-child(5) { margin-top: 0; padding-right: 0; }

.hide-desktop-hp{ display:none !important; }
.header-right-hp{ display:flex; align-items:center; padding-left:8px; padding-top:0px; }
.mobile-menu-icon-hp{ margin:0px; padding:0px; float:right; display:none;  width:22px; height:22px; text-align:center; cursor:pointer; }
.menu-toggle-btn{ margin:21px 0px 20px 0px; cursor:pointer; width:30px; height:19px; padding:0; position:relative; z-index:999999999; }
.menu-toggle-btn span{ background:#000; display:block; width:30px; height:2px; border-radius:0px; margin-bottom:6px; -webkit-transition: all 0.5s linear; transition: all 0.3s linear;}
.menu-toggle-btn span:last-child{ margin-bottom:0px;}
.menu-toggle-btn span:nth-child(2){ width:100%; }
.menu-toggle-btn span:nth-child(3){ width:100%; }

.menu-toggle-btn.open span:nth-child(1), .menu-toggle-btn.open span:nth-child(3){ transform: translate(0px, 0px) rotate(-45deg) scalex(1); margin:0; width:100%; }
.menu-toggle-btn.open span:nth-child(2){ height:0; margin:0;}
.menu-toggle-btn.open span:nth-child(3){ transform: translate(0px, -2px) rotate(45deg) scalex(1);}
.overlay-mobile-menu-hp{ position:fixed; top:0; left:0; width:100%; height:100%; background:rgba(255,255,255,0.6); z-index: 999; opacity:0; z-index:-11; -webkit-transition: all 0.3s linear; -moz-transition: all 0.3s linear; -o-transition: all 0.3s linear; -ms-transition: all 0.3s linear; transition: all 0.3s linear; } 
.menu-text-hp{ font-size:10px; color:#fff; font-weight:700; line-height: 7px; margin: 0 0 0 -5px; position:absolute; top:25px; }
.menu-toggle-btn.open .menu-text-hp{  }
.show_menu .overlay-mobile-menu-hp{ background:rgba(29,56,53,0.9); opacity:1; z-index:991; }
.show_menu #header{ background:#fff; }

.header-absolute-hp{ position:absolute; left:53px; top:50%; z-index:3; }

.fix-header #header{ position:fixed; background:#fff;}
/*--------------- HEADER_END --------------*/
/* TOP_MAINVIEW_START */
.top-mv { margin-top: 99px; position: relative; }
.top-mv .bg-img { width: 100%; }
.top-mv .bg-img img { width: 100%; }
.top-mv .content { width: 100%; top: 50%; left: 50%; transform: translate(-50%, -50%); position: absolute; display: flex; flex-direction: column; align-items: center; justify-content: center; z-index: 1; }
.top-mv .content .mv-logo { margin-top: 50px; }
.top-mv .content .mv-logo img { width: 291px; height: 209px; }
.top-mv .content .catch .text { padding: 15px 35px; transform: skewX(-22.5deg); background-color: #fff; width: fit-content; }
.top-mv .content .catch .text h1 { transform: skewX(22.5deg); }
.top-mv .content .catch .text h1 span { color: #813771; }
.top-mv .content .catch .text:nth-child(1) { margin-top: 60px; }
.top-mv .content .catch .text:nth-child(2) { margin-top: 15px; margin-left: 50px; }
.top-mv .decor1 { width: 496px; height: 359px; top: -82px; left: -88px; position: absolute; background-image: url(images/bg-decor1.svg); background-size: contain; background-repeat: no-repeat; opacity: 0.65; transform: rotate(20deg); }
.top-mv .decor2 { width: 570px; height: 237px; bottom: -20px; right: -170px; position: absolute; background-image: url(images/bg-decor2.svg); background-size: contain; background-repeat: no-repeat; opacity: 0.65; }
/* TOP_MAINVIEW_END */
.common-section { padding: 75px 0; position: relative; }
.common-title { text-align: center; padding-bottom: 75px; }
.common-title p { font-weight: 900; color: #ADB1AA; }
.flex-3-wrapper { display: flex; align-items: center; }
.sp-arnd { justify-content: space-around; }
.sp-btwn { justify-content: space-between; }
.flex-3-wrapper .item { width: 30%; }
.flex-2-wrapper { display: flex; align-items: flex-start; justify-content: space-between; flex-wrap: wrap; }
.flex-2-wrapper .item.left { margin-left: calc(50% - 50vw); width: calc(-10% + 50vw); }
.flex-2-wrapper.rs .item.left { margin-right: calc(50% - 50vw); width: calc(-10% + 50vw); }
.flex-2-wrapper .item.left img { width: 100%; }
.flex-2-wrapper .item.right { width: 51%; }
.rs { flex-direction: row-reverse; }
.common-decor-bl { width: 543px; height: 317px; bottom: -45px; left: -45px; position: absolute; background-image: url(images/bg-decor1.svg); z-index: 0; background-repeat: no-repeat; }
.common-decor-tr { width: 559px; height: 258px; top: 15px; right: -127px; position: absolute; background-image: url(images/bg-decor3.svg); z-index: 0; background-repeat: no-repeat; }
.common-decor-br { width: 559px; height: 258px; bottom: 760px; right: -127px; position: absolute; background-image: url(images/bg-decor4.svg); z-index: 0; background-repeat: no-repeat; }
.sub-item .text p { letter-spacing: -0.5px; }
.map iframe { width: 100%; height: 450px; }
.company-logo { padding-bottom: 35px; }
.company-logo img { width: 405px; height: 95px; }
.detail-item { display: flex; width: 100%; }
.detail-item .item-label { padding: 20px 0; border-bottom: 1px solid #95b9b2; }
.detail-item .item-label p { font-weight: 700; }
.detail-item .item-text { padding: 20px 0; flex: 1; border-bottom: 1px solid #95b9b2; }
footer { padding: 75px; position: relative; text-align: center; }
footer p { color: #333333 !important; }
footer .footer-description { padding-bottom: 40px; }
footer .footer-logo { padding-bottom: 40px; }
footer .footer-logo img { width: 460px; height: 108px; }
footer .footer-menu { width: 543px; margin: auto; display: flex; border-top: 1px solid #333333; justify-content: space-around; position: relative; z-index: 2; }
footer .footer-menu p { color: #1a1a1a; }
footer .footer-address { padding-bottom: 30px; }
footer .footer-decor1 { width: 398px; height: 202px; bottom: 0; left: -50px; position: absolute; background-image: url(images/footer-decor1.svg); background-repeat: no-repeat; background-size: contain; }
footer .footer-decor2 { width: 398px; height: 202px; bottom: -34px; right: -50px; position: absolute; background-image: url(images/footer-decor2.svg); background-repeat: no-repeat; background-size: contain; }
.copyright { padding: 15px 0; background-color: #813771; text-align: center; }

/* INNERPAGE_START */
.inner-page-title p { font-size: 26px; line-height: 46px; font-weight: 900; color: #fff; }
.flex-wrapper { display: flex; flex-wrap: wrap; }
.flex-wrapper .item.wd23 { margin-right: 3%; margin-bottom: 45px; }
.flex-wrapper .item.wd23:nth-child(4n) { margin-right: 0; }
.img-con1 { width: 100%; padding: 15px 0; overflow: hidden; }
.img-con1 img { width: 258px; height: 258px; object-fit: cover; }
.img-con2 { width: 100%; padding: 15px 0; overflow: hidden; }
.img-con2 img { width: 523px; height: 356px; object-fit: cover; }
.img-con3 { width: 100%; padding: 15px 0; overflow: hidden; }
.img-con3 img { width: 348px; height: 348px; object-fit: cover; }
.img-con4 { width: 100%; overflow: hidden; }
.img-con4 img { width: 177px; height: 119px; object-fit: cover; }
.img-con5 { width: 100%; overflow: hidden; }
.img-con5 img { width: 272px; height: 218px; object-fit: cover; }
.img-con6 { width: 100%; overflow: hidden; }
.img-con6 img { width: 548px; height: 407px; object-fit: cover; }
.flex-item1 { margin-top: 20px; padding: 10px 15px; border-radius: 5px; box-shadow: 0px 0px 5px #33333380; display: flex; align-items: center; justify-content: space-between; box-sizing: border-box; }
.flex-item2 { margin-top: 20px; padding: 10px 15px; border-radius: 5px; box-shadow: 0px 0px 5px #33333380; display: flex; align-items: center; justify-content: space-between; box-sizing: border-box; }
.flex-item2 p:nth-child(2) { padding: 0 10px; border-radius: 14.5px; border: 1px solid #333333; }
.flex-item3 { display: flex; align-items: center; justify-content: space-between; }
.flex-item4 { padding: 0px 20px; display: flex; justify-content: space-between; position: relative; }
.flex-item4::before { width: 10px; height: 10px; border-radius: 5px; top: 15px; left: -5px; transform: translateY(-50%); background-color: #0F4539; content: ''; position: absolute; }
.flex-item4 p:nth-child(1) { width: 30%; }
.flex-item4 p:nth-child(2) { width: 70%; }
.col-wrapper { display: flex; flex-direction: column; align-items: center; justify-content: space-between; }
/* .company-message { padding-top: 100px; width: 100%; text-align: right; } */
.company-message { bottom: 0; right: 50%; position: absolute; }
.company-message img { width: 330px; height: 31px; }
.history-decor { border-left: 1px solid #0F4539; position: relative; }
.history-decor::after { width: 10px; height: 10px; top: 0; left: -5px; content: ''; background-color: #ECF5E3; position: absolute; }
.history-decor::before { width: 10px; height: 10px; bottom: 0; left: -5px; content: ''; background-color: #ECF5E3; position: absolute; }
.history-decor .flex-item4:nth-child(5)::before { content: none; }

.contact-form { padding-top: 30px; }
.contact-form .form-item .item-content { display: flex; align-items: center; }
.contact-form .form-item .item-content p { font-weight: 500; font-family: 'Noto Sans JP', sans-serif; color: #595757; }
.contact-form .form-item { padding: 30px 0; border-bottom: 1px solid #B6B1AF; display: flex; align-items: center; }
.contact-form .form-item .item-label { width: 245px; display: flex; align-items: center; }
.contact-form .form-item .item-label p:nth-child(1) { font-size: 15px; font-weight: 500; font-family: 'Noto Sans JP', sans-serif; color: #595757; }
.contact-form .form-item .item-label p:nth-child(2) { font-size: 13px; padding: 3px 5px; line-height: 13px; font-weight: 700; font-family: 'Noto Sans JP', sans-serif; border-radius: 3px; margin-left: 10px; color: #D43353; background-color: #EEBFCA; }
.contact-form .form-item input[type=text] { width: 675px; font-size: 15px; padding: 10px 15px; border-radius: 3px; border: 1px solid #666666; font-family: 'Noto Sans JP', sans-serif; }
.contact-form .form-item .item-content>div { padding-right: 25px; width: 160px; display: flex; align-items: center; }
.contact-form .form-item .item-content>div label { padding-left: 5px; }
.contact-form .form-item .item-content>div label p { font-weight: 500; }
.contact-form .form-item .item-content textarea { width: 745px; padding: 10px 15px; border: 1px solid #666666; border-radius: 3px; color: #333333; font-family: 'Noto Sans JP', sans-serif; }
.contact-form .form-item:nth-child(6), .contact-form .form-item:nth-child(7) { align-items: flex-start; }
.contact-form .privacy { width: 100%; padding: 30px; height: 270px; margin: 40px 0; border: 1px solid #B6B1AF; box-sizing: border-box; overflow-y: scroll; }
.contact-form .privacy h6 { font-size: 16px; line-height: 26px; font-weight: 700; }
.contact-form .privacy h5, .contact .contact-form .privacy h6, .contact .contact-form .privacy p { color: #333333; font-family: 'Noto Sans JP', sans-serif; }
.submit-btn { margin-top: 60px; }
.submit-btn .common-button { border-radius: 5px; }

/* RESPONSIVE */
@media screen and (max-width:1675px) {
  html { font-size: 0.5970vw; }
  .common-decor-bl { width: 50rem; height: 31.7rem; bottom: -10.5rem; left: -5.5rem; }
}
/* RESPONSIVE */
@media screen and (max-width:1200px) {
  html { font-size: 0.83333vw; }
  .container-fluid { max-width: 113.6rem; }
  :root {
    --fs_menu: 1.6rem
  }

  p { font-size: 1.5rem; line-height: 2.9rem; }
  h1 { font-size: 3.8rem; line-height: 6.5rem; }
  h2 { font-size: 3.7rem; line-height: 6.5rem; }
  h3 { font-size: 3.1rem; line-height: 4.5rem; }
  h4 { font-size: 2.6rem; }
  h5 { font-size: 2.0rem; }

  .title-decor { padding: 0 2.0rem; margin-bottom: 3.5rem; }
  .title-decor p { font-size: 1.6rem; }
  .title-decor::after { width: 500.0rem; height: .1rem; }
  .title { padding-bottom: 4.0rem; }
  .title p { font-size: 1.5rem; }
  .sub-title { margin-bottom: 2.5rem; padding-bottom: 1.0rem; }
  .sub-title img { width: 4.5rem; height: 3.7rem; }
  .sub-title h3 { padding-left: 1.0rem; }
  .pdbt-60 { padding-bottom: 6.0rem; }
  .pdbt-75 { padding-bottom: 7.5rem; }
  .pdbt-30 { padding-bottom: 3.0rem; }
  .pdbt-10 { padding-bottom: 1.0rem; }
  .pdv20 { padding: 2.0rem 0; }
  .fs19 { font-size: 1.9rem; }
  .fs16 { font-size: 1.6rem; }
  .fs13 { font-size: 1.3rem; line-height: 2.0rem; }
  .fs25 { font-size: 2.5rem; line-height: 4.5rem; }
  .fs28 { font-size: 2.8rem; }
  .lh22 { line-height: 2.2rem; }

  .carousel { padding: 7.5rem 0; }
  .carousel .item { padding: 2.0rem; }
  .carousel .item .item-title { width: 14.6rem; height: 4.6rem; top: -.5rem; }
  .item-title.r2 { top: -1.7rem !important; }
  
  .common-button { width: 32.9rem; height: 6.3rem; }
  .common-button p { font-size: 1.6rem; }
  .common-button img { width: 1.1rem; height: 1.4rem; left: 2.2rem; }
  /*--------------- HEADER_START --------------*/
  .header_middle_hp{ padding:1.7rem 0 1.7rem 2.8rem; height: 10.0rem; }

  .navigation .nav-text { width: 54.6rem; top: .5rem; right: 21.0rem; }
  .navigation .nav-text p { font-size: 1.4rem; line-height: 2.5rem; }
  .navbar-nav .nav-item{ margin-top: 3.0rem; font-size:1.4rem; line-height:1.9rem; padding:0 1.5rem ; }
  .navbar-nav .nav-link img { width: .4rem; height: 2.0rem; }
  .navbar-nav .nav-link p { line-height: 2.8rem; padding-left: 1.6rem; }
  .navbar-nav .nav-item:nth-child(5) .nav-link { width: 18.0rem; height: 10.0rem; margin-top: -1.7rem; margin-bottom: -1.7rem; }
  .header-logo-pc img { width: 36.5rem; height: 7.4rem; }
  .header-right-hp{ padding-left:.8rem; }
  .header-absolute-hp{ left:5.3rem; }
  /*--------------- HEADER_END --------------*/
  /* TOP_MAINVIEW_START */
  .top-mv { margin-top: 9.9rem; }
  .top-mv .content .mv-logo { margin-top: 0; }
  .top-mv .content .mv-logo img { width: 29.1rem; height: 20.9rem; }
  .top-mv .content .catch .text { padding: 1.5rem 3.5rem; }
  .top-mv .content .catch .text:nth-child(1) { margin-top: 3.0rem; }
  .top-mv .content .catch .text:nth-child(2) { margin-top: 1.5rem; margin-left: 5.0rem; }
  .top-mv .decor1 { width: 49.6rem; height: 35.9rem; top: -8.2rem; left: -8.8rem; }
  .top-mv .decor2 { width: 57.0rem; height: 23.7rem; bottom: -2.0rem; right: -17.0rem; }
  /* TOP_MAINVIEW_END */
  .common-section { padding: 7.5rem 0; }
  .common-title { padding-bottom: 7.5rem; }
  .common-decor-bl { width: 37rem; height: 31.7rem; bottom: -17.5rem; left: -5.5rem; }
  .common-decor-tr { width: 55.9rem; height: 25.8rem; top: 1.5rem; right: -12.7rem; }
  .common-decor-br { width: 55.9rem; height: 25.8rem; bottom: 76.0rem; right: -12.7rem; }
  .sub-item .text p { letter-spacing: -0..5rem; }
  .company-logo { padding-bottom: 3.5rem; }
  .company-logo img { width: 40.5rem; height: 9.5rem; }
  .detail-item .item-label { padding: 2.0rem 0; }
  .detail-item .item-text { padding: 2.0rem 0; }
  footer { padding: 7.5rem; }
  footer .footer-description { padding-bottom: 4.0rem; }
  footer .footer-logo { padding-bottom: 4.0rem; }
  footer .footer-logo img { width: 46.0rem; height: 10.8rem; }
  footer .footer-menu { width: 54.3rem; }
  footer .footer-address { padding-bottom: 3.0rem; }
  footer .footer-decor1 { width: 39.8rem; height: 20.2rem; bottom: 0; left: -5.0rem; }
  footer .footer-decor2 { width: 39.8rem; height: 20.2rem; bottom: -3.4rem; right: -5.0rem; }
  .copyright { padding: 1.5rem 0; }

  /* INNERPAGE_START */
  .inner-page-title p { font-size: 2.6rem; line-height: 4.6rem; }
  .flex-wrapper .item.wd23 { margin-bottom: 4.5rem; }
  .img-con1 { padding: 1.5rem 0; }
  .img-con1 img { width: 25.8rem; height: 25.8rem; }
  .img-con2 { padding: 1.5rem 0; }
  .img-con2 img { width: 52.3rem; height: 35.6rem; }
  .img-con3 { padding: 1.5rem 0; }
  .img-con3 img { width: 34.8rem; height: 34.8rem; }
  .img-con4 img { width: 17.7rem; height: 11.9rem; }
  .img-con5 img { width: 27.2rem; height: 21.8rem; }
  .img-con6 img { width: 54.8rem; height: 30.7rem; }
  .flex-item1 { margin-top: 2.0rem; padding: 1.0rem 1.5rem; }
  .flex-item2 { margin-top: 2.0rem; padding: 1.0rem 1.5rem; }
  .flex-item2 p:nth-child(2) { padding: 0 1.0rem; border-radius: 1.4rem; }
  .flex-item4 { padding: .0rem 2.0rem; }
  .flex-item4::before { width: 1.0rem; height: 1.0rem; border-radius: .5rem; top: 1.5rem; left: -.5rem; }
  .company-message { bottom: 0; }
  .company-message img { width: 33.0rem; height: 3.1rem; }
  .history-decor::after { width: 1.0rem; height: 1.0rem; top: 0; left: -.5rem; }
  .history-decor::before { width: 1.0rem; height: 1.0rem; bottom: 0; left: -.5rem; }

  .contact-form { padding-top: 3.0rem; }
  .contact-form .form-item { padding: 3.0rem 0; }
  .contact-form .form-item .item-label { width: 24.5rem; }
  .contact-form .form-item .item-label p:nth-child(1) { font-size: 1.5rem; }
  .contact-form .form-item .item-label p:nth-child(2) { font-size: 1.3rem; padding: .3rem .5rem; line-height: 1.3rem; }
  .contact-form .form-item input[type=text] { width: 67.5rem; font-size: 1.5rem; padding: 1.0rem 1.5rem; }
  .contact-form .form-item .item-content>div { padding-right: 2.5rem; width: 16.0rem; }
  .contact-form .form-item .item-content>div label { padding-left: .5rem; }
  .contact-form .form-item .item-content textarea { width: 74.5rem; padding: 1.0rem 1.5rem; }
  .contact-form .privacy { padding: 3.0rem; height: 27.0rem; margin: 4.0rem 0; }
  .contact-form .privacy h6 { font-size: 1.6rem; line-height: 2.6rem; }
  .submit-btn { margin-top: 6.0rem; }
  .submit-btn .common-button { border-radius: .5rem; }
}

/* RESPONSIVE */
@media screen and (max-width:767px) {
  html { font-size: 2.66667vw; }
  .container-fluid { max-width: 100%; padding: 0 1.5rem; box-sizing: border-box; }
  .pc_show { display: none !important; }
  .sp_show { display: block !important; }
  .sp_show_flex { display: flex !important; }
  .pc_show_inline { display: none !important; }
  .sp_show_inline { display: inline-block !important; }

  /*--------------- HEADER_START --------------*/
  .header_middle_hp{ justify-content: space-between; padding:0; width: 100%; height: 70px; }
  .header-logo-sp { text-align: left; transition: all 0.5s ease-in-out; padding: 10px 15px; }
  .header-logo-sp img { width: 204px; }
  .navigation { position: fixed; left: 0; width: 100%; background-color: #EEE6EC; display: none; top: 70px; clear: both; height:calc(100% - 64px); overflow:hidden; }
  .navbar-nav { flex-direction: column; }
  .navbar-nav .nav-item { border-bottom: 1px solid #989898; padding: 10px 0 !important; width:100%; margin-top: 0; }
  .navbar-nav .nav-link { padding: 0px 20px !important;  font-weight: 700; border:0 !important; margin-bottom: 0px; margin-top: 0; }
  .navbar-nav .nav-link img { width: 5px; height: 10px; }
  .navbar-nav .nav-item:nth-child(6) img { width: 5px !important; height: 10px !important; }
  .navbar-nav .nav-link p { color: #333333; font-size: 14px; line-height: 44px; }
  .navbar-nav .dropdown-menu.show{ display:block; opacity:1; height:auto; transform: translate(.0px, .0px); }
  .navbar-nav .nav-link.contact_hp { color: #fff !important; padding: 1.8px .8px !important; margin-left:0; }
  .navbar-collapse{ display:block !important; }
  .navbar-nav .nav-link:hover { color: #fff !important; }
  .navbar-nav .show .nav-link{ color: #fff !important; }
  .online-form-hp{ display:block; }
  .navbar-nav .nav-link.active { color: #fff !important; }
  .header-right-hp{ display:none; }
  .hide-desktop-hp{ display:block !important; }
  .mobile-menu-icon-hp{ width:70px; height:70px; display: flex; align-items: center; justify-content: center; background-color: #813771; position: relative; }
  .menu-toggle-btn{ margin: 0; width:39px; height: auto; }
  .menu-toggle-btn span{ width:39px !important; height:2px; margin-bottom:12px; background-color: #fff; margin-left: 0px; }
  .menu-toggle-btn span:nth-child(3) { margin-bottom: 0; }
  .header-right-hp .contact-btn-main-hp{ display:none; }
  .navbar{ display:block; padding-top: 0; }
  .navbar-nav .nav-link:before{ display:none; }
  .header-absolute-hp{ display:none; }
  .menuOpen #header{ background:#000; }
  .navbar-nav .nav-link.login_hp{ margin:1.0rem 0 .0rem 0; }
  .navbar-nav .nav-link.materials_hp{ margin-top:2.0rem; }
  .fix-header .header-in-hp { height: 7.0rem; }
  /*--------------- HEADER_END --------------*/
  :root {
    --fs_menu: 1.5rem
  }
  
  p { font-size: 1.5rem; line-height: 2.9rem; }
  h1 { font-size: 1.9rem; line-height: 3.3rem; }
  h2 { font-size: 2.4rem; line-height: 4.5rem; }
  h3 { font-size: 2.2rem; line-height: 4.5rem; }
  h4 { font-size: 2.6rem; }
  h5 { font-size: 2.0rem; }
    
  .title-decor { padding: 0 1.5rem; margin-bottom: 1.5rem; position: relative; background-color: #0F4539; width: fit-content; }
  .title-decor p { font-size: 1.4rem; }
  .title { padding-bottom: 4.0rem; text-align: center; }
  .title p { font-size: 1.5rem !important; }
  .sub-title { margin-bottom: 1.5rem; padding-bottom: .5rem; align-items: flex-start; }
  .sub-title img { width: 2.5rem; margin-top: -.5rem; }
  .sub-title h3 { padding-left: 1.0rem; font-size: 1.8rem; line-height: 2.5rem; }
  .pdbt-75 { padding-bottom: 6.0rem; }
  .pdbt-60 { padding-bottom: 4.0rem; }
  .pdbt-30 { padding-bottom: 1.5rem; }
  .pdbt-10 { padding-bottom: 1.0rem; }
  .pdbt-0 { padding-bottom: 0 !important; }
  .pdv20 { padding: 2.0rem 0; }
  .wd49 { width: 100%; }
  .wd48 { width: 100%; }
  .wd45 { width: 100%; }
  .wd20 { width: 100%; }
  .wd23 { width: 100%; }
  .wd24 { width: 100%; }
  .wd30 { width: 100%; }
  .wd60 { width: 100%; }
  .fs19 { font-size: 1.5rem; font-weight: 700; }
  .fs16 { font-size: 1.5rem; }
  .fs13 { font-size: 1.3rem; line-height: 2.0rem; }
  .fs25 { font-size: 2.0rem; line-height: 3.5rem; }
  .fs28 { font-size: 2.8rem; }
  .fwb { font-weight: 700; }
  .fwr { font-weight: 400 !important; }
  .fac { text-align: center; }
  .lh22 { line-height: 2.2rem; }
  .pr { position: relative; }
  .alc { align-items: center !important; }
  .separate { border-bottom: .1rem solid #333333; }
  
  .owl-theme .owl-dots .owl-dot { display: none; }
  .owl-carousel .owl-stage-outer { overflow: visible; }
  .carousel { padding: 6.0rem 1.5rem; }
  .carousel .item { padding: 2.0rem; border: .1rem solid #000; box-sizing: border-box; }
  .carousel .item .item-title { width: 14.6rem; height: 4.6rem; top: -.5rem; left: 50%; position: absolute; opacity: 0.5; background-color: #0F4539; position: absolute; display: flex; align-items: center; justify-content: center; transform-origin: 50% 50%; }
  .item-title.r1 { transform: rotate(3.83deg) translateX(-50%); }
  .item-title.r2 { top: -1.7rem !important; transform: rotate(-5.35deg) translateX(-50%); }
  .item-title.r3 { transform: rotate(7.44deg) translateX(-50%); }
  .item-title.r4 { transform: rotate(3.83deg) translateX(-50%); }
  .item-title.r5 { transform: rotate(-5.35deg) translateX(-50%); }
  
  .common-button { width: 30.0rem; height: 5.0rem; }
  .common-button p { font-size: 1.4rem; }
  .common-button img { width: .8rem; }
  /* TOP_MAINVIEW_START */
  .top-mv { margin-top: 69px; }
  .top-mv .content .mv-logo { margin-top: 2.0rem; }
  .top-mv .content .mv-logo img { width: 21.2rem; height: 15.2rem; }
  .top-mv .content .catch .text { padding: 1.0rem; transform: skewX(-22.5deg); background-color: #fff; width: fit-content; }
  .top-mv .content .catch .text h1 { transform: skewX(22.5deg); }
  .top-mv .content .catch .text h1 span { color: #813771; }
  .top-mv .content .catch .text:nth-child(1) { margin-top: 5.0rem; }
  .top-mv .content .catch .text:nth-child(2) { margin-top: 1.0rem; margin-left: 1.5rem; }
  .top-mv .decor1 { width: 19.0rem; height: 11.4rem; top: -1.2rem; left: -2.6rem; }
  .top-mv .decor2 { width: 25.4rem; height: 10.6rem; bottom: -.5rem; right: -7.0rem; transform: rotate(-18deg); }
  /* TOP_MAINVIEW_END */
  .common-section { padding: 6.0rem 0; }
  .common-title { text-align: center; padding-bottom: 4.5rem; position: relative; z-index: 1; }
  .common-title p { font-weight: 900; color: #ADB1AA; }
  .flex-3-wrapper { flex-direction: column; }
  .sp-arnd { justify-content: space-around; }
  .sp-btwn { justify-content: space-between; }
  .flex-3-wrapper .item { width: 100%; padding-top: 1.0rem; }
  .flex-2-wrapper { display: flex; align-items: flex-start; justify-content: space-between; flex-wrap: wrap; flex-direction: column; }
  .flex-2-wrapper .item.left { margin-left: -1.5rem; margin-right: -1.5rem; width: unset; }
  .flex-2-wrapper.rs .item.left { margin-right: -1.5rem; width: unset; }
  .flex-2-wrapper .item.left img { width: 100%; }
  .flex-2-wrapper .item.right { width: 100%; }
  .flex-2-wrapper .item.right .item-content { padding-top: 2.0rem; }
  .rs { flex-direction: column; }
  .common-decor-bl { width: 22.8rem; height: 11.4rem; bottom: -4.5rem; left: -4.5rem; }
  .common-decor-tr { width: 25.4rem; height: 10.6rem; top: 1.5rem; right: -7.0rem; z-index: 0; }
  .common-decor-br { width: 25.4rem; height: 10.6rem; bottom: 76.0rem; right: -7.0rem; }
  .sub-item .text p { letter-spacing: -0..5rem; }
  .map iframe { width: 100%; height: 45rem; padding-top: 4.5rem; }
  .company-logo { padding-bottom: 3.5rem; }
  .company-logo img { width: 100%; }
  .detail-item { flex-direction: column; }
  .detail-item .item-label { padding: 1.5rem 0 0 0; border-bottom: none; }
  .detail-item .item-label p { font-weight: 700; }
  .detail-item .item-text { padding: 0 0 1.5rem 0; flex: 1; border-bottom: .1rem solid #333333; }
  footer { padding: 6.0rem 1.5rem; }
  footer p { color: #333333 !important; }
  footer .footer-description { padding-bottom: 2.0rem; }
  footer .footer-logo { padding-bottom: 2.0rem; }
  footer .footer-logo img { width: 34.5rem; }
  footer .footer-menu { width: 100%; }
  footer .footer-menu p { font-size: 1.2rem; }
  footer .footer-address { padding-bottom: 3.0rem; }
  footer .footer-decor1 { display: none; }
  footer .footer-decor2 { display: none; }
  .copyright { padding: 1.0rem 0; background-color: #813771; text-align: center; }
  .copyright p { font-size: 1.2rem; }

  /* INNERPAGE_START */
  .inner-page-title p { font-size: 2.6rem; line-height: 4.6rem; font-weight: 900; color: #fff; }
  .flex-wrapper { display: flex; flex-wrap: wrap; }
  .flex-wrapper .item.wd23 { margin-right: 3%; margin-bottom: 4.5rem; }
  .flex-wrapper .item.wd23:nth-child(4n) { margin-right: 0; }
  .img-con1 { width: 100%; padding: 1.5rem 0; overflow: hidden; }
  .img-con1 img { width: 100%; height: auto; object-fit: cover; }
  .img-con2 { width: 100%; padding: 1.5rem 0; overflow: hidden; }
  .img-con2 img { width: 100%; height: auto; object-fit: cover; }
  .img-con3 { width: 100%; padding: 1.5rem 0; overflow: hidden; }
  .img-con3 img { width: 100%; height: auto; object-fit: cover; }
  .img-con4 { width: 100%; overflow: hidden; }
  .img-con4 img { width: 100%; height: auto; object-fit: contain; }
  .img-con5 { width: 100%; overflow: hidden; padding-top: 2.0rem; }
  .img-con5 img { width: 100%; height: auto; object-fit: contain; }
  .img-con6 { width: 100%; overflow: hidden; padding-top: 2.0rem; }
  .img-con6 img { width: 100%; height: auto; object-fit: contain; }
  .flex-item1 { flex-direction: column; align-items: flex-start; }
  .flex-item1 p { font-size: 1.3rem; }
  .flex-item2 { flex-direction: column; align-items: flex-start; }
  .flex-item2 p { font-size: 1.3rem; }
  .flex-item2 p:nth-child(2) { padding: 0 1.0rem; border-radius: 14..5rem; }
  .flex-item3 { display: flex; align-items: center; justify-content: space-between; }
  .flex-item4 { padding: .0rem 2.0rem; display: flex; justify-content: space-between; position: relative; }
  .flex-item4::before { width: 1.0rem; height: 1.0rem; border-radius: .5rem; top: 1.5rem; left: -.5rem; transform: translateY(-50%); background-color: #0F4539; content: ''; position: absolute; }
  .flex-item4 p:nth-child(1) { width: 30%; }
  .flex-item4 p:nth-child(2) { width: 70%; }
  .col-wrapper { padding: 3.0rem 0; }
  /* .company-message { padding-top: 10.0rem; width: 100%; text-align: right; } */
  .company-message { bottom: 0; right: 0; position: absolute; }
  .company-message img { width: 33.0rem; height: 3.1rem; }
  .history-decor { border-left: .1rem solid #0F4539; position: relative; }
  .history-decor::after { width: 1.0rem; height: 1.0rem; top: 0; left: -.5rem; content: ''; background-color: #ECF5E3; position: absolute; }
  .history-decor::before { width: 1.0rem; height: 1.0rem; bottom: 0; left: -.5rem; content: ''; background-color: #ECF5E3; position: absolute; }
  .history-decor .flex-item4:nth-child(5)::before { content: none; }

  .contact-form { padding-top: 2.0rem; }
  .contact-form .form-item { padding: 2.0rem 1.0rem; flex-direction: column; }
  .contact-form .form-item .item-content { width: 100%; justify-content: space-between; }
  .contact-form .form-item .item-label { width: 100%; padding-bottom: 1.0rem; }
  .contact-form .form-item .item-label p:nth-child(1) { font-size: 1.5rem; }
  .contact-form .form-item .item-label p:nth-child(2) { font-size: 1.3rem; padding: .3rem .5rem; line-height: 1.3rem; font-weight: 700; margin-left: 1.0rem; }
  .contact-form .form-item input[type=text] { width: 100%; font-size: 1.5rem; padding: 1.0rem 1.0rem; border-radius: .3rem; }
  .contact-form .form-item .item-content>div { padding-right: 2.5rem; width: 16.0rem; display: flex; align-items: center; }
  .contact-form .form-item .item-content>div label { padding-left: .5rem; }
  .contact-form .form-item .item-content textarea { width: 100%; padding: 1rem 1.5rem; border: 1px solid #666666; border-radius: .3rem; }
  .contact-form .form-item:nth-child(6), .contact-form .form-item:nth-child(7) { align-items: flex-start; }
  .contact-form .privacy { width: 100%; padding: 2.0rem; height: 27.0rem; margin: 4.0rem 0; }
  .submit-btn { margin-top: 60px; }
  .submit-btn .common-button { border-radius: 5px; }
}

/* EXTRA SPLID */
.splide__track { overflow: visible; }
.splide__arrow { display: none; }
.splide__pagination__page { display: none; }
.splide__slide { margin: 0 10px; }
.content-img img { width: 100%; }