@charset "UTF-8";
/*=============================================================
 home トップページ
=============================================================*/
/*! intro
================================================ */
#intro .inner { position: relative; z-index: 1; margin-top: -30px; }
#intro .inner .inset { position: relative; padding: 30px 0 27px; background: #fff; }
#intro .inner .inset:before { content: ""; position: absolute; right: -5px; top: -15px; z-index: 2; width: 42.5px; height: 38.5px; background: url(../img/ico_accent01.png) no-repeat center; background-size: contain; }
#intro .inner .inset .tit { padding: 0 0 20px; }
#intro .inner .inset .txt { line-height: 1.92308; }
#voice { padding-bottom: 35px; }
#voice .inner .mtit { margin-bottom: 29px; }
#voice .inner .stit { margin-bottom: 10px; }
#voice .voiceList { margin-bottom: 28px; }
#voice .voiceList .item { padding: 25px 25px 20px; border-radius: 0 10px 0 10px; }
#voice .voiceList .item + .item { margin-top: 15px; }
#voice .voiceList .item .label { display: inline-block; padding: 0 8px; margin-bottom: 8px; background: #0091a2; color: #fff; font-size: 1.2rem; font-weight: bold; line-height: 2.08333; }
#voice .voiceList .item .voiceTit { margin-bottom: 12px; font-size: 1.7rem; font-weight: bold; letter-spacing: 0.04em; }
#voice .voiceList .item .imgWrap { overflow: hidden; margin-bottom: 14px; }
#voice .voiceList .item .imgWrap .pic { position: relative; float: left; width: 50%; box-sizing: border-box; }
#voice .voiceList .item .imgWrap .pic:before { position: absolute; top: 0; display: inline-block; padding: 0 6px; font-size: 1.2rem; font-weight: bold; letter-spacing: 0.04em; }
#voice .voiceList .item .imgWrap .pic.is_bf { padding-right: 16px; }
#voice .voiceList .item .imgWrap .pic.is_bf:before { content: "Before"; color: #0091a2; background: #fff; left: 0; }
#voice .voiceList .item .imgWrap .pic.is_bf:after { content: ""; position: absolute; top: 50%; -webkit-transform: translateY(-50%); -ms-transform: translateY(-50%); transform: translateY(-50%); right: -14px; border: 10px solid transparent; border-left: 10px solid #0091a2; }
#voice .voiceList .item .imgWrap .pic.is_af { padding-left: 12px; }
#voice .voiceList .item .imgWrap .pic.is_af:before { content: "After"; color: #fff; background: #0091a2; left: 12px; }
#voice .voiceList .item .txt { line-height: 1.92308; }
#voice .box { padding: 14px; border: 1px solid; color: #0091a2; font-size: 1.3rem; line-height: 1.84615; }
#mechanism { padding-bottom: 33px; }
#mechanism .mtit { padding: 25px 0 30px; text-align: center; background: #0091a2; color: #fff; font-size: 2.2rem; font-weight: 600; line-height: 1.16659; letter-spacing: .04em; }
#mechanism .mtit .under { margin-bottom: 9px; font-size: 1.55rem; display: inline-block; border-bottom: 1px solid; line-height: 1.64516; letter-spacing: .08em; }
#mechanism .mechanismSlider { margin-bottom: 36px; }
#mechanism .mechanismSlider .slick-arrow { position: absolute; top: 50%; -webkit-transform: translateY(-50%); -ms-transform: translateY(-50%); transform: translateY(-50%); top: 39%; width: 40px; height: 40px; z-index: 1; }
#mechanism .mechanismSlider .slick-arrow:before { display: none; }
#mechanism .mechanismSlider .slick-disabled { display: none !important; }
#mechanism .mechanismSlider .slick-prev { left: 15px; background: url(../img/slide_arrowleft.png) no-repeat center; background-size: contain; }
#mechanism .mechanismSlider .slick-next { right: 15px; background: url(../img/slide_arrowright.png) no-repeat center; background-size: contain; }
#mechanism .mechanismSlider .slick-dots { bottom: -10px; }
#mechanism .mechanismSlider .slick-dots li { width: 8px; height: 8px; margin: 0 5px 0 0; border-radius: 100%; }
#mechanism .mechanismSlider .slick-dots li button { width: 8px; height: 8px; }
#mechanism .mechanismSlider .slick-dots li button:before { color: #eaeaea; opacity: 1; width: 8px; height: 8px; }
#mechanism .mechanismSlider .slick-dots li.slick-active button:before { color: #0091a2; }
#mechanism .mechanismSlider .item { position: relative; }
#mechanism .mechanismSlider .item .img { padding-bottom: 15px; }
#mechanism .mechanismSlider .item .txt { padding: 0 15px; }
#mechanism .courseTxt { text-align: center; overflow: hidden; margin-bottom: 14px; }
#mechanism .courseTxt .ballon { position: relative; left: -7px; display: inline-block; vertical-align: middle; width: 45px; height: 45px; background: #66bdc7; border-radius: 100%; line-height: 45px; color: #fff; font-size: 1.5rem; letter-spacing: 0.1em; }
#mechanism .courseTxt .txt { display: inline-block; font-size: 1.7rem; font-weight: bold; line-height: 1.47059; text-align: left; letter-spacing: .04em; }
#mechanism .courseTxt .txt .zei{ font-weight: bold;font-size: 84%; }
#mechanism .tableSet + .tableSet { margin-top: 18px; }
#mechanism .tableSet .tableTit { margin-bottom: 5px; color: #1f86a1; font-size: 1.5rem; letter-spacing: .08em; }
#mechanism .tableSet .table.table02 th { width: 58%; }
#mechanism .tableSet .table th { padding: 15px; vertical-align: top; font-size: 1.5rem; line-height: 1.16667; background: #e1f4f5; border-top: 1px solid #d0d2d2; border-bottom: 1px solid #d0d2d2; list-style: .08em; }
#mechanism .tableSet .table th .small { font-size: 1.2rem; }
#mechanism .tableSet .table td { padding: 15px; vertical-align: middle; border-top: 1px solid #d0d2d2; border-bottom: 1px solid #d0d2d2; text-align: right; font-size: 1.4rem; line-height: 1.28571; letter-spacing: .08em; }
#mechanism .tableSet .table td .zei{ font-size: 84%; }
#mechanism .note { margin-top: 13px; }
#flow { padding: 36px 0 5px; background: #e1f4f5; }
#flow .list .item { position: relative; padding: 26px 0; }
#flow .list .item:first-child { padding-top: 15px; }
#flow .list .item:not(:last-child) .inner:before { content: ""; position: absolute; bottom: 0; left: 0; width: 100%; border: 1px dashed #0091a2; }
#flow .list .item:not(:last-child) .inner:after { content: ""; position: absolute; left: 50%; -webkit-transform: translateX(-50%); -ms-transform: translateX(-50%); transform: translateX(-50%); bottom: -7.5px; padding: 0 5px; width: 29px; height: 15px; background: url(../img/ico_arrrowbottom01.png) no-repeat center #e1f4f5; background-size: 29px auto; }
#flow .list .item .img { float: left; width: 135px; margin-right: 15px; }
#flow .list .item .detail { overflow: hidden; }
#flow .list .item .detail .tit { color: #0091a2; font-size: 1.6rem; line-height: 1.15625; font-weight: 600; letter-spacing: .08em; }
#flow .list .item .detail .tit .num { position: relative; display: inline-block; top: -2px; vertical-align: middle; font-size: 2rem; letter-spacing: .02em; }
#flow .list .item .detail .tit .num:after { position: relative; content: ""; display: inline-block; margin: 0 9px; height: 1em; width: 1px; background: #0091a2; }
#reason { padding: 85px 0 35px; }
#reason .box { position: relative; padding: 0 30px 5px; border: 7px solid #c7e6e8; }
#reason .box:before { content: ""; position: absolute; left: 50%; -webkit-transform: translateX(-50%); -ms-transform: translateX(-50%); transform: translateX(-50%); top: -80px; width: 88px; height: 47px; background: url(../img/img_reason.png) no-repeat center; background-size: contain; }
#reason .box .mtit { position: relative; top: -23px; background: #fff; color: #0091a2; font-size: 2.4rem; font-weight: 600; line-height: 1.22917; text-align: center; }
#reason .box .list { margin-top: -3px; }
#reason .box .list .item { position: relative; }
#reason .box .list .item:before { content: ""; position: absolute; left: 50%; -webkit-transform: translateX(-50%); -ms-transform: translateX(-50%); transform: translateX(-50%); top: 11px; width: 100%; height: 1px; border-top: 1px dashed #0091a2; }
#reason .box .list .item .num { position: relative; text-align: center; width: 24px; height: 24px; line-height: 24px; margin: auto; background: #fff; border: 1px solid; border-radius: 100%; font-weight: 600; color: #0091a2; font-size: 1.85rem; }
#reason .box .list .item .num:before { content: ""; position: absolute; top: 50%; -webkit-transform: translateY(-50%); -ms-transform: translateY(-50%); transform: translateY(-50%); left: -6px; width: 5px; height: 24px; background: #fff; }
#reason .box .list .item .num:after { content: ""; position: absolute; top: 50%; -webkit-transform: translateY(-50%); -ms-transform: translateY(-50%); transform: translateY(-50%); right: -6px; width: 5px; height: 24px; background: #fff; }
#reason .box .list .item .txt { padding: 5px 0 16px; text-align: center; color: #0091a2; font-size: 1.5rem; font-weight: bold; line-height: 1.66667; }
#faq { padding: 35px 0 38px; }
#faq .qaList { margin-bottom: 25px; }
#faq .qaList .question { position: relative; padding: 15px 0 0 30px; margin-bottom: 3px; color: #0091a2; font-size: 1.5rem; line-height: 1.66667; letter-spacing: .08em; }
#faq .qaList .question:before { position: absolute; left: 0; top: 12px; font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif; display: inline-block; text-align: center; content: "Q"; height: 24px; width: 24px; line-height: 24px; background: #1f86a1; color: #fff; font-size: 1.5rem; }
#faq .qaList .answer { position: relative; padding: 0 0 12px 30px; line-height: 1.92308; border-bottom: 1px dashed #0091a2; }
#faq .qaList .answer:before { position: absolute; left: 0; top: 0; font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif; display: inline-block; text-align: center; content: "A"; height: 24px; width: 24px; line-height: 24px; background: #c7e6e8; color: #0091a2; font-size: 1.5rem; }
#faq .btn { padding: 0 15px; }
#owner { position: relative; padding: 35px 0; background: #e1f4f5; }
#owner .mtit { margin-bottom: 10px; }
#owner .img { width: 230px; margin: 0 auto 5px; }
#owner .lead { margin-bottom: 10px; color: #0091a2; font-size: 1.5rem; font-weight: 600; line-height: 1.33333; letter-spacing: .08em; }
#owner .txt { margin-bottom: 20px; line-height: 1.92308; }
#owner .txt + .btn { width: 80%; margin: 0 auto 20px; }
#owner .map { width: 100%; }
#owner .map iframe { width: 100%; height: 200px; }
#owner .box { position: relative; margin-bottom: -25px; top: -35px; padding: 25px 25px 25px; background: #fff; }
#owner .box:before { content: ""; position: absolute; left: 0; top: 0; width: 5px; height: 100%; background: #1f86a1; }
#owner .box .name { font-size: 1.6rem; font-weight: 600; line-height: 1.5625; color: #1f86a1; margin-bottom: 3px; letter-spacing: .08em; }
#owner .box .address { margin-bottom: 15px; line-height: 1.84615; }
#owner .gallery { position: absolute; left: 0; bottom: -50px; }
#reservation { padding: 44px 0 35px; background: #f5f5f5; }
#reservation .read { margin: 5px 0 26px; }
#reservation .stit { margin-bottom: 13px; }
#reservation .form { margin-top: 27px; }
#reservation .formArea { padding: 5px; background: #fff; }
#reservation .formArea .list .item .th { position: relative; padding: 9px 12px; background: #e1f4f5; font-weight: bold; font-size: 1.4rem; line-height: 1.78571; }
#reservation .formArea .list .item .th .label { margin-left: 10px; display: inline-block; vertical-align: middle; padding: 0 10px; background: #1f86a1; color: #fff; font-size: 1.2rem; font-weight: bold; }
#reservation .formArea .list .item .th .label.any { background: #fff; color: #1f86a1; }
#reservation .formArea .list .item .td { padding: 18px 15px; }
#reservation .formArea .list .item .td input + .note { margin-top: 10px; }
#reservation .formArea .list .item .td .note { margin-bottom: 5px; font-size: 1.2rem; line-height: 1.58333; }
#reservation .formArea input[type="text"], #reservation .formArea input[type="email"], #reservation .formArea input[type="tel"], #reservation .formArea select, #reservation .formArea textarea { width: 100%; padding: 9px; border: 1px solid #d0d2d2; border-radius: 0; background-image: -webkit-gradient(linear, left top, left bottom, from(#fff), to(#fff)); background-image: -webkit-linear-gradient(left, #fff, #fff); font-size: 1.6rem; box-sizing: border-box; }
#reservation .formArea select { width: auto; -webkit-appearance: none; -moz-appearance: none; appearance: none; padding-right: 25px; background: url(../img/bg_select01.png) no-repeat right top #fff; background-size: auto 100%; }
#reservation .formArea textarea { height: 160px; }
#reservation .formArea .radio label { position: relative; display: block; }
#reservation .formArea .radio label + label { margin-top: 5px; }
#reservation .formArea .radio label input[type="radio"] { display: none; }
#reservation .formArea .radio label input[type="radio"]:checked + span:after { display: block; }
#reservation .formArea .radio label input[type="radio"] + span { padding-left: 25px; }
#reservation .formArea .radio label input[type="radio"] + span:before { content: ""; position: absolute; left: 0; top: 1px; width: 16px; height: 16px; background: #e9ebeb; border: 1px solid #d1d3d3; border-radius: 100%; }
#reservation .formArea .radio label input[type="radio"] + span:after { content: ""; display: none; position: absolute; left: 4px; top: 5px; width: 10px; height: 10px; background: #41aabb; border-radius: 100%; }
#reservation .formArea .preferredList .preferredItem { padding: 12px 0 10px; }
#reservation .formArea .preferredList .preferredItem:not(:last-child) { border-bottom: 1px dashed #d0d2d2; }
#reservation .formArea .preferredList .preferredItem .listTit { position: relative; margin-bottom: 8px; font-size: 1.3rem; font-weight: bold; letter-spacing: 0.04em; }
#reservation .formArea .preferredList .preferredItem .listTit:before { content: ""; position: relative; top: 3px; display: inline-block; width: 10px; height: 10px; margin-right: 5px; background: #fff; border: 2px solid #1f86a1; border-radius: 100%; }
#reservation .formArea .preferredList .preferredItem .set { display: table; width: 100%; }
#reservation .formArea .preferredList .preferredItem .set select { display: table-cell; vertical-align: middle; width: 100%; }
#reservation .formArea .preferredList .preferredItem .set .listTxt { display: table-cell; vertical-align: middle; font-size: 1.3rem; padding: 0 5px; }
#reservation .importantArea { margin-top: 20px; background: #fff; border: 4px solid #bcdfe1; padding: 15px 15px 0; box-sizing: border-box; }
#reservation .importantArea .wrap { box-sizing: border-box; height: 110px; overflow: auto; padding: 15px; }
#reservation .importantArea .wrap .txt { font-size: 1.2rem; text-indent: -1em; padding-left: 1em; line-height: 1.58333; list-style: 0.08em; }
#reservation .importantArea .wrap .txt + .txt { margin-top: 1em; }
#reservation .importantArea .wrap .txt .circle { display: inline-block; vertical-align: middle; margin-right: 3px; color: #1f86a1; text-indent: 0; }
#reservation .importantArea .wrap .list { padding-left: 1em; margin-bottom: 1em; }
#reservation .importantArea .wrap .list .item:before { content: "・"; position: relative; top: -2px; display: inline-block; vertical-align: middle; }
#reservation .importantArea .tit { font-size: 1.5rem; color: #1f86a1; text-align: center; }
#reservation .submit { margin: 30px 20px 0; }
#reservation .submit input[type="submit"] { position: relative; display: block; background: #1f86a1; color: #fff; text-decoration: none; font-weight: bold; text-align: center; line-height: 1.85714; letter-spacing: .06em; width: 100%; border: 0; padding: 15px 0; font-size: 1.7rem; -webkit-appearance: none; -moz-appearance: none; appearance: none; border-radius: 0; }
.thankyou { padding: 40px 0; text-align: center; }
.thankyou .btn { padding: 10px 15px; }
@media all and (min-width: 600px) { #owner .gallery { bottom: -110px; } }
