@charset "UTF-8";

/*
 Theme Name:   税理士コンシェルジュ 
 Template:       hello-elementor
 Version:      1.0
*/

/* 基本設定 */
* {margin: 0; padding: 0; box-sizing: border-box;}
body {font-family: 'Yu Gothic', 'YuGothic', 'Hiragino Kaku Gothic ProN', 'Hiragino Sans', 'Meiryo', sans-serif; line-height: 1.6; color: #000;}
.container {max-width: 1000px; margin: 0 auto; padding: clamp(70px, 8vw, 120px); max-width: clamp(420px, 65vw, 880px)}
.site-header {display: none;}
html {margin-top: 0 !important;}

section h2 {font-size: clamp(18px, 3vw, 24px); font-weight: bold; margin-bottom: clamp(25px, 4vw, 50px);}
section h3 {font-size: clamp(14px, 2vw, 20px); text-align: center;}
section p {font-size: clamp(12px, 2vw, 16px);}

/* Header */
header {background: #fff; padding: clamp(10px, 1.7vw, 20px) clamp(18px, 2.5vw, 80px)}
.header-content {display: flex; justify-content: space-between; align-items: center;}
.logo {color: #CFA36C; font-size: clamp(12px, 2vw, 18px); font-weight: 600;}

/* CTA */
.btn {display: inline-block; padding: clamp(10px, 1.7vw, 14px) clamp(20px, 4vw, 30px); font-size: clamp(10px, 1.7vw, 16px); font-weight: bold; text-decoration: none; color: #fff; background:linear-gradient(to right, #E59809, #CE5629); border-radius: clamp(6px, 1vw, 8px); transition: 0.3s; box-shadow: 0 4px 6px rgba(0,0,0,0.2);}
.material-symbols-outlined{font-variation-settings: 'FILL' 0, 'wght' 350, 'GRAD' 0, 'opsz' 24; font-size: clamp(20px, 3.5vw, 38px) !important; vertical-align: middle;  }
.btn:hover {opacity: 0.8; transform: translateY(-2px); color: #fff;} 

/* FVセクション */
.fv {background: linear-gradient(135deg, #EFF6FD 0%, #F0F0F0 100%); overflow: hidden; padding: 0 clamp(35px, 6vw, 80px);}
.fv-container {display: flex; align-items: center; justify-content: space-between; max-width: 1000px; margin: 0 auto; gap: 0;}
.fv-image img {max-width: clamp(250px, 45vw, 450px); height: auto; display: block;}
.fv-subtitle {font-size: clamp(16px, 2vw, 28px); font-family: "Shippori Mincho", serif; font-weight: 400; font-style: normal; color: #073E98;}
.fv-title {color: #073E98; font-family: "Shippori Mincho", serif; font-size: clamp(28px, 4vw, 44px); font-weight: 500; line-height: 1.2;}
.fv-title .highlight{color: #A38108; font-size: clamp(34px, 6vw, 60px);} 
.fv-trust-1 {display: flex; justify-content: flex-start; gap: clamp(10px, 1vw, 20px); padding-top: clamp(20px, 3.5vw, 50px);}
.fv-trust-1 img {width: clamp(100px, 17vw, 190px); height: auto; display: block;}

/* 悩みセクション */
.concern {background: #f8f9fa;}
.concern .container {display: flex; justify-content: flex-end; max-width: 100%; padding-right: 0;}  
.concern-card {background: url("images/concern.jpg") center/cover; padding:50px 600px 60px 70px; border-radius: 6px 0 0 6px; position: relative; box-shadow: 0 4px 6px rgba(0,0,0,0.2);} 
.concern-title {color: white; font-size: clamp(18px, 3vw, 28px); text-align: center; margin-bottom: 30px;}
.concern-list {list-style: none; max-width: 100%; font-size: clamp(14px, 2vw, 18px);}
.concern-item {color: white; margin-bottom: 15px; padding-left: 35px; position: relative; display: flex; align-items: flex-start; gap: 10px;}
.concern-item .checkmark {width: clamp(15px, 2.5vw, 30px);  height: auto; flex-shrink: 0;}
.solution-box {background: linear-gradient(135deg, #c9a860 0%, #b8985a 100%); color: white; padding: 30px 40px; border-radius: 4px; text-align: center; margin-top: -35px; margin-left: auto; margin-right: 400px; max-width: 500px; position: relative; box-shadow: 0 4px 6px rgba(0,0,0,0.2);}
.solution-box p {font-size: clamp(14px, 2vw, 19px); line-height: 1.6; margin: 0; }
.solution-box strong {font-size: clamp(18px, 3vw, 24px); font-weight: bold;}

/* サービス特長セクション */
.features {background-color: #E8EDF8;}
.features h2 {text-align: center; color: #073E98; margin-bottom: clamp(45px, 8vw, 50px);}
.features-grid {display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: clamp(20px, 2vw, 30px);}
.feature-icon {width: clamp(100px, 17vw, 120px); margin: 0 auto; display: flex;}
.feature-item {max-width: 280px; margin: auto;}
.feature-item h3 {margin-top: clamp(20px, 3.5vw, 30px); margin-bottom: clamp(15px, 1.5vw, 15px); color: #2d3748;}
.feature-item p {line-height: 1.6; color: #4a5568; max-width: 310px;}

/* ポイントセクション */
.points {background: url("images/points.jpg") no-repeat center/cover; height: auto;}
.points-title{display: flex; flex-direction: column; text-align: center; }
.points-list {display: flex; flex-direction: column; gap: clamp(10px, 1vw, 15px);}
.points-title{color: #fff;}
.points-title h3 {padding: 0; margin: 0;}
.points-title h2 {margin-top: clamp(5px, 0.8vw, 15px);}
.point-item {padding: clamp(8px, 1vw, 40px); display: flex; width: clamp(310px, 55vw, 500px); margin: 0 auto; background-color: #F0F0F0;}
.point-item .checkmark {object-fit: contain; width: clamp(15px, 2.5vw, 27px); margin-left: clamp(15px, 1vw, 24px); margin-right:(15px, 1vw, 24px)}
.point-item p {margin: 0; padding: clamp(10px, 1vw, 25px); color: #000;}

/* ご利用の流れセクション */
.flow {background-color: #f7fafc;}
.flow h2 {text-align: center; color: #073E98;}
.flow-steps {display: flex;  flex-direction: column; max-width: 600px; margin: 0 auto; }
.step-number {background-color: #6082BD; color: white; padding: clamp(15px, 2.5vw, 20px) clamp(20px, 4vw, 30px); display: flex; align-items: center; justify-content: center; font-weight: bold; font-size: clamp(16px, 2vw, 22px); flex-shrink: 0;}
.step-content {display: flex; align-items: center; background-color:#fff; box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);}
.step-content p {color: #000; padding: 0 clamp(21px, 3vw, 28px); margin: 0;}
.arrow-down {text-align: center; font-size: clamp(22px, 3vw, 28px); color: #cbd5e0; margin: clamp(5px, 1vw, 15px) 0;}

/* 最終CTAセクション */
.final-cta .container {background-color: white; padding: 0; border-radius: 10px; box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);}
.final-cta {background-color: #E8EDF8; padding: clamp(50px, 8vw, 100px) 0;}
.final-cta-content {padding-top: clamp(25px, 4vw, 40px); padding-bottom: clamp(5px, 1vw, 10px); padding-left: clamp(20px, 3.5vw, 60px); padding-right: clamp(20px, 3.5vw, 60px);}
.final-cta h2 {margin-bottom: 20px; text-align: center; color: #073E98;}
.final-cta p {line-height: 1.8; margin-bottom: clamp(20px, 3vw, 25px); color: #4a5568; }
.final-cta .btn {display: table; margin: 0 auto;}
.final-cta-image {align-self: flex-end; padding-right: clamp(15px, 2.5vw, 20px);}
.final-cta-image img {display: block; margin: 0 auto; width: 60%; height: auto;} /* インラインの余白を消す */

/*　Contact Form */
.page-header{text-align: center; margin-top: 60px;  color: #073E98;}
.wpcf7.no-js{margin: 0 auto; max-width: clamp(400px, 85vw, 600px);}
.wpcf7-form input[type="submit"]{ margin:clamp(30px, 5vw, 40px) auto; width: clamp(150px, 25vw, 250px); display: block;}
.wpcf7-not-valid-tip {display: none;}
.wpcf7-form .wpcf7-submit,.wpcf7-form .wpcf7-submit:hover,.wpcf7-form input.wpcf7-submit,.wpcf7-form input.wpcf7-submit:hover {background:linear-gradient(to right, #E59809, #CE5629); color: #ffffff; border: none; border-radius: 5px; padding: 10px 32px; cursor: pointer; text-align: center;}
.wpcf7-form .wpcf7-submit:hover,.wpcf7-form input.wpcf7-submit:hover {opacity: 0.8; transform: translateY(-2px); color: #fff;} 
.wpcf7-form .wpcf7-submit {display: block; margin-top: 300px;} 
fieldset.hidden-fields-container {display: none;}
.wpcf7 form {max-width: 500px; margin: 0 auto; display: block;}
.wpcf7-form label {display: block; width: 100%; line-height: 1.66;}
.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form textarea {width: 100%; box-sizing: border-box; margin-bottom: 15px;  padding: clamp(8px, 1.4vw, 12px) clamp(10px, 2vw, 16px);}


/* レスポンシブ対応 s */
@media (max-width: 1150px) {
.concern-card {padding:40px 300px 50px 30px;}
.concern-item {margin-bottom: 12px; padding-left: 30px;}
.solution-box {padding: 22px; margin-top: -30px; margin-right: 250px; max-width: 450px;}
.solution-box p {line-height: 1.7;}
}

/* レスポンシブ対応 tab */
@media (max-width: 900px) {
.concern-card {padding:35px 250px 45px 10px;}
.solution-box {padding: 20px; margin-top: -25px; margin-right: 100px; max-width: 340px;}
.solution-box p {line-height: 1.6;}
}

/* レスポンシブ対応 sp */
@media (max-width: 576px) {
.fv-container {flex-direction: column; align-items: flex-start; margin-top: 20px;}
.fv-text {text-align: left; margin-top: 15px;}
.fv-subtitle {font-size: 20px;}
.fv-title {font-size: 34px; line-height: 1.3;}
.fv-title .highlight{font-size: 38px;}
.fv-image img  {margin: -30px 0 0 100px; max-width: 350px }
.fv-trust-1 {display: none;}
.fv-trust-2 {display: flex; justify-content: center; gap: clamp(10px, 1vw, 20px); padding: 30px 0;}
.fv-trust-2 img {width: 120px; height: auto;}
.concern-card {padding:30px 30px 40px 0;}
.solution-box {padding: 18px; margin-top: -15px; margin-right: 30px; max-width: 300px;}
.wpcf7 form {max-width: 400px;}
}

/* レスポンシブ対応 FV権威性 */
@media (min-width: 577px) {
.fv-trust-2 {display: none;}
}

/* レスポンシブ対応 最終CTAセクション */
@media (min-width: 1001px) {
.final-cta .container {display: flex; justify-content: space-between;}
.final-cta-content {padding-top: clamp(15px, 2.6vw, 40px); padding-bottom: clamp(25px, 4vw, 30px);  padding-left: clamp(20px, 3.5vw, 80px); padding-right: 0;}
.final-cta-image img {width: 80%; height: auto;}
}


