@charset "UTF-8";

/*
Theme Name: MY THEME 
Author: Zenshin
Description: オリジナルテーマ
Version: 1.0
*/
img {
	max-width: 100%;
	height: auto;
	vertical-align: bottom;
}

.img-full img {
	width: 100%;
	height: auto;
	text-align: center;
	vertical-align: bottom;
}


@media screen and (max-width: 780px) {
	.flex_res {
		flex-direction: column;
		align-items: center;
	}
}

.flex_hanyo {
	display: flex;
	justify-content: center;
}

.flex {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.flex-center {
	display: flex;
	justify-content: center;
}

.flex-base {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	margin-bottom: 3%;
}

.alignleft {
	float: left;
	margin-left: 0;
	margin-right: 1em;
}

.alignright {
	float: right;
	margin-left: 1em;
	margin-right: 0;
}

.aligncenter {
	margin-left: auto;
	margin-right: auto;
}

.wp-block-categories.aligncenter,
.wp-block-latest-posts.aligncenter,
.wp-block-archives.aligncenter,
.wp-block-tag-cloud.aligncenter,
.wp-block-latest-comments.aligncenter,
.wp-block-rss.aligncenter {
	text-align: center;
}

figure {
	margin-left: 0;
	margin-right: 0;
}

body {
	box-sizing: border-box;
}

body *,
body *::before,
body *::after {
	box-sizing: inherit;
}

ul {
	padding-inline-start: 1rem;
}

pre {
	font-family: unset;
}

/* 変数 */
:root {
	--f1: 2.44em;
	/* 39.04px */
	--f2: 1.95em;
	/* 31.2px */
	--f3: 1.56em;
	/* 24.96px */
	--f4: 1.25em;
	/* 20px */
	--f5: 1em;
	/* 16px */
	--f6: 0.8em;
	/* 12.8px */

	--f7: 0.66em;
	/* 12.8px */

	--basecolor: #63a211;
	/* 基本色 */
	--gradient: linear-gradient(81.7deg, rgba(34, 126, 34, 1) 8.1%, rgba(99, 162, 17, 1) 86.5%);

	--myfont: "Noto Sans JP", sans-serif;
	--myw: 720px;
	/*標準幅*/
}


/* フォント */
body {
	font-family: var(--myfont);
	font-size: 21px;
}

p {
	line-height: 1.8;
	font-size: var(--f5);
}


h1 {
	font-size: var(--f1);
	font-weight: 300;
}

h2 {
	font-size: var(--f3);
	margin-block-start: 0;
}

h3 {
	font-size: var(--f3);
}

h4 {
	font-size: var(--f4);
}

h5 {
	font-size: var(--f5);
}

h6 {
	font-size: var(--f6);
}

.text_item_double_L {
	width: 55%;
	padding: 30px 0;
	margin: 0 auto;
}

.text_item_double_L p {
	font-size: 18px;
}

.text_img_double_R {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 45%;
	padding: 30px 0;
	margin-left: 8%;
}

.text_img_double_R img {
	vertical-align: middle;
}

.title_wrapper {
	margin-right: 50%;
}

.title_img {
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 30px 0;
}

.top_assist_text {
	font-size: 14px;
	/* margin-top: 35px; */
}

@media screen and (max-width: 780px) {
	.text_item_double_L {
		width: 100%;
		display: flex;
		flex-direction: column;
		/* 要素を縦方向に並べる */
		justify-content: center;
		/* 横方向（左右方向）の中央揃え */
		align-items: center;
		/* 縦方向（上下方向）の中央揃え */
		padding: 0;
	}

	.text_img_double_R {
		width: 70%;
		margin-left: 0;
		margin-bottom: 10px;
	}

	.title_img {
		width: 70%;
		margin: 20px 0 30px 0;
	}

	.text_item_double_L p {
		font-size: 14px;
	}

	.title_wrapper {
		width: 100%;
		display: flex;
		flex-direction: column;
		/* 要素を縦方向に並べる */
		justify-content: center;
		/* 横方向（左右方向）の中央揃え */
		align-items: center;
		/* 縦方向（上下方向）の中央揃え */
	}

	.osirase_img {
		width: 50%;
	}
}


/* 横幅 */
body {
	margin: 0;
}


.alignfull {
	width: 100%;
	height: auto;
	overflow: hidden;
}

.alignwide {
	margin-top: 5%;
	padding-left: 25%;
	padding-right: 25%;
}

/*スマホ*/
@media (max-width: 600px) {
	.alignwide {
		padding-left: 20px;
		padding-right: 20px;
	}
}

@media (min-width: 1320px) {}


/*配置*/
.center {
	text-align: center;
}

.space-between {
	justify-content: space-between;
}

/* ポジション */
.relative {
	position: relative;
}

.top {
	vertical-align: top;
}

/*リンク*/
a {
	color: inherit;
	text-decoration: none;
}

a:hover {
	color: inherit;
	opacity: 0.7;
}

/*色*/
.white {
	color: white;
}

.red {
	color: red;
}

.green {
	color: green;
}

.grey {
	background-color: #F2F2F2;
	padding-bottom: 5%;
}

.white-bg {
	background-color: white;
}

/*スマホ限定/PC限定*/
/*フッターの画像切替のみに使用 bootstrapのxlに対応*/

@media only screen and (max-width:768px) {
	.sp-md {
		display: block;
	}

}

/*-----マージン共通-----*/
.margin_hanyo {
	margin-top: 120px;
}

.margin_hanyo_sub2 {
	margin-top: 100px;
}

.margin_right_pc {
	margin-right: 20px;
}

.margin_hanyo_bottom {
	margin-bottom: 5%;
}

@media screen and (max-width: 780px) {
	.margin_hanyo {
		margin-top: 50px;
	}

	.margin_hanyo_sub {
		margin-top: 10px;
	}

	.margin_hanyo_sub2 {
		margin-top: 50px;
	}

	.margin_top_res {
		margin-top: 15px;
	}

	.margin_right_pc {
		margin-right: 0;
	}
}

p {
	font-size: 21px;
}

/* ベーシックプラン用。汎用CSS */
/* width指定 */
.w-10 {
	width: 10%
}

.w-15 {
	width: 15%
}

.w-20 {
	width: 20%
}

.w-25 {
	width: 25%
}

.w-30 {
	width: 30%
}

.w-33 {
	width: 33%
}

/* flexの3等分用 */
.w-40 {
	width: 40%
}

.w-45 {
	width: 45%
}

.w-48 {
	width: 48%
}

/* flexの2等分用 */
.w-50 {
	width: 50%
}

.w-60 {
	width: 60%
}

.w-65 {
	width: 65%
}

/* flexの2:1の比率用 */
.w-70 {
	width: 70%
}

.w-75 {
	width: 75%
}

.w-80 {
	width: 80%
}

/* 基本のサイズ */
.w-90 {
	width: 90%
}

.w-95 {
	width: 95%
}

.w-100 {
	width: 100%
}

.w-fit {
	width: fit-content
}

/* 余白 */
.p-10 {
	padding: 10px
}

.p-15 {
	padding: 15px
}

.p-20 {
	padding: 20px
}

.p-30 {
	padding: 30px
}

.p-60 {
	padding: 60px
}

/* flexなど位置系 */
.flex-center {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 2%
}

.flex-between {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.column {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 2%
}

.flex-start {
	display: flex;
	justify-content: flex-start;
	align-items: center;
	gap: 2%
}

.flex-end {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	gap: 2%
}

.right {
	text-align: right;
}

.center {
	text-align: center;
}

.left {
	text-align: left;
}

/* font-size汎用 */
.font14 {
	font-size: 14px
}

.font16 {
	font-size: 16px
}

.font18 {
	font-size: 18px
}

.font20 {
	font-size: 20px
}

.font24 {
	font-size: 24px
}

.font30 {
	font-size: 30px;
	font-weight: bold
}

.font40 {
	font-size: 40px;
	font-weight: bold
}

/* その他汎用 marginやpaddingそのほか */
.style-none {
	list-style: none;
	padding: 0;
}

.bold {
	font-weight: bold
}

.m-auto {
	margin: auto
}

.m-0 {
	margin: 0
}

.m-l-3 {
	margin-left: 3%
}

.m-l-5 {
	margin-left: 5%
}

.m-t-5 {
	margin-top: 5%;
}

.p-l-8 {
	padding: 0 0 0 8%;
}

.p-l-15px {
	padding-left: 15px;
}

.p-b-5 {
	padding-bottom: 5px;
}

.p-t-5 {
	padding-top: 5px;
}

.vertical-top {
	vertical-align: top;
}

.p-y-10 {
	padding: 10px 0;
}

/* レスポ化用汎用 */
@media only screen and (min-width: 769px) {
	.sp {
		display: none
	}

	/* SP表示（769px未満で表示） */
}

@media only screen and (max-width: 768px) {
	.pc {
		display: none
	}

	/* PC表示（768px以上で表示） */
	.sp-column {
		display: flex;
		flex-direction: column;
		align-items: center;
	}

	.hamburger_menu_btn_wrap.sp {
		display: block;
	}

	.sp-w-70 {
		width: 70%;
	}
}

@media only screen and (min-width: 561px) {
	.sm {
		display: none
	}

	/* スマホ表示（561px未満で表示） */
}

@media only screen and (max-width: 560px) {
	.extra {
		display: none
	}

	/* それ以外表示（560px以上で表示） */
	.sm-column {
		display: flex;
		flex-direction: column;
		align-items: center;
	}

	.sm-w-90 {
		width: 90%;
	}
}

/* header */
.myhead {
	padding: 2% 0;
	background-color: #f0f8ff;
	box-shadow: 1px 2px 9px rgba(0, 0, 0, 0.4)
}

/*-----ハンバーガーメニュー-----*/
.hamburger_menu_btn_wrap {
	display: none;
	margin-right: 1.4%;
	margin-left: auto;
	position: fixed;
	right: 0;
	top: 15%;
}

.hamburger_menu_btn {
	width: 30px;
	height: 24px;
	position: relative;
	cursor: pointer;
	z-index: 1001;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}

.hamburger_menu_btn span {
	display: block;
	width: 100%;
	height: 3px;
	background-color: #0a4bc1;
	border-radius: 2px;
	transition: all 0.3s ease;
}

.hamburger_menu_btn.active span:nth-child(1) {
	transform: translateY(10.5px) rotate(45deg);
}

.hamburger_menu_btn.active span:nth-child(2) {
	opacity: 0;
}

.hamburger_menu_btn.active span:nth-child(3) {
	transform: translateY(-10.5px) rotate(-45deg);
}

.hamburger_window {
	position: fixed;
	top: 0;
	right: -300px;
	width: 300px;
	height: 100vh;
	background-color: rgba(30, 30, 30, 0.95);
	padding-top: 80px;
	box-sizing: border-box;
	transition: right 0.5s ease;
	z-index: 1000;
	visibility: hidden;
	overflow-y: auto;
}

.hamburger_window.open {
	right: 0;
	visibility: visible;
}

.hamburger_list_item {
	list-style: none;
	padding: 0;
	margin: 0;
}

.hamburger_list_item li {
	border-bottom: 1px solid rgba(255, 255, 255, 0.2);
}

.hamburger_list_item li:first-child {
	border-top: 1px solid rgba(255, 255, 255, 0.2);
}

.hamburger_list_item li a {
	display: block;
	padding: 15px 20px;
	color: white;
	text-decoration: none;
	font-size: 1.1rem;
	transition: background-color 0.3s ease;
}

.hamburger_list_item li a:hover {
	background-color: rgba(255, 255, 255, 0.1);
}

.hamburger_background {
	position: fixed;
	top: 0;
	left: 0;
	width: 100vw;
	height: 100vh;
	background-color: rgba(0, 0, 0, 0.5);
	z-index: 999;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.5s ease;
}

.hamburger_background.open {
	opacity: 1;
	visibility: visible;
}

/* footer */
.myfoot {
	background-color: #0071bc;
	padding: 20px 0 0;
}

.sp-li {
	background-color: #fff;
	color: #0071bc;
	margin-bottom: 10px;
	width: 100%;
	text-align: center;
	font-weight: bold
}

@media only screen and (max-width: 850px) {
	.c-width {
		width: 90% !important;
		margin: auto;
	}

	.pc-850 {
		display: none !important;
	}
}

@media only screen and (min-width: 851px) {
	.sp-850 {
		display: none !important;
	}
}

/* front-page */
.bg-sky {
	background-color: #f0f8ff
}

.bg-blue {
	background-color: #0071bc
}

.bg-white {
	background-color: #fff
}

.font-blue {
	color: #0071bc
}

.arrow-button {
	background-color: #3a75bb;
	color: #fff;
	width: fit-content;
	padding: 1px 6px;
	border-radius: 100%;
}

.arrow-button-wh {
	background-color: #fff;
	color: #3a75bb;
	width: fit-content;
	padding: 1px 6px;
	border-radius: 100%;
}

.b-tandb-wh {
	border-top: 1px solid #fff;
	border-bottom: 1px solid #fff;
}

/* お知らせ欄 */
.l-font {
	font-size: 120px;
	font-weight: bold;
	color: white;
	text-align: center;
	margin: 0;
	line-height: 1.0;
}

.s-font {
	font-size: 18px;
	color: white;
	text-align: right;
	margin-right: 115px;
}

@media only screen and (max-width: 900px) {
	.pc-900 {
		display: none !important;
	}

	.sp-900-column {
		flex-direction: column;
	}

	.sp-900-w-100 {
		width: 100%;
	}

	.sp-900-w-90 {
		width: 90%;
	}

	.l-font {
		font-size: 80px;
	}

	.s-font {
		text-align: center;
		margin-right: 0;
	}
}

@media only screen and (min-width: 901px) {
	.sp-900 {
		display: none !important;
	}
}

/* overview */
.font-pale {
	color: #2e3192;
}

.b-b-blue {
	border-bottom: 1px solid #29abe2;
	font-weight: normal
}

.b-b-ash {
	border-bottom: 1px solid #ccc
}

.normal {
	font-weight: normal
}

/* contact */
.cform {
	width: 100%
}

.cform tbody {
	width: 100%
}

.cform tr {
	width: 100%;
}

.bg-form {
	background-color: #0071bc;
	color: #fff;
	padding: 10px 25px 10px 25px;
}

.bg-form p,
.border-form p {
	margin: 0;
	font-size: 18px;
}

.b-b-black {
	border-bottom: 1px solid #000
}

.required-srt {
	background-color: #c1272d;
	padding: 2px 15px;
	border-radius: 12px;
	font-size: 16px !important;
}

.border-form input[type="text"],
.border-form textarea {
	width: 90%;
	margin: 10px 0 10px 4%;
}

.border-form input[type="tel"],
.border-form input[type="email"] {
	width: 60%;
	margin: 10px 0 10px 4%;
}

.zip-code {
	width: 40%
}

.short input[type="text"] {
	width: 80% !important;
	margin: 10px 0 10px 11%
}

.short {
	display: flex;
	justify-content: flex-start;
	gap: 15px;
	align-items: center;
}

.credential {
	font-size: 14px;
	margin: 0;
}

.a-tag {
	color: #29abe2
}

.a-tag:hover {
	opacity: 0.6;
	color: #0071bc;
}

.sending-button {
	background: url('./image/contact/bg-but.png');
	background-repeat: no-repeat;
	background-position: center bottom;
	padding: 40px 0 30px;
	background-size: 40%;
}

.sending-button p {
	margin: 0;
	font-size: 24px;
	text-align: center;
}

.sending-button input {
	color: #fff;
	background-color: #0071bc;
	border: none;
	box-shadow: none;
}

.wpcf7-spinner {
	display: none !important;
}

@media only screen and (max-width: 1200px) and (min-width: 769px) {
	.zip-code {
		width: 60%
	}

	.short input[type="text"] {
		width: 80% !important;
		margin: 10px 0 10px 12%
	}
}

@media only screen and (max-width: 768px) and (min-width: 561px) {
	.sp-w-90 {
		width: 90%
	}

	.cform tr {
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
	}

	.bg-form {
		width: 100%;
	}

	.border-form {
		width: 100%;
		text-align: center;
	}

	.border-form input[type="text"],
	.border-form textarea {
		width: 90%;
		margin: 10px auto;
	}

	.border-form input[type="tel"],
	.border-form input[type="email"] {
		width: 90%;
		margin: 10px auto;
	}

	.zip-code {
		width: 100%
	}

	.short input[type="text"] {
		width: 90% !important;
		margin: 10px auto
	}

	.short {
		flex-direction: column;
	}

	.credential {
		width: 90%;
	}
}

@media only screen and (max-width: 560px) {
	.sp-w-90 {
		width: 95%
	}

	.cform tr {
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
	}

	.bg-form {
		width: 100%;
	}

	.border-form {
		width: 100%;
		text-align: center;
	}

	.border-form input[type="text"],
	.border-form textarea {
		width: 90%;
		margin: 10px auto;
	}

	.border-form input[type="tel"],
	.border-form input[type="email"] {
		width: 90%;
		margin: 10px auto;
	}

	.zip-code {
		width: 100%
	}

	.short input[type="text"] {
		width: 90% !important;
		margin: 10px auto
	}

	.short {
		flex-direction: column;
	}

	.credential {
		width: 90%;
	}
}

/* recruit */
.bef-hash {
	margin-left: 8%;
	position: relative;
}

.bef-hash::before {
	width: 3.5vw;
	height: 2px;
	background-color: #0071bc;
	position: absolute;
	content: '';
	top: 50%;
	left: -8.7%;
}

.f-ash {
	color: #999;
}

.table-pad {
	padding-top: 15px;
	padding-bottom: 15px;
}

@media only screen and (max-width: 560px) {
	.sm-bg-ash {
		background-color: #999;
	}

	.sm-f-white {
		color: #fff;
	}

	.sm-w-100 {
		width: 100% !important;
		text-align: center !important;
	}
}

/* equip */
.bg-ash {
	background-color: #ccc;
}

/* products */
.bef-half-square {
	position: relative;
	margin-left: 35px;
}

.bef-half-square::before {
	position: absolute;
	content: '';
	width: 15px;
	height: 30px;
	top: 25%;
	left: -30px;
	background-color: #0071bc;
}

/* sending-button */
.send-btn-wrap {
	position: relative;
}

.send-btn-wrap input[type="submit"] {
	position: absolute;
	inset: 0;
	opacity: 0;
	z-index: 2;
}

.fake-btn {
	display: block;
	padding: 22px 70px 22px 40px;
	border-radius: 999px;
	background: #0071bc;
	color: #fff;
	position: relative;
	width: 25%;
	margin: auto;
	text-align: center;
}

.fake-btn .arrow {
	position: absolute;
	right: 18px;
	top: 50%;
	transform: translateY(-50%);
	background: #fff;
	color: #0071bc;
	width: 42px;
	height: 42px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 25px;
}

@media only screen and (max-width: 1300px) and (min-width: 1000px) {
	.fake-btn {
		width: 50%;
	}
}

@media only screen and (max-width: 1000px) and (min-width: 700px) {
	.fake-btn {
		width: 60%;
	}
}

@media only screen and (max-width: 700px) and (min-width: 500px) {
	.fake-btn {
		width: 70%;
	}
}

@media only screen and (max-width: 500px) {
	.fake-btn {
		width: 80%;
	}
}

/* counsel room */
.counsel-layout {
	min-height: 100vh;
	display: flex;
	flex-direction: column;
	background:
		radial-gradient(circle at top left, rgba(196, 247, 225, 0.45), transparent 32%),
		linear-gradient(180deg, #ffffff 0%, #f8fffc 100%);
	color: #1f2937;
}

.counsel-layout a {
	text-decoration: none;
}

.counsel-shell {
	width: min(1120px, calc(100% - 32px));
	margin: 0 auto;
}

.counsel-narrow {
	width: min(860px, 100%);
}

.counsel-center {
	text-align: center;
}

.counsel-front-page {
	flex: 1;
}

.counsel-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 14px 28px;
	border-radius: 999px;
	font-weight: 700;
	transition: transform 0.25s ease, box-shadow 0.25s ease, background-color 0.25s ease, color 0.25s ease;
}

.counsel-button:hover {
	transform: translateY(-2px);
}

.counsel-button--primary {
	background: linear-gradient(135deg, #19b37c 0%, #08996b 100%);
	color: #fff;
	box-shadow: 0 14px 30px rgba(8, 153, 107, 0.18);
}

.counsel-button--primary:hover {
	color: #fff;
	box-shadow: 0 18px 34px rgba(8, 153, 107, 0.24);
}

.counsel-button--secondary {
	background: #fff;
	color: #0f766e;
	border: 1px solid rgba(15, 118, 110, 0.18);
	box-shadow: 0 12px 24px rgba(15, 23, 42, 0.06);
}

.counsel-button--secondary:hover {
	color: #0f766e;
	background: #f0fdfa;
}

.counsel-header {
	position: sticky;
	top: 0;
	z-index: 50;
	background: rgba(255, 255, 255, 0.86);
	backdrop-filter: blur(14px);
	border-bottom: 1px solid rgba(16, 185, 129, 0.12);
}

.counsel-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
	min-height: 88px;
}

.counsel-header__brand-link {
	display: flex;
	flex-direction: column;
	line-height: 1.35;
}

.counsel-header__title {
	font-size: clamp(1.2rem, 1rem + 0.7vw, 1.6rem);
	font-weight: 700;
	color: #059669;
	letter-spacing: 0.02em;
}

.counsel-header__tag {
	font-size: 0.78rem;
	color: #6b7280;
}

.counsel-header__nav {
	display: flex;
	align-items: center;
	gap: 24px;
}

.counsel-header__menu {
	display: flex;
	align-items: center;
	gap: 24px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.counsel-header__menu a {
	font-weight: 600;
	color: #4b5563;
	font-size: 16px;
}

.counsel-header__menu a:hover {
	color: #059669;
}

.counsel-header__toggle {
	display: none;
	width: 52px;
	height: 52px;
	padding: 0;
	border: 0;
	border-radius: 50%;
	background: #f0fdf4;
}

.counsel-header__toggle span {
	display: block;
	width: 22px;
	height: 2px;
	margin: 5px auto;
	background: #047857;
	border-radius: 999px;
	transition: transform 0.2s ease, opacity 0.2s ease;
	transform-origin: center;
}

.counsel-header__toggle[aria-expanded="true"] span:nth-child(1) {
	transform: translateY(7px) rotate(45deg);
}

.counsel-header__toggle[aria-expanded="true"] span:nth-child(2) {
	opacity: 0;
}

.counsel-header__toggle[aria-expanded="true"] span:nth-child(3) {
	transform: translateY(-7px) rotate(-45deg);
}

.counsel-header__mobile {
	padding: 0 0 20px;
	border-top: 1px solid rgba(16, 185, 129, 0.12);
	background: rgba(255, 255, 255, 0.98);
}

.counsel-header__mobile-list {
	list-style: none;
	padding: 12px 0 0;
	margin: 0;
}

.counsel-header__mobile-list li+li {
	border-top: 1px solid #ecfdf5;
}

.counsel-header__mobile-list a {
	display: block;
	padding: 16px 0;
	color: #4b5563;
	font-weight: 600;
}

.counsel-header__mobile-cta {
	width: 100%;
	margin-top: 20px;
}

.counsel-hero {
	position: relative;
	min-height: 100vh;
	display: flex;
	align-items: center;
	overflow: hidden;
}

/* スライド */
.counsel-hero__slides {
	position: absolute;
	inset: 0;
}

.counsel-hero__slide {
	position: absolute;
	inset: 0;
	opacity: 0;
	transform: scale(1.04);
	transition: opacity 1s ease, transform 6s ease;
}

/* active */
.counsel-hero__slide.is-active {
	opacity: 1;
	transform: scale(1);
}

/* 背景画像 */
.counsel-hero__slide:not(.counsel-hero__slide--image) {
	background-size: cover;
	background-position: center;
}

/* 1枚目 img */
.counsel-hero__slide--image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	/* ★これ追加 */
	object-position: center bottom;
}

/* overlay */
.counsel-hero__overlay {
	position: absolute;
	inset: 0;
	background:
		linear-gradient(90deg, rgba(255, 255, 255, 0.92) 0%, rgba(255, 255, 255, 0.72) 45%, rgba(255, 255, 255, 0.1) 100%),
		linear-gradient(180deg, rgba(255, 255, 255, 0.08) 0%, rgba(255, 255, 255, 0.28) 100%);
	z-index: 1;

	transition: opacity .6s ease;
}

/* content */
.counsel-hero__content {
	position: relative;
	z-index: 2;
	width: 100%;
	padding: 90px 0;
	transition: opacity .6s ease;
}

/* dots */
.counsel-hero__dots {
	position: absolute;
	z-index: 3;
	bottom: 30px;
	left: 50%;
	transform: translateX(-50%);
	transition: opacity .6s ease;
}

/* 1枚目だけ非表示状態 */
.counsel-hero.is-first .counsel-hero__overlay,
.counsel-hero.is-first .counsel-hero__content,
.counsel-hero.is-first .counsel-hero__dots {
	opacity: 0;
	pointer-events: none;
}

.counsel-hero__copy {
	margin-left: 20vw;
}

.counsel-hero__label {
	display: inline-block;
	padding: 10px 18px;
	margin-bottom: 22px;
	border-radius: 999px;
	background: rgba(16, 185, 129, 0.14);
	color: #047857;
	font-size: 0.95rem;
	font-weight: 700;
}

.counsel-hero h1 {
	margin: 0;
	font-size: clamp(2.4rem, 1.7rem + 2vw, 4.4rem);
	line-height: 1.3;
	letter-spacing: 0.02em;
}

.counsel-hero p {
	margin: 24px 0 0;
	font-size: clamp(1rem, 0.9rem + 0.35vw, 1.25rem);
	line-height: 1.9;
	color: #4b5563;
}

.counsel-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
	margin-top: 34px;
}

.counsel-hero__dots {
	position: absolute;
	left: 50%;
	bottom: 30px;
	z-index: 3;
	display: flex;
	gap: 10px;
	transform: translateX(-50%);
}

.counsel-hero__dots button {
	width: 11px;
	height: 11px;
	padding: 0;
	border: 0;
	border-radius: 50%;
	background: rgba(16, 185, 129, 0.35);
	transition: transform 0.2s ease, background-color 0.2s ease;
}

.counsel-hero__dots button.is-active {
	background: #10b981;
	transform: scale(1.25);
}

.counsel-section {
	padding: 104px 0;
}

.counsel-section--white {
	background: #fff;
}

.counsel-section--tint {
	background: linear-gradient(180deg, rgba(236, 253, 245, 0.85) 0%, rgba(239, 246, 255, 0.7) 100%);
}

.counsel-section--accent {
	background: rgba(236, 253, 245, 0.66);
}

.counsel-section--contact {
	position: relative;
	background:
		radial-gradient(circle at top left, rgba(16, 185, 129, 0.14), transparent 26%),
		radial-gradient(circle at bottom right, rgba(96, 165, 250, 0.14), transparent 30%),
		#f8fafc;
}

.counsel-section__heading {
	text-align: center;
	margin-bottom: 52px;
}

.counsel-section__heading h2,
.counsel-center h2 {
	margin: 0;
	font-size: clamp(2rem, 1.5rem + 1vw, 3rem);
	line-height: 1.35;
}

.counsel-section__heading p,
.counsel-center p {
	margin: 16px auto 0;
	max-width: 760px;
	line-height: 1.9;
	color: #6b7280;
}

.counsel-grid {
	display: grid;
	gap: 24px;
}

.counsel-grid--two {
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.counsel-grid--three {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.counsel-grid--four {
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

.counsel-card {
	padding: 30px;
	border-radius: 28px;
}

.counsel-card--soft {
	background: rgba(236, 253, 245, 0.7);
	border: 1px solid rgba(16, 185, 129, 0.12);
	box-shadow: 0 14px 30px rgba(15, 23, 42, 0.04);
}

.counsel-card--soft p {
	margin: 0;
	font-size: 1.05rem;
	line-height: 1.85;
}

.counsel-message {
	margin: 36px 0 0;
	text-align: center;
	font-size: clamp(1.2rem, 1rem + 0.5vw, 1.7rem);
	font-weight: 700;
	line-height: 1.8;
	color: #047857;
}

.counsel-icon-card {
	padding: 28px 20px;
	background: #fff;
	border-radius: 26px;
	text-align: center;
	box-shadow: 0 14px 30px rgba(15, 23, 42, 0.05);
	border: 1px solid rgba(16, 185, 129, 0.1);
}

.counsel-icon-card span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 60px;
	height: 60px;
	margin-bottom: 18px;
	border-radius: 22px;
	background: rgba(16, 185, 129, 0.12);
	color: #059669;
	font-size: 1.05rem;
	font-weight: 700;
}

.counsel-icon-card h3 {
	margin: 0;
	font-size: 1rem;
}

.counsel-steps {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 20px;
}

.counsel-step {
	padding: 28px 24px;
	border-radius: 28px;
	background: #fff;
	border: 1px solid #e5e7eb;
	box-shadow: 0 10px 24px rgba(15, 23, 42, 0.05);
}

.counsel-step span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	margin-bottom: 18px;
	border-radius: 18px;
	background: #ecfdf5;
	color: #059669;
	font-weight: 700;
}

.counsel-step p {
	margin: 0;
	line-height: 1.85;
	font-size: 14px;
}

@media only screen and (max-width: 767px) {
	.counsel-step p {
		font-size: 18px;
	}
}

.counsel-voices {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 24px;
}

.counsel-voice {
	margin: 0;
	background: #fff;
	border-radius: 28px;
	box-shadow: 0 14px 28px rgba(15, 23, 42, 0.04);
	border: 1px solid rgba(16, 185, 129, 0.1);
	overflow: hidden;
	transition: box-shadow 0.25s ease, border-color 0.25s ease, transform 0.25s ease;
}

.counsel-voice:hover {
	transform: translateY(-2px);
	box-shadow: 0 18px 34px rgba(15, 23, 42, 0.07);
	border-color: rgba(16, 185, 129, 0.2);
}

.counsel-voice.is-open {
	border-color: rgba(16, 185, 129, 0.35);
	box-shadow: 0 20px 36px rgba(16, 185, 129, 0.09);
}

.counsel-voice__toggle {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 18px;
	align-items: stretch;
	column-gap: 18px;
	width: 100%;
	padding: 28px;
	border: 0;
	background: #fff;
	text-align: left;
	cursor: pointer;
}

.counsel-voice__summary {
	min-width: 0;
}

.counsel-voice__summary p {
	margin: 0;
	line-height: 1.9;
}

.counsel-voice__summary--fixed {
	display: flex;
	flex-direction: column;
	min-height: 100%;
}

.counsel-voice__summary cite {
	display: block;
	margin-top: auto;
	padding-top: 18px;
	font-style: normal;
	font-weight: 700;
	color: #059669;
}

.counsel-voice__icon {
	position: relative;
	width: 18px;
	height: 18px;
	flex-shrink: 0;
	align-self: end;
	margin-top: auto;
}

.counsel-voice__icon::before,
.counsel-voice__icon::after {
	content: "";
	position: absolute;
	top: 8px;
	left: 0;
	width: 18px;
	height: 2px;
	background: #10b981;
	border-radius: 999px;
	transition: transform 0.25s ease, opacity 0.25s ease;
}

.counsel-voice__icon::after {
	transform: rotate(90deg);
}

.counsel-voice.is-open .counsel-voice__icon::after {
	opacity: 0;
	transform: rotate(90deg) scaleX(0.2);
}

.counsel-voice__detail {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.35s ease;
}

.counsel-voice__detail p {
	margin: 0;
	padding: 0 28px 28px;
	font-size: 16px;
	line-height: 1.95;
	color: #4b5563;
}

.counsel-contact {
	max-width: 950px;
	margin: 0 auto;
	padding: 56px 42px;
	border-radius: 36px;
	background: rgba(255, 255, 255, 0.9);
	box-shadow: 0 20px 40px rgba(15, 23, 42, 0.06);
	text-align: center;
}

.counsel-contact h2 {
	margin: 0;
	font-size: clamp(2rem, 1.5rem + 1vw, 3rem);
	line-height: 1.35;
}

.counsel-contact p {
	margin: 18px 0 0;
	line-height: 1.9;
	color: #6b7280;
}

.counsel-contact__actions {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 20px;
	margin-top: 34px;
}

.counsel-contact__card {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 10px;
	padding: 28px;
	border-radius: 28px;
	background: #fff;
	border: 2px solid rgba(5, 150, 105, 0.14);
	color: #1f2937;
	box-shadow: 0 14px 28px rgba(15, 23, 42, 0.04);
	transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

.counsel-contact__card:hover {
	transform: translateY(-4px);
	border-color: rgba(5, 150, 105, 0.4);
	box-shadow: 0 20px 38px rgba(15, 23, 42, 0.08);
	color: #1f2937;
}

.counsel-contact__card--line {
	border-color: rgba(0, 195, 0, 0.18);
}

.counsel-contact__card strong {
	font-size: 1.2rem;
}

.counsel-contact__card span {
	line-height: 1.75;
	color: #6b7280;
}

.counsel-footer {
	padding: 70px 0 0;
	background: rgba(236, 253, 245, 0.62);
	border-top: 1px solid rgba(16, 185, 129, 0.12);
}

.counsel-footer__grid {
	display: grid;
	grid-template-columns: 1.2fr 0.8fr 0.8fr;
	gap: 40px;
}

.counsel-footer__block h3,
.counsel-footer__block h4 {
	margin: 0 0 18px;
}

.counsel-footer__block h3 {
	font-size: 1.4rem;
}

.counsel-footer__block h4 {
	font-size: 0.9rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: #9ca3af;
}

.counsel-footer__sub {
	margin: 0 0 18px;
	color: #6b7280;
}

.counsel-footer__text {
	margin: 0;
	line-height: 1.9;
	color: #4b5563;
}

.counsel-footer__links {
	list-style: none;
	margin: 0;
	padding: 0;
}

.counsel-footer__links li+li {
	margin-top: 16px;
}

.counsel-footer__links a,
.counsel-footer__links span {
	color: #4b5563;
}

.counsel-footer__links a:hover {
	color: #059669;
}

.counsel-footer__bottom {
	margin-top: 56px;
	padding-top: 28px;
	border-top: 1px solid rgba(16, 185, 129, 0.12);
	text-align: center;
	color: #6b7280;
}

.counsel-footer__bottom p {
	font-size: 12px;
}

.counsel-fixed-cta {
	position: fixed;
	right: 12px;
	bottom: 24px;
	z-index: 40;
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 16px 18px;
	border-radius: 18px;
	background: linear-gradient(135deg, #00b300 0%, #00c300 100%);
	color: #fff;
	font-weight: 700;
	box-shadow: 0 12px 32px rgba(0, 180, 0, 0.32);
	white-space: nowrap;
	transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.counsel-fixed-cta:hover {
	transform: translateY(-2px);
	color: #fff;
	box-shadow: 0 16px 36px rgba(0, 160, 0, 0.38);
	background: linear-gradient(135deg, #009900 0%, #00b000 100%);
}

.counsel-fixed-cta__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.counsel-fixed-cta__text {
	font-size: 13px;
	line-height: 1.4;
}

.js-fade-up {
	opacity: 0;
	transform: translateY(24px);
	transition: opacity 0.7s ease, transform 0.7s ease;
}

.js-fade-up.is-visible {
	opacity: 1;
	transform: translateY(0);
}

@media only screen and (max-width: 960px) {
	.counsel-header__nav {
		display: none;
	}

	.counsel-header__toggle {
		display: inline-block;
	}

	.counsel-grid--four {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.counsel-steps {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.counsel-footer__grid {
		grid-template-columns: 1fr;
	}
}

@media only screen and (max-width: 767px) {
	.counsel-shell {
		width: min(100% - 24px, 1120px);
	}

	.counsel-section {
		padding: 78px 0;
	}

	.counsel-grid--two,
	.counsel-grid--three,
	.counsel-grid--four,
	.counsel-voices,
	.counsel-contact__actions,
	.counsel-steps {
		grid-template-columns: 1fr;
	}

	.counsel-hero {
		min-height: 80vh;
	}

	.counsel-hero__content {
		padding: 74px 0 110px;
	}

	.counsel-hero h1 br,
	.counsel-message br {
		display: none;
	}

	.counsel-contact {
		padding: 40px 22px;
		border-radius: 28px;
	}

	.counsel-footer {
		padding-bottom: 140px;
	}

	.counsel-fixed-cta {
		right: 10px;
		left: 10px;
		bottom: 14px;
		justify-content: center;
	}
}

/* about page */
.counsel-about-page {
	background: #fff;
	padding-bottom: 96px;
}

.counsel-about-hero {
	padding: 80px 0;
	background: rgba(236, 253, 245, 0.75);
}

.counsel-about-hero h1 {
	margin: 0 0 20px;
	font-size: clamp(2rem, 1.5rem + 1.6vw, 3.4rem);
	line-height: 1.2;
	letter-spacing: 0.01em;
}

.counsel-about-hero p {
	margin: 0;
	font-size: 1.1rem;
	line-height: 1.8;
	color: #6b7280;
}

.counsel-about-section {
	padding: 96px 0 48px;
}

.counsel-about-card {
	overflow: hidden;
	border: 1px solid #f3f4f6;
	border-radius: 40px;
	background: #fff;
	box-shadow: 0 18px 38px rgba(15, 23, 42, 0.05);
}

.counsel-about-row {
	display: flex;
	gap: 28px;
	padding: 32px;
	transition: background-color 0.2s ease;
}

.counsel-about-row+.counsel-about-row {
	border-top: 1px solid #f3f4f6;
}

.counsel-about-row:hover {
	background: rgba(236, 253, 245, 0.35);
}

.counsel-about-label {
	width: 32%;
	flex-shrink: 0;
	font-weight: 700;
	color: #059669;
}

.counsel-about-value {
	width: 68%;
	line-height: 1.9;
	color: #374151;
	white-space: normal;
}

.counsel-about-value a {
	color: #374151;
	word-break: break-word;
}

.counsel-about-value a:hover {
	color: #059669;
}

.counsel-about-access {
	padding: 48px 0;
}

.counsel-about-access__card {
	padding: 48px 40px;
	border: 1px solid rgba(191, 219, 254, 0.7);
	border-radius: 40px;
	background: rgba(239, 246, 255, 0.55);
	text-align: center;
}

.counsel-about-access__card h2 {
	margin: 0 0 22px;
	font-size: clamp(1.5rem, 1.2rem + 0.8vw, 2rem);
}

.counsel-about-access__card p {
	margin: 0;
	line-height: 1.95;
	color: #4b5563;
}

.counsel-about-cta {
	padding: 96px 0 0;
}

.counsel-about-cta h2 {
	margin: 0 0 32px;
	font-size: clamp(1.7rem, 1.3rem + 1vw, 2.5rem);
	line-height: 1.5;
}

.counsel-about-cta__button {
	padding: 20px 40px;
	font-size: 1.2rem;
	box-shadow: 0 20px 40px rgba(16, 185, 129, 0.18);
}

@media only screen and (max-width: 767px) {
	.counsel-about-page {
		padding-bottom: 72px;
	}

	.counsel-about-hero {
		padding: 64px 0;
	}

	.counsel-about-section {
		padding: 72px 0 36px;
	}

	.counsel-about-row {
		flex-direction: column;
		gap: 10px;
		padding: 24px 22px;
	}

	.counsel-about-label,
	.counsel-about-value {
		width: 100%;
	}

	.counsel-about-access__card {
		padding: 36px 22px;
		border-radius: 28px;
	}

	.counsel-about-cta {
		padding-top: 72px;
	}

	.counsel-about-cta__button {
		width: 100%;
		max-width: 360px;
		font-size: 1.05rem;
	}
}

/* menu page */
.counsel-menu-page {
	background: #fff;
	padding-bottom: 96px;
}

.counsel-menu-hero {
	padding: 80px 0;
	background: rgba(236, 253, 245, 0.75);
}

.counsel-menu-hero h1 {
	margin: 0 0 20px;
	font-size: clamp(2rem, 1.5rem + 1.6vw, 3.4rem);
	line-height: 1.2;
	letter-spacing: 0.01em;
}

.counsel-menu-hero p {
	margin: 0;
	font-size: 1.1rem;
	line-height: 1.9;
	color: #6b7280;
}

.counsel-menu-section {
	padding: 96px 0;
}

.counsel-menu-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 32px;
}

.counsel-menu-card {
	position: relative;
	display: flex;
	flex-direction: column;
	padding: 32px;
	border: 1px solid #f3f4f6;
	border-radius: 32px;
	background: #fff;
	box-shadow: 0 14px 28px rgba(15, 23, 42, 0.05);
	transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
}

.counsel-menu-card:hover {
	transform: translateY(-8px);
	border-color: #bbf7d0;
	box-shadow: 0 24px 40px rgba(15, 23, 42, 0.08);
}

.counsel-menu-card--highlight {
	border-color: #34d399;
	background: rgba(236, 253, 245, 0.45);
	box-shadow: 0 22px 38px rgba(16, 185, 129, 0.12);
}

.counsel-menu-card__badge {
	position: absolute;
	top: -14px;
	left: 50%;
	transform: translateX(-50%);
	padding: 6px 16px;
	border-radius: 999px;
	background: #10b981;
	color: #fff;
	font-size: 0.85rem;
	font-weight: 700;
	box-shadow: 0 10px 18px rgba(16, 185, 129, 0.22);
}

.counsel-menu-card__head {
	margin-bottom: 28px;
}

.counsel-menu-card__head h2 {
	margin: 0 0 18px;
	font-size: 1.35rem;
	line-height: 1.5;
}

.counsel-menu-card__price-row {
	display: flex;
	align-items: baseline;
	gap: 6px;
	margin-bottom: 10px;
}

.counsel-menu-card__price {
	font-size: 2rem;
	font-weight: 700;
	color: #059669;
	line-height: 1.2;
}

.counsel-menu-card__note {
	font-size: 0.85rem;
	color: #6b7280;
}

.counsel-menu-card__time {
	display: inline-block;
	margin: 0;
	padding: 6px 12px;
	border-radius: 10px;
	background: rgba(16, 185, 129, 0.12);
	color: #047857;
	font-size: 0.9rem;
	font-weight: 700;
}

.counsel-menu-card__desc {
	flex: 1;
	margin: 0 0 28px;
	color: #4b5563;
	font-size: 0.95rem;
	line-height: 1.95;
}

.counsel-menu-card__button {
	display: block;
	width: 100%;
	padding: 16px 18px;
	border-radius: 16px;
	background: #f9fafb;
	color: #374151;
	text-align: center;
	font-weight: 700;
	transition: background-color 0.2s ease, color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.counsel-menu-card__button:hover {
	background: #ecfdf5;
	color: #047857;
}

.counsel-menu-card__button--primary {
	background: #10b981;
	color: #fff;
	box-shadow: 0 12px 24px rgba(16, 185, 129, 0.2);
}

.counsel-menu-card__button--primary:hover {
	background: #059669;
	color: #fff;
	transform: translateY(-2px);
	box-shadow: 0 16px 28px rgba(16, 185, 129, 0.25);
}

.counsel-menu-trust {
	padding: 96px 0;
	background: rgba(239, 246, 255, 0.5);
}

.counsel-menu-trust__card {
	padding: 48px;
	border: 1px solid rgba(191, 219, 254, 0.65);
	border-radius: 40px;
	background: #fff;
	box-shadow: 0 14px 28px rgba(15, 23, 42, 0.04);
}

.counsel-menu-trust__card h2 {
	margin: 0 0 40px;
	text-align: center;
	font-size: clamp(1.6rem, 1.3rem + 0.9vw, 2.3rem);
	line-height: 1.4;
}

.counsel-menu-trust__list {
	display: flex;
	flex-direction: column;
	gap: 30px;
}

.counsel-menu-trust__item {
	display: flex;
	gap: 22px;
}

.counsel-menu-trust__icon {
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 34px;
	height: 34px;
	margin-top: 4px;
	border-radius: 50%;
	background: #ecfdf5;
}

.counsel-menu-trust__icon span {
	position: relative;
	display: block;
	width: 14px;
	height: 8px;
	border-left: 3px solid #059669;
	border-bottom: 3px solid #059669;
	transform: rotate(-45deg);
	margin-top: -2px;
}

.counsel-menu-trust__item h3 {
	margin: 0 0 10px;
	font-size: 1.08rem;
	line-height: 1.5;
}

.counsel-menu-trust__item p {
	margin: 0;
	line-height: 1.95;
	color: #4b5563;
}

.counsel-menu-cta {
	padding: 96px 0 0;
}

.counsel-menu-cta h2 {
	margin: 0 0 32px;
	font-size: clamp(1.7rem, 1.3rem + 1vw, 2.5rem);
	line-height: 1.5;
}

.counsel-menu-cta__button {
	padding: 20px 40px;
	font-size: 1.2rem;
	box-shadow: 0 20px 40px rgba(16, 185, 129, 0.18);
}

@media only screen and (max-width: 960px) {
	.counsel-menu-grid {
		grid-template-columns: 1fr;
	}
}

@media only screen and (max-width: 767px) {
	.counsel-menu-page {
		padding-bottom: 72px;
	}

	.counsel-menu-hero {
		padding: 64px 0;
	}

	.counsel-menu-section,
	.counsel-menu-trust {
		padding: 72px 0;
	}

	.counsel-menu-card {
		padding: 28px 22px;
	}

	.counsel-menu-trust__card {
		padding: 36px 22px;
		border-radius: 28px;
	}

	.counsel-menu-trust__item {
		gap: 16px;
	}

	.counsel-menu-cta {
		padding-top: 72px;
	}

	.counsel-menu-cta__button {
		width: 100%;
		max-width: 360px;
		font-size: 1.05rem;
	}
}

/* profile page */
.counsel-profile-page {
	background: #fff;
	padding-bottom: 0;
}

.counsel-profile-hero {
	padding: 80px 0;
	background: #f5f8f5;
}

.counsel-profile-hero__inner {
	display: flex;
	align-items: center;
	gap: 64px;
}

.counsel-profile-hero__image {
	width: 40%;
	flex-shrink: 0;
}

.counsel-profile-hero__image-frame {
	overflow: hidden;
	border-radius: 32px;
	aspect-ratio: 4 / 5;
	box-shadow: 0 24px 40px rgba(15, 23, 42, 0.12);
}

.counsel-profile-hero__image-frame img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: top;
	display: block;
}

.counsel-profile-hero__content {
	width: 60%;
}

.counsel-profile-hero__lead {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.counsel-profile-hero__role {
	margin: 0;
	font-size: 0.9rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	color: #059669;
}

.counsel-profile-hero h1 {
	margin: 0;
	font-size: clamp(2.4rem, 1.8rem + 1.8vw, 4rem);
	line-height: 1.15;
	letter-spacing: 0.01em;
}

.counsel-profile-hero__meta {
	margin: 0;
	line-height: 1.9;
	color: #6b7280;
}

.counsel-profile-hero__line {
	width: 48px;
	height: 4px;
	margin: 28px 0;
	border-radius: 999px;
	background: #86efac;
}

.counsel-profile-hero__quote {
	margin: 0;
	font-size: clamp(1.2rem, 1rem + 0.7vw, 1.8rem);
	line-height: 1.9;
	font-weight: 500;
	font-style: italic;
	color: #374151;
}

.counsel-profile-section {
	padding: 80px 0;
}

.counsel-profile-section--white {
	background: #fff;
}

.counsel-profile-section--tint {
	background: #f5f8f5;
}

.counsel-profile-title {
	margin: 0;
	padding-left: 20px;
	border-left: 4px solid #34d399;
	font-size: clamp(1.6rem, 1.3rem + 0.9vw, 2.3rem);
	line-height: 1.45;
}

.counsel-profile-copy {
	display: flex;
	flex-direction: column;
	gap: 32px;
}

.counsel-profile-copy__body {
	display: flex;
	flex-direction: column;
	gap: 20px;
	color: #374151;
	font-size: 1.08rem;
	line-height: 2;
}

.counsel-profile-copy__body p {
	margin: 0;
}

.counsel-profile-copy__emphasis {
	font-size: 1.25rem;
	font-weight: 700;
	color: #047857;
}

.counsel-profile-story {
	display: flex;
	flex-direction: column;
	gap: 40px;
	margin-top: 40px;
}

.counsel-profile-story__item {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.counsel-profile-story__item h3 {
	margin: 0;
	font-size: 1.1rem;
	font-weight: 700;
	color: #047857;
}

.counsel-profile-story__item p {
	margin: 0;
	font-size: 1.08rem;
	line-height: 2;
	color: #374151;
}

.counsel-profile-activity {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 32px;
	margin-top: 40px;
}

.counsel-profile-activity__card {
	padding: 32px;
	border-radius: 32px;
	background: rgba(236, 253, 245, 0.65);
}

.counsel-profile-activity__card--accent {
	background: rgba(239, 246, 255, 0.7);
}

.counsel-profile-activity__card h3 {
	margin: 0 0 16px;
	font-size: 1.25rem;
}

.counsel-profile-activity__card ul {
	margin: 0;
	padding: 0;
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: 12px;
	font-size: 1.08rem;
	color: #374151;
}

.counsel-profile-activity__card li {
	display: flex;
	align-items: center;
	gap: 12px;
}

.counsel-profile-activity__card li::before {
	content: "";
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: #34d399;
	flex-shrink: 0;
}

.counsel-profile-activity__card p {
	margin: 0;
	color: #374151;
	line-height: 1.95;
}

.counsel-profile-activity__card p+p {
	margin-top: 14px;
	color: #4b5563;
	font-size: 0.96rem;
}

.counsel-profile-qualifications {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 20px;
	margin-top: 40px;
}

.counsel-profile-qualification {
	display: flex;
	align-items: center;
	gap: 16px;
	padding: 20px 24px;
	border: 1px solid #f3f4f6;
	border-radius: 24px;
	background: #fff;
	box-shadow: 0 10px 24px rgba(15, 23, 42, 0.04);
}

.counsel-profile-qualification::before {
	content: "";
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background: #34d399;
	flex-shrink: 0;
}

.counsel-profile-qualification p {
	margin: 0;
	font-weight: 500;
	color: #374151;
}

.counsel-profile-sign {
	margin-top: 32px;
	padding: 32px;
	border: 1px solid #d1fae5;
	border-radius: 32px;
	background: rgba(236, 253, 245, 0.5);
}

.counsel-profile-sign__name {
	margin: 0 0 8px;
	font-size: 1.15rem;
	font-weight: 700;
	color: #1f2937;
}

.counsel-profile-sign__meta {
	margin: 0;
	font-size: 0.95rem;
	line-height: 1.8;
	color: #6b7280;
}

.counsel-profile-contact {
	padding: 96px 0;
	background: #f0f7f4;
}

.counsel-profile-contact__inner {
	display: flex;
	flex-direction: column;
	gap: 40px;
}

.counsel-profile-contact__copy h2 {
	margin: 0 0 16px;
	font-size: clamp(1.7rem, 1.3rem + 1vw, 2.5rem);
	line-height: 1.45;
}

.counsel-profile-contact__copy p {
	margin: 0;
	font-size: 1.08rem;
	line-height: 1.95;
	color: #4b5563;
}

.counsel-profile-contact__grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 24px;
	max-width: 640px;
	margin: 0 auto;
}

.counsel-profile-contact__card {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 16px;
	padding: 40px 32px;
	border: 2px solid #d1fae5;
	border-radius: 32px;
	background: #fff;
	box-shadow: 0 12px 24px rgba(15, 23, 42, 0.04);
	transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease, background-color 0.3s ease;
}

.counsel-profile-contact__card:hover {
	transform: translateY(-4px);
	border-color: #34d399;
	background: #f0fdf4;
	box-shadow: 0 18px 32px rgba(15, 23, 42, 0.08);
}

.counsel-profile-contact__card--line {
	border-color: #bbf7d0;
}

.counsel-profile-contact__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 64px;
	height: 64px;
	border-radius: 20px;
}

.counsel-profile-contact__icon--mail {
	background: #d1fae5;
}

.counsel-profile-contact__icon--line {
	background: #06c755;
}

.counsel-profile-contact__mail-mark {
	position: relative;
	display: block;
	width: 28px;
	height: 20px;
	border: 2px solid #059669;
	border-radius: 4px;
}

.counsel-profile-contact__mail-mark::before,
.counsel-profile-contact__mail-mark::after {
	content: "";
	position: absolute;
	top: 4px;
	width: 14px;
	height: 2px;
	background: #059669;
}

.counsel-profile-contact__mail-mark::before {
	left: 0;
	transform: rotate(28deg);
	transform-origin: left center;
}

.counsel-profile-contact__mail-mark::after {
	right: 0;
	transform: rotate(-28deg);
	transform-origin: right center;
}

.counsel-profile-contact__title {
	margin: 0 0 6px;
	font-size: 1.2rem;
	font-weight: 700;
	color: #1f2937;
}

.counsel-profile-contact__text {
	margin: 0;
	font-size: 0.95rem;
	line-height: 1.8;
	color: #6b7280;
}

.js-profile-fade {
	opacity: 0;
	transform: translateY(24px);
	transition: opacity 0.7s ease, transform 0.7s ease;
}

.js-profile-fade.is-visible {
	opacity: 1;
	transform: translateY(0);
}

.pc-only {
	display: inline;
}

@media only screen and (max-width: 960px) {

	.counsel-profile-hero__inner,
	.counsel-profile-activity,
	.counsel-profile-contact__grid {
		grid-template-columns: 1fr;
	}

	.counsel-profile-hero__inner {
		display: flex;
		flex-direction: column;
		gap: 40px;
	}

	.counsel-profile-hero__image,
	.counsel-profile-hero__content {
		width: 100%;
	}

	.counsel-profile-qualifications {
		grid-template-columns: 1fr;
	}
}

@media only screen and (max-width: 767px) {

	.counsel-profile-hero,
	.counsel-profile-section {
		padding: 64px 0;
	}

	.counsel-profile-contact {
		padding: 72px 0;
	}

	.counsel-profile-hero__image-frame,
	.counsel-profile-activity__card,
	.counsel-profile-sign,
	.counsel-profile-contact__card {
		border-radius: 28px;
	}

	.counsel-profile-activity__card,
	.counsel-profile-sign,
	.counsel-profile-contact__card,
	.counsel-profile-qualification {
		padding-left: 22px;
		padding-right: 22px;
	}

	.counsel-profile-title {
		padding-left: 16px;
	}

	.counsel-profile-copy__body,
	.counsel-profile-story__item p {
		font-size: 1rem;
	}

	.pc-only {
		display: none;
	}
}

/* faq page */
.counsel-faq-page {
	background: #fff;
	padding-bottom: 96px;
}

.counsel-faq-hero {
	padding: 80px 0;
	background: rgba(236, 253, 245, 0.75);
}

.counsel-faq-hero h1 {
	margin: 0 0 20px;
	font-size: clamp(2rem, 1.5rem + 1.6vw, 3.4rem);
	line-height: 1.2;
	letter-spacing: 0.01em;
}

.counsel-faq-hero p {
	margin: 0;
	font-size: 1.1rem;
	line-height: 1.9;
	color: #6b7280;
}

.counsel-faq-section {
	padding: 80px 0;
}

.counsel-faq-list {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.counsel-faq-item {
	overflow: hidden;
	border: 1px solid #f3f4f6;
	border-radius: 24px;
	background: #fff;
	box-shadow: 0 10px 24px rgba(15, 23, 42, 0.04);
	transition: border-color 0.3s ease, box-shadow 0.3s ease;
}

.counsel-faq-item:hover {
	border-color: #bbf7d0;
	box-shadow: 0 16px 30px rgba(15, 23, 42, 0.06);
}

.counsel-faq-item.is-open {
	border-color: #86efac;
	box-shadow: 0 16px 30px rgba(16, 185, 129, 0.1);
}

.counsel-faq-question {
	display: flex;
	align-items: flex-start;
	gap: 16px;
	width: 100%;
	padding: 24px 28px;
	border: 0;
	background: #fff;
	text-align: left;
	cursor: pointer;
}

.counsel-faq-item.is-open .counsel-faq-question {
	background: #f0faf5;
}

.counsel-faq-question__mark,
.counsel-faq-answer__mark {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	border-radius: 50%;
	flex-shrink: 0;
	font-size: 0.9rem;
	font-weight: 700;
}

.counsel-faq-question__mark {
	margin-top: 2px;
	background: #d1fae5;
	color: #059669;
}

.counsel-faq-item.is-open .counsel-faq-question__mark {
	background: #10b981;
	color: #fff;
}

.counsel-faq-question__text {
	flex: 1;
	font-size: 1.08rem;
	font-weight: 700;
	line-height: 1.8;
	color: #1f2937;
}

.counsel-faq-question__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	margin-top: 2px;
	color: #9ca3af;
	transition: transform 0.3s ease, color 0.3s ease;
}

.counsel-faq-item.is-open .counsel-faq-question__icon {
	transform: rotate(180deg);
	color: #10b981;
}

.counsel-faq-answer {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.4s ease;
}

.counsel-faq-answer__inner {
	display: flex;
	align-items: flex-start;
	gap: 16px;
	padding: 4px 28px 28px;
}

.counsel-faq-answer__mark {
	margin-top: 2px;
	background: #eff6ff;
	color: #3b82f6;
}

.counsel-faq-answer__inner p {
	flex: 1;
	margin: 0;
	font-size: 1rem;
	line-height: 1.95;
	color: #4b5563;
	white-space: pre-wrap;
}

.counsel-faq-answer__inner p+p {
	margin-top: 16px;
}

.counsel-faq-cta {
	padding: 32px 0 0;
}

.counsel-faq-cta__card {
	padding: 40px;
	border: 1px solid #d1fae5;
	border-radius: 32px;
	background: rgba(236, 253, 245, 0.6);
	text-align: center;
}

.counsel-faq-cta__card h2 {
	margin: 0 0 18px;
	font-size: clamp(1.5rem, 1.2rem + 0.9vw, 2rem);
	line-height: 1.45;
}

.counsel-faq-cta__card p {
	margin: 0 0 26px;
	line-height: 1.9;
	color: #4b5563;
}

.counsel-faq-cta__button {
	padding: 16px 40px;
	font-size: 1.05rem;
}

@media only screen and (max-width: 767px) {
	.counsel-faq-page {
		padding-bottom: 72px;
	}

	.counsel-faq-hero,
	.counsel-faq-section {
		padding: 64px 0;
	}

	.counsel-faq-question,
	.counsel-faq-answer__inner,
	.counsel-faq-cta__card {
		padding-left: 22px;
		padding-right: 22px;
	}

	.counsel-faq-question {
		padding-top: 22px;
		padding-bottom: 22px;
	}

	.counsel-faq-answer__inner {
		padding-bottom: 24px;
	}

	.counsel-faq-question__text {
		font-size: 1rem;
	}

	.counsel-faq-cta__button {
		width: 100%;
		max-width: 320px;
	}
}

/* contact page */
.counsel-contact-page {
	background: #fff;
	padding-bottom: 96px;
}

.counsel-contact-hero {
	padding: 80px 0;
	background: rgba(236, 253, 245, 0.75);
}

.counsel-contact-hero h1 {
	margin: 0 0 20px;
	font-size: clamp(2rem, 1.5rem + 1.6vw, 3.4rem);
	line-height: 1.2;
	letter-spacing: 0.01em;
}

.counsel-contact-hero p {
	margin: 0;
	font-size: 1.1rem;
	line-height: 1.9;
	color: #6b7280;
}

.counsel-contact-badges {
	padding: 48px 0;
}

.counsel-contact-badges__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 24px;
}

.counsel-contact-badge {
	padding: 28px 24px;
	border: 1px solid #f3f4f6;
	border-radius: 32px;
	background: #fff;
	text-align: center;
	box-shadow: 0 10px 24px rgba(15, 23, 42, 0.04);
}

.counsel-contact-badge__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 58px;
	height: 58px;
	margin: 0 auto 18px;
	color: #10b981;
}

.counsel-contact-badge h2 {
	margin: 0 0 10px;
	font-size: 1.02rem;
}

.counsel-contact-badge p {
	margin: 0;
	font-size: 0.82rem;
	line-height: 1.8;
	color: #6b7280;
}

.counsel-contact-badge__icon--shield span,
.counsel-contact-badge__icon--clock span,
.counsel-contact-badge__icon--heart span {
	position: relative;
	display: block;
}

.counsel-contact-badge__icon--shield span {
	width: 28px;
	height: 34px;
	border: 3px solid #10b981;
	border-bottom-left-radius: 14px;
	border-bottom-right-radius: 14px;
	border-top-left-radius: 10px;
	border-top-right-radius: 10px;
	clip-path: polygon(50% 100%, 0 78%, 0 0, 100% 0, 100% 78%);
}

.counsel-contact-badge__icon--shield span::after {
	content: "";
	position: absolute;
	left: 8px;
	top: 10px;
	width: 10px;
	height: 6px;
	border-left: 3px solid #10b981;
	border-bottom: 3px solid #10b981;
	transform: rotate(-45deg);
}

.counsel-contact-badge__icon--clock span {
	width: 34px;
	height: 34px;
	border: 3px solid #10b981;
	border-radius: 50%;
}

.counsel-contact-badge__icon--clock span::before {
	content: "";
	position: absolute;
	left: 15px;
	top: 7px;
	width: 3px;
	height: 10px;
	background: #10b981;
	border-radius: 999px;
}

.counsel-contact-badge__icon--clock span::after {
	content: "";
	position: absolute;
	left: 15px;
	top: 16px;
	width: 9px;
	height: 3px;
	background: #10b981;
	border-radius: 999px;
}

.counsel-contact-badge__icon--heart span {
	width: 30px;
	height: 28px;
	transform: rotate(-45deg);
	background: #10b981;
	border-radius: 4px;
}

.counsel-contact-badge__icon--heart span::before,
.counsel-contact-badge__icon--heart span::after {
	content: "";
	position: absolute;
	width: 30px;
	height: 30px;
	background: #10b981;
	border-radius: 50%;
}

.counsel-contact-badge__icon--heart span::before {
	top: -15px;
	left: 0;
}

.counsel-contact-badge__icon--heart span::after {
	top: 0;
	left: 15px;
}

.counsel-contact-form-section {
	padding: 48px 0 0;
}

.counsel-contact-form-card {
	padding: 32px;
	border: 1px solid #f3f4f6;
	border-radius: 40px;
	background: #fff;
	box-shadow: 0 24px 40px rgba(15, 23, 42, 0.08);
}

.counsel-contact-form {
	display: flex;
	flex-direction: column;
	gap: 40px;
}

.counsel-contact-form__fields {
	display: flex;
	flex-direction: column;
	gap: 24px;
}

.counsel-contact-field label {
	display: block;
	margin-bottom: 10px;
	font-size: 1.08rem;
	font-weight: 700;
	color: #1f2937;
}

.counsel-contact-field label span {
	margin-left: 8px;
	font-size: 0.85rem;
	font-weight: 400;
	color: #ef4444;
}

.counsel-contact-field input,
.counsel-contact-field select,
.counsel-contact-field textarea {
	width: 100%;
	padding: 18px 24px;
	border: 0;
	border-radius: 22px;
	background: #f9fafb;
	font-size: 1.05rem;
	color: #1f2937;
	transition: box-shadow 0.2s ease, background-color 0.2s ease;
}

.counsel-contact-field input:focus,
.counsel-contact-field select:focus,
.counsel-contact-field textarea:focus {
	outline: none;
	background: #fff;
	box-shadow: 0 0 0 4px rgba(16, 185, 129, 0.1);
}

.counsel-contact-field textarea {
	resize: vertical;
	min-height: 180px;
}

.counsel-contact-form__actions {
	padding-top: 8px;
}

.counsel-contact-form__submit {
	width: 100%;
	padding: 22px 24px;
	border: 0;
	border-radius: 24px;
	background: #10b981;
	color: #fff;
	font-size: 1.2rem;
	font-weight: 700;
	box-shadow: 0 18px 36px rgba(16, 185, 129, 0.18);
	transition: transform 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}

.counsel-contact-form__submit:hover {
	background: #059669;
	transform: translateY(-2px);
	box-shadow: 0 22px 40px rgba(16, 185, 129, 0.24);
}

.counsel-contact-form__actions p {
	margin: 18px 0 0;
	text-align: center;
	font-size: 0.85rem;
	line-height: 1.8;
	color: #9ca3af;
}

.counsel-contact-thanks {
	display: none;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 24px;
	padding: 48px 12px;
}

.counsel-contact-thanks.is-active {
	display: flex;
}

.counsel-contact-thanks__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 96px;
	height: 96px;
	border-radius: 50%;
	background: #d1fae5;
	color: #10b981;
}

.counsel-contact-thanks__icon span {
	position: relative;
	display: block;
	width: 30px;
	height: 28px;
	transform: rotate(-45deg);
	background: #10b981;
	border-radius: 4px;
}

.counsel-contact-thanks__icon span::before,
.counsel-contact-thanks__icon span::after {
	content: "";
	position: absolute;
	width: 30px;
	height: 30px;
	background: #10b981;
	border-radius: 50%;
}

.counsel-contact-thanks__icon span::before {
	top: -15px;
	left: 0;
}

.counsel-contact-thanks__icon span::after {
	top: 0;
	left: 15px;
}

.counsel-contact-thanks h2 {
	margin: 0;
	font-size: clamp(1.8rem, 1.4rem + 1vw, 2.6rem);
	line-height: 1.4;
}

.counsel-contact-thanks p {
	margin: 0;
	font-size: 1.05rem;
	line-height: 2;
	color: #4b5563;
}

.counsel-contact-thanks a {
	color: #059669;
	font-weight: 700;
}

.counsel-contact-thanks a:hover {
	text-decoration: underline;
}

.w-500 {
	width: 500px;
	margin-bottom: 40px;
}

@media only screen and (max-width: 960px) {
	.counsel-contact-badges__grid {
		grid-template-columns: 1fr;
	}
}

@media only screen and (max-width: 767px) {
	.counsel-contact-page {
		padding-bottom: 72px;
	}

	.counsel-contact-hero {
		padding: 64px 0;
	}

	.counsel-contact-badges,
	.counsel-contact-form-section {
		padding-top: 36px;
	}

	.counsel-contact-form-card {
		padding: 24px 20px;
		border-radius: 28px;
	}

	.counsel-contact-field input,
	.counsel-contact-field select,
	.counsel-contact-field textarea {
		padding: 16px 18px;
		font-size: 1rem;
	}

	.counsel-contact-form__submit {
		font-size: 1.05rem;
		padding: 20px 18px;
	}
}
