@charset "UTF-8";
/*-------------------------------------------
TOP
--------------------------------------------*/
/* ----  mv ---- */
.mv{
	width: 100%;
	background-image: url(../images/alpha.jpg);
	background-size: cover;
	position: relative;
	height: 100vh;
}
.mv::before{
	content: '';
	width: 100%;
	height: 100%;
	display: block;
	background-color: rgba(0,0,0,0.01);
}
.mv_txt {
	position: absolute;
	bottom: 8vw;
	left: 5.0vw;
}
.mv_txt h2{
	/* font-family: 'Noto Serif JP', serif; */
	font-weight: 500;
	font-size: 2.45vw;
	line-height: 1.4;
	color: #fff;
	text-shadow: 1px 2px 3px #808080;
}
.mv_news{
	background-color: rgba(0,0,0,0.8);
	display: inline-block;
	min-width: 50%;
	position: absolute;
	right: 0;
	bottom: 0;
}
.mv_news_inner{
	display: flex;
	color: #fff;
	padding: 1.3em 2em;
}
.mv_news .mv_news_ttl{
	font-size: 1.05vw;
	position: relative;
	margin-right: 2em;
	padding-right: 2em;
}
.mv_news .mv_news_ttl::before{
	content: '';
	width: 1px;
	height: calc(100% + 10px);
	display: block;
	background: #fff;
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
}
.mv_news dl{
	display: flex;
	align-items: center;
	& dt{
		font-size: 0.8vw;
		font-weight: 400;
		padding-right: 1.35em;
	}
	& dd{
		font-size: 0.9vw;
	}
}


/* ----  top_sec01 ---- */

.top_section_ttl_bg{
	background-color: var(--SubColor2);
	text-align: center;
	position: relative;
	padding: 3.7vw 0;

	& h3{
		font-size: 2.2vw;
		color: #fff;
		font-weight: 400;
	}

	& span{
		font-size: 7.0vw;
		color: rgba(255, 255, 255, 0.12);
		font-weight: 300;
		position: absolute;
		top: 47%;
		left: 50%;
		transform: translate(-50%,-50%);
	}
}

.section_inner{
	padding: 4.5vw 0 4.0vw;
}

.lower_page_ttl_bg{
	background-color: var(--SubColor2);
	text-align: center;
	position: relative;
	padding: 3.7vw 0;

	& h2{
		font-size: 2.2vw;
		color: #fff;
		font-weight: 400;
	}
	
	& span{
		font-size: 7.0vw;
		color: rgba(255, 255, 255, 0.12);
		font-weight: 300;
		position: absolute;
		top: 47%;
		left: 50%;
		transform: translate(-50%,-50%);
		width: 100%;
		text-align: center;
	}
}


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

.top_sec01_txtbox{
	width: 61%;

	& .top_sec01_ttl{
		/*font-family: 'Noto Serif JP', serif;*/
		font-size: 1.8vw;
		line-height: 1.4;
		margin-bottom: 1em;
	}

	& .top_sec01_txt p{
		margin-top: 1.5em;
	}

	& .sign {
		text-align: right;
		font-size: 1.4vw;
		font-weight: 600;

		& span{
			font-size: 0.7em;
			padding-right: 1em;
		}
	}
}

.top_sec01_imgbox{
	width: 31%;
}



/* ---- トップ 業務内容 ---- */
.top_service_box_ttl{
	font-size: 1.4vw;
	font-weight: 600;
	padding-left: 0.65em;
	margin-bottom: 2.4vw;
	position: relative;
}
.top_service_box_ttl:nth-of-type(n+2){
	margin-top: 4vw;
}


.top_service_box_ttl::before{
		content: '';
		width: 4.5px;
		height: 2.9vw;
		background-color: #333;
		display: block;
		position: absolute;
		left: 0;
		top: 50%;
		transform: translateY(-50%);
}

.top_service_box01 ul{
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	row-gap: 3vw;

	& li{
		width: 31.5%;
		text-align: center;

		& a{
			text-decoration: none;
			color: #333;
			font-size: 1.1vw;
			font-weight: 600;

			& div{
				margin-bottom: 1.0em;
			}
		}
	}
}


/* ---- トップ アクセス ---- */
.top_access_box{
	display: flex;
	justify-content: space-between;

	& >div{
		width: 45%;
	}
}

.top_access_box01 dl{
	& dt{
		font-size: 1.1vw;
		font-weight: 600;
		padding-left: 0.75em;
		margin-bottom: 0.5em;
		position: relative;
	}

	& dt::before{
		content: '';
		width: 4.5px;
		height: 2vw;
		background-color: #333;
		display: block;
		position: absolute;
		left: 0;
	}
	& dd+dt{
		margin-top: 2.0vw;
	}
	& dd span{
		font-size: 0.9em;
	}
}

.top_access_box02 dl{

	& dt{
		font-size: 1vw;
		font-weight: 600;
		display: flex;
    	align-items: center;
		margin-bottom: 0.3em;
	}

	& dt::before{
		content: '';
		display: block;
		margin-right: 0.3em;
		width: 0.7vw;
		height: 0.8vw;
		background-color: #333;
		clip-path: polygon(0.7vw 50%, 0% 0%, 0% 0.8vw);
	}

	& dd+dt{
		margin-top: 2.5vw;
	}
}

.top_gmap{
	width: 100%;
	padding-top: 3vw;

	& iframe{
		width: 100%;
		height: 34vw;
	}
}


/* ---- トップ お知らせ ---- */
.top_news_box dl{
	display: flex;
	align-items: flex-start;
	color: #707070;
	border-bottom: 1px solid #ccc;
	padding: 3.5% 1.5%;

	& dt{
		width: 9%;
		color: #999;
		font-size: 1vw;
	}

	& .category{
		width: 8%;
		color: #fff;
		font-size: 0.75em;
		background-color: var(--AccentColor);
		line-height: 2.0;
		text-align: center;

	}

	& .text{
		width: 82%;
		padding-left: 2.5%;
	}
}



/*-------------------------------------------
下層ページ
--------------------------------------------*/
.pankuzu{
	font-size: 0.85vw;
    padding-top: 1.5em;
    color: #999999;

	& a{
		color: #999999;
		text-decoration: none;
	}
}

.lower_section_ttl {
	& h3{
		font-size: 2.2vw;
		font-weight: 500;
		text-align: center;
		position: relative;
		padding-bottom: 1.1vw;
		margin-bottom: 2.87vw;
	}

	& h3::before{
		content: "";
		height: 0.25vw;
		width: 4vw;
		background-color: var(--AccentColor);
		position: absolute;
		bottom: 0px;
		left: 50%;
		transform: translate(-50%, 0px);
		}
}


/*---------- 業務内容（個人・法人） -----------*/
.service_link_box {
    display: flex;
	flex-wrap: wrap;
    gap: 1.5vw 2.75%;
    margin: 7% 0;

	& li{
		width: 31.5%;
	}

	& a{
		font-size: 1vw;
		color: #333;
		display: block;
		text-decoration: none;
		border: 1px solid #bbb;
		padding: 7.5% 11% 7.5% 7.5%;
		position: relative;
	}

	& a::before{
		font-family: "Font Awesome 5 Free";
		content: "\f054 ";
		color: #555555;
		font-weight: 900;
		font-size: 0.95vw;
		position: absolute;
		right: 1.3em;
		top: 50%;
		transform: translateY(-50%) rotate(90deg);
	}
}

.service_explain{
	display: flex;
	justify-content: space-between;

	& .service_explain_txt{
		width: 50%;

		& p+p{
			padding-top: 1.2em;
		}
	}

	& .service_explain_img{
		width: 47%;

		& img {
			width: 100%;
			aspect-ratio: 3 / 2;
			object-fit: cover;
		}
	}
}

/*-よくある質問-*/
.service_faq_ttl{
	font-size: 1.25vw;
	font-weight: 600;
	padding: 4.0% 0 1.5%;
}
.service_faq_item{
	position: relative;
}

/*-- アコーディオン --*/
.service_faq .toggle {
	display: none;
}
.service_faq .option {
	position: relative;
	margin-bottom: 2.0%;
}
.service_faq .option:last-of-type{
	margin-bottom: 0;
}
.service_faq .title,
.service_faq .content {
	backface-visibility: hidden;
	transform: translateZ(0);
	transition: all 0.3s;
}
.service_faq .title {
	border: solid 1px #aaaaaa;
	padding: 2.55%;
	padding-left: 2.5%;
	padding-right: 7%;
	display: block;
	cursor: pointer;
}
.service_faq .title::after,
.service_faq .title::before {
	content: "";
	position: absolute;
	right: 3.5%;
	top: calc(50% - 0.4em);
	width: 2px;
	height: 0.8em;
	background-color: #707070;
	transition: all 0.3s;
}
.service_faq .title::after {
	transform: rotate(90deg);
}
.service_faq .content {
	max-height: 0;
	overflow: hidden;
}
/*.service_faq .content p {
	margin: 0;
	padding: 1em 1.4em 1em;
}*/
.service_fag_content_p {
	margin: 0;
	padding: 1em 1.4em 1em;
}
.service_fag_content_ul {
	margin: 0;
	padding: 1em 1.4em 1em;
}
.service_fag_content_ul li {
	text-indent: -1.2em;
    padding-left: 1.2em;
	font-size: 0.95em;
}
.service_fag_content_p2 {
	margin: 0;
	padding: 1em 1.4em 0 1.4em;
}
.service_faq .content ul {
	margin: 0;
	padding: 0.5em 1.4em 1em;
}
.service_faq .toggle:checked + .title + .content {
	max-height: 500px;
	transition: all 1.0s;
}
.service_faq .toggle:checked + .title::before {
	transform: rotate(90deg) !important;
}
/*----- アコーディオンの設定ここまで ----*/


/*---------- 事務所概要 -----------*/
/*--- 代表挨拶 ---*/
.message_box{
	display: flex;
	justify-content: space-between;
}
.message_box_txt{
	width: 56%;

	& .message_box_ttl{
		font-size: 2vw;
		font-weight: 400;
		line-height: 1.4;
		padding-bottom: 1.2vw;
		color: #333333;
	}

	& .message_box_p+p{
		padding-top: 1.2em;
	}
}

.message_box_sign{
	text-align: right;
	font-size: 1.35vw;
	padding-top: 1.2vw;
	font-weight: 400;

	& span{
		font-size: 0.6em;
		display: inline-block;
		padding-right: 1.2em;
		font-weight: 400;
	}
}

.message_box_img{
	width: 38%;
}


/*----- 事務所概要 ------*/
.office_info dl{
	display: flex;
}
.office_info dt{
	font-weight: 600;
	color: #555555;
	width: 17.5%;
	padding: 2.97% 0;
	padding-left: 1.86%;
	border-bottom: 0.156vw solid var(--SubColor);
}
.office_info dd{
	width: 82.5%;
	padding: 2.97% 0;
	padding-left: 4.24%;
	border-bottom: 0.156vw solid #ccc;
}
.office_info dd span{
	font-size: 0.9em;
}
.office_info dl:first-child dt{
	font-weight: 600;
	padding-top: 1.5%;
	color: #555555;
}
.office_info dl:first-child dd{
	padding-top: 1.5%;
}
.office_info_imgarea{
	display: flex;
	justify-content: space-between;
	text-align: center;
	padding-top: 3.64vw;
}
.office_info_imgarea li{
	width: 31.25%;
}
.office_info_imgarea li p{
	padding-top: 0.8vw;
	font-size: 0.9vw;
}

/*----- アクセス ------*/
.access01{
	text-align: center;
}

.access_gmap iframe{
	display: block;
	width: 100%;
	height: 36vw;
	margin-top: 2.0%;;
}
.access_howto{
	display: flex;
	margin-top: 2.2%;
}
.access_howto .howto_ttl{
	font-size: 0.9vw;
	font-weight: 600;
	padding-bottom: 0.5vw;
	color: #555555;
}
.howto01,.howto02{
	width: 50%;
}
.howto02{
	border-left: 1px solid #cccccc;
	padding-left: 4.15%;
}
.access_howto ul li{
	font-size: 0.9vw;
	padding-bottom: 0.1vw;
	line-height: 1.6;
}



/*---------- 料金について -----------*/
.fee_section_introtxt{
	padding-bottom: 1.5vw;
	line-height: 1.5;
}
.fee_table{
	width: 100%;
}
.fee_table th,.fee_table td{
	border: 1px solid #cacaca;
	font-weight: 400;
	/*font-size: 1.3vw;*/
	vertical-align: middle;
	padding: 1.4vw;
}
.fee_table tr:first-of-type th{
	background-color: var(--SubColor);
	color: #fff;
	padding: 0.68vw;
}
.fee_table tr:nth-of-type(n+2) th{
	text-align: left;
	background-color: var(--TableBgColor);
}
.fee_table tr:nth-of-type(n+2) td{
	text-align: left;
	background-color: #fff;
}
.fee_table .zei_small{
	font-size: 0.8em;
}
.fee_table_ttl01{
	font-size: 1.2vw;
	font-weight: 500;
	padding-bottom: 1.2%;
}
.fee_table_ttl01:nth-of-type(n+2){
	padding-top: 3.2%;
}
.table_note_area{
	font-size: 0.95vw;
	margin-top: 1.2vw;
	line-height: 1.5;
}
.table_note_area li+li{
	padding-top: 0.26vw;
}
.table_note_area li,.table_note_area p{
	text-indent: -1.2em;
	padding-left: 1.5em;
}

/*テーブルの横幅*/
.fee_table3_7 tr th:first-of-type{width: 30%;}
.fee_table3_7 tr td:nth-of-type(2){width: 70%;}

.fee_table4_6 tr th:first-of-type{width: 40%;}
.fee_table4_6 tr td:nth-of-type(2){width: 60%;}

.fee_table5_5 tr th:first-of-type,.fee_table5_5 tr td:nth-of-type(2){width: 50%;}


/*---------- お問合せ -----------*/
.contact_info{
	text-align: center;
}
.contactpage_point{
	display: flex;
	justify-content: space-between;
	width: 78%;
	margin: 0 auto;
	padding: 3.8% 0;
}
.contactpage_point li{
	width: 31.5%;
	border: 1px solid #000;
	text-align: center;
	padding: 0.85vw;
}
.contactpage_point li span{
	font-size: 0.8em;
}
.contact_telbox{
	border: 0.26vw solid #ececec;
	padding: 2.4%;
	text-align: center;
}
.contact_tool_ttl{
	font-size: 1.8vw;
	font-weight: 500;
	text-align: center;
	line-height: 1.5;
}
.contact_telbox_tel a{
	color: #333333;
	text-decoration: none;
	font-size: 3.0vw;
	padding-left: 2.3vw;
	background: url(../images/icon_tel_black.svg) no-repeat;
	background-size: 1.8vw 1.8vw;
	background-position: left 0.45em;
}
.contact_telbox_uketsuke{
	font-size: 0.9vw;
}

/*---お問い合わせフォーム---*/

.form_info{
	text-align: center;
	padding-top: 2.5vw;
}


/*---form---*/
.contact_form{
	padding-top: 2.9vw;
}
.contact_form dl{
	display: flex;
	align-items: center;
	justify-content: space-between;
	border-bottom: 1px solid #d8d8d8;
	padding: 2.3% 1.7%;
}
.contact_form dl:first-of-type{
	padding-top: 0;
}
.contact_form dl:last-of-type{
	margin-bottom: 3.12vw;
}
.contact_form dt{
	width: 26%;
	font-weight: 600;
	display: flex;
	justify-content: space-between;
}
.contact_form dd{
	width: 70.5%;
}
.contact_form span.hissu,
.contact_form span.nini{
font-size: 0.7em;
	font-weight: 400;
	color: #fff;
	display: inline-block;
	background-color: var(--SubColor);
	padding: 0.2vw 1.0vw;
	letter-spacing: 0.2em;
	margin-left: 1.04vw;
}
.contact_form span.nini{
	background-color: #b7b7b7;
}
.checkbox label{
	display: inline-block;
}
.checkbox label:nth-of-type(n+2){
	padding-top: 0.26vw;
}
input,textarea{
	font-size:1.1vw;
}
#company,
#name,
#telefon,
#ad,
#Email,
#subject,
#details{
	width:100%;
	background-color: #fff;
	border: 1px solid #e6e6e6;
	padding: 0.8vw 0.7vw;
	}
#details{
	height: 12vw;
}
/*form placeholdeのfontcolor*/
input::placeholder,
textarea::placeholder{
	color: #a1a1a1;
	font-size:1vw;
}
/*submit*/
form_b{
	text-align: center;
}
.btn_effect01{
	background: none;
	background-color: var(--AccentColor);
	/*border: 1px solid var(--AccentColor);*/
	border:none;
	color: #fff;
	font-size: 1.4vw;
	letter-spacing: 0.08em;
	width: 33%;
	height: 3.5vw;
	border-radius: 1000px;
	cursor: pointer;
	display: block;
	margin: 0 auto;
	position: relative;
	overflow: hidden;
}
/*form input[type=submit] {
	background: none;
	background-color: var(--AccentColor);
	border: 1px solid var(--AccentColor);
	color: #fff;
	font-size: 1.4vw;
	letter-spacing: 0.08em;
	width: 33%;
	height: 3.5vw;
	border-radius: 1000px;
	cursor: pointer;
	display: block;
	margin: 0 auto;
}
form input[type=submit]:hover{
	text-decoration: none;
	background-color: #fff;
	color: var(--SubColor);
	border: 1px solid var(--SubColor);
}
form input[type=submit],
form input[type=submit]::before,
form input[type=submit]::after {
	transition: all .3s;
}
form input[type=submit]:hover {
	color: var(--SubColor);
	text-decoration: none;
}
*/

/*ラジオボタン*/
.radio-input{
	display: none;
}
.radio-input + label{
	padding-left: 23px;
	position:relative;
	margin-right: 40px;
}
.radio-input + label::before{
	content: "";
	display: block;
	position: absolute;
	top: 5px;
	left: 0;
	width: 15px;
	height: 15px;
	border: 1px solid #999;
	border-radius: 50%;
	background-color: #fff;
}
.radio-input:checked + label::after{
	content: "";
	display: block;
	position: absolute;
	top: 8px;
	left: 3px;
	width: 11px;
	height: 11px;
	background: var(--SubColor);
	border-radius: 50%;
}

/*チェックボックス*/

.checkbox-input{
	display: none;
}
.checkbox-parts{
	padding-left: 1.45vw;
	position:relative;
}
.checkbox-parts::before{
	content: "";
	display: block;
	position: absolute;
	top: 0.3vw;
	left: 0;
	width: 0.88vw;
	height: 0.88vw;
	border: 1px solid #999;
	border-radius: 2px;
	background-color: #fff;
}
.checkbox-input:checked + .checkbox-parts::after{
	content: "";
	display: block;
	position: absolute;
	/*top: -5px;
	left: 5px;
	width: 7px;
	height: 14px;*/
	top: 0vw;
	left: 0.26vw;
	width: 0.36vw;
	height: 0.729vw;
	transform: rotate(40deg);
	border-bottom: 3px solid var(--SubColor);
	border-right: 3px solid var(--SubColor);
}

/*個人情報保護方針チェック*/
.policy_box{
	text-align: center;
	margin-bottom: 2.8vw;
}
.policy_box a{
	color: #000;
}
.policy_box p{
	margin-top: 0.5vw;
	font-size: 0.9vw;
}


/*---------- 個人情報保護方針 -----------*/
.policy_info{
	text-align: center;
}
.policy_wrap dl{
	margin-top: 3.5vw;
}
.policy_wrap dt{
	font-size: 1.2vw;
	padding-bottom: 1.0vw;
	margin-bottom: 1.0vw;
	border-bottom: 1px solid #707070;
	font-weight: 500;
}
/*.policy_wrap ul{
	margin: 1vw 0;
}*/
.policy_wrap ul li{
	text-indent: -1.3em;
	padding-left: 1.5em;
}
.policy_info_wrap {
	padding-top: 1vw;
}
.policy_info_wrap p span {
	font-size: 0.9em;
}
.policy_info_ttl {
	/*font-size: 1.0vw;*/
	padding-top: 1vw;
    padding-bottom: 0.1vw;
    font-weight: 500;
}
.policy_info_ul {
	padding-top: 0.5vw;
    padding-bottom: 0vw;
}
.policy_info_ul li {
	text-indent: -1.2em;
    padding-left: 1.2em;
}




/*-------------------------------------------
レスポンシブ
--------------------------------------------*/

@media screen and (max-width: 768px){
	/*--------------------------
	 TOP
	----------------------------*/
	/*--mv--*/
	.mv{
		background-image: url(../images/mv_sp.jpg);
		height: 585px;
		background-position: center center;
		margin-top: clamp(43px, 13vw, 70px);
	}

	.mv_txt {
		bottom: 45%;
		left: 50%;
		transform: translateX(-50%);
		width: 93%;
	}
	
	.mv_txt h2{
		/*font-family: 'Noto Serif JP', serif;*/
		font-weight: 400;
		font-size: 22px;
		/*color: #fff;*/
		text-align: center;
		line-height: 1.5;
	}
	
	.mv_news{
		background-color: rgba(0,0,0,0.76);
		display: block;
		width: 100%;
	}
	
	.mv_news_inner{
		padding: 0.75em 1.5em;
	}

	.mv_news .mv_news_ttl{
		font-size: 12px;
		margin-right: 1.6em;
		padding-right: 1.6em;
	}
	
	.mv_news .mv_news_ttl::before{
		height: calc(100% + 3px);
		display: block;
		background: #fff;
		right: 0;
		top: 50%;
		transform: translateY(-50%);
	}
	.mv_news dl{
		flex-direction: column;
		align-items: flex-start;
		& dt{
			font-size: 11px;
			font-weight: 400;
			padding-right: 1.8em;
			margin-bottom: 1.5px;
		}
		& dd{
			font-size: 11px;
			line-height: 1.6;
		}
	}



	/* ----  top_sec01 ---- */

	.top_section_ttl_bg{
		text-align: center;
		padding: 5.5% 0;

		& h3{
			font-size: 20px;
			color: #fff;
			font-weight: 400;
		}

		& span{
			font-size: 46px;
			line-height: 1.3;
			color: rgba(255, 255, 255, 0.2);
			font-weight: 300;
			top: 47%;
			left: 50%;
			transform: translate(-50%,-50%);
		}
	}

	
	.section_inner{
		padding: 35px 0 45px;
	}


	.lower_page_ttl_bg{
		background-color: #var(--SubColor2);
		text-align: center;
		padding: 25px 0;
		margin-top: clamp(43px, 13vw, 70px);
	
		& h2{
			font-size: 20px;
			color: #fff;
			font-weight: 400;
		}
		& span{
			font-size: 46px;
			line-height: 1.3;
			color: rgba(255, 255, 255, 0.2);
			font-weight: 300;
			top: 47%;
			left: 50%;
			transform: translate(-50%,-50%);
		}
	}







	.top_sec01_box{
		flex-direction: column-reverse;
		justify-content: space-between;
	}

	.top_sec01_txtbox{
		width: 100%;

		& .top_sec01_ttl{
			font-family: 'Noto Serif JP', serif;
			font-size: 19px;
			line-height: 1.4;
			margin-top: 1em;
			margin-bottom: 1em;
		}

		& .top_sec01_txt p{
			margin-top: 0.8em;
		}

		& .sign {
			text-align: right;
			font-size: 15px;
			font-weight: 600;

			& span{
				font-size: 0.9em;
				padding-right: 1em;
			}
		}
	}

	.top_sec01_imgbox{
		width: 70%;
    	max-width: 400px;
		margin: 0 auto;
	}



	/* ---- トップ 業務内容 ---- */
	.top_service_box_ttl{
		font-size: 17.5px;
		font-weight: 600;
		padding-left: 0.75em;
		margin-bottom: 1.2em;
	}
	.top_service_box_ttl:nth-of-type(n+2){
		margin-top: 30px;
	}


	.top_service_box_ttl::before{
			content: '';
			width: 3.5px;
			height: 1.8em;
			background-color: #333;
			display: block;
			position: absolute;
			left: 0;
			top: 50%;
			transform: translateY(-50%);
	}

	.top_service_box01 ul{
		display: flex;
		flex-direction: column;
		justify-content: space-between;
		flex-wrap: wrap;
		row-gap: 30px;

		& li{
			width: 100%;
			text-align: center;

			& a{
				text-decoration: none;
				color: #333;
				font-size: 16px;
				font-weight: 500;

				& div{
					margin-bottom: 0.8em;

					& img{
						aspect-ratio: 16 / 9;
						object-fit: cover;
						object-position: center center;
					}
				}
			}
		}
	}



	/* ---- トップ アクセス ---- */
	.top_access_box{
		flex-direction: column;
		justify-content: space-between;

		& >div{
			width: 100%;
		}
	}

	.top_access_box01 dl{
		& dt{
			font-size: 16px;
			font-weight: 600;
			padding-left: 0.75em;
			margin-bottom: 0.4em;
			position: relative;
		}

		& dt::before{
			content: '';
			width: 3.5px;
			height: 1.5em;
			background-color: #333;
			display: block;
			position: absolute;
			left: 0;
			top: 1px;
		}
		& dd+dt{
			margin-top: 1.2em;
		}
	}

	.top_access_box02 dl{

		& dt{
			font-size: 15px;
			font-weight: 600;
			display: flex;
			align-items: center;
		}

		& dt::before{
			content: '';
			display: block;
			margin-right: 0.35em;
			width: 10px;
			height: 11px;
			background-color: #333;
			clip-path: polygon(10px 50%, 0% 0%, 0% 11px);
		}

		& dt{
			margin-top: 1.7em;
		}
		& dd+dt{
			margin-top: 1.35em;
		}
	}

	.top_gmap{
		width: 100%;
		padding-top: 25px;

		& iframe{
			width: 100%;
			height: 300px;
		}
	}


	/* ---- トップ お知らせ ---- */
	.top_news_box dl{
		flex-wrap: wrap;
		align-items: flex-start;
		color: #707070;
		border-bottom: 1px solid #ccc;
		padding: 6% 1.5%;

		& dt{
			width: 6em;
			color: #999;
			font-size: 14px;
		}

		& .category{
			width: 6.5em;
			color: #fff;
			font-size: 0.7em;
			background-color: var(--AccentColor);
			line-height: 2.0;
			text-align: center;

		}

		& .text{
			width: 100%;
			padding-left: 0;
			padding-top: 5px;
		}
	}


	/*-------------------------------------------
	下層ページ
	--------------------------------------------*/
	.pankuzu{
		font-size: 10px;
		padding-top: 1.2em;
		/* color: #999999; */
	
		/* & a{
			color: #999999;
			text-decoration: none;
		} */
	}
	
	.lower_section_ttl {
		& h3{
			font-size: 22.5px;
			line-height: 1.3;
			font-weight: 500;
			text-align: center;
			position: relative;
			padding-bottom: 3.5%;
			margin-bottom: 6%;
		}
	
		& h3::before{
			content: "";
			height: 2px;
			width: 40px;
			background-color: var(--AccentColor);
		}
	}


	/*---------- 業務内容（個人・法人） -----------*/
	/*-- ページ上部アンカーリンク --*/
	.service_link_box{
		flex-direction: column;
		gap: 10px;

		& li{
			width: 100%;
		}
	
		& a{
			font-size: 15px;
			padding: 1em;
			position: relative;
		}
	
		& a::before{
			font-family: "Font Awesome 5 Free";
			content: "\f054 ";
			color: #555555;
			font-weight: 900;
			font-size: 0.8em;
			position: absolute;
			right: 1.3em;
			top: 50%;
			transform: translateY(-50%) rotate(90deg);
		}

	}

	.service_explain{
		display: flex;
		/*justify-content: space-between;*/
		flex-direction: column-reverse;
	
		& .service_explain_txt{
			width: 100%;

			& p+p{
				padding-top: 1.2em;
			}
		}
		
		& .service_explain_img{
			width: 100%;
			padding-bottom: 5%;
		}
	}

	/*-よくある質問-*/
	.service_faq_ttl{
		font-size: 17px;
		font-weight: 600;
		padding: 6.0% 0 2.5%;
	}

	.service_faq_item::before{
		width: 0.7em;
		height: auto;
		position: absolute;
		left: 1.4em;
		top: 0.7em;
		/*transform: rotate(-90deg);*/
	}

	/*アコーディオン*/
	.service_faq .option {
		position: relative;
		margin-bottom: 3.0%;
	}
	.service_faq .option:last-of-type{
		margin-bottom: 0;
	}

	.service_faq .title {
		/*border: solid 1px #aaaaaa;*/
		padding: 0.8em 2.2em 0.8em 0.8em;
		/*display: block;
		cursor: pointer;*/
	}
	.service_faq .title::after,
	.service_faq .title::before {
		/*content: "";
		position: absolute;*/
		right: 1.25em;
		top: calc(50% - 0.4em);
		/*width: 2px;
		height: 0.8em;
		background-color: #707070;
		transition: all 0.3s;*/
	}
	/*.service_faq .title::after {
		transform: rotate(90deg);
	}
	.service_faq .content {
		max-height: 0;
		overflow: hidden;
	}*/
	.service_fag_content_p {
		margin: 0;
		padding: 0.8em 0.8em 0.8em;
	}
	.service_fag_content_p2 {
		margin: 0;
		padding: 0.8em 0.8em 0 0.8em;
	}
	.service_faq .content ul {
		margin: 0;
		padding: 0.4em 0.8em 1em;
	}
	.service_faq .content ul li {
		text-indent: -1.1em;
		padding-left: 1.1em;
	}
	.service_faq .toggle:checked + .title + .content {
		max-height: 500px;
		/*transition: all 1.0s;*/
	}
	/*.service_faq .toggle:checked + .title::before {
		transform: rotate(90deg) !important;
	}*/
	/*--------アコーディオンの設定ここまで------*/


	/*---------- 事務所概要 -----------*/
	/*----- 代表挨拶 ------*/
	.message_box{
		flex-direction: column-reverse;
		align-items: center;
	}
	.message_box_txt{
		width: 100%;
		display: flex;
		flex-direction: column;

		& .message_box_ttl{
			font-size: 23px;
			font-weight: 500;
			line-height: 1.35;
			padding-bottom: 3%;
		}

		& .message_box_p+p{
			padding-top: 1.2em;
		}
	}

	.message_box_sign{
		order: -1;
		text-align: center;
		font-size: 18px;
		padding-top: 3%;
		padding-bottom: 5%;
	}
	.message_box_sign span {
		font-size: 0.65em;
		padding-right: 1.2em;
	}

	.message_box_img{
		width: 70%;
		max-width: 400px;
	}
	

	/*----- 事務所概要 ------*/
	.office_info > dl{
		flex-direction: column;
		padding: 3.8% 2%;
		border-bottom: 1px solid #ccc;
	}
	.office_info dt{
		font-weight: 600;
		color: #555555;
		font-size: 15px;
		width: 100%;
		padding: 0 ;
		font-weight: 600;
		border: none;
	}
	.office_info dl dd{
		width: 100%;
		padding: 1.5% 0 0;
		border: none;
	}

	.office_info dl:first-child dt{
		font-weight: 600;
		padding-top: 1.5%;
		color: #555555;
	}

	.office_info_imgarea{
		flex-direction: column;
		padding-top: 6%;
	}
	.office_info_imgarea li{
		width: 100%;
	}
	.office_info_imgarea li p{
		padding-top: 2%;
		padding-bottom: 5%;
		font-size: 14px;
	}
	.office_info_imgarea li:last-of-type p{
		padding-bottom: 0;
	}

/*----- アクセス ------*/
/*.access01{
	text-align: center;
}*/
	.access01{
		padding-bottom: 2.5%;
	}

	.access_gmap iframe{
		height: 36vw;
		min-height: 300px;
		margin-top: 2.0%;;
	}
	.access_howto{
		flex-direction: column;
		margin-top: 4%;
	}
	.access_howto .howto_ttl{
		font-size: 15px;
		font-weight: 600;
		padding-bottom: 1%;
		/*color: #555555;*/
	}
	.howto02{
		border: none;
		border-top: 1px solid #cccccc;
		padding-top: 3%;
		margin-top: 3%;
	}
		.howto01,.howto02{
		width: 100%;
		padding-left: 2%;
		padding-right: 2%;
	}
	.access_howto ul li{
		font-size: 14px;
		padding-bottom: 3px;
		line-height: 1.6;
	}



	/*---------- 料金について -----------*/
	.fee_section_introtxt{
		padding-bottom: 3%;
		line-height: 1.5;
	}
	.fee_table_outer_s{
		width: 100%;
		margin: 0 auto;
		overflow-x: scroll;
	}
	.fee_table_outer_s .fee_table{
		width: 100%;
		min-width: 500px;
	}
	.fee_table th,.fee_table td{
		/*border: 1px solid #cacaca;
		font-weight: normal;
		vertical-align: middle;*/
		padding: 4%;
	}
	.fee_table tr:first-of-type th{
		/*background-color: var(--SubColor);
		color: #fff;*/
		padding: 1.3%;
	}
	.fee_table tr:nth-of-type(n+2) th{
		/*text-align: left;
		background-color: var(--TableBgColor);*/
	}
	.fee_table tr:nth-of-type(n+2) td{
		/*text-align: right;
		background-color: #fff;*/
	}
	.fee_table .zei_small{
		font-size: 0.8em;
	}
	.fee_table_ttl01{
		font-size: 16px;
		font-weight: 600;
		padding-bottom: 2%;
		padding-top: 1%;
		line-height: 1.3;
	}
	.fee_table_ttl01:nth-of-type(n+2){
		padding-top: 5%;
	}
	.table_note_area{
		font-size: 13px;
		margin-top: 2.5%;
		/*line-height: 1.5;*/
	}
	.table_note_area li+li{
	padding-top: 0.7%;
	}
	.table_note_area li{
		text-indent: -1.3em;
		padding-left: 1.5em;
	}

	/*テーブルの横幅*/
	.fee_table3_7 tr th:first-of-type{width: 40%;}
	.fee_table3_7 tr td:nth-of-type(2){width: 70%;}

	.fee_table4_6 tr th:first-of-type{width: 40%;}
	.fee_table4_6 tr td:nth-of-type(2){width: 60%;}

	.fee_table5_5 tr th:first-of-type,.fee_table5_5 tr td:nth-of-type(2){width: 50%;}



	/*---------- お問合せ -----------*/
	.contact_info{
		text-align: left;
	}
	.contactpage_point{
		width: 100%;
		margin: 0 auto;
		padding: 4% 0 4%;
	}
	.contactpage_point li{
		font-size: 13px;
		font-weight: 500;
		width: 31.5%;
		padding: 2% 0;
		line-height: 1.35;
	}
	.contactpage_point li span{
		font-size: 0.8em;
	}
	.contact_telbox{
		border: 5px solid #ececec;
		padding: 5%;
		/*text-align: center;*/
	}
	.contact_tool_ttl{
		font-size: 20px;
		font-weight: 600;
		line-height: 1.5;
		padding-bottom: 1%;
	}
	.contact_telbox_tel{
		padding: 2% 0;
		line-height: 1;
	}
	.contact_telbox_tel a{
		line-height: 1;
		font-size: 30px;
		padding-left: 1em;
		background-size: 0.75em auto;
		background-position: left 3.3vw;
	}
	.contact_telbox_uketsuke{
		font-size: 12px;
	}
	/*---お問い合わせフォーム---*/
	.form_wrap{
		padding-top: 0%;
	}
	.form_info{
		text-align: left;
		padding-top: 2.5vw;
	}

	/*---form---*/
	.contact_form{
		padding-top: 6%;
	}
	.contact_form dl{
		align-items: flex-start;
		flex-direction: column;
		border:none;
		padding: 5.5% 0 0;
	}
	/*.contact_form dl:first-of-type{
		padding-top: 0;
	}*/
	.contact_form dl:last-of-type{
		margin-bottom: 5.5%;
	}
	.contact_form dt{
		width: 100%;
		font-weight: 600;
		margin-bottom: 1%;
		/*display: flex;
		justify-content: space-between;*/
	}
	.contact_form dd{
		width: 100%;
		padding-top: 1.5%;
	}
	.contact_form span.hissu,
	.contact_form span.nini{
		font-size: 0.6em;
		font-weight: 500;
		/*color: #fff;
		display: inline-block;
		background-color: var(--SubColor);*/
		padding: 1% 2% 0.2%;
		letter-spacing: normal;
		margin-bottom: 0.5%;
		margin-left: 2%;
		margin-right: 1px;
	}
	.contact_form span.nini{
		/*background-color: #b7b7b7;*/
	}
	.checkbox label{
		display: inline-block;
	}
	.checkbox label:nth-of-type(n+2){
		padding-top: 1%;
	}
	input,textarea{
		font-size:16px;
	}
	#company,
	#name,
	#telefon,
	#ad,
	#Email,
	#remarks,
	#subject,
	#details{
		/*width:100%;
		background-color: #f3f3f3;*/
		border: none;
		border:1px solid #ccc;
		padding: 3%;
		}
	#details {
		min-height: 150px;
	}
	/*form placeholdeのfontcolor*/
	input::placeholder,
	textarea::placeholder{
		color: #a1a1a1;
		font-size: inherit;
	}
	/*submit*/
	form_b{
		text-align: center;
		pointer-events: none;
	}
	.btn_effect01{
		appearance: none;
		-webkit-appearance: none;
		/*background: none;
		background-color: var(--SubColor);
		border: 1px solid var(--SubColor);
		color: #fff;*/
		font-size: 18px;
		font-weight: 600;
		letter-spacing: 0.08em;
		width: 90%;
		height: 56px;
		border-radius: 1000px;
		cursor: pointer;
		display: block;
		margin: 0 auto;
	}
	/*form input[type=submit] {
		appearance: none;
		-webkit-appearance: none;
		background: none;
		background-color: var(--SubColor);
		border: 1px solid var(--SubColor);
		color: #fff;
		font-size: 1.8rem;
		font-weight: 600;
		letter-spacing: 0.08em;
		width: 90%;
		height: 56px;
		border-radius: 1000px;
		cursor: pointer;
		display: block;
		margin: 0 auto;
	}*/
	/*form input[type=submit]:hover{
		text-decoration: none;
		background-color: #fff;
		color: var(--SubColor);
		border: 1px solid var(--SubColor);
	}
	form input[type=submit],
	form input[type=submit]::before,
	form input[type=submit]::after {
		transition: all .3s;
	}
	form input[type=submit]:hover {
		color: var(--SubColor);
		text-decoration: none;
	}*/

	/*ラジオボタン*/
	.radio-input{
		display: none;
	}
	.radio-input + label{
		padding-left: 23px;
		position:relative;
		margin-right: 40px;
	}
	.radio-input + label::before{
		content: "";
		display: block;
		position: absolute;
		top: 5px;
		left: 0;
		width: 15px;
		height: 15px;
		border: 1px solid #999;
		border-radius: 50%;
		background-color: #fff;
	}
	.radio-input:checked + label::after{
		content: "";
		display: block;
		position: absolute;
		top: 8px;
		left: 3px;
		width: 11px;
		height: 11px;
		background: var(--SubColor);
		border-radius: 50%;
	}

	/*チェックボックス*/
	.checkbox{
	line-height: 0.9;
	}
	/*.checkbox-input{
		display: none;
	}*/
	.checkbox-parts{
		padding-left: 1.3em;
		/*position:relative;*/
		display: inline-block;
		padding-top: 1px;
		padding-bottom:8px;
	}
	.checkbox-parts::before{
		/*content: "";
		display: block;
		position: absolute;*/
		/*top:2px;*/
		left: 0;
		width: 0.9em;
		height: 0.9em;
		border: 1px solid #777;
		/*border-radius: 2px;
		background-color: #fff;*/
	}
	.checkbox-input:checked + .checkbox-parts::after{
		/*content: "";
		display: block;
		position: absolute;*/
		top: -0.2em;
		left: 0.2em;
		width: 0.4em;
		height: 0.8em;
		transform: rotate(40deg);
		border-bottom: 3px solid var(--SubColor);
		border-right: 3px solid var(--SubColor);
	}

	/*個人情報保護方針チェック*/
	.policy_box{
		text-align: left;
		margin-bottom: 5%;
	}
	.policy_box label{
		line-height: 0.9;
	}
	.policy_box .checkbox-parts{
		display: flex;
		/*justify-content: center;*/
	}
	.policy_box a{
		color: #000;
	}
	.policy_box p{
		padding-left: 7%;
		margin-top: 0.5vw;
		margin-bottom: 6vw;
		font-size: 12px;
	}
	.policy_box span.hissu{
		padding: 1.5% 2% 2%;
		margin-top: -2px;
	}



	/*---------- 個人情報保護方針 -----------*/
	.policy_wrap{
		padding-top: 1%;
	}
	.policy_info{
		text-align: left;
	}
	.policy_wrap dl{
		margin-top: 8%;
	}
	.policy_wrap dt{
		font-size: 15px;
		padding-bottom: 1.5vw;
		margin-bottom: 1.5vw;
		border-bottom: 1px solid #707070;
		font-weight: 600;
	}
	.policy_wrap ul{
		margin: 1vw 0;
	}
	.policy_wrap ul li{
	text-indent: -1.3em;
	padding-left: 1.5em;
	}
	.policy_info_ttl {
		font-size: 15px;
        font-weight: 600;
		padding-top: 3vw;
		padding-bottom: 0.75vw;
	}
	.policy_info_wrap {
		padding-top: 3vw;
	}

}

@media screen and (min-width: 768px) {

    /* --- 1. ヘッダー本体の制御 --- */
    #header {
        position: fixed;
        top: 0;
        left: 0;
        width: 300px; /* メニューの幅（適宜調整） */
        height: 100vh;
        background: #fff; /* 背景色 */
        z-index: 1000;
        
        /* ▼▼ 重要：デフォルトで左に隠す ▼▼ */
        transform: translateX(-100%);
        transition: transform 0.4s cubic-bezier(0.25, 1, 0.5, 1);
        box-shadow: 2px 0 10px rgba(0,0,0,0.1);
        
        /* スクロール可能にする設定 */
        overflow-y: auto; 
    }

    /* クラスがついたら表示する */
    #header.is-open {
        transform: translateX(0);
    }

    /* ヘッダーの中身（ボタンと被らないように余白） */
    .header_inner_scroll {
        padding-top: 60px; /* ボタンの高さ分空ける */
    }


    /* --- 2. PC用ハンバーガーボタン --- */
    .pc_hamburger {
        position: fixed;
        top: 20px;
        left: 20px;
        z-index: 1100; 
        width: 60px;
        height: 60px;
        background: #1f4fbf; /* ボタンの色 */
        border-radius: 8px;
        cursor: pointer;
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        box-shadow: 0 4px 10px rgba(0,0,0,0.15);
        transition: 0.3s;
    }

    .pc_hamburger span {
        display: block;
        width: 30px;
        height: 2px;
        background: #fff;
        margin-bottom: 6px;
        transition: 0.3s;
    }
    .pc_hamburger span:nth-child(3) {
        margin-bottom: 0;
    }
    
    .pc_hamburger .menu_txt {
        font-size: 10px;
        color: #fff;
        margin-top: 4px;
        font-weight: bold;
        letter-spacing: 0.05em;
    }

    /* 開いた時のボタンの変化（位置を移動させたい場合はleftを変更） */
    #header.is-open .pc_hamburger {
        background: transparent;
        box-shadow: none;
    }
    /* ×印にするアニメーション */
    #header.is-open .pc_hamburger span {
        background: #333; /* 開いた後は黒色などで見やすく */
    }
    #header.is-open .pc_hamburger span:nth-child(1) {
        transform: translateY(8px) rotate(45deg);
    }
    #header.is-open .pc_hamburger span:nth-child(2) {
        opacity: 0;
    }
    #header.is-open .pc_hamburger span:nth-child(3) {
        transform: translateY(-8px) rotate(-45deg);
    }
    #header.is-open .pc_hamburger .menu_txt {
        display: none; /* 開いている時は文字を消す */
    }


    /* --- 3. 背景マスク --- */
    .drawer_overlay {
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: rgba(0, 0, 0, 0.6);
        z-index: 900; /* ヘッダーの下、コンテンツの上 */
        opacity: 0;
        visibility: hidden;
        transition: 0.3s;
    }
    /* クラスがついたら表示 */
    .drawer_overlay.is-active {
        opacity: 1;
        visibility: visible;
    }
    
    /* コンテンツエリア（メイン）が左メニュー分空いている場合の打ち消し */
    main {
        margin-left: 0 !important;
        width: 100% !important;
    }
}

/* --- サイドメニューとボタンの背景を濃紺(#171c61)にする設定 --- */

@media screen and (min-width: 768px) {
    /* ▼ 追加：ハンバーガーボタンの背景色 ▼ */
    .pc_hamburger {
        background-color: #171c61 !important; /* ボタンの色をご指定の色に変更 */
    }

    /* メニュー本体の背景色（既存の設定） */
    #header {
        background-color: #171c61 !important;
    }

    /* 文字色を白で統一（既存の設定） */
    #header,
    #header p,
    #header h1,
    #header h1 a,
    #header span,
    #header li,
    #header a,
    #header .nav_ttl {
        color: #ffffff !important;
    }
    
    /* 枠線などがある場合に薄くする調整（既存の設定） */
    .nav_menu ul li {
        border-bottom: 1px solid rgba(255, 255, 255, 0.2) !important;
    }

    /* メニューを開いた時の「×ボタン」も白にする（既存の設定） */
    #header.is-open .pc_hamburger span {
        background-color: #ffffff !important;
    }
}

/* --- フッターの背景色を画面幅いっぱいに広げる設定 --- */

footer {
    width: 100% !important;          /* 横幅いっぱいにする */
    background-color: #000000 !important; /* 背景色を黒にする */
    margin: 0 !important;            /* 余計な余白を消す */
    padding-top: 20px;               /* 上下の適度な余白（お好みで調整） */
    padding-bottom: 20px;
    color: #ffffff !important;       /* 文字色を白にする */
}

/* もし内側の箱に背景色が残っていたら透明にする */
footer .wrap_r,
footer .footer_inner {
    background-color: transparent !important;
}

/* コピーライトの文字調整 */
footer .copyright {
    text-align: center;              /* 中央寄せ */
    color: #ffffff !important;       /* 文字色を白に */
    margin: 0;
}

/* ====================================
   トップページ MVのリッチ化設定
   ==================================== */

/* --- MV全体のエリア設定 --- */
.mv {
    position: relative;
    width: 100%;
    height: 85vh; /* 画面の高さの85% */
    min-height: 600px;
    overflow: hidden;
    background-color: #000; /* 画像が出るまでの背景色 */
}

/* --- スライダーコンテナ --- */
.mv_slider {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
}

/* --- 各画像のラッパー（配置用） --- */
.mv_img_wrap {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0; /* 最初は隠す */
    animation: sliderAnime 18s linear infinite; /* 18秒ループ */
}

/* 画像本体の設定（オブジェクトフィットでトリミング） */
.mv_img_wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover; /* 画面いっぱいに広げる */
    object-position: center;
}

/* --- アニメーションのタイミング調整 --- */
/* 1枚目 */
.mv_img_wrap:nth-child(1) {
    animation-delay: 0s;
}
/* 2枚目 */
.mv_img_wrap:nth-child(2) {
    animation-delay: 6s;
}
/* 3枚目 */
.mv_img_wrap:nth-child(3) {
    animation-delay: 12s;
}

/* --- スライドショーの動き（クロスフェード＆ズーム） --- */
@keyframes sliderAnime {
    0% {
        opacity: 0;
        transform: scale(1); /* 等倍 */
    }
    4% { /* ふわっと現れる */
        opacity: 1;
    }
    33.33% { /* 次の画像が出るまで表示し続ける */
        opacity: 1;
    }
    37.33% { /* 次の画像と重なりながら消える */
        opacity: 0;
    }
    100% {
        opacity: 0;
        transform: scale(1.1); /* ゆっくり1.1倍まで拡大 */
    }
}


/* --- キャッチコピーのリッチ化 --- */
.mv_txt {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 5;
    width: 100%;
    text-align: center;
}

.mv_txt h2 {
    /* フォントを明朝体に（Windows/Mac両対応） */
    font-family: "Yu Mincho", "YuMincho", "Hiragino Mincho ProN", "HGSMinchoE", serif;
    color: #ffffff;
    font-size: 3.6rem; /* 大きく */
    font-weight: 500;
    line-height: 1.8;
    letter-spacing: 0.15em; /* 文字間隔を広げて高級感 */
    text-shadow: 0 5px 20px rgba(0,0,0,0.8); /* 濃い影を落として読みやすく */
    
    /* ぼかしながら現れるアニメーション */
    opacity: 0;
    filter: blur(10px); /* 最初はぼかす */
    animation: blurFadeIn 2.5s ease forwards 0.5s;
}

/* 文字出現アニメーション定義 */
@keyframes blurFadeIn {
    0% {
        opacity: 0;
        filter: blur(15px);
        transform: translateY(10px) scale(0.95);
    }
    100% {
        opacity: 1;
        filter: blur(0);
        transform: translateY(0) scale(1);
    }
}


/* --- ニュースエリア（一番下に配置） --- */
.mv_news {
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 10;
    width: 100%;
    background: rgba(255, 255, 255, 0.95);
    border-top: 1px solid rgba(0,0,0,0.1);
}

/* ====================================
   スマホ表示（幅768px以下）の時の調整
   ==================================== */
@media screen and (max-width: 768px) {
    
    /* 1. PC用のスライダー・キャッチコピー・ロゴエリアを消す */
    .mv_slider,
    .mv_txt,
    .mv_sp_logo { 
        display: none !important;
    }

    /* 2. スマホ用：指定の画像(mv_sp.jpg)を背景に設定 */
    .mv {
        display: block !important;
        width: 100%;
        height: 85vh !important;          /* 画面の高さの85%（お好みで100vhでもOK） */
        min-height: 500px !important;     /* 画像が見切れないよう最低高さを確保 */
        
        /* ▼▼▼ ここで画像を指定 ▼▼▼ */
        background-image: url('../images/mv_sp.jpg') !important;
        background-repeat: no-repeat !important;
        background-position: center center !important;
        background-size: cover !important; /* 画面いっぱいに広げる */
        
        background-color: transparent !important;
        padding-top: 60px; /* ヘッダー被り防止 */
    }

    /* 3. NEWSを画像の下部に配置 */
    .mv_news {
        position: absolute !important;
        bottom: 0 !important;
        left: 0 !important;
        width: 100% !important;
        background: rgba(255, 255, 255, 0.9) !important; /* 白背景で少し透かす */
        margin-top: 0;
        z-index: 10;
    }
}