@charset "utf-8";
/* http://meyerweb.com/eric/tools/css/reset/
   v2.0 | 20110126
   License: none (public domain)
*/

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
	display: block;
}
body {
	line-height: 1;
	color: rgb(105, 104, 104);
	font-family: "Yu Mincho", "YuMincho", serif;
	width:100%;
	overflow-x: hidden !important;
}
ol, ul {
	list-style: none;
}
a {
    text-decoration: none !important;
    color: #212529 !important;
}
a:hover{
opacity:0.8;
}
blockquote, q {
	quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}
/* ==============================
ここから
============================== */
img {
	vertical-align: bottom;
}

/* ==============================
ページ全体ラッパー（max-width 500px 中央寄せ）
============================== */
.page-wrap {
	max-width: 500px;
	margin: 0 auto;
}

/* ==============================
画像セクション共通
============================== */
.section-img img {
	width: 100%;
	height: auto;
	display: block;
}

/* ==============================
CTA セクション
============================== */
.cta-section {
	background-color: #4ec6b0;
	padding: 50px 20px;
	text-align: center;
}
.cta-title {
	color: #fff;
	font-size: 32px;
	font-weight: bold;
	margin-bottom: 20px;
	line-height: 1.4;
}
.cta-subtitle {
	margin-bottom: 30px;
}
.cta-subtitle span {
	display: inline-block;
	color: #fff;
	font-size: 16px;
	border: 2px solid #fff;
	border-radius: 30px;
	padding: 8px 30px;
	letter-spacing: 0.05em;
}
.cta-buttons {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 16px;
	max-width: 420px;
	margin: 0 auto;
}
.cta-btn {
	display: flex;
	align-items: center;
	width: 100%;
	max-width: 400px;
	padding: 16px 24px;
	border-radius: 50px;
	font-size: 18px;
	font-weight: bold;
	text-decoration: none !important;
	color: #333 !important;
	position: relative;
	transition: opacity 0.3s;
	box-shadow: 0 4px 8px rgba(0,0,0,0.15);
}
.cta-btn:hover {
	opacity: 0.85;
}
.cta-btn--phone,
.cta-btn--mail {
	background: linear-gradient(to bottom, #ffe082, #f5c842);
}
.cta-btn--line {
	background: #06C755;
	color: #fff !important;
}
.cta-btn__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	margin-right: 12px;
	flex-shrink: 0;
}
.cta-btn__text {
	flex: 1;
	text-align: center;
}
.cta-btn__hand {
	margin-left: 8px;
	flex-shrink: 0;
	display: flex;
	align-items: center;
}
.cta-btn__hand img {
	width: 28px;
	height: auto;
}

/* ==============================
お問い合わせフォーム
============================== */
.form-section {
	background-color: #f9f9f6;
	padding: 50px 20px 60px;
	text-align: center;
}
.form-heading {
	font-size: 26px;
	font-weight: bold;
	color: #333;
	margin-bottom: 8px;
	line-height: 1.4;
}
.form-subtitle {
	font-size: 14px;
	color: #888;
	margin-bottom: 30px;
}
.form-wrap {
	max-width: 460px;
	margin: 0 auto;
	text-align: left;
}
.cf7-field {
	margin-bottom: 20px;
}
.cf7-field label {
	display: block;
	font-size: 14px;
	font-weight: bold;
	color: #333;
	margin-bottom: 6px;
}
.cf7-required {
	font-size: 11px;
	color: #fff;
	background-color: #d4835e;
	padding: 2px 8px;
	border-radius: 3px;
	margin-left: 6px;
	font-weight: normal;
}
.cf7-field input[type="text"],
.cf7-field input[type="tel"],
.cf7-field input[type="email"],
.cf7-field textarea {
	width: 100% !important;
	padding: 12px 14px !important;
	border: 1px solid #ccc !important;
	border-radius: 8px !important;
	font-size: 15px !important;
	font-family: "Yu Mincho", "YuMincho", serif !important;
	background-color: #fff !important;
	box-sizing: border-box !important;
	transition: border-color 0.3s !important;
}
.cf7-field input:focus,
.cf7-field textarea:focus {
	border-color: #4eb8a0 !important;
	outline: none !important;
}
.cf7-field textarea {
	height: 140px !important;
	resize: vertical !important;
}
.cf7-submit {
	text-align: center;
	margin-top: 28px;
}
.cf7-submit input[type="submit"] {
	background-color: #4eb8a0 !important;
	color: #fff !important;
	border: none !important;
	padding: 14px 60px !important;
	font-size: 16px !important;
	font-weight: bold !important;
	font-family: "Yu Mincho", "YuMincho", serif !important;
	border-radius: 50px !important;
	cursor: pointer !important;
	transition: opacity 0.3s !important;
	box-shadow: 0 4px 8px rgba(0,0,0,0.15) !important;
}
.cf7-submit input[type="submit"]:hover {
	opacity: 0.85 !important;
}
.wpcf7-response-output {
	text-align: center !important;
	font-size: 14px !important;
	margin-top: 16px !important;
}

/* ==============================
FAQ セクション
============================== */
.faq-section {
	background-color: #e8ede9;
	padding: 50px 16px 60px;
	text-align: center;
}
.faq-icon {
	width: 40px;
	height: 40px;
	background-color: #8baf9a;
	color: #fff;
	font-size: 22px;
	font-weight: bold;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 12px;
}
.faq-heading {
	font-size: 24px;
	font-weight: bold;
	color: #333;
	margin-bottom: 28px;
	line-height: 1.4;
}
.faq-list {
	max-width: 500px;
	margin: 0 auto;
	text-align: left;
}
.faq-item {
	background-color: #fff;
	border-radius: 12px;
	margin-bottom: 14px;
	overflow: hidden;
}
.faq-question {
	display: flex;
	align-items: center;
	padding: 16px 16px 12px;
	cursor: pointer;
}
.faq-question:hover {
	opacity: 0.85;
}
.faq-label {
	width: 32px;
	height: 32px;
	min-width: 32px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 16px;
	font-weight: bold;
	color: #fff;
	flex-shrink: 0;
}
.faq-label--q {
	background-color: #4eb8a0;
}
.faq-label--a {
	background-color: #d4835e;
}
.faq-question__text {
	flex: 1;
	margin-left: 12px;
	font-size: 14px;
	font-weight: bold;
	color: #333;
	line-height: 1.5;
}
.faq-arrow {
	font-size: 10px;
	color: #aaa;
	margin-left: 8px;
	transition: transform 0.3s;
	flex-shrink: 0;
}
.faq-item.is-open .faq-arrow {
	transform: rotate(180deg);
}
.faq-answer {
	display: none;
	padding: 0 16px 16px;
}
.faq-item.is-open .faq-answer {
	display: flex;
	align-items: flex-start;
}
.faq-answer__text {
	flex: 1;
	margin-left: 12px;
	font-size: 13px;
	color: #666;
	line-height: 1.8;
}
