@charset "UTF-8";

/*
 Theme Name:   Hello Elementor Child
 Template:       hello-elementor
 Version:      1.0
*/

* {margin: 0; padding: 0; box-sizing: border-box;}
body {font-family: "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif; line-height: 1.6; color: #333; margin-top: 20px;}
#concept {scroll-margin-top: 20px;}
.container {max-width: 700px; margin: 0 auto; padding: 100px 0;}
h3 {text-align: center; margin-bottom: 40px; font-size: clamp(20px,2.5vw,26px); color: #64765c;}
p {font-size: clamp(14px,2vw,18px); margin-block-start: 0; margin-block-end: 0;}

/* Header */
header {position: fixed; top: 0; left: 0; width: 100%;  z-index: 1000; background-color: #fff; margin: 0;}
.header-content {display: flex; justify-content: space-between; align-items: center; padding: 15px 80px;}
.logo-wrap {display: flex; align-items: center; gap: 10px;}
.logo {background-image:url(../images/logo.svg); width: 40px; height: 40px; background-size: cover; background-repeat: no-repeat;}
.logo-text {font-size: 18px; color: #64765c;}
.nav-pc ul li {display: flex;}
.nav-pc ul li a {text-decoration: none;}
.menu-pc {display: flex; justify-content: center; align-items: center; gap: 25px;} 
.menu-pc a {color: #64765c; transition: transform 0.3s;}
.menu-pc a:hover {transform: translateX(2px);}
.cta-button {background: #adcda0; padding: 14px 24px; border-radius: 5px; text-decoration: none; font-weight: bold; display: inline-flex; align-items: center; transition: transform 0.3s; color: #fff !important; font-size: 14px; z-index: 1200;}
.cta-button:hover {transform: translateX(2px);}

/* FV */
.fv-image {background-image:url(../images/fv-pc.jpg); width: 100%; height: 850px; background-size: cover; background-position: center; background-repeat: no-repeat; padding: 200px 0 0 180px;}
.fv-image h1 {position: absolute; top: 480px; left: 180px; font-size: 35px; color: #fff;}
.fv-image h2 {position: absolute; top: 540px; left: 180px; font-size: 22px; color: #fff;}
.fv-section{opacity: 0;}

/* コンセプト */
.concept .container p {position: relative; padding-left: 26px;}
.concept .container p::before {content: ""; position: absolute; left: 0; top: 0; width: 4px; height: 100%; background-color: #64765c;}
/* スライダー */
body { box-sizing: border-box; margin: 0; padding: 0; }
.slider {margin: 100px auto; width: 100%; margin: 0 auto; padding: 0 0 80px 0;}
.slider img {height: auto; width: 100%; height: clamp(150px, 40vw, 250px); object-fit: cover; margin: 0 auto;}
.slick-prev, .slick-next {width: 0; height: 0; display: none !important; /* ← 矢印を完全に非表示に */}

/* 料金 */
.price {background-image:url(../images/price.jpg); width: 100%; height: auto; background-size: cover; background-position: center; background-repeat: no-repeat; padding: 100px 0;}
.price .container {background-color: rgba(255,255,255,0.1); padding: 50px 60px; border-radius: 8px;}
.price-title h3 {margin-bottom: 0px; font-size: clamp(16px,2vw,22px); margin-block-start: 0; margin-block-end: 0; color: #fff; font-weight: bold;}
.price-title {position: relative; display: flex;  margin: 10px 0; gap: 10px; border-width:0 0 1.5px 0; border-style:solid; border-color:#fff;}
.price-title p {color: #fff;}
.price-title:not(:first-of-type) {margin-top: 50px;}
.price-item {display: flex; justify-content: space-between; align-items: center; list-style: none; margin-top: 20px; color: #fff;} 

/* ご利用までの流れ */
.flow {background-color: #f0f5ec; }
.step-content {display: flex; justify-content: space-between; background-color: #fff; padding: 28px 32px; margin-bottom: 15px; border-radius: 6px; gap: clamp(20px,3vw,30px)}
.step-number {font-size: clamp(17px,3vw,24px); font-weight: bold; width: clamp(28px,5vw,35px); border-bottom: 2px solid #333;}
.step-p {margin-top: clamp(14px,2vw,15px); font-size: clamp(14px,2vw,18px);}
.step-p strong {font-size: clamp(16px,2.5vw,20px);}
.step-content img {width: 200px; height: auto; background-size: cover; background: no-repeat; border-radius: 6px;}

/* よくあるご質問 */
.section-faq {background-color: #adcda0;}
.faq {width: 100%; margin-top: 20px;}
.faq__question {display: flex; justify-content: space-between; align-items: center; background: #e7f0e3; color: #000; padding: 22px 32px;}
.faq__p {position: relative; display: flex; align-items: center; gap: clamp(14px,2.8vw,20px);}
.faq__q {background-color: #91ac87; color: #fff; padding: 5px 14px; border-radius: 25px; font-size: clamp(20px,3vw,24px)}
.faq__answer {display: none; padding: 22px 25px; background: #fff; padding: 22px 34px;}
.faq__a {background-color: #fff; color: #91ac87; border: 2px solid #91ac87; padding: 3px 12px; border-radius: 25px; font-size: clamp(18px,2.8vw,22px)}
.faq__toggleIcon {transition: transform .3s ease-in-out;}
.faq__question.is-open .faq__toggleIcon {transform: rotate(180deg);}
.faq__toggleIcon {display: block; width: 15px; height: 15px; position: relative; cursor: pointer;}
.faq__toggleIcon::before {content: ""; display: inline-block; height: 2px; width: 9px; background: #91ac87; transform: translateY(50%) rotate(45deg); position: absolute; top: 50%; left: 0;}
.faq__toggleIcon::after {content: ""; display: inline-block; height: 2px; width: 9px; background: #91ac87; transform: translateY(50%) rotate(-45deg); position: absolute; top: 50%; right: 0;}

/* アクセス */
.access-content {display: flex; background-color: #fff; border-radius: 6px; border: 1.5px solid #64765c; padding: 30px 40px;}
.section-access .access-content {display: grid; grid-template-columns: 1fr 1fr; grid-template-rows: auto auto; grid-template-areas: "text map" "image image"; gap: 20px; align-items: start;}
.access-text {grid-area: text;}
.access-map {grid-area: map;}
.access-image {grid-area: image;}
.access-image img {width: 100%; height: auto; display: block; border-radius: 8px;}

/* お問い合わせフォーム */
.page-header{text-align: center; margin: 150px 0 40px 0; color: #64765c;}
.page-header h2 {font-size: clamp(20px,2.5vw,26px);}
.wpcf7-form{max-width: 600px; margin: 0 auto;}
.wpcf7-form label{width: 100%; line-height: 1.66; margin-bottom: 10px; color: #64765c; font-size: clamp(14px,2vw,18px);}
.wpcf7-form input[type="text"], .wpcf7-form input[type="email"] {height: 50px;}
.wpcf7-form textarea {height: 280px; margin-bottom: 40px;}
.wpcf7-form input[type="submit"]{margin: auto; width: 200px; display: block;}
.wpcf7-form input.wpcf7-submit {display: block; margin: 0 auto;}
.wpcf7-form .wpcf7-submit,.wpcf7-form .wpcf7-submit:hover,.wpcf7-form input.wpcf7-submit,.wpcf7-form input.wpcf7-submit:hover {background: #adcda0; padding: 14px 24px; border-radius: 5px; text-decoration: none; font-weight: bold; transition: transform 0.3s; color: #fff; font-size: 16px; border: none; margin-bottom: 100px;}
.wpcf7-form .wpcf7-submit:hover,.wpcf7-form input.wpcf7-submit:hover {transform: translateX(2px);}


/* フッター */
.footer-container {text-align: center; padding: 40px; background-color: #e7f0e3; color: #64765c;}
.footer-container p {font-size: clamp(10px,1.3vw,13px);}


/* レスポンシブ対応 NAV */
@media (min-width: 1151px) {
.wrapper-sp {display: none;}
}

/* レスポンシブ対応 s */
@media (max-width: 1150px) {
.wrapper-pc {display: none;}
#concept {scroll-margin-top: 70px;}
.nav-sp {position: fixed; top: 0; right: -300px; height: 440px; padding-top: 70px; background: #f1f4f0; font-size: 16px; z-index: 2000; transition: 0.25s; border-radius: 0 0 0 8px; }
.nav-sp ul li {display: block; padding: 8px 0; margin-left: 45px;}
.nav-sp ul li a {text-decoration: none; font-size: 15px;}
.nav-sp.open {right: 0;}
.wrapper {margin: 0; padding: 0;}
.logo {width: 35px; height: 35px;}
.logo-text {font-size: 17px;}
.botan {position: fixed; top: 23px; right: 55px; width: 30px; height: 24px; z-index: 2100; cursor: pointer;}
.botan span { position: absolute; width: 30px; height: 2.5px; background: #666; border-radius: 10px; transition: all 0.7s ease;}
.botan span:nth-child(1) {top: 0;}
.botan span:nth-child(2) {top: 9px;}
.botan span:nth-child(3) {top: 18px;}
.botan.hyoji span {background: #64765c; width: 30px;}
.botan.hyoji span:nth-child(1) {top: 9px; transform: rotate(38deg);}
.botan.hyoji span:nth-child(2) {transition: opacity 0.6s ease;}
.botan.hyoji span:nth-child(3) {top: 9px; transform: rotate(-38deg);}
.botan.hyoji span:nth-child(2) {opacity: 0; transition: opacity 0s ease;}
.menu-sp {text-decoration: none;}
.menu-sp a {color: #64765c;}
.cta-button {margin: 30px 45px; padding: 13px 23px; font-size: 13px;}
.container {max-width: 600px; padding: 70px 0;}
.header-content {padding: 15px 55px;}
.fv-image {height: 800px; background-image:url(../images/fv-s.jpg);}
.fv-image h1 {top: 480px; left: 90px; font-size: 32px;}
.fv-image h2 {top: 535px; left: 90px; font-size: 21px;}
.slider {padding: 0 0 50px 0;}
.step-content {padding: 24px 30px;}
.faq__question {padding: 20px 28px;}
.faq__q {padding: 3.5px 13px}
.faq__answer {padding: 20px 28px;}
.faq__a {padding: 1.5px 10.5px;}
.access-content {padding: 20px 25px;}
.page-header{margin: 120px 0 35px 0;}
.wpcf7-form input[type="text"], .wpcf7-form input[type="email"], .wpcf7-form input[type="tel"] {height: 45px;}
.wpcf7-form textarea {margin-bottom: 30px;}
.footer-container {padding: 35px;}
}

/* レスポンシブ対応 tab */
@media (max-width: 900px) {
body {margin-top: 60px;}
.nav-sp {height: 390px; padding-top: 60px;}
.nav-sp ul li {display: block; padding: 6px 0; margin-left: 40px;}
.nav-sp ul li a {font-size: 14px;}
.cta-button {margin: 15px 40px; padding: 12px 22px; font-size: 12px;}
.container {max-width: 520px; padding: 60px 0;}
.header-content {padding: 13px 50px;}
.logo{width: 30px; height: 30px;}
.logo-text {font-size: 16px;}
.botan {top: 18px; right: 50px;}
.fv-image{height: 800px; background-image:url(../images/fv-tab.jpg);}
.fv-image h1 {top: 110px; left: 100px; font-size: 30px;}
.fv-image h2 {top: 160px; left: 100px; font-size: 20px;}
.slider {padding: 0 0 40px 0;}
.price .container {padding: 40px 50px;}
.step-content {padding: 20px 28px;}
.step-content img {width: 190px;}
.faq__question {padding: 18px 24px;}
.faq__q {padding: 2px 11.5px}
.faq__answer {padding: 18px 26px;}
.faq__a {padding: 0.2px 9px;}
.access-content {display: block;}
.access-text {margin-bottom: clamp(20px,3vw,30px);}
.access-content img {width: 100%;}
.section-access .access-content {grid-template-columns: 1fr; grid-template-areas: "text" "map" "image";}
.page-header{margin: 100px 0 30px 0;}
.wpcf7-form{max-width: 500px;}
.wpcf7-form input[type="text"], .wpcf7-form input[type="email"], .wpcf7-form input[type="tel"] {height: 40px;}
.wpcf7-form textarea {height: 250px; margin-bottom: 30px;}
.footer-container {padding: 30px;}
}

@media (max-width: 576px) {
body {margin-top: 55px;}
.nav-sp {height: 370px; width: 220px; padding-top: 55px;}
.nav-sp ul li {display: block; padding: 5px 0; margin-left: 38px;}
.nav-sp ul li a {font-size: 13px;}
.cta-button {margin: 20px 30px; padding: 11px 21px; font-size: 11px;}
.container {max-width: 420px; padding: 50px 0;}
.header-content {padding: 13px 30px;}
.botan {top: 17px; right: 30px;}
.fv-image {height: 800px; background-image:url(../images/fv-sp.jpg);}
.fv-image h1 {top: 110px; left: 60px; font-size: 28px;}
.fv-image h2 {top: 160px; left: 60px; font-size: 19px;}
.slider {padding: 0 0 30px 0;}
.price .container {padding: 30px 40px;}
.step-content {padding: 20px 26px;}
.step-content img {width: 170px;}
.faq__question {padding: 16px 20px;}
.faq__q {padding: 1px 9.5px}
.faq__answer {padding: 16px 20px;}
.faq__a {padding: 0.1px 7.5px;}
.page-header{margin: 90px 0 25px 0;}
.wpcf7-form{max-width: 400px;}
.wpcf7-form input[type="text"], .wpcf7-form input[type="email"], .wpcf7-form input[type="tel"] {height: 38px;}
.wpcf7-form textarea {margin-bottom: 20px;}
.footer-container {padding: 25px;}
}

/* アニメーション */
.toujo-fv {animation-name:fadein-anime; animation-duration:6s; animation-fill-mode: forwards;}
.toujo-price {animation-name:fadein-anime; animation-duration:3s; animation-fill-mode: forwards;}
.toujo-content {animation-name:fadein-left; animation-duration:3s; animation-fill-mode: forwards;}
.toujo-faq {animation-name:fadein-anime; animation-duration:6s; animation-fill-mode: forwards;}
@keyframes fadein-anime{0% {opacity:0} 100% {opacity:1;}}
@keyframes fadein-right {0% {opacity: 0; transform: translateX(20px);} 100% {opacity: 1; transform: translateX(0);}}
@keyframes fadein-left {0% {opacity: 0; transform: translateX(-30px);} 100% {opacity: 1; transform: translateX(0);}}


