@charset "UTF-8";

/* CSS Document */

body {
    overflow: hidden;
    font-feature-settings: "palt";
}

.flex {
    display: flex;
    justify-content: center;
}
.red {
    color: #de2520!important;
}
.wrap {
    width: 1080px;
    margin: 0 auto;
}

.pc_only {
    display: block!important;
}

.sp_only {
    display: none!important;
}
.line-yel {
    background: linear-gradient(transparent 60%, #fcf300 0%);
}
#anc02,
#anc03,
#anc04,
#anc05,
#anc06,
#anc07,
#anc08,
#contact {
    margin-top: -50px;
    padding-top: 50px;
}

header {
    background: #FFF;
    margin-bottom: 60px;
	
}

header .inner {
    width: 1365px;
    margin: 0 auto;
}

header h1 {
    width: 196.50px;
    padding-bottom: 23px;
    padding-left: 30px;
	margin-top: 30px;
}
header .mv-block{

}
header .mv-txt {
    background: #0096ff;
    color: #FFF;
    border-radius: 30px;
    font-size: 33px;
    font-weight: bold;
    padding: 5px 0;
    margin: 10px auto 20px;
}

header .head {
    background: url("../img/hd-bg.jpg") repeat-x;
    padding: 10px 0 40px;
    background-size: auto 100%;
    margin-bottom: 30px;
}

header .mv-txt2 h2 {
    font-size: 37px;
    text-shadow: 2px 2px 1px #ffffff, -2px 2px 1px #ffffff, 2px -2px 1px #ffffff, -2px -2px 1px #ffffff, 2px 0px 1px #ffffff, 0px 2px 1px #ffffff, -2px 0px 1px #ffffff, 0px -2px 1px #ffffff;
    /* 文字の影 */
    margin-bottom: 25px;
    line-height: 1.3;
}

header .mv-txt2 p {
    line-height: 1.8;
}

header .mv-txt2 p b {
    font-size: 23px;
}
header .mv-txt3{
	margin-bottom: 20px;
}
header .mv-txt3 p{
	
}
header .mv-txt3 .red{

}
header .logoArea {
    background: rgba(255, 255, 255, 0.8);
    border-radius: 10px;
    padding: 30px 10px;
    align-content: center;
    align-items: center;
    border: solid 1px #00a5ff;
}

header .logoArea .logo {
    width: 130px;
    margin-right: 40px;
}

header .logoArea img {
    width: 100%;
}

.btn {
    position: relative;
    background: #ffa414;
    border: solid 1px #e4c7ab;
    border-radius: 10px;
    font-size: 20px;
    font-weight: bold;
}

.btn::before {
    content: '';
    display: inline-block;
    position: absolute;
    top: 50%;
    left: 95%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    width: 0;
    height: 0;
    border-top: 10px solid transparent;
    border-right: 6px solid transparent;
    border-bottom: 10px solid transparent;
    border-left: 10px solid #FFF;
}

.btn a {
    display: block;
    color: #FFF;
    padding: 10px 25px 10px 10px;
}

header nav {
    background: url("../img/nav-bg.jpg") repeat;
    padding: 16px 0;
    background-size: auto;
    margin-top: 2px;
}

header nav ul {
    justify-content: flex-start !important;
    flex-flow: wrap;
}

header nav li {
    position: relative;
    display: -webkit-flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-justify-content: center;
    background: #fff;
    border-radius: 10px;
    margin-right: 1%;
    text-align: center;
    width: 19.2%;
}

header nav li:last-child {
    background: #de2520;
}

header nav li::after {
    content: '';
    width: 10px;
    height: 10px;
    border: 0px;
    border-top: solid 3px #ffa414;
    border-right: solid 3px #ffa414;
    -ms-transform: rotate(135deg);
    -webkit-transform: rotate(135deg);
    transform: rotate(135deg);
    position: absolute;
    margin: auto;
    bottom: 10px;
    left: 0;
    right: 0;
}

header nav li:last-child::after {
    border-top: solid 3px #FFF;
    border-right: solid 3px #FFF;
}

header nav li a {
    display: inline-block;
    text-align: center;
    display: -webkit-box;
    display: -ms-flexbox;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    padding: 15px 0 20px;
    color: #000;
}

header nav li:last-child a {
    color: #FFF;
}

header nav li:nth-child(5) {
    margin-right: 0;
}

header nav li:nth-child(-n+5) {
    margin-bottom: 1%;
}

section .ttl-h2 {
    background: url("../img/h2ttl-bg.jpg") repeat;
    padding: 16px 0;
    background-size: auto;
    border-radius: 10px;
    color: #000;
    font-size: 33px;
    text-align: center;
    font-weight: 600;
    margin-bottom: 37px;
    text-shadow:1px 1px 0 #FFF, -1px -1px 0 #FFF,
                -1px 1px 0 #FFF, 1px -1px 0 #FFF,
                0 1px 0 #FFF,  0-1px 0 #FFF,
                -1px 0 0 #FFF, 1px 0 0 #FFF;
}

section .ttl-h2 small {
    font-size: 28px;
}

main h3 {
    position: relative;
    background: url("../img/ttl-bg.jpg") repeat-x;
    background-size: auto;
    height: 98px;
    border-bottom: solid 15px #0096ff;
    margin-bottom: 65px;
    align-items: center;
}

main h3 img {
    position: absolute;
    top: -20px;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
}

main h3.ttl3 {
    height: 50px;
}

main h3.ttl3-1 {
    height: 50px;
    margin-bottom: 50px;
}

main h3.ttl3-1 img {
    top: 0;
}

main .h3-sub-ttl {
    font-size: 30px;
    text-align: center;
    font-weight: 700;
    margin-bottom: 45px;
}

main .h3-sub-ttl::before,
main .h3-sub-ttl::after {
    content: url(../img/before.jpg);
    display: inline-block;
    vertical-align: middle;
    padding: 0 20px;
}

main .item-block {
    background: url(../img/sec-bg.jpg) no-repeat;
    background-repeat: no-repeat;
    background-position: bottom center;
    background-size: contain;
    padding-bottom: 66px;
    margin-bottom: 40px;
}

main .item-block .box {
    background: url("../img/box-bg.jpg") repeat;
    border: solid 6px #ff8484;
    padding: 30px 103px;
    border-radius: 30px;
    margin-bottom: 20px;
}

main .item-block .box h4 {
    background-size: auto;
    text-align: center;
    font-size: 36px;
    font-weight: bold;
}

main .item-block .box h4::after {
    content: '';
    height: 55px;
    background: url(../img/ttl2-bg.png) repeat-x;
    width: 100%;
    display: block;
    border-top: solid 3px #ff8484;
    background-size: auto;
}

main .item-block .box h4 img {
    width: 27%;
    margin-bottom: 5px;
    display: inline-block;
    padding-right: 10px;
}

main .item-block .box .flex {
    align-content: center;
    align-items: center;
    justify-content: space-between;
}

main .item-block .box .flex {
    align-content: center;
    align-items: center;
    justify-content: space-between;
}

main .item-block .box .txt {
    font-size: 20px;
    font-feature-settings: "palt";
}

main .item-block .box .price1 {
    font-size: 27px;
    margin-bottom: 10px;
}

main .item-block .price1 .pr {
    display: inline;
    font-size: 43px;
    color: #d82622;
    text-shadow: 2px 2px 1px #ffffff, -2px 2px 1px #ffffff, 2px -2px 1px #ffffff, -2px -2px 1px #ffffff, 2px 0px 1px #ffffff, 0px 2px 1px #ffffff, -2px 0px 1px #ffffff, 0px -2px 1px #ffffff;
}

main .item-block .box .price1 small {
    font-size: 27px;
    color: #000;
    text-shadow: none;
}

main .item-block .box .price1 .tax {
    font-size: 20px;
    color: #000;
    text-shadow: none
}

main .item-block .box .price2 {
    font-size: 26px;
    margin-bottom: 10px;
}

main .item-block .icon {
    margin-top: 25px;
    justify-content: flex-start !important;
}

main .icon li {
    text-align: center;
    display: -webkit-box;
    display: -ms-flexbox;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    border-radius: 10px;
    background: #000;
    color: #FFF;
    text-align: center;
    width: 50px;
    height: 50px;
    padding: 5px;
    line-height: 1.1;
    font-size: 18px;
    margin-right: 10px;
}

main .icon .gou {
    position: relative;
    background: #6bcefc;
}

main .icon .gou.th-p::after {
    content: '(3名〜)';
    display: block;
    position: absolute;
    color: #000;
    bottom: -20px;
    font-size: 14px;
    margin: auto;
    left: 0;
    right: 0;
}

main .icon .gou.on-p::after {
    content: '(1～2名)';
    display: block;
    position: absolute;
    color: #000;
    bottom: -20px;
    font-size: 14px;
    margin: auto;
    left: 0;
    right: 0;
}

main .icon .oi {
    background: #fc976b;
}

main .icon .uv {
    background: #6ba1fc;
}

main .icon .kino {
    background: #17c4a1;
}

main .icon .onsui {
    background: #ff5600;
}

main .item-block .sub {}

main .item-block .sub-box {
    background: #FFF;
    border: solid 2px #83e4fc;
    padding: 20px 15px 40px;
    border-radius: 30px;
    margin-right: 10px;
    width: 33.33%;
}

main .item-block .sub-box:last-child {
    margin-right: 0;
}

main .item-block .sub-box h5 {
    text-align: center;
    font-size: 28px;
    font-weight: bold;
    line-height: 1.3;
    margin-bottom: 10px;
}

main .item-block .sub-box h5 span {
    height: 70px;
    display: grid;
    place-items: center;
}

main .item-block .sub-box h5 img {
    display: block;
    max-height: 30px;
    margin: 0 auto 10px;
}

main .item-block .sub-box .catch {
    font-size: 20px;
    font-weight: 500;
    letter-spacing: 1px;
    margin: 0 auto 30px;
    max-width: 100%;
    display: flex;
    align-items: center;
    align-content: center;
    justify-content: center;
	text-align: center;
}

main .item-block .sub-box .txt {
    font-size: 18px;
    font-feature-settings: "palt"
}

main .item-block .sub-box .ph {
    margin: 0 auto 30px;
    display: block;
}

main .item-block .sub-box .price1 .pr {
    display: inline;
    font-size: 28px;
    color: #d82622;
}

main .item-block .sub-box .price1 small,
main .item-block .sub-box .price1 .tax {
    color: #000;
}

main .item-block .sub-box .price1 small {
    font-size: 18px;
}

main .item-block .sub-box .price1 .tax {
    font-size: 14px;
}

main .item-block .sub-box .price2 {
    margin-bottom: 10px;
}

main .item-block .sub-box .price2 small {
    font-size: 14px;
}

main .item-block .sub-box .in {
    display: block;
    text-indent: 2.5em;
}

main .item-block .sub-box .pay {
    margin-top: 15px;
}

main .item-block .icon-ex {
    margin-bottom: 50px;
}

main .item-block .icon-ex dd {
    display: flex;
    align-items: center;
    margin-right: 30px;
}

main .item-block .icon-ex dd span:first-child {
    text-align: center;
    display: -webkit-box;
    display: -ms-flexbox;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    border-radius: 10px;
    border: solid 2px #FFF;
    color: #FFF;
    text-align: center;
    width: 38px;
    height: 38px;
    line-height: 1.1;
    font-size: 12px;
    margin-right: 10px;
}

main .item-block .icon-ex dd span:last-child {}
main .bene {
    margin: 40px 0 80px;
}
main .bene .flex{
	position: relative;
    background: #d82622;
}
main .bene .flex p{
    color: #fff;
	font-size: 40px;
    font-weight: 600;
    padding-top: 10px;
    padding-bottom: 10px;
    padding-left: 100px;
    display: block;
    margin-bottom: 0;
}
main .bene .flex .icon{
    
}
main .bene .note{
	font-size: 18px;
    padding: 40px 30px;
	border: solid 4px #d82622;
	line-height: 1.8;
	border-radius: 0 0 20px 20px;
	border-top: none;
}
main .bg--line {
    position: relative;
    display: flex;
    justify-content: space-around;
    z-index: 9;
}

main .bg--line div {
    position: relative;
    z-index: 9;
}

main .bg--line::before {
    content: '';
    width: 200%;
    position: absolute;
    height: 170px;
    background: rgba(255, 255, 255, 0.8);
    display: block;
    z-index: 1;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
}

main .item-block2 {
    margin-bottom: 100px;
}

main .item-block2 .arrow-bg {
    position: relative;
    z-index: 2;
    background: url("../img/arrow-gry.png") no-repeat;
    background-position: bottom center;
    padding: 20px 0 30px;
}

main .item-block2 .arrow-bg div:first-child {
    margin-top: -25px;
}

main .item-block2 .arrow-bg div:last-child {
    margin-top: -65px;
    padding-left: 60px;
}

main .contact {
    position: relative;
    z-index: 1;
    background: url("../img/contact-box-bg.jpg") repeat;
    padding: 30px 0;
    margin-top: -15px;
    border-radius: 30px;
    margin-bottom: 20px;
    text-align: center;
}

main .contact .ttl {
    font-size: 38px;
    font-weight: 600;
    margin-bottom: 20px;
    text-shadow: 2px 2px 1px #ffffff, -2px 2px 1px #ffffff, 2px -2px 1px #ffffff, -2px -2px 1px #ffffff, 2px 0px 1px #ffffff, 0px 2px 1px #ffffff, -2px 0px 1px #ffffff, 0px -2px 1px #ffffff;
}

main .contact .cta-btn {
    margin-bottom: 20px;
}
.item-block_contact .contact {
    position: relative;
    z-index: 1;
    background: url("../img/contact-box-bg.jpg") repeat;
    padding: 30px 0;
    margin-top: -15px;
    border-radius: 30px;
    margin-bottom: 20px;
    text-align: center;
}

.item-block_contact .contact .ttl {
    font-size: 38px;
    font-weight: 600;
    margin-bottom: 20px;
    text-shadow: 2px 2px 1px #ffffff, -2px 2px 1px #ffffff, 2px -2px 1px #ffffff, -2px -2px 1px #ffffff, 2px 0px 1px #ffffff, 0px 2px 1px #ffffff, -2px 0px 1px #ffffff, 0px -2px 1px #ffffff;
}

.item-block_contact .contact .cta-btn {
    margin-bottom: 20px;
}

main .item-block3 {
    margin-bottom: 90px;
}

main .item-block3 .fuki {
    justify-content: space-between;
    align-content: center;
    align-items: center;
    margin-bottom: 55px;
    font-family: "ヒラギノ角ゴシック";
    font-size: 26px;
}

main .item-block3 .fukidashi p {
    position: relative;
    background: #E5F3EF;
    padding: 20px;
    text-align: left;
    border-radius: 30px;
    -webkit-border-radius: 30px;
    -moz-border-radius: 30px;
    width: 65%;
    display: -webkit-box;
    display: -ms-flexbox;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: start;
    -ms-flex-pack: center;
    justify-content: center;
    min-height: 140px;
}

main .item-block3 .fukidashi p:after {
    border: solid transparent;
    content: '';
    height: 0;
    width: 0;
    pointer-events: none;
    position: absolute;
    border-color: rgba(229, 243, 239, 0);
    border-top-width: 15px;
    border-bottom-width: 15px;
    border-left-width: 20px;
    border-right-width: 20px;
    margin-top: -15px;
    border-right-color: #E5F3EF;
    right: 100%;
    top: 50%;
}

main .item-block3 .wrap,
main .item-block5 .box-bl {
    width: 960px;
}

main .item-block3 .fukidashi2 p {
    position: relative;
    background: #FFFFFF;
    padding: 20px;
    text-align: left;
    border: 5px solid #20B9DF;
    border-radius: 30px;
    -webkit-border-radius: 30px;
    -moz-border-radius: 30px;
    width: 65%;
    display: -webkit-box;
    display: -ms-flexbox;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: start;
    -ms-flex-pack: center;
    justify-content: center;
    min-height: 140px;
}

main .item-block3 .fukidashi2 p:after,
main .item-block3 .fukidashi2 p:before {
    border: solid transparent;
    content: '';
    height: 0;
    width: 0;
    pointer-events: none;
    position: absolute;
    left: 100%;
    top: 50%;
}

main .item-block3 .fukidashi2 p:after {
    border-color: rgba(255, 255, 255, 0);
    border-top-width: 15px;
    border-bottom-width: 15px;
    border-left-width: 20px;
    border-right-width: 20px;
    margin-top: -15px;
    border-left-color: #FFFFFF;
}

main .item-block3 .fukidashi2 p:before {
    border-color: rgba(32, 185, 223, 0);
    border-top-width: 17px;
    border-bottom-width: 17px;
    border-left-width: 22px;
    border-right-width: 22px;
    margin-top: -17px;
    margin-left: 5px;
    border-left-color: #20B9DF;
}

main .item-block4 .flex {
    justify-content: space-between;
    margin-bottom: 80px;
    align-items: center;
}

main .item-block4 dl {
    width: 50%;
    margin-right: 40px;
}

main .item-block4 dl:last-child {
    margin-right: 0;
}

main .item-block4 dt {
    border-radius: 20px 20px 0 0;
    background: #b7dee0;
    font-size: 32px;
    font-weight: bold;
    text-align: center;
    padding: 15px 0;
    margin-bottom: 10px;
}

main .item-block4 dd {
    position: relative;
    margin-bottom: 10px;
    padding: 10px 0;
    display: flex;
    align-items: center;
    align-content: center;
    padding-left: 20px;
    min-height: 80px;
    line-height: 1.3;
}

main .item-block4 dd span {
    position: relative;
    margin-right: 20px;
}

main .item-block4 dl:first-child dd {
    background: #e9f5f6;
    color: #666;
    font-size: 22px;
}

main .item-block4 dl:first-child dd span {
    display: block;
    position: relative;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    background: #fff;
    /* ボタンの背景色 */
}

main .item-block4 dl:first-child dd span::before,
main .item-block4 dl:first-child dd span::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 4px;
    /* 棒の幅（太さ） */
    height: 20px;
    /* 棒の高さ */
    background: #000;
    /* バツ印の色 */
}

main .item-block4 dl:first-child dd span::before {
    transform: translate(-50%, -50%) rotate(45deg);
}

main .item-block4 dl:first-child dd span::after {
    transform: translate(-50%, -50%) rotate(-45deg);
}

main .item-block4 dd:last-child {
    border-radius: 0 0 20px 20px;
}

main .item-block4 dl:last-child dt {
    position: relative;
    background: #0096ff;
    color: #fff;
}

main .item-block4 dl:last-child dt::before {
    content: url(../img/Iwatani-logo.svg);
    display: block;
    width: 120px;
    border: solid #0096ff 4px;
    position: absolute;
    margin: auto;
    left: 0;
    right: 0;
    top: -45%;
    border-radius: 10px;
    background: #FFF;
    padding: 0 10px;
}

main .item-block4 dl:last-child dd {
    background: #66c0ff;
    color: #FFF;
    font-weight: bold;
    font-size: 28px;
}

main .item-block4 dl:last-child small {
    font-weight: normal;
    font-size: 22px;
    display: contents;
}

main .item-block4 dl:last-child dd span {
    background: #fff;
    padding: 10px;
    border-radius: 50%;
}

main .item-block4 dl:last-child dd span::before {
    content: "";
    position: absolute;
    width: 6px;
    height: 15px;
    top: -10%;
    left: 8px;
    -webkit-transform: rotate( 50deg);
    -ms-transform: rotate(50deg);
    transform: rotate( 50deg);
    border-right: 3px solid #e70008;
    border-bottom: 3px solid #e70008;
}

main .item-block4 .txt {
    position: relative;
    font-family: "ヒラギノ角ゴシック";
    color: #296fd9;
    font-size: 34px;
    line-height: 2;
}

main .item-block4 .txt span {
    color: #003483;
    font-weight: 800;
    border-bottom: 2px solid #003483;
    padding-bottom: 2px;
}

main .item-block4 .txt .btn {
    background: #0096ff;
    border: none;
    border-radius: 50px;
    font-weight: 400;
    margin-top: 20px;
    text-align: center;
    font-size: 24px;
}

main .item-block4 .txt .btn a {
    padding: 0 25px 0 10px;
}

main .item-block4 .txt .btn::before {
    left: 78%;
}

main .item-block5 .box-bl {
    border: solid 5px #6bcefc;
    border-radius: 20px;
    background: #fff;
    text-align: center;
    padding-bottom: 35px;
    margin: 0 auto 60px;
}

main .item-block5 .box-bl .box-ttl {
    background: #6bcefc;
    color: #FFF;
    font-size: 32px;
    font-weight: bold;
    border-radius: 0 0 20px 20px;
    width: 520px;
    margin: 0 auto 30px;
    padding-bottom: 10px;
}

main .item-block5 .box-bl p {
    font-size: 24px;
    font-family: "ヒラギノ角ゴシック";
    font-weight: 600;
    margin-bottom: 45px;
}

main .item-block5 .box-bl.grn {
    border: none;
    background: #d4f2ef;
    text-align: left;
    padding: 20px 20px 35px;
    margin-bottom: 100px;
}

main .item-block5 .box-bl.grn .bold {
    font-size: 24px;
}

main .item-block5 .box-bl.grn small {
    font-size: 16px;
}

main .item-block6 {
    margin-bottom: 80px;
}

main .item-block6 .flex {
    flex-wrap: wrap;
    position: relative;
    width: 960px;
    margin: 0 auto 70px;
}

main .item-block6 ul::after {
    content: url(../img/Iwatani-logo.svg);
    display: block;
    width: 28%;
    position: absolute;
    top: 46%;
}

main .item-block6 li {
    margin-right: 18px;
}

main .item-block6 li:nth-of-type(-n+3) {
    margin-bottom: 30px;
}

main .item-block6 li:nth-last-child(-n+3) {
    margin-top: 70px;
}

main .item-block6 li:nth-of-type(3n) {
    margin-right: 0;
}

main .item-block7 .box-bl2 {
    position: relative;
    border: solid 4px #4ab4ff;
    background: #FFF;
    border-radius: 30px;
    padding: 55px 60px 100px;
    margin-bottom: 20%;
}

main .item-block7 .box-bl2 .ttl {
    font-size: 34px;
    text-align: center;
    font-weight: bold;
    margin-bottom: 55px;
    display: flex;
    align-items: center;
}

main .item-block7 .box-bl2 .ttl::before,
main .item-block7 .box-bl2 .ttl::after {
    content: "";
    flex-grow: 1;
    height: 5px;
    /* 線の太さ */
    background: url("../img/line-ttl.jpg") repeat-x;
    /* 線の色 */
    margin: 0 1em;
    /* 文字と線の余白 */
}

main .item-block7 .box-bl2 img {
    width: 100%;
    display: block;
    text-align: center;
}

main .item-block7 .box-bl2 p {
    font-size: 24px;
    line-height: 2;
    letter-spacing: 1px;
    margin-bottom: 35px;
}

main .item-block7 .box-bl2 .fuki--bl {
    position: absolute;
    bottom: -13%;
    margin: auto;
    left: 0;
    right: 0;
    width: 88%;
}

main .item-block7 .box-bl2 .fuki--bl small {
    font-size: 18px;
}

main .item-block8 ul {
    margin-bottom: 100px;
}

main .item-block8 li {
    position: relative;
    background: #f3fbff;
    border: solid 1px #296fd9;
    border-radius: 10px;
    width: 20%;
    margin-right: 20px;
    padding: 20px 10px;
}

main .item-block8 li:last-child {
    margin-right: 0;
    background: #4eb4fc;
    color: #FFF;
}

main .item-block8 li::before {
    position: absolute;
    bottom: 10px;
    right: 0;
    display: block;
}

main .item-block8 li:nth-child(1)::before {
    content: url(../img/cont-ic01.png);
}

main .item-block8 li:nth-child(2)::before {
    content: url(../img/cont-ic02.png);
}

main .item-block8 li:nth-child(3)::before {
    content: url(../img/cont-ic03.png);
}

main .item-block8 li:nth-child(4)::before {
    content: url(../img/cont-ic04.png);
}

main .item-block8 li:nth-child(5)::before {
    content: url(../img/cont-ic05.png);
}

main .item-block8 li:nth-of-type(-n+4)::after {
    content: '';
    display: inline-block;
    position: absolute;
    top: 50%;
    left: 100%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    width: 0;
    height: 0;
    border-top: 20px solid transparent;
    border-right: 6px solid transparent;
    border-bottom: 20px solid transparent;
    border-left: 20px solid #296fd9;
}

main .item-block8 li span {
    font-size: 24px;
    font-family: "ヒラギノ角ゴシック";
    font-weight: 700;
    color: #296fd9;
    display: block;
    margin-bottom: 10px;
}

main .item-block8 li:last-child span {
    color: #FFF;
}

main .ft-contact{
	position: relative;
    z-index: 1;
    background: url(../img/ftcontact-box-bg.jpg) repeat;
    padding:120px 0 40vh;
	text-align: center;
	clip-path: ellipse(90% 70% at right 50% bottom 30%);
    width: 100%;
    height: 90vh;
	margin-top: 100px;
}
main .ft-contact .ft-item{
	position: absolute;
    width: 1080px;
    bottom: 0;
    margin: auto;
    left: 0;
    right: 0;
    padding-bottom: 40px;
}
main .ft-contact .ft-ttl {
    font-size: 54px;
    font-weight: bold;
    margin-bottom: 40px;
}

main .ft-contact p {
    font-size: 32px;
}

main .ft-contact .grn-txt {
    margin-top: 40px;
    font-size: 28px;
    color: #418683;
    margin-bottom: 65px;
}

main .ft-contact .grn-txt a {
    color: #418683;
    border-bottom: 2px solid #418683;
    padding-bottom: 2px;
}

main .ft-contact .info {
    border: solid 4px #4ab4ff;
    border-radius: 30px;
    background: #fff;
   
}

main .ft-contact .ttl-info {
    overflow: hidden;
    background: #4ab4ff;
    color: #fff;
    text-align: center;
    font-size: 3rem;
    font-weight: bold;
    padding: 40px 0;
    letter-spacing: 1px;
    margin: 0 0 50px;
    border-radius: 20px 20px 0 0;
}

main .ft-contact .ft-tel {
    margin: 50px auto;
}

footer {
    background: #296fd9;
    color: #fff;
    text-align: center;
    display: flex;
    align-content: center;
    align-items: center;
    font-size: .8rem;
    padding: 10px 0;
    font-weight: bold;
}

@media screen and (max-width: 1095px) {
    header .inner {
        width: 100%;
        margin: 0 auto;
    }
    img {
        max-width: 100%;
        height: auto;
        margin-left: auto;
        margin-right: auto;
        vertical-align: top;
        width: auto;
    }
    .wrap {
        width: 98%;
    }
    main .item-block3 .wrap,
    main .item-block5 .box-bl {
        width: auto;
    }
    main .item-block5 .box-bl .box-ttl {
        width: auto;
    }
    main .item-block .box {
        padding: 30px 50px;
    }
    main .item-block .sub-box {
        padding: 20px 5px 40px;
    }
	main .ft-contact .ft-item{
    width: 95%;
}
	main .h3-sub-ttl::before,
	main .h3-sub-ttl::after{
		display: none;
	}

}

@media screen and (max-width: 980px) {
    main .item-block4 dt {
        font-size: 1.8rem;
    }
    main .item-block4 dl:last-child dd {
        font-size: 1.3rem;
    }
    main .item-block4 dl:last-child small {
        font-size: 18px;
    }
    main .item-block4 dl {
        margin-right: 20px;
    }
}

@media screen and (max-width: 860px) {
    header .mv-txt {
        font-size: 26px;
    }
    header .mv-txt2 h2 {
        font-size: 38px;
        line-height: 2;
    }
    header .logoArea {
        padding: 15px 10px;
    }
    header .logoArea {

    }
}

@media screen and (max-width: 768px) {
    .pc_only {
        display: none!important;
    }
    .sp_only {
        display: block!important;
    }
    #anc01,
    #anc02,
    #anc03,
    #anc04,
    #anc05,
    #anc06,
    #anc07,
    #anc08,
    #contact {
        margin-top: -80px;
        padding-top: 80px;
    }
    header h1 {
        padding-bottom: 0;
    }
    header {
        margin-bottom: 30px!important;
    }
	header .head {
    margin-top: 60px;
}
	
    header .mv-txt2 h2 {
        line-height: 1.8;
        margin-bottom: 5px;
    }
    header .mv-txt2 h2 img {
        width: 28%;
    }
	header .mv-txt3 .red {

}
	header .mv-txt3 p{

}
    header .flex {
        flex-wrap: wrap;
    }
    header .logoArea {
        align-items: flex-end;
        justify-content: space-evenly;
    }
    header .logoArea .logo {
        margin: 0 10px 10px;
        display: flex;
        align-items: center;
        width: 20%;
    }
    .btn {
        margin-top: 5px;
        width: 95%;
        font-size: 1.3rem;
    }
    main h3 {
        background: none;
        border-bottom: none;
        margin-bottom: 35px;
        height: auto;
    }
    main h3.ttl3 {
        height: auto;
    }
    main h3 img {
        position: static;
        top: 0;
        left: 0;
        transform: none;
        -webkit-transform: none;
        -ms-transform: none;
    }
    section .ttl-h2 {
        font-size: 1.3rem;
        margin-bottom: 0;
    }
    section .ttl-h2 small {
        font-size: 1.1rem;
    }
    main .item-block .box h4 {
        line-height: 2.5;
    }
    main .item-block .box h4,
    main .item-block .sub-box h5 {
        font-size: 24px;
    }
    main .item-block .sub-box h5 span {
        height: auto;
    }
    main .item-block .box {
        padding: 20px 15px;
        border: solid 3px #ff8484;
    }
    main .item-block .price1 .pr {
        font-size: 2.2rem;
    }
    main .item-block .sub-box .price1 .pr {
        font-size: 1.6rem;
    }
    main .item-block {
        background-size: 200vh auto;
        margin-bottom: 70px;
    }
    main .item-block .icon {
        flex-wrap: wrap;
    }
    main .item-block .icon-ex dd {
        margin-right: 10px;
        margin-bottom: 5px;
    }
    main .item-block .icon-ex {
        margin-bottom: 10px;
    }
    main .item-block2 .arrow-bg div:last-child {
        margin-top: -25px;
        padding-left: 60px;
    }
    main .item-block .box .price1 .tax {
        font-size: 14px;
    }
    main .item-block .box .price1 small {
        font-size: 18px;
    }
    main .item-block .box .price1,
    main .item-block .box .price2 {
        font-size: 18px;
    }
    main .item-block .sub-box .catch {
        font-size: 16px;
		
    }
    main .item-block .sub-box .txt,
    main .item-block .box .txt {
        font-size: 16px;
    }
    main .item-block .sub-box .price1,
    main .item-block .sub-box .price2 {
        font-size: 18px
    }
	main .bene .flex{
	display: block;
	}
	main .bene .flex .icon{
    text-align: center;
    margin: 0 auto;
	position: static;
	padding: 0;
	background: #FFF;
}
	main .bene .flex .icon img{
		width: 30%;
		margin-bottom: -10px;
	}
main .bene .flex p {
    font-size: 23px;
    padding: 20px 10px 10px;
	margin-top: -10px;
}
	main .bene .note{
	    font-size: 14px;
    padding: 20px;	
	}
	main .icon .gou.on-p::after,
	main .icon .gou.th-p::after {
    font-size: 12px;
    
}
	main .bene {
    margin: 20px 0;
}
    main .item-block4 .flex {
        flex-wrap: wrap;
        margin-bottom: 40px;
    }
    main .item-block4 dl {
        width: 96%;
        margin-right: 0;
        margin: 0 auto 60px;
    }
    main .item-block4 dl:last-child {
        margin: 0 auto;
    }
    main .item-block4 .txt {
        width: 96%;
        margin: 0 auto 30px;
    }
    main .h3-sub-ttl {
        position: relative;
    }
    main .h3-sub-ttl::before,
    main .h3-sub-ttl::after {
        display: none;
    }
    main .item-block5 .box-bl {
        padding: 0 10px 35px;
        border: solid 3px #6bcefc;
        margin: 0 auto 30px;
    }
    main .item-block6 .flex {
        width: 100%;
    }
    main .item-block6 li {
        margin-right: 1%;
        width: 31.33%;
    }
    main .item-block6 ul::after {
        margin: auto;
        left: 0;
        right: 0;
    }
    main .item-block7 .box-bl2 .ttl {
        font-size: 26px;
        margin-bottom: 25px;
    }
    main .item-block7 .box-bl2 p {
        margin-bottom: 25px;
    }
    main .item-block7 .box-bl2 {
        padding: 35px 20px 120px;
        margin-bottom: 20%;
    }
    main .item-block7 .box-bl2 .fuki--bl {
        width: 96%;
    }
    main .item-block7 .box-bl2 p {
        font-size: 18px;
    }
    main .item-block7 .box-bl2 .ttl::before,
    main .item-block7 .box-bl2 .ttl::after {
        margin: 0 15px;
    }
    main .item-block7 .box-bl2 .fuki--bl small {
        font-size: 16px;
    }
    main .item-block .sub-box .ph {
        min-height: auto;
        width: 100%;
    }
	main .ft-contact{
	clip-path: ellipse(130% 70% at right 50% bottom 30%);
	height: 90vh;
	margin-top: 60px;	
	padding-bottom: 15%;
	}
	main .ft-contact .ft-ttl {
    font-size: 7vw;
	margin-bottom: 10px;
}
	main .ft-contact p {
    font-size: 4vw;
}
	main .ft-contact .grn-txt{
    font-size: 3.5vw;
	margin-top: 10px;
}
    main .item-block8 ul {
        flex-wrap: wrap;
    }
    main .item-block8 ul {
        flex-wrap: wrap;
    }
    main .item-block8 li {
        width: 28%;
        min-height: 170px;
        margin-bottom: 20px;
    }
    
    main .ft-contact .ttl-info {
        font-size: 1.8rem;
        margin: 0 0 30px;
    }
    main .ft-contact .info {
        font-size: 34px;
    }
    main .ft-contact .z-in {
        width: 90%;
        margin: 0 auto;
    }
    main .item-block .box .txt {
        width: 80%;
    }
    main .item-block .sub-box {
        padding: 20px 5px 40px;
    }
    main .icon li {
        width: 40px;
        height: 40px;
        margin-bottom: 10px;
    }
    main .item-block3 .fuki {
        font-size: 1.2rem;
        width: 95%;
        margin: 0 auto 15px;
    }
    main .item-block3 .fukidashi p {
        min-height: 80px;
        margin-left: 30px;
    }
    main .item-block3 .fukidashi2 p {
        border: 3px solid #20B9DF;
        margin-right: 30px;
        min-height: 100px;
        padding: 20px 10px;
    }
    main .item-block3 .fukidashi2 p:before {
        margin-left: 3px;
    }
    main .item-block2,
    main .item-block3,
    main .item-block8 ul {
        margin-bottom: 60px;
    }
    main .item-block4 dt {
        font-size: 1.8rem;
    }
    main .item-block4 dl:last-child dd,
    main .item-block4 dl:first-child dd {
        font-size: 1.3rem;
    }
    main .item-block4 dl:last-child small {
        font-size: 1.156rem;
    }
    main .item-block4 .txt {
        font-size: 1.4rem;
    }
    main .item-block4 .txt span {
        margin-right: 3px;
        font-size: 1.5rem;
    }
    main .item-block4 .txt .btn {
        margin-top: 10px;
        font-size: 1.4rem;
        width: 100%;
    }
    main .item-block5 .box-bl .box-ttl {
        width: 60%;
        font-size: 1.6rem;
        margin: 0 auto 20px;
        padding: 0;
    }
    main .item-block5 .box-bl p {
        font-size: 1.4rem;
        margin-bottom: 25px;
    }
    main .contact .ttl {
        font-size: 1.8rem;
    }
	footer {
    font-size: .5rem;
  
}
}

@media screen and (max-width: 676px) {
    header .logoArea {
    }
    main .item-block .box {}
    main .item-block .box h4,
    main .item-block .sub-box h5 {
        font-size: 22px;
    }
    main .item-block .box h4 img {
        display: block;
        padding-right: 0;
    }
    main .item-block5 .box-bl.grn {
        margin-bottom: 60px;
    }
}

@media screen and (max-width: 636px) {
    header .mv-txt2 h2 {
        font-size: 1.6rem;
    }
    header .mv-txt2 p {
        line-height: 1.5;
        margin-bottom: 10px;
    }
    header .mv-txt2 p b {
        font-size: 1.3rem;
    }
    header .mv-txt {
        font-size: 22px;
        font-feature-settings: "palt";
    }
    main .item-block .price1 .pr {
        font-size: 28px;
    }
}

@media screen and (max-width: 570px) {
    .sp-57_only {
        display: block!important;
    }
    header .logoArea {
    }
    header .mv-txt {
        font-size: 1.2rem;
        margin: 10px auto;
    }
    header .mv-txt2 h2 img {
        width: 28%;
    }
    main h3.ttl3-1 {
        height: auto;
        margin-bottom: 20px;
    }
    main .item-block .box .flex {
        justify-content: center;
        flex-wrap: wrap;
    }
    main .item-block .sub {
        flex-wrap: wrap;
    }
    main .item-block .box {
        width: 80%;
        margin: 0 auto 10px;
    }
    main .item-block .sub-box {
        width: 80%;
        margin-right: 0;
        margin-bottom: 10px;
        padding: 20px 15px 40px;
    }
    
    main .item-block .sub-box .txt {
        width: auto;
        margin: 0 auto;
    }
    main .bg--line::before {
        height: 80px;
    }
    main .contact .ttl {
        font-size: 22px;
    }
    main .contact {
        padding: 30px 10px;
    }
    main .item-block3 .fuki {
        font-size: 18px;
        margin-bottom: 25px;
    }
    main .item-block3 .fukidashi p,
    main .item-block3 .fukidashi2 p {
        width: 60%;
        font-size: 16px;
        padding: 20px 10px;
    }
    main .item-block8 ul {
        margin-bottom: 40px;
    }
    main .item-block4 dt {
        font-size: 1.4rem;
    }
    main .item-block4 dl:first-child dd {
        font-size: 1rem;
    }
    main .item-block4 dl:last-child dd {
        font-size: 1.2rem;
    }
    main .item-block4 dl:last-child small {
        font-size: 1rem;
    }
    main .item-block4 .txt span {
        font-size: 1.2rem;
    }
    main .item-block4 .txt {
        font-size: 1rem;
    }
    main .item-block4 .txt .btn {
        font-size: 1.2rem;
    }
    main .item-block8 li {
        width: 60%;
        min-height: 170px;
        margin-bottom: 20px;
        margin-right: 0;
    }
    main .item-block8 li:nth-of-type(-n+4)::after {
        border-left: 20px solid transparent;
        border-right: 20px solid transparent;
        border-top: 20px solid #296fd9;
        top: 0;
        left: 0;
        right: 0;
        margin: auto;
        bottom: -290px;
    }
	main .ft-contact {
    
}
    
    main .item-block .box h4 span {
        display: block;
    }
    main .item-block .box h4 {
        line-height: 1.5;
    }
    main .item-block2 .arrow-bg div:last-child {
        margin-top: -45px;
    }
    main .item-block .box .txt {
        width: 100%;
    }
    main .item-block5 .box-bl .box-ttl {
        width: 75%;
        font-size: 1.4rem;
    }
    main .item-block5 .box-bl p {
        font-size: 1.2rem;
    }
    main .item-block5 .box-bl.grn .bold {
        font-size: 1.4rem;
        line-height: 1.2;
    }
    main .item-block5 .box-bl.grn small {
        font-size: .9rem;
    }
    main .item-block6,
    main .item-block5 .box-bl.grn {
        margin-bottom: 25px;
    }
    main .item-block,
    main .item-block2,
    main .item-block3,
    main .item-block8 ul {
        margin-bottom: 25px;
    }
    main .item-block7 .box-bl2 .ttl {
        font-size: 1.4rem;
        margin-bottom: 10px;
    }
    main .ft-contact .ttl-info {
        font-size: 1.5rem;
    }

}

@media screen and (max-width: 470px) {
    header {
        margin-bottom: 40px;
    }
    header h1 {
        width: 160px;
        padding-bottom: 20px;
        padding-left: 30px;
    }
    header .mv-txt2 h2 {
        margin-bottom: 5px;
    }
    header .mv-txt {
        font-size: 1rem;
        padding: 5px;
        font-feature-settings: "palt";
        margin: 10px auto 5px;
    }
    header .mv-txt2 h2 img {
        width: 22%;
    }
    header .mv-txt2 h2 {
        font-size: 20px;
    }
    header .mv-txt2 p {
        line-height: 1.5;
    }
    header .mv-txt2 p b {
        font-size: 1rem;
    }
    header .logoArea {
    }
    header .logoArea .logo {
        margin: 0 8px 10px;
    }
    .btn {
        font-size: 1.1rem;
    }
    section .ttl-h2 {
        font-size: 18px;
    }
    section .ttl-h2 small {
        font-size: 16px;
    }
    header nav li:nth-child(-n+6) {
        margin-bottom: 10px;
    }
    header nav li {
        width: 32.33%;
    }
    header nav li:nth-child(5) {
        margin-right: 1%;
    }
    main .item-block .box h4 img {
        width: auto;
        max-height: 30px;
        display: block;
        padding-right: 0;
    }
    main .item-block8 li span {
        font-size: 1.2rem;
    }
    main .item-block2 {
        margin-bottom: 30px;
    }
    main .item-block4 {
        margin-bottom: 30px;
    }
    main .item-block4 .flex {
        margin-bottom: 0;
    }
    main .h3-sub-ttl::before,
    main .h3-sub-ttl::after {
        content: none;
    }
    main .h3-sub-ttl {
        font-size: 23px;
        margin-bottom: 15px;
    }
    main .item-block5 .box-bl .box-ttl {
        width: 90%;
        font-size: 22px;
    }
    main .item-block5 .box-bl p {
        font-size: 18px;
        margin-bottom: 25px;
    }
    main .item-block3 .fukidashi p,
    main .item-block3 .fukidashi2 p {
        width: 80%;
    }
    main .item-block3 .wrap {
        width: 95%;
    }
    main .item-block5 .box-bl {
        width: 90%;
    }
    main .ft-contact .ft-tel {
        margin-top: 20px;
        width: 90%;
    }
    
    main .item-block5 .box-bl.grn .bold {
        font-size: 20px;
        line-height: 1.3;
    }
    main .item-block5 .box-bl.grn small {
        font-size: 12px;
    }
    main .item-block7 .box-bl2 .ttl {
        margin-bottom: 5px;
    }
    main .item-block7 .box-bl2 p {
        font-size: 14px;
    }
    main .item-block7 .box-bl2 {
        padding: 35px 20px 80px;
        margin-bottom: 25%;
    }
    main .item-block7 .box-bl2 .fuki--bl small {
        font-size: 14px;
        margin-top: 10px;
        display: block;
    }
    main .item-block .icon-ex {
        width: 86%;
        margin: 0 auto 10px;
    }
    main .item-block5 .box-bl p,
    main .item-block5 .box-bl.grn .bold {
        font-size: 1rem;
    }
    main .item-block3 .fukidashi p,
    main .item-block3 .fukidashi2 p {
        font-size: 14px;
    }

}

@media screen and (max-width: 376px) {
    section .ttl-h2 {
        font-size: 14px;
    }
    section .ttl-h2 small {
        font-size: 12px;
    }
    header {
        margin-bottom: 50px;
    }
    header .logoArea .logo {
        margin: 0 5px 10px;
    }
    main .item-block .price1 .pr {
        font-size: 36px;
    }
    main .item-block .box .price1,
    main .item-block .box .price2 {
        font-size: 16px;
    }
    main .item-block .icon {
        margin-top: 15px;
    }
    main .ft-contact .ft-ttl {
        margin-bottom: 20px;
    }
    main .ft-contact .grn-txt {
        margin-top: 20px;
        margin-bottom: 45px;
    }
    
    main .item-block .box .txt {
        font-size: 14px;
    }
    main .item-block .sub-box .txt {
        font-size: 14px;
    }
    main .item-block .box .price1 small,
    main .item-block .box .price1 .tax {
        font-size: 16px;
    }
    main .item-block .price1 .pr {
        font-size: 26px;
    }
    main .item-block .sub-box .price1 .pr {
        font-size: 26px;
    }
    main .item-block5 .box-bl p {
        font-size: 16px;
    }
    main .item-block5 .box-bl .box-ttl {
        font-size: 20px;
        padding: 0 0 5px;
        margin: 0 auto 20px;
    }
    .btn {
        font-size: 16px;
    }

}

@media screen and (max-width: 414px) {
    header .mv-txt2 h2 img {
        width: 28%;
    }
	main .ft-contact .ttl-info {
    font-size: 1.3rem;
	padding: 20px 0;
}
	
}

@media screen and (max-width: 375px) {
	main .ft-contact {
    padding-bottom: 10%;
}
}
@media screen and (max-width: 320px) {
    main .item-block .sub-box .txt {
        font-size: 16px;
    }
    header .mv-txt2 h2 img {
        width: 36%;
    }
    header .logoArea {
        margin-top: -58%;
    }
    main .item-block4 dd {
        padding-left: 10px;
    }
    main .ft-contact .grn-txt {
        margin-bottom: 15px;
    }
	main .ft-contact {
    padding-bottom: 0;
    height: 75vh;
}
    .btn {
        font-size: 14px;
    }
    main .item-block .sub-box,
    main .item-block .box {
        width: 85%;
    }
    main .item-block .box .price1,
    main .item-block .box .price2 {
        font-size: 14px;
    }
    main .item-block .box .price1 small,
    main .item-block .box .price1 .tax {
        font-size: 12px;
    }
    main .item-block .sub-box .txt {
        font-size: 14px;
    }
    main .item-block .sub-box .price1 small {
        font-size: 14px;
    }
    main .item-block .sub-box .price2 small {
        font-size: 12px;
    }
    main .icon li {
        font-size: 14px;
        width: 40px;
        height: 40px;
    }
    main .icon .gou.th-p::after,
    main .icon .gou.on-p::after {
        bottom: -20px;
        font-size: 12px;
    }
    main .item-block5 .box-bl .box-ttl {
        font-size: 18px;
        padding-bottom: 0;
        margin: 0 auto 20px;
    }
    main .h3-sub-ttl {
        font-size: 20px;
    }
    main .item-block5 .box-bl {
        margin: 0 auto 20px;
    }
    main .item-block5 .box-bl p {
        font-size: 14px;
    }
    main .item-block5 .box-bl.grn small {
        font-size: 12px;
    }
    main .item-block5 .box-bl.grn .bold {
        font-size: 18px;
        line-height: 1;
    }
    main .item-block7 .box-bl2 .ttl {
        font-size: 20px;
    }
    main .item-block7 .box-bl2 .fuki--bl {
        bottom: -13%;
    }
    main .item-block7 .box-bl2 .fuki--bl small {
        font-size: 12px;
    }
    
    main .ft-contact .ttl-info {
        font-size: 1.2rem;
        padding: 20px 0;
    }
	
}