/*===========================
add
===========================*/
/*===========================
list
===========================*/
ul.nb_circle li {
    padding: 0 0 0.2em 1.2em;
    margin-bottom: 0.2em;
}
ul.nb_circle li:before {
    position: absolute;
    content: "";
    width: 6px;
    height: 6px;
    background-color: #222;
    border-radius: 50%;
    left: 0.3em;
    margin-top: 0.5em;
}
ul.nb_circle, ul.circle2, ul.circle3, ul.check2, ul.check3 {
    position: relative;
}
ul.circle2 li, ul.check2 li {
    float: left;
    width: 45%;
    padding: 0 0 0.5em 1.8em;
    margin: 0 1% 0.5em;
    border-bottom: 1px dashed #CCC;
}
ul.circle2 li:before {
    position: absolute;
    content: "";
    width: 6px;
    height: 6px;
    background-color: #222;
    border-radius: 50%;
    /* [disabled]left: 0.5em;
*/
    margin-top: 0.6em;
    margin-left: -1em;
}
ul.check2 li::before {
    display: block;
    position: absolute;
    content: "\f14a";
    font-family: FontAwesome;
    font-size: 1.3em;
    margin-left: -1.2em;
}
ul.circle3 li, ul.check3 li {
    float: left;
    width: 30%;
    margin: 0 1.5% 0.5em;
    padding-bottom: 0.5em;
}
ul.circle3 li:before {
    position: absolute;
    content: "";
    width: 6px;
    height: 6px;
    background-color: #222;
    border-radius: 50%;
    /* [disabled]left: 0.5em;
*/
    margin-top: 0.6em;
    margin-left: -1em;
}
ul.check3 li::before {
    display: block;
    position: absolute;
    content: "\f14a";
    font-family: FontAwesome;
    font-size: 1.3em;
    margin-left: -1.2em;
}
ul.circle4 li, ul.check4 li {
    float: left;
    padding: 0 0 0.5em 1.8em;
    margin: 0 1.5% 0.5em;
    width: 22%;
}
ul.circle4 li:before {
    position: absolute;
    content: "";
    width: 6px;
    height: 6px;
    background-color: #222;
    border-radius: 50%;
    /* [disabled]left: 0.5em;
*/
    margin-top: 0.6em;
    margin-left: -1em;
}
ul.check4 li::before {
    display: block;
    position: absolute;
    content: "\f14a";
    font-family: FontAwesome;
    font-size: 1.3em;
    margin-left: -1.2em;
}
ul.circle5 li {
    margin-bottom: 0.2em;
    margin-top: 0.2em;
    float: left;
    padding-top: 0;
    padding-right: 0;
    padding-bottom: 0.5em;
    padding-left: 1.8em;
    margin-right: 35px;
}
ul.circle5 li:before {
    position: absolute;
    content: "";
    width: 6px;
    height: 6px;
    background-color: #222;
    border-radius: 50%;
    /* [disabled]left: 0.5em;
*/
    margin-top: 0.6em;
    margin-left: -1em;
}
ul.point2 li {
    background: #C93232;
    padding: 0.4em 0;
    margin: 0 1%;
    margin-bottom: 10px;
    font-size: 1rem;
    color: #FFF;
    text-align: center;
    border-radius: 20px; /* CSS3草案 */
    -webkit-border-radius: 20px; /* Safari,Google Chrome用 */
    -moz-border-radius: 20px; /* Firefox用 */
    float: left;
    width: 48%;
}
ul.li_pdf {
    position: relative;
}
ul.li_pdf li {
    padding: 0 0 0.5em 1.8em;
    margin-bottom: 0.5em;
}
ul.li_pdf li:before {
    display: block;
    position: absolute;
    content: "\f1c1";
    font-family: FontAwesome;
    font-size: 1.3em;
    margin-left: -1.2em;
}
ul.li_pdf2 {
    position: relative;
}
ul.li_pdf2 li {
    float: left;
    width: 45%;
    padding: 0 0 0.5em 1.8em;
    margin: 0 1% 0.5em;
}
ul.li_pdf2 li:before {
    display: block;
    position: absolute;
    content: "\f1c1";
    font-family: FontAwesome;
    font-size: 1.3em;
    margin-left: -1.2em;
}
ol.num-list {
    counter-reset: number; /*数字をリセット*/
    list-style-type: none !important; /*数字を一旦消す*/
    padding: 0.5em;
}
ol.num-list li {
    position: relative;
    padding-left: 30px;
    line-height: 1.5em;
    padding: 0.5em 0.5em 0.5em 30px;
}
ol.num-list li:before {
    /* 以下数字をつける */
    position: absolute;
    counter-increment: number;
    content: counter(number);
    /*以下数字のデザイン変える*/
    display: inline-block;
    background: #ee8800;
    color: white;
    font-family: 'Avenir', 'Arial Black', 'Arial', sans-serif;
    font-weight: bold;
    font-size: 15px;
    border-radius: 50%;
    left: 0;
    width: 25px;
    height: 25px;
    line-height: 25px;
    text-align: center;
    /*以下 上下中央寄せのため*/
    top: 50%;
    -moz-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -o-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
}
@media screen and (max-width: 768px) {
    .content ul.circle2 li, .content ul.check2 li {
        float: none;
        padding: 0 0 0.5em 1.8em;
        margin: 0 1% 0.7em;
        width: 90%;
    }
    ul.circle5 li {
        width: 90%;
    }
    ul.li_pdf2 li {
        float: none;
        width: 90%;
        margin: 0 auto;
        margin-bottom: 0.5em;
    }
}
/*===========================
table
===========================*/
table.table-various1 td.td_right {
    text-align: right;
}
.inquiry table {
    border: none;
}
/* 線のtable */
table.table-various3 th {
    text-align: center;
    vertical-align: middle;
}
/*tableをスクロールさせる*/
/* 	スクロール用テーブル  */
.scroll table th {
    text-align: center;
    vertical-align: middle;
}
/*tableのセル内にある文字の折り返しを禁止*/
.scroll {
    overflow: auto;
    white-space: nowrap;
}
/*tableにスクロールバーを追加*/
.scroll::-webkit-scrollbar {
    height: 5px;
}
/*tableにスクロールバーを追加*/
.scroll::-webkit-scrollbar-track {
    background: #F1F1F1;
}
/*tableにスクロールバーを追加*/
.scroll::-webkit-scrollbar-thumb {
    background: #BCBCBC;
}
@media only screen and (max-width: 768px) {
    /*table {
	border-top: 1px #ccc solid;
}
table th {
	width: 100%;
	display: block;
	border-top: none;
	border-bottom: none;
	box-sizing: border-box;
}
table td {
	width: 100%;
	display: block;
	box-sizing: border-box;
}
.scroll table {
	min-width:768px;
	overflow:scroll;
}
.scroll table th {
	width:auto;
	display:table-cell;
	vertical-align:middle;
	border-top: 1px #8c7656 solid;
	border-bottom: 1px #8c7656 solid;
}
.scroll table td {
	width:auto;
	display:table-cell;
}
*/
}
/*===========================
others
===========================*/
/* テキスト */
.mb25 {
    margin-bottom: 25px !important;
}
.mb45 {
    margin-bottom: 45px !important;
}
.mb55 {
    margin-bottom: 55px !important;
}
.txtsize1 {
    font-size: 1.2rem;
}
.txtsize2 {
    font-size: 1.4rem;
}
.tx-center-sp {
    text-align: left;
}
.tx-right {
    text-align: right;
}
.indent-1 {
    padding-left: 1em; /*1em（1文字）分、右に動かす*/
    text-indent: -1em; /*最初の行だけ1em（1文字）分、左に動かす*/
    line-height: 1.5em;
}
.catchcopy {
    font-size: 1.7rem;
    font-family: 'Noto Sans Japanese';
    font-weight: 300;
    line-height: 1.1em;
    color: #E66700;
}
.orange {
    color: #d58400;
}
.marker_y {
    background: linear-gradient(transparent 60%, rgba(255, 250, 137, 0.71) 0%);
}
@media screen and (max-width: 768px) {
    .tx-center-sp {
        text-align: center;
    }
}
/* ボックス */
.Boxwrap {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-box;
    display: -webkit-flexbox;
    display: -moz-flexbox;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}
.Boxwrap .box {
    width: 44%;
    border: 2px solid #ddd;
    background-color: #FFF;
    box-shadow: none;
    list-style: none;
    padding: 20px;
    margin-bottom: 40px;
    position: relative;
    margin-left: 2%;
    -moz-border-radius: 8px; /* Firefox */
    -webkit-border-radius: 8px; /* Google Chrome、Safari  */
    -o-border-radius: 8px; /* Opera  */
    -ms-border-radius: 8px; /* Internet Explorer  */
    border-radius: 8px;
}
.Boxwrap .no-border {
    border: none;
}
.Boxwrap .first {
    margin-left: 0 !important;
}
.box {
    background-color: #f6f6f6;
    border: 2px dashed #fff;
    border-radius: 8px;
    box-shadow: 0 0 0 8px #f6f6f6;
    padding: 2em;
}
.box h3 {
    font-size: 1.4em;
    margin-bottom: 1em;
}
.box h3::after {
    position: relative;
    background: none;
    bottom: 0;
}
.box2 {
    background-color: #f6f6f6;
    border: 2px solid #fff;
    box-shadow: 0 0 0 2px #f6f6f6;
    padding: 2em;
}
.box2 h3 {
    font-size: 1.4em;
    margin-bottom: 1em;
}
.box2 h3::after {
    position: relative;
    background: none;
    bottom: 0;
}
.box3 {
    border: 4px double #ccc;
    padding: 2em;
}
.box3 h3 {
    font-size: 1.4em;
    margin-bottom: 1em;
    border: none;
    padding: 0;
}
.box3 h3::after {
    position: relative;
    background: none;
    bottom: 0;
}
ul.box4 {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
}
ul.box4 li {
    border: 1px solid #b8e1a6;
    padding: 2em 1.5em;
    border-radius: 10px;
    width: 31%;
    margin: 1%;
}
ul.box5 {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
}
ul.box5 li {
    border: 1px solid #b8e1a6;
    padding: 2em 1.5em;
    border-radius: 10px;
    width: 40%;
    margin: 1%;
}
@media screen and (max-width: 768px) {
    ul.box4 li, ul.box5 li {
        width: 90%;
    }
}
/* ボタン */
.btn2 a {
    text-decoration: none;
    text-align: center;
    color: #FFF !important;
    position: relative;
    display: inline-block;
    padding: 0 1em;
    line-height: 30px;
    background: #e89a1a;
    -webkit-border-radius: 2px;
    -moz-border-radius: 2px;
    border-radius: 2px;
    transition: all .3s;
    -webkit-transition: all .3s;
    box-shadow: 1px 1px 5px #333;
}
.btn2 a:hover {
    background: #edae48;
}
/* PDF */
.pdf {
    background-color: #ffffff;
    display: block;
}
.pdf img:hover, .pdf a:hover {
    cursor: pointer;
    filter: alpha(opacity=60); /* ie lt 8 */
    -ms-filter: "alpha(opacity=60)"; /* ie 8 */
    -moz-opacity: 0.6; /* FF lt 1.5, Netscape */
    -khtml-opacity: 0.6; /* Safari 1.x */
    opacity: 0.6;
    zoom: 1;
    transition: all .5s;
    -webkit-transition: all .5s;
}
.service {
    background: #8fafc3;
    padding: 0.4em 1em;
    margin-bottom: 10px;
    font-size: 1.1rem;
    color: #FFF;
    text-align: center;
    border-radius: 20px; /* CSS3草案 */
    -webkit-border-radius: 20px; /* Safari,Google Chrome用 */
    -moz-border-radius: 20px; /* Firefox用 */
}
/* 画像とテキストを交互に表示 */
.contents-wrap {
    display: -webkit-box; /*Android4.3*/
    display: -moz-box; /*Firefox21*/
    display: -ms-flexbox; /*IE10*/
    display: -webkit-flex; /*PC-Safari,iOS8.4*/
    display: flex;
    -webkit-box-pack: justify; /*Android4.3*/
    -moz-box-pack: justify; /*Firefox21*/
    -ms-flex-pack: justify; /*IE10*/
    -webkit-justify-content: space-between; /*PC-Safari,iOS8.4*/
    justify-content: space-between;
}
.contents-wrap:nth-child(odd) {
    -ms-flex-direction: row-reverse; /*IE10*/
    -webkit-flex-direction: row-reverse; /*old webkit browser*/
    flex-direction: row-reverse;
}
.contents-text {
    width: 47.5%; /*flex: 2;*/
}
.contents-img {
    width: 47.5%; /*flex: 1;*/
}
.contents-text h3 {
    margin-bottom: 2rem;
    font-size: 2rem;
    line-height: 1.1em;
    border: none;
    padding: 0;
}
.contents-img img {
    display: block;
    width: auto;
    max-width: 100%;
}
@media screen and (max-width: 768px) {
    .contents-wrap, .contents-wrap:nth-child(odd) {
        -ms-flex-direction: row-reverse; /*IE10*/
        -webkit-flex-direction: row-reverse; /*old webkit browser*/
        flex-direction: column-reverse;
    }
    .contents-text, .contents-img {
        width: 100%; /*flex: 1;*/
        margin-bottom: 3em;
    }
    .contents-text h3 {
        text-align: center;
    }
}
/*----------------------------
variable grid
-----------------------------*/
.one_half2, .one_third2, .one_quarter2 {
    display: inline;
    float: left;
    margin: 0 0 0 5%;
    list-style: none;
}
.one_half2:first-child, .one_third2:first-child, .one_quarter2:first-child {
    margin-left: 0;
}
.one_half2 {
    width: 47.5%;
}
.one_third2 {
    width: 30%;
}
.one_quarter2 {
    width: 21.25%;
}
.wrapper-type1 {
    width: 80%;
    max-width: 1200px;
    margin: auto;
    border: 4px solid #f4c3cc;
    padding: 30px;
    border-radius: 20px;
    box-sizing: border-box;
}
.box-type1 {
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.box-type1 li {
    width: 46%;
    float: left;
    margin: 0 2% 3em 2%;
    box-sizing: border-box;
}
table.table2 td.t1 {
    background-color: #fcfce8;
}
.box-type2 {
    background-color: #fff;
    padding: 20px;
    box-shadow: 1px 1px 5px #b2b2b2;
}
@media only screen and (max-width: 600px) {
    .box-type1 {
        flex-direction: column;
    }
    .box-type1 li {
        width: 100%;
    }
}
.title-type1 {
    color: #fff;
    background-color: #9a6144;
    padding: 5px 10px;
    border-radius: 5px;
}
@media only screen and (max-width: 600px) {
    .wrapper-type1 {
        width: 100%;
        border: none;
        padding: 0px;
        box-sizing: border-box;
    }
}
.btn, a.btn, button.btn {
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 1.5;
    position: relative;
    display: inline-block;
    padding: 1rem 4rem;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
    text-align: center;
    vertical-align: middle;
    text-decoration: none;
    letter-spacing: 0.1em;
    color: #212529;
    border-radius: 0.5rem;
}
.btn-wrap {
    margin: 30px 0;
}
a.btn-c {
    font-size: 1.1rem;
    position: relative;
    padding: 0.25rem 1.5rem 1.5rem 1.5rem;
    color: #fff;
    background: #EBA1AB;
    -webkit-box-shadow: 0 5px 0 #EBA1AB;
    box-shadow: 0 5px 0 #EBA1AB;
}
a.btn-c span {
    font-size: 1rem;
    position: absolute;
    top: -1.25rem;
    left: calc(50% - 150px);
    display: block;
    width: 300px;
    padding: 0.2rem 0;
    color: #EBA1AB;
    border: 2px solid #EBA1AB;
    border-radius: 100vh;
    background: #fff;
    -webkit-box-shadow: 0 3px 3px rgba(0, 0, 0, 0.2);
    box-shadow: 0 3px 3px rgba(0, 0, 0, 0.2);
}
a.btn-c span:before, a.btn-c span:after {
    position: absolute;
    left: calc(50% - 10px);
    content: "";
}
a.btn-c span:before {
    bottom: -10px;
    border-width: 10px 10px 0 10px;
    border-style: solid;
    border-color: #EBA1AB transparent transparent transparent;
}
a.btn-c span:after {
    bottom: -7px;
    border-width: 10px 10px 0 10px;
    border-style: solid;
    border-color: #fff transparent transparent transparent;
}
a.btn-c i {
    margin-right: 1rem;
}
a.btn-c:hover {
    -webkit-transform: translate(0, 3px);
    transform: translate(0, 3px);
    color: #fff;
    background-color: #E57988;
    -webkit-box-shadow: 0 2px 0 #E57988;
    box-shadow: 0 2px 0 #E57988;
}
.flow04 {
    padding-left: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 60px;
}
.flow04 > li {
    list-style-type: none;
    width: 100%;
    max-width: 350px;
    display: flex;
}
.flow04 > li {
    list-style-type: none;
    width: calc(23% - 30px); /* 4カラムにする */
    display: flex;
    flex-direction: column;
}
.flow04 > li .icon04 {
    line-height: 2;
    width: 2em;
    height: 2em;
    text-align: center;
    color: #fff;
    background: #E26B5D;
    margin: 0 auto 10px;
    display: block;
    border-radius: 100vh;
    position: relative;
}
.flow04 > li .icon04::before {
    content: "";
    border: solid transparent;
    border-width: 7px;
    border-top-color: #E26B5D;
    position: absolute;
    top: calc(100% - 2px);
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
}
.flow04 > li dl {
    padding: 30px 20px;
    margin: 0;
    border: 3px solid #E26B5D;
    position: relative;
}
.flow04 > li:not(:first-child) dl::before {
    content: "";
    width: 14px;
    height: 14px;
    margin-right: 10px;
    display: inline-block;
    border-top: 4px solid #E26B5D;
    border-right: 4px solid #E26B5D;
    position: absolute;
    top: calc(50% - 14px);
    left: -45px;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}
.flow04 > li dl dt {
    font-size: 1.2em;
    font-weight: 600;
    color: #E26B5D;
    -ms-flex-preferred-size: 20%;
    flex-basis: 20%;
    margin-bottom: 10px;
    text-align: center;
}
.flow04 > li dl dd {
    margin-left: 0;
}
@media(max-width: 767px) {
    .flow04 {
        gap: 20px;
    }
    .flow04 > li {
        max-width: unset;
        display: block;
    }
    .flow04 > li:not(:first-child) dl::before {
        display: none;
    }
}
@media(max-width: 1024px) {
    .flow04 > li {
        width: calc(47% - 20px); /* タブレットでは2カラム */
    }
}
@media(max-width: 767px) {
    .flow04 > li {
        width: 100%; /* スマホでは1カラム */
    }
}
.contact table td.radio input {
    height: 1em;
}


/* 右フローティングバナー  */
ul.fixRightBnr {
    position: fixed;
    z-index: 777;
    top: 30vmin;
    right: 0;
}
ul.fixRightBnr li {
    display: block;
}
ul.fixRightBnr li a {
    display: block;
    background-color: #7E7E7E;
    opacity: .9;
    font-size: 4.6vmin;
    box-sizing: border-box;
    width: 100%;
    padding: 1.8vmin 1.2vmin;
    /*
	padding:1.8vmin 1.8vmin;
	*/
    margin-bottom: 0.6vmin;
    color: #fff;
    text-decoration: none;
    text-align: center;
}
ul.fixRightBnr li span {
    display: block;
    box-sizing: border-box;
    margin-top: 10px;
    font-size: 1.6vmin;
    line-height: 1em;
}
ul.fixRightBnr li a:hover {
    opacity: .7;
}
ul.fixRightBnr li.insta a {
    /* background-color:#CF2E92; */
    background: linear-gradient(135deg, #427eff 0%, #f13f79 70%) no-repeat;
}
ul.fixRightBnr li.twitter a {
    background-color: #0f1419;
}
ul.fixRightBnr li.facebook a {
    background-color: #1877f2;
}
ul.fixRightBnr li.youtube a {
    background-color: #da1725;
}
ul.fixRightBnr li.line a {
    background-color: #00B900;
}
ul.fixRightBnr li.tictok a {
    background-color: #000;
}
ul.fixRightBnr li.ameba a {
    background-color: #298737;
}
@media screen and (max-width: 768px) {
    ul.fixRightBnr {
        top: 14vmin;
    }
}
@media only screen and (max-width: 600px) {
    ul.fixRightBnr {
        top: 45vmin;
    }
}