@charset "utf-8";
/*============================================================
	COMMMON
============================================================*/
/*------------------------------------------------------------
	共通
------------------------------------------------------------*/
/* clearfix */
.clearfix:after {
    content: "";
    display: block;
    clear: both;
}
/* flex */
.flex, .flexA, .flexB, .flexC {
    display: flex;
    flex-wrap: wrap;
}
.flexA {
    justify-content: space-around;
}
.flexB {
    justify-content: space-between;
}
.flexC {
    justify-content: center;
}
/* font */
.raleway {
    font-family: 'Raleway', sans-serif;
}
.notoSc {
    font-family: 'Noto Sans SC', sans-serif;
}
.fwB {
    font-weight: 600;
}
/*  v-align  */
.vam {
    vertical-align: middle !important;
}
/*  align  */
.taL {
    text-align: left !important;
}
.taC {
    text-align: center !important;
}
.taR {
    text-align: right !important;
}
/* margin */
.mt10 {
    margin-top: 10px;
}
.mt12 {
    margin-top: 12px;
}
.mt20 {
    margin-top: 20px;
}
.mt30 {
    margin-top: 30px;
}
.mt40 {
    margin-top: 40px;
}
.mt50 {
    margin-top: 50px;
}
.mt60 {
    margin-top: 60px;
}
.mt70 {
    margin-top: 70px;
}
.mt80 {
    margin-top: 80px;
}
.mt90 {
    margin-top: 90px;
}
.mb0 {
    margin-bottom: 0px !important;
}
.mb5 {
    margin-bottom: 5px !important;
}
.mb10 {
    margin-bottom: 10px !important;
}
.mb20 {
    margin-bottom: 20px !important;
}
.mb30 {
    margin-bottom: 30px !important;
}
.mb40 {
    margin-bottom: 40px !important;
}
.mb50 {
    margin-bottom: 50px !important;
}
.mb60 {
    margin-bottom: 60px !important;
}
.mb70 {
    margin-bottom: 70px !important;
}
.mb80 {
    margin-bottom: 80px !important;
}
.mb90 {
    margin-bottom: 90px !important;
}
.mb100 {
    margin-bottom: 100px !important;
}
.mb110 {
    margin-bottom: 110px !important;
}
.mb120 {
    margin-bottom: 120px !important;
}
.mb200 {
    margin-bottom: 200px !important;
}
.mL10 {
    margin-left: 10px !important;
}
.mL15 {
    margin-left: 15px !important;
}
.mL20 {
    margin-left: 20px !important;
}
.mL30 {
    margin-left: 30px !important;
}
.mL40 {
    margin-left: 40px !important;
}
.mL47 {
    margin-left: 47px !important;
}
.mL50 {
    margin-left: 50px !important;
}
.mL52 {
    margin-left: 52px !important;
}
.mL60 {
    margin-left: 60px !important;
}
.mL70 {
    margin-left: 70px !important;
}
.mL80 {
    margin-left: 80px !important;
}
.mL90 {
    margin-left: 90px !important;
}
.mL100 {
    margin-left: 100px !important;
}
.mL110 {
    margin-left: 110px !important;
}
.mL120 {
    margin-left: 120px !important;
}
.mL130 {
    margin-left: 130px !important;
}
.mL140 {
    margin-left: 140px !important;
}
.mL150 {
    margin-left: 150px !important;
}
.mL160 {
    margin-left: 160px !important;
}
.supH2 {
    font-size: 17px !important;
}
/* responsive */
.pcOnly {
    display: block;
}
.spOnly {
    display: none;
}
@media (max-width: 896px) {
    .pcOnly {
        display: none;
    }
    .spOnly {
        display: block;
    }
}
/*------------------------------------------------------------
	fadeInUp
------------------------------------------------------------*/
.fadeInUp {
    opacity: 0;
    -webkit-transform: translateY(60px);
    transform: translateY(60px);
    transition: transform 1s, opacity 1s;
}
.fadeInUp.on {
    opacity: 1;
    -webkit-transform: translateY(0);
    transform: translateY(0);
}
/*------------------------------------------------------------
	pageTitle
------------------------------------------------------------*/
.pageTitle {
    height: 260px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}
.pageTitle h2 {
    color: #000;
    font-weight: 600;
    font-size: 4.8rem;
    line-height: 1.65;
    letter-spacing: 0.15em;
    font-family: "Raleway", "Noto Sans JP";
    margin-right: 4%;
}
.pageTitle .sml {
    margin-bottom: 0px;
    display: block;
    font-weight: 400;
    font-size: 1.6rem;
    letter-spacing: 0.2em;
}
.pageTitle h2.white {
    color: #fff;
    text-shadow: 0 0 15px #666;
}
.pageTitle h2.red {
    color: #ef0041;
}
@media all and (min-width: 897px) and (max-width: 1679px) {
    .pageTitle {
        height: 17.57vw;
    }
    .pageTitle h2 {
        font-size: 2.48vw;
    }
    .pageTitle .sml {
        font-size: 1.12vw;
    }
}
@media all and (max-width: 896px) {
    .pageTitle {
        height: 100px;
        background-image: url("../../images/common/common_bg_sp.jpg");
    }
    .pageTitle01 {
        height: 180px;
    }
    .pageTitle02 {
        height: 80px;
    }
    .pageTitle h2 {
        margin-top: 5px;
        padding-bottom: 0;
        font-size: 2rem;
        line-height: 1.4;
    }
    .pageTitle .sml {
        margin-bottom: 0;
        font-size: 1.4rem;
    }
    .pageTitle01 .h2Ttl01 {
        margin-bottom: 4px;
        padding: 0 18px;
        width: 100%;
        box-sizing: border-box;
    }
    .pageTitle01 .h2Ttl01 .txt {
        margin-top: 6px;
        font-size: 1.4rem;
        line-height: 1.43;
    }
}
/*------------------------------------------------------------
	content
------------------------------------------------------------*/
.content {
    margin: 0 auto;
    width: 980px;
    color: #333;
}
@media all and (max-width: 896px) {
    .content {
        margin: 0 7%;
        /*margin: 0 20px;*/
        width: auto;
    }
}
/*------------------------------------------------------------
	headLine01
------------------------------------------------------------*/
.headLine01 {
    padding-bottom: 39px;
    position: relative;
    text-align: left;
    font-weight: 400;
    font-size: 3.4rem;
    line-height: 1.65;
    letter-spacing: 0.2em;
    font-family: "Raleway", "Noto Sans JP";
    color: #000;
}
.headLine01 .sml {
    margin-bottom: 22px;
    display: block;
    font-size: 1.8rem;
    letter-spacing: 0.2em;
    color: #000;
}
@media all and (max-width: 896px) {
    .headLine01 {
        padding-bottom: 25px;
        font-size: 2rem;
        line-height: 1.6;
        letter-spacing: 0.1em;
    }
    .headLine01::after {
        width: 40px;
    }
    .headLine01 .sml {
        margin-bottom: 9px;
        font-size: 1.4rem;
        letter-spacing: 0.1em;
        line-height: 1.43;
    }
}
/*------------------------------------------------------------
	headLine02
------------------------------------------------------------*/
.headLine02 {
    position: relative;
    font-size: 2.4rem;
    font-weight: 500;
    line-height: 1.38;
    letter-spacing: 0.1em;
    font-family: "Raleway", "Noto Sans JP";
    color: #333;
    margin-bottom: 40px;
}
.headLine02 .sml {
    display: block;
    font-weight: 300;
    font-size: 1.4rem;
    letter-spacing: 0.1em;
    color: #ed0041;
    margin: 10px 0 30px;
}
@media all and (max-width: 896px) {
    .headLine02 {
        margin-bottom: 7px;
        padding-bottom: 13px;
        font-size: 1.6rem;
        line-height: 1.375;
        letter-spacing: 0.05em;
    }
    .headLine02 .sml {
        margin-bottom: 9px;
        font-size: 1.4rem;
        letter-spacing: 0.1em;
        line-height: 1.43;
    }
}
/*------------------------------------------------------------
	headLine03
------------------------------------------------------------*/
.headLine03 {
    position: relative;
    font-size: 1.8rem;
    font-weight: 400;
    line-height: 1.38;
    letter-spacing: 0.1em;
    font-family: "Raleway", "Noto Sans JP";
    color: #000;
    padding: 0 0 0 16px;
    margin-bottom: 30px;
    border-left: solid 2px #2355a7;
}
.headLine03 .sml {
    font-weight: 300;
    font-size: 1.5rem;
    letter-spacing: 0.1em;
    margin-bottom: 10px;
    color: #000;
}
@media all and (max-width: 896px) {
    .headLine03 {
        font-size: 1.6rem;
        line-height: 1.6;
        letter-spacing: 0.05em;
    }
    .headLine03 .sml {
        margin-bottom: 12px;
        font-size: 1.4rem;
        letter-spacing: 0.1em;
        line-height: 1.43;
    }
}
/*------------------------------------------------------------
	headLine04
------------------------------------------------------------*/
.headLine04 {
    margin-bottom: 20px;
    position: relative;
    text-align: center;
    font-weight: 400;
    font-size: 1.4rem;
    letter-spacing: 0.2em;
    line-height: 1.63;
    color: #000;
}
@media all and (max-width: 896px) {
    .headLine04 {
        margin-bottom: 15px;
        padding-bottom: 12px;
        font-size: 1.4rem;
        letter-spacing: 0.05em;
    }
}
/*------------------------------------------------------------
	headLine05
------------------------------------------------------------*/
.headLine05 {
    padding: 24px 0 16px;
    position: relative;
    font-weight: 600;
    font-size: 1.8rem;
    letter-spacing: 0.1em;
    color: #000;
}
@media all and (max-width: 896px) {
    .headLine05 {
        padding: 0 0 12px;
        font-size: 1.4rem;
        letter-spacing: 0.1em;
    }
}
/*------------------------------------------------------------
	headLine06
------------------------------------------------------------*/
.headLine06 {
    padding-bottom: 8px;
    position: relative;
    font-weight: 600;
    font-size: 1.5rem;
    line-height: 2;
    letter-spacing: 0.1em;
    color: #000;
}
@media all and (max-width: 896px) {
    .headLine06 {
        margin-bottom: 0;
        padding-bottom: 4px;
        font-size: 1.2rem;
        line-height: 2.66;
        letter-spacing: 0.05em;
    }
}
/*------------------------------------------------------------
	headLine07
------------------------------------------------------------*/
.headLine07 {
    margin-bottom: 10px;
    color: #333;
    font-size: 1.5rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    line-height: 1.8;
    color: #000;
}
@media all and (max-width: 896px) {
    .headLine07 {
        margin-bottom: 7px;
        font-size: 1.4rem;
        letter-spacing: 0.05em;
        line-height: 1.429;
    }
}
/*------------------------------------------------------------
	headLine08
------------------------------------------------------------*/
.headLine08 {
    margin-bottom: 16px;
    color: #0053A4;
    font-size: 1.6rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    line-height: 1.8;
    color: #000;
}
@media all and (max-width: 896px) {
    .headLine08 {
        margin-bottom: 10px;
        font-size: 1.2rem;
        letter-spacing: 0.05em;
        line-height: 1.5;
    }
}
/*------------------------------------------------------------
	comBtn
------------------------------------------------------------*/
.comBtn {
    margin: 0 auto;
}
.comBtn a, .comBtn.blank a {
    padding: 12px 38px 15px 18px;
    display: block;
    position: relative;
    font-size: 1.4rem;
    font-weight: 700;
    letter-spacing: 0.15em;
    border: 1px solid #666;
}
.comBtn a::after {
    width: 17px;
    height: 9px;
    position: absolute;
    right: 20px;
    top: 50%;
    background: url("../img/common/arrow_01_b.svg") no-repeat right center / 100% auto;
    content: '';
    transform: translateY(-50%);
}
.comBtn.blank a::after {
    width: 17px;
    height: 17px;
    background: url("../img/common/blank_01_b.svg") no-repeat right center / 100% auto;
    margin: 0;
}
.comBtn.en {
    width: 180px;
}
.comBtn.en a {
    padding: 12px 30px 8px 14px;
    font-family: 'Raleway', sans-serif;
    font-weight: 700;
    font-size: 1.2rem;
    letter-spacing: 0.1em;
}
.comBtn.en a::after {
    right: 9px;
}
@media all and (min-width: 897px) {
    .comBtn a {
        transition: all 0.3s;
    }
    .comBtn a::after {
        transition: ease-in-out right 0.3s;
    }
    .comBtn a:hover {
        color: #fff;
        border: 1px solid #000;
        background-color: #000;
    }
    .comBtn a:hover::after {
        background-image: url("../img/common/arrow_01_w.svg");
        right: 10px;
    }
    .comBtn.blank a:hover::after {
        background-image: url("../img/common/blank_01_w.svg");
        right: 20px;
    }
    .comBtn.en a:hover::after {
        right: 4px;
    }
}
@media all and (max-width: 896px) {
    .comBtn {
        width: 184px;
    }
    .comBtn a {
        padding: 11px 28px 12px 14px;
        font-size: 1rem;
    }
    .comBtn a::after {
        width: 11px;
        height: 12px;
        right: 15px;
    }
    .comBtn.en {
        width: auto;
        max-width: 136px;
    }
    .comBtn.en a {
        padding: 8px 25px 5px 12px;
        text-align: center;
        font-size: 1rem;
        letter-spacing: 0.05em;
    }
    .comBtn.en a::after {
        right: 9px;
    }
}
/*------------------------------------------------------------
	comNavi
------------------------------------------------------------*/
.comNaviBox .comNavi > li > a {
    padding-bottom: 16px;
    display: block;
    position: relative;
    font-weight: 700;
    font-size: 2.0rem;
    letter-spacing: 0.2em;
}
.comNaviBox .comNavi > li {
    margin-bottom: 0;
}
.comNaviBox .comNavi > li:last-child {
    margin-bottom: 45px;
}
.comNaviBox .comNavi li .subList {
    margin-top: 8px;
}
.comNaviBox .comNavi li .subList li {
    margin-bottom: 14px;
}
.comNavi li .subList li:last-child {
    margin-bottom: 0;
}
.comNaviBox .comNavi li .subList li a {
    display: block;
    font-size: 1.6rem;
    letter-spacing: 0.2em;
}
.comNaviBox .inner .utilityList {
    margin-bottom: 16px;
}
.comNaviBox .inner .utilityList li {
    margin-bottom: 12px;
}
.comNaviBox .inner .utilityList li:last-child {
    margin-bottom: 0;
}
.comNaviBox .inner .utilityList li a {
    font-size: 1.2rem;
    letter-spacing: 0.2em;
    color: #000;
}
.comNaviBox .inner .twBtn a {
    display: inline-block;
    font-size: 1.4rem;
    letter-spacing: 0.05em;
}
.comNaviBox .inner .blank::after {
    margin-left: 12px;
    width: 16px;
    height: 12px;
    display: inline-block;
    background: url("../img/common/icon_blank_w.svg") no-repeat center center / 100% 100%;
    content: '';
}
@media all and (min-width: 897px) {
    .comNaviBox .comNavi li a:hover, .comNaviBox .comNavi li .subList li a:hover {
        color: rgba(229, 0, 18, 1.00);
    }
    .comNaviBox .fBtn a:hover {
        background: rgba(229, 0, 18, 0.7);
    }
    .comNaviBox .inner .utilityList li a:hover {
        text-decoration: underline;
    }
    .comNaviBox .inner .twBtn a:hover {
        text-decoration: underline;
    }
}
@media all and (max-width: 896px) {
    .comNaviBox {
        display: block;
    }
    .comNaviBox .comNavi > li:last-child {
        margin-bottom: 0px;
    }
    .comNaviBox .inner .fBtn {
        margin: 0 auto 20px;
    }
    .comNaviBox .inner .utilityList {
        margin-bottom: 29px;
    }
    .comNaviBox .inner .utilityList li {
        margin-bottom: 15px;
    }
    .comNaviBox .inner .utilityList li:last-child {
        margin-bottom: 0;
    }
    .comNaviBox .inner .utilityList li a {
        font-size: 1rem;
    }
    .comNaviBox .inner .twBtn {
        margin-bottom: 25px;
    }
    .comNaviBox.inner a {
        font-size: 1rem;
    }
    .comNaviBox .inner .blank::after {
        margin-left: 7px;
        width: 12px;
        height: 9px;
    }
    .comNaviBox .inner .twBtn a img {
        margin: -8px 10px 10px 0px;
        width: 33px;
        height: 33px;
    }
    .comNaviBox > div {
        width: auto;
    }
    .comNaviBox > div:nth-child(2) {
        width: auto;
    }
    .comNaviBox > div:nth-child(3) {
        width: auto;
    }
    .comNaviBox .comNavi > li {
        margin-bottom: 0;
        border-bottom: 1px solid #dadada;
    }
    .comNaviBox .comNavi > li > a {
        padding: 15px 25px 16px 15px;
        font-size: 1.2rem;
        letter-spacing: 0.2em;
    }
    .comNaviBox .comNavi > li > a::after {
        display: none;
    }
    .comNaviBox .comNavi li .subList {
        display: none;
    }
    .comNaviBox .inner {
        margin: 0;
        padding: 27px 15px 0;
        border-top: none;
    }
}
/*------------------------------------------------------------
	comPageNavi
------------------------------------------------------------*/
.pageNaviBox {
    margin: 0 auto;
    padding: 48px 48px 76px;
    width: 1194px;
}
.comPageNavi {
    background: #f4f4f4;
    border-top: 1px solid #dadada;
}
.comPageNavi .link {
    margin-bottom: 24px;
    font-weight: 700;
    line-height: 2.25;
    letter-spacing: 0.1em;
}
.comPageNavi .link a::after {
    margin: 1px 0 0 12px;
    width: 17px;
    height: 11px;
    display: inline-block;
    content: '';
}
.comPageNavi .linkList {
    margin-top: -29px;
}
.comPageNavi .linkList li {
    margin-top: 29px;
    margin-right: -1px;
    width: 299px;
    box-sizing: border-box;
    border-left: 1px solid #dadada;
    border-right: 1px solid #dadada;
}
.comPageNavi .linkList li a {
    padding: 11px 19px 13px;
    display: block;
    font-size: 1.4rem;
    letter-spacing: 0.1em;
    text-align: center;
}
.comPageNavi .linkList li a::after {
    width: 17px;
    height: 9px;
    display: inline-block;
    content: '';
}
@media all and (max-width: 896px) {
    .pageNaviBox {
        margin: 0 20px;
        width: auto;
        padding: 0;
    }
}
@media all and (min-width: 897px) {
    .comPageNavi .link a, .comPageNavi .link a::after {
        transition: 0.3s;
    }
    .comPageNavi .link a:hover {
        opacity: 0.7;
    }
    .comPageNavi .link a:hover::after {
        transform: translateX(10px);
    }
    .comPageNavi .linkList li a, .comPageNavi .linkList li a::after {
        transition: 0.3s;
    }
    .comPageNavi .linkList li a:hover {
        opacity: 0.7;
    }
    .comPageNavi .linkList li a:hover::after {
        transform: translateX(10px);
    }
}
@media all and (max-width: 896px) {
    .comPageNavi {
        padding: 23px 0 29px;
    }
    .comPageNavi .link {
        margin-bottom: 14px;
        font-size: 1.2rem;
        line-height: 2;
        letter-spacing: 0.05em;
    }
    .comPageNavi .link a::after {
        margin: 1px 0 0 8px;
        width: 11px;
        height: 7px;
    }
    .comPageNavi .linkList {
        margin: 0 2px;
        display: block;
    }
    .comPageNavi .linkList li {
        margin: 0 0 20px;
        width: auto;
    }
    .comPageNavi .linkList li:last-child {
        margin-bottom: 0;
    }
    .comPageNavi .linkList li a {
        padding: 1px 13px;
        font-size: 1.2rem;
        text-align: left;
    }
    .comPageNavi .linkList li a::after {
        margin: 2px 0 0 10px;
        width: 11px;
        height: 7px;
        position: absolute;
        right: 40px;
    }
}
/*------------------------------------------------------------
	comNewsList
------------------------------------------------------------*/
.comNewsList {
    border-top: 1px solid #999;
}
.comNewsList li {
    border-bottom: 1px solid #999;
    position: relative;
}
.comNewsList li a {
    padding: 28px 24px;
    display: flex;
    align-items: flex-start;
    position: relative;
    background: #fff;
    transition: 0.3s;
}
.comNewsList li a::after {
    width: 17px;
    height: 9px;
    position: absolute;
    right: 20px;
    top: 50%;
    background: url("../img/common/arrow_01_b.svg") no-repeat center center / 100% 100%;
    content: '';
    transform: translateY(-50%);
    transition: 0.3s;
}
.comNewsList li .date {
    width: 132px;
    font-weight: 400;
    font-size: 1.4rem;
    letter-spacing: 0.15em;
}
.comNewsList li .tag {
    box-sizing: border-box;
    margin-top: 1px;
    margin-right: 40px;
    padding: 3px 5px 5px;
    width: 80px;
    display: block;
    text-align: center;
    color: #fff;
    font-size: 1.2rem;
    line-height: 1;
    letter-spacing: 0.1em;
    background: #0053A4;
}
.comNewsList li .txt {
    position: absolute;
    left: 260px;
    width: calc(100% - 252px);
    display: block;
    font-size: 1.4rem;
    letter-spacing: 0.15em;
}
.comNewsList li a.noClick {
    cursor: default;
    pointer-events: none;
}
.comNewsList li a.noClick::after {
    display: none;
}
@media all and (min-width: 897px) {
    .comNewsList li a:hover {
        background: #f6f6f6;
    }
    .comNewsList li a:hover::after {
        right: 10px;
    }
}
@media all and (max-width: 896px) {
    .comNewsList li a {
        padding: 13px 30px 11px 10px;
        display: block;
    }
    .comNewsList li a::after {
        width: 11px;
        height: 7px;
        right: 10px;
        transition: none;
    }
    .comNewsList li .date {
        margin-bottom: 7px;
        width: auto;
        display: block;
        font-size: 1.2rem;
        letter-spacing: 0.05em;
    }
    .comNewsList li .tag {
        position: absolute;
        top: 15px;
        left: 100px;
        margin: 0 0 6px;
        padding: 3px 5px;
        width: 65px;
        font-size: 1rem;
    }
    .comNewsList li .txt {
        position: relative;
        left: auto;
        width: auto;
        min-height: 24px;
        font-size: 1.2rem;
        letter-spacing: 0.15em;
    }
    .comNewsList li .viewList {
        font-size: 0.8rem;
        letter-spacing: 0.15em;
    }
}
/*------------------------------------------------------------
	LIST
------------------------------------------------------------*/
/* 通常リスト */
.listCommon {
    margin-left: 20px;
}
.listCommon li {
    list-style: disc !important;
    margin: 0 0 5px;
}
.listCommon li ul {
    margin-top: 5px;
}
/* 通常リスト:Square  */
.listSquare {
    margin-left: 20px;
}
.listSquare li {
    list-style: square !important;
    margin: 0 0 5px;
}
.listSquare li ul {
    margin-top: 5px;
}
/* 通常リスト:Circle */
.listCircle {
    margin-left: 20px;
}
.listCircle li {
    list-style: circle !important;
    margin: 0 0 5px;
}
.listCircle li ul {
    margin-top: 5px;
}
/* 順列リスト */
.listOrder {
    margin-left: 20px;
}
.listOrder li {
    list-style: decimal;
    margin: 0 0 15px;
    line-height: 1.8;
}
.listOrder li ul {
    margin-top: 10px;
}
/* 順列リスト 数字） */
ol.listPar {
    margin-left: 40px;
}
ol.listPar > li {
    list-style-type: none;
    counter-increment: cnt;
    position: relative;
}
ol.listPar > li:before {
    content: ""counter(cnt)"）";
    display: inline-block;
    margin-left: -40px;
    width: 2em;
    text-align: right;
    position: absolute;
    top: 0;
    left: 0;
}
/* 順列リスト （数字） */
ol.listPar2 {
    margin-left: 50px;
}
ol.listPar2 > li {
    list-style-type: none;
    counter-increment: cnt;
    position: relative;
}
ol.listPar2 > li:before {
    content: "（"counter(cnt)"）";
    display: inline-block;
    margin-left: -50px;
    width: 2em;
    text-align: right;
    position: absolute;
    top: 0;
    left: 0;
}
/* 定義リスト */
.dList1 dt {
    padding-left: 1.5em;
    text-indent: -1.5em;
}
.dList1 dt:before {
    content: "●";
    color: #0053A4;
    margin-right: 0.5em;
}
.dList1 dd {
    margin-left: 1.5em;
    font-weight: bold;
}
dl.dtalign {
    overflow: hidden;
    margin-bottom: 30px;
}
dl.dtalign dt {
    float: left;
    margin-right: 15px;
    clear: both;
}
dl.dtalign dd {
    float: left;
    text-indent: -1em;
}
dl.dtalign dd.indent0 {
    text-indent: 0em;
}
dl.dtalign dd:before {
    content: "：";
}
dl.dtalign.num dd:before {
    content: "";
}
dl.dtalign.mark dt:before {
    content: "・";
    font-weight: bold;
}
dl.dtalign.mark dd:before {
    content: "";
}
dl.dtalign.w1em dt {
    width: 1em;
}
dl.dtalign.w1em dd {
    max-width: 440px;
}
dl.dtalign.w10 dt {
    width: 10px;
}
dl.dtalign.w10 dd {
    max-width: 707px;
}
dl.dtalign.w20 dt {
    width: 20px;
}
dl.dtalign.w20 dd {
    max-width: 697px;
}
dl.dtalign.w30 dt {
    width: 30px;
}
dl.dtalign.w30 dd {
    max-width: 687px;
}
dl.dtalign.w50 dt {
    width: 50px;
}
dl.dtalign.w50 dd {
    max-width: 667px;
}
dl.dtalign.w70 dt {
    width: 70px;
}
dl.dtalign.w70 dd {
    max-width: 647px;
}
dl.dtalign.w80 dt {
    width: 80px;
}
dl.dtalign.w80 dd {
    max-width: 637px;
}
dl.dtalign.w85 dt {
    width: 85px;
}
dl.dtalign.w85 dd {
    max-width: 632px;
}
dl.dtalign.w90 dt {
    width: 90px;
}
dl.dtalign.w90 dd {
    max-width: 627px;
}
dl.dtalign.w95 dt {
    width: 95px;
}
dl.dtalign.w95 dd {
    max-width: 622px;
}
dl.dtalign.w100 dt {
    width: 100px;
}
dl.dtalign.w100 dd {
    max-width: 617px;
}
dl.dtalign.w110 dt {
    width: 110px;
}
dl.dtalign.w110 dd {
    max-width: 607px;
}
dl.dtalign.w120 dt {
    width: 120px;
}
dl.dtalign.w120 dd {
    max-width: 597px;
}
dl.dtalign.w130 dt {
    width: 130px;
}
dl.dtalign.w130 dd {
    max-width: 587px;
}
dl.dtalign.w140 dt {
    width: 140px;
}
dl.dtalign.w140 dd {
    max-width: 577px;
}
dl.dtalign.w150 dt {
    width: 150px;
}
dl.dtalign.w150 dd {
    max-width: 567px;
}
dl.dtalign.w160 dt {
    width: 130px;
}
dl.dtalign.w160 dd {
    max-width: 557px;
}
dl.dtalign.w170 dt {
    width: 140px;
}
dl.dtalign.w170 dd {
    max-width: 547px;
}
dl.dtalign.w180 dt {
    width: 180px;
}
dl.dtalign.w180 dd {
    max-width: 537px;
}
dl.dtalign.w210 dt {
    width: 210px;
}
dl.dtalign.w210 dd {
    max-width: 497px;
}
dl.dtalign.w220 dt {
    width: 220px;
}
dl.dtalign.w220 dd {
    max-width: 497px;
}
dl.dtalign.w400 dt {
    width: 400px;
}
dl.dtalign.w400 dd {
    max-width: 317px;
}
dl.dtalign.w170t dt {
    width: 170px;
}
dl.dtalign.w170 dd {
    max-width: 547px;
}
dl.dtalign.w200 dt {
    width: 200px;
}
dl.dtalign.w200 dd {
    max-width: 517px;
}
dl.dtalign.w230 dt {
    width: 230px;
}
dl.dtalign.w230 dd {
    max-width: 487px;
}
dl.dtalign.w240 dt {
    width: 240px;
}
dl.dtalign.w240 dd {
    max-width: 477px;
}
dl.dtalign.w250 dt {
    width: 250px;
}
dl.dtalign.w250 dd {
    max-width: 467px;
}
dl.dtalign.w230-02 dt {
    width: 230px;
}
dl.dtalign.w230-02 dd {
    max-width: 612px;
}
dl.dtalign dt.w30 {
    width: 30px;
}
dl.dtalign dt.w50 {
    width: 50px;
}
dl.dtalign.w50 + dd {
    max-width: 667px;
}
dl.dtalign dt.w70 {
    width: 70px;
}
dl.dtalign.w70 + dd {
    max-width: 647px;
}
dl.dtalign dt.w80 {
    width: 80px;
}
dl.dtalign.w80 + dd {
    max-width: 637px;
}
dl.dtalign dt.w85 {
    width: 85px;
}
dl.dtalign.w85 + dd {
    max-width: 632px;
}
dl.dtalign dt.w90 {
    width: 90px;
}
dl.dtalign.w90 + dd {
    max-width: 627px;
}
dl.dtalign dt.w95 {
    width: 95px;
}
dl.dtalign.w95 + dd {
    max-width: 622px;
}
dl.dtalign dt.w100 {
    width: 100px;
}
dl.dtalign.w100 + dd {
    max-width: 617px;
}
dl.dtalign dt.w110 {
    width: 110px;
}
dl.dtalign.w110 + dd {
    max-width: 607px;
}
dl.dtalign dt.w120 {
    width: 120px;
}
dl.dtalign.w120 + dd {
    max-width: 597px;
}
dl.dtalign dt.w130 {
    width: 130px;
}
dl.dtalign.w130 + dd {
    max-width: 587px;
}
dl.dtalign dt.w140 {
    width: 140px;
}
dl.dtalign.w140 + dd {
    max-width: 577px;
}
dl.dtalign dt.w150 {
    width: 150px;
}
dl.dtalign.w150 + dd {
    max-width: 567px;
}
dl.dtalign dt.w160 {
    width: 160px;
}
dl.dtalign.w160 + dd {
    max-width: 557px;
}
dl.dtalign dt.w170 {
    width: 170px;
}
dl.dtalign.w170 + dd {
    max-width: 547px;
}
dl.dtalign dt.w180 {
    width: 180px;
}
dl.dtalign.w180 + dd {
    max-width: 537px;
}
dl.dtalign dt.w220 {
    width: 220px;
}
dl.dtalign.w220 + dd {
    max-width: 497px;
}
dl.dtalign dt.w400 {
    width: 400px;
}
dl.dtalign.w400 + dd {
    max-width: 317px;
}
@media only screen and (max-width: 640px) {
    dl.dtalign dt, dl.dtalign dd {
        float: none;
        text-indent: 0;
        margin-right: 0;
    }
    dl.dtalign dt {
        font-weight: bold;
    }
    dl.dtalign dt:after {
        content: "：";
    }
    dl.dtalign dd:before {
        display: none;
    }
    dl.dtalign.num dt:after {
        display: none;
    }
    dl.dtalign.mark dt:before {
        display: none;
    }
    dl.dtalign.mark dt:after {
        display: none;
    }
}
/*------------------------------------------------------------
	TABLE
------------------------------------------------------------*/
#main table {
    width: auto;
    border-collapse: collapse;
    table-layout: fixed;
    word-break: break-all;
    word-wrap: break-all;
}
#main th, #main td {
    padding: 18px 10px 19px;
    width: 70%;
    vertical-align: top;
    text-align: left;
    font-size: 1.4rem;
    letter-spacing: 0.1em;
    line-height: 2;
    border-top: 1px solid #969696;
    border-bottom: 1px solid #969696;
}
#main th {
    width: 30%;
    font-weight: 600;
    color: #333;
}
#main td {
    padding-right: 8px;
}
@media all and (max-width: 896px) {
    #main table {
        border-top: 1px solid #969696;
    }
    #main th, #main td {
        padding: 2px 0 9px;
        width: auto;
        display: block;
        box-sizing: border-box;
        font-size: 1.2rem;
        letter-spacing: 0.05em;
        border-top: none;
    }
    #main th {
        padding: 7px 0 0;
        width: auto;
        border-bottom: none;
    }
}
/*------------------------------------------------------------
	TEL
------------------------------------------------------------*/
@media (min-width: 897px) {
    a[href*="tel:"] {
        pointer-events: none;
        cursor: default;
        text-decoration: none;
    }
}
/*------------------------------------------------------------
	BUTTON
------------------------------------------------------------*/
/*== グラデーションが流れる */
.gradient {
    /*ボタンの形状*/
    display: inline-block;
    text-align: center;
    padding: 18px 0;
    border-radius: 30px;
    text-decoration: none;
    outline: none;
    /*背景の色と形状*/
    background: linear-gradient(90deg, rgba(18, 100, 190, 1), rgba(14, 244, 255, 1));
    background-position: 5% 50%;
    background-size: 200% auto;
    /*アニメーションの指定*/
    transition: all 0.3s ease-out;
}
/*hoverした際の、背景の場所とテキスト色の変更*/
.gradient:hover {
    color: #fff;
    background-position: 50% 50%;
}
a.gradient:link {
    color: #fff;
    text-decoration: none;
}
a.gradient:visited {
    color: #fff;
}
/*------------------------------------------------------------
	FADE UP
------------------------------------------------------------*/
/* fadeUp */
.fadeUp {
animation-name:fadeUpAnime;
animation-duration:0.5s;
animation-fill-mode:forwards;
opacity:0;
}
@keyframes fadeUpAnime{
  from {
    opacity: 0;
  transform: translateY(100px);
  }

  to {
    opacity: 1;
  transform: translateY(0);
  }
}
/* スクロールをしたら出現する要素にはじめに透過0を指定　*/
.fadeUpTrigger {
    opacity: 0;
}
/* delay */
.delay-time02 {
animation-delay: 0.2s;
}
.delay-time04 {
animation-delay: 0.4s;
}
.delay-time06 {
animation-delay: 0.6s;
}
.delay-time08 {
animation-delay: 0.8s;
}
.delay-time10 {
animation-delay: 1.0s;
}
.delay-time12 {
animation-delay: 1.2s;
}
.delay-time14 {
animation-delay: 1.4s;
}
.delay-time16 {
animation-delay: 1.6s;
}
/*------------------------------------------------------------
	BUTTON
------------------------------------------------------------*/
.gradient {
    width: 480px;
    margin: 60px 0 40px;
}
@media all and (max-width: 896px) {
    .gradient {
        width: 90%;
        margin: 0 auto;
        padding: 18px 0;
        font-size: 1.4rem;
    }
}
/*------------------------------------------------------------
	MODAL
------------------------------------------------------------*/
.hide-area {
  display: none;
}
.modaal-close:after, .modaal-close:before {
  background: #ccc;
}
.modaal-close:focus:after, .modaal-close:focus:before, .modaal-close:hover:after, .modaal-close:hover:before {
  background: #666;
}
 /*------------------------------------------------------------
	PRIVACY POLICY - MODAL
------------------------------------------------------------*/
.modaal-content-container {
    padding: 0;
}
#handling {
    padding: 100px 60px 80px;
    background: #e9f8ff;
    }
#objective {
    padding: 100px 60px 80px;
    background: #fff;
    }
#objective h4 {
    margin-top: 30px;
    }
#inquiry {
    padding: 100px 60px 80px;
    background: #e9f8ff;
    }
@media all and (max-width: 896px) {
    #handling, #objective, #inquiry {
        font-size: 1.2rem;
        padding: 50px 20px 40px;
      }
    #inquiry {
        margin-bottom: 30px;
      }
    }