@charset "UTF-8";
/******************************** setting **********************************/
body {
    font-size: 1em;
    font-family: 'Pretendard', sans-serif;
    letter-spacing: -0.02em;
    --theme  : #2953BE;
    --light1 : #F3F6FF;
    --light2 : #DFE5F5;
    --light3 : #5475CB;
    --dark1  : #254BAB;
    --dark2  : #214298;
    --emph   : #e91538;
    --mark   : #FFD600;
    --ellipsis : 1;
}
.inner { max-width: 1200px; width: 100%; margin-left: auto; margin-right: auto; }
.ellipsis { overflow: hidden; white-space: normal; text-overflow: ellipsis; display: -webkit-box; -webkit-line-clamp: var(--ellipsis); -webkit-box-orient: vertical; word-break: keep-all; }
.mark { background: linear-gradient(to bottom, transparent 40%, var(--mark) 40%); padding-right: 0.2em; padding-left: 0.2em; }
.color { color: var(--theme); }
.container { display: flex; align-items: center; justify-content: center; min-height: 75vh; }
.container-title { text-align: center; font-size: 2em; font-weight: 700; margin-bottom: 1em; }

/******************************** content **********************************/
.header { text-align: center; padding: 2em 0; position: absolute; left: 0; top: 0; right: 0; }
.header .logo { width: 9.375em; max-width: 150px; margin: auto; }
.header .logo img { width: 100%; }

.footer { background-color: #f1d6d6; color: #fff; padding: 3em 0 8em; }
.footer ul { display: flex; justify-content: center; align-items: flex-start; }
.footer li { width: 35%; }
.footer li h5 { font-size: 2em; font-weight: 700; margin-bottom: 0.3em; }
.footer li p { font-size: 1.75em; font-weight: 600; margin-bottom: 0.2em; }
.footer li small { font-size: 1.25em; font-weight: 400; margin-bottom: 0.3em; display: block;}

.wrapper {  }
.main { text-align: center; }
.section { padding: 8em 0; }
.btn_open { background-color: #FD7BA7; color: #000; font-size: 1.5em; font-weight: 700; border-radius: 0.5em; border: 0; padding: 0 2em; height: 2.5em; }

.visual { padding-top: 15em; background-color: #F5FAFE; }
.visual h2 span { padding: 0 1.5em; font-size: 2.25em; color: #186CB5; font-weight: 700; display: inline-flex; background: url(../img/img_leaf_left.png) no-repeat left center/auto 100%, url(../img/img_leaf_right.png) no-repeat right center/auto 100%; }
.visual .box { margin: 3em 0; background-color: #fff; border-radius: 1em; display: inline-flex; flex-direction: column; align-items: center; justify-content: center; padding: 2em 3em; box-shadow: 0 0 1.5em rgba(0,0,0,0.05); }
.visual .box p { font-size: 1.5em; background: linear-gradient(45deg, #46BDFF, #9EB5FB); color: #fff; padding: 0 0.8em; line-height: 2.2; border-radius: 0.5em; }
.visual .box p:last-child { background: none; color: #1C2552; font-weight: 700; }
.visual .box b { font-size: 3em; font-weight: 900; }
.visual .box .plus { margin: 0.2em 0; }
.visual .box .equal { display: inline-flex; flex-direction: column; }
.visual .box .equal i { height: 0.3em; line-height: 0.3; }
.visual .box h5 { margin: 1.5em 0 0.5em; display: flex; align-items: center; font-size: 1.25em; gap: 0.5em; }
.visual .box h5 del { font-size: 1.25em; color: #aaa; }
.visual .box h5 span { display: inline-block; position: relative; text-align: left; font-size: 1em; }
.visual .box h5 strong { font-size: 2.5em; font-weight: 800; color: #e02626; }
.visual h3 { font-size: 2.6em; font-weight: 700; line-height: 1.5; }
.visual hr { width: 1px; height: 4em; border: 0; background-color: #000; margin: 0.5em auto 1em; }
.visual h4 { font-size: 2em; line-height: 1.2; }
.visual .img { width: 60%; margin: 3em auto 0; max-width: 500px; }

.process { background: url(../img/bg_process.png) no-repeat center/cover; }
.process .box { border-radius: 0.875em; display: inline-flex; flex-direction: column; align-items: center; justify-content: center; padding: 5em 8em; box-shadow: 0 0 1.5em rgba(0,0,0,0.2); }
.process .box h5 { font-size: 1.5em; color: #87B6ED; margin-bottom: 2em; }
.process .box h3 { font-size: 2.6em; color: #186CB5; font-weight: 700; }
.process .box ul { display: flex; flex-direction: column; gap: 1em; margin-top: 3em; }
.process .box li { font-size: 2em; display: flex; border: 2px solid #186CB5; background-color: #fff;  color: #186CB5; }
.process .box li b { background-color: #186CB5; color: #fff; padding: 0.2em 0; width: 6em; font-weight: 600; } 
.process .box li p { padding: 0.2em 0.875em 0.2em 0.5em ; font-weight: 500; }
.process .box li i { transform: rotate(90deg); }

.cost { background-color: #F5FAFE; }
.cost h3 { font-size: 2em; font-weight: 600; display: inline-block; background: linear-gradient(45deg, #46BDFF, #9EB5FB); color: #fff; padding: 0 1.25em; line-height: 2.2; border-radius: 5em;  }
.cost ul { display: flex; margin-top: 5em; flex-wrap: wrap; gap: 3em; justify-content: center; }
.cost li { max-width: 46%; background-color: #fff; border: 3px solid #fff; }  
.cost li img { width: 100%; }
.cost li h5 { font-weight: 700; font-size: 1.875em; margin-top: 1em; }
.cost li p { margin: 1em 0; font-size: 1.25em; display: flex; align-items: center; justify-content: center; }
.cost li p del { font-size: 1.25em; color: #aaa; }
.cost li p span { text-align: left; }
.cost li p span strong { font-size: 2.5em; font-weight: 800; color: #e02626; }

.banner { padding: 10em 0 5em; background-color: #EFECFB; position: relative; }
.banner .path { clip-path: polygon(0 0,50% 25%,100% 0); background-color: #F5FAFE; width: 100%; height: 100%; position: absolute; left: 0; top: 0; }
.banner h3 { font-size: 2.25em; font-weight: 700; }
.banner h3 b { color: #e02626; }
.banner .btn_open { margin-top: 1.5em; }

.merit { background-color: #F5FAFE; }
.merit h3 { font-size: 2.25em; font-weight: 600; line-height: 1.3; }
.merit h3 span { color: #e02626; }
.merit h3 b { color: #186CB5; }
.merit hr { width: 2px; height: 5em; border: 0; background-color: #000; margin: 1.5em auto; }
.merit h4 { font-size: 3.75em; line-height: 1.2; font-weight: 700; }
.merit h4 + p { font-size: 1.5em; font-weight: 300; margin-top: 0.5em; }
.merit ul { max-width: 800px; margin: auto; margin-top: 3em; }
.merit li { background-color: #fff; margin-top: 1em; display: flex; }
.merit li b { width: 6.25em; font-size: 2em; font-weight: 700; color: #fff; display: flex; align-items: center; justify-content: center; }
.merit li:nth-child(odd) b { background-color: #F1A6AB; }
.merit li:nth-child(even) b { background-color: #F9DADA; }
.merit li .txt { width: calc(100% - 6.25em); text-align: left; padding: 2em 4em; }
.merit li .txt h5 { font-weight: 700; font-size: 1.5em; margin-bottom: 0.3em; }
.merit li .txt p { font-weight: 300; font-size: 1.25em; position: relative; padding-left: 0.8em; line-height: 1.6; }
.merit li .txt p::before { content:"-"; position: absolute; left: 0; top: 0; }

.review { background-color: #EFECFB; }
.review h3 { font-size: 2em; font-weight: 600; display: inline-block; background: linear-gradient(45deg, #46BDFF, #9EB5FB); color: #fff; padding: 0 1.25em; line-height: 2.2; border-radius: 5em;  }
.review .box { position: relative; margin-top: 4em; }
.review .box .phone { width: 25em; position: absolute; left: 50%; top: 0; transform: translateX(-50%); z-index: 5; }
.review .box .swiper-slide { width: auto; padding: 0 2em; }
.review .box .swiper-slide img { width: 24.375em; }
.review h4 { font-size: 2.25em; font-weight: 500; line-height: 1.3; margin-top: 2em; }
.review h4 b { color: #e02626; display: block; margin-top: 0.5em; }

.location .box { display: flex; align-items: center; justify-content: space-between;}
.location .txt { text-align: left; }
.location .txt h5 { font-size: 2em; font-weight: 500; margin-bottom: 0.3em; }
.location .txt p { font-size: 1.25em; font-weight: 300; line-height: 1.6; }
.location .map { width: 50%; }
.location .map > div { width: 100%; padding-top: 60%; position: relative; }
.location .map iframe { position: absolute; width: 100%; height: 100%; top: 0; left: 0; }


.quick { max-width: 600px; width: 100%; position: fixed; left: 50%; transform: translate(-50%,100%); bottom: 0; z-index: 9999; margin-bottom: 4.25em; transition: 0.4s; }
.quick .btn_open { font-size: 2em; height: 2.2em; padding: 0; width: 100%; border-radius: 1em 1em 0 0; display: block; }
.quick .frm-wrap { text-align: center; font-size: 1.5em; background-color: #FD7BA7; padding: 0 1em; overflow: hidden; }
.quick .frm-wrap form { max-width: 450px; margin: 0.5em auto; }
.quick .frm-box { display: flex; align-items: center; margin-bottom: 0.5em; text-align: left; }
.quick .frm-box label { width: 5em; }
.quick .frm-box input { flex-grow: 1; }
.quick .chk_box { margin-bottom: 1em; font-size: 0.875em; }
.quick .chk_box input[type="checkbox"] + label span { border-radius: 5em; background: transparent; border-color: #fff; border-width: 2px; filter: invert(1); }
.quick .chk_box input[type="checkbox"]:checked + label span { background: url(../img/chk.png) no-repeat center; }
.quick .btn-submit { width: 100%; height: 2.4em; border: 0; background-color: #000; color: #fff; }

.quick.open { transform: translate(-50%,0); margin-bottom: 0; }


/******************************** effect **********************************/
/* fade */
.fade-up,
.fade-down,
.fade-right,
.fade-left { opacity: 0; }
.fade-up { transform: translateY(3rem); }
.fade-down { transform: translateY(-3rem); }
.fade-right { transform: translateX(-3rem); }
.fade-left { transform: translateX(3rem); }
.fade-up.on,
.fade-down.on { animation: fadeY 0.4s ease-out 0s 1 normal forwards; }
.fade-right.on,
.fade-left.on { animation: fadeX 0.4s ease-out 0s 1 normal forwards; }
@keyframes fadeY {
    100% { transform: translateY(0); opacity: 1; }
}
@keyframes fadeX {
    100% { transform: translateX(0); opacity: 1; }
}

/* typing */
.js-typing { --theme: #000; height: 1.4em; }
.js-typing .typing-list { display: none; }
.js-typing .typing-txt::after { content:""; width: 0.07em; height: 1em; background-color: var(--theme); display: inline-block; vertical-align: middle; margin-top: -0.1em; margin-left: 0.1em; animation: typing-cursor 1.5s linear 0s infinite normal forwards; }
@keyframes typing-cursor {
    0% { opacity: 1; }
    50% { opacity: 0; }
    100% { opacity: 1; }
}

/******************************** responsive **********************************/
@media screen and (max-width: 1280px){
    .inner { padding-left: 3%; padding-right: 3%; }
}
@media screen and (max-width: 1024px){
    .header, .footer, .quick, .main  { font-size: 1.5vw; }
}
@media screen and (max-width: 768px){
    .header, .footer, .quick, .main  { font-size: 2vw; } 
    .process .box { padding: 5em 0; width: 90%; }
    .cost ul { gap: 1.5em; }
    .cost li { width: 48%; }
    .location .box { flex-direction: column; }
    .location .txt { width: 90%; margin-bottom: 3em; }
    .location .map { width: 90%; }
    .footer li { width: 50%; }
}
@media screen and (max-width: 586px){
    .header, .footer, .quick, .main  { font-size: 2.375vw; word-break: keep-all;} 
    .process .box { width: 94%; padding: 5em 2em; }
    .process .box li { font-size: 1.875em; }
    .cost li { max-width: 100%; width: 100%; display: flex; align-items: center; }
    .cost li img { width: 50%; }
    .cost li .txt { width: 50%; padding: 1em; }
    .merit li .txt { padding: 2em; padding-right: 1em; }

    .footer ul { flex-direction: column; }
    .footer li { width: 100%; margin-bottom: 2em; font-size: 1.125em; }

    .quick .frm-wrap { font-size: 1.675em; }
    .quick .frm-box label { display: none; }
}
@media screen and (max-width: 324px){
    .cost li { display: block; }
    .cost li img { width: 100%; }
    .cost li .txt { width: 100%; font-size: 1.25em; }
    .merit li { display: block; }
    .merit li b { width: 100%; line-height: 2.25; }
    .merit li b br { display: none; }
    .merit li .txt { font-size: 1.25em; width: 100%; }
}