

body {
    background: #fafafa;
    margin: 0;
    padding: 0;
    font-size: 16px;
    font-family: YakuHanJP, "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Noto Sans JP", Meiryo, sans-serif;
}
img{
    max-width: 100%;
}
li{
    list-style: none;
}
.container {
    display: block;
    max-width: 1024px;
    margin: 0 auto;
}
br.pc-none{
    display: none;
}
@media (max-width: 1024px) {
    .container {
        width: 90%;
        max-width: 90%;
        margin: 0 auto;
    }
}
@media (max-width: 767px) {
  html, body{
    overflow-x: clip;
  }
br.pc-none{
    display: block;
}
}
/* ファーストビュー */
header{
    position: relative;
    background-image: url("images/fv.webp");
    background-size: cover;
    background-position: center;
    aspect-ratio: 1920/920;
    width: 100%;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    align-items: normal;
    justify-content: flex-start;
    border-top: 7px solid #178b5e;
}
picture.fv01 {
    width: 55%;
    margin: 2.5% 0 0 5%;
}
picture.fv02 {
    width: 60%;
    margin: 0% 0 0 5%;
}
picture.fv03 {
    width: 45%;
    margin: 0% 0 0 5%;
}
picture.fv04 {
    position: absolute;
    bottom: -7px;
    right: 0;
    width: 37%;
}
@media (max-width: 1024px) {


}
@media (max-width: 767px) {
picture.fv01,picture.fv02,picture.fv03,picture.fv04{
    display: none;
}
header{
    position: relative;
    background-image: url("images/fv-sp.png");
    background-size: cover;
    background-position: center;
    aspect-ratio: 750/1000;
    width: 100%;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    align-items: normal;
    justify-content: flex-start;
    border-top: none
}
}
/* 導入 */
.leading-header {
    background: #178b5e;
    text-align: center;
}
.leading-header h2{
    font-size: 58px;
    letter-spacing: 2px;
    padding: 10px 0 12px;
    color: #fff;
    text-shadow: 0 2px 5px rgb(0 0 0 / 15%);
}
.leading-header h2 span{
    color: #f8eb09;
}
.leading-contents{
    background-image: url(images/leading-bg.webp);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    padding: 50px 0;
}
.leading-wrap{
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
}
.leading-wrap h3{
    text-align: center;
    color: #fff;
    font-size: 36px;
    font-weight: 600;
    width: 100%;
    margin: 0 auto 40px;
    text-shadow: 0 2px 3px rgb(0 0 0 / 15%);
}
.leading-inner{
    width: 220px;
    height: 220px;
    background: #178b5e;
    margin: 0 1.5%;
    border-radius: 50%;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 2px 5px rgb(0 0 0 / 35%);
}
.leading-inner h4{
    font-size: 30px;
    letter-spacing: 2px;
    color: #fff;
    font-weight: 600;
    line-height: 1.2;
    text-shadow: 0 2px 5px rgb(0 0 0 / 15%);
}
.leading-inner h4 span.l01{
    color: #f8eb09;
    font-size: 48px;
    font-weight: 700;
}
.leading-inner h4 span.l02{
    font-size: 28px;
    color: #f8eb09;
}
.leading-inner h4 span.l03{
    color: #f8eb09;
}
.leading-contents p{
    color: #fff;
    font-size: 20px;
    font-weight: 600;
    text-align: center;
    line-height: 1.7;
    margin: 40px auto 0;
    text-shadow: 0 2px 2px rgb(0 0 0 / 15%);
}
.leading-contents p span {
    color: #f8eb09;
}
.leading-contents p.sub{
    font-size: 15px;
    font-weight: 600;
    margin: 15px auto 0;
}
@media (max-width: 1024px) {
    .leading-contents {
        padding: 25px 0;
    }
    .leading-header h2 {
        font-size: 28px;
    }
    .leading-wrap h3 {
        text-align: center;
        color: #fff;
        font-size: 22px;
        margin: 0 auto 20px;
    }
    .leading-inner {
        width: 150px;
        height: 150px;
    }
    .leading-inner h4 {
        font-size: 20px;
        line-height: 1.3;
    }
    .leading-inner h4 span.l01 {
        font-size: 38px;
    }
    .leading-contents p {
        font-size: 16px;
        margin: 20px auto 0;
    }
    .leading-contents p.sub {
        font-size: 13px;
        margin: 10px auto 0;
    }
}
@media (max-width: 767px) {
    .leading-contents {
        padding: 30px 0;
    }
    .leading-wrap h3 {
        font-size: 22px;
        margin: 0 auto 20px;
        font-weight: 700;
        letter-spacing: 1px;
    }
    br.sp-none{
        display: none;
    }
    .leading-contents p {
        font-size: 16px;
        margin: 20px auto 0;
        text-align: left;
        line-height: 1.8;
    }
    .leading-contents p.sub {
        font-size: 13px;
        margin: 15px auto 0;
        text-align: left;
        line-height: 1.6;
    }
    .leading-inner {
        width: 150px;
        height: 150px;
        max-width: 45%;
        margin: 1.5%;
    }
}
/* 解決事例 */
.case{
    position: relative;
    background: #fffbf3;
    padding: 80px 0 5px;
}
.case::before {
    content: "";
    position: absolute;
    left: 0;
    bottom: -150px;
    width: 100%;
    height: 150px;
    background: #fffbf3;
    clip-path: polygon(0 0, 50% 100%, 100% 0);
    z-index: 1;
}
.case-header {
    position: relative;
    margin: 0 auto 50px;
}
.case-header h2{
    text-align: center;
    font-size: 36px;
    line-height: 1.6;
    color: #222;
    font-weight: 700;
}
.case-header h2 span{
    color: #f47722;
    font-size: 1.3em;
}
.case-header p{
    text-align: right;
    color: #222;
    margin: 10px auto 0;
}
.case-wrap h3 {
    position: relative;
    font-size: 40px;
    text-align: center;
    color: #178b5e;
    margin: 0 auto 115px;
}
.case-wrap h3::before {
    content: "";
    position: absolute;
    left: 50%;
    bottom: -70px;
    transform: translateX(-50%);
    width: 0;
    height: 0;
    border-left: 40px solid transparent;
    border-right: 40px solid transparent;
    border-top: 40px solid #178b5e;
}
.case-inner{
    position: relative;
    background: #fff;
    display: flex;
    flex-wrap: wrap;
    margin: 70px auto;
    align-items: stretch;
    width: 100%;
    border: 1px solid #333;
    box-shadow: 0 3px 5px rgb(0 0 0 / 10%);
}
.case-inner .left {
    width: 50%;
    padding: 2%;
}
.case-inner .right {
    width: 50%;
    padding: 3%;
    background: #fafafa;
    display: flex;
    align-items: center;
    justify-content: center;
}
.case-num {
    position: absolute;
    top: -32px;
    left: 20px;
}
.case-num h4 {
    font-size: 30px;
    font-weight: 600;
    display: inline-block;
    background: #178b5e;
    color: #fff;
    border: 1px solid #333;
    padding: 3px 10px 2px 15px;
}
.case-num h4 span {
    font-size: 1.3em;
    font-weight: 700;
}
.case-ba {
    position: relative;
    margin: 35px auto 0;
    padding: 0 0 15px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-bottom: 1px solid #ccc;
}
.case-ba dl{
    width: 45%;
    margin: 0 0%;
    display: flex;
    align-items: center;
    justify-content: center;
}
.case-ba dl.after{
    width: 50%;
}
.case-ba dl dt{
    position: relative;
    font-size: 15px;
    line-height: 1;
    background: #222;
    color: #fff;
    font-weight: 500;
    letter-spacing: 1px;
    padding: 8px 12px;
}
.case-ba dl dt::after {
    content: "";
    position: absolute;
    top: 50%;
    right: -8px;
    transform: translateY(-50%);
    width: 0;
    height: 0;
    border-top: 6px solid transparent;
    border-bottom: 6px solid transparent;
    border-left: 8px solid #222;
}
.case-ba dl dd{
    padding: 0 0 0 0.8em;
    font-size: 16px;
    line-height: 1;
    font-weight: 600;
    letter-spacing: 1px;
}
.case-ba dl.after dt{
    background: #178b5e;
}
.case-ba dl.after dt::after{
    border-left: 8px solid #178b5e;
}
.case-ba dl.after dd{
    font-size: 17px;
    line-height: 1;
    font-weight: 700;
    letter-spacing: 1px;
}
.case-result {
    position: relative;
    margin: 15px auto 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}
.case-result dl{
    width: 100%;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
}
.case-result dl dt {
    position: relative;
    font-size: 26px;
    font-weight: 500;
    background: #f47722;
    padding: 3px 15px;
    color: #fff;
    letter-spacing: 2px;
}
.case-result dl dt::after {
    content: "";
    position: absolute;
    top: 50%;
    right: -8px;
    transform: translateY(-50%);
    width: 0;
    height: 0;
    border-top: 6px solid transparent;
    border-bottom: 6px solid transparent;
    border-left: 8px solid #f47722;
}
.case-result dl dd{
    font-weight: 700;
    font-size: 30px;
    padding: 0 0 0 0.8em;
    color: #f47722;
    letter-spacing: 2px;
}
.case-result dl dd.bai01,.case-result dl dd.bai02{
    position: relative;
}
.case-result dl dd.bai01::before{
    content: "";
    background-image: url(images/bai01.png);
    position: absolute;
    background-repeat: no-repeat;
    background-size: contain;
    top: -23px;
    right: -70px;
    width: 70px;
    height: 48px;
}
.case-result dl dd.bai02::before{
    content: "";
    background-image: url(images/bai02.png);
    position: absolute;
    background-repeat: no-repeat;
    background-size: contain;
    top: -23px;
    right: -70px;
    width: 70px;
    height: 48px;
}
.case-result p{
    font-size: 16px;
    color: #111;
    line-height: 1.5;
    display: inline-block;
    margin: 10px auto 0;
}
.case-inner .right p {
    font-size: 16px;
    line-height: 1.8;
}
@media (max-width: 1024px) {
    .case {
        padding: 50px 0;
    }
    .case::before {
        bottom: -80px;
        width: 100%;
        height: 80px;
    }
    .case-header h2 {
        font-size: 24px;
        line-height: 1.6;
    }
    .case-header p {
        font-size: 13px;
        margin: 5px auto 0;
    }
    .case-wrap h3 {
        font-size: 26px;
        margin: 0 auto 110px;
    }
    .case-inner {
        margin: 60px auto;
    }
    .case-inner .left {
        width: 100%;
        padding: 3% 10%;
    }
    .case-ba dl {
        width: 40%;
    }
    .case-ba dl.after {
        width: 41%;
    }
    .case-result p {
        font-size: 15px;
    }
    .case-inner .right {
        width: 100%;
        padding: 3% 5%;
    }
    .case-inner .right p {
        font-size: 15px;
        line-height: 1.8;
    }
}
@media (max-width: 767px) {
    .case {
        padding: 50px 0 5px;
    }
    .case::before {
        bottom: -60px;
        width: 100%;
        height: 60px;
    }
    .case-header {
        position: relative;
        margin: 0 auto 30px;
    }
    .case-header h2 {
        font-size: 20px;
        line-height: 1.5;
        text-align: left;
    }
    .case-header p {
        font-size: 13px;
        margin: 10px auto 0;
        text-align: left;
    }
    .case-wrap h3 {
        font-size: 24px;
        margin: 0 auto 100px;
        line-height: 1.4;
    }
    .case-wrap h3::before {
        bottom: -50px;
        transform: translateX(-50%);
        border-left: 30px solid transparent;
        border-right: 30px solid transparent;
        border-top: 30px solid #178b5e;
    }
    .case-num {
        position: absolute;
        top: -28px;
        left: 15px;
    }
    .case-num h4 {
        font-size: 24px;
    }
    .case-inner .left {
        width: 100%;
        padding: 10px 15px 20px;
    }
    .case-ba {
        position: relative;
        margin: 40px auto 0;
        padding: 0 0 15px;
        display: flex;
        flex-wrap: wrap;
    }
    .case-ba dl {
        width: 100%;
        justify-content: flex-start;
        margin: 0 auto 10px;
    }
    .case-ba dl.after {
        width: 100%;
    }
    .case-ba dl.after {
        width: 100%;
        margin: 0;
    }
    .case-ba dl dt {
        font-size: 16px;
    }
    .case-ba dl.after dd {
        font-size: 18px;
        padding: 0 0 0 0.85em;
    }
    .case-ba dl dd {
        padding: 0 0 0 1em;
    }
    .case-result dl {
        width: 100%;
        justify-content: flex-start;
    }
    .case-result dl dt {
        font-size: 20px;
        padding: 3px 12px;
    }
    .case-result dl dd {
        font-size: 24px;
        padding: 0 0 0 0.7em;
        letter-spacing: 1px;
    }
    .case-result p {
        font-size: 15px;
        margin: 15px auto 0;
        line-height: 1.7;
        font-weight: 600;
    }
    .case-inner {
        margin: 60px auto 50px;
    }
    .case-inner .right {
        width: 100%;
        padding: 20px 15px;
    }
    .case-result dl dd.bai01::before,.case-result dl dd.bai02::before {
        top: -35px;
        right: -64px;
        width: 70px;
        height: 48px;
    }
}
/* CTA */
.cta {
    position: relative;
    padding: 220px 0 75px;
    background-image: url(images/cta-bg.webp);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}
.cta h2{
    position: relative;
    font-size: 34px;
    text-align: center;
    color: #178b5e;
    margin: 0 auto 15px;
}
.cta h3{
    font-family: "Noto Serif JP", serif;
    color: #ff7b1d;
    font-size: 30px;
    letter-spacing: 1px;
    text-align: center;
    margin: 0 auto 5px;
    text-shadow: 0 2px 5px rgb(0 0 0 / 10%);
}
.cta p.h-txt{
    font-size: 16px;
    text-align: center;
    color: #111;
}
.cta-wrap{
    width: 100%;
    position: relative;
    background: #fff;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    margin: 30px auto;
    padding: 30px 25px;
    box-shadow: 0 3px 5px rgb(0 0 0 / 10%);
}
.cta-tel {
    width: 50%;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
}
.tel-wrap{
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}
.tel-wrap img {
    width: 43px;
    height: 44px;
    margin: 0 0.8em 0 0;
}
.tel-wrap p{
    font-family: serif;
    color: #178b5e;
    font-size: 48px;
    letter-spacing: 2px;
    font-weight: 700;
    line-height: 1;
}
.tel-wrap p a{
    color: #178b5e;
    text-decoration: none;
}
.cta-tel p.date {
    margin: 8px auto;
    font-size: 16px;
    font-weight: 600;
    color: #222;
    letter-spacing: 1px;
}
.cta-tel p.caution{
    text-align: center;
    font-size: 14px;
    color: #111;
}
.cta-mail{
    width: 23%;
}
.cta-mail a{
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    border: 2px solid #ff7019;
    padding: 15px 5px;
    transition: 0.3s;
}
.cta-mail a img{
    width: 40px;
    height: 30px;
    margin: 0 0.8em 0 0;
}
.cta-mail a p{
    font-size: 18px;
    text-align: center;
    color: #ff7019;
    font-weight: 600;
    letter-spacing: 1px;
}
.cta-line{
    width: 23%;
}
.cta-line a{
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    border: 2px solid #12b912;
    padding: 15px 5px;
    transition: 0.3s;
}
.cta-line a img{
    width: 40px;
    height: 40px;
    margin: 0 0.8em 0 0;
}
.cta-line a p{
    font-size: 18px;
    text-align: center;
    color: #12b912;
    font-weight: 600;
    letter-spacing: 1px;
}
.cta-mail a:hover,.cta-line a:hover{
    opacity: 0.6;
}
.cta p.h-txt02{
    text-align: center;
    font-size: 18px;
    line-height: 1.8;
    color: #111;
}
.secret-wrap{
    background: #178b5e;
    margin: 20px auto 0;
    width: 75%;
    border-radius: 10px;
}
.secret-wrap p{
    color: #fff;
    text-align: center;
    font-size: 24px;
    font-weight: 600;
    line-height: 1;
    padding: 15px 10px;
}
.secret-wrap p span {
    color: #f8eb09;
}
@media (max-width: 1024px) {
    .cta {
        padding: 130px 0 50px;
    }
    .cta h2 {
        position: relative;
        font-size: 24px;
        margin: 0 auto 10px;
    }
    .cta h3 {
        font-size: 22px;
    }
    .cta p.h-txt {
        font-size: 15px;
    }
    .cta p.h-txt02 {
        font-size: 16px;
    }
    .cta-mail a img {
        width: 30px;
        height: 22px;
        margin: 0 0.5em 0 0;
    }
    .cta-line a img {
        width: 30px;
        height: 30px;
        margin: 0 0.5em 0 0;
    }
    .cta-mail a p,.cta-line a p {
        font-size: 14px;
        letter-spacing: 0px;
    }
    .cta-tel p.caution {
        font-size: 12px;
    }
    .cta-tel p.date {
        font-size: 15px;
    }
    .tel-wrap p {
        font-size: 30px;
    }
    .secret-wrap {
        margin: 20px auto 0;
        width: 85%;
    }
    .secret-wrap p {
        font-size: 18px;
    }
}
@media (max-width: 767px) {
    .cta {
        padding: 100px 0 50px;
    }
    .cta h2 {
        font-size: 22px;
        margin: 0 auto 10px;
    }
    .cta h3 {
        font-size: 19px;
        font-weight: 800;
        margin: 0px auto 8px;
    }
    .cta p.h-txt {
        font-size: 14px;
    }
    .cta p.h-txt02 {
        font-size: 15px;
        text-align: left;
    }
    .cta-wrap {
        margin: 30px auto;
        padding: 30px 15px;
    }
    .cta-tel {
        width: 100%;
    }
    .tel-wrap p {
        font-size: 32px;
    }
    .tel-wrap img {
        width: 42px;
        height: 44px;
        margin: 0 0.6em 0 0;
    }
    .cta-tel p.date {
        font-size: 16px;
    }
    .cta-tel p.caution {
        font-size: 13px;
        text-align: left;
    }
    .cta-mail {
        width: 90%;
        margin: 20px auto;
    }
    .cta-mail a p, .cta-line a p {
        font-size: 18px;
        letter-spacing: 0px;
    }
    .cta-line {
        width: 90%;
        margin: 0px auto;
    }
    .cta-line a img {
        width: 45px;
        height: 45px;
        margin: 0 0.9em 0 0;
    }
    .cta-mail a img {
        width: 45px;
        height: 35px;
        margin: 0 0.9em 0 0;
    }
    .secret-wrap {
        margin: 20px auto 0;
        width: 100%;
    }
    .secret-wrap p {
        font-size: 18px;
        line-height: 1.5;
    }




}
/* お悩み */
.nayami {
    position: relative;
    padding: 80px 0;
}
.nayami h2{
    text-align: center;
    font-size: 30px;
    font-family: serif;
    font-weight: 700;
    color: #222;
    line-height: 1.7;

}
.nayami h2 span.green{
    color: #178b5e;
}
.nayami h2 span.orange{
    color: #ff7b1d;
}
.nayami-wrap{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start;
    margin: 50px auto;
}
.nayami-left{
    width: 49%;
    border:1px solid #178b5e;
    background-image: url(images/nayami01.webp);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}
.nayami-left h3{
    font-size: 22px;
    line-height: 1;
    color: #fff;
    padding: 15px 5px 14px;
    background: #178b5e;
    font-family: serif;
    font-weight: 600;
    letter-spacing: 1px;
    text-align: center;
}
.nayami-left ul {
    padding: 15px 25px;
}
.nayami-left ul li {
    padding: 10px 0;
    line-height: 1.6;
    font-weight: 500;
    font-size: 16px;
}
.nayami-left ul li::before{
    content: "・";
    color: #178b5e;
    padding: 0 5px 0 0;
}
.nayami-right{
    width: 49%;
    border:1px solid #f68535;
    background-image: url(images/nayami02.webp);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}
.nayami-right h3{
    font-size: 22px;
    line-height: 1;
    color: #fff;
    padding: 15px 5px 14px;
    background: #f68535;
    font-family: serif;
    font-weight: 600;
    letter-spacing: 1px;
    text-align: center;
}
.nayami-right ul {
    padding: 15px 25px;
}
.nayami-right ul li{
    padding: 10px 0;
    line-height: 1.6;
    font-weight: 500;
    font-size: 16px;
}
.nayami-right ul li::before{
    content: "・";
    color: #f16327;
    padding: 0 5px 0 0;
}
.nayami-block {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    z-index: 2;
}
.nayami-block h3{
    width: 28%;
    background: #178b5e;
    margin: 2px;
    color: #fff;
    font-size: 28px;
    text-align: center;
    letter-spacing: 1px;
    padding: 15px 5px;
    z-index: 3;
}
.nayami-txt {
    position: relative;
    box-shadow: 0 0 10px rgb(0 0 0 / 20%);
    padding: 65px 55px 0;
    margin: -35px auto 150px;
    z-index: 1;
}
.nayami-txt::before {
    content: "";
    position: absolute;
    left: 50%;
    bottom: -110px;
    transform: translateX(-50%);
    width: 0;
    height: 0;
    border-left: 60px solid transparent;
    border-right: 60px solid transparent;
    border-top: 60px solid #178b5e;
}
.nayami-txt h3{
    font-size: 22px;
    text-align: center;
    color: #222;
    font-weight: 700;
}
.nayami-txt h3 span {
    background: linear-gradient(transparent 65%, #ffe259 35%);
    font-weight:700;
}
.nayami-inner{
    display: flex;
    justify-content: space-evenly;
    flex-wrap: wrap;
}
.nayami-inner-left {
    width: 65%;
    padding: 23px 0 30px;
}
.nayami-inner-left p{
    font-size: 16px;
    line-height: 1.9;
    margin: 0.75em auto;
    color: #222;
}
.nayami-inner-right{
    width: 22%;
    display: flex;
    align-items: flex-end;
}
.nayami-bottom p{
    display: block;
    color: #222;
    text-align: center;
    line-height: 1.9;
    font-weight: 600;
    font-size: 18px;
    margin: 0 auto 15px;
}
.nayami-bottom h3 {
    background: linear-gradient(180deg, #f68535, #ef4c23);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    text-align: center;
    font-size: 45px;
    font-family: serif;
    font-weight: 700;
}
img.sp-img {
    display: none;
}
@media (max-width: 1024px) {
    .nayami h2 {
        font-size: 26px;
    }
    .nayami-wrap {
        margin: 30px auto 40px;
    }
    .nayami-left h3,.nayami-right h3 {
        font-size: 16px;
    }
    .nayami-left ul li,.nayami-right ul li {
        padding: 5px 0;
        line-height: 1.7;
        font-weight: 500;
        font-size: 14px;
    }
    .nayami-block h3 {
        width: 31%;
        margin: 2px;
        font-size: 22px;
    }
    .nayami-txt {
        padding: 65px 25px 0;
        margin: -35px auto 110px;
        z-index: 1;
    }
    .nayami-txt h3 {
        font-size: 20px;
        line-height: 1.6;
    }
    .nayami-inner-left {
        width: 70%;
        padding: 15px 0 25px;
    }
    .nayami-inner-left p {
        font-size: 14px;
        line-height: 1.9;
        margin: 0.75em auto;
    }
    .nayami-inner-right {
        width: 29%;
    }
    .nayami-txt::before {
        bottom: -90px;
    }
    .nayami-bottom h3 {
        font-size: 30px;
    }
}
@media (max-width: 767px) {
    .nayami {
        position: relative;
        padding: 50px 0;
    }
    .nayami h2 {
        font-size: 22px;
    }
    .nayami-left,.nayami-right {
        width: 100%;
    }
    .nayami-left{
        margin: 0 auto 15px;
    }
    .nayami-left h3, .nayami-right h3 {
        font-size: 16px;
        letter-spacing: 0px;
        font-weight: 700;
    }
    .nayami-left ul li, .nayami-right ul li {
        padding: 5px 0;
        line-height: 1.7;
        font-weight: 500;
        font-size: 15px;
    }
    .nayami-left ul,.nayami-right ul {
        padding: 15px 15px;
    }
    .nayami-block h3 {
        width: 48%;
        margin: 1px;
        font-size: 18px;
        letter-spacing: 0;
        padding: 15px 2px;
    }
    .nayami-txt {
        padding: 65px 15px 0;
        margin: -35px auto 135px;
        z-index: 1;
    }
    .nayami-wrap {
        margin: 25px auto 30px;
    }
    .nayami-txt h3 {
        font-size: 20px;
        line-height: 1.7;
        text-align: left;
    }
    .nayami-inner-left {
        width: 100%;
        padding: 10px 0 15px;
    }
    .nayami-inner-left p {
        font-size: 15px;
        line-height: 1.9;
        margin: 0.75em auto;
    }
    .nayami-inner-right {
        width: 100%;
        display: none;
    }
    img.sp-img {
        display: block;
        float: right;
        width: 85px;
        margin: 0px 0 0px 10px;
    }
    .nayami-inner-right img {
        width: 40%;
        margin: 0 0 0 auto;
    }
    .nayami-txt::before {
        bottom: -110px;
        border-left: 70px solid transparent;
        border-right: 70px solid transparent;
        border-top: 70px solid #178b5e;
    }
    .nayami-bottom p {
        line-height: 1.9;
        font-weight: 600;
        font-size: 18px;
        text-align: left;
        margin: 0 auto 20px;
    }
    .nayami-bottom h3 {
        font-size: 24px;
        line-height: 1.5;
        text-align: left;
    }
}
/* コスト */
.midashi-wrap {
    position: relative;
    text-align: center;
    margin: 0 auto 75px;
}
.midashi-wrap h2 {
    display: inline-block;
    position: relative;
    font-family: 'Noto Serif JP', serif;
    color: #222;
    text-align: center;
    font-size: 48px;
    letter-spacing: 1px;
}
.midashi-wrap h2::before {
    content: "";
    position: absolute;
    left: 50%;
    bottom: -30px;
    transform: translateX(-50%);
    width: 100px;
    height: 2px;
    background: #178b5e;
}
.sub-midashi-wrap {
    position: relative;
    text-align: center;
    margin: 0 auto 65px;
}
.sub-midashi-wrap h3 {
    display: inline-block;
    position: relative;
    font-family: 'Noto Serif JP', serif;
    color: #222;
    text-align: center;
    font-size: 36px;
    letter-spacing: 1px;
}
.sub-midashi-wrap h3::before {
    content: "";
    position: absolute;
    left: 50%;
    bottom: -30px;
    transform: translateX(-50%);
    width: 100px;
    height: 2px;
    background: #178b5e;
}
.cost{
    position: relative;
    padding: 80px 0 90px;
    background-size: cover;
    background-image: url(images/cost-bg.webp);
    background-position: center;
    background-repeat: no-repeat;
}
.cost-about{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: stretch;
    margin: 0 auto 75px;
}
.cost-about-left{
    width: 49%;
}
.cost-about-left h3,.cost-about-right h3{
    font-size: 24px;
    background: #178b5e;
    color: #fff;
    font-weight: 600;
    text-align: center;
    padding: 20px 10px;
    line-height: 1;
    letter-spacing: 1px;
}
.cost-about-left p{
    font-size: 20px;
    line-height: 2.3;
    font-weight: 500;
    padding: 27px 0;
}
.cost-about-right{
    width: 49%;
}
.cost-about-right h4{
    color: #f68535;
    text-align: center;
    font-size: 20px;
    margin: 0 auto 15px;
    font-weight: 700;
}
.cost-about-right ul li{
    font-size: 15px;
    line-height: 1.6;
    padding: 5px 0;
}
.cost-about-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    background: #fff;
    padding: 25px;
}
.down ul li{
    font-size: 16px;
    color: #111;
    padding: 5px 0;
    line-height: 1.7;
}
.down p{
    font-size: 16px;
    line-height: 1.7;
    display: block;
    margin: 20px auto 0;
}
.cost-table-container h4{
    font-size: 24px;
    letter-spacing: 1px;
    display: block;
    margin: 0 auto 30px;
    color: #222;
    text-align: center;
    font-weight: 700;
}
.table-scroll{
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}
.cost-table {
    border-collapse: collapse;
    table-layout: fixed;
    width: 100%;
    min-width: 100%;
    font-weight: bold;
    text-align: center;
    margin: 0 auto 10px;
}
.cost-table thead th {
    padding: 1em .8em;
    border-right: 2px solid transparent;
}
.cost-table thead th{
    position: relative;
    color: #fff;
    font-size: 18px;
    border-radius: 15px 15px 0 0;
    padding: 25px 10px;
    letter-spacing: 1px;
    font-weight: 600;
}
.cost-table thead th:nth-child(2) {
    background-color: #f68535;
}
.cost-table thead th:nth-child(3) {
    background-color: #74c9a8;
}
.cost-table thead th:nth-child(4) {
    background-color: #37a67b;
}
.cost-table thead th:nth-child(5) {
    background-color: #178b5e;
}
.cost-table td {
    color: #333;
    padding: 20px 10px;
    font-size: 16px;
    font-weight: 600;
    border-bottom: 1px solid #fff;
}
.cost-table td p{
    color: #333;
    padding: 0px 0px 0;
    font-size: 11px;
    font-weight: 500;
}
.cost-table tbody tr th{
    font-size: 18px;
    font-weight: 600;
    color: #222;
    background: #f5c6b2;
    border-bottom: 1px solid #fff;
}
.cost-table tbody tr {
  background-color: #f7f7f7;
}
.cost-table tbody tr:nth-child(odd) {
  background-color: #fff;
}
.cost-table td {
    border-left: 2px solid #ececec;
}
.cost-table td:nth-child(2) {
    color: #f88400;
    font-size: 20px;
    border-right: 2px solid #f88400;
    border-left: 2px solid #f88400;
}
.cost-table tr:last-child td:nth-child(2) {
  border-bottom: 2px solid #f88400;
}
.cost-table th.red,.cost-table td.red {
    color: #d30000;
    font-weight: 700;
    border-bottom:none;
    background: #ffe2bf;
}
@media (max-width: 1024px) {
    .midashi-wrap h2 {
        font-size: 36px;
    }
    .midashi-wrap {
        margin: 0 auto 70px;
    }
    .sub-midashi-wrap h3 {
        font-size: 28px;
    }
    .cost {
        position: relative;
        padding: 80px 0 80px;
    }
    .cost-about-right h4 {
        font-size: 16px;
    }
    .cost-about-right ul li {
        font-size: 14px;
    }
    .cost-about-left p {
        font-size: 18px;
    }
    .cost-table h4 {
        font-size: 20px;
    }
    .down ul li {
        font-size: 14px;
    }
    .down p {
        font-size: 14px;
    }
}
@media (max-width: 767px) {
    .midashi-wrap h2 {
        font-size: 28px;
    }
    .midashi-wrap {
        margin: 0 auto 70px;
    }
    .sub-midashi-wrap {
        margin: 0 auto 50px;
    }
    .sub-midashi-wrap h3 {
        font-size: 24px;
    }
    .sub-midashi-wrap h3::before {
        bottom: -25px;
    }
    .cost {
        padding: 50px 0 50px;
    }
    .cost-about-left {
        width: 100%;
        margin: 0 auto 20px;
    }
    .cost-about-left h3, .cost-about-right h3 {
        font-size: 20px;
    }
    .cost-about-wrap {
        padding: 15px 15px 25px;
    }
    .cost-about-left p {
        font-size: 16px;
        padding: 12px 0 15px;
        font-weight: 600;
    }
    .cost-about-right {
        width: 100%;
    }
    .cost-about-right h4 {
        font-size: 18px;
        margin: 10px auto 15px;
    }
    .cost-about {
        margin: 0 auto 50px;
    }
    .cost-table-container h4 {
        font-size: 17px;
        margin: 0 auto 10px;
    }
    .table-scroll{
        width: 100%;
        max-width: 100%;
        overflow-x: auto;
        overflow-y: hidden;
        min-width: 0;
        margin-bottom: 0px;
        position: relative;
    }
    .cost-table{
        width: 750px;
        min-width: 750px;
        margin: 0 auto 15px;
    }
    .cost-table tbody tr th {
        font-size: 16px;
    }
    .cost-table td:nth-child(2) {
        font-size: 17px;
    }
    .cost-table td {
        padding: 15px 5px;
        font-size: 15px;
    }
    .cost-table thead th {
        font-size: 16px;
        border-radius: 10px 10px 0 0;
        padding: 15px 10px;
    }
    .table-scroll::before {
        content: "← 横にスクロールできます →";
        display: block;
        font-size: 13px;
        color: #333333;
        text-align: center;
        margin-bottom: 10px;
    }
    .down ul li,.down p {
        font-size: 15px;
    }  
}
/* 紹介 */
.intro{
    position: relative;
    padding: 80px 0;
    border-top:1px solid #178b5e;
}
.intro-wrap {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
}
.intro-left {
    width: 37%;
}
.intro-left img {
    display: block;
    margin: 0 auto 25px;
}
.intro-inner h3{
    display: inline-block;
    background: #178b5e;
    color: #fff;
    letter-spacing: 1px;
    font-family: 'Noto Serif JP', serif;
    font-weight: 600;
    font-size: 20px;
    padding: 5px 20px 6px;
}
.intro-inner p{
    font-size: 15px;
    line-height: 1.8;
    display: block;
    margin: 15px auto 0;
}
.intro-right{
    width: 58%;
}
.intro-right p{
    font-size: 15px;
    line-height: 2;
    margin: 0.75em auto;
}
@media (max-width: 1024px) {
    .intro-right p {
        font-size: 14px;
    }
    .intro-inner p {
        font-size: 14px;
    }
}
@media (max-width: 767px) {
    .intro {
        padding: 50px 0 40px;
    }
    .intro-left {
        width: 100%;
    }
    .intro-inner h3 {
        font-size: 18px;
    }
    .intro-inner p {
        font-size: 13px;
        line-height: 1.9;
        margin: 10px auto 0;
    }
    .intro-right {
        width: 100%;
        border-top: 1px solid #ccc;
        padding: 15px 0 0;
        margin: 25px auto 0;
    }
    .intro-right p {
        font-size: 15px;
    }
}
/* 紹介 */
.faq{
    position: relative;
    padding: 80px 0 100px;
    background: #f5f5f5;
}
.faq-wrap {
    background: #fafafa;
    position: relative;
    padding: 10px 35px;
}
.faq-item{
  border-bottom: 1px solid #ccc;
}
.faq-item:last-child{
  border-bottom: none
}
.faq-q{
    list-style: none;
    display: flex;
    gap: 16px;
    align-items: center;
    padding: 22px 10px;
    cursor: pointer;
}
.faq-q::-webkit-details-marker{
  display: none;
}
.faq-mark{
    color: #0a7a4a;
    display: grid;
    place-items: center;
    font-weight: 700;
    border-radius: 50%;
    flex: none;
    font-size: 28px;
}
.faq-amark{
  color: #ff4a1c;
}
.faq-qtext {
    font-size: 18px;
    font-weight: 500;
    line-height: 1.7;
}
.faq-a {
    display: flex;
    gap: 16px;
    align-items: center;
    padding: 0 10px 22px;
}
.faq-atext p{
  margin: 0 0 10px;
  line-height: 1.9;
}
.faq-atext p:last-child{
  margin-bottom: 0;
}
.faq-item[open] .faq-q{
  padding-bottom: 12px;
}
/* A部分をアニメ対象にする */
.faq-a {
  overflow: hidden;
  height: 0;
  opacity: 0;
  transition:
    height 0.35s ease,
    opacity 0.25s ease;
}
/* open時 */
.faq-item[open] .faq-a {
  max-height: 1000px; /* 中身より十分大きく */
  opacity: 1;
}
@media (max-width: 1024px) {
    .faq-qtext {
        font-size: 16px;
    }
    .faq-atext p {
        font-size: 14px;
    }
    .faq-mark {
        font-size: 24px;
    }
    .faq-q {
        gap: 14px;
    }
    .faq-a {
        gap: 14px;
    }
    .faq-wrap {
        padding: 10px 25px;
    }
}
@media (max-width: 767px) {
    .faq {
        padding: 50px 0 60px;
    }
    .faq-wrap {
        padding: 10px 10px;
    }
    .faq-qtext {
        font-size: 15px;
    }
}
/*お問い合わせ*/
#contact {
    position: relative;
    padding: 100px 0 0px;
    background: #fafafa;
}
.contact-container {
    background: #e6f4f1;
    padding: 50px 20px 75px;
}
.contact-txt{
    position: relative;
    display: flex;
    justify-content: center;
    background: #fff;
    width: 65%;
    margin: 0 auto 50px;
    padding: 30px;
}
.contact-txt ul li {
    font-size: 16px;
    color: #222;
    padding: 3px 0;
}
.contact-wrap {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    margin: 0 auto 50px;
}
.contact-wrap-left {
    width: 50%;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
}
.contact-tel-wrap {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}
.contact-wrap-left h3 {
    font-size: 20px;
    letter-spacing: 1px;
    display: block;
    margin: 0 auto 10px;
    color: #178b5e;
}
.contact-tel-wrap img {
    width: 43px;
    height: 44px;
    margin: 0 0.8em 0 0;
}
.contact-tel-wrap p {
    font-family: serif;
    color: #178b5e;
    font-size: 48px;
    letter-spacing: 2px;
    font-weight: 700;
    line-height: 1;
}
.contact-tel-wrap p a {
    color: #178b5e;
    text-decoration: none;
}
.contact-wrap-left p.c-date {
    margin: 10px auto;
    font-size: 16px;
    font-weight: 600;
    color: #222;
    letter-spacing: 1px;
}
.contact-wrap-left p.c-caution {
    text-align: center;
    font-size: 14px;
    color: #111;
}
.contact-wrap-right {
    width: 50%;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
}
.contact-wrap-right h3{
    font-size: 20px;
    letter-spacing: 1px;
    display: block;
    margin: 0 auto 10px;
    color:#12b912;
}
.contact-wrap-right p{
    font-size: 15px;
    display: block;
    width: 100%;
    margin: 0 auto 15px;
    text-align: center;
    color: #111;
}
.contact-wrap-right a {
    width: 70%;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    border: 2px solid #12b912;
    padding: 12px 5px;
    transition: 0.3s;
    background: #fff;
}
.contact-wrap-right a img {
    width: 45px;
    height: 45px;
    margin: 0 0.8em 0 0;
}
.contact-wrap-right a p {
    font-size: 18px;
    text-align: center;
    color: #12b912;
    font-weight: 600;
    letter-spacing: 1px;
    width: 63%;
    margin: 0;
}
.contact-wrap-right a:hover {
    opacity: 0.6;
}
.contact-form-wrap {
    margin: 50px auto 0;
    width: 85%;
    position: relative;
}

dl.form-txt {
    position: relative;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding: 15px 0;
}
dl.form-txt dt {
    width: 100%;
    display: flex;
    font-size: 16px;
    align-items: center;
    font-weight: 500;
    margin: 0 auto 15px;
}
dl.form-txt dt span{
    display: inline-block;
    font-size: 13px;
    background: #ff7b1d;
    padding: 6px 5px 5px;
    line-height: 1;
    color: #fff;
    border-radius: 3px;
    margin: 0px 0 0 1em;
}
dl.form-txt dt span.any{
    background: #757575;
}
dl.form-txt dd {
    width: 100%;
}
dl.form-txt dd input {
    background: #fff;
    border: 1px solid #e0e0e0;
    width: 100%;
    padding: 12px 10px 13px;
    border-radius: 5px;
    font-size: 15px;
}
dl.form-txt dd textarea{
    width: 100%;
    border: 1px solid #e0e0e0;
    padding: 12px 10px 13px;
    border-radius: 5px;
    font-size: 15px;
    line-height: 1.6;
    background: #fff;
}
.submit-wrap {
    display: flex;
    position: relative;
    text-align: center;
    margin: 40px auto 0;
    flex-wrap: wrap;
}
.submit-wrap p {
    width: 100%;
    display: block;
    margin: 0 auto 20px;
    line-height: 1.8;
}
.submit-wrap p a{
    color: #178b5e;
    text-decoration: underline;
}
.submit-wrap label{
    width: 100%;
    font-size: 16px;
    margin: 0 auto 20px;
}
.submit-wrap label a:hover{
    opacity: 0.7;
}
.submit-wrap input[type="submit"] {
    font-size: 18px;
    letter-spacing: 1px;
    font-weight: 600;
    display: inline-block;
    background: #fff;
    color: #178b5e;
    padding: 20px 70px 22px;
    border-radius: 0px;
    transition: 0.2s;
    border: #178b5e 2px solid;
    height: auto;
    margin: 15px auto 0;
}
.submit-wrap input[type="submit"]:hover{
    background: #178b5e;
    color: #fff;
}
#submitBtn[disabled]{
    opacity: .5;
    cursor: not-allowed;
}
dl.form-reserve01,dl.form-reserve03 {
    position: relative;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding: 10px 0 0;
}
dl.form-reserve03 {
    padding: 15px 0;
    justify-content: flex-start;
}
dl.form-reserve01 dt,dl.form-reserve03 dt {
    width: 100%;
    display: flex;
    font-size: 16px;
    align-items: center;
    font-weight: 500;
    margin: 0 auto 15px;
}
dl.form-reserve01 dt span,dl.form-reserve03 dt span{
    display: inline-block;
    font-size: 13px;
    background: #ff7b1d;
    padding: 6px 5px 5px;
    line-height: 1;
    color: #fff;
    border-radius: 3px;
    margin: 0px 0 0 1em;
}
dl.form-reserve01 dt span.any,dl.form-reserve03 dt span.any{
    background: #757575;
}
dl.form-reserve02{
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    margin: 0 auto 10px;
}
dl.form-reserve02 dt{
    width: 10%;
}
dl.form-reserve02 dd.calendar{
    width: 42%;
}
dl.form-reserve02 dd.calendar input {
    width: 100%;
    background: #fff;
    border: 1px solid #e0e0e0;
    width: 100%;
    height: 52px;
    padding: 12px 10px 13px;
    border-radius: 5px;
    font-size: 15px;
}
dl.form-reserve02 dd.time {
    width: 42%;
}
dl.form-reserve02 dd.time select {
    width: 100%;
    height: 52px;
    padding: 12px 10px 13px;
    border: 1px solid #dcdcdc;
    border-radius: 6px;
    background: #fff;
    box-sizing: border-box;
}
.radio-wrap{
    display: flex;
    gap: 40px;
    align-items: center;
}
.radio-item{
    display: flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
    font-size: 16px;
}
.radio-item input[type="radio"]{
    appearance: none;
    -webkit-appearance: none;
    width: 20px;
    height: 20px;
    border: 2px solid #afafaf;
    border-radius: 50%;
    position: relative;
    cursor: pointer;
}
.radio-item input[type="radio"]:checked{
    border-color: #178b5e;
}
.radio-item input[type="radio"]:checked::after{
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 10px;
    height: 10px;
    background: #178b5e;
    border-radius: 50%;
    transform: translate(-50%, -50%);
}
small.hint {
    width: 100%;
    display: block;
    margin: 5px auto 0;
    padding: 0 0 0 0.5em;
    font-size: 14px;
}
@media (max-width: 1024px) {
    .contact-txt ul li {
        font-size: 14px;
    }
    .contact-txt {
        width: 80%;
    }
    .contact-wrap-left h3,.contact-wrap-right h3 {
        font-size: 18px;
    }
    .contact-tel-wrap p {
        font-size: 32px;
    }
    .contact-wrap-left p.c-caution {
        font-size: 12px;
    }
    .contact-wrap-right a p {
        font-size: 16px;
        width: 70%;
    }
    .contact-wrap-right a {
        width: 85%;
    }
    .contact-wrap-right p {
        font-size: 14px;
    }
    dl.form-txt dt {
        font-size: 14px;
        margin: 0 auto 10px;
    }
    dl.form-txt dd input {
        font-size: 14px;
    }
    dl.form-txt dt span {
        font-size: 12px;
        padding: 5px 5px 5px;
    }
    dl.form-reserve01 dt, dl.form-reserve03 dt {
        font-size: 14px;
        margin: 0 auto 10px;
    }
    dl.form-reserve01 dt span, dl.form-reserve03 dt span {
        font-size: 12px;
        padding: 5px 5px 5px;
    }
    dl.form-txt dd textarea {
        font-size: 14px;
    }
    dl.form-reserve02 dt {
        width: 15%;
    }
    dl.form-reserve02 dd.calendar {
        width: 40%;
    }
    dl.form-reserve02 dd.time {
        width: 40%;
    }
    dl.form-reserve02 dd.calendar input,dl.form-reserve02 dd.time select {
        height: 48px;
        font-size: 14px;
    }
    .radio-item {
        font-size: 15px;
    }
    .submit-wrap p {
        font-size: 14px;
    }
    .submit-wrap label {
        font-size: 15px;
    }
    .submit-wrap {
        margin: 25px auto 0;
    }
    small.hint {
        font-size: 12px;
    }
}
@media (max-width: 767px) {
    #contact {
        position: relative;
        padding: 60px 0 0;
    }
    .contact-container {
        padding: 35px 10px 50px;
    }
    .contact-txt {
        width: 100%;
        padding: 20px 15px;
        margin: 0 auto 40px;
    }
    .contact-txt ul li {
        font-size: 15px;
        padding: 5px 0;
    }
    .contact-wrap {
        margin: 0 auto 40px;
    }
    .contact-wrap-left {
        width: 100%;
        margin: 0 auto 20px;
    }
    .contact-wrap-left p.c-date {
        margin: 8px auto;
        font-size: 15px;
    }
    .contact-wrap-left p.c-caution {
        font-size: 13px;
        text-align: left;
    }
    .contact-wrap-right {
        width: 100%;
    }
    .contact-wrap-left h3, .contact-wrap-right h3 {
        font-size: 20px;
    }
    .contact-wrap-right p {
        font-size: 15px;
    }
    .contact-wrap-right a {
        width: 92%;
    }
    .contact-wrap-right a img {
        margin: 0 0.5em 0 0;
    }
    .contact-wrap-right a p {
        font-size: 18px;
        width: 75%;
    }
    .contact-form-wrap {
        margin: 0px auto 0;
        width: 100%;
    }
    dl.form-txt dt {
        font-size: 15px;
        margin: 0 auto 10px;
    }
    dl.form-txt dt span {
        font-size: 12px;
        padding: 5px 5px 5px;
        margin: -1px 0 0 1em;
        min-width: 34px;
    }
    dl.form-txt dt span.any {
        background: #757575;
        width: 15%;
        max-width: 34px;
    }
    dl.form-reserve01 dt, dl.form-reserve03 dt {
        font-size: 15px;
        margin: 0 auto 10px;
    }
    dl.form-reserve02 dt {
        width: 100%;
        font-size: 14px;
        padding: 0 0 5px 1em;
    }
    dl.form-reserve02 {
        justify-content: flex-end;
        margin: 0 auto 10px;
    }
    dl.form-reserve02 dd.calendar {
        width: 35%;
        margin-right: 6%;
    }
    dl.form-reserve02 dd.time {
        width: 45%;
    }
    dl.form-reserve02 dd.calendar input, dl.form-reserve02 dd.time select {
        height: 45px;
        font-size: 13px;
    }
    .radio-wrap {
        gap: 15px;
        flex-wrap: wrap;
    }
    .radio-item {
        font-size: 15px;
        padding: 0 0 0 1em;
    }
    small.hint {
        font-size: 13px;
        line-height: 1.5;
    }
}
footer {
    background: #fafafa;
    position: relative;
    padding: 40px 0;
}
footer p {
    text-align: center;
    font-size: 16px;
}
footer p a{
    color: #222;
    transition: 0.2s;
}
footer p a:hover{
    opacity: 0.7;
}
footer p:nth-child(2){
    font-size: 14px;
    display: block;
    margin: 10px auto 0;
}
@media (max-width: 1024px) {
    footer p {
        font-size: 14px;
    }
    footer p:nth-child(2) {
        font-size: 12px;
    }
}
@media (max-width: 767px) {
    footer p {
        font-size: 15px;
    }
    footer p:nth-child(2) {
        font-size: 13px;
        line-height: 1.7;
    }
}
.thanks-txt {
    position: relative;
    display: block;
    background: #fff;
    width: 85%;
    margin: 0 auto 50px;
    padding: 20px 30px;
}
.thanks-txt p{
    font-size: 16px;
    line-height: 1.9;
    color:#222;
    margin: 10px auto;
}
.thanks-bottom{
    position: relative;
    display: block;
    width: 85%;
    margin: 0 auto 0px;
    padding: 0px 30px;
}
.thanks-bottom p{
    font-size: 16px;
    line-height: 1.9;
    color:#222;
    margin: 10px auto;
}
.thanks-link-wrap {
    display: block;
    text-align: center;
    margin: 40px auto 0;
}
.thanks-link-wrap a{
    font-size: 18px;
    letter-spacing: 1px;
    font-weight: 600;
    display: inline-block;
    background: #fff;
    color: #178b5e;
    padding: 20px 70px 22px;
    border-radius: 0px;
    transition: 0.2s;
    border: #178b5e 2px solid;
    height: auto;
    margin: 0 auto 0;
    text-decoration: none;
}
.thanks-link-wrap a:hover{
    opacity: 0.7;
}
@media (max-width: 1024px) {
    .thanks-txt p,.thanks-bottom p {
        font-size: 14px;
    }
}
@media (max-width: 767px) {
    .thanks-txt {
        width: 100%;
        padding: 20px 15px;
        margin: 0 auto 40px;
    }
    .thanks-txt p, .thanks-bottom p {
        font-size: 15px;
    }
    .thanks-bottom {
        width: 100%;
        margin: 0 auto 0px;
        padding: 0px 10px;
    }
    .thanks-link-wrap {
        margin: 30px auto 0;
    }
    .thanks-link-wrap a {
        font-size: 18px;
        letter-spacing: 0px;
        padding: 20px 30px 22px;
    }
}