
html {overflow: auto;}
html.wf-loading {
	opacity: 0;
	transition: all .3s ease;
}
html.wf-inactive,
html.wf-active {
	opacity: 1;
}
body {font-family:"YakuHanJPs",'Noto Sans JP', sans-serif, "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;font-size: 16px;color:#404040;background: #fff;line-height: 1.6;overflow: hidden;}
.tb {display: none}
.sp {display:none;}
.spbr {display:none;}
.en {
    font-family: "Roboto", sans-serif;
    letter-spacing: 0.02em;
}
.tx-right {
    text-align: right;
}

/*flexbox*/
.fbox {
    display: -webkit-flex;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    width: 100%;
}
.fb-center {justify-content: center;}
.fb-between {justify-content: space-between;}


/*リンク*/
a {color:#404040;text-decoration: none; transition: opacity .3s ease 0s;}
.content-area a {color:#2994FF;text-decoration: underline; transition: opacity .3s ease 0s;}
a:hover {opacity: 0.7}
/*見出し*/

h1,h2,h3,h4,h5 {color: #0C6262;font-weight: 700;} 
h1 {
    margin:0;
    line-height: 1;
}
h1 a {
    display: block;
}
h3 {
    font-size: 20px;
    margin: 0 0 30px;
}
h4 {
    font-size: 20px;
    margin-bottom: 10px;
}
h5 {margin-bottom: 10px;font-size: 16px;}
p {margin-bottom: 40px;text-align: justify;line-height: 1.8;}
figure {text-align: center;}
.mincho {
    font-family:'Noto Serif JP', "ヒラギノ明朝 ProN W6", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
}
.kome {font-size: 12px;margin-top: 5px;}
.red {color: #A52A2A;}
em {
    font-weight: 700;
    font-style: normal;
}
strong {
    background-image: linear-gradient(transparent 60%, #fff69d 0%);
    font-weight: bold;
}

.arrow{
    position: relative;
    display: inline-block;
    padding: 0 0 0 16px;
    color: #000;
    vertical-align: middle;
    text-decoration: none;
    font-size: 15px;
    top: -2px;
}
.arrow::before,
.arrow::after{
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    content: "";
    vertical-align: middle;
}
.right::before{
    left: 10px;
    width: 10px;
    height: 10px;
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}
.arrb {
    display: block;
    top: 2px;
    width: 30px;
    margin: 0 auto;
}
.bottom::before{
    left: 10px;
    width: 10px;
    height: 10px;
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
    -webkit-transform: rotate(135deg);
    transform: rotate(135deg);
}

.balloon1{
    position: relative;
    padding: 20px;
    width: 120px;
    height: 75px;
    line-height: 17px;
    border-radius: 50%;
    text-align: center;
    color: #ffffff;
    letter-spacing: 0em;
    font-size: 14px;
    background-color: #eb6100;
    display: inline-block;
    margin-right: 20px;
}
.balloon1::before{
    content: '';
    position: absolute;
    display: block;
    width: 0;
    height: 0;
    left: 77px;
    bottom: -10px;
    border-right: 20px solid #eb6100;
    border-top: 10px solid transparent;
    border-bottom: 10px solid transparent;
    transform: rotate(-120deg);
}

/*リスト・テーブル*/
table {
    width: 100%;
    margin-bottom: 20px;
}
td,th {
    font-weight: normal;
    width: 80%;
    border-bottom: solid 1px #eee;
    padding: 15px 10px 15px 0;
    line-height: 1.8;
}
th {
    text-align: left;
    width: 20%;
    vertical-align: top;
    color: #118E8E;
}

.btn-more {
    width: 35%;
    margin: 30px auto 0;
    text-align: center;
}
.btn-more a {
    color: #fff;
    padding: 20px;
    display: block;
    background:#723121 url(images/common/icon-arrow.png)no-repeat;
    background-size: 19px;
    background-position: 20px;
    border: solid 1px #723121;
    border-radius: 10px;
    transition: all 0.5s;
}
.btn-more a:hover {
    color: #723121;
    background:#fff url(images/common/icon-arrow-brown.png)no-repeat;
    background-size: 19px;
    background-position: 20px;
}


/*カラム設定*/
.wrapper {overflow: hidden;position: relative;}
.container {padding: 0 20px;margin:0 auto;}
.con-l {max-width: 1140px;}
.con-m {max-width: 1070px;}
.con-s {max-width: 1000px;}
.content-area {padding: 60px 0 80px;}
.content-area img {
    max-width: 100%;
    height: auto;
}

/*ヘッダー*/
header {
    width: 100%;
    background: linear-gradient(to right, #118e8e 0%,#094747 100%);
}
.header-inner {align-items: center;}
.logo-area {
    width: 300px;
    background: url(./images/logo-bg.png)no-repeat;
    background-size: 100%;
    padding: 23px 0 0px 30px;
    height: 75px;
}
.logo-area img {
    width: 170px;
    vertical-align: baseline;
}

/*ナビメニュー*/
.nav-area {
    width: 670px;
    margin-right: 30px;
}
.sp-btn {display: none}
.sp-nav {display: none}
.navbar {}
.navbar li {
    float: left;
}
.navbar li a{
    color: #fff;
    padding: 10px 24px;
    display: block;
    font-size: 15px;
}
.navbar li a:hover {
    color: #fff;
}
/*サブメニュー*/
.sub-menu {
    width: 340px;
    background: #fff;
    display: none;
    position: absolute;
    z-index: 1;
    text-align: left;
    padding: 15px 0;
}
.sub-menu li{float: none}
.sub-menu-link {
    width: 49%;
    margin-right: 2%;
    font-size: 13px;
    line-height: 2;
}
.sub-menu-link img{width: 100%;}
.navbar li:hover::after{
    opacity: 1;
    transition: all 0.5s ease-in-out;
}
.navbar li:hover .sub-menu {
    display: block;
    animation: show 0.3s linear 0s;
    animation: slide 0.3s linear;
}
@keyframes show{
    from{
        opacity: 0;
    }
    to{
        opacity: 1;
    }
}

@keyframes slide {
    from {
        opacity: 0;
/*        transform: translateX(-220px);*/
    }
    to {
        opacity: 1;
/*        transform: translateX(0px);*/
    }
}


/*  メニューアクティブ時  */
nav.open {transform: translate(0);}
.on {display: block;}

/************
トップページ
*************/
/*メインビジュアル*/
.main-v {
    background: url(./images/mv-bg.png)no-repeat;
    background-size: cover;
    padding: 229px 0;
    margin-bottom: 150px;
}
.main-v h2 {
    font-size: 47px;
    position: relative;
    font-weight: bold;
    color: #fff;
    line-height: 1.5;
}
.main-v h2 span {
    display: block;
    font-size: 20px;
    margin-top: 10px;
}
.main-v h2::before {
    content: "";
    display: block;
    width: 307px;
    height: 356px;
    background: url(./images/mv-obj.png)no-repeat;
    background-size: 100%;
    position: absolute;
    top: -41%;
    left: -6%;
}

.future, .service, .reason, .message, .member, .company, .faq {
    margin-bottom: 100px;
    position: relative;
}
.future h3 {
    font-size: 25px;
    font-weight: normal;
    text-align: center;
    position: relative;
    margin-bottom: 70px;
}
.future h3::after {
    content: "";
    display: block;
    width: 1px;
    height: 44px;
    background: #707070;
    position: absolute;
    left: 50%;
    bottom: -50px;
    transform: translateX(-50%);
}
.future p {
    font-size: 18px;
    padding: 0 50px;
}

.service {
    background-color: #fff;
    position: relative;
    padding: 40px 0;
}
.service::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 56%;
  background: linear-gradient(to bottom, #e6ffff 0%, #bfe0e0 100%);
  z-index: 0;
  pointer-events: none;
}
.img-fit {
    width: 100%;
    height: auto;
}

.service > * {
  position: relative;
  z-index: 1;
}

.en-tit {
    font-size: 46px;
    font-weight: 700;
    text-align: center;
    position: absolute;
    left: 50%;
    top: -77px;
    transform: translate(-50%);
    letter-spacing: 0.05em;
    color: #0C6262;
}
.tit {
    font-size: 30px;
    color: #444444;
    text-align: center;
}
.disc {
    text-align: center;
}
.service .fbox {
    gap: 90px;
}
.service .item {
    flex:1;
  display:flex;
  flex-direction:column;
}
.service .item h4{
  margin:0;
  line-height:1.35;
  display:flex;
  align-items:center;
  min-height:3em;
  font-weight:700;
  font-size: 20px;
}
.service .item .img {
    margin-bottom: 5px;
}
.service .item p {
    margin-bottom: 0;
}
.service-num {
    position: relative;
    text-align: right;
    font-size: 14px;
    color: #118E8E;
    margin-bottom: 5px;
}
.service-num::before {
    content: "";
    display: block;
    width: 68%;
    height: 1px;
    background: #118E8E;
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
}


.reason {
    position: relative;
    padding: 40px 0;
}
.reason__img {
    position: absolute;
    right: 0;
    top: 0;
    width: 57%;
    height: 100%;
}
.reason__img img {
height: 100%;
object-fit: cover;
width: 100%;
}
/* 上に重ねる斜めグラデーションレイヤー */
.reason__overlay {
    position: absolute;
    background: url(./images/reason-gra.png)no-repeat;
    background-size: cover;
    width: 71%;
    height: 100%;
    top: 0;
    background-position-x: right;
}
.reason .container {
    position: relative;
    z-index: 1;
}

.reason-content {
    width: 705px;
}
.reason-content .reason-num {
    width: 15%;
    color: #fff;
    text-align: center;
    font-size: 13px;
    line-height: 1.3;
}
.reason-content .reason-num span {
    font-size: 46px;
    display: block;
}
.reason-content .tx {
    width: 81%;
}

.message {
    position: relative;
    padding: 40px 0;
}
.message__img {
    position: absolute;
    left: 0;
    top: 0;
    width: 57%;
    height: 100%;
}
.message__img img {
height: 100%;
object-fit: cover;
width: 100%;
}
/* 上に重ねる斜めグラデーションレイヤー */
.message__overlay {
    position: absolute;
    background: url(./images/message-gra.png)no-repeat;
    background-size: cover;
    width: 65%;
    height: 100%;
    top: 0;
    right: 0;
    background-position-x: left;
}
.message .container {
    position: relative;
    z-index: 1;
}
.message-content {
    width: 50%;
    margin-left: auto;
    margin-top: 100px;
}
.message-content h3 {
    font-size: 30px;
    color: #444;
}
.message-content p {
    font-size: 18px;
}
.message-content span {
    font-size: 14px;
}
.member {
    margin-top: 150px;
}
.menber-content .item {
    width: 18.4%;
    margin-right: 2%;
}
.menber-content .item:last-child {
    margin-right:0;
}
.menber-content .tx {
    text-align: center;
    padding: 10px 0 0;
}
.menber-content .tx span {
    display: block;
    font-size: 12px;
}
.company {
    margin-bottom: 150px;
}
.company-inner {
    background: #F8F8F8;
    padding: 40px;
}
.company-inner h3 {
    font-size: 24px;
    margin-bottom: 25px;
}
.company-inner .about {
}
.company-inner .about .tx {
width: 55%;
}
.company-inner .about .map {
width: 40%;
}

.company-inner .about .office .item {
    width: 48%;
}

.faq {
    background: #ECFAFA;
    padding: 40px 0;
}
.faq-content {
    border-bottom: 2px solid #fff;
    padding: 30px 0;
    margin: 0 40px;
}
.faq-content .fbox {
    align-items: center;
}
.faq .en-tit {
    top: -35px;
}
.fq, .fa {
    font-size: 46px;
    width: 5%;
    line-height: 1.4;
}
.fq {
    color: #0C6262;
}
.fa {
    color: #DB5D2E;
}
.fq-tx, .fa-tx {
    width: 93%;
}
.fq-tx {
    color: #118E8E;
    font-size: 18px;
}

/*フッター*/
footer {
    padding: 50px 0;
    background: url(./images/footer-bg.png)no-repeat;
    background-size: cover;
    color: #fff;
}
footer h3 {
    color: #fff;
    margin-bottom: 15px;
}
footer .tx {
    width: 49%;
}
footer .cta {
    width: 40%;
}
footer .label {
    background: #fff;
    color: #0C6262;
    font-size: 14px;
    width: 15%;
    text-align: center;
    padding: 3px;
    border-radius: 10px;
    font-weight: 900;
    height: 30px;
    position: relative;
    top: 5px;
}
footer .tel {
    margin-bottom: 25px;
}
footer .tel .num {
    width: 80%;
    font-size: 36px;
    font-weight: 900;
    line-height: 1;
}
footer .tel .num a {
    color: #fff;
}
footer .tel .num span {
    font-size: 12px;
    display: block;
    margin-top: 10px;
}
footer .mail .num {
    width: 80%;
    font-size: 23px;
    font-weight: 900;
    line-height: 1;
}
footer .mail .num span {
    font-size: 12px;
    display: block;
    margin-top: 10px;
}
footer .mail .num a {
    color: #fff;
}
.form-btn {
    margin-top: 25px;
}
.form-btn a {
    display: block;
    background: #fff;
    border-radius: 10px;
    padding: 15px;
    font-size: 14px;
    font-weight: bold;
    position: relative;
    color: #0C6262;
}
.form-btn a span {
    font-size: 12px;
}
.form-btn a::after {
    content: "";
    display: block;
    width: 8px;
    height: 16px;
    background: url(./images/arrow.png)no-repeat;
    background-size: 100%;
    position: absolute;
    right: 4%;
    top: 40%;
}



.footer-logo-area {
    width: 50%;
    font-size: 14px;
}
.footer-logo img{
    width: 180px;
}

.footer-menu li {display: inline-block;}
.footer-menu li a {
    color: #fff;
}

.copyright {
    padding: 30px 0;
    font-size: 12px;
    text-align: center;
}



@media (max-width: 1024px) {
    body {
        font-size: 1.58vw;
    }
    .pc {display: none}
    .tb {display: block}
    .sp {display: block}
    .scroll-prevent {
        position: fixed;
        z-index: -1;
        width: 100%;
        height: 100%;
    }
    .container {padding: 0 2vw;}
    .content-area h1 {
        margin-bottom: 4vw;
        font-size: 2.3vw;
    }
    h2 {
        margin-bottom: 4vw;
        font-size: 2.3vw;
    }
    h3 {
        font-size: 2vw;
    }
    h4 {
        font-size: 1.8vw;
    }
    h5 {
        font-size: 1.6vw;
    }
    p {
        margin-bottom: 4vw;
    }
    .kome {
        font-size: 1.2vw;
    }
    table {
        margin-bottom: 2vw;
    }
    td, th {
        padding: 1.5vw 1vw 1.5vw 0;
    }
    header {
        position: fixed;
        width: 100%;
        top: 0;
        z-index: 100;
    }

    /*ナビメニュー*/
    .sp-nav {
        display: block;
        background: #234d86;
        padding: 20px 0;
        position: fixed;
        bottom: 0;
        width: 100%;
        z-index: 10180;
    }
    .sp-nav .fbox div {width: 50%;text-align: center;color: #fff}
    .sp-nav a{color: #fff;display: block;}
    .sp-nav img {
        height: 25px;
        width: auto;
        margin-right: 10px;
    }
    #top-bar .logo-area{
        position: absolute;
        top: 0px;
        left: 12px;
    }
    .mod-gnav-foldingBtn-btn {
        position: absolute;
        right: 0;
        top: 13px;
        width: 38px;
        height: 38px;
    }
    .mod-gnav-foldingBtn-btn::before,.mod-gnav-foldingBtn-btn::after {
        content: "";
        display: block;
        width: 46%;
        height: 1px;
        background: #000;
        position: absolute;
        left: 50%;
        top: 50%;
        margin-left: -7px;
        margin-top: -1px;
    }
    .mod-gnav-foldingBtn-btn::after {
        -webkit-transform: rotate(90deg);
        -ms-transform: rotate(90deg);
        transform: rotate(90deg);
    }
    .off::after {
        display: none!important;
    }
    
    .sp-btn {
        display: block;
        cursor: pointer;
        width: 75px;
        height: 75px;
        z-index: 10100;
        text-align: center;
        padding-top: 24px;
        position: fixed;
        right: 20px;
        top: 0px;
    }
    .sp-navi {
        transition: all 0.2s;
        transform: translate(200%);
        position: absolute;
        z-index: 10;
        padding: 5vw;
        margin-top: 75px;
        width: 50%;
    }
    .sp-navi h3 {
        font-size: 18px;
        text-align: center;
        margin-bottom: 20px;
    }
    .sp-navi li {text-align: left}
    .sp-navi li a{color: #0C6262}

    .navbar {width: 100%;}
    
    .off + .sub-menu {animation: show 0.5s linear 0s;display: block;}

    @keyframes show{
        from{
            opacity: 0;
        }
        to{
            opacity: 1;
        }
    }
    .main-nav dt, .main-nav dd {background: none;}
    .main-nav dt {
        line-height: 1;
        position: relative;
        text-align: left;
    }
    
    .main-nav dt .title {
        padding-left: 10px;
        line-height: 1;
        float: none;
        margin-top: 0;
    }
    .main-nav .accordion_icon {
        position: absolute;
        width: 37px;
        height: 37px;
        margin-right: 5px;
        right: 0;
        top: 6px;
    }
    .main-nav a {
        color: #0C6262;
        padding: 15px 0;
        font-size: 18px;
        font-weight: normal;
        display: block;
        position: relative;
        padding-left: 20px;
    }
    .main-nav a::before {
        content: "";
        display: block;
        width: 6px;
        height: 9px;
        background: url(./images/arrow-spmenu.png)no-repeat;
        background-size: 100%;
        position: absolute;
        left: 0;
        top: 45%;
    }
    .sub-menu {
        position: static;
        padding: 0 0 20px;
        height: auto;
        background: none;
        display: block;
        width: 100%;
    }
    .sp-btn .btn_menu {
        display: inline-block;
        position: relative;
        z-index: 1001;
    }
    .hbmenu, .hbmenu span {
        display: inline-block;
        transition: all .4s;
        box-sizing: border-box;
    }
    .hbmenu {
        position: relative;
        width: 28px;
        height: 18px;
        cursor: pointer;
    }
    .hbmenu span {
        position: absolute;
        left: 0;
        width: 100%;
        height: 2px;
        background-color: #fff;
    }

    .hbmenu span:nth-of-type(1) {
        top: 3px;
    }

    .hbmenu span:nth-of-type(2) {
        top: 22px;
    }
    .hbmenu span:nth-of-type(3) {
        bottom: 4px;
    }
    .active .hbmenu span:nth-of-type(1) {
        background-color: #fff;
        top: -4px;
        animation: active-menu-bar04-01 .75s forwards;
    }
    @keyframes active-menu-bar04-01 {
        0% {
            transform: translateY(0) rotate(0);
        }
        50% {
            transform: translateY(15px) rotate(0);
        }
        100% {
            transform: translateY(14px) rotate(45deg);
        }
    }
    .active .hbmenu span:nth-of-type(2) {
        background-color: #fff;
        opacity: 0;
        animation: none;
    }
    .active .hbmenu span:nth-of-type(3) {
        background-color: #fff;
        bottom: -3px;
        animation: active-menu-bar04-03 .75s forwards;
    }
    @keyframes active-menu-bar04-03 {
        0% {
            transform: translateY(0) rotate(0);
        }
        50% {
            transform: translateY(-7px) rotate(0);
        }
        100% {
            transform: translateY(-9px) rotate(-45deg);
        }
    }
    
    /*  メニューアクティブ時  */
    .main-v nav.open, .main-v-page nav.open {height: 100vh;transform: translate(0);}
    .sp-navi.open{
        transform: translate(100%);
        overflow: scroll;
        height: 100vh;
        background: #fff;
        box-shadow: 0 0 15px rgba(0, 0, 0, 0.4);
    }
    .sp-navi:after {
        height: 150px;
        content:"";
        display: block;
    }
    .on {animation: show 0.5s linear 0s;}
     
    @keyframes show{
        from{
            opacity: 0;
        }
        to{
            opacity: 1;
        }
    }
    .sp-cta-area {
        margin-top: 40px;
    }
    .sp-navi .label {
    background: #C6E3E3;
    color: #0C6262;
    font-size: 14px;
    width: 15%;
    text-align: center;
    padding: 3px;
    border-radius: 10px;
    font-weight: 900;
    height: 30px;
    position: relative;
    top: 5px;
}
.sp-navi .tel {
    margin-bottom: 25px;
}
.sp-navi .tel .num {
    width: 80%;
    font-size: 36px;
    font-weight: 900;
    line-height: 1;
}
.sp-navi .tel .num a {
    color: 0C6262;
}
.sp-navi .tel .num span {
    font-size: 12px;
    display: block;
    margin-top: 10px;
}
.sp-navi .mail .num {
    width: 80%;
    font-size: 23px;
    font-weight: 900;
    line-height: 1;
}
.sp-navi .mail .num span {
    font-size: 12px;
    display: block;
    margin-top: 10px;
}
.sp-navi .mail .num a {
    color: #0C6262;
}
.sp-navi .form-btn {
    margin-top: 25px;
}
.sp-navi .form-btn a {
    display: block;
    background: #C6E3E3;
    border-radius: 10px;
    padding: 15px;
    font-size: 14px;
    font-weight: bold;
    position: relative;
    color: #0C6262;
    text-align: center;
}
.sp-navi .form-btn a span {
    font-size: 12px;
    display: block;
}
.sp-navi .form-btn a::after {
    content: "";
    display: block;
    width: 8px;
    height: 16px;
    background: url(./images/arrow.png)no-repeat;
    background-size: 100%;
    position: absolute;
    right: 4%;
    top: 53%;
}

    .main-v {
        margin-top: 71px;
        padding: 15vw 0;
        margin-bottom: 10vw;
    }
    .main-v h2 {
        font-size: 4.4vw;
        margin: 0 6vw;
    }
    .main-v h2 span {
        display: block;
        font-size: 1.85vw;
        margin-top: 1vw;
    }
    .main-v h2::before {
        width: 30vw;
        height: 36vw;
        top: -47%;
    }
    .future, .service, .reason, .message, .member, .company, .faq {
        margin-bottom: 10vw;
    }
    .future h3 {
        font-size: 2.5vw;
        margin-bottom: 7vw;
    }
    .future h3::after {
        height: 4vw;
        bottom: -5vw;
    }
    .future p {
        font-size: 1.75vw;
        padding: 0 5vw;
    }
    .en-tit {
        font-size: 4.6vw;
        top: -7.7vw;
    }
    .tit {
        font-size: 2.9vw;
    }
    .service .fbox {
        gap: 5vw;
    }
    .service .item h4 {
        font-size: 2vw;
    }
    .service-num {
        font-size: 1.4vw;
        margin-bottom: 0.5vw;
    }
    .reason-content {
        width: 54vw;
    }
    .reason-content .reason-num {
        font-size: 1.3vw;
    }
    .reason-content .reason-num span {
        font-size: 4.6vw;
    }
    .message-content {
        width: 53%;
        margin-top: 8vw;
    }
    .message-content h3 {
        font-size: 2.8vw;
    }
    .company-inner {
        padding: 4vw;
    }
    .company-inner h3 {
        font-size: 2.4vw;
        margin-bottom: 2.5vw;
    }
    .faq-content {
        padding: 3vw 0;
        margin: 0 4vw;
    }
    .fq, .fa {
        font-size: 4.6vw;
    }
    .fq-tx {
        font-size: 1.8vw;
    }
    footer {
        padding: 5vw 0;
    }
    footer h3 {
        margin-bottom: 1.5vw;
    }
    footer .tel {
        margin-bottom: 2.5vw;
    }
    footer .label {
        font-size: 1.4vw;
        padding: 0.3vw;
        height: 3vw;
        top: 0.5vw;
    }
    footer .tel .num {
        font-size: 3.6vw;
    }
    footer .tel .num span {
        font-size: 1.2vw;
        margin-top: 1vw;
    }
    footer .mail .num {
        font-size: 2.3vw;
    }
    footer .mail .num span {
        font-size: 1.2vw;
        margin-top: 1vw;
    }
    .form-btn {
        margin-top: 2.5vw;
    }
    .form-btn a {
        padding: 1.5vw;
        font-size: 1.4vw;
    }
    .form-btn a span {
        font-size: 1.2vw;
    }
    .form-btn a::after {
        width: 0.8vw;
        height: 1.6vw;
    }
}



@media (max-width: 480px) {
    body {font-size: 14px}
    .pcbr {display:none;}
    .spbr {display:block;}
    p {margin-bottom: 7vw;}
    h2 {
        font-size: 5.4vw;
        margin-bottom: 8vw;
        margin-top: 8vw;
    }
    h3 {font-size: 4.6vw}
    h4 {
        font-size: 3.9vw;
    }
    h5 {
        font-size: 3.9vw;
    }
    .kome {
        font-size: 3vw;
    }
    .container {padding: 0 5vw;}
    .content-area {
        padding: 5vw 0 15vw;
    }
    header {
        padding: 0;
    }
    .logo-area {
        width: 185px;
        background: url(./images/logo-bg.png)no-repeat;
        background-size: 100%;
        padding: 9px 0 0px 10px;
        height: 46px;
    }
    .logo-area img {width: 110px;}
    .sp-navi {
        margin-top: 46px;
        transform: translate(130%);
        overflow: scroll;
        height: 100vh;
        background: #fff;
        width: 90%;
    }
    .sp-btn {
        width: 46px;
        height: 46px;
        padding-top: 10px;
        right: 7px;
        top: 0px;
    }
    .sp-navi.open {
        transform: translate(12%);
    }
    .sp-navi .label {
        font-size: 3vw;
        padding: 1.2vw 0;
        height: 7vw;
        top: 2vw;
    }
    .sp-navi .tel .num {
        font-size: 9vw;
    }
    .sp-navi .tel {
        margin-bottom: 5.5vw;
    }
    .sp-navi .mail .num {
        font-size: 5vw;
    }
    .sp-navi .form-btn a {
        padding: 4vw;
        font-size: 3.6vw;
    }
    .main-nav {margin: 0 0 30px;}
    .accordionlist dd {padding: 10px 20px;}
    .sub-menu li {
        background: url(images/common/icon-arrow-right-w.png)no-repeat;
        background-size: 6px;
        background-position-y: 12px;
        padding-left: 15px;        
    }
    .sp-navi li a {
        display: block;
        padding: 6px 0;
    }
    .sp-cta-area {
        width: 100%;
    }
    .sp-cta-area h3 {
        background: none;
        color: #fff;
        border: none;
        padding: 0;
        margin: 5vw 0 3vw;
        font-weight: 400;
    }
    .sp-cta-area .kome {
        color: #fff;
        margin-bottom: 5vw;
    }
    .sp-bnr-cta-tel, .sp-bnr-cta-mail {
        width: 100%;
        margin-bottom: 5vw;
    }
    .sp-tel-num {
        font-size: 8vw;
        background-size: 5.5vw;
        padding-left: 8vw;
    }
    .sp-bnr-cta-tel {
        font-size: 2.5vw;
    }
    .sp-bnr-cta-mail .fbox div {
        background-size: 7vw;
        width: 70%;
    }

    /*トップ*/
    .main-v {
        height: auto;
        margin-top: 46px;
        padding: 18vw 0;
        background-size: 140%;
        background-position-x: -130px;
    }
    .future, .service, .reason, .message, .member, .company, .faq {
        margin-bottom: 15vw;
    }
    .future h3 {
        font-size: 4.2vw;
        margin-bottom: 17vw;
    }
    .future h3::after {
        height: 10vw;
        bottom: -13vw;
    }
    .future p {
        font-size: 4.2vw;
        padding: 0 3vw;
    }
    .service {
        background-color: #fff;
        position: relative;
        padding: 7vw 0;
    }
    .en-tit {
        font-size: 7.6vw;
        top: -13.7vw;
    }
    .tit {
        font-size: 5vw;
        margin-bottom: 2vw;
    }
    .service .fbox {
        gap: 0;
    }
    .reason__img_sp {
        width: 100vw;
        margin-left: -5vw;
    }
    .service .item {
        flex: none;
        display: block;
        width: 71%;
        margin: 0 auto 8vw;
    }
    .service .item h4 {
        font-size: 4.6vw;
    }
    .service-num {
        font-size: 3.4vw;
        margin-bottom: 1vw;
    }
    .reason {
        padding: 7vw 0 12vw;
        background: linear-gradient(to right, #b5dbef 0%,#dff0f9 100%);
        margin-bottom: 20vw;
    }
    .reason__overlay, .reason__img {
        display: none;
    }
    .reason-content {
        width: 100%;
        margin-top: 10vw;
        padding: 0 2vw;
    }
    .reason-content .reason-num {
        font-size: 2.2vw;
    }
    .reason-content .reason-num span {
        font-size: 9vw;
    }
    .reason-content .tx p {
        margin-bottom: 0;
    }
    .message {
        padding: 7vw 0 10vw;
        background: linear-gradient(to right, #fafafa 0%,#f6f6f6 100%);
    }
    .message__img, .message__overlay {
        display: none;
    }
    .message__img_sp {
        width: 100vw;
        margin-left: -5vw;
    }
    .message-content {
        width: 100%;
        margin-top: 10vw;
        padding: 0 2vw;
    }
    .message-content p {
        font-size: 4.2vw;
    }
    .message-content span {
        font-size: 3.4vw;
    }
    .message-content h3 {
        font-size: 5.2vw;
        text-align: center;
        margin-bottom: 5vw;
    }
    .member {
        margin-top: 30vw;
    }
    .menber-content {
        padding: 0 4vw;
    }
    .menber-content .item {
        width: 48%;
        margin-right: 4%;
        margin-bottom: 6vw;
    }
    .menber-content .item:nth-child(2n) {
        margin-right: 0;
    }
    .company-inner {
        padding: 8vw 6vw;
        width: 96vw;
        margin-left: -3vw;
    }
    .company-inner h3 {
        font-size: 4.8vw;
        margin-bottom: 3.5vw;
    }
    .company-inner .about .tx {
        width: 100%;
        margin-bottom: 5vw;
    }
    .company-inner .about .map {
        width: 100%;
    }
    .map iframe {
        height: 50vw;
    }

    .faq .en-tit {
        top: -6vw;
    }
    .fq, .fa {
        font-size: 8.2vw;
        width: 10%;
    }
    .fq-tx, .fa-tx {
        width: 88%;
    }
    .fq-tx {
        font-size: 4.2vw;
    }
    .faq-content {
        padding: 6vw 0;
        margin: 0 4vw;
    }
    .faq-content .fbox{
        margin-bottom: 2vw;
    }
    footer {
        padding: 10vw 5vw;
    }
    footer .tx {
        width: 100%;
    }
    footer .cta {
        width: 100%;
    }
    footer .label {
        font-size: 3vw;
        padding: 1vw;
        height: 6.5vw;
        top: 0.5vw;
    }
    footer .tel {
        margin-bottom: 5.5vw;
    }
    footer .tel .num {
        font-size: 8vw;
    }
    footer .mail .num {
        font-size: 5.3vw;
    }
    footer .tel .num span {
        font-size: 2.7vw;
        margin-top: 3vw;
    }
    footer .mail .num span {
        font-size: 2.7vw;
        margin-top: 3vw;
    }
    .form-btn {
        margin-top: 5.5vw;
    }
    .form-btn a {
        padding: 4.5vw;
        font-size: 3vw;
    }
    .form-btn a span {
        font-size: 2vw;
    }
    .form-btn a::after {
        width: 1.8vw;
        height: 3.6vw;
    }
    .copyright {
        padding: 5vw 0;
        font-size: 2.4vw;
        text-align: center;
    }
}
